/* ============================================================
   GIVE Ecosystem — calm growth design system
   Served from /give-theme.css by Cloudflare Pages / Vite public.
   ============================================================ */

:root{
  --bg:#FAF8F3;
  --surface:#FFFFFF;
  --surface-2:#F3EFE7;
  --ink:#1A1F1C;
  --ink-sub:#5C635E;
  --ink-faint:#666B66;
  --line:#E7E1D5;
  --green:#114B3C;
  --green-deep:#0D3B2F;
  --green-soft:#E9F2EC;
  --mint:#00A885;
  --mint-soft:#E2F4EE;
  --mint-ink:#0A5F4D;
  --amber:#9A6516;
  --amber-accent:#E9A23B;
  --amber-soft:#F6ECD8;
  --amber-ink:#7A4E12;
  --r:14px;
  --r-lg:20px;
  --r-pill:999px;
  --sans:'Pretendard Variable',Pretendard,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --serif:'Fraunces',Georgia,serif;
}

*{box-sizing:border-box;margin:0;padding:0;word-break:keep-all;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{min-width:320px;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
a{color:inherit;}
button,input,textarea,select{font:inherit;}
button,a{-webkit-tap-highlight-color:transparent;}
img{display:block;max-width:100%;height:auto;}
.wrap{width:min(100%,560px);margin:0 auto;padding:0 22px;}
.skip{position:absolute;left:-999px;top:8px;z-index:10000;background:var(--green);color:var(--surface);padding:10px 16px;border-radius:8px;font-weight:800;text-decoration:none;}
.skip:focus{left:16px;}

nav,.site-nav{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 0;border-bottom:1px solid var(--line);}
.logo,.brand{min-height:40px;display:inline-flex;align-items:center;font-family:var(--serif);font-style:italic;font-weight:500;font-size:1.05rem;letter-spacing:.01em;color:var(--green);text-decoration:none;}
.nav-links{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px 15px;}
.nav-links a{min-height:44px;display:inline-flex;align-items:center;color:var(--ink-sub);font-size:.88rem;font-weight:700;text-decoration:none;}
.nav-links a:hover{color:var(--green);}

.hero{padding:52px 0 30px;text-align:center;}
.eyebrow,.section-label{display:inline-block;margin-bottom:14px;color:var(--mint-ink);font-family:var(--serif);font-size:.95rem;font-style:italic;}
.hero h1{max-width:12em;margin:0 auto 14px;font-size:clamp(2rem,8.4vw,2.8rem);font-weight:800;line-height:1.16;letter-spacing:-.025em;text-wrap:balance;}
.hero p{max-width:25em;margin:0 auto 26px;color:var(--ink-sub);font-size:1rem;font-weight:450;line-height:1.75;text-wrap:pretty;}
.hero-actions{display:grid;gap:9px;max-width:380px;margin:0 auto;}
.hero-note{margin-top:12px;color:var(--ink-faint);font-size:.8rem;font-weight:700;}

.btn{min-height:54px;border:1px solid transparent;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 18px;background:var(--surface);color:var(--green);font-weight:800;font-size:.98rem;text-decoration:none;cursor:pointer;will-change:transform;transition:transform .15s ease,background .2s ease,border-color .2s ease,box-shadow .2s ease;}
.btn:active{transform:scale(.985);}
.btn-primary{background:var(--green);color:var(--surface);box-shadow:0 12px 26px rgba(17,75,60,.16);}
.btn-primary:hover{background:var(--green-deep);}
.btn-ghost{background:var(--surface);color:var(--green);border-color:var(--line);}
.btn-ghost:hover{background:var(--green-soft);}
.btn-line{background:transparent;color:var(--surface);border-color:rgba(255,255,255,.34);}

.choice-grid{display:grid;gap:12px;}
.choice-card{display:block;width:100%;padding:22px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);color:inherit;text-align:left;text-decoration:none;will-change:transform;transition:transform .18s cubic-bezier(.16,1,.3,1),border-color .2s,box-shadow .2s;}
.choice-card:hover{transform:translateY(-4px);border-color:var(--mint);box-shadow:0 18px 38px rgba(17,75,60,.08);}
.choice-card.featured{border-color:var(--mint);box-shadow:0 14px 34px rgba(17,75,60,.07);}
.choice-card h2,.choice-card h3{margin:14px 0 7px;font-size:1.18rem;font-weight:800;line-height:1.35;letter-spacing:-.01em;text-wrap:balance;}
.card-desc{margin-bottom:16px;color:var(--ink-sub);font-size:.95rem;line-height:1.65;text-wrap:pretty;}
.go{color:var(--green);font-size:.9rem;font-weight:800;text-decoration:none;}
.pill{display:inline-flex;margin-bottom:14px;padding:5px 10px;border-radius:var(--r-pill);background:var(--mint-soft);color:var(--mint-ink);font-size:.72rem;font-weight:800;letter-spacing:.02em;}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;}
.tag{border:1px solid transparent;border-radius:var(--r-pill);padding:4px 9px;font-size:.72rem;font-weight:800;}
.tag-amber{background:var(--amber-soft);color:var(--amber-ink);border-color:var(--line);}

.itile{width:46px;height:46px;border-radius:13px;background:var(--green-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.itile.warn{background:var(--amber-soft);}
.itile svg{width:24px;height:24px;fill:none;stroke:var(--green);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}
.itile.warn svg{stroke:var(--amber);}
.itile svg .fa{fill:var(--mint);stroke:none;}
.itile svg .sa{stroke:var(--mint);}
.itile svg .fw{fill:var(--amber-accent);stroke:none;}
.itile.lg{width:54px;height:54px;border-radius:15px;}
.itile.lg svg{width:28px;height:28px;}
.itile.sm{width:40px;height:40px;border-radius:11px;}
.itile.sm svg{width:21px;height:21px;}

.test-card{display:grid;gap:16px;overflow:hidden;}
.test-card-image{margin:-22px -22px 2px;aspect-ratio:1/1;background:var(--green-soft);overflow:hidden;}
.test-card-image img{width:100%;height:100%;object-fit:cover;}
.row-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:17px 18px;}
.row-card h3{margin:0;font-size:1.02rem;}
.row-card .go{white-space:nowrap;font-size:.84rem;}

.block{padding:42px 0 4px;border-top:1px solid var(--line);margin-top:42px;}
.block.first,.block:first-of-type{border-top:0;margin-top:0;}
.block-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:20px;gap:12px;}
.block h2{font-size:1.4rem;font-weight:800;line-height:1.3;letter-spacing:-.01em;text-wrap:balance;}
.block-head .more{min-height:44px;display:inline-flex;align-items:center;color:var(--green);font-size:.88rem;font-weight:800;text-decoration:none;white-space:nowrap;}
.lead,.section-text{color:var(--ink-sub);font-size:.95rem;line-height:1.7;text-wrap:pretty;}

.art{display:grid;gap:12px;}
.art a{display:flex;gap:16px;align-items:center;padding:18px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);color:inherit;text-decoration:none;transition:border-color .2s,transform .18s;}
.art a:hover{border-color:var(--mint);transform:translateY(-3px);}
.art a > div{flex:1;min-width:0;}
.art .kicker{display:block;margin-bottom:4px;color:var(--mint-ink);font-family:var(--serif);font-style:italic;font-size:.78rem;}
.art h3{margin-bottom:5px;font-size:1.02rem;font-weight:800;line-height:1.35;letter-spacing:-.01em;text-wrap:balance;}
.art p{color:var(--ink-sub);font-size:.9rem;line-height:1.55;text-wrap:pretty;}

.types{display:grid;gap:12px;margin-bottom:18px;}
.type{padding:20px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);}
.type strong{display:block;margin-bottom:6px;font-size:1.02rem;}
.type.g{background:var(--green-soft);border-color:var(--line);}
.type.g strong{color:var(--green);}
.type.t{background:var(--amber-soft);border-color:var(--line);}
.type.t strong{color:var(--amber-ink);}
.type.m{background:var(--surface-2);}
.type.m strong{color:var(--ink-sub);}
.type p{color:var(--ink-sub);font-size:.95rem;line-height:1.65;}

.challenge{margin:14px 0 0;padding:26px 22px;background:var(--green);color:var(--surface);border-radius:var(--r-lg);}
.challenge h3{margin-bottom:10px;font-size:1.4rem;font-weight:800;line-height:1.25;letter-spacing:-.01em;}
.challenge p{margin-bottom:18px;color:var(--mint-soft);font-size:.95rem;line-height:1.65;}

.faq{display:grid;gap:10px;}
.faq details{padding:0 18px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);}
.faq summary{min-height:56px;padding:16px 0;display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:1rem;font-weight:800;cursor:pointer;list-style:none;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";color:var(--mint-ink);font-size:1.3rem;font-weight:500;}
.faq details[open] summary::after{content:"\2013";}
.faq p{padding:0 0 16px;color:var(--ink-sub);font-size:.95rem;line-height:1.7;}

.share-wrap{margin:28px 0 0;padding:22px 20px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);text-align:center;}
.sh-title{margin-bottom:14px;color:var(--ink);font-size:.95rem;font-weight:800;}
.share-row{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;}
.s-btn{width:64px;min-height:54px;padding:8px 4px;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface-2);color:var(--ink-sub);font-size:.68rem;font-weight:800;cursor:pointer;}
.s-btn:hover{border-color:var(--mint);color:var(--green);}
.s-btn svg,.s-btn img{width:22px;height:22px;}
.share-toast{position:fixed;left:50%;bottom:28px;z-index:9999;max-width:calc(100vw - 48px);transform:translateX(-50%);padding:10px 18px;border-radius:var(--r-pill);background:var(--ink);color:var(--surface);text-align:center;font-size:.85rem;opacity:0;pointer-events:none;transition:opacity .25s;}
.share-toast.on{opacity:1;}

footer{padding:54px 0 44px;border-top:1px solid var(--line);margin-top:48px;text-align:center;color:var(--ink-faint);font-size:.84rem;}
.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 18px;margin-bottom:18px;}
.footer-links a{min-height:44px;display:inline-flex;align-items:center;color:var(--ink-sub);text-decoration:none;}
.footer-links a:hover{color:var(--green);text-decoration:underline;}

.sequence-page{--sequence-accent:var(--green);--sequence-accent-ink:var(--green);--sequence-soft:var(--green-soft);--sequence-hero:var(--green);--sequence-hero-text:var(--surface);--sequence-hero-sub:var(--mint-soft);--sequence-shadow:rgba(13,59,47,.28);min-height:100vh;overflow:hidden;background:var(--bg);color:var(--ink);font-family:'Hahmlet',var(--sans);}
.sequence-header{position:fixed;top:0;left:0;right:0;z-index:30;height:58px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 22px;background:rgba(250,248,243,.92);border-bottom:1px solid var(--line);backdrop-filter:blur(12px);}
.sequence-brand{min-height:44px;display:inline-flex;align-items:center;color:var(--sequence-accent-ink);font-family:var(--serif);font-size:.98rem;font-style:italic;font-weight:500;text-decoration:none;}
.sequence-dots{display:flex;align-items:center;gap:6px;}
.sequence-dots span{width:7px;height:7px;border-radius:var(--r-pill);background:var(--line);transition:transform .25s ease,background .25s ease;}
.sequence-dots span.is-active{background:var(--sequence-accent-ink);transform:scale(1.22);}
.sequence-main{position:fixed;inset:58px 0 0;overflow:hidden;}
.sequence-slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:34px 22px 104px;text-align:center;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .42s cubic-bezier(.2,.72,.18,1),transform .42s cubic-bezier(.2,.72,.18,1);}
.sequence-slide.active{opacity:1;pointer-events:auto;transform:none;}
.sequence-slide.is-green{background:var(--sequence-hero);color:var(--sequence-hero-text);}
.sequence-line{max-width:13.5em;color:var(--ink);font-size:clamp(1.24rem,5.1vw,1.82rem);font-weight:800;line-height:1.72;letter-spacing:-.012em;text-wrap:balance;}
.sequence-line strong{color:var(--sequence-accent-ink);font-weight:900;}
.sequence-line.is-soft{max-width:18em;color:var(--ink-sub);font-size:clamp(1rem,4.1vw,1.3rem);font-weight:550;line-height:1.7;}
.sequence-copy{max-width:23em;margin-top:8px;color:var(--ink-sub);font-size:clamp(.98rem,3.9vw,1.14rem);font-weight:550;line-height:1.72;text-wrap:pretty;}
.sequence-rule{display:block;width:34px;height:1px;margin:16px 0;background:var(--line);}
.sequence-label{display:inline-flex;align-items:center;min-height:34px;margin-bottom:18px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--surface);color:var(--sequence-accent-ink);padding:0 13px;font-size:.78rem;font-weight:900;letter-spacing:.04em;}
.sequence-label.is-amber{color:var(--amber);}
.sequence-action{width:min(100%,340px);margin-top:22px;padding:20px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);text-align:left;box-shadow:0 14px 32px rgba(17,75,60,.06);}
.sequence-action span{display:block;margin-bottom:8px;color:var(--sequence-accent-ink);font-size:.78rem;font-weight:900;letter-spacing:.04em;}
.sequence-action p{color:var(--ink);font-size:1rem;font-weight:800;line-height:1.65;}
.sequence-slide.is-green .sequence-label{border-color:rgba(255,255,255,.26);background:rgba(255,255,255,.1);color:var(--sequence-hero-sub);}
.sequence-character{position:relative;width:156px;height:156px;margin:2px auto 18px;border-radius:38px;background:linear-gradient(180deg,var(--bg),var(--sequence-soft));border:1px solid rgba(255,255,255,.28);box-shadow:0 22px 44px var(--sequence-shadow);display:grid;place-items:center;overflow:hidden;}
.sequence-character::before{content:"";position:absolute;inset:12px;border-radius:30px;background:rgba(250,248,243,.72);}
.sequence-character.is-empty::after{content:"";position:relative;z-index:1;width:58px;height:58px;border:2px solid var(--sequence-accent-ink);border-radius:22px;background:var(--sequence-soft);box-shadow:inset 0 0 0 12px rgba(255,255,255,.52);}
.sequence-character img{position:relative;z-index:1;width:88%;height:88%;object-fit:contain;filter:saturate(.94) contrast(.98) drop-shadow(0 10px 18px rgba(13,59,47,.14));}
.sequence-type{max-width:13em;color:var(--sequence-hero-text);font-size:clamp(1.9rem,8vw,2.55rem);font-weight:900;line-height:1.2;letter-spacing:-.018em;text-wrap:balance;}
.sequence-tagline{max-width:20em;margin-top:10px;color:var(--sequence-hero-sub);font-size:1rem;font-weight:650;line-height:1.6;text-wrap:pretty;}
.sequence-cta{min-height:54px;display:inline-flex;align-items:center;justify-content:center;margin-top:26px;border-radius:12px;background:var(--sequence-accent-ink);color:var(--surface);padding:0 24px;font-size:1rem;font-weight:900;text-decoration:none;}
.sequence-sub-link{min-height:44px;display:inline-flex;align-items:center;margin-top:12px;color:var(--sequence-accent-ink);font-size:.9rem;font-weight:800;text-decoration:underline;text-underline-offset:4px;}
.sequence-back,.sequence-next{position:fixed;bottom:22px;z-index:35;min-height:44px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--surface);color:var(--sequence-accent-ink);padding:0 16px;font-family:inherit;font-size:.9rem;font-weight:900;cursor:pointer;box-shadow:0 10px 24px rgba(17,75,60,.08);}
.sequence-back{left:22px;}
.sequence-next{right:22px;background:var(--sequence-accent-ink);color:var(--surface);border-color:var(--sequence-accent-ink);}
.sequence-back:disabled{opacity:.42;cursor:not-allowed;}
.sequence-hint{position:fixed;left:50%;bottom:76px;z-index:34;width:min(100% - 132px,300px);transform:translateX(-50%);color:var(--ink-faint);font-size:.78rem;font-weight:800;line-height:1.45;text-align:center;pointer-events:none;}
.sequence-green-active .sequence-header{background:var(--sequence-hero);border-bottom-color:rgba(255,255,255,.14);}
.sequence-green-active .sequence-brand{color:var(--surface);}
.sequence-green-active .sequence-dots span{background:rgba(255,255,255,.24);}
.sequence-green-active .sequence-dots span.is-active{background:var(--surface);}
.sequence-green-active .sequence-back{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.24);color:var(--surface);}
.sequence-green-active .sequence-next{background:var(--surface);border-color:var(--surface);color:var(--sequence-accent-ink);}
.sequence-green-active .sequence-hint{color:rgba(255,255,255,.58);}

.prologue-lab-bar{width:min(100%,360px);min-height:38px;margin:0 auto 16px;border:1px solid var(--line);border-radius:var(--r-pill);background:rgba(255,255,255,.78);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 13px;box-shadow:0 10px 24px rgba(17,75,60,.06);}
.prologue-lab-bar span{color:var(--green);font-size:.74rem;font-weight:950;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;}
.prologue-lab-bar strong{color:var(--ink-sub);font-size:.75rem;font-weight:850;white-space:nowrap;}
.prologue-metrics{width:min(100%,360px);display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:18px auto 18px;}
.prologue-metrics div{min-width:0;min-height:62px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.82);padding:10px 8px;text-align:center;box-shadow:0 10px 24px rgba(17,75,60,.05);}
.prologue-metrics strong{display:block;color:var(--test-accent-ink,var(--green));font-size:1rem;font-weight:950;line-height:1.1;}
.prologue-metrics span{display:block;margin-top:5px;color:var(--ink-sub);font-size:.72rem;font-weight:850;line-height:1.25;}
.prologue-start-card{width:min(100%,390px);margin:16px auto 18px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.9);padding:16px;box-shadow:0 16px 36px rgba(17,75,60,.08);text-align:left;}
.prologue-start-head{display:grid;gap:6px;margin-bottom:14px;}
.prologue-start-head span{color:var(--test-accent-ink,var(--green));font-size:.72rem;font-weight:950;letter-spacing:.08em;text-transform:uppercase;}
.prologue-start-head strong{color:var(--ink);font-size:1.02rem;font-weight:900;line-height:1.45;text-wrap:balance;}
.prologue-signals{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.prologue-signals div{min-width:0;min-height:74px;border:1px solid var(--line);border-radius:8px;background:var(--surface-2);padding:10px 8px;}
.prologue-signals strong{display:block;color:var(--test-accent-ink,var(--green));font-size:.84rem;font-weight:950;line-height:1.2;}
.prologue-signals span{display:block;margin-top:5px;color:var(--ink-sub);font-size:.72rem;font-weight:780;line-height:1.35;}
.test-tabs{counter-reset:test-tab;margin-top:20px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.92);box-shadow:0 18px 42px rgba(17,75,60,.08);overflow:hidden;text-align:left;}
.test-tabs::before{content:"REPORT MAP";display:block;border-bottom:1px solid var(--line);background:linear-gradient(90deg,var(--green-soft),var(--surface));color:var(--green);padding:11px 14px 9px;font-size:.72rem;font-weight:950;letter-spacing:.08em;}
.tab-list{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;padding:8px;background:var(--surface);}
.tab-btn{counter-increment:test-tab;position:relative;min-height:54px;border:1px solid var(--line);border-radius:8px;background:var(--surface-2);color:var(--ink-sub);padding:8px 10px 8px 34px;font-size:.86rem;font-weight:850;line-height:1.25;text-align:left;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease,transform .18s ease;}
.tab-btn::before{content:counter(test-tab);position:absolute;left:10px;top:50%;width:18px;height:18px;display:grid;place-items:center;border-radius:var(--r-pill);background:var(--surface-2);color:var(--ink-sub);font-size:.68rem;font-weight:900;line-height:1;transform:translateY(-50%);}
.tab-btn:hover{border-color:var(--line);color:var(--green);}
.tab-btn[aria-selected="true"]{background:var(--green);color:var(--surface);border-color:var(--green);box-shadow:0 10px 22px rgba(17,75,60,.12);transform:translateY(-1px);}
.tab-btn[aria-selected="true"]::before{background:var(--surface);color:var(--green);}
.tab-panel{display:none;position:relative;padding:22px 20px 24px;background:linear-gradient(180deg,var(--surface),rgba(250,248,243,.72));}
.tab-panel.active{display:block;animation:tabPanelIn .28s cubic-bezier(.2,.72,.18,1) both;}
.tab-panel.active::before{content:"";position:absolute;left:20px;right:20px;top:0;height:1px;background:var(--line);}
.tab-panel h3{max-width:13em;font-size:1.16rem;font-weight:800;line-height:1.35;margin-bottom:9px;letter-spacing:-.01em;text-wrap:balance;}
.tab-panel p{max-width:24em;color:var(--ink-sub);font-size:1rem;line-height:1.7;text-wrap:pretty;}
@keyframes tabPanelIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.test-intro-image{position:relative;width:min(100%,260px);margin:0 auto 20px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--green-soft);box-shadow:0 18px 38px rgba(17,75,60,.09);}
.test-intro-image::before{content:"GIVE";position:absolute;left:12px;top:10px;z-index:1;border-radius:var(--r-pill);background:rgba(255,255,255,.82);color:var(--green);padding:4px 8px;font-size:.66rem;font-weight:950;letter-spacing:.08em;}
.test-intro-image img{width:100%;aspect-ratio:1/1;object-fit:cover;}
.test-intro-caption{max-width:25em;margin:-8px auto 18px;color:var(--ink-sub);font-size:.9rem;font-weight:700;line-height:1.6;text-align:center;text-wrap:pretty;}
.result-report-lead{display:grid;gap:14px;margin-bottom:16px;}
.result-report-copy{padding:18px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface-2);}
.result-report-copy strong{display:block;margin-bottom:6px;font-size:1.02rem;color:var(--green);}
.result-report-copy p{color:var(--ink-sub);font-size:.95rem;line-height:1.7;}
.result-story{display:grid;gap:16px;margin-top:16px;}
.result-visual{border-radius:var(--r-lg);overflow:hidden;background:var(--green-soft);}
.result-visual img{width:100%;aspect-ratio:1/1;object-fit:cover;}
.result-cards{display:grid;gap:12px;}
.prologue-visual{width:100%;height:100px;margin-bottom:14px;border:1px solid var(--line);border-radius:8px;background:var(--green-soft);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.prologue-visual svg{display:block;width:160px;height:90px;flex-shrink:0;}
.hogoo-page .prologue-visual,.risk-page .prologue-visual{background:var(--amber-soft);}
.refusal-page .prologue-visual{background:var(--mint-soft);}

.page-shell{width:min(100%,680px);margin:0 auto;padding:0 22px;}
.page-main{padding:44px 0 8px;}
.legal-page h1{max-width:13em;margin-bottom:26px;font-size:clamp(2rem,8.4vw,2.45rem);font-weight:800;line-height:1.16;letter-spacing:-.02em;text-wrap:balance;}
.legal-page h2{margin:32px 0 12px;font-size:1.4rem;font-weight:800;line-height:1.3;letter-spacing:-.01em;text-wrap:balance;}
.legal-page p,.legal-page li{color:var(--ink-sub);font-size:1rem;line-height:1.75;text-wrap:pretty;}
.legal-page ul{padding-left:20px;margin:0 0 22px;}
.legal-page li{margin-bottom:8px;}

.form-page .form-header{padding:48px 0 30px;text-align:center;}
.form-page .form-header h1{max-width:13em;margin:0 auto 12px;font-size:clamp(2rem,8.4vw,2.55rem);font-weight:800;line-height:1.16;letter-spacing:-.02em;text-wrap:balance;}
.form-page .form-header p{max-width:24em;margin:0 auto;color:var(--ink-sub);font-size:1rem;line-height:1.75;text-wrap:pretty;}
.form-container{padding:26px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);box-shadow:0 16px 36px rgba(17,75,60,.06);}
.form-group{margin-bottom:20px;}
.form-group label{display:block;margin-bottom:8px;color:var(--ink);font-size:.92rem;font-weight:800;}
.form-group input,.form-group textarea{width:100%;min-height:48px;border:1px solid var(--line);border-radius:12px;background:var(--surface);color:var(--ink);padding:13px 15px;font-size:1rem;line-height:1.5;}
.form-group textarea{resize:vertical;min-height:144px;}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--mint);box-shadow:0 0 0 4px rgba(0,168,133,.13);}
.submit-btn{width:100%;min-height:54px;border:0;border-radius:12px;background:var(--green);color:var(--surface);font-size:1rem;font-weight:800;cursor:pointer;box-shadow:0 12px 26px rgba(17,75,60,.16);}
.submit-btn:hover{background:var(--green-deep);}

.error-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:28px 22px;text-align:center;}
.error-card{width:min(100%,480px);}
.error-card .itile{margin:0 auto 22px;}
.error-code{display:block;margin-bottom:8px;color:var(--green);font-family:var(--serif);font-size:clamp(4.2rem,22vw,6rem);font-style:italic;line-height:1;}
.error-page h1{max-width:13em;margin:0 auto 12px;font-size:1.45rem;font-weight:800;line-height:1.3;letter-spacing:-.01em;text-wrap:balance;}
.error-page p{max-width:24em;margin:0 auto 24px;color:var(--ink-sub);font-size:1rem;line-height:1.7;text-wrap:pretty;}
.link-row{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 18px;margin-top:20px;}
.link-row a{min-height:44px;display:inline-flex;align-items:center;color:var(--green);font-size:.92rem;font-weight:800;text-decoration:none;}
.link-row a:hover{text-decoration:underline;}

.review-shell{width:min(100%,760px);margin:0 auto;padding:0 22px;}
.site-nav .review-shell{display:flex;align-items:center;justify-content:space-between;gap:14px;}
.review-hero{padding:44px 0 26px;}
.review-hero h1{max-width:13em;margin:0 0 14px;font-size:clamp(2rem,8vw,3.2rem);font-weight:800;line-height:1.12;letter-spacing:-.02em;text-wrap:balance;}
.review-hero .lead{max-width:30em;color:var(--ink-sub);font-size:1rem;font-weight:650;line-height:1.75;text-wrap:pretty;}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:24px 0;}
.stat{padding:17px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);}
.stat strong{display:block;color:var(--green);font-size:1.3rem;font-weight:900;}
.stat span{color:var(--ink-sub);font-size:.8rem;font-weight:800;}
.review-grid{display:grid;gap:12px;padding-bottom:34px;}
.review-card,.write-card{padding:20px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);box-shadow:0 12px 28px rgba(17,75,60,.06);}
.review-card.own-review{border-color:var(--mint);box-shadow:0 12px 28px rgba(0,168,133,.11);}
.review-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;}
.name{display:flex;align-items:center;gap:8px;min-width:0;font-weight:900;}
.name span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.own-review-badge{display:inline-flex;flex:0 0 auto;min-height:22px;align-items:center;border-radius:var(--r-pill);background:var(--green-soft);color:var(--green);padding:0 8px;font-size:.72rem;font-weight:950;}
.stars{color:var(--amber-accent);font-size:.92rem;flex:0 0 auto;}
.content{color:var(--ink);font-size:.96rem;font-weight:650;line-height:1.7;text-wrap:pretty;}
.meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;color:var(--ink-sub);font-size:.8rem;font-weight:800;}
.review-delete-btn{display:inline-flex;min-height:34px;align-items:center;justify-content:center;border:1px solid var(--amber-accent);border-radius:8px;background:transparent;color:var(--amber);padding:0 12px;font-size:.78rem;font-weight:900;cursor:pointer;}
.review-delete-btn:hover{background:var(--amber-soft);}
.empty{padding:28px;border:1px dashed var(--line);border-radius:var(--r);background:var(--surface);color:var(--ink-sub);text-align:center;font-weight:800;}
.review-cta{display:grid;gap:12px;margin:6px 0 42px;padding:24px;border-radius:var(--r-lg);background:var(--green);color:var(--surface);}
.review-cta p{color:var(--mint-soft);font-size:.95rem;line-height:1.65;}
.review-info{margin:8px 0 32px;padding:24px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);}
.review-info h2,.related-block h2,.write-card h2{margin-bottom:14px;font-size:1.12rem;font-weight:800;line-height:1.35;letter-spacing:-.01em;text-wrap:balance;}
.review-info p{margin-bottom:14px;color:var(--ink-sub);font-size:.96rem;line-height:1.75;text-wrap:pretty;}
.mission-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:18px;}
.mission-tile{padding:16px;border:1px solid var(--line);border-radius:var(--r);background:var(--green-soft);}
.mission-day{margin-bottom:6px;color:var(--mint-ink);font-size:.78rem;font-weight:900;}
.mission-title{color:var(--ink);font-size:.93rem;font-weight:800;}
.mission-desc{margin-top:4px;color:var(--ink-sub);font-size:.84rem;line-height:1.55;}
.related-block{margin:0 0 48px;}
.related-list{display:grid;gap:10px;}
.related-link{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);color:var(--ink);text-decoration:none;}
.related-link:hover{border-color:var(--mint);}
.related-link strong{display:block;margin-bottom:2px;font-size:.93rem;font-weight:800;line-height:1.35;}
.related-link span{display:block;color:var(--ink-sub);font-size:.82rem;line-height:1.5;}
.field{margin-bottom:14px;}
.field label{display:block;margin-bottom:6px;color:var(--ink-sub);font-size:.82rem;font-weight:800;}
.field input,.field textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 13px;background:var(--surface);color:var(--ink);font-size:1rem;line-height:1.55;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--mint);box-shadow:0 0 0 4px rgba(0,168,133,.13);}
.field textarea{resize:vertical;min-height:96px;}
.star-row{display:flex;gap:4px;}
.star-btn{min-width:44px;min-height:44px;border:0;background:transparent;color:var(--line);font-size:1.45rem;cursor:pointer;}
.star-btn.on{color:var(--amber-accent);}
.form-msg{min-height:1.2em;margin-top:10px;text-align:center;font-size:.86rem;font-weight:750;color:var(--ink-sub);}
.form-msg.success{color:var(--green);}
.form-msg.error{color:var(--amber);}
.auth-notice{margin-bottom:28px;padding:20px;border:1px solid var(--line);border-radius:var(--r);background:var(--green-soft);text-align:center;}
.auth-notice strong{display:block;margin-bottom:8px;color:var(--ink);font-weight:900;}
.auth-notice a{color:var(--green);font-weight:900;text-decoration:none;}

.challenge-seo{background:var(--green);color:var(--surface);}
.challenge-seo .seo-inner{width:min(100%,760px);margin:0 auto;padding:36px 22px;}
.challenge-seo h1,.challenge-seo h2,.challenge-seo h3{line-height:1.28;letter-spacing:-.01em;text-wrap:balance;}
.challenge-seo h1{margin:0 0 14px;font-size:clamp(2rem,8vw,2.8rem);font-weight:800;}
.challenge-seo h2{margin:34px 0 14px;font-size:1.4rem;font-weight:800;}
.challenge-seo h3{margin:0 0 8px;color:var(--surface);font-size:1rem;font-weight:800;}
.challenge-seo p,.challenge-seo li{color:var(--mint-soft);font-size:1rem;line-height:1.75;text-wrap:pretty;}
.challenge-seo p{margin:0 0 14px;}
.challenge-seo ul,.challenge-seo ol{padding-left:20px;color:var(--mint-soft);line-height:1.75;}
.challenge-seo li{margin-bottom:8px;}
.seo-grid{display:grid;gap:12px;margin:18px 0;}
.seo-card{padding:18px;border:1px solid rgba(255,255,255,.22);border-radius:var(--r);background:rgba(255,255,255,.08);}
.seo-note{padding:18px;border-left:4px solid var(--amber-accent);border-radius:var(--r);background:rgba(255,255,255,.1);}
.challenge-footer-shell{width:min(100%,760px);margin:0 auto;padding:0 22px;}

.article-shell{width:min(100%,720px);margin:0 auto;padding:0 22px;}
.article-hub-hero{padding:54px 0 46px;border-bottom:1px solid var(--line);margin-bottom:42px;background:var(--surface);}
.article-hub-hero h1{max-width:13em;margin:0 0 16px;font-size:clamp(2rem,8vw,2.7rem);font-weight:800;line-height:1.18;letter-spacing:-.02em;text-wrap:balance;}
.hero-desc{max-width:34em;margin-bottom:28px;color:var(--ink-sub);font-size:1rem;line-height:1.75;text-wrap:pretty;}
.category-row{display:flex;flex-wrap:wrap;gap:10px;}
.cat-btn{min-height:40px;display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--surface-2);color:var(--ink-sub);padding:0 15px;font-size:.82rem;font-weight:800;}
.cat-btn.active{background:var(--green);color:var(--surface);border-color:var(--green);}
.articles-section{padding-bottom:56px;}
.article-list{display:grid;gap:14px;}
.article-card{display:flex;align-items:flex-start;gap:18px;padding:22px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);color:var(--ink);text-decoration:none;box-shadow:0 12px 28px rgba(17,75,60,.05);transition:border-color .2s,transform .18s;}
.article-card:hover{border-color:var(--mint);transform:translateY(-2px);}
.article-body{flex:1;min-width:0;}
.article-tag{display:block;margin-bottom:8px;color:var(--amber);font-size:.74rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;}
.article-title{margin-bottom:8px;color:var(--ink);font-size:1.14rem;font-weight:800;line-height:1.4;letter-spacing:-.01em;text-wrap:balance;}
.article-desc{margin-bottom:14px;color:var(--ink-sub);font-size:.94rem;line-height:1.65;text-wrap:pretty;}
.article-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.read-time{color:var(--ink-faint);font-size:.8rem;font-weight:800;}
.read-btn{display:inline-flex;align-items:center;min-height:34px;border-radius:var(--r-pill);background:var(--green-soft);color:var(--green);padding:0 13px;font-size:.82rem;font-weight:800;}
.intro-text{margin-bottom:32px;padding:24px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);}
.intro-text h2{margin-bottom:12px;color:var(--ink);font-size:1.18rem;font-weight:800;line-height:1.35;}
.intro-text p{color:var(--ink-sub);font-size:.96rem;line-height:1.75;text-wrap:pretty;}
.cta-banner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin:44px 0;padding:28px;border-radius:var(--r-lg);background:var(--green);color:var(--surface);}
.cta-banner h3{margin-bottom:8px;font-size:1.2rem;font-weight:800;}
.cta-banner p{color:var(--mint-soft);font-size:.95rem;line-height:1.65;}
.cta-btn{min-height:48px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:var(--surface);color:var(--green);padding:0 18px;font-size:.95rem;font-weight:800;text-decoration:none;}

.article-detail-page{background:var(--bg);color:var(--ink);line-height:1.8;}
.article-detail-page .container{width:min(100%,720px);margin:0 auto;padding:0 22px;}
.article-detail-page nav{margin-bottom:54px;}
.article-header{margin-bottom:50px;}
.category{display:inline-block;margin-bottom:14px;color:var(--mint-ink);font-size:.86rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;}
.article-detail-page .article-title{margin-bottom:24px;font-size:clamp(2rem,8vw,2.8rem);font-weight:800;line-height:1.22;letter-spacing:-.02em;text-wrap:balance;}
.author-box{display:flex;align-items:center;gap:12px;margin-bottom:36px;}
.author-img{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--green-soft);color:var(--green);}
.author-img svg{width:24px;height:24px;fill:none;stroke:var(--green);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}
.author-info{font-size:.95rem;}
.author-name{color:var(--ink);font-weight:800;}
.publish-date{color:var(--ink-faint);}
.featured-image{width:100%;min-height:320px;margin-bottom:50px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;background:var(--green-soft);box-shadow:inset 0 0 36px rgba(17,75,60,.05);}
.featured-image .itile{width:86px;height:86px;border-radius:24px;}
.featured-image .itile svg{width:44px;height:44px;}
.article-content h2,.faq-section > h2{margin:58px 0 22px;padding-left:18px;border-left:5px solid var(--green);font-size:1.45rem;font-weight:800;line-height:1.35;letter-spacing:-.01em;text-wrap:balance;}
.article-content p{margin-bottom:26px;color:var(--ink-sub);font-size:1rem;line-height:1.8;text-wrap:pretty;}
.article-content blockquote{margin:44px 0;padding:28px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);color:var(--green);font-size:1.12rem;font-weight:750;line-height:1.65;}
.article-content ul,.article-content ol{margin-bottom:36px;padding-left:24px;}
.article-content li{margin-bottom:14px;color:var(--ink-sub);font-size:1rem;line-height:1.75;}
.article-content strong{color:var(--ink);font-weight:800;}
.script-box{margin:36px 0;padding:24px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);}
.script-label{display:block;margin-bottom:10px;color:var(--amber);font-size:.78rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;}
.script-text{color:var(--ink-sub);font-size:1rem;line-height:1.7;}
.cta-section{margin:70px 0;padding:34px 26px;border-radius:var(--r-lg);background:var(--green);color:var(--surface);text-align:center;}
.cta-section h3{margin-bottom:16px;font-size:1.55rem;font-weight:800;line-height:1.3;}
.cta-section p{margin-bottom:24px;color:var(--mint-soft);font-size:1rem;line-height:1.65;}
.summary-box{margin-bottom:50px;padding:26px;border-left:5px solid var(--green);border-radius:var(--r-lg);background:var(--green-soft);}
.summary-box h3{margin-bottom:14px;color:var(--green);font-size:.86rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;}
.summary-box ul{list-style:none;padding-left:0;}
.summary-box li{padding:10px 0;border-bottom:1px solid var(--line);color:var(--ink);font-size:1rem;font-weight:650;}
.summary-box li:last-child{border-bottom:0;}
.summary-box li::before{content:"✓  ";color:var(--green);font-weight:900;}
.faq-section{margin:72px 0 48px;}
.faq-item{padding:26px 0;border-bottom:1px solid var(--line);}
.faq-item:last-child{border-bottom:0;}
.faq-q{display:flex;gap:10px;margin-bottom:12px;color:var(--ink);font-size:1.05rem;font-weight:800;}
.faq-q::before{content:"Q.";color:var(--green);font-weight:900;flex-shrink:0;}
.faq-a{margin:0;padding-left:28px;color:var(--ink-sub);font-size:1rem;line-height:1.75;}
.related-section{margin:48px 0;padding:26px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);}
.related-section h3{margin-bottom:18px;color:var(--ink-sub);font-size:.92rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;}
.related-links{display:grid;gap:10px;}
.related-link-icon{flex-shrink:0;color:var(--green);}
.related-grid{display:grid;gap:12px;margin-top:18px;}
.related-card{display:block;padding:18px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);color:var(--ink);text-decoration:none;}
.related-card:hover{border-color:var(--mint);}
.related-card-label{margin-bottom:5px;color:var(--amber);font-size:.78rem;font-weight:900;}
.related-card-title{color:var(--ink);font-size:.98rem;font-weight:800;line-height:1.45;}

.about-page .container{width:min(100%,720px);margin:0 auto;padding:0 22px;}
.about-page main h1{max-width:13em;margin-bottom:18px;font-size:clamp(2rem,8vw,2.65rem);font-weight:800;line-height:1.22;letter-spacing:-.02em;text-wrap:balance;}
.about-page main h2{margin:54px 0 20px;padding-left:16px;border-left:5px solid var(--green);font-size:1.4rem;font-weight:800;line-height:1.35;letter-spacing:-.01em;text-wrap:balance;}
.about-page main h3{margin-bottom:10px;color:var(--ink);font-size:1.1rem;font-weight:800;}
.about-page main p{margin-bottom:24px;color:var(--ink-sub);font-size:1rem;line-height:1.8;text-wrap:pretty;}
.about-page .lead{margin-bottom:44px;color:var(--ink-sub);font-size:1.08rem;line-height:1.8;}
.highlight-box{margin:38px 0;padding:26px;border-left:5px solid var(--green);border-radius:var(--r-lg);background:var(--green-soft);}
.highlight-box h3{color:var(--green);}
.highlight-box p{margin:0;color:var(--ink);}
.value-grid,.team-grid{display:grid;gap:16px;margin:30px 0;}
.value-card,.team-card{padding:22px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);}
.value-card .itile{margin-bottom:12px;}
.value-card h3{color:var(--green);}
.value-card p,.team-info p{margin:0;color:var(--ink-sub);font-size:.95rem;line-height:1.7;}
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:38px 0;}
.stat-box{padding:24px 14px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);text-align:center;}
.stat-box strong{display:block;margin-bottom:6px;color:var(--green);font-size:1.8rem;font-weight:900;}
.stat-box span{color:var(--ink-sub);font-size:.86rem;font-weight:800;line-height:1.45;}
.research-box{margin:32px 0;padding:24px;border-left:5px solid var(--amber-accent);border-radius:0 var(--r-lg) var(--r-lg) 0;background:var(--amber-soft);}
.research-box .label{display:block;margin-bottom:10px;color:var(--amber);font-size:.76rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;}
.research-box p{margin:0;color:var(--ink-sub);font-size:.95rem;line-height:1.75;}
.team-card{display:flex;align-items:flex-start;gap:18px;}
.team-avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--green-soft);}
.team-avatar svg{width:28px;height:28px;fill:none;stroke:var(--green);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}
.team-info .role{display:block;margin-bottom:8px;color:var(--green);font-size:.82rem;font-weight:800;}
.cta-box{margin:58px 0;padding:34px 26px;border-radius:var(--r-lg);background:var(--green);color:var(--surface);text-align:center;}
.cta-box h3{margin-bottom:14px;color:var(--surface);font-size:1.45rem;font-weight:800;}
.cta-box p{margin-bottom:24px;color:var(--mint-soft);}

.done-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:0;}
.done-top-wrap{width:100%;border-bottom:1px solid var(--line);}
.topbar{width:100%;max-width:560px;margin:0 auto;padding:16px 22px;display:flex;align-items:center;justify-content:space-between;}
.topbar-logo{font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--green);text-decoration:none;}
.topbar-home{min-height:44px;display:inline-flex;align-items:center;color:var(--ink-sub);font-size:.86rem;font-weight:800;text-decoration:none;}
.topbar-home:hover{color:var(--green);}
.done-page .page{width:100%;max-width:420px;margin:0 auto;padding:0 22px 64px;}
.badge-wrap{text-align:center;padding:48px 0 36px;position:relative;}
.badge-ring{width:120px;height:120px;margin:0 auto 20px;position:relative;}
.badge-ring svg{width:100%;height:100%;}
.badge-progress{transition:stroke-dashoffset 1.2s cubic-bezier(.2,.72,.18,1);}
.badge-inner{position:absolute;inset:10px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;flex-direction:column;}
.badge-num{font-family:var(--serif);font-size:2rem;font-weight:700;color:var(--surface);line-height:1;}
.badge-unit{margin-top:3px;color:var(--mint-soft);font-size:.65rem;font-weight:800;letter-spacing:.06em;}
.badge-label{margin-bottom:10px;color:var(--mint-ink);font-family:var(--serif);font-size:.95rem;font-style:italic;}
.badge-title{margin-bottom:10px;color:var(--ink);font-size:clamp(1.6rem,7vw,2.2rem);font-weight:800;line-height:1.22;letter-spacing:-.02em;text-wrap:balance;}
.badge-sub{max-width:22em;margin:0 auto;color:var(--ink-sub);font-size:.97rem;line-height:1.72;text-wrap:pretty;}
.done-page .stats{grid-template-columns:repeat(3,1fr);margin:28px 0;}
.done-page .stat{text-align:center;}
.done-page .stat .num{color:var(--green);font-size:1.35rem;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums;}
.done-page .stat .lbl{margin-top:3px;color:var(--ink-faint);font-size:.72rem;}
.share-card{margin-bottom:16px;padding:26px 22px;border-radius:var(--r-lg);background:var(--green);text-align:center;}
.share-card .sc-eyebrow{display:block;margin-bottom:10px;color:var(--mint-soft);font-family:var(--serif);font-size:.88rem;font-style:italic;}
.share-card h2{margin-bottom:8px;color:var(--surface);font-size:1.18rem;font-weight:800;line-height:1.35;}
.share-card p{margin-bottom:20px;color:var(--mint-soft);font-size:.88rem;line-height:1.65;}
.share-btns{display:grid;gap:10px;}
.btn-threads,.btn-share-more{min-height:52px;border-radius:12px;font-family:inherit;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;}
.btn-threads{border:0;background:var(--surface);color:var(--green);font-size:.98rem;}
.btn-threads img{width:22px;height:22px;}
.btn-share-more{border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.12);color:var(--surface);font-size:.9rem;}
.next-title{margin-bottom:12px;color:var(--ink);font-size:1rem;font-weight:800;}
.next-grid{display:grid;gap:10px;}
.next-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);color:inherit;text-decoration:none;transition:border-color .2s;}
.next-card:hover{border-color:var(--mint);}
.next-card .itile{flex-shrink:0;}
.nc-text{flex:1;}
.nc-title{display:block;margin-bottom:3px;font-size:1rem;font-weight:800;}
.nc-desc{color:var(--ink-sub);font-size:.84rem;}
.nc-go{color:var(--green);font-size:.84rem;font-weight:800;white-space:nowrap;}
.reset-wrap{margin-top:28px;padding-top:24px;border-top:1px solid var(--line);text-align:center;}
.reset-btn{border:0;background:none;color:var(--ink-faint);font-family:inherit;font-size:.84rem;cursor:pointer;text-decoration:underline;text-underline-offset:3px;}
.reset-btn:hover{color:var(--ink-sub);}
.paid-lite-cta{margin-top:16px;padding:20px;border:1px solid var(--line);border-radius:var(--r);background:var(--green-soft);}
.paid-lite-cta p{margin:0 0 14px;color:var(--green);font-size:.95rem;font-weight:800;line-height:1.5;}
.paid-lite-cta .micro{margin-top:10px;color:var(--ink-sub);}
.unlock-note{color:var(--ink-sub);font-size:.9rem;font-weight:800;}
.flush-title{margin:0;}
.related-card.is-locked{cursor:pointer;opacity:.72;}
.related-icon.locked{background:var(--surface-2);color:var(--green);}
.reward-root-spaced{margin-top:32px;}
.result-sequence-link{display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px;text-decoration:none;}
.result-preview-link{display:inline-flex;align-items:center;justify-content:center;width:min(100%,280px);min-height:46px;margin:18px auto 12px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--surface);color:var(--green);padding:0 18px;font-size:.94rem;font-weight:900;text-decoration:none;box-shadow:0 10px 24px rgba(17,75,60,.07);}
.result-preview-link:hover{border-color:var(--mint);background:var(--green-soft);}

.refusal-page .inner{width:min(100%,480px);margin:0 auto;padding:0 22px;}
.refusal-page .page{width:100%;}
.refusal-page .hidden{display:none!important;}
.refusal-page #intro{position:relative;min-height:100vh;display:flex;align-items:center;padding:72px 0 92px;text-align:center;background:linear-gradient(180deg,var(--mint-soft) 0%,var(--bg) 48%,var(--surface) 100%);overflow:hidden;}
.refusal-page #intro::before{content:"";position:absolute;inset:36px calc(50% - 260px) 64px;border:1px solid rgba(10,95,77,.08);border-radius:8px;background:linear-gradient(90deg,rgba(10,95,77,.05) 1px,transparent 1px),linear-gradient(180deg,rgba(10,95,77,.04) 1px,transparent 1px);background-size:30px 30px;pointer-events:none;}
.refusal-page #intro > .inner{position:relative;z-index:1;}
.refusal-page #test{min-height:100vh;padding:40px 0 80px;background:var(--surface);}
.refusal-page #result{padding:40px 0 100px;background:var(--bg);}
.refusal-page .badge{display:inline-flex;margin-bottom:20px;padding:7px 12px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--green-soft);color:var(--green);font-size:.78rem;font-weight:900;letter-spacing:.03em;}
.refusal-page h1{margin-bottom:14px;color:var(--ink);font-size:clamp(2rem,8.4vw,2.6rem);font-weight:800;line-height:1.18;letter-spacing:-.02em;text-wrap:balance;}
.refusal-page p{color:var(--ink-sub);font-size:1rem;line-height:1.7;text-wrap:pretty;}
.refusal-page .meta{margin:-4px 0 24px;color:var(--ink-faint);font-size:.85rem;font-weight:700;}
.refusal-page button,.refusal-page a.btn{min-height:54px;width:100%;border:0;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--green);color:var(--surface);padding:0 18px;font-family:inherit;font-size:1rem;font-weight:800;text-decoration:none;cursor:pointer;box-shadow:0 12px 26px rgba(17,75,60,.16);}
.refusal-page .progress{height:8px;margin-bottom:40px;border-radius:var(--r-pill);background:var(--surface-2);overflow:hidden;}
.refusal-page .fill{width:0;height:100%;border-radius:var(--r-pill);background:var(--mint);transition:width .4s cubic-bezier(.4,0,.2,1);}
.refusal-page .q{min-height:80px;margin-bottom:34px;color:var(--ink);font-size:1.35rem;font-weight:800;line-height:1.4;text-wrap:balance;}
.refusal-page .answers{display:flex;flex-direction:column;gap:12px;}
.refusal-page .ans{justify-content:flex-start;min-height:62px;border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:18px 20px;text-align:left;box-shadow:none;}
.refusal-page .ans:hover{border-color:var(--mint);background:var(--green-soft);}
.refusal-page .card{margin-bottom:20px;padding:28px 24px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);box-shadow:0 12px 28px rgba(17,75,60,.06);}
.refusal-page .card h2{margin-bottom:14px;color:var(--green);font-size:1.15rem;font-weight:800;}
.result-name{margin-bottom:12px!important;font-size:clamp(1.9rem,8vw,2.35rem)!important;}
.result-body-copy{font-size:1.02rem!important;color:var(--ink-sub)!important;}
.practice-card{background:var(--green-soft)!important;border-color:var(--line)!important;}
.practice-card h2{color:var(--green)!important;}
.practice-script{color:var(--ink)!important;font-size:1.1rem!important;font-weight:800!important;line-height:1.55!important;}
.expert-insight{position:relative;margin-bottom:24px;padding:26px 24px;border-radius:var(--r-lg);background:var(--green);color:var(--surface);overflow:hidden;}
.expert-title{display:block;margin-bottom:12px;color:var(--mint-soft);font-size:.8rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;}
.expert-headline{margin-bottom:12px;color:var(--surface);font-size:1.12rem;font-weight:800;line-height:1.4;}
.expert-text{margin-bottom:20px;color:var(--mint-soft)!important;font-size:.92rem!important;line-height:1.7!important;}
.expert-link{display:inline-flex;align-items:center;min-height:44px;color:var(--surface);font-size:.9rem;font-weight:800;text-decoration:underline;text-underline-offset:4px;}
.info{display:grid;gap:16px;margin-top:24px;}
.info-card{padding:22px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);}
.info-card h2{margin-bottom:12px;color:var(--green);font-size:1.08rem;font-weight:800;}
.practice-list{padding-left:20px;color:var(--ink-sub);font-weight:650;line-height:1.7;}
.practice-list li{margin-bottom:8px;}
.refusal-page .grid{display:grid;gap:12px;margin-top:32px;}
.refusal-page .rel{display:block;padding:18px 20px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);color:var(--ink);font-weight:800;text-decoration:none;}
.refusal-page .rel span{display:block;margin-top:4px;color:var(--ink-sub);font-size:.84rem;font-weight:650;}
.home-return{text-align:center;margin-top:40px;}
.home-return a{color:var(--ink-sub);font-weight:800;text-decoration:none;}

.risk-page{background:var(--bg);}
.risk-page .inner{width:min(100%,480px);margin:0 auto;padding:0 22px;}
.risk-page .hidden{display:none!important;}
.risk-page #intro-page{position:relative;min-height:100vh;display:flex;align-items:center;padding:72px 0 92px;text-align:center;background:linear-gradient(180deg,var(--amber-soft) 0%,var(--bg) 48%,var(--surface) 100%);overflow:hidden;}
.risk-page #intro-page::before{content:"";position:absolute;inset:36px calc(50% - 260px) 64px;border:1px solid rgba(122,78,18,.08);border-radius:8px;background:linear-gradient(90deg,rgba(122,78,18,.05) 1px,transparent 1px),linear-gradient(180deg,rgba(122,78,18,.04) 1px,transparent 1px);background-size:30px 30px;pointer-events:none;}
.risk-page #intro-page > .inner{position:relative;z-index:1;}
.hogoo-page #intro-page .test-tabs,.risk-page #intro-page .test-tabs,.refusal-page #intro .test-tabs,.hogoo-page #intro-page .quality-section,.risk-page #intro-page .quality-section,.refusal-page #intro .quality-section,.hogoo-page #intro-page .test-meta,.risk-page #intro-page .test-meta{display:none;}
.risk-page #test-page{min-height:100vh;padding:40px 0 80px;background:var(--surface);}
.risk-page #result-page{padding:40px 0 100px;background:var(--bg);}
.test-badge{display:inline-flex;margin-bottom:22px;padding:7px 12px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--surface);color:var(--amber);font-size:.78rem;font-weight:900;letter-spacing:.03em;}
.test-title{max-width:13em;margin:0 auto 16px;color:var(--ink);font-size:clamp(2rem,8.4vw,2.6rem);font-weight:800;line-height:1.18;letter-spacing:-.02em;text-wrap:balance;}
.test-subtitle{max-width:24em;margin:0 auto;color:var(--ink-sub);font-size:1rem;line-height:1.7;text-wrap:pretty;}
.test-meta{margin:22px 0 30px;color:var(--ink-faint);font-size:.85rem;font-weight:700;}
.start-btn{min-height:54px;width:100%;border:0;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--green);color:var(--surface);padding:0 18px;font-family:inherit;font-size:1rem;font-weight:800;cursor:pointer;box-shadow:0 12px 26px rgba(17,75,60,.16);}
.progress-wrap{margin-bottom:40px;}
.progress-info{display:flex;justify-content:space-between;margin-bottom:12px;color:var(--ink-sub);font-size:.85rem;font-weight:800;}
.progress-bar{height:8px;border-radius:var(--r-pill);background:var(--surface-2);overflow:hidden;}
.progress-fill{width:0;height:100%;border-radius:var(--r-pill);background:var(--amber-accent);transition:width .4s cubic-bezier(.4,0,.2,1);}
.q-num-label{display:block;margin-bottom:16px;color:var(--amber);font-size:.85rem;font-weight:900;letter-spacing:.05em;}
.q-text{min-height:80px;margin-bottom:34px;color:var(--ink);font-size:1.35rem;font-weight:800;line-height:1.4;text-wrap:balance;}
.answer-list{display:flex;flex-direction:column;gap:12px;}
.ans-btn{min-height:62px;border:1px solid var(--line);border-radius:12px;background:var(--surface);color:var(--ink);padding:18px 20px;text-align:left;font-family:inherit;font-size:1rem;font-weight:750;line-height:1.45;cursor:pointer;}
.ans-btn:hover{border-color:var(--amber-accent);background:var(--amber-soft);}
.result-header{padding-top:16px;margin-bottom:32px;text-align:center;}
.result-header .label{margin-bottom:8px;color:var(--ink-sub);font-size:.9rem;font-weight:800;}
.character{width:140px;height:140px;display:block;margin:16px auto;overflow:visible;color:var(--amber-accent);}
.result-character-frame{width:156px;height:156px;margin:16px auto;position:relative;display:grid;place-items:center;border:1px solid var(--line);border-radius:38px;background:linear-gradient(180deg,var(--bg),var(--green-soft));box-shadow:0 18px 38px rgba(17,75,60,.12);overflow:hidden;}
.result-character-frame::before{content:"";position:absolute;inset:12px;border-radius:30px;background:rgba(250,248,243,.72);}
.result-character-frame.is-empty::after{content:"";position:relative;z-index:1;width:58px;height:58px;border:2px solid var(--green);border-radius:22px;background:var(--mint-soft);box-shadow:inset 0 0 0 12px rgba(255,255,255,.52);}
.result-character-frame img,.result-character-frame svg{position:relative;z-index:1;width:88%;height:88%;object-fit:contain;filter:saturate(.94) contrast(.98) drop-shadow(0 10px 18px rgba(13,59,47,.14));}
.result-character-frame img + svg{display:none;}
.result-character-frame svg{overflow:visible;}
.type-name{margin-top:12px;color:var(--ink);font-size:clamp(1.9rem,8vw,2.35rem);font-weight:800;line-height:1.2;letter-spacing:-.02em;text-wrap:balance;}
.score-bar{margin-top:16px;}
.score-label{margin-bottom:8px;color:var(--ink-sub);font-size:.82rem;font-weight:800;}
.score-track{height:10px;border-radius:var(--r-pill);background:var(--surface-2);overflow:hidden;}
.score-fill{height:100%;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--mint),var(--amber-accent),var(--amber));transition:width 1s cubic-bezier(.4,0,.2,1);}
.type-desc-box,.result-card{margin-bottom:18px;padding:26px 24px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);box-shadow:0 12px 28px rgba(17,75,60,.06);}
.type-tagline{margin-bottom:12px;color:var(--amber);font-size:1.12rem;font-weight:800;line-height:1.5;text-align:center;text-wrap:balance;}
.type-body{color:var(--ink-sub);font-size:1rem;line-height:1.75;text-align:center;text-wrap:pretty;}
.card-title{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:var(--green);font-size:.92rem;font-weight:900;letter-spacing:.02em;}
.card-title.is-warning{color:var(--amber);}
.card-body{color:var(--ink-sub);font-size:.96rem;font-weight:550;line-height:1.7;text-wrap:pretty;}
.risk-page .expert-insight{background:var(--green);}
.risk-page .expert-title{color:var(--surface);}
.result-card.is-warning{background:var(--amber-soft);}
.result-card.is-action{background:var(--green-soft);}
.result-cta,.paid-deep-cta{margin-top:32px;padding:26px 24px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);text-align:center;}
.result-cta h3,.paid-deep-cta h3{margin-bottom:12px;color:var(--green);font-size:1.15rem;font-weight:800;line-height:1.45;text-wrap:balance;}
.result-cta p,.paid-deep-cta p{margin-bottom:20px;color:var(--ink-sub);font-size:.95rem;line-height:1.65;}
.white-psychology-bridge{margin:22px 0 0;padding:22px 20px;border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--surface),var(--green-soft));text-align:left;}
.white-psychology-bridge .bridge-label{display:block;margin-bottom:8px;color:var(--green);font-size:.78rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;}
.white-psychology-bridge h2,.white-psychology-bridge h3{margin:0 0 10px;color:var(--ink);font-size:1.18rem;font-weight:850;line-height:1.35;text-wrap:balance;}
.white-psychology-bridge p{margin:0 0 14px;color:var(--ink-sub);font-size:.95rem;line-height:1.7;text-wrap:pretty;}
.white-psychology-bridge a{display:inline-flex;align-items:center;min-height:42px;padding:0 16px;border:1px solid var(--green);border-radius:999px;color:var(--green);background:var(--surface);font-size:.92rem;font-weight:850;text-decoration:none;}
.giver-spectrum{margin:18px 0 0;padding:16px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface-2);}
.giver-spectrum-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;color:var(--ink-sub);font-size:.82rem;font-weight:800;}
.giver-spectrum-track{position:relative;height:10px;border-radius:999px;background:linear-gradient(90deg,#f3d6c6 0%,#f2e4bd 42%,#cfeade 100%);}
.giver-spectrum-dot{position:absolute;top:50%;left:var(--spectrum-pos,50%);width:18px;height:18px;border:3px solid var(--surface);border-radius:999px;background:var(--green);box-shadow:0 5px 12px rgba(17,75,60,.18);transform:translate(-50%,-50%);}
.giver-spectrum-copy{margin:10px 0 0;color:var(--ink);font-size:.94rem;font-weight:800;line-height:1.55;}
.axis-snapshot{margin:14px 0 14px;padding:16px;border:1px solid var(--line);border-radius:8px;background:var(--surface);}
.axis-snapshot-head{display:grid;gap:6px;margin-bottom:12px;}
.axis-kicker{color:var(--green);font-size:.72rem;font-weight:950;letter-spacing:.08em;text-transform:uppercase;}
.axis-snapshot h2{font-size:1.16rem;line-height:1.25;font-weight:950;letter-spacing:0;margin:0;}
.axis-snapshot-head p{color:var(--ink-sub);font-size:.9rem;font-weight:750;line-height:1.65;margin:0;}
.axis-grid{display:grid;grid-template-columns:1fr;gap:9px;}
.axis-card{min-height:132px;border:1px solid var(--line);border-radius:8px;background:var(--surface-2);padding:13px;display:grid;grid-template-rows:auto auto auto 1fr;gap:8px;}
.axis-card-top{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.axis-card-top strong{font-size:.92rem;font-weight:950;color:var(--ink);}
.axis-card-top span{min-width:46px;text-align:right;color:var(--green);font-size:.8rem;font-weight:950;}
.axis-bar{height:8px;border-radius:999px;background:rgba(23,25,28,.09);overflow:hidden;}
.axis-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--green),var(--mint));}
.axis-card-label{margin:0;color:var(--ink);font-size:.86rem;font-weight:950;line-height:1.35;}
.axis-card-action{margin:0;color:var(--ink-sub);font-size:.8rem;font-weight:750;line-height:1.5;}
.axis-note{margin:10px 0 0;color:var(--ink-faint);font-size:.72rem;font-weight:750;line-height:1.5;}
.lace-note{display:block;margin-top:10px;color:var(--ink-sub);font-size:.82rem;font-weight:700;line-height:1.55;}
.cta-btn,.paid-deep-link{min-height:50px;width:100%;border:0;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--green);color:var(--surface);padding:0 18px;font-family:inherit;font-size:.98rem;font-weight:800;text-decoration:none;cursor:pointer;}
.paid-deep-link{margin-top:18px;}
.cta-sub-text,.paid-deep-note{display:block;margin-top:10px;color:var(--ink-faint);font-size:.78rem;font-weight:700;}
.related-tests{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:32px;}
.rel-card{display:flex;min-height:92px;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 12px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);color:var(--ink);text-align:center;text-decoration:none;}
.rel-name{font-size:.86rem;font-weight:800;line-height:1.35;}
.retry-wrap{text-align:center;margin-top:40px;}
.retry-link{min-height:44px;border:0;background:none;color:var(--ink-sub);font-family:inherit;font-size:.9rem;font-weight:800;cursor:pointer;text-decoration:underline;text-underline-offset:3px;}
.footer-links{margin-bottom:16px;}
.risk-page footer a{color:var(--ink-sub);text-decoration:none;margin:0 10px;font-weight:700;}
.risk-page footer .copy{margin-top:20px;color:var(--ink-faint);}

.hogoo-page{background:var(--bg);}
.hogoo-page .inner{width:min(100%,480px);margin:0 auto;padding:0 22px;}
.hogoo-page .hidden{display:none!important;}
.hogoo-page #intro-page{position:relative;min-height:100vh;display:flex;align-items:center;padding:72px 0 92px;text-align:center;background:linear-gradient(180deg,var(--amber-soft) 0%,var(--bg) 48%,var(--surface) 100%);overflow:hidden;}
.hogoo-page #intro-page::before{content:"";position:absolute;inset:36px calc(50% - 260px) 64px;border:1px solid rgba(122,78,18,.08);border-radius:8px;background:linear-gradient(90deg,rgba(122,78,18,.05) 1px,transparent 1px),linear-gradient(180deg,rgba(122,78,18,.04) 1px,transparent 1px);background-size:30px 30px;pointer-events:none;}
.hogoo-page #intro-page > .inner{position:relative;z-index:1;}
.hogoo-page #test-page{min-height:100vh;padding:40px 0 80px;background:var(--surface);}
.hogoo-page #result-page{padding:40px 0 100px;background:var(--bg);}
.hogoo-page .test-badge{color:var(--green);}
.hogoo-page .progress-fill{background:var(--mint);}
.hogoo-page .q-num-label{color:var(--green);}
.hogoo-page .ans-btn:hover{border-color:var(--mint);background:var(--green-soft);}
.hogoo-page .type-tagline{color:var(--green);}
.hogoo-page .result-card.is-action{position:relative;}
.hogoo-page .result-cta{background:var(--surface);}
.hogoo-page .result-cta h3{color:var(--green);}
.hogoo-page footer a{color:var(--ink-sub);text-decoration:none;margin:0 10px;font-weight:700;}
.hogoo-page footer .copy{margin-top:20px;color:var(--ink-faint);}

.hogoo-page{--test-accent:var(--amber-accent);--test-accent-ink:var(--amber-ink);--test-soft:var(--amber-soft);}
.risk-page{--test-accent:var(--amber-accent);--test-accent-ink:var(--amber);--test-soft:var(--amber-soft);}
.refusal-page{--test-accent:var(--mint);--test-accent-ink:var(--mint-ink);--test-soft:var(--mint-soft);}
.hogoo-page .test-badge,.risk-page .test-badge,.refusal-page .badge{background:var(--test-soft);color:var(--test-accent-ink);}
.hogoo-page .tab-btn:hover,.risk-page .tab-btn:hover,.refusal-page .tab-btn:hover{color:var(--test-accent-ink);}
.hogoo-page .tab-btn[aria-selected="true"],.risk-page .tab-btn[aria-selected="true"],.refusal-page .tab-btn[aria-selected="true"]{background:var(--test-accent-ink);border-color:var(--test-accent-ink);}
.hogoo-page .tab-btn[aria-selected="true"]::before,.risk-page .tab-btn[aria-selected="true"]::before,.refusal-page .tab-btn[aria-selected="true"]::before{color:var(--test-accent-ink);}
.hogoo-page .start-btn,.risk-page .start-btn,.refusal-page button{background:var(--test-accent-ink);box-shadow:0 12px 26px rgba(122,78,18,.14);}
.refusal-page button{box-shadow:0 12px 26px rgba(10,95,77,.14);}
.hogoo-page .result-preview-link,.risk-page .result-preview-link,.refusal-page .result-preview-link{color:var(--test-accent-ink);}
.hogoo-page .result-preview-link:hover,.risk-page .result-preview-link:hover,.refusal-page .result-preview-link:hover{border-color:var(--test-accent);background:var(--test-soft);}
.hogoo-page .progress-fill,.risk-page .progress-fill{background:var(--test-accent);}
.hogoo-page .q-num-label,.risk-page .q-num-label{color:var(--test-accent-ink);}
.hogoo-page .ans-btn:hover,.risk-page .ans-btn:hover{border-color:var(--test-accent);background:var(--test-soft);}
.hogoo-page .type-tagline,.risk-page .type-tagline{color:var(--test-accent-ink);}

/* GIVE ID test page */
.give-test-page * { box-sizing: border-box; margin: 0; padding: 0; word-break: keep-all; }
html { scroll-behavior: smooth; }
.give-test-page {
    font-family: Pretendard, -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
    background: var(--bg);
    color: var(--ink);
    line-height: 1.55;
    overflow-x: hidden;
}
.give-test-page button, .give-test-page a { font-family: inherit; -webkit-tap-highlight-color: transparent; }
.give-test-page a { color: inherit; text-decoration: none; }
.give-test-page .hidden { display: none !important; }
.give-test-page .inner { width: min(100%, 520px); margin: 0 auto; padding: 0 20px; }
.give-test-page .nav { background: rgba(255,255,255,0.92); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 10; }
.give-test-page .nav .inner { height: 58px; display: flex; align-items: center; justify-content: space-between; }
.give-test-page .brand { color: var(--mint-ink); font-weight: 900; font-size: 0.96rem; letter-spacing: 0; }
.give-test-page .nav-links { display: flex; gap: 14px; color: var(--ink-sub); font-size: 0.82rem; font-weight: 700; }
.give-test-page .landing { position:relative;background: linear-gradient(180deg, var(--green-soft) 0%, var(--surface) 62%, var(--bg) 100%); padding: 26px 0 48px; overflow:hidden; }
.give-test-page .landing::before{content:"";position:absolute;inset:18px calc(50% - 330px) auto;height:520px;border:1px solid rgba(17,75,60,.08);border-radius:8px;background:linear-gradient(90deg,rgba(17,75,60,.05) 1px,transparent 1px),linear-gradient(180deg,rgba(17,75,60,.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;}
.give-test-page .landing > .inner{position:relative;z-index:1;}
.give-test-page .hero{padding:0 0 28px;}
.give-test-page .hero h1 { max-width:12em;font-size: clamp(2rem, 9.4vw, 3.35rem); line-height: 1.12; letter-spacing: -.018em; font-weight: 950; margin-bottom: 12px; }
.give-test-page .hero-copy { max-width:24em;color: var(--ink-sub); font-size: 1rem; font-weight: 650; line-height:1.68; margin-bottom: 14px; }
.give-test-page .hero-panel { background: rgba(255,255,255,.88); border: 1px solid var(--line); border-radius: 8px; padding: 16px; margin: 18px 0 0; box-shadow: 0 14px 36px rgba(24, 31, 43, 0.08); }
.give-test-page .landing .hero-panel,.give-test-page .landing .quality-section{display:none;}
.give-test-page .problem-list { display: grid; gap: 10px; }
.give-test-page .problem-list li { list-style: none; display: flex; gap: 10px; align-items: flex-start; color: var(--ink); font-weight: 750; font-size: 0.95rem; }
.give-test-page .dot { width: 8px; height: 8px; border-radius: 999px; background: var(--mint); margin-top: 8px; flex: 0 0 auto; }
.give-test-page .primary-btn, .give-test-page .secondary-btn, .give-test-page .ghost-btn {
    min-height: 56px; border-radius: 8px; border: 0; cursor: pointer; font-weight: 900; font-size: 1rem;
    display: inline-flex; align-items: center; justify-content: center; width: 100%; transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}
.give-test-page .primary-btn { background: var(--mint); color: var(--surface); box-shadow: 0 12px 26px rgba(0,168,133,0.28); }
.give-test-page .primary-btn:hover { background: var(--mint-ink); transform: translateY(-1px); }
.give-test-page .secondary-btn { background: var(--ink); color: var(--surface); }
.give-test-page .ghost-btn { background: var(--surface); color: var(--ink); border: 1px solid var(--line); }
.give-test-page .micro { color: var(--ink-sub); text-align: center; font-size: 0.8rem; font-weight: 700; line-height:1.55; margin-top: 10px; }
.give-test-page .test-tabs{margin:16px auto 14px;text-align:left;}
.give-test-page .tab-list{grid-template-columns:repeat(2,minmax(0,1fr));}
.give-test-page .tab-btn{min-width:0;padding-right:8px;word-break:keep-all;}
.give-test-page .tab-panel h3,.give-test-page .tab-panel p{margin-left:auto;margin-right:auto;text-align:center;}
.quality-section{margin:30px 0 0;padding:24px 20px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);text-align:left;}
.quality-section.muted{background:var(--surface-2);}
.quality-section h2{margin:0 0 12px;color:var(--ink);font-size:1.28rem;font-weight:850;line-height:1.35;letter-spacing:0;text-wrap:balance;}
.quality-section p{margin:0 0 12px;color:var(--ink-sub);font-size:.98rem;line-height:1.75;text-wrap:pretty;}
.quality-section p:last-child{margin-bottom:0;}
.quality-grid{display:grid;gap:12px;margin-top:16px;}
.quality-grid article{padding:16px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);}
.quality-grid h3{margin:0 0 8px;color:var(--green);font-size:1rem;font-weight:850;line-height:1.35;}
.quality-grid p{font-size:.93rem;line-height:1.68;}
.give-test-page #test-page { min-height: calc(100vh - 58px); background: var(--surface); padding: 24px 0 44px; }
.give-test-page .test-top { margin-bottom: 34px; }
.give-test-page .progress-row { display: flex; justify-content: space-between; color: var(--ink-sub); font-size: 0.82rem; font-weight: 850; margin-bottom: 9px; }
.give-test-page .progress-track { height: 9px; border-radius: 999px; background: var(--surface-2); overflow: hidden; }
.give-test-page .progress-fill { width: 0; height: 100%; background: linear-gradient(90deg, var(--mint), var(--mint)); border-radius: inherit; transition: width 0.35s ease; }
.give-test-page .reward { margin-top: 12px; background: var(--amber-soft); color: var(--amber); border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px; font-size: 0.84rem; font-weight: 850; }
.give-test-page .question-card { animation: slideIn 0.26s ease; }
@keyframes slideIn{ from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.give-test-page .q-label { color: var(--mint-ink); font-weight: 950; font-size: 0.85rem; margin-bottom: 12px; }
.give-test-page .q-text { white-space: pre-line; font-size: 1.45rem; line-height: 1.35; font-weight: 950; letter-spacing: 0; margin-bottom: 26px; }
.give-test-page .answers { display: grid; gap: 12px; }
.give-test-page .answer-btn {
    width: 100%; min-height: 66px; background: var(--surface); color: var(--ink); border: 2px solid var(--line); border-radius: 8px;
    text-align: left; padding: 16px 18px; font-size: 1rem; font-weight: 850; line-height: 1.35; cursor: pointer; transition: background 0.18s ease, border 0.18s ease, transform 0.18s ease;
}
.give-test-page .answer-btn:hover, .give-test-page .answer-btn:active { background: var(--mint-soft); border-color: var(--mint); transform: translateY(-1px); }
.give-test-page #result-page { padding: 18px 0 70px; }
.give-test-page .completion { display: none; background: var(--ink); color: var(--surface); border-radius: 8px; padding: 14px 16px; margin-bottom: 16px; font-weight: 900; text-align: center; animation: pop 0.5s ease; }
.give-test-page .completion.show { display: block; }
@keyframes pop{ 0% { transform: scale(0.96); opacity: 0; } 70% { transform: scale(1.02); } 100% { transform: scale(1); opacity: 1; } }
.give-test-page .result-shell { background: var(--surface); border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 14px 36px rgba(24, 31, 43, 0.08); overflow: hidden; }
.give-test-page .result-hero { padding: 26px 20px 22px; text-align: center; background: linear-gradient(180deg, var(--mint-soft), var(--surface)); }
.give-test-page .result-label { color: var(--ink-sub); font-weight: 900; font-size: 0.82rem; margin-bottom: 8px; }
.give-test-page .character { width: 122px; height: 132px; display: block; margin: 0 auto 8px; overflow: visible; animation: float 3.4s ease-in-out infinite; }
.give-test-page .type-char { width: 150px; height: 150px; object-fit: contain; overflow: hidden; border-radius: 8px; }
@keyframes float{ 0%,100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
.give-test-page .type-name { font-size: 1.85rem; line-height: 1.15; font-weight: 950; letter-spacing: 0; color: var(--ink); margin-bottom: 10px; }
.give-test-page .summary { color: var(--ink-sub); font-size: 1rem; font-weight: 750; }
.give-test-page .result-body { padding: 18px; }
.give-test-page .insight-grid { display: grid; gap: 10px; }
.give-test-page .insight { border: 1px solid var(--line); border-radius: 8px; padding: 16px; background: var(--surface); }
.give-test-page .insight h3 { font-size: 0.84rem; color: var(--ink-sub); margin-bottom: 8px; font-weight: 950; }
.give-test-page .insight p { font-size: 0.96rem; font-weight: 650; color: var(--ink); }
.give-test-page .risk { background: var(--amber-soft); border-color: var(--line); }
.give-test-page .advice { background: var(--green-soft); border-color: var(--line); }
.give-test-page .locked-interpretation { position: relative; margin: 16px 0 18px; border: 1px solid var(--line); background: var(--amber-soft); border-radius: 12px; overflow: hidden; box-shadow: 0 12px 26px rgba(70,45,15,.08); }
.give-test-page .locked-interpretation-text { padding: 18px; color: var(--ink-sub); font-size: .96rem; font-weight: 800; line-height: 1.75; filter: blur(8px); pointer-events: none; user-select: none; transition: filter .45s ease, opacity .45s ease; }
.give-test-page .locked-interpretation-text p { margin: 0 0 10px; }
.give-test-page .locked-interpretation-text p:last-child { margin-bottom: 0; }
.give-test-page .locked-interpretation-overlay { position: absolute; inset: 0; width: 100%; border: 0; background: rgba(255,250,240,.74); backdrop-filter: blur(1px); display: flex; align-items: center; justify-content: center; color: var(--ink); font-size: 1rem; font-weight: 950; cursor: pointer; font-family: inherit; transition: opacity .35s ease, visibility .35s ease; }
.give-test-page .locked-interpretation.unlocked .locked-interpretation-text { filter: none; pointer-events: auto; user-select: auto; animation: fadeInterpretation .45s ease both; }
.give-test-page .locked-interpretation.unlocked .locked-interpretation-overlay { opacity: 0; visibility: hidden; pointer-events: none; }
@keyframes fadeInterpretation{ from { opacity: .25; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }
.give-test-page .cta-section { margin-top: 16px; display: grid; gap: 10px; }
.give-test-page .cta-kicker { color: var(--amber-ink); font-size: 0.9rem; font-weight: 950; text-align: center; margin-top: 16px; }
.give-test-page .paid-bridge { margin-top: 16px; background: var(--ink); color: var(--surface); border-radius: 8px; padding: 20px; box-shadow: 0 16px 34px rgba(16,20,24,0.16); }
.give-test-page .paid-eyebrow { color: var(--mint); font-size: 0.78rem; font-weight: 950; margin-bottom: 8px; }
.give-test-page .paid-bridge h2 { font-size: 1.35rem; line-height: 1.25; letter-spacing: 0; font-weight: 950; margin-bottom: 10px; }
.give-test-page .paid-bridge p { color: var(--surface-2); font-size: 0.92rem; font-weight: 700; margin-bottom: 14px; }
.give-test-page .paid-preview { margin: 16px 0; border: 1px solid rgba(255,255,255,.12); border-radius: 8px; background: rgba(255,255,255,.06); padding: 14px; }
.give-test-page .paid-preview-head { display: grid; gap: 4px; margin-bottom: 12px; }
.give-test-page .paid-preview-head strong { color: var(--surface); font-size: .95rem; font-weight: 950; line-height: 1.35; }
.give-test-page .paid-preview-head span { color: var(--surface-2); font-size: .78rem; font-weight: 800; line-height: 1.45; }
.give-test-page .paid-preview-grid { display: grid; grid-template-columns: 1fr; gap: 8px; }
.give-test-page .paid-preview-card { min-height: 102px; border: 1px solid rgba(255,255,255,.1); border-radius: 8px; background: rgba(255,255,255,.07); padding: 12px; }
.give-test-page .paid-preview-card span { display: inline-flex; min-height: 22px; align-items: center; border-radius: 999px; background: rgba(0,168,133,.18); color: var(--mint); padding: 0 8px; font-size: .68rem; font-weight: 950; margin-bottom: 8px; }
.give-test-page .paid-preview-card strong { display: block; color: var(--surface); font-size: .9rem; font-weight: 950; line-height: 1.35; margin-bottom: 5px; }
.give-test-page .paid-preview-card p { margin: 0; color: var(--surface-2); font-size: .78rem; font-weight: 750; line-height: 1.5; }
.give-test-page .paid-list { display: grid; gap: 8px; margin: 16px 0; }
.give-test-page .paid-item { display: flex; gap: 10px; align-items: flex-start; background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.1); border-radius: 8px; padding: 11px 12px; font-size: 0.9rem; font-weight: 850; color: var(--surface); }
.give-test-page .paid-check { color: var(--mint); font-weight: 950; flex: 0 0 auto; }
.give-test-page .paid-btn { width: 100%; min-height: 58px; border: 0; border-radius: 8px; background: var(--mint); color: var(--surface); font-size: 1rem; font-weight: 950; cursor: pointer; box-shadow: 0 14px 26px rgba(0,168,133,0.26); }
.give-test-page .paid-btn:hover { background: var(--mint-ink); transform: translateY(-1px); }
.give-test-page .paid-sub { display: block; color: var(--ink-faint); text-align: center; font-size: 0.76rem; font-weight: 800; margin-top: 9px; }
.give-test-page .result-retry-btn { border: 1px solid var(--line); background: transparent; color: var(--ink-sub); border-radius: 999px; padding: 8px 13px; font-size: .8rem; font-weight: 850; font-family: inherit; cursor: pointer; min-height: 0; width: auto; justify-self: center; }
.give-test-page .result-retry-btn:hover { color: var(--ink); border-color: var(--line); background: var(--surface); }
.give-test-page .unlock-badge { display: none; background: var(--green-soft); color: var(--mint); border: 1px solid var(--line); border-radius: 999px; padding: 4px 10px; font-size: .75rem; font-weight: 800; margin: 12px 18px 0; }
.give-test-page .locked-interpretation.unlocked .unlock-badge { display: inline-block; animation: fadeInBadge .45s ease .1s both; }
@keyframes fadeInBadge{ from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.give-test-page .loop-title { margin: 26px 0 12px; font-size: 1.08rem; font-weight: 950; }
.give-test-page .related-tests { display: grid; grid-template-columns: 1fr; gap: 10px; }
.give-test-page .related-card { background: var(--surface); border: 1px solid var(--line); border-radius: 8px; padding: 16px; display: flex; gap: 14px; align-items: center; box-shadow: 0 8px 22px rgba(24,31,43,0.05); }
.give-test-page .related-icon { width: 42px; height: 42px; border-radius: 8px; display: grid; place-items: center; background: var(--mint-soft); color: var(--mint-ink); font-weight: 950; flex: 0 0 auto; }
.give-test-page .related-card strong { display: block; font-size: 0.98rem; margin-bottom: 2px; }
.give-test-page .related-card span { display: block; color: var(--ink-sub); font-size: 0.8rem; font-weight: 700; }
.give-test-page .recommend { background: var(--ink); color: var(--surface); border-radius: 8px; padding: 18px; margin-top: 12px; }
.give-test-page .recommend p { color: var(--surface-2); font-size: 0.88rem; margin: 4px 0 14px; }
.give-test-page .unlock-panel { background: var(--surface); border: 1px solid var(--line); border-radius: 8px; padding: 18px; margin-top: 16px; box-shadow: 0 14px 36px rgba(24, 31, 43, 0.08); }
.give-test-page .unlock-top { display: flex; justify-content: space-between; gap: 12px; align-items: center; margin-bottom: 10px; }
.give-test-page .unlock-top strong { font-size: 1.05rem; font-weight: 950; }
.give-test-page .unlock-pill { background: var(--ink); color: var(--surface); border-radius: 999px; padding: 6px 9px; font-size: 0.72rem; font-weight: 900; flex: 0 0 auto; }
.give-test-page .unlock-track { height: 8px; background: var(--surface-2); border-radius: 999px; overflow: hidden; margin: 10px 0 14px; }
.give-test-page .unlock-fill { width: 62%; height: 100%; background: linear-gradient(90deg, var(--mint), var(--mint)); }
.give-test-page .locked-list { display: grid; gap: 8px; margin: 14px 0; }
.give-test-page .locked-item { display: flex; gap: 10px; align-items: center; background: var(--bg); border: 1px solid var(--line); border-radius: 8px; padding: 11px 12px; font-size: 0.9rem; font-weight: 800; color: var(--ink-sub); }
.give-test-page .blurred { filter: blur(3px); user-select: none; }
.give-test-page .choice-grid { display: grid; grid-template-columns: 1fr; gap: 10px; margin-top: 12px; }
.give-test-page .choice-card { background: var(--surface); border: 2px solid var(--line); border-radius: 8px; padding: 14px; text-align: left; cursor: pointer; }
.give-test-page .choice-card.best { border-color: var(--mint); background: var(--mint-soft); position: relative; }
.give-test-page .choice-card.best:before { content: "가장 많이 클릭"; position: absolute; right: 10px; top: -10px; background: var(--mint); color: var(--surface); border-radius: 999px; padding: 4px 8px; font-size: 0.68rem; font-weight: 950; }
.give-test-page .choice-name { display: block; font-weight: 950; margin-bottom: 3px; }
.give-test-page .choice-copy { display: block; color: var(--ink-sub); font-size: 0.8rem; font-weight: 750; }
.give-test-page .social-nudge { color: var(--ink-sub); text-align: center; font-size: 0.78rem; font-weight: 800; margin-top: 10px; }
.give-test-page .share-panel { background: var(--surface); border: 1px solid var(--line); border-radius: 8px; padding: 18px; margin-top: 16px; }
.give-test-page .share-card {
    position: relative; width: 100%; aspect-ratio: 1.586 / 1; min-height: 304px; border-radius: 18px;
    background: linear-gradient(135deg, var(--surface) 0%, var(--green-soft) 44%, var(--green-soft) 100%);
    border: 1px solid var(--line); box-shadow: 0 22px 50px rgba(64, 44, 120, 0.18);
    overflow: hidden; padding: 18px; margin: 12px 0; color: var(--ink);
}
.give-test-page .share-card:before {
    content: ""; position: absolute; inset: -30% -16% auto auto; width: 220px; height: 220px;
    border-radius: 999px; background: var(--card-color, var(--green-soft)); opacity: .72;
}
.give-test-page .share-card:after {
    content: ""; position: absolute; left: 18px; right: 18px; bottom: 14px; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(23,25,28,.18), transparent);
}
.give-test-page .give-id-card-inner { position: relative; z-index: 1; height: 100%; display: grid; grid-template-rows: auto 1fr auto; gap: 12px; }
.give-test-page .give-id-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.give-test-page .give-id-brand { display: grid; gap: 2px; }
.give-test-page .give-id-label { color: var(--green); font-size: .72rem; font-weight: 950; letter-spacing: .16em; }
.give-test-page .give-id-issued { color: var(--ink-sub); font-size: .68rem; font-weight: 850; }
.give-test-page .give-id-chip { border: 1px solid rgba(109,40,217,.24); background: rgba(255,255,255,.74); border-radius: 999px; padding: 6px 9px; color: var(--green); font-size: .68rem; font-weight: 950; white-space: nowrap; }
.give-test-page .give-id-main { display: grid; grid-template-columns: .9fr 1.1fr; gap: 14px; align-items: center; min-height: 0; }
.give-test-page .give-id-portrait { align-self: center; display: grid; place-items: center; min-width: 0; }
.give-test-page .give-id-portrait .character { width: min(34vw, 138px); height: auto; margin: 0; filter: drop-shadow(0 14px 20px rgba(23,25,28,.16)); animation: none; }
.give-test-page .give-id-portrait .type-char { aspect-ratio: 1; object-fit: contain; }
.give-test-page .give-id-info { min-width: 0; }
.give-test-page .share-card .type-name { font-size: clamp(1.18rem, 5vw, 1.72rem); line-height: 1.08; margin: 0 0 8px; word-break: keep-all; }
.give-test-page .give-id-tagline { font-weight: 850; color: var(--ink-sub); font-size: .82rem; line-height: 1.45; margin: 0; word-break: keep-all; }
.give-test-page .give-id-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 11px; }
.give-test-page .give-id-tag { border: 1px solid rgba(23,25,28,.1); background: rgba(255,255,255,.72); border-radius: 999px; padding: 4px 8px; color: var(--ink-sub); font-size: .68rem; font-weight: 900; }
.give-test-page .give-id-bottom { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: end; }
.give-test-page .give-id-stats { display: grid; gap: 5px; min-width: 0; }
.give-test-page .give-id-stat { display: grid; grid-template-columns: 42px 1fr 28px; gap: 7px; align-items: center; color: var(--ink-sub); font-size: .66rem; font-weight: 950; }
.give-test-page .give-id-bar { height: 6px; border-radius: 999px; background: rgba(23,25,28,.1); overflow: hidden; }
.give-test-page .give-id-bar span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--green), var(--mint)); }
.give-test-page .give-id-code { text-align: right; color: var(--ink-sub); font-size: .65rem; font-weight: 900; letter-spacing: .08em; white-space: nowrap; }
.give-test-page .give-id-stat-note { margin: 2px 0 0; color: var(--ink-faint); font-size: .6rem; font-weight: 700; }
.give-test-page .result-card-download-button {
    min-height: 44px; width: 100%; border: 1px solid var(--green); background: var(--surface); color: var(--green);
    border-radius: 8px; padding: 0 16px; font-family: inherit; font-size: .88rem; font-weight: 950; cursor: pointer;
}
.give-test-page .result-card-download-button:hover { background: var(--green-soft); }
.give-test-page .result-card-download-button:disabled { opacity: .62; cursor: wait; }
.give-test-page .share-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.give-test-page .download-action { grid-column: 1 / -1; }
.give-test-page .share-retry-actions { display: flex; justify-content: center; margin-top: 12px; }
.give-test-page .toast { position: fixed; left: 50%; bottom: 22px; transform: translateX(-50%); background: var(--ink); color: var(--surface); border-radius: 999px; padding: 10px 14px; font-size: 0.82rem; font-weight: 850; opacity: 0; pointer-events: none; transition: opacity 0.2s ease; z-index: 20; }
.give-test-page .toast.show { opacity: 1; }
.give-test-page footer { margin-top: 44px; padding: 30px 0; border-top: 1px solid var(--line); color: var(--ink-faint); text-align: center; font-size: 0.8rem; }
.give-test-page .footer-links { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; margin-bottom: 14px; color: var(--ink-sub); font-weight: 700; }
@media (min-width: 720px){
.test-intro-image{width:min(100%,260px);}
.give-test-page .inner { width: min(100%, 680px); }
.give-test-page .landing { padding-top: 36px; }
.give-test-page .hero-panel { padding: 22px; }
.give-test-page .test-tabs{max-width:620px;margin-top:18px;}
.give-test-page .tab-list{grid-template-columns:repeat(4,minmax(0,1fr));}
.give-test-page .tab-btn{min-height:58px;padding-left:30px;font-size:.82rem;text-align:left;}
.give-test-page .tab-btn::before{left:8px;}
.give-test-page .related-tests { grid-template-columns: repeat(3, 1fr); }
.give-test-page .related-card { display: block; min-height: 164px; }
.give-test-page .related-icon { margin-bottom: 12px; }
.give-test-page .choice-grid { grid-template-columns: repeat(3, 1fr); }
.give-test-page .axis-grid { grid-template-columns: repeat(2, 1fr); }
.give-test-page .paid-preview-grid { grid-template-columns: repeat(3, 1fr); }
.give-test-page .share-actions { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width:420px){
  .sequence-header{height:54px;padding:0 14px;}
  .sequence-main{inset:54px 0 0;}
  .sequence-slide{padding:22px 18px 106px;}
  .sequence-line{max-width:12.5em;font-size:clamp(1.16rem,5.8vw,1.38rem);line-height:1.68;}
  .sequence-line.is-soft{font-size:1rem;line-height:1.66;}
  .sequence-copy{font-size:.96rem;line-height:1.66;}
  .sequence-character{width:136px;height:136px;border-radius:32px;}
  .sequence-type{font-size:clamp(1.55rem,8vw,2rem);}
  .sequence-hint{bottom:74px;width:min(100% - 118px,260px);}
  .give-test-page .inner{padding:0 16px;}
  .give-test-page .landing{padding-top:20px;}
  .give-test-page .test-intro-image{width:min(100%,180px);margin-bottom:14px;}
  .give-test-page .test-intro-caption{margin-bottom:12px;font-size:.84rem;}
  .give-test-page .hero h1{font-size:clamp(1.9rem,9.6vw,2.35rem);line-height:1.13;margin-bottom:10px;}
  .give-test-page .hero-copy{font-size:.95rem;line-height:1.62;margin-bottom:12px;}
  .give-test-page .test-tabs{margin-top:12px;}
  .give-test-page .tab-list{gap:5px;padding:6px;}
  .give-test-page .tab-btn{min-height:48px;padding:7px 7px 7px 30px;font-size:.78rem;line-height:1.22;}
  .give-test-page .tab-btn::before{left:8px;width:16px;height:16px;font-size:.62rem;}
  .give-test-page .tab-panel{padding:18px 16px 20px;}
  .give-test-page .tab-panel h3{font-size:1.06rem;line-height:1.34;}
  .give-test-page .tab-panel p{font-size:.95rem;line-height:1.62;}
  .result-preview-link{width:100%;margin-top:14px;}
}
.mb18{margin-bottom:18px;}

@media (min-width:560px){
  .hero-actions{grid-template-columns:1fr 1fr;}
}

@media (min-width:680px){
  .seo-grid.two{grid-template-columns:repeat(2,1fr);}
}

@media (max-width:520px){
  .hogoo-page #intro-page,.risk-page #intro-page{padding:38px 0 58px;}
  .refusal-page .page{padding:38px 0 58px;}
  .hogoo-page #intro-page::before,.risk-page #intro-page::before{inset:22px calc(50% - 244px) 36px;}
  .hogoo-page #intro-page .prologue-lab-bar,.risk-page #intro-page .prologue-lab-bar,.refusal-page #intro .prologue-lab-bar{margin-bottom:12px;}
  .hogoo-page #intro-page .test-badge,.risk-page #intro-page .test-badge,.refusal-page #intro .badge{margin-bottom:12px;padding:6px 10px;font-size:.74rem;}
  .hogoo-page #intro-page .test-intro-image,.risk-page #intro-page .test-intro-image,.refusal-page #intro .test-intro-image{width:min(100%,206px);margin-bottom:12px;}
  .hogoo-page #intro-page .test-intro-caption,.risk-page #intro-page .test-intro-caption,.refusal-page #intro .test-intro-caption,.hogoo-page #intro-page .test-subtitle,.risk-page #intro-page .test-subtitle,.refusal-page #intro h1 + p{display:none;}
  .hogoo-page #intro-page .test-title,.risk-page #intro-page .test-title,.refusal-page #intro h1{margin-bottom:12px;font-size:clamp(1.82rem,8vw,2.18rem);line-height:1.13;}
  .hogoo-page #intro-page .prologue-metrics,.risk-page #intro-page .prologue-metrics,.refusal-page #intro .prologue-metrics{margin:12px auto;}
  .hogoo-page #intro-page .prologue-metrics div,.risk-page #intro-page .prologue-metrics div,.refusal-page #intro .prologue-metrics div{min-height:56px;padding:8px 6px;}
  .hogoo-page #intro-page .prologue-start-card,.risk-page #intro-page .prologue-start-card,.refusal-page #intro .prologue-start-card{margin:12px auto 14px;padding:13px;}
  .hogoo-page #intro-page .prologue-start-head,.risk-page #intro-page .prologue-start-head,.refusal-page #intro .prologue-start-head{margin-bottom:10px;}
  .hogoo-page #intro-page .prologue-start-head strong,.risk-page #intro-page .prologue-start-head strong,.refusal-page #intro .prologue-start-head strong{font-size:.96rem;line-height:1.38;}
  .hogoo-page #intro-page .prologue-signals div,.risk-page #intro-page .prologue-signals div,.refusal-page #intro .prologue-signals div{min-height:62px;padding:8px 7px;}
  .hogoo-page #intro-page .result-preview-link,.risk-page #intro-page .result-preview-link,.refusal-page #intro .result-preview-link{min-height:42px;margin-bottom:8px;}
  .hogoo-page #intro-page .start-btn,.risk-page #intro-page .start-btn,.refusal-page #intro button:not(.tab-btn){min-height:50px;}
  .wrap{padding:0 20px;}
  .site-nav,nav{align-items:flex-start;}
  .choice-card{padding:20px;}
  .test-card-image{margin:-20px -20px 2px;}
  .art a{align-items:flex-start;padding:16px;}
  .tab-list{grid-template-columns:1fr 1fr;}
  .stats,.mission-grid{grid-template-columns:1fr;}
  .article-card{flex-direction:column;}
  .cta-banner{align-items:flex-start;}
}

.reveal{opacity:0;transform:translateY(14px);animation:rise .7s cubic-bezier(.2,.72,.18,1) forwards;}
@keyframes rise{to{opacity:1;transform:none;}}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important;}
  .choice-card:hover,.art a:hover{transform:none;}
  .reveal{opacity:1;transform:none;}
}
