/*
Theme Name: Sesang Editable
Theme URI: https://example.com/sesang
Author: Sesang Project
Description: Sesang公式サイトの編集可能モックアップテーマ
Version: 1.0.0
Text Domain: sesang-editable
*/

@import url("https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@500;700;900&display=swap");

:root{
  --yellow:#fce303;
  --red:#eb5050;
  --green:#5ed686;
  --blue:#0b78ff;
  --cyan:#28c7d8;
  --pink:#f24fbd;
  --black:#111;
  --white:#fff;
  --pale:#f6f6f6;
  --display:'Zen Kaku Gothic New','Noto Sans JP',sans-serif;
  --body:'Zen Kaku Gothic New','Noto Sans JP','Hiragino Kaku Gothic ProN','Yu Gothic',sans-serif;
}

/* Apply page: LIVER INTERVIEW */
.section--interview{
  background:#e8fbef;
  color:var(--black);
}

.section--interview .section-kicker{
  color:var(--red);
}

.section--interview .outline{
  color:var(--white);
  -webkit-text-stroke:3px var(--black);
  paint-order:stroke fill;
}

.section--interview .page-lead{
  color:var(--black);
}

.section--interview .interview-grid{
  display:grid;
  grid-auto-flow:column;
  grid-template-rows:repeat(2, minmax(0, auto));
  grid-auto-columns:minmax(260px, calc((100% - 18px) / 2));
  gap:18px;
  overflow-x:auto;
  overflow-y:hidden;
  padding:4px 4px 18px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}

.section--interview .interview-grid::-webkit-scrollbar{
  height:10px;
}

.section--interview .interview-grid::-webkit-scrollbar-track{
  background:var(--white);
  border:2px solid var(--black);
}

.section--interview .interview-grid::-webkit-scrollbar-thumb{
  background:var(--green);
  border:2px solid var(--black);
}

.section--interview .interview-card{
  min-width:0;
  scroll-snap-align:start;
}

@media (max-width:640px){
  .section--interview .interview-grid{
    grid-auto-columns:minmax(238px, calc((100vw - 76px) / 2));
    gap:14px;
  }

  .section--interview .outline{
    -webkit-text-stroke:2.2px var(--black);
  }
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--white);color:var(--black);font-family:var(--body);font-weight:700;overflow-x:hidden}
*,*::before,*::after{box-shadow:none!important;text-shadow:none!important}
.top-header,.menu-toggle,.header-nav,.header-nav a,.page-label,.page-label::before,.section,.card,.form-box,.table-box,.table,.table th,.table td,.faq-item,input,textarea,select,.pop-button,.site-footer,.sns-icon,.sns-icon--instagram::before,.symbol.coin,.symbol.coin::before{border-width:3px!important}
h1,.outline,.footer-sns-label{-webkit-text-stroke-width:4.6px!important}
a{color:inherit;text-decoration:none}
.top-header{min-height:96px;padding:16px clamp(14px,3vw,42px);display:flex;align-items:center;justify-content:space-between;border-bottom:7px solid var(--black);background:var(--white);position:sticky;top:0;z-index:100}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:58px;aspect-ratio:1;position:relative;clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0 50%);background:var(--black);display:grid;place-items:center;flex:0 0 auto}
.brand-mark::before,.brand-mark::after{content:"";position:absolute;clip-path:inherit}
.brand-mark::before{inset:8px;background:var(--yellow)}
.brand-mark::after{inset:18px;background:var(--red)}
.brand-name{font-family:var(--display);font-weight:900;font-size:clamp(34px,5.2vw,56px);font-style:italic;letter-spacing:.01em}
.menu-toggle{width:46px;height:34px;display:grid;place-items:center;border:0;background:transparent;box-shadow:none;cursor:pointer;padding:0}
.menu-toggle span,.menu-toggle::before,.menu-toggle::after{content:"";display:block;width:36px;height:5px;background:var(--black)}
.menu-toggle span{margin:7px 0}
.header-nav{position:absolute;right:clamp(20px,5vw,72px);top:calc(100% + 14px);width:min(380px,calc(100vw - 36px));padding:18px;background:var(--white);border:5px solid var(--black);box-shadow:8px 8px 0 var(--black);display:none;grid-template-columns:1fr;gap:10px}
.header-nav.is-open{display:grid}
.header-nav a{display:block;padding:12px 14px;background:var(--white);border:3px solid var(--black);font-weight:900}
.header-nav a:hover,.header-nav a.is-current{background:var(--yellow)}
.page-hero{position:relative;min-height:360px;padding:92px clamp(22px,7vw,96px);border-bottom:7px solid var(--black);overflow:hidden;background:var(--white)}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.12;background-image:radial-gradient(var(--black) 3px,transparent 3.5px);background-size:34px 34px}
.page-hero__inner{position:relative;z-index:1;max-width:1120px;margin:0 auto}
.page-label{display:inline-flex;align-items:center;gap:10px;min-height:44px;padding:8px 28px;margin-bottom:26px;background:var(--black);color:var(--yellow);clip-path:polygon(8% 0,94% 0,100% 50%,94% 100%,8% 100%,0 50%);font-family:var(--display);font-weight:900;letter-spacing:.12em}
.page-label::before{content:"P";display:grid;place-items:center;width:25px;aspect-ratio:1;border:3px solid var(--yellow);border-radius:50%;background:var(--white);color:var(--black);font-size:14px;box-shadow:2px 2px 0 var(--red)}
h1{margin:0;font-family:var(--display);font-weight:900;font-size:clamp(42px,8vw,92px);line-height:1.16;color:var(--white);-webkit-text-stroke:4px var(--black);paint-order:stroke fill;text-shadow:7px 7px 0 var(--red)}
.page-lead{max-width:760px;margin:28px 0 0;font-size:clamp(16px,2vw,22px);line-height:2;font-weight:900}
.symbol-cloud{position:absolute;left:-64px;top:0;width:min(560px,68vw);height:250px;pointer-events:none;opacity:.98;--symbol-main:var(--cyan);--symbol-sub:var(--red);--symbol-third:var(--cyan)}
.page-hero:nth-of-type(1) .symbol-cloud{--symbol-main:var(--cyan);--symbol-sub:var(--red);--symbol-third:var(--cyan)}
.symbol{position:absolute;display:block}
.symbol.circle{width:48px;aspect-ratio:1;border-radius:50%;background:var(--symbol-main);left:16%;top:22%}
.symbol.donut{width:154px;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,transparent 0 33%,var(--symbol-main) 34%);left:-48px;top:88px}
.symbol.square{width:48px;aspect-ratio:1;background:var(--symbol-sub);left:38%;top:46px;transform:rotate(0)}
.symbol.triangle{width:0;height:0;border-top:72px solid var(--symbol-third);border-left:72px solid transparent;left:58%;top:0;transform:rotate(0)}
.symbol.coin{width:150px;height:126px;border:0;border-radius:0;background:linear-gradient(var(--symbol-sub) 0 0) 0 0/48px 48px no-repeat,linear-gradient(var(--symbol-main) 0 0) 48px 48px/48px 48px no-repeat,linear-gradient(var(--symbol-sub) 0 0) 96px 0/48px 48px no-repeat;box-shadow:none;left:24%;top:76px;display:block}
.symbol.coin::before{content:"";display:none}
.page-hero::after{content:"";position:absolute;right:-32px;top:0;width:220px;height:170px;pointer-events:none;background:linear-gradient(var(--yellow) 0 0) right top/96px 96px no-repeat,linear-gradient(var(--pink) 0 0) right 108px/160px 48px no-repeat,linear-gradient(var(--yellow) 0 0) right 156px/160px 48px no-repeat;opacity:.98}
.section{position:relative;padding:80px clamp(20px,6vw,84px);border-bottom:7px solid var(--black);overflow:hidden}
.section--black{background:var(--black);color:var(--white)}
.section--white{background:var(--white);color:var(--black)}
.inner{max-width:1120px;margin:0 auto;position:relative;z-index:1}
.section-kicker{font-family:var(--display);font-weight:900;color:var(--red);letter-spacing:.14em;margin:0 0 10px}
h2{margin:0 0 30px;font-family:var(--display);font-weight:900;font-size:clamp(32px,5vw,64px);line-height:1.25}
.outline{color:var(--white);-webkit-text-stroke:3.2px var(--black);paint-order:stroke fill;text-shadow:5px 5px 0 var(--red)}
.section--black .outline{color:var(--yellow);text-shadow:5px 5px 0 var(--red)}
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.card,.form-box,.table-box{background:var(--white);color:var(--black);border:5px solid var(--black);box-shadow:8px 8px 0 var(--black);padding:24px}
.card:nth-child(even),.card:nth-child(odd){transform:none}
.card h3{margin:0 0 12px;font-family:var(--display);font-size:24px}
.card p{margin:0;line-height:1.8}
.liver-photo{width:100%;aspect-ratio:4/5;object-fit:cover;border:5px solid var(--black);box-shadow:6px 6px 0 var(--black);margin-bottom:16px;background:var(--pale)}
.badge{display:inline-flex;margin:0 0 12px;padding:6px 14px;background:var(--yellow);border:3px solid var(--black);font-family:var(--display);font-weight:900}
.table{width:100%;border-collapse:collapse;background:var(--white);border:5px solid var(--black);box-shadow:8px 8px 0 var(--black);overflow:hidden}
.table th,.table td{padding:18px 14px;border:4px solid var(--black);text-align:left;vertical-align:top}
.table th{width:220px;background:var(--yellow);font-family:var(--display)}
.compare td,.compare th{text-align:center}
.faq-item{background:var(--white);color:var(--black);border:5px solid var(--black);box-shadow:7px 7px 0 var(--black);padding:22px;margin-bottom:20px}
.faq-q{font-family:var(--display);font-size:22px;margin:0 0 10px}
.faq-a{margin:0;line-height:1.8}
label{display:block;margin:0 0 8px;font-weight:900}
input,textarea,select{width:100%;padding:14px 16px;border:4px solid var(--black);font:inherit;background:var(--white)}
textarea{min-height:150px;resize:vertical}
.field{margin-bottom:18px}
.actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:24px}
.pop-button{display:inline-flex;align-items:center;justify-content:center;min-height:58px;padding:12px 24px;border:5px solid var(--black);background:var(--yellow);box-shadow:6px 6px 0 var(--black);font-family:var(--display);font-weight:900;font-size:clamp(16px,2.4vw,24px)}
.pop-button.secondary{background:var(--white)}
.entry-lead-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:stretch}
.entry-catch{background:var(--yellow);border:5px solid var(--black);padding:34px;color:var(--black)}
.entry-catch strong{display:block;margin-bottom:16px;font-family:var(--display);font-size:clamp(26px,4vw,48px);line-height:1.25}
.entry-catch p{margin:0;line-height:2;font-weight:800}
.entry-list{display:grid;gap:16px}
.entry-list .card{display:flex;gap:16px;align-items:flex-start}
.entry-number{display:grid;place-items:center;flex:0 0 42px;width:42px;aspect-ratio:1;border:3px solid var(--black);border-radius:50%;background:var(--green);font-family:var(--display);font-weight:900}
.line-cta-box{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;background:var(--white);color:var(--black);border:5px solid var(--black);padding:30px}
.line-cta-box h2{margin-bottom:12px}
.line-cta-box p{margin:0;line-height:1.9;font-weight:800}
  .interview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
  .interview-filter{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 28px}
  .interview-filter__button{min-height:46px;padding:9px 22px;border:3px solid var(--black);border-radius:999px;background:var(--white);color:var(--black);font-family:var(--display);font-weight:900;font-size:15px;cursor:pointer}
  .interview-filter__button.is-active{background:var(--red);color:var(--white)}
  .interview-card{background:var(--white);color:var(--black);border:4px solid var(--black);padding:18px;display:grid;gap:14px}
  .interview-card[hidden]{display:none!important}
  .interview-thumb{display:grid;place-items:center;min-height:190px;border:4px solid var(--black);background:linear-gradient(135deg,var(--yellow),var(--red));font-family:var(--display);font-size:clamp(20px,3vw,34px);font-weight:900;color:var(--white);-webkit-text-stroke:1.6px var(--black);paint-order:stroke fill}
.interview-tag{display:inline-flex;align-items:center;width:max-content;padding:7px 12px;border:3px solid var(--black);background:var(--green);font-weight:900;font-size:13px}
.interview-card h3{margin:0;font-family:var(--body);font-size:clamp(20px,2.6vw,28px);font-weight:900;line-height:1.45}
.interview-card p{margin:0;line-height:1.8;font-weight:700}
.benefit-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.benefit-card{background:var(--white);color:var(--black);border:5px solid var(--black);padding:22px}
.benefit-card h3{margin:0 0 10px;font-family:var(--display);font-size:clamp(20px,2.4vw,28px)}
.benefit-card p{margin:0;line-height:1.8}
.section-cta{display:flex;justify-content:center;margin-top:clamp(28px,4vw,46px)}
.liver-flow-board{position:relative;margin-top:30px;padding:clamp(24px,4vw,42px);border:4px solid var(--black);background:var(--white);overflow:hidden}
.liver-flow-board::before{content:"";position:absolute;right:-58px;top:-58px;width:170px;aspect-ratio:1;border:4px solid var(--black);border-radius:50%;background:var(--yellow);opacity:.45}
.liver-flow-board::after{content:"";position:absolute;left:-38px;bottom:-38px;width:126px;aspect-ratio:1;border:4px solid var(--black);border-radius:50%;background:var(--green);opacity:.34}
.liver-flow-list{position:relative;z-index:1;display:grid;max-width:860px;margin:24px auto 0}
.liver-flow-step{display:grid;grid-template-columns:76px 1fr;align-items:stretch;min-height:82px;margin-top:-4px;border:4px solid var(--black);background:var(--yellow)}
.liver-flow-step:first-child{margin-top:0}
.liver-flow-step:nth-child(2n){background:var(--green)}
.liver-flow-step:nth-child(3n){background:var(--red);color:var(--black)}
.liver-flow-num{display:grid;place-items:center;background:var(--black);color:var(--white);font-family:var(--body);font-size:28px;font-weight:900}
.liver-flow-text{display:flex;align-items:center;padding:16px 24px;font-size:clamp(22px,3vw,34px);font-weight:900;line-height:1.3}
.apply-hero{position:relative;min-height:calc(100svh - 96px);padding:clamp(42px,7vw,88px) clamp(20px,6vw,86px);border-bottom:7px solid var(--black);overflow:hidden;isolation:isolate;background:linear-gradient(132deg,var(--yellow) 0 31%,var(--red) 31% 79%,var(--green) 79% 100%)}
.apply-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(132deg,transparent 0 31%,var(--black) 31% 31.7%,transparent 31.7% 79%,var(--black) 79% 79.7%,transparent 79.7% 100%);opacity:.72}
.apply-hero__inner{display:grid;grid-template-columns:minmax(420px,1fr) minmax(390px,.92fr);gap:clamp(28px,4vw,56px);align-items:center;max-width:1240px;margin:0 auto;position:relative;z-index:1}
.apply-kicker{display:inline-flex;align-items:center;min-height:48px;padding:10px 26px;margin:0 0 24px;background:var(--black);color:var(--yellow);font-family:var(--display);font-size:clamp(13px,1.6vw,18px);font-weight:900;letter-spacing:.08em;clip-path:polygon(7% 0,94% 0,100% 50%,94% 100%,7% 100%,0 50%)}
.apply-title{margin:0;color:var(--black);font-family:var(--body);font-size:clamp(40px,7vw,76px);font-weight:900;line-height:1.16;letter-spacing:.01em;-webkit-text-stroke:0;text-shadow:none}
.apply-title span{display:block;white-space:nowrap}
.apply-title .accent{display:inline-block;margin:.12em 0;padding:.04em .22em .1em;color:var(--red);background:var(--white);border:3px solid var(--black);-webkit-text-stroke:1.8px var(--black);paint-order:stroke fill}
.apply-lead-card{width:min(650px,100%);margin:28px 0 0;padding:22px 26px;border:3px solid var(--black);background:var(--white);font-size:clamp(15px,1.9vw,21px);line-height:1.9;font-weight:800}
.apply-lead-cta{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:14px;width:min(640px,100%);margin-top:34px;min-height:88px;padding:18px 30px;border:4px solid var(--black);background:var(--green);color:var(--black);font-family:var(--body);font-size:clamp(24px,3.2vw,38px);font-weight:900;line-height:1.15;text-decoration:none;overflow:hidden;animation:cta-pop 2.2s ease-in-out infinite}
.apply-lead-cta::before{content:"";position:absolute;inset:-40% auto -40% -45%;width:34%;background:rgba(255,255,255,.58);transform:skewX(-18deg);animation:cta-shine 2.8s ease-in-out infinite}
.apply-lead-cta::after{content:"";position:absolute;inset:7px;border:2px solid rgba(252,227,3,.9);pointer-events:none}
.apply-lead-cta .line-mark{width:56px;height:46px}
.apply-visual{position:relative;width:min(500px,100%);min-height:min(700px,calc(100svh - 190px));margin:0 auto}
.apply-phone{position:absolute;right:50%;top:0;width:min(390px,30vw);max-height:calc(100svh - 190px);aspect-ratio:9/16;border:4px solid var(--black);border-radius:34px;background:var(--white);overflow:hidden;transform:translateX(50%)}
.apply-phone::before{content:"";position:absolute;left:50%;top:10px;width:76px;height:13px;border-radius:0 0 16px 16px;background:var(--black);transform:translateX(-50%);z-index:2}
.apply-phone img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.apply-phone-label{position:absolute;left:22px;bottom:24px;padding:8px 15px;border:3px solid var(--black);background:var(--white);font-size:15px;font-weight:900;z-index:3}
.apply-support-box{position:absolute;left:0;bottom:0;width:min(360px,100%);padding:18px 20px;border:3px solid var(--black);background:var(--white);font-weight:800;line-height:1.7}
.apply-support-box strong{display:block;margin-bottom:8px;font-size:22px}
.apply-bubble{position:absolute;right:0;bottom:76px;display:grid;place-items:center;width:78px;aspect-ratio:1;border:3px solid var(--black);border-radius:50%;background:var(--green);font-size:30px;font-weight:900}
.apply-fixed-line-cta{position:fixed;left:50%;bottom:16px;z-index:110;width:min(620px,calc(100vw - 28px));min-height:70px;display:flex;flex-direction:column;gap:2px;align-items:center;justify-content:center;padding:14px 22px;border:5px solid var(--black);background:var(--green);color:var(--black);font-family:var(--body);text-decoration:none;font-weight:900;opacity:0;pointer-events:none;transform:translate(-50%,calc(100% + 44px));transition:opacity .22s ease,transform .22s ease}
.apply-fixed-line-cta.is-visible{opacity:1;pointer-events:auto;transform:translate(-50%,0)}
.apply-fixed-line-cta .cta-sub{font-size:clamp(11px,2.8vw,14px);letter-spacing:.08em}
.apply-fixed-line-cta .cta-main{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:clamp(20px,4.8vw,30px);line-height:1.15}
.line-mark{position:relative;display:inline-grid;place-items:center;width:42px;height:36px;flex:0 0 auto;border-radius:50%;background:var(--white);color:var(--green);font-size:11px;font-weight:900;letter-spacing:.02em;line-height:1}
.line-mark::after{content:"";position:absolute;left:5px;bottom:-10px;width:18px;height:18px;background:var(--white);clip-path:polygon(0 0,100% 0,0 100%);z-index:-1}
@keyframes cta-pop{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes cta-shine{0%{left:-45%}45%,100%{left:115%}}
.apply-fixed-cta-spacer{height:106px}
.partner-hero{position:relative;min-height:calc(100svh - 96px);padding:clamp(46px,7vw,92px) clamp(20px,6vw,86px);border-bottom:7px solid var(--black);overflow:hidden;isolation:isolate;background:linear-gradient(132deg,var(--yellow) 0 31%,var(--red) 31% 79%,var(--green) 79% 100%)}
.partner-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(132deg,transparent 0 31%,var(--black) 31% 31.7%,transparent 31.7% 79%,var(--black) 79% 79.7%,transparent 79.7% 100%);opacity:.72}
.partner-hero__inner{display:grid;grid-template-columns:1fr;gap:clamp(26px,4vw,46px);align-items:start;max-width:960px;margin:0 auto;position:relative;z-index:1}
.partner-title{margin:0;color:var(--black);font-family:var(--body);font-size:clamp(42px,7vw,86px);font-weight:900;line-height:1.12;letter-spacing:.01em}
.partner-title span{display:block}
.partner-title .accent{display:inline-block;margin:.12em 0;padding:.04em .22em .1em;color:var(--red);background:var(--white);border:3px solid var(--black);-webkit-text-stroke:1.8px var(--black);paint-order:stroke fill}
.partner-lead-card{width:min(650px,100%);margin:34px 0 0;padding:22px 26px;border:3px solid var(--black);background:var(--white);font-size:clamp(15px,1.9vw,21px);line-height:1.9;font-weight:800}
.partner-visual{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;width:min(820px,100%)}
.partner-metric{background:var(--white);border:3px solid var(--black);padding:24px}
.partner-metric strong{display:block;font-family:var(--display);font-size:clamp(34px,6vw,72px);line-height:1;color:var(--red);-webkit-text-stroke:2px var(--black);paint-order:stroke fill}
.partner-metric span{display:block;margin-top:10px;font-weight:900}
.bulk-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
.bulk-note{background:var(--yellow);border:3px solid var(--black);padding:28px;font-size:clamp(18px,2.4vw,28px);line-height:1.7;font-weight:900}
.bulk-diagram{border:3px solid var(--black);background:var(--white);padding:24px;display:grid;gap:18px;align-content:center}
.bulk-diagram__head{display:flex;justify-content:space-between;gap:16px;align-items:end;border-bottom:3px solid var(--black);padding-bottom:12px}
.bulk-diagram__title{font-size:clamp(24px,3vw,42px);font-weight:900;line-height:1;margin:0}
.bulk-diagram__example{font-size:clamp(13px,1.4vw,16px);font-weight:800;margin:0;text-align:right}
.bulk-diagram__flow{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:center;gap:10px}
.bulk-node{aspect-ratio:1;border:3px solid var(--black);border-radius:50%;display:grid;place-items:center;text-align:center;font-size:clamp(16px,1.7vw,24px);font-weight:900;line-height:1.25;padding:14px;min-width:112px}
.bulk-node--app{background:var(--green)}
.bulk-node--office{background:var(--red);color:var(--white)}
.bulk-node--liver{background:var(--yellow)}
.bulk-link{display:grid;gap:3px;place-items:center;min-width:74px;font-weight:900}
.bulk-link__label{font-size:13px;color:var(--black)}
.bulk-link__contract{font-size:30px;line-height:1;color:#777}
.bulk-link__reward{font-size:13px;color:var(--red)}
.bulk-link__reward-arrow{font-size:34px;line-height:1;color:var(--red)}
.bulk-diagram__caption{border:3px solid var(--black);padding:14px 16px;font-weight:800;line-height:1.7;background:var(--yellow)}
.strength-comparison{margin-top:clamp(34px,5vw,58px)}
.strength-comparison__head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:18px}
.strength-comparison__title{margin:0;font-size:clamp(34px,5vw,62px);font-weight:900;line-height:1.1;color:var(--black)}
.strength-comparison__note{margin:0;font-size:clamp(13px,1.5vw,16px);font-weight:900;color:#555}
.strength-table-wrap{overflow-x:auto;padding:4px 4px 14px;-webkit-overflow-scrolling:touch}
.strength-table{min-width:880px;display:grid;grid-template-columns:160px minmax(260px,1.35fr) minmax(160px,.8fr) minmax(160px,.8fr);align-items:stretch;border:4px solid var(--black);background:var(--black)}
.strength-cell{min-height:98px;display:grid;place-items:center;text-align:center;padding:14px 12px;background:var(--white);border:2px solid var(--black);font-weight:900;line-height:1.45}
.strength-label{justify-items:start;text-align:left;background:#f7f7f7;font-size:clamp(14px,1.5vw,18px)}
.strength-label--head{background:var(--black);color:var(--yellow);letter-spacing:.08em}
.strength-brand-head{background:var(--yellow);color:var(--black);font-size:clamp(28px,4vw,48px);letter-spacing:.02em}
.strength-competitor-head{background:#666;color:var(--white);font-size:clamp(22px,3vw,34px)}
.strength-brand{background:var(--yellow);border-left:6px solid var(--black);border-right:6px solid var(--black);font-size:clamp(17px,2.3vw,24px)}
.strength-brand--last{border-bottom:6px solid var(--black)}
.strength-price{font-size:clamp(40px,5vw,64px);line-height:1;font-weight:900}
.strength-price small{font-size:.38em;margin-left:.08em}
.strength-sub{display:block;margin-top:6px;font-size:clamp(12px,1.4vw,16px)}
.strength-mark{font-size:clamp(44px,5vw,68px);line-height:1;font-weight:900}
.strength-mark--good{color:var(--green)}
.strength-mark--ok{color:var(--yellow);-webkit-text-stroke:2px var(--black);paint-order:stroke fill}
.strength-mark--bad{color:var(--red)}
.strength-comment{display:block;margin-top:6px;font-size:clamp(12px,1.4vw,16px);line-height:1.45}
.flow-lp{background:#eaf1fb;color:var(--black)}
.flow-board{position:relative;padding:36px 0 8px}
.flow-line{position:absolute;left:5%;right:16%;top:96px;height:3px;background:#28238d}
.flow-steps{display:grid;grid-template-columns:repeat(4,1fr) minmax(88px,.9fr);gap:14px;align-items:end}
.flow-step{position:relative;padding-top:80px}
.flow-step::before{content:"";position:absolute;top:49px;left:50%;width:16px;height:16px;border-radius:50%;background:#28238d;transform:translateX(-50%)}
.flow-step::after{content:"";position:absolute;top:65px;left:50%;height:32px;border-left:3px dashed #28238d;transform:translateX(-50%)}
.flow-step-label{display:block;text-align:center;font-family:var(--display);font-size:clamp(22px,4vw,42px);line-height:.95;color:#5289ff;font-weight:900}
.flow-step-label small{display:block;font-size:.44em;letter-spacing:.08em}
.flow-card{min-height:116px;display:grid;place-items:center;text-align:center;padding:20px 18px;background:#d8d8d8;border:0;font-weight:900;font-size:clamp(15px,2vw,24px);line-height:1.45;clip-path:polygon(0 0,82% 0,100% 50%,82% 100%,0 100%,13% 50%)}
.flow-start{align-self:stretch;display:grid;place-items:center;min-height:260px;padding:20px 18px;background:#28238d;color:var(--white);border-radius:18px;font-family:var(--display);font-size:clamp(22px,3.5vw,38px);font-weight:900;line-height:1.2;writing-mode:vertical-rl}
.partner-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.partner-form-grid .field--full{grid-column:1/-1}
.site-footer{padding:34px clamp(20px,5vw,72px);background:var(--white);border-top:7px solid var(--black)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;max-width:1180px;margin:0 auto}
.footer-brand{margin:0;font-family:var(--display);font-size:20px;font-weight:900}
.footer-cta{display:flex;gap:12px;flex:1;justify-content:center}
.footer-cta .pop-button{min-width:190px;min-height:54px;padding:10px 18px;font-size:clamp(14px,1.8vw,20px);border-width:4px;box-shadow:5px 5px 0 var(--black)}
.footer-sns{display:flex;align-items:center;gap:14px}
.footer-sns-label{font-family:var(--display);font-size:clamp(22px,3.2vw,34px);font-weight:900;color:var(--yellow);-webkit-text-stroke:3px var(--black);paint-order:stroke fill;text-shadow:4px 5px 0 var(--red);white-space:nowrap}
.sns-icon{display:grid;place-items:center;width:58px;aspect-ratio:1;border:4px solid var(--black);background:var(--yellow);box-shadow:5px 5px 0 var(--black);font-family:var(--display);font-size:24px;font-weight:900}
.sns-icon--instagram{border-radius:16px;background:var(--white)}
.sns-icon--instagram::before{content:"";width:27px;aspect-ratio:1;border:5px solid var(--black);border-radius:9px;box-shadow:inset 0 0 0 4px var(--yellow)}
.footer-privacy{max-width:1180px;margin:18px auto 0;font-size:12px;font-weight:800;line-height:1.5;opacity:.72}
.footer-privacy a{color:var(--black);text-decoration:underline;text-underline-offset:4px}
.footer-privacy a:hover{opacity:1}
.privacy-page{background:var(--white);color:var(--black)}
.privacy-content{max-width:980px}
.privacy-card{font-size:clamp(14px,1.6vw,18px);line-height:2}
.privacy-card h3{margin:28px 0 8px;font-size:clamp(17px,2vw,22px)}
.privacy-card ul{margin:10px 0 0;padding-left:1.35em}
.privacy-kicker{margin-top:54px}
#news > .deco,
#news .section-deco{display:none!important}
@media (max-width:780px){
  .top-header{min-height:102px;padding:18px}
  .brand{gap:14px}
  .brand-mark{width:52px}
  .brand-name{font-size:clamp(38px,12vw,58px)}
  .menu-toggle{width:58px;height:52px}
  .grid,.grid.two,.entry-lead-grid,.benefit-grid,.line-cta-box,.interview-grid{grid-template-columns:1fr}
  .line-cta-box .pop-button{width:100%}
  .table th,.table td{display:block;width:100%}
  .footer-inner{align-items:flex-start;flex-direction:column}
  .footer-cta{width:100%;justify-content:flex-start;flex-wrap:nowrap;gap:8px}
  .footer-cta .pop-button{width:50%;min-width:0;min-height:50px;padding:8px 6px;font-size:clamp(12px,3.25vw,16px);white-space:nowrap}
  .liver-flow-board{padding:22px 16px}
  .liver-flow-step{grid-template-columns:52px 1fr;min-height:64px;border-width:3px;margin-top:-3px}
  .liver-flow-num{font-size:20px}
  .liver-flow-text{padding:12px 14px;font-size:17px}
  .apply-hero__inner{grid-template-columns:1fr}
  .apply-title{font-size:clamp(36px,10vw,54px)}
  .apply-visual{width:100%;min-height:470px}
  .apply-phone{right:0;width:min(300px,72vw);max-height:none;transform:none}
  .apply-support-box{bottom:0}
  .partner-hero__inner,.bulk-grid,.partner-form-grid{grid-template-columns:1fr}
  .bulk-diagram__head{display:grid;gap:8px}
  .bulk-diagram__example{text-align:left}
  .bulk-diagram{padding:18px}
  .bulk-diagram__flow{grid-template-columns:1fr auto 1fr auto 1fr;justify-items:center;gap:5px}
  .bulk-node{min-width:0;width:min(21vw,98px);padding:8px;font-size:clamp(12px,3.4vw,16px)}
  .bulk-link{min-width:32px;grid-template-columns:1fr;gap:1px}
  .bulk-link__label,.bulk-link__reward{font-size:12px}
  .bulk-link__contract,.bulk-link__reward-arrow{font-size:22px;transform:none}
  .strength-comparison__head{display:grid;gap:8px}
  .strength-table-wrap{margin-inline:-8px;padding-inline:8px}
  .strength-table{min-width:760px;grid-template-columns:130px 230px 150px 150px}
  .strength-cell{min-height:86px;padding:12px 10px}
  .partner-visual{grid-template-columns:1fr}
  .partner-title{font-size:clamp(38px,10vw,56px)}
  .flow-board{overflow-x:auto;padding-bottom:18px}
  .flow-steps{min-width:760px}
}

/* Home mockup styles */
:root{
    --yellow:#fce303;
    --red:#eb5050;
    --green:#5ed686;
    --blue:#0b78ff;
    --cyan:#28c7d8;
    --pink:#f24fbd;
    --black:#111;
    --white:#fff;
    --shadow:10px 10px 0 var(--black);
    --border:7px solid var(--black);
    --display:'Noto Sans JP','Hiragino Kaku Gothic ProN','Yu Gothic',sans-serif;
    --body:'Noto Sans JP','Hiragino Kaku Gothic ProN','Yu Gothic',sans-serif;
  }

/* Current top hero mockup sync: 2026-05-22 */
.hero-logo{
  display:none;
}

@media (min-width:981px){
  .hero{
    min-height:680px;
    background:
      linear-gradient(143deg,
        var(--yellow) 0 30%,
        var(--red) 30% 76%,
        var(--green) 76% 100%) !important;
  }

  .hero::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:-1;
    opacity:.30;
    pointer-events:none;
    background:
      url("data:image/svg+xml,%3Csvg width='132' height='132' viewBox='0 0 132 132' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='66 10 115 38 115 94 66 122 17 94 17 38' fill='none' stroke='white' stroke-width='5' opacity='.7'/%3E%3C/svg%3E") 12px 18px/142px 142px,
      url("data:image/svg+xml,%3Csvg width='92' height='92' viewBox='0 0 92 92' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='46 10 78 28 78 64 46 82 14 64 14 28' fill='white' opacity='.35'/%3E%3C/svg%3E") 74px 80px/174px 174px;
  }

  .hero::after{
    background:
      linear-gradient(143deg,
        transparent 0 30%,
        var(--black) 30% 30.5%,
        transparent 30.5% 76%,
        var(--black) 76% 76.5%,
        transparent 76.5% 100%) !important;
    opacity:1;
  }

  .hero-inner{
    display:block;
    min-height:680px;
    width:min(1180px,100%);
    padding:0 56px 54px;
  }

  .hero-logo{
    display:block;
    position:absolute;
    top:118px;
    left:48px;
    right:auto;
    z-index:4;
    color:var(--white);
    font-family:'Inter',var(--display),system-ui,sans-serif;
    font-size:142px;
    font-style:italic;
    font-weight:900;
    letter-spacing:-.065em;
    line-height:.9;
    white-space:nowrap;
    text-shadow:0 9px 16px rgba(0,0,0,.28) !important;
    -webkit-text-stroke:0 !important;
  }

  .specialized-ribbon{
    top:50px;
    left:56px;
    width:420px;
    min-height:56px;
    padding:14px 46px;
    font-size:23px;
    box-shadow:none !important;
  }

  .copy-block{
    width:480px;
    margin-top:0;
    padding-top:318px;
  }

  .hero-title{
    color:var(--white);
    font-size:43px;
    line-height:1.45;
    letter-spacing:-.035em;
    text-shadow:0 2px 0 rgba(0,0,0,.2) !important;
    -webkit-text-stroke:1.2px var(--black) !important;
  }

  .hero-title .emphasis-wrap{
    display:flex;
    align-items:center;
    gap:.32em;
    margin:.18em 0 .22em;
  }

  .hero-title .emphasis{
    padding:.03em .2em .09em;
    border:3px solid var(--black);
    color:var(--red);
    box-shadow:none !important;
    -webkit-text-stroke:1px var(--black) !important;
  }

  .hero-actions{
    width:360px;
    gap:18px;
    margin-top:74px;
    grid-template-columns:1fr;
  }

  .hero-actions .pop-button{
    min-height:66px;
    justify-content:flex-start;
    padding:14px 26px;
    background:var(--white);
    font-size:26px;
  }

  .visual-stage{
    position:absolute;
    z-index:2;
    right:-70px;
    top:270px;
    width:520px;
    min-height:auto;
    aspect-ratio:1;
    transform:rotate(-10deg);
    transform-origin:center;
    pointer-events:none;
  }

  .slider-window{
    position:relative;
    inset:auto;
    width:100%;
    height:100%;
    aspect-ratio:1;
    transform:none;
    filter:none;
  }

  .hex-slider,
  .hex-track{
    position:relative;
    width:100%;
    height:100%;
  }

  .hex-slide,
  .hex-slide::before,
  .hex-slide img{
    clip-path:none;
  }

  .hex-slide{
    border:0;
    background:var(--black);
    transform:translateX(62%) scale(.98);
  }

  .hex-slide::before{
    inset:10px;
    background:var(--white);
  }

  .hex-slide img{
    inset:10px;
    width:calc(100% - 20px);
    height:calc(100% - 20px);
    object-fit:cover;
    object-position:center 34%;
  }

  .hex-slide:nth-child(1) img,
  .hex-slide:nth-child(2) img,
  .hex-slide:nth-child(5) img{
    object-fit:cover;
    background:transparent;
  }

  .floating-hex{
    display:none;
  }

  @keyframes hexFrameSlide{
    0%{opacity:0;transform:translateX(62%) scale(.98)}
    5%,14%{opacity:1;transform:translateX(0) scale(1)}
    18%{opacity:0;transform:translateX(-62%) scale(.98)}
    100%{opacity:0;transform:translateX(-62%) scale(.98)}
  }
}

@media (max-width:980px){
  .hero-logo{
    display:block;
    position:absolute;
    top:116px;
    left:20px;
    z-index:3;
    color:var(--white);
    font-family:'Inter',var(--display),system-ui,sans-serif;
    font-size:clamp(76px,20vw,116px);
    font-style:italic;
    font-weight:900;
    letter-spacing:-.07em;
    line-height:.9;
    white-space:nowrap;
    text-shadow:0 7px 14px rgba(0,0,0,.24) !important;
    -webkit-text-stroke:0 !important;
  }

  .copy-block{
    margin-top:0;
    padding-top:510px;
  }
}

/* Final WordPress hero sync from header_design_options.html */
.hero{
  min-height:1180px;
  background:linear-gradient(132deg,var(--yellow) 0 31%,var(--red) 31% 79%,var(--green) 79% 100%) !important;
}

.hero::before{
  content:"" !important;
  position:absolute;
  inset:0;
  z-index:-2;
  opacity:1 !important;
  background:linear-gradient(132deg,transparent 0 31%,var(--black) 31% 31.7%,transparent 31.7% 79%,var(--black) 79% 79.7%,transparent 79.7% 100%) !important;
}

.hero::after{
  content:"" !important;
  position:absolute;
  inset:0;
  z-index:-1;
  opacity:.3 !important;
  background:
    url("data:image/svg+xml,%3Csvg width='132' height='132' viewBox='0 0 132 132' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='66 10 115 38 115 94 66 122 17 94 17 38' fill='none' stroke='white' stroke-width='5' opacity='.7'/%3E%3C/svg%3E") 12px 18px/142px 142px,
    url("data:image/svg+xml,%3Csvg width='92' height='92' viewBox='0 0 92 92' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='46 10 78 28 78 64 46 82 14 64 14 28' fill='white' opacity='.35'/%3E%3C/svg%3E") 74px 80px/174px 174px !important;
}

.hero-inner{
  min-height:1180px;
  padding:0 30px 56px;
}

.specialized-ribbon{
  top:76px;
  left:30px;
  width:min(340px,80%);
  min-height:48px;
  padding:10px 30px;
  font-size:20px;
  transform:none !important;
  box-shadow:none !important;
}

.hero-logo{
  display:block;
  position:absolute;
  top:194px;
  left:24px;
  right:10px;
  z-index:4;
  color:var(--white);
  font-family:"Inter",var(--display),system-ui,sans-serif;
  font-size:116px;
  font-style:italic;
  font-weight:900;
  letter-spacing:-.07em;
  line-height:.9;
  white-space:nowrap;
  text-shadow:0 9px 16px rgba(0,0,0,.28) !important;
  -webkit-text-stroke:0 !important;
}

.copy-block{
  position:relative;
  z-index:3;
  width:100%;
  margin-top:0;
  padding-top:555px;
}

.hero-title{
  color:var(--white);
  font-size:37px;
  line-height:1.55;
  letter-spacing:-.035em;
  -webkit-text-stroke:1.2px var(--black) !important;
  text-shadow:0 2px 0 rgba(0,0,0,.2) !important;
}

.hero-title .line{
  display:block;
  white-space:nowrap;
}

.hero-title .emphasis-wrap{
  display:flex;
  align-items:center;
  gap:.32em;
  margin:.18em 0 .22em;
  white-space:nowrap;
}

.hero-title .emphasis{
  padding:.04em .18em .1em;
  border:2px solid var(--black);
  background:var(--white);
  color:var(--red);
  -webkit-text-stroke:1px var(--black) !important;
  box-shadow:none !important;
}

.hero-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
  width:270px;
  margin-top:172px;
}

.hero-actions .pop-button{
  min-height:74px;
  justify-content:center;
  padding:16px 24px;
  background:var(--white);
  color:var(--black);
  font-size:23px;
  white-space:nowrap;
  transform:none !important;
  box-shadow:none !important;
}

.visual-stage{
  position:absolute;
  z-index:2;
  right:-110px;
  top:585px;
  width:520px;
  min-height:auto;
  aspect-ratio:1;
  transform:none;
  pointer-events:none;
}

.slider-window,
.hex-slider,
.hex-track{
  position:relative;
  inset:auto;
  width:100%;
  height:100%;
  aspect-ratio:1;
  transform:none;
  filter:none;
}

.hex-slide{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0 50%);
  background:var(--black);
  overflow:hidden;
  opacity:0;
  transform:translateX(62%) scale(.98);
  animation:hexFrameSlide 24s cubic-bezier(.72,0,.22,1) infinite;
}

.hex-slide::before{
  content:"";
  position:absolute;
  inset:9px;
  clip-path:inherit;
  background:var(--white);
  z-index:0;
}

.hex-slide img{
  position:absolute;
  inset:9px;
  width:calc(100% - 18px);
  height:calc(100% - 18px);
  display:block;
  object-fit:cover;
  object-position:center 34%;
  clip-path:inherit;
  z-index:1;
}

.hex-slide:nth-child(1) img{object-position:center 36%}
.hex-slide:nth-child(2) img{object-position:center 31%}
.hex-slide:nth-child(3) img{object-position:center 28%}
.hex-slide:nth-child(4) img{object-position:center 38%}
.hex-slide:nth-child(5) img{object-position:center 40%}
.hex-slide:nth-child(6) img{object-position:center 24%}

.floating-hex{
  display:block;
  position:absolute;
  z-index:5;
  top:-78px;
  right:92px;
  width:70px;
  aspect-ratio:1;
  background:var(--yellow);
  clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0 50%);
  border:var(--line) solid var(--black);
}

.floating-hex--two{
  width:40px;
  right:128px;
  top:-106px;
  background:var(--white);
}

@media (min-width:981px){
  .hero{
    min-height:680px;
    background:linear-gradient(143deg,var(--yellow) 0 30%,var(--red) 30% 76%,var(--green) 76% 100%) !important;
  }

  .hero::before{
    background:linear-gradient(143deg,transparent 0 30%,var(--black) 30% 30.5%,transparent 30.5% 76%,var(--black) 76% 76.5%,transparent 76.5% 100%) !important;
  }

  .hero-inner{
    min-height:680px;
    width:min(1180px,100%);
    padding:0 56px 54px;
  }

  .specialized-ribbon{
    top:50px;
    left:56px;
    width:420px;
    min-height:56px;
    padding:14px 46px;
    font-size:23px;
  }

  .hero-logo{
    top:118px;
    left:48px;
    right:auto;
    font-size:142px;
    letter-spacing:-.065em;
  }

  .copy-block{
    width:480px;
    padding-top:318px;
  }

  .hero-title{
    font-size:43px;
    line-height:1.45;
  }

  .hero-title .emphasis{
    padding:.03em .2em .09em;
    border-width:3px;
  }

  .hero-actions{
    width:360px;
    gap:18px;
    margin-top:74px;
  }

  .hero-actions .pop-button{
    min-height:66px;
    justify-content:flex-start;
    padding:14px 26px;
    font-size:26px;
  }

  .visual-stage{
    top:270px;
    right:-70px;
    width:520px;
    transform:rotate(-10deg);
    transform-origin:center;
  }

  .hex-slide,
  .hex-slide::before,
  .hex-slide img{
    clip-path:none;
  }

  .hex-slide::before{
    inset:10px;
  }

  .hex-slide img{
    inset:10px;
    width:calc(100% - 20px);
    height:calc(100% - 20px);
    object-position:center 34%;
  }

  .floating-hex{
    display:none;
  }
}

/* Final hero photo position override. Keep this after all hero rules. */
.visual-stage{
  top:520px !important;
  right:-60px !important;
}

@media (min-width:981px){
  .visual-stage{
    top:220px !important;
    right:-20px !important;
  }
}

/* Hero photo frame: rectangular version */
.visual-stage{
  aspect-ratio:4 / 5 !important;
}

.slider-window,
.hex-slider,
.hex-track{
  aspect-ratio:4 / 5 !important;
}

.hex-slide{
  clip-path:none !important;
  border:6px solid var(--black) !important;
  box-sizing:border-box;
  background:var(--white);
}

.hex-slide::before{
  display:none !important;
}

.hex-slide img{
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  clip-path:none !important;
  object-fit:cover;
}

@media (min-width:981px){
  .visual-stage{
    width:430px !important;
    aspect-ratio:4 / 5 !important;
  }
}

/* NEWS: keep the "more" icon closer to the top of the card row. */
#news .news-more{
  transform:translateY(-42px);
}

@media (max-width:640px){
  #news .news-more{
    transform:translateY(-34px);
  }
}

/* Final override: Apply page interview carousel */
.section--interview{
  background:#e8fbef!important;
  color:var(--black)!important;
}

.section--interview .section-kicker{
  color:var(--red)!important;
}

.section--interview .outline{
  color:var(--white)!important;
  -webkit-text-stroke:3px var(--black);
  paint-order:stroke fill;
}

.section--interview .page-lead{
  color:var(--black)!important;
}

.section--interview .interview-grid{
  display:grid!important;
  grid-template-columns:none!important;
  grid-auto-flow:column!important;
  grid-template-rows:repeat(2, minmax(0, auto))!important;
  grid-auto-columns:minmax(260px, calc((100% - 18px) / 2))!important;
  gap:18px!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  padding:4px 4px 18px!important;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}

.section--interview .interview-grid::-webkit-scrollbar{
  height:10px;
}

.section--interview .interview-grid::-webkit-scrollbar-track{
  background:var(--white);
  border:2px solid var(--black);
}

.section--interview .interview-grid::-webkit-scrollbar-thumb{
  background:var(--green);
  border:2px solid var(--black);
}

.section--interview .interview-card{
  min-width:0;
  scroll-snap-align:start;
}

@media (max-width:640px){
  .section--interview .interview-grid{
    grid-auto-columns:minmax(238px, calc((100vw - 76px) / 2))!important;
    gap:14px!important;
  }

  .section--interview .outline{
    -webkit-text-stroke:2.2px var(--black);
  }
}

/* Header design preview sync: 2026-05-22 */
.hero{
  overflow:hidden;
  isolation:isolate;
  min-height:1180px;
  background:linear-gradient(132deg,var(--yellow) 0 31%,var(--red) 31% 79%,var(--green) 79% 100%) !important;
}

.hero::before{
  content:"" !important;
  position:absolute;
  inset:0;
  z-index:-2;
  opacity:1 !important;
  background:linear-gradient(132deg,transparent 0 31%,var(--black) 31% 31.7%,transparent 31.7% 79%,var(--black) 79% 79.7%,transparent 79.7% 100%) !important;
}

.hero::after{
  content:"" !important;
  position:absolute;
  inset:0;
  z-index:-1;
  opacity:.3 !important;
  background:
    url("data:image/svg+xml,%3Csvg width='132' height='132' viewBox='0 0 132 132' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='66 10 115 38 115 94 66 122 17 94 17 38' fill='none' stroke='white' stroke-width='5' opacity='.7'/%3E%3C/svg%3E") 12px 18px/142px 142px,
    url("data:image/svg+xml,%3Csvg width='92' height='92' viewBox='0 0 92 92' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='46 10 78 28 78 64 46 82 14 64 14 28' fill='white' opacity='.35'/%3E%3C/svg%3E") 74px 80px/174px 174px !important;
}

.hero-inner{
  min-height:1180px;
  padding:0 30px 56px;
}

.specialized-ribbon{
  top:76px;
  left:30px;
  width:min(340px,80%);
  min-height:48px;
  padding:10px 30px;
  font-size:20px;
  box-shadow:none !important;
  transform:none !important;
}

.hero-logo{
  display:block;
  top:194px;
  left:24px;
  right:10px;
  z-index:4;
  color:var(--white);
  font-family:"Inter",var(--display),system-ui,sans-serif;
  font-size:116px;
  font-style:italic;
  font-weight:900;
  letter-spacing:-.07em;
  line-height:.9;
  white-space:nowrap;
  text-shadow:0 9px 16px rgba(0,0,0,.28) !important;
  -webkit-text-stroke:0 !important;
}

.copy-block{
  position:relative;
  z-index:3;
  width:100%;
  margin-top:0;
  padding-top:555px;
}

.hero-title{
  color:var(--white);
  font-size:37px;
  line-height:1.55;
  letter-spacing:-.035em;
  -webkit-text-stroke:1.2px var(--black) !important;
  text-shadow:0 2px 0 rgba(0,0,0,.2) !important;
}

.hero-title .line{
  display:block;
  white-space:nowrap;
}

.hero-title .emphasis-wrap{
  display:flex;
  align-items:center;
  gap:.32em;
  margin:.18em 0 .22em;
  white-space:nowrap;
}

.hero-title .emphasis{
  padding:.04em .18em .1em;
  border:2px solid var(--black);
  background:var(--white);
  color:var(--red);
  box-shadow:none !important;
  -webkit-text-stroke:1px var(--black) !important;
}

.hero-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
  width:270px;
  margin-top:172px;
}

.hero-actions .pop-button{
  min-height:74px;
  justify-content:center;
  padding:16px 24px;
  background:var(--white);
  font-size:23px;
  white-space:nowrap;
  box-shadow:none !important;
  transform:none !important;
}

.visual-stage{
  position:absolute;
  z-index:2;
  right:-110px;
  top:585px;
  width:520px;
  min-height:auto;
  aspect-ratio:1;
  transform:none;
  pointer-events:none;
}

.slider-window,
.hex-slider,
.hex-track{
  position:relative;
  inset:auto;
  width:100%;
  height:100%;
  aspect-ratio:1;
  transform:none;
  filter:none;
}

.hex-slide{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0 50%);
  background:var(--black);
  overflow:hidden;
  opacity:0;
  transform:translateX(62%) scale(.98);
  animation:hexFrameSlide 24s cubic-bezier(.72,0,.22,1) infinite;
}

.hex-slide::before{
  content:"";
  position:absolute;
  inset:9px;
  clip-path:inherit;
  background:var(--white);
  z-index:0;
}

.hex-slide img{
  position:absolute;
  inset:9px;
  width:calc(100% - 18px);
  height:calc(100% - 18px);
  display:block;
  object-fit:cover;
  object-position:center 34%;
  clip-path:inherit;
  z-index:1;
}

.hex-slide:nth-child(1) img{object-position:center 36%}
.hex-slide:nth-child(2) img{object-position:center 31%}
.hex-slide:nth-child(3) img{object-position:center 28%}
.hex-slide:nth-child(4) img{object-position:center 38%}
.hex-slide:nth-child(5) img{object-position:center 40%}
.hex-slide:nth-child(6) img{object-position:center 24%}

.floating-hex{
  display:block;
  position:absolute;
  z-index:5;
  top:-78px;
  right:92px;
  width:70px;
  aspect-ratio:1;
  background:var(--yellow);
  clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0 50%);
  border:var(--line) solid var(--black);
}

.floating-hex--two{
  width:40px;
  right:128px;
  top:-106px;
  background:var(--white);
}

@media (min-width:981px){
  .hero{
    min-height:680px;
    background:linear-gradient(143deg,var(--yellow) 0 30%,var(--red) 30% 76%,var(--green) 76% 100%) !important;
  }

  .hero::before{
    background:linear-gradient(143deg,transparent 0 30%,var(--black) 30% 30.5%,transparent 30.5% 76%,var(--black) 76% 76.5%,transparent 76.5% 100%) !important;
  }

  .hero-inner{
    min-height:680px;
    width:min(1180px,100%);
    padding:0 56px 54px;
  }

  .specialized-ribbon{
    top:50px;
    left:56px;
    width:420px;
    min-height:56px;
    padding:14px 46px;
    font-size:23px;
  }

  .hero-logo{
    top:118px;
    left:48px;
    right:auto;
    font-size:142px;
    letter-spacing:-.065em;
  }

  .copy-block{
    width:480px;
    padding-top:318px;
  }

  .hero-title{
    font-size:43px;
    line-height:1.45;
  }

  .hero-title .emphasis{
    padding:.03em .2em .09em;
    border-width:3px;
  }

  .hero-actions{
    width:360px;
    gap:18px;
    margin-top:74px;
  }

  .hero-actions .pop-button{
    min-height:66px;
    justify-content:flex-start;
    padding:14px 26px;
    font-size:26px;
  }

  .visual-stage{
    top:270px;
    right:-70px;
    width:520px;
    transform:rotate(-10deg);
    transform-origin:center;
  }

  .hex-slide,
  .hex-slide::before,
  .hex-slide img{
    clip-path:none;
  }

  .hex-slide::before{
    inset:10px;
  }

  .hex-slide img{
    inset:10px;
    width:calc(100% - 20px);
    height:calc(100% - 20px);
    object-position:center 34%;
  }

  .floating-hex{
    display:none;
  }
}

  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0;
    color:var(--black);
    background:var(--white);
    font-family:var(--body);
    overflow-x:hidden;
  }

  *,
  *::before,
  *::after{
    box-shadow:none !important;
    text-shadow:none !important;
  }

  .top-header,
  .menu-toggle,
  .header-nav,
  .header-nav a,
  .specialized-ribbon,
  .hero-title .emphasis,
  .message-card,
  .pop-button,
  .slider-window,
  .hex-slider,
  .section,
  .section-label,
  .section-label::before,
  .pop-card,
  .event-calendar,
  .calendar-month,
  .calendar-weekday,
  .calendar-cell,
  .calendar-event,
  .ranking-tab,
  .rank-card,
  .rank-no,
  .rank-icon,
  .news-card,
  .news-thumb,
  .news-thumb-text,
  .news-category,
  .site-footer,
  .sns-icon,
  .site-footer .sns-icon,
  .site-footer .sns-icon--instagram::before,
  .footer-sns-label,
  .poco-symbol--coin,
  .poco-symbol--coin::before,
  .poco-symbol--coin::after{
    border-width:3px !important;
  }

  a{color:inherit;text-decoration:none}

  .top-header{
    min-height:96px;
    padding:16px clamp(14px,3vw,42px);
    display:flex;
    align-items:center;
    justify-content:space-between;
    border-bottom:7px solid var(--black);
    background:var(--white);
    position:sticky;
    top:0;
    z-index:100;
  }

  .brand{
    display:flex;
    align-items:center;
    gap:14px;
  }

  .menu-toggle{
    width:46px;
    height:34px;
    display:grid;
    place-items:center;
    border:0;
    background:transparent;
    box-shadow:none;
    cursor:pointer;
    padding:0;
  }

  .menu-toggle span,
  .menu-toggle::before,
  .menu-toggle::after{
    content:"";
    display:block;
    width:31px;
    height:4px;
    background:var(--black);
  }

  .menu-toggle span{
    margin:6px 0;
  }

  .header-nav{
    position:absolute;
    right:clamp(20px,5vw,72px);
    top:calc(100% + 14px);
    width:min(360px,calc(100vw - 36px));
    padding:18px;
    background:var(--white);
    border:5px solid var(--black);
    box-shadow:8px 8px 0 var(--black);
    display:none;
    grid-template-columns:1fr;
    gap:10px;
  }

  .header-nav.is-open{
    display:grid;
  }

  .header-nav a{
    display:block;
    padding:12px 14px;
    background:var(--white);
    border:3px solid var(--black);
    font-weight:800;
  }

  .header-nav a:hover{
    background:var(--yellow);
  }

  .brand-mark{
    width:58px;
    aspect-ratio:1;
    position:relative;
    clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0 50%);
    background:var(--black);
    display:grid;
    place-items:center;
    flex:0 0 auto;
  }

  .brand-mark::before,
  .brand-mark::after{
    content:"";
    position:absolute;
    clip-path:inherit;
  }

  .brand-mark::before{
    inset:8px;
    background:var(--yellow);
  }

  .brand-mark::after{
    inset:18px;
    background:var(--red);
  }

  .brand-name{
    font-family:var(--display);
    font-weight:800;
    font-size:clamp(34px,5.2vw,56px);
    line-height:1;
    letter-spacing:.02em;
  }

  .brand-name,
  .specialized-ribbon,
  .hero-title .emphasis-wrap,
  .message-card,
  .section-label,
  .pop-card,
  .ranking-tab,
  .news-card,
  .news-more .pop-button,
  .month-tab{
    transform:none !important;
  }

  .hero-title,
  .hero-title .emphasis,
  .section-title,
  .footer-sns-label,
  .big-number,
  .calendar-title,
  .rank-no,
  .rank-icon{
    -webkit-text-stroke-width:2.7px !important;
  }

  .hero{
    min-height:calc(100vh - 96px);
    position:relative;
    isolation:isolate;
    overflow:hidden;
    background:
      linear-gradient(138deg,
        var(--yellow) 0 35%,
        var(--red) 35% 78%,
        var(--green) 78% 100%);
    border-bottom:7px solid var(--black);
  }

  .hero::after{
    content:"";
    position:absolute;
    inset:0;
    z-index:-1;
    background:
      linear-gradient(138deg, transparent 0 35%, var(--black) 35% 35.6%, transparent 35.6% 78%, var(--black) 78% 78.55%, transparent 78.55% 100%);
    opacity:.72;
    pointer-events:none;
  }

  .hero-inner{
    min-height:calc(100vh - 96px);
    width:min(1220px,100%);
    margin-inline:auto;
    padding:44px clamp(18px,4vw,54px) 34px;
    display:grid;
    grid-template-columns:minmax(330px,.9fr) minmax(430px,1fr);
    gap:34px;
    align-items:center;
    position:relative;
  }

  .admin-bar .hero,
  .admin-bar .hero-inner{
    min-height:calc(100vh - 128px);
  }

  .specialized-ribbon{
    position:absolute;
    top:46px;
    left:clamp(20px,4vw,58px);
    width:min(590px,49vw);
    min-height:62px;
    padding:14px 46px;
    display:flex;
    align-items:center;
    justify-content:center;
    color:var(--yellow);
    background:var(--black);
    font-family:var(--display);
    font-weight:800;
    font-size:clamp(20px,2.55vw,32px);
    letter-spacing:.06em;
    transform:rotate(-2.3deg);
    clip-path:polygon(7% 0,94% 0,100% 50%,94% 100%,7% 100%,0 50%);
    box-shadow:8px 10px 0 rgba(17,17,17,.22);
    z-index:5;
    white-space:nowrap;
  }

  .copy-block{
    margin-top:clamp(98px,9vw,128px);
    position:relative;
    z-index:4;
  }

  .hero-title{
    margin:0;
    font-family:var(--display);
    font-weight:700;
    font-size:clamp(34px,5.25vw,64px);
    line-height:1.34;
    letter-spacing:.01em;
    -webkit-text-stroke:1.2px var(--black);
    paint-order:stroke fill;
    text-shadow:6px 7px 0 rgba(17,17,17,.28);
  }

  .hero-title .line{
    display:block;
    white-space:nowrap;
  }

  .hero-title .emphasis-wrap{
    margin:12px 0 2px;
    display:block;
    transform:rotate(-1.7deg);
    white-space:nowrap;
  }

  .hero-title .emphasis{
    display:inline-block;
    white-space:nowrap;
    margin-right:.22em;
    padding:.06em .24em .12em;
    color:var(--red);
    font-weight:800;
    -webkit-text-stroke:3.2px var(--black);
    paint-order:stroke fill;
    text-shadow:4px 5px 0 rgba(17,17,17,.18);
    background:var(--white);
    border:var(--border);
    box-shadow:8px 8px 0 var(--black);
  }

  .message-card{
    width:min(760px,100%);
    margin-top:34px;
    padding:20px 30px;
    background:var(--white);
    border:var(--border);
    box-shadow:var(--shadow);
    font-weight:800;
    font-size:clamp(17px,2vw,25px);
    line-height:1.62;
    transform:rotate(-.4deg);
  }

  .message-card .line{
    display:block;
    white-space:nowrap;
  }

  .message-card .spark{
    color:var(--red);
  }

  .hero-actions{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:24px;
    width:min(760px,100%);
    margin-top:28px;
  }

  .hero-actions .pop-button{
    width:100%;
    min-width:0;
    background:var(--white);
    white-space:nowrap;
    letter-spacing:.02em;
    font-size:clamp(17px,2vw,25px);
  }

  .pop-button{
    min-width:270px;
    min-height:72px;
    padding:14px 30px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border:var(--border);
    box-shadow:var(--shadow);
    font-family:var(--display);
    font-weight:800;
    font-size:clamp(18px,2.35vw,30px);
    letter-spacing:.08em;
    transition:transform .18s ease, box-shadow .18s ease;
  }

  .pop-button:hover{
    transform:translate(5px,5px);
    box-shadow:5px 5px 0 var(--black);
  }

  .pop-button--primary{background:var(--yellow)}
  .pop-button--secondary{background:var(--white)}

  .sticky-cta .pop-button--secondary,
  .footer-cta .pop-button--secondary{
    background:var(--yellow);
  }

  .sticky-cta{
    position:fixed;
    left:50%;
    bottom:18px;
    width:min(920px,calc(100vw - 28px));
    transform:translate(-50%, calc(100% + 46px));
    z-index:120;
    display:flex;
    gap:16px;
    padding:14px;
    background:var(--white);
    border:5px solid var(--black);
    box-shadow:8px 8px 0 var(--black);
    opacity:0;
    pointer-events:none;
    transition:transform .25s ease, opacity .25s ease;
  }

  .sticky-cta.is-visible{
    transform:translate(-50%, 0);
    opacity:1;
    pointer-events:auto;
  }

  .sticky-cta .pop-button{
    flex:1;
    min-width:0;
    min-height:64px;
    padding:12px 18px;
    font-size:clamp(15px,2.8vw,28px);
    box-shadow:5px 5px 0 var(--black);
  }

  .visual-stage{
    position:relative;
    min-height:520px;
    z-index:3;
  }

  .slider-window{
    position:absolute;
    right:-2%;
    top:17%;
    width:min(470px,38vw);
    aspect-ratio:1;
    transform:none;
    filter:drop-shadow(12px 12px 0 var(--black));
  }

  .hex-slider{
    width:100%;
    height:100%;
    overflow:visible;
    background:transparent;
    padding:0;
  }

  .hex-track{
    position:relative;
    height:100%;
  }

  .hex-slide{
    position:absolute;
    inset:0;
    height:100%;
    width:100%;
    min-width:0;
    clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0 50%);
    background:var(--black);
    overflow:hidden;
    opacity:0;
    transform:translateX(58%);
    animation:hexFrameSlide 24s cubic-bezier(.72,0,.22,1) infinite;
  }

  .hex-slide::before{
    content:"";
    position:absolute;
    inset:7px;
    clip-path:inherit;
    background:
      radial-gradient(circle at 52% 38%, rgba(255,255,255,.9) 0 4%, transparent 4.5%),
      linear-gradient(135deg, rgba(252,227,3,.95), rgba(235,80,80,.88) 45%, rgba(94,214,134,.92));
    z-index:0;
  }

  .hex-slide:nth-child(2){
    animation-delay:4s;
  }

  .hex-slide:nth-child(3){
    animation-delay:8s;
  }

  .hex-slide:nth-child(4){
    animation-delay:12s;
  }

  .hex-slide:nth-child(5){
    animation-delay:16s;
  }

  .hex-slide:nth-child(6){
    animation-delay:20s;
  }

  .hex-slide:nth-child(2)::before{
    background:
      radial-gradient(circle at 42% 34%, rgba(255,255,255,.88) 0 4%, transparent 4.5%),
      linear-gradient(135deg, rgba(94,214,134,.95), rgba(252,227,3,.88) 50%, rgba(235,80,80,.88));
  }

  .hex-slide:nth-child(3)::before{
    background:
      radial-gradient(circle at 56% 34%, rgba(255,255,255,.88) 0 4%, transparent 4.5%),
      linear-gradient(135deg, rgba(235,80,80,.95), rgba(252,227,3,.9) 52%, rgba(94,214,134,.92));
  }

  .hex-slide:nth-child(4)::before{
    background:
      radial-gradient(circle at 47% 35%, rgba(255,255,255,.88) 0 4%, transparent 4.5%),
      linear-gradient(135deg, rgba(252,227,3,.95), rgba(94,214,134,.9) 48%, rgba(235,80,80,.92));
  }

  .hex-slide:nth-child(5)::before{
    background:
      radial-gradient(circle at 48% 38%, rgba(255,255,255,.88) 0 4%, transparent 4.5%),
      linear-gradient(135deg, rgba(94,214,134,.92), rgba(235,80,80,.9) 45%, rgba(252,227,3,.92));
  }

  .hex-slide:nth-child(6)::before{
    background:
      radial-gradient(circle at 50% 36%, rgba(255,255,255,.88) 0 4%, transparent 4.5%),
      linear-gradient(135deg, rgba(235,80,80,.92), rgba(94,214,134,.9) 50%, rgba(252,227,3,.95));
  }

  .hex-slide img{
    position:absolute;
    inset:7px;
    width:calc(100% - 14px);
    height:calc(100% - 14px);
    object-fit:cover;
    object-position:center 34%;
    clip-path:inherit;
    z-index:1;
    display:block;
  }

  .hex-slide:nth-child(2) img{object-position:center 30%}
  .hex-slide:nth-child(3) img{object-position:center 28%}
  .hex-slide:nth-child(4) img{object-position:center 38%}
  .hex-slide:nth-child(5) img{object-position:center 34%}
  .hex-slide:nth-child(6) img{object-position:center 31%}

  .hex-slide:nth-child(1) img,
  .hex-slide:nth-child(2) img,
  .hex-slide:nth-child(5) img{
    object-fit:contain;
    object-position:center;
    background:var(--white);
  }

  @keyframes hexFrameSlide{
    0%{opacity:0;transform:translateX(58%) scale(.98)}
    5%,14%{opacity:1;transform:translateX(0) scale(1)}
    18%{opacity:0;transform:translateX(-58%) scale(.98)}
    100%{opacity:0;transform:translateX(-58%) scale(.98)}
  }

  .person{
    position:absolute;
    left:50%;
    bottom:0;
    width:72%;
    height:90%;
    transform:translateX(-50%);
    z-index:1;
  }

  .hair,
  .face,
  .neck,
  .body,
  .mic,
  .hand{
    position:absolute;
    left:50%;
    transform:translateX(-50%);
  }

  .hair{
    top:4%;
    width:47%;
    aspect-ratio:.82;
    border-radius:48% 48% 38% 38%;
    background:linear-gradient(120deg,#4a2516,#b46c2f 55%,#2b1711);
    border:6px solid var(--black);
  }

  .face{
    top:18%;
    width:35%;
    aspect-ratio:.78;
    border-radius:46% 46% 42% 42%;
    background:#ffd9bd;
    border:5px solid var(--black);
    z-index:3;
  }

  .face::before,
  .face::after{
    content:"";
    position:absolute;
    top:42%;
    width:12px;
    height:12px;
    border-radius:50%;
    background:var(--black);
  }

  .face::before{left:28%}
  .face::after{right:28%}

  .smile{
    position:absolute;
    left:50%;
    bottom:23%;
    width:44px;
    height:19px;
    border-bottom:5px solid var(--red);
    border-radius:0 0 50px 50px;
    transform:translateX(-50%);
  }

  .neck{
    top:49%;
    width:14%;
    height:12%;
    background:#ffd9bd;
    border-left:5px solid var(--black);
    border-right:5px solid var(--black);
    z-index:2;
  }

  .body{
    bottom:-5%;
    width:58%;
    height:42%;
    border-radius:42px 42px 0 0;
    background:var(--white);
    border:6px solid var(--black);
    z-index:2;
  }

  .mic{
    left:27%;
    bottom:10%;
    width:17%;
    height:25%;
    border-radius:26px 26px 8px 8px;
    background:var(--black);
    z-index:4;
  }

  .mic::after{
    content:"";
    position:absolute;
    left:50%;
    bottom:-44%;
    width:8px;
    height:60px;
    background:var(--black);
    transform:translateX(-50%);
  }

  .hand{
    right:16%;
    left:auto;
    top:42%;
    width:14%;
    height:23%;
    border-radius:24px;
    background:#ffd9bd;
    border:5px solid var(--black);
    transform:rotate(-14deg);
    z-index:4;
  }

  .person--bob .hair{
    width:43%;
    top:8%;
    border-radius:45% 45% 52% 52%;
    background:linear-gradient(120deg,#171717,#593321 55%,#111);
  }

  .person--bob .body{background:#78d8ff}
  .person--bob .mic{display:none}
  .person--bob .hand{right:20%;top:38%;height:19%}

  .person--wave .hair{
    width:50%;
    top:6%;
    border-radius:48% 48% 45% 45%;
    background:linear-gradient(120deg,#2c1711,#7c3a22 50%,#321510);
  }

  .person--wave .body{background:#fff1f1}
  .person--wave .hand{left:23%;right:auto;top:36%;transform:rotate(18deg)}

  .person--pony .hair{
    width:39%;
    top:5%;
    border-radius:50%;
    background:linear-gradient(120deg,#1d1613,#6a3a1e 55%,#16100e);
  }

  .person--pony .hair::after{
    content:"";
    position:absolute;
    right:-28%;
    top:20%;
    width:42%;
    height:50%;
    border-radius:50%;
    background:#4a2516;
    border:5px solid var(--black);
  }

  .person--pony .body{background:var(--green)}
  .person--pony .mic{display:none}

  .floating-hex{
    position:absolute;
    clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0 50%);
    background:var(--black);
    z-index:2;
  }

  .floating-hex::after{
    content:"";
    position:absolute;
    inset:9px;
    clip-path:inherit;
    background:var(--yellow);
  }

  .floating-hex--one{
    width:92px;
    aspect-ratio:1;
    right:-3%;
    top:-6%;
    transform:rotate(13deg);
  }

  .floating-hex--two{
    width:64px;
    aspect-ratio:1;
    right:13%;
    top:-11%;
    transform:rotate(-20deg);
  }

  .floating-hex--two::after{background:var(--white)}

  @media (max-width:980px){
    .top-header{
      min-height:92px;
      padding:20px 20px;
    }

    .brand{gap:16px}
    .brand-mark{width:60px}
    .brand-name{font-size:clamp(36px,10vw,54px)}
    .menu-toggle{width:62px;height:52px;border-width:4px;box-shadow:5px 5px 0 var(--black)}
    .menu-toggle span,
    .menu-toggle::before,
    .menu-toggle::after{width:31px;height:4px}

    .hero{min-height:calc(100svh - 92px)}

    .hero-inner{
      min-height:calc(100svh - 92px);
      padding:76px 18px 34px;
      grid-template-columns:46% 54%;
      gap:0;
      align-items:center;
    }

    .specialized-ribbon{
      position:absolute;
      top:36px;
      left:18px;
      width:min(70vw,560px);
      min-height:50px;
      margin:0;
      padding:10px 34px;
      font-size:clamp(16px,3.45vw,28px);
      letter-spacing:.04em;
    }

    .copy-block{
      margin-top:6px;
      grid-column:1;
      grid-row:1;
    }

    .hero-title{
      font-size:clamp(24px,7.4vw,54px);
      line-height:1.5;
      text-shadow:3px 4px 0 rgba(17,17,17,.2);
    }

    .hero-title .emphasis-wrap{
      margin:10px 0 4px;
    }

    .hero-title .emphasis{
      box-shadow:6px 6px 0 var(--black);
      border-width:5px;
    }

    .visual-stage{
      grid-column:2;
      grid-row:1;
      align-self:start;
      min-height:min(66svh,560px);
      margin-top:-2px;
    }

    .slider-window{
      width:min(61vw,420px);
      top:0;
      left:auto;
      right:-12vw;
      transform:none;
    }

    .message-card{
      margin-top:54px;
      width:min(88vw,640px);
      padding:18px 20px;
      border-width:5px;
      box-shadow:7px 7px 0 var(--black);
      font-size:clamp(13px,2.75vw,22px);
      line-height:1.8;
    }

    .hero-actions{
      gap:18px;
      margin-top:28px;
      width:min(88vw,640px);
      grid-template-columns:repeat(2,minmax(0,1fr));
    }

    .hero-actions .pop-button{
      padding-inline:14px;
      font-size:clamp(16px,3.45vw,24px);
    }

    .pop-button{
      min-width:min(220px,42vw);
      min-height:74px;
      padding:14px 24px;
      font-size:clamp(17px,4.2vw,31px);
      border-width:5px;
      box-shadow:7px 7px 0 var(--black);
    }
  }

  @media (max-width:520px){
    .top-header{
      min-height:78px;
      padding:16px 18px;
    }

    .brand{gap:12px}
    .brand-mark{width:48px}
    .brand-name{font-size:clamp(34px,11vw,44px)}
    .menu-toggle{width:54px;height:46px}
    .header-nav{right:18px}

    .hero{
      min-height:calc(100svh - 78px);
      background:
        linear-gradient(138deg,
          var(--yellow) 0 38%,
          var(--red) 38% 76%,
          var(--green) 76% 100%);
    }

    .hero-inner{
      min-height:calc(100svh - 78px);
      padding:62px 14px 28px;
      grid-template-columns:45% 55%;
    }

    .specialized-ribbon{
      top:28px;
      left:12px;
      width:76vw;
      min-height:42px;
      padding:8px 18px;
      font-size:clamp(14px,4.1vw,22px);
      box-shadow:5px 7px 0 rgba(17,17,17,.22);
    }

    .copy-block{
      margin-top:2px;
    }

    .hero-title{
      font-size:clamp(24px,8.35vw,40px);
      line-height:1.58;
    }

    .hero-title .line,
    .message-card .line{
      white-space:nowrap;
    }

    .hero-title .emphasis{
      border-width:4px;
      box-shadow:5px 5px 0 var(--black);
    }

    .visual-stage{
      min-height:52svh;
      margin-top:-4px;
    }

    .slider-window{
      width:min(62vw,330px);
      right:-15vw;
      top:0;
    }

    .floating-hex--one{width:48px;right:-2%;top:-9%}
    .floating-hex--two{width:34px;right:15%;top:-13%}

    .message-card{
      width:92vw;
      margin-top:46px;
      padding:14px 14px;
      font-size:clamp(11px,3.15vw,16px);
      border-width:4px;
      box-shadow:5px 5px 0 var(--black);
    }

    .hero-actions{
      width:92vw;
      gap:14px;
      margin-top:22px;
      grid-template-columns:repeat(2,minmax(0,1fr));
    }

    .hero-actions .pop-button{
      padding-inline:8px;
      font-size:clamp(13px,3.65vw,18px);
    }

    .pop-button{
      min-width:0;
      width:100%;
      min-height:60px;
      padding:10px 10px;
      font-size:clamp(15px,4.8vw,22px);
      border-width:4px;
      box-shadow:5px 5px 0 var(--black);
    }

    .sticky-cta{
      bottom:10px;
      width:calc(100vw - 16px);
      gap:8px;
      padding:8px;
      border-width:4px;
      box-shadow:5px 5px 0 var(--black);
    }

    .sticky-cta .pop-button{
      min-height:52px;
      padding:8px 6px;
      border-width:4px;
      font-size:clamp(13px,3.9vw,18px);
    }
  }

  .section{
    position:relative;
    padding:92px clamp(18px,5vw,72px);
    border-bottom:7px solid var(--black);
    overflow:hidden;
  }

  .section::before{
    content:"";
    position:absolute;
    inset:0;
    opacity:.13;
    background-image:radial-gradient(var(--black) 3px, transparent 3.5px);
    background-size:34px 34px;
    pointer-events:none;
  }

  .section-inner{
    position:relative;
    z-index:1;
    width:min(1120px,100%);
    margin-inline:auto;
    padding-top:76px;
  }

  .section-label{
    display:inline-flex;
    align-items:center;
    gap:10px;
    min-height:44px;
    padding:8px 28px;
    margin-bottom:22px;
    background:var(--black);
    color:var(--yellow);
    clip-path:polygon(8% 0,94% 0,100% 50%,94% 100%,8% 100%,0 50%);
    font-family:var(--display);
    font-weight:800;
    font-size:clamp(13px,1.8vw,20px);
    letter-spacing:.08em;
    transform:rotate(-1deg);
  }

  .section-label::before{
    content:"P";
    display:grid;
    place-items:center;
    width:25px;
    aspect-ratio:1;
    flex:0 0 auto;
    border:3px solid var(--yellow);
    border-radius:50%;
    background:var(--white);
    color:var(--black);
    font-family:var(--display);
    font-size:14px;
    line-height:1;
    box-shadow:2px 2px 0 var(--red);
  }

  .section-title{
    margin:0 0 34px;
    font-family:var(--display);
    font-weight:800;
    font-size:clamp(34px,5.4vw,70px);
    line-height:1.28;
    color:var(--white);
    -webkit-text-stroke:3.4px var(--black);
    paint-order:stroke fill;
    text-shadow:5px 6px 0 var(--black);
  }

  .section--red .section-title,
  .section--green .section-title{
    color:var(--yellow);
    -webkit-text-stroke:3.2px var(--black);
    text-shadow:5px 6px 0 var(--red);
  }

  .section--green .section-title{
    color:var(--white);
    -webkit-text-stroke:4px var(--black);
    text-shadow:6px 7px 0 var(--red);
  }

  .section-lead{
    max-width:820px;
    margin:0 0 36px;
    font-size:clamp(16px,2vw,22px);
    line-height:2;
    font-weight:800;
  }

  .section-note{
    margin:26px 0 0;
    font-size:12px;
    line-height:1.7;
    font-weight:800;
    opacity:.72;
  }

  .section--white,
  .section--yellow{
    background:var(--white);
    color:var(--black);
  }

  .section--red,
  .section--green{
    background:var(--black);
    color:var(--white);
  }

  .section--event-calendar{
    background:var(--red);
    color:var(--white);
  }

  .section--red::before,
  .section--green::before{
    opacity:.18;
    background-image:radial-gradient(var(--white) 2.5px, transparent 3px);
  }

  .section-deco{
    position:absolute;
    left:-58px;
    top:0;
    width:420px;
    height:230px;
    pointer-events:none;
    overflow:hidden;
    z-index:0;
    opacity:.96;
    background:none;
    --deco-main:var(--pink);
    --deco-sub:var(--yellow);
    --deco-third:var(--green);
  }

  .poco-symbol{
    position:absolute;
    display:block;
    place-items:center;
    color:var(--black);
    font-family:var(--display);
    font-weight:800;
    filter:none;
  }

  .section-deco::before,
  .section-deco::after{
    content:none;
  }

  .section-deco::before{
    left:80px;
    top:28px;
    width:118px;
    height:118px;
    background:
      linear-gradient(#8a8a8a 0 0) 0 0/28px 28px no-repeat,
      linear-gradient(var(--black) 0 0) 36px 0/18px 18px no-repeat,
      linear-gradient(#c9c9c9 0 0) 0 36px/20px 20px no-repeat,
      linear-gradient(var(--red) 0 0) 38px 42px/24px 24px no-repeat,
      linear-gradient(var(--black) 0 0) 76px 18px/20px 20px no-repeat,
      linear-gradient(#bdbdbd 0 0) 74px 66px/26px 26px no-repeat;
    transform:rotate(12deg);
  }

  .section-deco::after{
    left:-66px;
    top:84px;
    width:132px;
    aspect-ratio:1;
    border:19px solid var(--black);
    border-radius:50%;
    background:transparent;
  }

  .section:nth-of-type(even) .section-deco:not(.section-deco--right){
    left:auto;
    right:-58px;
    top:0;
    background-position:right top;
  }

  main > .section:nth-of-type(2) .section-deco{
    --deco-main:var(--pink);
    --deco-sub:var(--yellow);
    --deco-third:var(--pink);
  }

  main > .section:nth-of-type(3) .section-deco{
    --deco-main:var(--green);
    --deco-sub:var(--blue);
    --deco-third:var(--green);
  }

  main > .section:nth-of-type(4) .section-deco{
    --deco-main:var(--cyan);
    --deco-sub:var(--red);
    --deco-third:var(--cyan);
  }

  main > .section:nth-of-type(5) .section-deco{
    --deco-main:var(--pink);
    --deco-sub:var(--yellow);
    --deco-third:var(--pink);
  }

  .poco-symbol--circle{
    width:48px;
    aspect-ratio:1;
    border-radius:50%;
    background:var(--deco-main);
    transform:rotate(-12deg);
  }

  .poco-symbol--donut{
    width:138px;
    aspect-ratio:1;
    border-radius:50%;
    background:radial-gradient(circle, transparent 0 34%, var(--deco-main) 35%);
    transform:rotate(8deg);
  }

  .poco-symbol--quarter{
    width:112px;
    aspect-ratio:1;
    border-radius:0 0 100% 0;
    background:var(--deco-sub);
    transform:rotate(90deg);
  }

  .poco-symbol--semi{
    width:112px;
    aspect-ratio:1;
    border-radius:50%;
    background:linear-gradient(90deg, var(--deco-main) 0 50%, transparent 50% 100%);
    transform:rotate(18deg);
  }

  .poco-symbol--triangle{
    width:0;
    height:0;
    border-top:72px solid var(--deco-sub);
    border-left:72px solid transparent;
    transform:rotate(45deg);
  }

  .poco-symbol--square{
    width:48px;
    aspect-ratio:1;
    background:var(--deco-main);
    transform:rotate(2deg);
  }

  .poco-symbol--stripe{
    width:140px;
    height:96px;
    background:linear-gradient(0deg, var(--deco-main) 0 33%, var(--deco-sub) 33% 66%, var(--deco-main) 66% 100%);
    transform:rotate(1deg);
  }

  .poco-symbol--blocks{
    width:172px;
    height:150px;
    background:
      linear-gradient(var(--deco-main) 0 0) 0 32px/42px 42px no-repeat,
      linear-gradient(var(--deco-sub) 0 0) 44px 74px/42px 42px no-repeat,
      linear-gradient(var(--deco-main) 0 0) 88px 32px/42px 42px no-repeat,
      linear-gradient(var(--deco-sub) 0 0) 132px 74px/32px 32px no-repeat,
      linear-gradient(var(--deco-third) 0 0) 44px 0/32px 32px no-repeat,
      linear-gradient(var(--deco-main) 0 0) 98px 92px/32px 32px no-repeat;
    transform:rotate(-6deg);
  }

  .poco-symbol--coin{
    width:82px;
    aspect-ratio:1;
    border:0;
    border-radius:50%;
    background:var(--deco-third);
    box-shadow:6px 6px 0 var(--black);
    transform:rotate(-10deg);
  }

  .poco-symbol--coin::before{
    content:"";
    display:grid;
    place-items:center;
    width:58%;
    aspect-ratio:1;
    border:0;
    border-radius:50%;
    background:var(--white);
    color:var(--black);
    font-family:var(--display);
    font-size:30px;
    line-height:1;
  }

  .poco-symbol--coin::after{
    content:"";
    position:absolute;
    right:9px;
    top:10px;
    width:10px;
    aspect-ratio:1;
    border-radius:50%;
    background:var(--red);
    border:3px solid var(--black);
  }

  .deco-a{left:-26px;top:128px}
  .deco-b{left:110px;top:36px}
  .deco-c{left:210px;top:-36px}
  .deco-d{left:276px;top:58px}
  .deco-e{left:316px;top:-22px}

  .deco-f{left:34px;top:-18px}
  .deco-g{left:144px;top:18px}
  .deco-h{left:236px;top:36px}

  .section-deco--right{
    left:auto;
    right:-58px;
    transform:scaleX(-1);
    background-position:left top;
  }

  .section-deco--wide{
    width:100%;
    height:240px;
    left:0;
    top:0;
    background:none;
  }

  .section-deco--wide .deco-a{left:-36px;top:76px}
  .section-deco--wide .deco-b{left:78px;top:18px}
  .section-deco--wide .deco-c{left:170px;top:96px}
  .section-deco--wide .deco-d{right:20%;left:auto;top:-18px}
  .section-deco--wide .deco-e{right:7%;left:auto;top:58px}
  .section-deco--wide .deco-f{right:-48px;left:auto;top:108px}
  .section-deco--wide .deco-g{left:292px;top:6px}
  .section-deco--wide .deco-h{right:32%;left:auto;top:104px}

  .grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:24px;
  }

  .grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid--four{grid-template-columns:repeat(4,minmax(0,1fr))}

  .pop-card{
    background:var(--white);
    border:5px solid var(--black);
    box-shadow:8px 8px 0 var(--black);
    padding:28px;
    min-height:190px;
    transform:rotate(var(--tilt, -1deg));
    color:var(--black);
  }

  .pop-card::before{
    content:"";
    display:block;
    width:72px;
    height:12px;
    margin-bottom:18px;
    background:linear-gradient(90deg,var(--yellow) 0 33%,var(--red) 33% 66%,var(--green) 66% 100%);
    border:3px solid var(--black);
  }

  .pop-card:nth-child(even){--tilt:1deg}

  .pop-card h3{
    margin:0 0 14px;
    font-family:var(--display);
    font-weight:800;
    font-size:clamp(22px,2.4vw,32px);
    line-height:1.35;
  }

  .pop-card p{
    margin:0;
    font-size:16px;
    line-height:1.8;
    font-weight:800;
  }

  .sns-icons{
    display:flex;
    gap:22px;
    align-items:center;
    flex-wrap:wrap;
  }

  .sns-icon{
    width:96px;
    aspect-ratio:1;
    display:grid;
    place-items:center;
    background:var(--white);
    border:5px solid var(--black);
    box-shadow:8px 8px 0 var(--black);
    color:var(--black);
    font-family:var(--display);
    font-weight:800;
    font-size:34px;
    line-height:1;
    transform:rotate(-2deg);
  }

  .sns-icon:nth-child(even){
    transform:rotate(2deg);
  }

  .sns-icon--instagram{
    border-radius:28px;
  }

  .sns-icon--instagram::before{
    content:"";
    width:46px;
    aspect-ratio:1;
    border:7px solid var(--black);
    border-radius:15px;
    box-shadow:inset 0 0 0 7px var(--yellow);
  }

  .sns-icon--x{
    background:var(--yellow);
  }

  .site-footer{
    padding:34px clamp(20px,5vw,72px);
    background:var(--white);
    border-top:7px solid var(--black);
  }

  .footer-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    max-width:1180px;
    margin:0 auto;
  }

  .footer-cta{
    display:flex;
    gap:12px;
    flex:1;
    justify-content:center;
  }

  .footer-cta .pop-button{
    width:auto;
    min-width:190px;
    min-height:54px;
    padding:10px 18px;
    font-size:clamp(14px,1.8vw,20px);
    border-width:4px;
    box-shadow:5px 5px 0 var(--black);
  }

  .footer-brand{
    margin:0;
    font-family:var(--display);
    font-size:20px;
    font-weight:800;
  }

  .footer-sns{
    display:flex;
    align-items:center;
    gap:14px;
  }

  .footer-sns-label{
    font-family:var(--display);
    font-size:clamp(22px,3.2vw,34px);
    font-weight:800;
    letter-spacing:.04em;
    color:var(--yellow);
    -webkit-text-stroke:3px var(--black);
    paint-order:stroke fill;
    text-shadow:4px 5px 0 var(--red);
    white-space:nowrap;
  }

  .site-footer .sns-icon{
    width:58px;
    border-width:4px;
    box-shadow:5px 5px 0 var(--black);
    font-size:24px;
  }

  .site-footer .sns-icon--instagram{
    border-radius:16px;
  }

  .site-footer .sns-icon--instagram::before{
    width:27px;
    border-width:5px;
    border-radius:9px;
    box-shadow:inset 0 0 0 4px var(--yellow);
  }

  @media (max-width: 760px){
    .footer-inner{
      align-items:flex-start;
      flex-direction:column;
    }

    .footer-cta{
      width:100%;
      justify-content:flex-start;
      flex-wrap:nowrap;
      gap:8px;
    }

    .footer-cta .pop-button{
      width:50%;
      min-width:0;
      min-height:50px;
      padding:8px 6px;
      font-size:clamp(12px,3.25vw,16px);
      white-space:nowrap;
    }
  }

  .big-number{
    display:block;
    margin-bottom:8px;
    color:var(--red);
    font-family:var(--display);
    font-weight:800;
    font-size:clamp(42px,6vw,74px);
    line-height:1;
    -webkit-text-stroke:2.4px var(--black);
    paint-order:stroke fill;
    text-shadow:4px 4px 0 var(--black);
  }

  .flow-line{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:28px;
    align-items:stretch;
  }

  .flow-node{
    background:var(--white);
    border:5px solid var(--black);
    box-shadow:8px 8px 0 var(--black);
    padding:30px;
    text-align:center;
    color:var(--black);
  }

  .flow-node strong{
    display:block;
    font-family:var(--display);
    font-weight:800;
    font-size:clamp(26px,3.6vw,42px);
    margin-bottom:10px;
    color:var(--yellow);
    -webkit-text-stroke:2.4px var(--black);
    paint-order:stroke fill;
    text-shadow:3px 3px 0 var(--black);
  }

  .compare-table{
    width:100%;
    border-collapse:separate;
    border-spacing:0;
    background:var(--white);
    border:5px solid var(--black);
    box-shadow:8px 8px 0 var(--black);
    overflow:hidden;
    font-weight:800;
    color:var(--black);
  }

  .compare-table th,
  .compare-table td{
    padding:18px 14px;
    border-right:4px solid var(--black);
    border-bottom:4px solid var(--black);
    text-align:center;
  }

  .compare-table th{
    background:var(--yellow);
    font-family:var(--display);
    font-weight:800;
  }

  .compare-table tr:last-child td{border-bottom:0}
  .compare-table th:last-child,
  .compare-table td:last-child{border-right:0}

  .calendar-list,
  .news-list,
  .faq-list{
    display:grid;
    gap:18px;
  }

  .event-calendar{
    background:var(--white);
    border:5px solid var(--black);
    box-shadow:8px 8px 0 var(--black);
    padding:18px;
    color:var(--black);
  }

  .calendar-month{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:16px;
    margin-bottom:16px;
    padding:12px 16px;
    background:var(--yellow);
    border:4px solid var(--black);
    font-family:var(--display);
    font-weight:800;
    font-size:clamp(20px,3vw,34px);
  }

  .section-title-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    margin-bottom:34px;
    flex-wrap:wrap;
  }

  .section-title-row .section-title{
    margin-bottom:0;
  }

  .month-tabs{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
  }

  .month-tab{
    padding:10px 16px;
    border:4px solid var(--black);
    background:var(--white);
    box-shadow:5px 5px 0 var(--black);
    color:var(--black);
    font-family:var(--display);
    font-weight:800;
    font-size:15px;
    cursor:pointer;
    transform:rotate(-1deg);
  }

  .month-tab:nth-child(even){
    transform:rotate(1deg);
  }

  .month-tab.is-active{
    background:var(--yellow);
  }

  .calendar-grid{
    display:grid;
    grid-template-columns:repeat(7,minmax(0,1fr));
    border-top:4px solid var(--black);
    border-left:4px solid var(--black);
  }

  .calendar-day-name,
  .calendar-cell{
    min-height:92px;
    padding:8px;
    border-right:4px solid var(--black);
    border-bottom:4px solid var(--black);
    background:var(--white);
  }

  .calendar-day-name{
    min-height:auto;
    text-align:center;
    background:var(--black);
    color:var(--yellow);
    font-family:var(--display);
    font-weight:800;
    font-size:13px;
  }

  .calendar-cell{
    display:flex;
    flex-direction:column;
    gap:6px;
    font-weight:800;
  }

  .calendar-cell.is-muted{
    background:#f2f2f2;
    color:#aaa;
  }

  .calendar-date{
    font-family:var(--display);
    font-size:15px;
  }

  .calendar-event{
    display:block;
    padding:6px 7px;
    background:var(--yellow);
    border:3px solid var(--black);
    font-size:11px;
    line-height:1.35;
    box-shadow:3px 3px 0 var(--black);
  }

  .calendar-event small{
    display:block;
    margin-bottom:2px;
    font-size:10px;
    letter-spacing:.04em;
  }

  .calendar-event--office{
    background:var(--yellow);
  }

  .calendar-event--app{
    background:var(--green);
  }

  .calendar-legend{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
    margin:-18px 0 18px;
  }

  .calendar-legend-item{
    display:inline-flex;
    align-items:center;
    min-height:34px;
    padding:6px 12px;
    border:3px solid var(--black);
    font-weight:900;
    font-size:13px;
  }

  .calendar-legend-item--office{
    background:var(--yellow);
  }

  .calendar-legend-item--app{
    background:var(--green);
  }

  .list-row{
    display:grid;
    grid-template-columns:130px 1fr;
    gap:18px;
    align-items:center;
    background:var(--white);
    border:5px solid var(--black);
    box-shadow:7px 7px 0 var(--black);
    padding:18px 22px;
    font-weight:800;
    color:var(--black);
  }

  .list-row time,
  .list-badge{
    display:inline-flex;
    justify-content:center;
    align-items:center;
    min-height:42px;
    padding:8px 14px;
    background:var(--yellow);
    border:4px solid var(--black);
    font-family:var(--display);
    font-size:15px;
  }

  .news-hint{
    margin:0 0 22px;
    text-align:center;
    font-family:var(--display);
    font-size:clamp(13px,2vw,18px);
    font-weight:800;
    letter-spacing:.08em;
    color:var(--black);
    opacity:.72;
  }

  .news-track{
    display:flex;
    gap:24px;
    margin-inline:calc(50% - 50vw);
    padding:10px max(28px,calc((100vw - 1120px) / 2)) 22px;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    scrollbar-color:var(--red) var(--white);
  }

  .news-track::-webkit-scrollbar{
    height:14px;
  }

  .news-track::-webkit-scrollbar-track{
    background:var(--white);
    border:3px solid var(--black);
    border-radius:999px;
  }

  .news-track::-webkit-scrollbar-thumb{
    background:var(--red);
    border:3px solid var(--black);
    border-radius:999px;
  }

  .news-card{
    flex:0 0 min(330px,78vw);
    scroll-snap-align:start;
    background:var(--white);
    border:5px solid var(--black);
    box-shadow:7px 7px 0 var(--black);
    padding:16px;
    transform:rotate(-.6deg);
    cursor:pointer;
  }

  .news-card:focus-visible{
    outline:4px solid var(--red);
    outline-offset:5px;
  }

  .news-thumb-img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }

  .news-thumb--image::before,
  .news-thumb--image::after{
    display:none;
  }

  .liver-image-link{
    display:block;
    width:100%;
    height:100%;
  }

  .liver-image-link .news-thumb-img{
    transition:transform .22s ease;
  }

  .liver-image-link:hover .news-thumb-img,
  .liver-image-link:focus-visible .news-thumb-img{
    transform:scale(1.04);
  }

  .liver-archive-card{
    cursor:default;
  }

  .news-more{
    flex:0 0 140px;
    display:grid;
    place-items:center;
    scroll-snap-align:start;
  }

  .news-more-icon{
    width:96px;
    aspect-ratio:1;
    display:grid;
    place-items:center;
    gap:4px;
    border:4px solid var(--black);
    border-radius:50%;
    background:var(--yellow);
    color:var(--black);
    font-family:var(--display);
    font-size:42px;
    font-weight:900;
    text-align:center;
  }

  .news-more-icon span{
    display:block;
    font-size:12px;
    line-height:1.2;
    letter-spacing:.04em;
  }

  .news-panel{
    margin-top:28px;
    padding:22px;
    background:var(--white);
    border:4px solid var(--black);
  }

  .news-panel[hidden]{
    display:none;
  }

  .news-panel-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:18px;
    margin-bottom:20px;
  }

  .news-panel-head h3{
    margin:8px 0 0;
    font-size:clamp(30px,5vw,56px);
    line-height:1.05;
    font-weight:900;
  }

  .news-panel-close{
    width:48px;
    height:48px;
    display:grid;
    place-items:center;
    border:3px solid var(--black);
    background:var(--yellow);
    color:var(--black);
    font-family:var(--display);
    font-size:30px;
    font-weight:900;
    cursor:pointer;
  }

  .news-panel .grid{
    margin-top:0;
  }

  .news-panel .news-card{
    flex:auto;
    transform:none;
    cursor:default;
  }

  .interview-thumb-img{
    width:100%;
    height:100%;
    min-height:190px;
    object-fit:cover;
    display:block;
  }

  .news-card:nth-child(even){
    transform:rotate(.6deg);
  }

  .news-thumb{
    position:relative;
    display:grid;
    place-items:center;
    min-height:180px;
    margin-bottom:16px;
    border:4px solid var(--black);
    overflow:hidden;
    background:
      linear-gradient(135deg, rgba(252,227,3,.86), rgba(235,80,80,.82) 52%, rgba(94,214,134,.78)),
      radial-gradient(circle at 20% 20%, var(--white) 0 9px, transparent 10px);
  }

  .news-thumb::before,
  .news-thumb::after{
    content:"";
    position:absolute;
    width:72px;
    height:72px;
    border:4px solid var(--black);
    background:var(--yellow);
  }

  .news-thumb::before{
    left:22px;
    top:24px;
    border-radius:50%;
  }

  .news-thumb::after{
    right:24px;
    bottom:22px;
    clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);
    background:var(--green);
  }

  .news-thumb-text{
    position:relative;
    z-index:1;
    padding:8px 18px;
    background:var(--white);
    border:4px solid var(--black);
    box-shadow:5px 5px 0 var(--black);
    font-family:var(--display);
    font-size:22px;
    font-weight:800;
  }

  .news-category{
    display:inline-flex;
    align-items:center;
    min-height:36px;
    margin-bottom:14px;
    padding:6px 16px;
    background:var(--red);
    border:4px solid var(--black);
    color:var(--white);
    font-family:var(--display);
    font-size:14px;
    font-weight:800;
    letter-spacing:.16em;
  }

  .news-card h3{
    margin:0;
    font-size:clamp(18px,2.3vw,24px);
    line-height:1.55;
    font-weight:800;
  }

  .news-detail{
    display:grid;
    gap:12px;
    max-height:0;
    margin-top:0;
    opacity:0;
    overflow:hidden;
    transition:max-height .28s ease, opacity .22s ease, margin-top .22s ease;
  }

  .news-card.is-open .news-detail{
    max-height:280px;
    margin-top:16px;
    opacity:1;
  }

  .news-detail.is-static{
    max-height:none;
    margin-top:16px;
    opacity:1;
    overflow:visible;
  }

  .news-body{
    margin:0;
    font-size:15px;
    line-height:1.75;
    font-weight:800;
  }

  .news-meta,
  .news-date{
    margin:0;
    padding-top:14px;
    border-top:2px dashed var(--black);
    color:var(--red);
    font-family:var(--display);
    font-size:14px;
    font-weight:800;
    letter-spacing:.08em;
  }

  .news-more{
    flex:0 0 150px;
    scroll-snap-align:start;
    display:grid;
    place-items:center;
  }

  .news-more .pop-button{
    width:118px;
    height:118px;
    min-height:0;
    padding:0;
    border-radius:50%;
    justify-content:center;
    text-align:center;
    font-size:16px;
    line-height:1.25;
    flex-direction:column;
    gap:4px;
    transform:rotate(4deg);
  }

  .news-more .pop-button::after{
    content:"➜";
    display:block;
    font-size:24px;
    line-height:1;
  }

  .news-modal[hidden]{
    display:none !important;
  }

  .news-modal{
    position:fixed;
    inset:0;
    z-index:10000;
    display:grid;
    place-items:center;
    padding:24px;
  }

  .news-modal-backdrop{
    position:absolute;
    inset:0;
    background:rgba(17,17,17,.72);
  }

  .news-modal-card{
    position:relative;
    z-index:1;
    width:min(720px,100%);
    max-height:calc(100dvh - 48px);
    overflow:auto;
    padding:28px;
    background:var(--white);
    border:4px solid var(--black);
    color:var(--black);
  }

  .news-modal-close{
    position:absolute;
    top:14px;
    right:14px;
    width:44px;
    height:44px;
    display:grid;
    place-items:center;
    border:3px solid var(--black);
    border-radius:999px;
    background:var(--yellow);
    color:var(--black);
    font-size:28px;
    font-weight:900;
    line-height:1;
    cursor:pointer;
  }

  .news-modal-thumb{
    width:100%;
    aspect-ratio:1.08 / 1;
    margin-bottom:18px;
    border:3px solid var(--black);
    overflow:hidden;
    background:var(--light-blue);
  }

  .news-modal-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }

  .news-modal-card .news-category{
    margin-right:52px;
  }

  .news-modal-card h3{
    margin:0 0 16px;
    font-size:clamp(24px,4vw,42px);
    line-height:1.25;
    font-weight:900;
  }

  .news-modal-card .news-body{
    white-space:pre-line;
    font-size:clamp(16px,2.2vw,18px);
    line-height:1.9;
  }

  .is-news-modal-open{
    overflow:hidden;
  }

  @media (max-width:640px){
    .news-modal{
      padding:14px;
    }

    .news-modal-card{
      padding:20px 16px;
    }

    .news-modal-close{
      top:10px;
      right:10px;
    }
  }

  .rank-card{
    position:relative;
    width:100%;
    display:flex;
    flex-direction:column;
    gap:14px;
    align-items:center;
    background:var(--white);
    border:0;
    border-radius:22px;
    box-shadow:none;
    padding:0 0 4px;
    color:var(--black);
    overflow:visible;
  }

  .rank-card--top{
    grid-column:1/-1;
    max-width:720px;
    justify-self:center;
  }

  .rank-card--small{
    min-width:0;
  }

  .rank-icon{
    width:100%;
    aspect-ratio:1/1;
    display:grid;
    place-items:center;
    border:6px solid #48d1cc;
    border-radius:18px;
    background:linear-gradient(135deg,#fff6a4,var(--yellow) 45%,#6ed86b);
    box-shadow:none;
    color:var(--black);
    font-family:var(--display);
    font-size:clamp(44px,10vw,92px);
    font-weight:800;
    overflow:hidden;
  }

  .rank-card--top .rank-icon{
    aspect-ratio:1.06/1;
    border-width:7px;
    border-radius:20px;
  }

  .rank-icon img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }

  .ranking-tabs{
    display:flex;
    gap:14px;
    margin:0 0 24px;
    flex-wrap:wrap;
  }

  .ranking-tab{
    min-width:180px;
    padding:14px 22px;
    border:5px solid var(--black);
    background:var(--white);
    box-shadow:6px 6px 0 var(--black);
    color:var(--black);
    cursor:pointer;
    font-family:var(--display);
    font-weight:800;
    font-size:18px;
    transform:rotate(-1deg);
  }

  .ranking-tab:nth-child(even){
    transform:rotate(1deg);
  }

  .ranking-tab.is-active{
    background:var(--red);
    color:var(--white);
  }

  .ranking-panel{
    display:none;
    gap:28px;
  }

  .ranking-panel.is-active{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,360px))!important;
    justify-content:center;
    align-items:start;
    max-width:860px;
    margin:0 auto;
  }

  .rank-no{
    position:absolute;
    top:0;
    left:26px;
    z-index:2;
    width:64px;
    height:96px;
    display:grid;
    place-items:center;
    clip-path:polygon(0 0,100% 0,100% 100%,50% 78%,0 100%);
    background:var(--yellow);
    color:var(--white);
    font-family:var(--display);
    font-weight:800;
    font-size:30px;
    -webkit-text-stroke:0;
    paint-order:normal;
  }

  .rank-card--small .rank-no{
    left:18px;
    width:54px;
    height:82px;
    background:#cfd6d2;
    font-size:24px;
  }

  .rank-card--small:nth-child(3) .rank-no{
    background:#ed9a72;
  }

  .rank-card strong{
    max-width:100%;
    color:var(--sesang-ink);
    font-size:clamp(22px,3.2vw,34px);
    font-weight:900;
    line-height:1.25;
    text-align:center;
    overflow-wrap:anywhere;
  }

  .rank-card--small strong{
    font-size:clamp(18px,2.4vw,26px);
  }

  @media (max-width:640px){
    .ranking-panel.is-active{
      grid-template-columns:repeat(2,minmax(0,1fr))!important;
      gap:18px 14px;
      max-width:100%;
    }

    .rank-card{
      gap:10px;
    }

    .rank-card--top{
      max-width:100%;
    }

    .rank-card--top .rank-icon{
      border-width:5px;
      border-radius:16px;
    }

    .rank-icon{
      border-width:5px;
      border-radius:14px;
      font-size:clamp(34px,14vw,64px);
    }

    .rank-no{
      left:18px;
      width:48px;
      height:74px;
      font-size:24px;
    }

    .rank-card--small .rank-no{
      left:12px;
      width:38px;
      height:58px;
      font-size:18px;
    }

    .rank-card strong{
      font-size:clamp(20px,7vw,28px);
    }

    .rank-card--small strong{
      font-size:clamp(15px,4.6vw,18px);
    }
  }

  .simple-form{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
    background:var(--white);
    border:5px solid var(--black);
    box-shadow:8px 8px 0 var(--black);
    padding:28px;
    color:var(--black);
  }

  .simple-form label{
    display:grid;
    gap:8px;
    font-weight:800;
  }

  .simple-form input,
  .simple-form textarea{
    width:100%;
    min-height:54px;
    padding:12px 14px;
    border:4px solid var(--black);
    font:inherit;
    font-weight:800;
  }

  .simple-form textarea,
  .simple-form .form-wide{
    grid-column:1 / -1;
  }

  .simple-form textarea{min-height:130px;resize:vertical}

  @media (max-width:820px){
    .section{padding:70px 18px}
    .section-deco{
      width:300px;
      height:140px;
      transform-origin:left top;
    }

    .section-deco:not(.section-deco--right){
      transform:scale(.72);
    }

    .section-deco--right{
      transform:scaleX(-1) scale(.72);
      transform-origin:right top;
    }

    .section-deco--wide{
      width:100%;
      transform:scale(.7);
    }

    .section-inner{
      padding-top:58px;
    }

    .grid,
    .grid--two,
    .grid--four,
    .flow-line{
      grid-template-columns:1fr;
    }

    .list-row{
      grid-template-columns:1fr;
      gap:10px;
    }

    .event-calendar{
      padding:8px;
    }

    .calendar-grid{
      min-width:0;
      border-top-width:3px;
      border-left-width:3px;
    }

    .calendar-month{
      margin-bottom:10px;
      padding:9px 10px;
    }

    .calendar-day-name,
    .calendar-cell{
      min-height:58px;
      padding:4px;
      border-right-width:3px;
      border-bottom-width:3px;
    }

    .calendar-day-name{
      min-height:auto;
      font-size:9px;
      padding:5px 2px;
    }

    .calendar-date{
      font-size:11px;
    }

    .calendar-event{
      font-size:8px;
      padding:3px 3px;
      border-width:2px;
      box-shadow:2px 2px 0 var(--black);
      word-break:break-all;
    }

    .section-title-row{
      align-items:flex-start;
      gap:14px;
    }

    .month-tabs{
      width:100%;
    }

    .month-tab{
      flex:1;
      min-width:0;
      padding:8px 6px;
      font-size:12px;
    }

    .compare-table{
      font-size:13px;
    }

    .compare-table th,
    .compare-table td{
      padding:12px 8px;
    }

    .simple-form{
      grid-template-columns:1fr;
      padding:20px;
    }
  }

/* Current top hero mockup sync override: 2026-05-22 */
.hero-logo{
  display:none;
}

@media (min-width:981px){
  .hero{
    min-height:680px;
    background:linear-gradient(143deg,var(--yellow) 0 30%,var(--red) 30% 76%,var(--green) 76% 100%) !important;
  }
  .hero::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:-1;
    opacity:.30;
    pointer-events:none;
    background:
      url("data:image/svg+xml,%3Csvg width='132' height='132' viewBox='0 0 132 132' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='66 10 115 38 115 94 66 122 17 94 17 38' fill='none' stroke='white' stroke-width='5' opacity='.7'/%3E%3C/svg%3E") 12px 18px/142px 142px,
      url("data:image/svg+xml,%3Csvg width='92' height='92' viewBox='0 0 92 92' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='46 10 78 28 78 64 46 82 14 64 14 28' fill='white' opacity='.35'/%3E%3C/svg%3E") 74px 80px/174px 174px;
  }
  .hero::after{
    background:linear-gradient(143deg,transparent 0 30%,var(--black) 30% 30.5%,transparent 30.5% 76%,var(--black) 76% 76.5%,transparent 76.5% 100%) !important;
    opacity:1;
  }
  .hero-inner{
    display:block;
    min-height:680px;
    width:min(1180px,100%);
    padding:0 56px 54px;
  }
  .hero-logo{
    display:block;
    position:absolute;
    top:118px;
    left:48px;
    right:auto;
    z-index:4;
    color:var(--white);
    font-family:'Inter',var(--display),system-ui,sans-serif;
    font-size:142px;
    font-style:italic;
    font-weight:900;
    letter-spacing:-.065em;
    line-height:.9;
    white-space:nowrap;
    text-shadow:0 9px 16px rgba(0,0,0,.28) !important;
    -webkit-text-stroke:0 !important;
  }
  .specialized-ribbon{
    top:50px;
    left:56px;
    width:420px;
    min-height:56px;
    padding:14px 46px;
    font-size:23px;
    box-shadow:none !important;
  }
  .copy-block{
    width:480px;
    margin-top:0;
    padding-top:318px;
  }
  .hero-title{
    color:var(--white);
    font-size:43px;
    line-height:1.45;
    letter-spacing:-.035em;
    text-shadow:0 2px 0 rgba(0,0,0,.2) !important;
    -webkit-text-stroke:1.2px var(--black) !important;
  }
  .hero-title .emphasis-wrap{
    display:flex;
    align-items:center;
    gap:.32em;
    margin:.18em 0 .22em;
  }
  .hero-title .emphasis{
    padding:.03em .2em .09em;
    border:3px solid var(--black);
    color:var(--red);
    box-shadow:none !important;
    -webkit-text-stroke:1px var(--black) !important;
  }
  .hero-actions{
    width:360px;
    gap:18px;
    margin-top:74px;
    grid-template-columns:1fr;
  }
  .hero-actions .pop-button{
    min-height:66px;
    justify-content:flex-start;
    padding:14px 26px;
    background:var(--white);
    font-size:26px;
  }
  .visual-stage{
    position:absolute;
    z-index:2;
    right:-70px;
    top:270px;
    width:520px;
    min-height:auto;
    aspect-ratio:1;
    transform:rotate(-10deg);
    transform-origin:center;
    pointer-events:none;
  }
  .slider-window{
    position:relative;
    inset:auto;
    width:100%;
    height:100%;
    aspect-ratio:1;
    transform:none;
    filter:none;
  }
  .hex-slider,
  .hex-track{
    position:relative;
    width:100%;
    height:100%;
  }
  .hex-slide,
  .hex-slide::before,
  .hex-slide img{
    clip-path:none;
  }
  .hex-slide{
    border:0;
    background:var(--black);
    transform:translateX(62%) scale(.98);
  }
  .hex-slide::before{
    inset:10px;
    background:var(--white);
  }
  .hex-slide img{
    inset:10px;
    width:calc(100% - 20px);
    height:calc(100% - 20px);
    object-fit:cover;
    object-position:center 34%;
  }
  .hex-slide:nth-child(1) img,
  .hex-slide:nth-child(2) img,
  .hex-slide:nth-child(5) img{
    object-fit:cover;
    background:transparent;
  }
  .floating-hex{
    display:none;
  }
  @keyframes hexFrameSlide{
    0%{opacity:0;transform:translateX(62%) scale(.98)}
    5%,14%{opacity:1;transform:translateX(0) scale(1)}
    18%{opacity:0;transform:translateX(-62%) scale(.98)}
    100%{opacity:0;transform:translateX(-62%) scale(.98)}
  }
}

@media (max-width:980px){
  .hero-logo{
    display:block;
    position:absolute;
    top:116px;
    left:20px;
    z-index:3;
    color:var(--white);
    font-family:'Inter',var(--display),system-ui,sans-serif;
    font-size:clamp(76px,20vw,116px);
    font-style:italic;
    font-weight:900;
    letter-spacing:-.07em;
    line-height:.9;
    white-space:nowrap;
    text-shadow:0 7px 14px rgba(0,0,0,.24) !important;
    -webkit-text-stroke:0 !important;
  }
  .copy-block{
    margin-top:0;
    padding-top:510px;
  }
}
/* Final WordPress hero sync from header_design_options.html */
.hero{
  min-height:1180px;
  background:linear-gradient(132deg,var(--yellow) 0 31%,var(--red) 31% 79%,var(--green) 79% 100%) !important;
}

.hero::before{
  content:"" !important;
  position:absolute;
  inset:0;
  z-index:-2;
  opacity:1 !important;
  background:linear-gradient(132deg,transparent 0 31%,var(--black) 31% 31.7%,transparent 31.7% 79%,var(--black) 79% 79.7%,transparent 79.7% 100%) !important;
}

.hero::after{
  content:"" !important;
  position:absolute;
  inset:0;
  z-index:-1;
  opacity:.3 !important;
  background:
    url("data:image/svg+xml,%3Csvg width='132' height='132' viewBox='0 0 132 132' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='66 10 115 38 115 94 66 122 17 94 17 38' fill='none' stroke='white' stroke-width='5' opacity='.7'/%3E%3C/svg%3E") 12px 18px/142px 142px,
    url("data:image/svg+xml,%3Csvg width='92' height='92' viewBox='0 0 92 92' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='46 10 78 28 78 64 46 82 14 64 14 28' fill='white' opacity='.35'/%3E%3C/svg%3E") 74px 80px/174px 174px !important;
}

.hero-inner{
  min-height:1180px;
  padding:0 30px 56px;
}

.specialized-ribbon{
  top:76px;
  left:30px;
  width:min(340px,80%);
  min-height:48px;
  padding:10px 30px;
  font-size:20px;
  transform:none !important;
  box-shadow:none !important;
}

.hero-logo{
  display:block;
  position:absolute;
  top:194px;
  left:24px;
  right:10px;
  z-index:4;
  color:var(--white);
  font-family:"Inter",var(--display),system-ui,sans-serif;
  font-size:116px;
  font-style:italic;
  font-weight:900;
  letter-spacing:-.07em;
  line-height:.9;
  white-space:nowrap;
  text-shadow:0 9px 16px rgba(0,0,0,.28) !important;
  -webkit-text-stroke:0 !important;
}

.copy-block{
  position:relative;
  z-index:3;
  width:100%;
  margin-top:0;
  padding-top:555px;
}

.hero-title{
  color:var(--white);
  font-size:37px;
  line-height:1.55;
  letter-spacing:-.035em;
  -webkit-text-stroke:1.2px var(--black) !important;
  text-shadow:0 2px 0 rgba(0,0,0,.2) !important;
}

.hero-title .line{
  display:block;
  white-space:nowrap;
}

.hero-title .emphasis-wrap{
  display:flex;
  align-items:center;
  gap:.32em;
  margin:.18em 0 .22em;
  white-space:nowrap;
}

.hero-title .emphasis{
  padding:.04em .18em .1em;
  border:2px solid var(--black);
  background:var(--white);
  color:var(--red);
  -webkit-text-stroke:1px var(--black) !important;
  box-shadow:none !important;
}

.hero-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
  width:270px;
  margin-top:172px;
}

.hero-actions .pop-button{
  min-height:74px;
  justify-content:center;
  padding:16px 24px;
  background:var(--white);
  color:var(--black);
  font-size:23px;
  white-space:nowrap;
  transform:none !important;
  box-shadow:none !important;
}

.visual-stage{
  position:absolute;
  z-index:2;
  right:-110px;
  top:585px;
  width:520px;
  min-height:auto;
  aspect-ratio:1;
  transform:none;
  pointer-events:none;
}

.slider-window,
.hex-slider,
.hex-track{
  position:relative;
  inset:auto;
  width:100%;
  height:100%;
  aspect-ratio:1;
  transform:none;
  filter:none;
}

.hex-slide{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0 50%);
  background:var(--black);
  overflow:hidden;
  opacity:0;
  transform:translateX(62%) scale(.98);
  animation:hexFrameSlide 24s cubic-bezier(.72,0,.22,1) infinite;
}

.hex-slide::before{
  content:"";
  position:absolute;
  inset:9px;
  clip-path:inherit;
  background:var(--white);
  z-index:0;
}

.hex-slide img{
  position:absolute;
  inset:9px;
  width:calc(100% - 18px);
  height:calc(100% - 18px);
  display:block;
  object-fit:cover;
  object-position:center 34%;
  clip-path:inherit;
  z-index:1;
}

.hex-slide:nth-child(1) img{object-position:center 36%}
.hex-slide:nth-child(2) img{object-position:center 31%}
.hex-slide:nth-child(3) img{object-position:center 28%}
.hex-slide:nth-child(4) img{object-position:center 38%}
.hex-slide:nth-child(5) img{object-position:center 40%}
.hex-slide:nth-child(6) img{object-position:center 24%}

.floating-hex{
  display:block;
  position:absolute;
  z-index:5;
  top:-78px;
  right:92px;
  width:70px;
  aspect-ratio:1;
  background:var(--yellow);
  clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0 50%);
  border:var(--line) solid var(--black);
}

.floating-hex--two{
  width:40px;
  right:128px;
  top:-106px;
  background:var(--white);
}

@media (min-width:981px){
  .hero{
    min-height:680px;
    background:linear-gradient(143deg,var(--yellow) 0 30%,var(--red) 30% 76%,var(--green) 76% 100%) !important;
  }

  .hero::before{
    background:linear-gradient(143deg,transparent 0 30%,var(--black) 30% 30.5%,transparent 30.5% 76%,var(--black) 76% 76.5%,transparent 76.5% 100%) !important;
  }

  .hero-inner{
    min-height:680px;
    width:min(1180px,100%);
    padding:0 56px 54px;
  }

  .specialized-ribbon{
    top:50px;
    left:56px;
    width:420px;
    min-height:56px;
    padding:14px 46px;
    font-size:23px;
  }

  .hero-logo{
    top:118px;
    left:48px;
    right:auto;
    font-size:142px;
    letter-spacing:-.065em;
  }

  .copy-block{
    width:480px;
    padding-top:318px;
  }

  .hero-title{
    font-size:43px;
    line-height:1.45;
  }

  .hero-title .emphasis{
    padding:.03em .2em .09em;
    border-width:3px;
  }

  .hero-actions{
    width:360px;
    gap:18px;
    margin-top:74px;
  }

  .hero-actions .pop-button{
    min-height:66px;
    justify-content:flex-start;
    padding:14px 26px;
    font-size:26px;
  }

  .visual-stage{
    top:270px;
    right:-70px;
    width:520px;
    transform:rotate(-10deg);
    transform-origin:center;
  }

  .hex-slide,
  .hex-slide::before,
  .hex-slide img{
    clip-path:none;
  }

  .hex-slide::before{
    inset:10px;
  }

  .hex-slide img{
    inset:10px;
    width:calc(100% - 20px);
    height:calc(100% - 20px);
    object-position:center 34%;
  }

  .floating-hex{
    display:none;
  }
}

/* Final hero photo sizing: match the large black reference frame while preserving the slide animation. */
.visual-stage{
  top:520px !important;
  right:-60px !important;
  width:520px !important;
  aspect-ratio:4 / 5 !important;
}

.slider-window,
.hex-slider,
.hex-track{
  aspect-ratio:4 / 5 !important;
}

.hex-slide{
  clip-path:none !important;
  border:6px solid var(--black) !important;
  box-sizing:border-box;
  background:var(--white);
}

.hex-slide::before{
  display:none !important;
}

.hex-slide img{
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  clip-path:none !important;
  object-fit:cover;
}

@media (min-width:981px){
  .visual-stage{
    top:100px !important;
    right:-210px !important;
    width:clamp(640px, 38vw, 780px) !important;
    transform:none !important;
  }
}

/* Fine tune hero photo: move the large photo frame further left. */
.visual-stage{
  right:-20px !important;
}

@media (min-width:981px){
  .visual-stage{
    right:-80px !important;
  }
}

/* Home NEWS thumbnails: fixed near-square rectangle, no overlapping symbols. */
#news .news-thumb{
  width:100%;
  aspect-ratio:1.08 / 1;
  min-height:0 !important;
  height:auto;
}

#news .news-thumb::before,
#news .news-thumb::after{
  display:none !important;
}

#news .news-thumb-img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* Home FAQ section directly after NEWS. */
.section--faq-home{
  background:var(--white);
  color:var(--black);
}

.section--faq-home .faq-list{
  display:grid;
  gap:18px;
  margin-top:28px;
}

.section--faq-home .faq-item{
  margin:0;
  box-shadow:none !important;
}

/* Footer width tune: give the footer content and CTA buttons a little more room. */
.site-footer{
  padding-left:clamp(18px,4vw,56px) !important;
  padding-right:clamp(18px,4vw,56px) !important;
}

.footer-inner{
  width:100%;
  max-width:1320px !important;
}

.footer-cta{
  width:100%;
  gap:14px !important;
}

.footer-cta .pop-button{
  flex:1 1 0;
  min-width:0 !important;
}

.apply-contact-section .page-lead{
  max-width:760px;
}

.apply-contact-form{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px 22px;
  margin-top:26px;
}

.apply-contact-form .field{
  margin:0;
}

.apply-contact-form .field span{
  display:block;
  margin-bottom:8px;
  font-weight:900;
}

.apply-contact-form .field--full,
.apply-contact-form .pop-button{
  grid-column:1/-1;
}

.apply-contact-form .pop-button{
  width:min(460px,100%);
  justify-self:center;
  background:var(--yellow);
}

.sticky-cta--global{
  display:flex;
}

.sticky-cta--global .pop-button{
  white-space:nowrap;
}

@media (max-width:760px){
  .site-footer{
    padding-left:22px !important;
    padding-right:22px !important;
  }

  .footer-cta{
    gap:10px !important;
  }

  .footer-cta .pop-button{
    width:auto !important;
    padding-left:10px !important;
    padding-right:10px !important;
  }

  .apply-contact-form{
    grid-template-columns:1fr;
  }

  .apply-contact-form .field--full,
  .apply-contact-form .pop-button{
    grid-column:auto;
  }

  .sticky-cta--global{
    flex-direction:row!important;
  }

  .sticky-cta--global .pop-button{
    min-height:54px!important;
    padding:10px 8px!important;
    font-size:clamp(13px,3.3vw,16px)!important;
  }
}

/* Apply LP hero: replace the lead copy area with Sesang branding and two CTA buttons. */
.apply-hero .apply-copy{
  align-self:center;
  max-width:680px;
  position:relative;
  z-index:2;
}

.apply-brand-title{
  margin:clamp(24px,4vw,44px) 0 clamp(26px,4vw,48px);
  color:var(--white);
  font-family:var(--display);
  font-size:clamp(82px,13vw,168px);
  font-style:italic;
  font-weight:900;
  line-height:.9;
  letter-spacing:.01em;
  filter:drop-shadow(0 8px 12px rgba(0,0,0,.24));
  white-space:nowrap;
}

.apply-hero-actions{
  display:grid;
  gap:18px;
  width:min(610px,100%);
  margin-top:clamp(20px,3vw,36px);
}

.apply-hero-cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:clamp(72px,8vw,92px);
  padding:18px clamp(26px,4vw,42px);
  border:4px solid var(--black);
  background:var(--white);
  color:var(--black);
  font-family:var(--body);
  font-size:clamp(24px,3.4vw,38px);
  font-weight:900;
  line-height:1.1;
  text-decoration:none;
  box-shadow:none;
  transition:transform .18s ease, background .18s ease;
}

.apply-hero-cta:hover,
.apply-hero-cta:focus-visible{
  transform:translateY(-2px);
}

.apply-hero-cta--primary{
  background:var(--white);
}

.apply-hero-cta--secondary{
  background:var(--white);
}

@media (min-width:981px){
  .apply-hero .apply-copy{
    padding-top:clamp(8px,2vw,28px);
  }
}

@media (max-width:760px){
  .apply-brand-title{
    font-size:clamp(72px,22vw,120px);
    margin-top:30px;
    margin-bottom:28px;
  }

  .apply-hero-actions{
    gap:14px;
  }

  .apply-hero-cta{
    min-height:68px;
    padding:15px 22px;
    font-size:clamp(22px,6vw,30px);
  }
}

/* Footer CTA buttons: match the hero red. */
.site-footer .footer-cta .pop-button,
.site-footer .footer-cta .pop-button.secondary{
  background:var(--red)!important;
  color:var(--black)!important;
}

/* CTA buttons: keep every main action button softly rounded. */
.pop-button,
.hero-actions .pop-button,
.sticky-cta .pop-button,
.footer-cta .pop-button,
.site-footer .footer-cta .pop-button,
.apply-hero-cta,
.apply-lead-cta,
.apply-fixed-line-cta,
.line-cta-box .pop-button,
.form-box .pop-button,
button.pop-button{
  border-radius:18px!important;
}

.apply-lead-cta::after{
  border-radius:14px!important;
}

/* 2026 redesign: clean white base with Sesang logo colors. */
:root{
  --sesang-red:#ff3636;
  --sesang-yellow:#ffe100;
  --sesang-green:#16c978;
  --sesang-ink:#171717;
  --sesang-muted:#5f646d;
  --sesang-line:#e9edf2;
  --sesang-cream:#fffdf4;
  --sesang-mint:#effcf5;
  --sesang-pink:#fff3f3;
  --sesang-font:"Zen Kaku Gothic New","Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
}

html body{
  background:#fff!important;
  color:var(--sesang-ink)!important;
  font-family:var(--sesang-font)!important;
}

body *,
body *::before,
body *::after{
  letter-spacing:0!important;
  text-shadow:none!important;
  box-shadow:none!important;
}

body .top-header{
  min-height:112px!important;
  padding:14px clamp(18px,4vw,56px)!important;
  background:rgba(255,255,255,.94)!important;
  border-bottom:1px solid var(--sesang-line)!important;
  backdrop-filter:blur(16px);
}

body .brand{
  gap:12px!important;
}

body .brand-mark{
  width:clamp(290px,32vw,420px)!important;
  height:84px!important;
  aspect-ratio:auto!important;
  border-radius:0!important;
  background:none!important;
  clip-path:none!important;
  overflow:hidden!important;
}

body .brand-mark::before,
body .brand-mark::after{
  display:none!important;
}

body .brand-mark::before{
  content:""!important;
  display:block!important;
  width:100%!important;
  height:100%!important;
  background:url("assets/sesang-logo-header.png") left center/contain no-repeat!important;
  clip-path:none!important;
}

body .brand-name{
  display:none!important;
}

body .menu-toggle{
  width:48px!important;
  height:48px!important;
  border:1px solid var(--sesang-line)!important;
  border-radius:999px!important;
  background:#fff!important;
}

body .menu-toggle span,
body .menu-toggle::before,
body .menu-toggle::after{
  width:24px!important;
  height:2px!important;
  background:var(--sesang-ink)!important;
  border-radius:999px!important;
}

body .header-nav{
  width:min(360px,calc(100vw - 32px))!important;
  padding:14px!important;
  gap:8px!important;
  background:#fff!important;
  border:1px solid var(--sesang-line)!important;
  border-radius:20px!important;
}

body .header-nav a{
  padding:14px 16px!important;
  background:#fff!important;
  border:1px solid var(--sesang-line)!important;
  border-radius:14px!important;
  color:var(--sesang-ink)!important;
  font-weight:900!important;
}

body .header-nav a:hover,
body .header-nav a.is-current{
  background:var(--sesang-yellow)!important;
  border-color:var(--sesang-yellow)!important;
}

body .page-hero,
body .apply-hero,
body .partner-hero,
body .hero{
  min-height:auto!important;
  padding:clamp(72px,9vw,128px) clamp(20px,6vw,86px)!important;
  background:#fff!important;
  border-bottom:1px solid var(--sesang-line)!important;
  overflow:hidden!important;
}

body .page-hero::before,
body .page-hero::after,
body .apply-hero::after,
body .partner-hero::after,
body .symbol-cloud,
body .section::before,
body .section::after,
body .deco,
body .section-deco,
body .hero-deco,
body .mv-deco,
body [class*="deco"],
body [class*="symbol"]{
  display:none!important;
}

body .apply-hero__inner,
body .partner-hero__inner,
body .hero-inner,
body .page-hero__inner,
body .inner{
  max-width:1180px!important;
}

body h1,
body .apply-title,
body .partner-title,
body .hero-title,
body .outline,
body h2,
body .section-title{
  color:var(--sesang-ink)!important;
  -webkit-text-stroke:0!important;
  paint-order:normal!important;
  font-family:var(--sesang-font)!important;
  font-weight:900!important;
  line-height:1.16!important;
  font-style:normal!important;
  transform:none!important;
  filter:none!important;
}

body h1,
body .apply-title,
body .partner-title,
body .hero-title{
  font-size:clamp(42px,7vw,92px)!important;
}

body h2,
body .outline,
body .section-title{
  font-size:clamp(32px,5vw,64px)!important;
}

body .apply-title .accent,
body .partner-title .accent{
  color:var(--sesang-red)!important;
  background:linear-gradient(transparent 60%, rgba(255,225,0,.7) 60%)!important;
  border:0!important;
  padding:0 .06em!important;
  -webkit-text-stroke:0!important;
}

body .page-label,
body .apply-kicker,
body .section-kicker,
body .badge,
body .interview-tag{
  display:inline-flex!important;
  align-items:center!important;
  width:max-content!important;
  min-height:auto!important;
  padding:0!important;
  color:var(--sesang-red)!important;
  background:transparent!important;
  border:0!important;
  border-radius:0!important;
  clip-path:none!important;
  font-size:13px!important;
  font-weight:900!important;
  line-height:1.4!important;
}

body .page-label::before{
  display:none!important;
}

body .page-lead,
body .apply-lead-card,
body .partner-lead-card,
body .card p,
body .benefit-card p,
body .faq-a,
body .line-cta-box p{
  color:var(--sesang-muted)!important;
  font-weight:700!important;
  line-height:1.9!important;
}

body .section,
body .section--white,
body .section--black,
body .flow-lp{
  padding:clamp(64px,8vw,112px) clamp(20px,6vw,84px)!important;
  background:#fff!important;
  color:var(--sesang-ink)!important;
  border-bottom:1px solid var(--sesang-line)!important;
}

body .section:nth-of-type(3n+1){
  background:#fff!important;
}

body .section:nth-of-type(3n+2){
  background:#fafdfb!important;
}

body .card,
body .benefit-card,
body .interview-card,
body .faq-item,
body .form-box,
body .table-box,
body .line-cta-box,
body .partner-metric,
body .bulk-note,
body .bulk-diagram,
body .liver-flow-board,
body .entry-catch{
  background:#fff!important;
  border:1px solid var(--sesang-line)!important;
  border-radius:24px!important;
  color:var(--sesang-ink)!important;
  padding:clamp(22px,3vw,34px)!important;
}

body .card:hover,
body .benefit-card:hover,
body .interview-card:hover{
  transform:none!important;
}

body .grid,
body .grid.two,
body .benefit-grid,
body .interview-grid{
  gap:clamp(16px,3vw,28px)!important;
}

body .card h3,
body .benefit-card h3,
body .interview-card h3,
body .faq-q{
  color:var(--sesang-ink)!important;
  font-weight:900!important;
}

body .pop-button,
body .apply-lead-cta,
body .apply-fixed-line-cta,
body .apply-hero-cta,
body button.pop-button,
body .line-cta-box .pop-button,
body .form-box .pop-button,
body .sticky-cta .pop-button,
body .footer-cta .pop-button{
  min-height:58px!important;
  padding:14px 24px!important;
  border:0!important;
  border-radius:999px!important;
  background:var(--sesang-red)!important;
  color:#fff!important;
  font-family:var(--sesang-font)!important;
  font-weight:900!important;
}

body .pop-button.secondary,
body .pop-button--secondary,
body .footer-cta .pop-button.secondary{
  background:var(--sesang-green)!important;
  color:#fff!important;
}

body .apply-lead-cta::before,
body .apply-lead-cta::after,
body .line-mark::after{
  display:none!important;
}

body .line-mark{
  background:#fff!important;
  color:var(--sesang-green)!important;
}

body input,
body textarea,
body select{
  border:1px solid var(--sesang-line)!important;
  border-radius:14px!important;
  background:#fff!important;
}

body .table{
  border:1px solid var(--sesang-line)!important;
  border-radius:24px!important;
  overflow:hidden!important;
  background:#fff!important;
}

body .table th,
body .table td{
  border:1px solid var(--sesang-line)!important;
}

body .table th{
  background:var(--sesang-yellow)!important;
  color:var(--sesang-ink)!important;
}

body .liver-flow-step,
body .flow-card{
  background:#fff!important;
  border:1px solid var(--sesang-line)!important;
  border-radius:18px!important;
  clip-path:none!important;
}

body .liver-flow-num{
  background:var(--sesang-green)!important;
  color:#fff!important;
}

body .liver-flow-step:nth-child(2n) .liver-flow-num,
body .liver-flow-step:nth-child(2n){
  background:#fff!important;
}

body .liver-flow-step:nth-child(2n) .liver-flow-num{
  background:var(--sesang-yellow)!important;
  color:var(--sesang-ink)!important;
}

body .apply-phone{
  border:1px solid var(--sesang-line)!important;
  border-radius:32px!important;
  background:
    linear-gradient(135deg, rgba(255,54,54,.1), rgba(22,201,120,.1)),
    #fff!important;
}

body .apply-phone::before{
  display:none!important;
}

body .apply-phone img{
  object-fit:contain!important;
  padding:18px!important;
  background:transparent!important;
}

body .apply-support-box,
body .apply-bubble{
  border:1px solid var(--sesang-line)!important;
  border-radius:22px!important;
}

body .apply-bubble{
  background:var(--sesang-yellow)!important;
  color:var(--sesang-ink)!important;
}

body .sticky-cta--global,
body .sticky-cta--partner{
  background:rgba(255,255,255,.9)!important;
  border:1px solid var(--sesang-line)!important;
  border-radius:999px!important;
  padding:8px!important;
  backdrop-filter:blur(16px);
}

body .site-footer{
  background:#fff!important;
  color:var(--sesang-ink)!important;
  border-top:1px solid var(--sesang-line)!important;
}

body .footer-sns-label{
  color:var(--sesang-red)!important;
  -webkit-text-stroke:0!important;
}

body .sns-icon{
  background:var(--sesang-yellow)!important;
  border:0!important;
  border-radius:999px!important;
}

@media (max-width:780px){
  body .top-header{
    min-height:88px!important;
    padding:12px 16px!important;
  }

  body .brand-mark{
    width:clamp(230px,68vw,300px)!important;
    height:64px!important;
  }

  body .brand-name{
    display:none!important;
  }

  body .page-hero,
  body .apply-hero,
  body .partner-hero,
  body .hero{
    padding:56px 18px!important;
  }

  body h1,
  body .apply-title,
  body .partner-title,
  body .hero-title{
    font-size:clamp(36px,11vw,54px)!important;
  }

  body .footer-cta{
    flex-wrap:wrap!important;
  }

  body .footer-cta .pop-button{
    width:100%!important;
  }
}

/* Redesign cleanup: remove legacy comic-style geometry and oversized display effects. */
body .page-label,
body .apply-kicker{
  margin-bottom:18px!important;
}

body .page-label::after,
body .apply-kicker::before,
body .apply-kicker::after,
body .section-kicker::before,
body .section-kicker::after,
body .badge::before,
body .badge::after{
  display:none!important;
}

body .brand-name,
body .apply-brand-title,
body .hero-logo,
body .hero-brand{
  color:var(--sesang-ink)!important;
  font-size:clamp(42px,8vw,92px)!important;
  font-style:normal!important;
  line-height:1!important;
  filter:none!important;
  transform:none!important;
}

body .apply-brand-title{
  margin:0 0 28px!important;
}

body .apply-hero__inner{
  grid-template-columns:minmax(0,1.05fr) minmax(300px,.75fr)!important;
}

body .apply-copy{
  max-width:760px!important;
}

body .apply-lead-card,
body .partner-lead-card{
  margin-top:24px!important;
  border:0!important;
  background:transparent!important;
  padding:0!important;
  font-size:clamp(16px,2vw,22px)!important;
}

body .apply-visual{
  min-height:520px!important;
}

body .section h2,
body .section .outline{
  margin-bottom:22px!important;
}

body .grid,
body .benefit-grid,
body .interview-grid{
  margin-top:34px!important;
}

body .table-box{
  overflow:hidden!important;
}

body .table{
  border-collapse:separate!important;
  border-spacing:0!important;
}

body .sticky-cta--global,
body .sticky-cta--partner{
  left:50%!important;
  right:auto!important;
  bottom:16px!important;
  width:min(720px,calc(100vw - 28px))!important;
  transform:translateX(-50%)!important;
  display:flex!important;
  gap:8px!important;
}

@media (max-width:780px){
  body .apply-hero__inner{
    grid-template-columns:1fr!important;
  }

  body .apply-visual{
    min-height:360px!important;
  }
}

/* Typography tune: modern readable gothic, close to the requested sample. */
body,
body button,
body input,
body textarea,
body select{
  font-family:var(--sesang-font)!important;
  font-feature-settings:"palt" 1!important;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

body p,
body li,
body td,
body input,
body textarea,
body select{
  font-weight:500!important;
}

body h1,
body h2,
body h3,
body .apply-title,
body .partner-title,
body .hero-title,
body .section-title,
body .outline{
  font-family:var(--sesang-font)!important;
  font-weight:900!important;
}

body .page-lead,
body .apply-lead-card,
body .partner-lead-card{
  font-weight:700!important;
}

/* First view carousel: rounded portrait cards that slide horizontally like the reference video. */
body .visual-stage{
  --hero-card-width:clamp(240px,22vw,310px);
  --hero-card-gap:clamp(22px,3vw,36px);
  top:118px!important;
  right:clamp(-120px,-5vw,-42px)!important;
  width:clamp(430px,42vw,640px)!important;
  aspect-ratio:1.12 / 1!important;
  overflow:hidden!important;
  border-radius:32px!important;
  transform:none!important;
  pointer-events:none;
  isolation:isolate;
}

body .visual-stage::before,
body .visual-stage::after{
  content:""!important;
  position:absolute;
  top:0;
  bottom:0;
  z-index:3;
  width:24%;
  pointer-events:none;
}

body .visual-stage::before{
  left:0;
  background:linear-gradient(90deg,rgba(255,255,255,.96),rgba(255,255,255,0));
}

body .visual-stage::after{
  right:0;
  background:linear-gradient(270deg,rgba(255,255,255,.96),rgba(255,255,255,0));
}

body .slider-window,
body .hex-slider{
  width:100%!important;
  height:100%!important;
  aspect-ratio:auto!important;
  overflow:hidden!important;
}

body .hex-track{
  position:absolute!important;
  top:50%!important;
  left:50%!important;
  width:max-content!important;
  height:82%!important;
  display:flex!important;
  align-items:center!important;
  gap:var(--hero-card-gap)!important;
  aspect-ratio:auto!important;
  transform:translate(calc(-50% + ((var(--hero-card-width) + var(--hero-card-gap)) / 2)),-50%)!important;
  animation:sesangHeroCardFlow 26s linear infinite!important;
  margin-left:0;
  will-change:margin-left;
}

body .hex-slide{
  position:relative!important;
  inset:auto!important;
  flex:0 0 var(--hero-card-width)!important;
  width:var(--hero-card-width)!important;
  height:100%!important;
  opacity:1!important;
  transform:none!important;
  animation:none!important;
  border:0!important;
  border-radius:24px!important;
  clip-path:none!important;
  overflow:hidden!important;
  background:linear-gradient(135deg,#fff8c8,#e9fff2)!important;
  box-shadow:0 22px 56px rgba(20,25,35,.16)!important;
}

body .hex-slide:nth-child(3n+1){
  background:linear-gradient(135deg,#fff1bf,#dff8ff)!important;
}

body .hex-slide:nth-child(3n+2){
  background:linear-gradient(135deg,#fff,#fff3f0)!important;
}

body .hex-slide:nth-child(3n){
  background:linear-gradient(135deg,#f4fff8,#fff7bf)!important;
}

body .hex-slide::before{
  display:none!important;
}

body .hex-slide img{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  object-position:center bottom!important;
  clip-path:none!important;
  display:block!important;
  transform:scale(1.02);
}

body .hex-slide:nth-child(odd){
  transform:translateY(-10px)!important;
}

body .hex-slide:nth-child(even){
  transform:translateY(12px)!important;
}

body .visual-stage .floating-hex{
  display:none!important;
}

@keyframes sesangHeroCardFlow{
  0%{margin-left:0}
  100%{margin-left:-2388px}
}

@media (max-width:980px){
  body .hero{
    min-height:1040px!important;
  }

  body .hero-inner{
    min-height:1040px!important;
  }

  body .visual-stage{
    --hero-card-width:238px;
    --hero-card-gap:22px;
    top:320px!important;
    right:50%!important;
    width:min(560px,calc(100vw - 24px))!important;
    height:360px!important;
    aspect-ratio:auto!important;
    transform:translateX(50%)!important;
  }

  body .copy-block{
    padding-top:650px!important;
  }
}

@media (max-width:640px){
  body .hero{
    min-height:980px!important;
  }

  body .hero-inner{
    min-height:980px!important;
  }

  body .visual-stage{
    --hero-card-width:210px;
    --hero-card-gap:18px;
    top:260px!important;
    height:330px!important;
    border-radius:26px!important;
  }

  body .hex-track{
    height:84%!important;
    gap:var(--hero-card-gap)!important;
  }

  body .hex-slide{
    flex-basis:var(--hero-card-width)!important;
    width:var(--hero-card-width)!important;
    border-radius:22px!important;
  }

  body .copy-block{
    padding-top:600px!important;
  }
}

/* First view composition update: red upper field, simple label, stronger main copy. */
body .hero{
  position:relative!important;
  min-height:clamp(720px,78svh,860px)!important;
  padding:0 clamp(20px,6vw,86px)!important;
  background:linear-gradient(140deg,var(--sesang-red) 0 49.4%,#1c1c1c 49.4% 50.1%,#fff 50.1% 100%)!important;
  border-bottom:1px solid var(--sesang-line)!important;
}

body .hero::before,
body .hero::after{
  display:none!important;
}

body .hero-inner{
  min-height:clamp(720px,78svh,860px)!important;
  padding:0!important;
}

body .hero-logo{
  display:none!important;
}

body .specialized-ribbon{
  top:clamp(52px,8vw,82px)!important;
  left:0!important;
  width:auto!important;
  min-height:0!important;
  padding:10px 20px!important;
  clip-path:none!important;
  border:0!important;
  border-radius:6px!important;
  background:#e60012!important;
  box-shadow:none!important;
  color:#fff!important;
  font-size:clamp(15px,1.7vw,20px)!important;
  font-weight:900!important;
  line-height:1!important;
  letter-spacing:.02em!important;
}

body .copy-block{
  position:relative!important;
  z-index:5!important;
  width:min(720px,62vw)!important;
  padding-top:clamp(132px,15vw,174px)!important;
}

body .hero-title{
  color:#fff!important;
  font-size:clamp(56px,7.2vw,92px)!important;
  line-height:1.04!important;
  letter-spacing:0!important;
  text-shadow:0 10px 28px rgba(0,0,0,.18)!important;
}

body .hero-title .line{
  display:block!important;
  white-space:normal!important;
}

body .hero-title .emphasis-wrap{
  display:flex!important;
  align-items:baseline!important;
  gap:.16em!important;
  margin:.1em 0!important;
  white-space:normal!important;
}

body .hero-title .emphasis{
  display:inline-block!important;
  padding:.02em .1em .08em!important;
  border:0!important;
  border-radius:12px!important;
  background:#fff!important;
  color:var(--sesang-red)!important;
  box-shadow:0 10px 0 rgba(255,225,0,.95)!important;
  text-shadow:none!important;
}

body .hero-actions{
  width:min(520px,100%)!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
  margin-top:36px!important;
}

body .hero-actions .pop-button{
  min-height:60px!important;
  border-radius:999px!important;
  font-size:clamp(16px,1.8vw,20px)!important;
  justify-content:center!important;
}

body .visual-stage{
  top:clamp(190px,20vw,236px)!important;
  right:clamp(-220px,-12vw,-130px)!important;
  z-index:4!important;
}

@media (max-width:980px){
  body .hero{
    min-height:980px!important;
    background:linear-gradient(142deg,var(--sesang-red) 0 52%,#1c1c1c 52% 52.7%,#fff 52.7% 100%)!important;
  }

  body .hero-inner{
    min-height:980px!important;
  }

  body .specialized-ribbon{
    left:50%!important;
    top:82px!important;
    transform:translateX(-50%)!important;
  }

  body .copy-block{
    width:calc(100vw - 40px)!important;
    padding-top:145px!important;
    margin:0 auto!important;
    text-align:center!important;
  }

  body .hero-title{
    font-size:clamp(46px,12vw,72px)!important;
  }

  body .hero-title .emphasis-wrap{
    justify-content:center!important;
  }

  body .visual-stage{
    top:470px!important;
    right:50%!important;
    transform:translateX(50%)!important;
  }

  body .hero-actions{
    margin:470px auto 0!important;
  }
}

@media (max-width:640px){
  body .hero{
    min-height:930px!important;
  }

  body .hero-inner{
    min-height:930px!important;
  }

  body .specialized-ribbon{
    top:70px!important;
    font-size:15px!important;
  }

  body .copy-block{
    width:calc(100vw - 36px)!important;
    padding-top:118px!important;
  }

  body .hero-title{
    font-size:clamp(36px,10.8vw,46px)!important;
    line-height:1.12!important;
  }

  body .hero-title .line{
    white-space:nowrap!important;
  }

  body .hero-title .emphasis-wrap{
    flex-wrap:nowrap!important;
    white-space:nowrap!important;
    gap:.12em!important;
  }

  body .hero-title .emphasis{
    border-radius:8px!important;
    box-shadow:0 7px 0 rgba(255,225,0,.95)!important;
  }

  body .visual-stage{
    top:410px!important;
  }

  body .hero-actions{
    grid-template-columns:1fr!important;
    width:min(310px,100%)!important;
    margin-top:420px!important;
  }
}

/* PC hero art direction: match the supplied composition mock. */
body .hero{
  min-height:630px!important;
  padding:0 clamp(20px,5vw,70px)!important;
  background:linear-gradient(135deg,var(--sesang-red) 0 63.8%,#fff 63.9% 100%)!important;
  isolation:isolate;
}

body .hero-inner{
  position:relative!important;
  min-height:630px!important;
  max-width:1365px!important;
  margin:0 auto!important;
}

body .hero-orbit-logo{
  position:absolute;
  top:-30px;
  left:-40px;
  z-index:1;
  width:300px;
  opacity:.82;
  filter:brightness(0) saturate(100%) invert(78%) sepia(69%) saturate(753%) hue-rotate(333deg) brightness(103%) contrast(101%);
  transform-origin:center;
  animation:sesangLogoSpin 16s linear infinite;
  pointer-events:none;
}

body .hero-orbit-logo img,
body .hero-bottom-brand img{
  display:block;
  width:100%;
  height:auto;
}

body .hero-sparkles{
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  overflow:hidden;
}

body .hero-sparkles span{
  position:absolute;
  top:48px;
  left:72px;
  width:14px;
  aspect-ratio:1;
  background:#ffd158;
  clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);
  filter:drop-shadow(0 2px 0 rgba(0,0,0,.08));
  opacity:0;
  animation:sesangDiamondScatter 5.4s ease-out infinite;
  animation-delay:var(--d);
}

body .hero-sparkles span:nth-child(3n){
  width:10px;
  background:#fff;
}

body .hero-sparkles span:nth-child(3n+2){
  width:18px;
}

body .specialized-ribbon{
  top:390px!important;
  left:0!important;
  width:520px!important;
  z-index:6!important;
  padding:0!important;
  border-radius:0!important;
  background:transparent!important;
  color:#fff!important;
  font-size:28px!important;
  line-height:1!important;
  text-align:center!important;
  text-shadow:0 3px 0 rgba(0,0,0,.12)!important;
}

body .copy-block{
  z-index:6!important;
  width:520px!important;
  padding-top:120px!important;
  margin:0!important;
}

body .hero-title{
  color:#fff!important;
  font-size:62px!important;
  line-height:1.18!important;
  text-shadow:0 4px 0 rgba(0,0,0,.16)!important;
}

body .hero-title .line{
  white-space:nowrap!important;
}

body .hero-title .emphasis-wrap{
  display:flex!important;
  gap:.1em!important;
  align-items:baseline!important;
  white-space:nowrap!important;
}

body .hero-title .emphasis{
  padding:0 .08em .04em!important;
  border-radius:0!important;
  background:var(--sesang-green)!important;
  color:#fff!important;
  box-shadow:none!important;
}

body .hero-actions{
  display:none!important;
}

body .hero-bottom-brand{
  position:absolute;
  left:0;
  top:432px;
  z-index:6;
  width:520px;
  filter:brightness(0) invert(1);
  pointer-events:none;
}

body .visual-stage{
  --hero-card-width:374px;
  --hero-card-gap:24px;
  top:104px!important;
  right:-360px!important;
  z-index:4!important;
  width:920px!important;
  height:500px!important;
  aspect-ratio:auto!important;
  border-radius:0!important;
  overflow:hidden!important;
}

body .visual-stage::before{
  width:22%!important;
  background:linear-gradient(90deg,var(--sesang-red),rgba(255,49,49,0))!important;
}

body .visual-stage::after{
  width:13%!important;
  background:linear-gradient(270deg,#fff,rgba(255,255,255,0))!important;
}

body .hex-track{
  height:100%!important;
}

body .hex-slide{
  height:100%!important;
  border-radius:28px!important;
  background:#050505!important;
  box-shadow:none!important;
}

body .hex-slide img{
  background:#050505!important;
}

@keyframes sesangLogoSpin{
  to{transform:rotate(360deg)}
}

@keyframes sesangDiamondScatter{
  0%{
    opacity:0;
    transform:translate(0,0) scale(.1) rotate(0deg);
  }
  14%{
    opacity:1;
  }
  62%{
    opacity:.95;
  }
  100%{
    opacity:0;
    transform:translate(calc(var(--x) - 72px),calc(var(--y) - 48px)) scale(1) rotate(220deg);
  }
}

@media (max-width:980px){
  body .hero{
    min-height:860px!important;
    background:linear-gradient(142deg,var(--sesang-red) 0 74%,#fff 74.2% 100%)!important;
  }

  body .hero-inner{
    min-height:860px!important;
  }

  body .hero-orbit-logo{
    width:210px;
    top:-18px;
    left:-34px;
  }

  body .specialized-ribbon{
    top:92px!important;
    left:28px!important;
    width:auto!important;
    transform:none!important;
    font-size:16px!important;
    text-align:left!important;
    white-space:nowrap!important;
  }

  body .copy-block{
    position:absolute!important;
    top:128px!important;
    left:28px!important;
    transform:none!important;
    width:min(350px,calc(100vw - 56px))!important;
    padding-top:0!important;
    margin:0!important;
    text-align:left!important;
  }

  body .hero-title{
    font-size:clamp(31px,9vw,40px)!important;
    line-height:1.1!important;
  }

  body .hero-title .emphasis-wrap{
    justify-content:flex-start!important;
  }

  body .hero-bottom-brand{
    display:none!important;
  }

  body .visual-stage{
    --hero-card-width:230px;
    --hero-card-gap:18px;
    top:260px!important;
    right:50%!important;
    width:min(560px,calc(100vw - 16px))!important;
    height:430px!important;
    transform:translateX(50%)!important;
  }

  body .visual-stage::before{
    width:18%!important;
    background:linear-gradient(90deg,var(--sesang-red),rgba(255,49,49,0))!important;
  }

  body .visual-stage::after{
    width:8%!important;
    background:linear-gradient(270deg,var(--sesang-red),rgba(255,49,49,0))!important;
  }

  body .hex-track{
    left:0!important;
    top:50%!important;
    height:100%!important;
    transform:translate3d(0,-50%,0)!important;
    animation:sesangHeroMobileLoop 18s linear infinite!important;
    margin-left:0;
    will-change:margin-left!important;
  }

  body .hex-slide{
    flex-basis:230px!important;
    width:230px!important;
    height:100%!important;
  }
}

@keyframes sesangHeroMobileLoop{
  0%{margin-left:0}
  100%{margin-left:-1488px}
}

/* Mobile fixed CTA: keep both bars fully inside the viewport. */
@media (max-width:780px){
  body .sticky-cta,
  body .sticky-cta--global,
  body .sticky-cta--partner{
    left:12px!important;
    right:12px!important;
    bottom:max(10px,env(safe-area-inset-bottom))!important;
    width:auto!important;
    max-width:none!important;
    box-sizing:border-box!important;
    transform:none!important;
    display:flex!important;
    grid-template-columns:none!important;
    flex-direction:row!important;
    gap:8px!important;
    padding:7px!important;
    overflow:hidden!important;
  }

  body .sticky-cta.is-visible,
  body .sticky-cta--always,
  body .sticky-cta--global{
    transform:none!important;
  }

  body .sticky-cta .pop-button,
  body .sticky-cta--global .pop-button,
  body .sticky-cta--partner .pop-button{
    flex:1 1 0!important;
    min-width:0!important;
    min-height:50px!important;
    box-sizing:border-box!important;
    padding:10px 6px!important;
    white-space:nowrap!important;
    font-size:clamp(11px,3.25vw,14px)!important;
    line-height:1!important;
  }
}

/* Floating header card and smooth compositor-based hero sliders. */
body:has(.hero#top){
  background:var(--sesang-red)!important;
}

body:has(.hero#top) .top-header{
  background:rgba(255,255,255,.97)!important;
}

body .top-header{
  position:sticky!important;
  top:16px!important;
  z-index:200!important;
  width:min(1060px,calc(100% - 48px))!important;
  min-height:108px!important;
  margin:16px auto 0!important;
  padding:14px 36px!important;
  align-items:center!important;
  border:0!important;
  border-radius:10px!important;
  background:rgba(255,255,255,.96)!important;
  box-shadow:0 16px 42px rgba(17,24,39,.18)!important;
  backdrop-filter:blur(18px)!important;
}

body .brand-mark{
  width:clamp(220px,24vw,300px)!important;
  height:78px!important;
  aspect-ratio:auto!important;
}

body .brand-mark::before{
  inset:0!important;
  background:url("assets/sesang-floating-header.png") left center/contain no-repeat!important;
}

body .menu-toggle{
  width:56px!important;
  height:56px!important;
  border-radius:999px!important;
  background:#fff!important;
  box-shadow:0 8px 24px rgba(17,24,39,.12)!important;
}

body .hex-track{
  margin-left:0!important;
  translate:0 0;
  height:88%!important;
  will-change:translate!important;
  animation:sesangHeroCardFlowSmooth 26s linear infinite!important;
}

body .hex-slide img{
  object-fit:contain!important;
  object-position:center center!important;
}

@keyframes sesangHeroCardFlowSmooth{
  0%{translate:0 0}
  100%{translate:-2388px 0}
}

@media (max-width:780px){
  body .top-header{
    top:10px!important;
    width:calc(100% - 24px)!important;
    min-height:92px!important;
    margin:10px auto 0!important;
    padding:9px 14px!important;
    align-items:center!important;
    border-radius:10px!important;
  }

  body .brand{
    align-items:center!important;
  }

  body .brand-mark{
    width:clamp(174px,50vw,202px)!important;
    height:70px!important;
    aspect-ratio:auto!important;
    align-self:center!important;
    overflow:visible!important;
  }

  body .menu-toggle{
    width:50px!important;
    height:50px!important;
    flex:0 0 50px!important;
  }

  body .hex-track{
    margin-left:0!important;
    translate:0 0;
    height:88%!important;
    animation:sesangHeroMobileLoopSmooth 18s linear infinite!important;
  }
}

@keyframes sesangHeroMobileLoopSmooth{
  0%{translate:0 0}
  100%{translate:-1488px 0}
}

@media (hover:hover) and (pointer:fine){
  .cursor-sparkle{
    position:fixed;
    left:0;
    top:0;
    z-index:9999;
    pointer-events:none;
    transform:translate(-50%,-50%) rotate(45deg) scale(.2);
    background:var(--sparkle-color,#ffd91a);
    border:1px solid rgba(17,17,17,.18);
    box-shadow:0 0 14px color-mix(in srgb,var(--sparkle-color,#ffd91a) 68%,transparent);
    animation:sesangCursorSparkle .72s cubic-bezier(.2,.8,.2,1) forwards;
  }

  .cursor-sparkle::before,
  .cursor-sparkle::after{
    content:"";
    position:absolute;
    inset:50% auto auto 50%;
    width:170%;
    height:2px;
    background:currentColor;
    color:var(--sparkle-color,#ffd91a);
    opacity:.45;
    transform:translate(-50%,-50%) rotate(-45deg);
  }

  .cursor-sparkle::after{
    transform:translate(-50%,-50%) rotate(45deg);
  }
}

@keyframes sesangCursorSparkle{
  0%{
    opacity:0;
    transform:translate(-50%,-50%) rotate(45deg) scale(.2);
  }
  20%{
    opacity:1;
    transform:translate(calc(-50% + var(--sparkle-x) * .18),calc(-50% + var(--sparkle-y) * .18)) rotate(45deg) scale(1);
  }
  100%{
    opacity:0;
    transform:translate(calc(-50% + var(--sparkle-x)),calc(-50% + var(--sparkle-y))) rotate(135deg) scale(0);
  }
}

@media (prefers-reduced-motion:reduce){
  .cursor-sparkle{
    display:none!important;
  }
}

body .site-footer .footer-cta .pop-button,
body .site-footer .footer-cta .pop-button.secondary,
body .site-footer .footer-cta .pop-button--primary,
body .site-footer .footer-cta .pop-button--secondary{
  color:#fff!important;
}

body .site-footer .footer-sns{
  display:flex!important;
  align-items:center!important;
  gap:14px!important;
  color:#111!important;
}

body .site-footer .footer-sns-label{
  color:#111!important;
  font-family:var(--sesang-font,var(--display),sans-serif)!important;
  font-size:14px!important;
  font-weight:900!important;
  letter-spacing:.02em!important;
  line-height:1!important;
  text-shadow:none!important;
  -webkit-text-stroke:0!important;
  paint-order:normal!important;
}

body .site-footer .footer-sns-line{
  width:18px!important;
  height:1px!important;
  background:#111!important;
  display:inline-block!important;
}

body .site-footer .sns-icon,
body .site-footer .sns-icon--instagram,
body .site-footer .sns-icon--x{
  width:26px!important;
  height:26px!important;
  min-width:26px!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
  color:#111!important;
  font-family:Arial,Helvetica,sans-serif!important;
  font-size:26px!important;
  font-weight:400!important;
  line-height:1!important;
  padding:0!important;
}

body .site-footer .sns-icon--instagram{
  position:relative!important;
  font-size:0!important;
}

body .site-footer .sns-icon--instagram::before{
  content:""!important;
  position:absolute!important;
  inset:2px!important;
  width:auto!important;
  height:auto!important;
  border:3px solid #111!important;
  border-radius:7px!important;
  background:transparent!important;
  box-shadow:none!important;
}

body .site-footer .sns-icon--instagram::after{
  content:""!important;
  position:absolute!important;
  left:50%!important;
  top:50%!important;
  width:7px!important;
  height:7px!important;
  border:3px solid #111!important;
  border-radius:50%!important;
  transform:translate(-50%,-50%)!important;
  box-sizing:border-box!important;
  background:transparent!important;
  box-shadow:7px -7px 0 -4px #111!important;
}

body .news-archive-thumb{
  width:100%!important;
  aspect-ratio:1 / 1!important;
  min-height:0!important;
  height:auto!important;
}

body .news-archive-thumb .news-thumb-img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
}

@media (max-width:980px){
  body .specialized-ribbon{
    left:14px!important;
  }

  body .copy-block{
    left:14px!important;
    width:min(370px,calc(100vw - 28px))!important;
  }
}

@media (max-width:780px){
  body .hero{
    min-height:710px!important;
    background:linear-gradient(142deg,var(--sesang-red) 0 78%,#fff 78.2% 100%)!important;
  }

  body .hero-inner{
    min-height:710px!important;
  }

  body #strength,
  body .hero + .section{
    padding-top:28px!important;
  }
}

body .page-hero{
  min-height:0!important;
  padding-top:clamp(44px,6vw,76px)!important;
  padding-bottom:clamp(34px,5vw,64px)!important;
}

body .page-hero + .section{
  padding-top:clamp(34px,5vw,64px)!important;
}

@media (max-width:780px){
  body .page-hero{
    padding:32px 18px 28px!important;
  }

  body .page-hero h1{
    margin:0!important;
  }

  body .page-hero + .section{
    padding-top:24px!important;
  }
}

body #line .line-cta-box .pop-button{
  background:#06c755!important;
  color:#fff!important;
}

body #line .line-cta-box .line-mark{
  display:none!important;
}

body .news-hint{
  display:none!important;
}

body #news .news-more{
  display:none!important;
}

body #compare .table-box{
  overflow-x:auto!important;
  overflow-y:hidden!important;
  -webkit-overflow-scrolling:touch;
  padding:0!important;
}

body #compare .table.compare{
  min-width:760px!important;
  width:760px!important;
  table-layout:fixed!important;
  border-collapse:separate!important;
  border-spacing:0!important;
}

body #compare .table.compare tr{
  display:table-row!important;
}

body #compare .table.compare th,
body #compare .table.compare td{
  display:table-cell!important;
  width:190px!important;
  min-width:190px!important;
  padding:18px 16px!important;
  vertical-align:middle!important;
}

@media (max-width:780px){
  body #compare .table-box{
    margin-inline:-2px!important;
    border-radius:24px!important;
  }

  body #compare .table.compare{
    min-width:820px!important;
    width:820px!important;
  }

  body #compare .table.compare th,
  body #compare .table.compare td{
    width:205px!important;
    min-width:205px!important;
    font-size:16px!important;
    line-height:1.65!important;
  }
}

body .apply-lead-cta,
body .apply-fixed-line-cta{
  background:#06c755!important;
  color:#fff!important;
}

body .apply-lead-cta{
  min-height:76px!important;
  gap:0!important;
  font-size:clamp(22px,3vw,34px)!important;
}

body .apply-fixed-line-cta{
  min-height:62px!important;
}

body .apply-fixed-line-cta .cta-main{
  font-size:clamp(20px,4.5vw,28px)!important;
}

@media (max-width:780px){
  body .apply-lead-cta{
    min-height:68px!important;
    margin-top:28px!important;
    padding:14px 22px!important;
    font-size:clamp(22px,6vw,28px)!important;
  }

  body .apply-visual{
    display:block!important;
    min-height:auto!important;
    margin-top:36px!important;
  }

  body .apply-phone{
    position:relative!important;
    right:auto!important;
    top:auto!important;
    width:min(300px,74vw)!important;
    max-height:none!important;
    margin:0 auto!important;
    transform:none!important;
  }

  body .apply-support-box{
    position:relative!important;
    left:auto!important;
    bottom:auto!important;
    width:calc(100% - 8px)!important;
    margin:18px auto 0!important;
    padding:24px!important;
  }

  body .apply-bubble{
    display:none!important;
  }
}

body #news .news-marquee{
  margin-inline:calc(50% - 50vw)!important;
  overflow:hidden!important;
  padding:10px 0 22px!important;
}

body #news .news-track--auto{
  display:flex!important;
  width:max-content!important;
  margin-inline:0!important;
  padding:0!important;
  overflow:visible!important;
  scroll-snap-type:none!important;
  scrollbar-width:none!important;
  animation:sesangTopNewsMarquee 34s linear infinite!important;
  will-change:transform;
}

body #news .news-track--auto::-webkit-scrollbar{
  display:none!important;
}

body #news .news-marquee-group{
  display:flex!important;
  flex:0 0 auto!important;
  gap:24px!important;
  padding-inline:max(28px,calc((100vw - 1120px) / 2))!important;
}

body #news .news-marquee-group[aria-hidden="true"] .news-card{
  pointer-events:none!important;
}

body #news .news-track--auto:hover{
  animation-play-state:paused!important;
}

@keyframes sesangTopNewsMarquee{
  from{
    transform:translate3d(0,0,0);
  }

  to{
    transform:translate3d(-50%,0,0);
  }
}

@media (prefers-reduced-motion:reduce){
  body #news .news-track--auto{
    animation:none!important;
  }
}

@media (max-width:780px){
  body .event-calendar{
    overflow-x:auto!important;
    -webkit-overflow-scrolling:touch;
    padding:10px!important;
  }

  body .calendar-month,
  body .calendar-grid{
    min-width:700px!important;
  }

  body .calendar-grid{
    grid-template-columns:repeat(7,100px)!important;
  }

  body .calendar-day-name,
  body .calendar-cell{
    min-height:86px!important;
    padding:6px!important;
  }

  body .calendar-day-name{
    min-height:auto!important;
    font-size:11px!important;
  }

  body .calendar-date{
    font-size:14px!important;
  }

  body .calendar-event{
    width:auto!important;
    max-width:100%!important;
    padding:5px 6px!important;
    font-size:10px!important;
    line-height:1.35!important;
    word-break:normal!important;
    overflow-wrap:break-word!important;
    writing-mode:horizontal-tb!important;
  }

  body .ranking-tabs{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:10px!important;
    width:100%!important;
  }

  body .ranking-tab{
    min-width:0!important;
    width:100%!important;
    padding:13px 8px!important;
    font-size:clamp(16px,4.4vw,20px)!important;
    text-align:center!important;
    box-shadow:none!important;
    transform:none!important;
  }
}

body .section,
body .section--white,
body .section--black,
body .section--yellow,
body .section--green,
body .section--event-calendar,
body .section--faq-home{
  padding-top:clamp(42px,5vw,72px)!important;
  padding-bottom:clamp(42px,5vw,72px)!important;
}

body .section-inner{
  padding-top:0!important;
}

body .section-title{
  margin-bottom:clamp(18px,2.4vw,28px)!important;
}

body .section-label{
  margin-bottom:clamp(12px,1.8vw,18px)!important;
}

body .grid,
body .benefit-grid,
body .interview-grid{
  margin-top:clamp(18px,2.4vw,28px)!important;
}

body .pop-card h3{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:12px!important;
}

body .point-icon{
  display:inline-grid!important;
  place-items:center!important;
  flex:0 0 auto!important;
  width:42px!important;
  height:42px!important;
  border:3px solid var(--sesang-ink)!important;
  border-radius:50%!important;
  background:var(--sesang-yellow)!important;
  color:var(--sesang-ink)!important;
  font-size:22px!important;
  font-weight:900!important;
  line-height:1!important;
  box-shadow:4px 4px 0 rgba(17,17,17,.12)!important;
}

body .point-icon--reward{
  background:var(--sesang-green)!important;
  color:#fff!important;
}

body .point-icon--manager{
  background:var(--sesang-red)!important;
  color:#fff!important;
}

body .point-icon--pococha{
  background:#fff!important;
  color:var(--sesang-red)!important;
}

@media (max-width:780px){
  body .section,
  body .section--white,
  body .section--black,
  body .section--yellow,
  body .section--green,
  body .section--event-calendar,
  body .section--faq-home{
    padding-top:30px!important;
    padding-bottom:32px!important;
  }

  body #strength,
  body .hero + .section{
    padding-top:22px!important;
  }

  body .section-title{
    margin-bottom:16px!important;
  }

  body .grid,
  body .benefit-grid,
  body .interview-grid{
    margin-top:18px!important;
  }

  body .pop-card{
    min-height:auto!important;
    padding:22px!important;
  }

  body .point-icon{
    width:36px!important;
    height:36px!important;
    font-size:18px!important;
  }
}

body .contact-page-section .page-lead{
  margin:0 0 28px!important;
}

body .contact-route-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:22px!important;
  max-width:980px!important;
  margin:0 auto 28px!important;
}

body .contact-route-card{
  display:grid!important;
  justify-items:center!important;
  gap:14px!important;
  min-height:220px!important;
  padding:28px 24px!important;
  border:1px solid var(--sesang-line)!important;
  border-radius:28px!important;
  background:#fff!important;
  color:var(--sesang-ink)!important;
  text-align:center!important;
  text-decoration:none!important;
  transition:transform .18s ease, box-shadow .18s ease;
}

body .contact-route-card:hover{
  transform:translateY(-3px)!important;
  box-shadow:0 18px 42px rgba(17,24,39,.08)!important;
}

body .contact-route-icon{
  display:grid!important;
  place-items:center!important;
  width:64px!important;
  height:64px!important;
  border-radius:22px!important;
  background:#f0e7ff!important;
  color:var(--sesang-red)!important;
  font-size:28px!important;
  line-height:1!important;
}

body .contact-route-card strong{
  font-size:18px!important;
  font-weight:900!important;
  line-height:1.45!important;
}

body .contact-route-card span:not(.contact-route-icon){
  color:var(--sesang-muted)!important;
  font-size:14px!important;
  font-weight:700!important;
  line-height:1.7!important;
}

body .contact-route-card em{
  display:grid!important;
  place-items:center!important;
  width:38px!important;
  height:38px!important;
  border-radius:50%!important;
  background:#f0e7ff!important;
  color:var(--sesang-red)!important;
  font-style:normal!important;
  font-weight:900!important;
}

body .contact-line-guide{
  display:grid!important;
  justify-items:center!important;
  gap:14px!important;
  max-width:980px!important;
  margin:0 auto 28px!important;
  padding:clamp(22px,3vw,30px) 20px!important;
  border:1px solid rgba(6,199,85,.16)!important;
  border-radius:0!important;
  background:linear-gradient(180deg,#f4fffa,#eafff3)!important;
  text-align:center!important;
}

body .contact-line-guide p{
  margin:0!important;
  color:var(--sesang-muted)!important;
  font-size:clamp(14px,1.6vw,16px)!important;
  font-weight:800!important;
  line-height:1.7!important;
}

body .contact-line-guide__button{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:10px!important;
  min-height:56px!important;
  padding:13px 28px!important;
  border-radius:999px!important;
  background:#06c755!important;
  color:#fff!important;
  font-size:clamp(15px,1.8vw,18px)!important;
  font-weight:900!important;
  line-height:1.2!important;
  text-decoration:none!important;
  box-shadow:0 14px 30px rgba(6,199,85,.28)!important;
}

body .contact-line-guide__button .line-mark{
  width:30px!important;
  height:26px!important;
  font-size:8px!important;
  color:#06c755!important;
}

body .contact-form{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:20px 22px!important;
  max-width:980px!important;
  margin:0 auto!important;
  padding:clamp(24px,4vw,42px)!important;
}

body .contact-status{
  max-width:980px!important;
  margin:0 auto 18px!important;
  padding:16px 18px!important;
  border-radius:14px!important;
  font-weight:900!important;
  line-height:1.7!important;
}

body .contact-status--success{
  background:rgba(6,199,85,.12)!important;
  border:1px solid rgba(6,199,85,.36)!important;
  color:#087b38!important;
}

body .contact-status--error{
  background:rgba(255,48,54,.1)!important;
  border:1px solid rgba(255,48,54,.32)!important;
  color:var(--sesang-red)!important;
}

body .contact-form .field{
  margin:0!important;
}

body .contact-form .field--full,
body .contact-form .pop-button{
  grid-column:1 / -1!important;
}

body .contact-form label,
body .contact-field-title{
  display:block!important;
  margin:0 0 9px!important;
  color:var(--sesang-ink)!important;
  font-weight:900!important;
}

body .contact-form input,
body .contact-form textarea,
body .contact-form select{
  border:1px solid var(--sesang-line)!important;
  border-radius:14px!important;
  background:#fff!important;
  box-shadow:none!important;
}

body .contact-form textarea{
  min-height:180px!important;
}

body .required{
  display:inline-flex!important;
  align-items:center!important;
  margin-left:8px!important;
  padding:3px 8px!important;
  border-radius:999px!important;
  background:var(--sesang-red)!important;
  color:#fff!important;
  font-size:12px!important;
  font-weight:900!important;
  line-height:1.2!important;
}

body .radio-group{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:12px!important;
}

body .radio-card{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  min-height:58px!important;
  margin:0!important;
  padding:14px 16px!important;
  border:1px solid var(--sesang-line)!important;
  border-radius:14px!important;
  background:#fff!important;
}

body .radio-card input{
  width:18px!important;
  height:18px!important;
  padding:0!important;
  flex:0 0 auto!important;
  accent-color:var(--sesang-red);
}

body .privacy-consent label{
  display:flex!important;
  align-items:flex-start!important;
  gap:10px!important;
  margin:0!important;
  color:var(--sesang-muted)!important;
  font-size:14px!important;
  line-height:1.8!important;
}

body .privacy-consent input{
  width:18px!important;
  height:18px!important;
  margin-top:4px!important;
  padding:0!important;
  flex:0 0 auto!important;
  accent-color:var(--sesang-red);
}

body .contact-form .pop-button{
  width:min(360px,100%)!important;
  margin:10px auto 0!important;
}

@media (max-width:780px){
  body .contact-form,
  body .radio-group,
  body .contact-route-grid{
    grid-template-columns:1fr!important;
  }

  body .contact-route-card{
    min-height:190px!important;
    padding:24px 20px!important;
  }

  body .contact-form{
    gap:16px!important;
    padding:22px!important;
  }

  body .contact-form textarea{
    min-height:150px!important;
  }
}

body #news .news-marquee{
  padding-left:max(28px,calc((100vw - 1120px) / 2))!important;
  padding-right:0!important;
}

body #news .news-marquee-group{
  padding-inline:0!important;
  padding-right:24px!important;
}

body #news .news-card,
body #news .news-track--auto .news-card,
body #news .news-marquee-group .news-card{
  flex:0 0 330px!important;
  width:330px!important;
  max-width:330px!important;
  min-width:330px!important;
}

@media (max-width:780px){
  body #news .news-card,
  body #news .news-track--auto .news-card,
  body #news .news-marquee-group .news-card{
    flex-basis:min(300px,78vw)!important;
    width:min(300px,78vw)!important;
    max-width:min(300px,78vw)!important;
    min-width:min(300px,78vw)!important;
  }
}

body .partner-line-cta,
body .partner-final-cta .pop-button.partner-line-cta,
body .sticky-cta--partner .pop-button.partner-line-cta{
  background:#06c755!important;
  color:#fff!important;
}

body #strength .section-note{
  display:none!important;
}

@media (min-width:981px){
  body .visual-stage::before{
    top:-18%!important;
    bottom:-18%!important;
    left:-2%!important;
    width:40%!important;
    height:auto!important;
    background:radial-gradient(ellipse at left center,rgba(255,54,54,.88) 0%,rgba(255,54,54,.64) 38%,rgba(255,54,54,0) 76%)!important;
  }
}

@media (max-width:780px){
  body #line .line-cta-box h2{
    white-space:nowrap!important;
    font-size:clamp(24px,6.4vw,32px)!important;
    line-height:1.18!important;
    letter-spacing:0!important;
  }
}

@media (max-width:780px){
  body .apply-hero{
    position:relative!important;
    min-height:720px!important;
    padding-top:56px!important;
    padding-bottom:34px!important;
  }

  body .apply-hero__inner{
    position:relative!important;
    display:block!important;
    min-height:630px!important;
  }

  body .apply-copy{
    position:relative!important;
    z-index:2!important;
    padding-top:210px!important;
  }

  body .apply-visual{
    position:absolute!important;
    top:112px!important;
    right:0!important;
    z-index:1!important;
    width:min(205px,48vw)!important;
    min-height:0!important;
    height:auto!important;
    margin:0!important;
    pointer-events:none!important;
  }

  body .apply-phone{
    position:relative!important;
    top:auto!important;
    right:auto!important;
    width:100%!important;
    max-height:none!important;
    margin:0!important;
    transform:none!important;
    border-radius:26px!important;
  }

  body .apply-phone img{
    padding:10px!important;
  }

  body .apply-phone-label,
  body .apply-support-box,
  body .apply-bubble{
    display:none!important;
  }

  body .apply-title{
    font-size:clamp(34px,10.2vw,46px)!important;
  }
}

@media (min-width:981px){
  body .visual-stage::before{
    display:none!important;
    content:none!important;
  }

  body .hex-slide{
    overflow:hidden!important;
    isolation:isolate!important;
  }
}

@media (max-width:780px){
  body .apply-hero{
    min-height:auto!important;
    padding-top:34px!important;
    padding-bottom:34px!important;
  }

  body .apply-hero__inner{
    display:flex!important;
    flex-direction:column!important;
    min-height:0!important;
  }

  body .apply-copy{
    display:flex!important;
    flex-direction:column!important;
    padding-top:0!important;
  }

  body .apply-visual{
    order:-1!important;
    position:relative!important;
    top:auto!important;
    right:auto!important;
    width:min(250px,58vw)!important;
    margin:0 0 24px auto!important;
    z-index:1!important;
  }

  body .apply-phone{
    width:100%!important;
  }

  body .apply-kicker{
    margin-top:0!important;
  }
}

@media (max-width:780px){
  body .apply-hero{
    padding-top:26px!important;
    padding-left:18px!important;
    padding-right:18px!important;
  }

  body .apply-hero__inner{
    gap:0!important;
  }

  body .apply-visual{
    order:-1!important;
    width:100%!important;
    max-width:none!important;
    margin:0 0 18px!important;
  }

  body .apply-phone{
    width:100%!important;
    max-width:none!important;
    aspect-ratio:auto!important;
    border-radius:28px!important;
    background:transparent!important;
    overflow:hidden!important;
  }

  body .apply-phone img{
    display:block!important;
    width:100%!important;
    height:auto!important;
    padding:0!important;
    object-fit:cover!important;
    object-position:center top!important;
  }

  body .apply-copy{
    gap:0!important;
  }

  body .apply-kicker{
    margin-bottom:12px!important;
  }

  body .apply-title{
    margin-bottom:18px!important;
  }
}

body .interview-thumb{
  width:100%!important;
  aspect-ratio:1/1!important;
  min-height:0!important;
  overflow:hidden!important;
}

body .interview-thumb-img{
  width:100%!important;
  height:100%!important;
  min-height:0!important;
  object-fit:cover!important;
  object-position:center!important;
  display:block!important;
}

body .liver-image-link{
  display:block!important;
  width:100%!important;
  height:100%!important;
  cursor:pointer!important;
}

body .liver-image-link .news-thumb-img{
  transition:transform .22s ease!important;
}

body .liver-image-link:hover .news-thumb-img,
body .liver-image-link:focus-visible .news-thumb-img{
  transform:scale(1.04)!important;
}

body .liver-archive-thumb{
  width:100%!important;
  aspect-ratio:4/5!important;
  min-height:0!important;
  overflow:hidden!important;
}

body .liver-archive-thumb .news-thumb-img{
  width:100%!important;
  height:100%!important;
  min-height:0!important;
  object-fit:cover!important;
  object-position:center!important;
  display:block!important;
}

body main > section{
  position:relative!important;
  isolation:isolate!important;
}

body main > section::before,
body main > section::after{
  content:""!important;
  position:absolute!important;
  z-index:0!important;
  display:block!important;
  width:clamp(116px,13vw,210px)!important;
  aspect-ratio:1/1!important;
  background:center/contain no-repeat!important;
  pointer-events:none!important;
  opacity:.62!important;
  mix-blend-mode:screen!important;
  filter:saturate(1.08)!important;
}

body main > section::before{
  top:-42px!important;
  left:-34px!important;
}

body main > section::after{
  right:-34px!important;
  bottom:-44px!important;
}

body main > section > .inner,
body main > section > .page-hero__inner,
body main > section > .hero-inner,
body main > section > .apply-hero__inner,
body main > section > .partner-hero__inner{
  position:relative!important;
  z-index:2!important;
}

body main > section:nth-of-type(10n+1)::before{background-image:url("assets/section-decor/pattern-01.png")!important;}
body main > section:nth-of-type(10n+1)::after{background-image:url("assets/section-decor/pattern-02.png")!important;}
body main > section:nth-of-type(10n+2)::before{background-image:url("assets/section-decor/pattern-03.png")!important;}
body main > section:nth-of-type(10n+2)::after{background-image:url("assets/section-decor/pattern-04.png")!important;}
body main > section:nth-of-type(10n+3)::before{background-image:url("assets/section-decor/pattern-05.png")!important;}
body main > section:nth-of-type(10n+3)::after{background-image:url("assets/section-decor/pattern-06.png")!important;}
body main > section:nth-of-type(10n+4)::before{background-image:url("assets/section-decor/pattern-07.png")!important;}
body main > section:nth-of-type(10n+4)::after{background-image:url("assets/section-decor/pattern-08.png")!important;}
body main > section:nth-of-type(10n+5)::before{background-image:url("assets/section-decor/pattern-09.png")!important;}
body main > section:nth-of-type(10n+5)::after{background-image:url("assets/section-decor/pattern-10.png")!important;}
body main > section:nth-of-type(10n+6)::before{background-image:url("assets/section-decor/pattern-02.png")!important;}
body main > section:nth-of-type(10n+6)::after{background-image:url("assets/section-decor/pattern-05.png")!important;}
body main > section:nth-of-type(10n+7)::before{background-image:url("assets/section-decor/pattern-04.png")!important;}
body main > section:nth-of-type(10n+7)::after{background-image:url("assets/section-decor/pattern-09.png")!important;}
body main > section:nth-of-type(10n+8)::before{background-image:url("assets/section-decor/pattern-06.png")!important;}
body main > section:nth-of-type(10n+8)::after{background-image:url("assets/section-decor/pattern-01.png")!important;}
body main > section:nth-of-type(10n+9)::before{background-image:url("assets/section-decor/pattern-08.png")!important;}
body main > section:nth-of-type(10n+9)::after{background-image:url("assets/section-decor/pattern-03.png")!important;}
body main > section:nth-of-type(10n+10)::before{background-image:url("assets/section-decor/pattern-10.png")!important;}
body main > section:nth-of-type(10n+10)::after{background-image:url("assets/section-decor/pattern-07.png")!important;}

@media (max-width:780px){
  body main > section::before,
  body main > section::after{
    width:clamp(86px,28vw,128px)!important;
    opacity:.48!important;
  }

  body main > section::before{
    top:-24px!important;
    left:-24px!important;
  }

  body main > section::after{
    right:-24px!important;
    bottom:-28px!important;
  }
}

body main > section.section::before,
body main > section.section::after,
body main > section.page-hero::before,
body main > section.page-hero::after,
body main > section.hero::before,
body main > section.hero::after,
body main > section.apply-hero::before,
body main > section.apply-hero::after,
body main > section.partner-hero::before,
body main > section.partner-hero::after{
  content:""!important;
  display:block!important;
}

body .hero .hex-slide{
  overflow:hidden!important;
  background:transparent!important;
}

body .hero .hex-slide img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  object-position:center center!important;
  background:transparent!important;
  transform:none!important;
}

body a.rank-card,
body a.rank-card:hover,
body a.rank-card:focus-visible{
  color:inherit!important;
  text-decoration:none!important;
}

body .rank-card--link{
  cursor:pointer!important;
}

body .coming-soon-block{
  display:grid!important;
  place-items:center!important;
  min-height:clamp(220px,34vw,420px)!important;
  border:1px solid var(--sesang-line)!important;
  border-radius:28px!important;
  background:#fff!important;
  text-align:center!important;
}

body .coming-soon-block p{
  margin:0!important;
  color:var(--sesang-red)!important;
  font-size:clamp(42px,8vw,92px)!important;
  font-weight:900!important;
  letter-spacing:.04em!important;
  line-height:1!important;
}

@media (min-width:781px){
  body.sesang-static-page-liver-entry #compare .table-box{
    width:min(100%,760px)!important;
    margin-left:auto!important;
    margin-right:auto!important;
    overflow:visible!important;
  }
}

body a.news-card,
body a.news-card:hover,
body a.news-card:focus-visible{
  color:inherit!important;
  text-decoration:none!important;
}

body .news-card--link{
  cursor:pointer!important;
}

body .news-detail-inner{
  max-width:920px!important;
}

body .news-detail-hero{
  width:100%!important;
  aspect-ratio:16/9!important;
  margin:0 0 24px!important;
  border:1px solid var(--sesang-line)!important;
  border-radius:24px!important;
  overflow:hidden!important;
  background:#fff!important;
}

body .news-detail-hero img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  display:block!important;
}

body .news-detail-meta{
  display:flex!important;
  align-items:center!important;
  gap:12px!important;
  flex-wrap:wrap!important;
  margin:0 0 18px!important;
}

body .news-detail-content{
  font-size:clamp(15px,1.8vw,18px)!important;
  line-height:2!important;
}

body a.interview-card,
body a.interview-card:hover,
body a.interview-card:focus-visible{
  color:inherit!important;
  text-decoration:none!important;
}

body .interview-card--link{
  cursor:pointer!important;
}

body.sesang-static-page-news-detail .page-hero h1,
body.sesang-static-page-interview-detail .page-hero h1{
  max-width:980px!important;
  font-size:clamp(28px,3.8vw,48px)!important;
  line-height:1.38!important;
  letter-spacing:0!important;
}

@media (max-width:780px){
  body.sesang-static-page-news-detail .page-hero h1,
  body.sesang-static-page-interview-detail .page-hero h1{
    font-size:clamp(24px,7vw,34px)!important;
    line-height:1.45!important;
  }
}

body main > section{
  position:relative!important;
  overflow:hidden!important;
}

body main > section::before,
body main > section::after{
  content:""!important;
  position:absolute!important;
  z-index:1!important;
  display:block!important;
  width:clamp(132px,16vw,240px)!important;
  height:auto!important;
  aspect-ratio:1/1!important;
  background-position:center!important;
  background-size:contain!important;
  background-repeat:no-repeat!important;
  opacity:.9!important;
  mix-blend-mode:normal!important;
  filter:none!important;
  pointer-events:none!important;
}

body main > section::before{
  top:clamp(14px,3vw,42px)!important;
  left:clamp(-38px,-2vw,-18px)!important;
}

body main > section::after{
  right:clamp(-42px,-2.2vw,-20px)!important;
  bottom:clamp(12px,3vw,42px)!important;
}

body main > section:nth-of-type(10n+1)::before{background-image:url("assets/section-decor/pattern-01.png")!important;}
body main > section:nth-of-type(10n+1)::after{background-image:url("assets/section-decor/pattern-06.png")!important;}
body main > section:nth-of-type(10n+2)::before{background-image:url("assets/section-decor/pattern-03.png")!important;}
body main > section:nth-of-type(10n+2)::after{background-image:url("assets/section-decor/pattern-08.png")!important;}
body main > section:nth-of-type(10n+3)::before{background-image:url("assets/section-decor/pattern-05.png")!important;}
body main > section:nth-of-type(10n+3)::after{background-image:url("assets/section-decor/pattern-10.png")!important;}
body main > section:nth-of-type(10n+4)::before{background-image:url("assets/section-decor/pattern-07.png")!important;}
body main > section:nth-of-type(10n+4)::after{background-image:url("assets/section-decor/pattern-02.png")!important;}
body main > section:nth-of-type(10n+5)::before{background-image:url("assets/section-decor/pattern-09.png")!important;}
body main > section:nth-of-type(10n+5)::after{background-image:url("assets/section-decor/pattern-04.png")!important;}
body main > section:nth-of-type(10n+6)::before{background-image:url("assets/section-decor/pattern-02.png")!important;}
body main > section:nth-of-type(10n+6)::after{background-image:url("assets/section-decor/pattern-07.png")!important;}
body main > section:nth-of-type(10n+7)::before{background-image:url("assets/section-decor/pattern-04.png")!important;}
body main > section:nth-of-type(10n+7)::after{background-image:url("assets/section-decor/pattern-09.png")!important;}
body main > section:nth-of-type(10n+8)::before{background-image:url("assets/section-decor/pattern-06.png")!important;}
body main > section:nth-of-type(10n+8)::after{background-image:url("assets/section-decor/pattern-01.png")!important;}
body main > section:nth-of-type(10n+9)::before{background-image:url("assets/section-decor/pattern-08.png")!important;}
body main > section:nth-of-type(10n+9)::after{background-image:url("assets/section-decor/pattern-03.png")!important;}
body main > section:nth-of-type(10n+10)::before{background-image:url("assets/section-decor/pattern-10.png")!important;}
body main > section:nth-of-type(10n+10)::after{background-image:url("assets/section-decor/pattern-05.png")!important;}

body main > section > .inner,
body main > section > .page-hero__inner,
body main > section > .hero-inner,
body main > section > .apply-hero__inner,
body main > section > .partner-hero__inner{
  position:relative!important;
  z-index:2!important;
}

body .hero::before{
  top:110px!important;
  left:-28px!important;
  width:clamp(110px,12vw,190px)!important;
}

body .hero::after{
  right:-24px!important;
  bottom:34px!important;
  width:clamp(120px,13vw,210px)!important;
}

@media (max-width:780px){
  body main > section::before,
  body main > section::after{
    width:clamp(82px,27vw,126px)!important;
    opacity:.8!important;
  }

  body main > section::before{
    top:16px!important;
    left:-32px!important;
  }

  body main > section::after{
    right:-34px!important;
    bottom:14px!important;
  }
}
