:root{
  --plum:#6f2f78;
  --plum-deep:#2d1338;
  --rose:#8f3561;
  --moss:#4f7d3b;
  --paper:#fffdf8;
  --wash:#f8f1f5;
  --mist:#eee4ef;
  --line:#dfcfdf;
  --ink:#231525;
  --muted:#67586a;
  --soft:#f3e8f1;
  --danger:#c62828;
  --shadow:0 18px 44px rgba(74,39,82,.13);
  --shadow-sm:0 8px 24px rgba(74,39,82,.09);
  --radius:18px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Pretendard",system-ui,-apple-system,"Segoe UI",sans-serif;color:var(--ink);background:var(--wash);line-height:1.7;-webkit-font-smoothing:antialiased;word-break:keep-all}
a{color:inherit;text-decoration:none}
button,input{font:inherit}
.wrap{width:100%;max-width:1120px;margin:0 auto;padding:0 22px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:999px;padding:14px 22px;font-size:15px;font-weight:850;cursor:pointer;transition:transform .16s var(--ease),box-shadow .16s var(--ease),background .16s var(--ease),border-color .16s var(--ease)}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.52;cursor:not-allowed;box-shadow:none;transform:none}
.btn-primary{background:var(--plum);color:#fff;box-shadow:0 14px 28px rgba(111,47,120,.25)}
.btn-primary:hover{background:#5c2365}
.btn-ghost{background:#fff;color:var(--plum-deep);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--plum);box-shadow:var(--shadow-sm)}
.full{width:100%}

.nav{position:sticky;top:0;z-index:50;background:rgba(255,253,248,.94);border-bottom:1px solid var(--line);backdrop-filter:blur(14px)}
.nav-in{width:100%;max-width:1180px;height:66px;margin:0 auto;padding:0 22px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:inline-flex;align-items:center;gap:10px;font-size:18px;font-weight:900;color:var(--plum-deep);letter-spacing:-.02em}
.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:12px;background:var(--plum);color:#fff;font-size:15px;font-weight:900}
.nav-links{display:none;align-items:center;gap:22px;color:var(--muted);font-size:14px;font-weight:750}
.nav-links a:hover{color:var(--plum)}
.nav-cta{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--plum);color:#fff;padding:10px 17px;font-size:14px;font-weight:850}
.nav-cta.ghost{background:#fff;color:var(--plum);border:1px solid var(--line)}

.restart-desk{width:100%;max-width:1180px;margin:0 auto;padding:28px 18px 76px}
.desk-rail{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:24px;box-shadow:var(--shadow-sm)}
.rail-kicker,.eyebrow,.section-label{color:var(--rose);font-size:13px;font-weight:900;letter-spacing:.04em}
.desk-rail strong{display:block;margin:8px 0 10px;color:var(--plum-deep);font-size:26px;line-height:1.25;letter-spacing:-.04em}
.desk-rail p:not(.rail-kicker){margin-bottom:18px;color:var(--muted);font-size:15px}
.desk-rail .btn+.btn{margin-top:10px}
.story-scroll{display:grid;gap:18px;margin-top:18px}

.opening-page,.turning-page,.relief-page,.diagnosis-page,.faq-page{background:var(--paper);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);overflow:hidden}
.opening-page{min-height:calc(100vh - 128px);display:grid;align-items:center;gap:26px;padding:34px 24px}
.page-copy{max-width:680px}
.eyebrow{display:inline-flex;align-items:center;margin-bottom:12px}
h1{color:var(--plum-deep);font-size:clamp(38px,9vw,74px);line-height:1.02;letter-spacing:-.07em}
.lead{max-width:610px;margin:20px 0 24px;color:#403144;font-size:18px;line-height:1.75}
.action-row{display:flex;flex-wrap:wrap;gap:10px}
.paper-visual{position:relative;min-height:360px}
.paper{position:absolute;left:50%;top:50%;width:min(82vw,360px);min-height:190px;padding:26px;border:1px solid var(--line);border-radius:22px;background:#fff;box-shadow:0 20px 50px rgba(45,19,56,.16);transform-origin:center}
.paper span{display:inline-flex;color:var(--rose);font-size:13px;font-weight:900}
.paper b{display:block;margin-top:18px;color:var(--plum-deep);font-size:25px;line-height:1.25}
.paper i{display:block;width:70%;height:12px;margin-top:28px;border-radius:999px;background:var(--soft)}
.paper.before{transform:translate(-58%,-52%) rotate(-9deg);background:#f6eef5}
.paper.middle{transform:translate(-50%,-47%) rotate(2deg)}
.paper.after{transform:translate(-42%,-40%) rotate(9deg);border-color:#cbd8c5}
.paper.after span{color:var(--moss)}
.paper.after i{background:#dfe9d9}

.turning-page{padding:34px 24px}
.turning-page h2,.relief-page h2,.diagnosis-page h2,.faq-heading h2{margin-top:8px;color:var(--plum-deep);font-size:clamp(28px,5vw,46px);line-height:1.12;letter-spacing:-.05em}
.section-intro{max-width:720px;margin-top:16px;color:#493b4e;font-size:17px}
.fold-board{display:grid;gap:0;margin-top:28px;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff}
.fold-board article{display:grid;grid-template-columns:48px 1fr;column-gap:14px;padding:22px;border-bottom:1px solid var(--line)}
.fold-board article:last-child{border-bottom:0}
.fold-board span{grid-row:1 / span 2;color:var(--rose);font-size:13px;font-weight:900}
.fold-board h3{color:var(--plum-deep);font-size:19px;line-height:1.35}
.fold-board p{margin-top:5px;color:var(--muted);font-size:15px}

.relief-page{display:grid;gap:22px;padding:0}
.relief-note{padding:34px 24px;background:linear-gradient(135deg,#f1e5f0,#fffdf8)}
.relief-copy{padding:0 24px 34px;color:#433346;font-size:17px}
.relief-copy p+p{margin-top:12px}
.text-link{display:inline-flex;margin-top:18px;color:var(--plum);font-weight:900;border-bottom:2px solid rgba(111,47,120,.28)}

.diagnosis-page{display:grid;gap:24px;align-items:center;padding:34px 24px;background:linear-gradient(135deg,#fffdf8 0%,#f4e9f3 100%)}
.diagnosis-ticket{position:relative;display:block;min-height:220px;padding:26px;border-radius:24px;background:var(--plum-deep);color:#fff;box-shadow:0 20px 48px rgba(45,19,56,.26);overflow:hidden}
.diagnosis-ticket::after{content:"";position:absolute;right:-54px;bottom:-54px;width:170px;height:170px;border-radius:50%;background:rgba(255,255,255,.12)}
.diagnosis-ticket span{display:block;color:#e6d4e8;font-size:14px;font-weight:800}
.diagnosis-ticket strong{display:block;margin-top:38px;font-size:32px;line-height:1.15;letter-spacing:-.04em}
.diagnosis-ticket em{display:block;margin-top:26px;color:#d9bfdc;font-style:normal;font-size:13px}

.faq-page{padding:34px 24px}
.faq-heading{margin-bottom:18px}
.faq{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;background:transparent;border:0;color:var(--plum-deep);font-size:17px;font-weight:850;text-align:left;cursor:pointer}
.faq-q span{display:grid;place-items:center;flex:none;width:30px;height:30px;border-radius:50%;background:var(--soft);color:var(--plum);font-size:20px;font-weight:800}
.faq-a{max-height:0;overflow:hidden;color:#4d3d52;font-size:16px;line-height:1.75;transition:max-height .25s var(--ease),padding .25s var(--ease)}
.faq-item.open .faq-a{max-height:240px;padding:0 46px 20px 0}

.foot{background:var(--plum-deep);color:#dacbde;padding:38px 20px 90px}
.foot-in{width:100%;max-width:1180px;margin:0 auto}
.foot strong{display:block;color:#fff;font-size:18px;margin-bottom:10px}
.foot p{max-width:760px;color:#dacbde;font-size:14px;line-height:1.75}
.foot small{display:block;margin-top:14px;color:#bdaac3;font-size:12px}

.float-cta{position:fixed;right:22px;bottom:22px;z-index:60;display:none;align-items:center;justify-content:center;border-radius:999px;background:var(--plum);color:#fff;padding:15px 22px;font-size:15px;font-weight:900;box-shadow:0 16px 32px rgba(111,47,120,.3)}
.mbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid var(--line);box-shadow:0 -12px 30px rgba(45,19,56,.12)}
.mbar span{color:var(--plum-deep);font-size:14px;font-weight:850}
.mbar .btn{padding:11px 18px}

/* Diagnosis shared classes */
.diag-body{background:linear-gradient(180deg,var(--wash),#fff)}
.diag-wrap{width:100%;max-width:590px;margin:0 auto;padding:26px 16px 88px}
.diag-card{min-height:62vh;display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:28px 22px;box-shadow:var(--shadow)}
.hidden{display:none!important}
.steps{display:flex;justify-content:center;gap:8px;margin-bottom:26px}
.dot{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--soft);color:#85698b;font-size:13px;font-weight:850;transition:all .22s var(--ease)}
.dot.on{background:var(--plum);color:#fff;box-shadow:0 8px 18px rgba(111,47,120,.25)}
.diag-loading{text-align:center;color:var(--muted);padding:42px 0}
.q-title{color:var(--plum-deep);font-size:24px;font-weight:900;line-height:1.35;letter-spacing:-.03em}
.q-title.accent{color:var(--plum)}
.q-sub{margin-top:8px;margin-bottom:20px;color:var(--muted);font-size:15px}
.opts{display:flex;flex-direction:column;gap:10px;margin-top:18px;flex:1}
.opt{display:flex;align-items:center;gap:12px;width:100%;padding:16px 18px;border:2px solid var(--line);border-radius:16px;background:#fff;color:var(--ink);font-size:16px;font-weight:750;text-align:left;cursor:pointer;transition:all .16s var(--ease)}
.opt i{flex:none;width:22px;height:22px;border:2px solid #bfaac4;border-radius:50%;transition:all .16s var(--ease)}
.opt:hover{border-color:var(--plum)}
.opt.sel{border-color:var(--plum);background:var(--soft);color:var(--plum-deep)}
.opt.sel i{border-color:var(--plum);background:var(--plum);box-shadow:inset 0 0 0 4px #fff}
.field{width:100%;margin-top:12px;padding:15px 16px;border:2px solid var(--line);border-radius:16px;background:#fff;color:var(--ink);font-size:16px;transition:border .16s var(--ease),box-shadow .16s var(--ease)}
.field:focus{outline:none;border-color:var(--plum);box-shadow:0 0 0 4px rgba(111,47,120,.1)}
.agree{display:flex;align-items:center;gap:9px;margin-top:14px;color:var(--muted);font-size:14px;cursor:pointer}
.agree input{width:18px;height:18px;accent-color:var(--plum)}
.err{min-height:18px;margin-top:10px;color:var(--danger);font-size:13px}
.result-box{margin:16px 0;padding:22px;border:1px solid var(--line);border-radius:20px;background:var(--soft);color:var(--ink);font-size:16px;line-height:1.75}
.result-box .amount{display:block;margin:6px 0;color:var(--plum);font-size:31px;font-weight:950;letter-spacing:-.04em}
.diag-nav{display:flex;gap:12px;margin-top:24px}
.diag-nav .btn{flex:1}
.diag-nav #btn_prev{flex:0 0 98px;background:#fff}
.done-box{text-align:center;padding:32px 0;margin:auto 0}
.done-box .check{display:grid;place-items:center;width:74px;height:74px;margin:0 auto 20px;border-radius:50%;background:var(--moss);color:#fff;font-size:38px;font-weight:900;box-shadow:0 12px 28px rgba(79,125,59,.24)}
.done-box h2{color:var(--plum-deep);font-size:23px;font-weight:900;margin-bottom:8px}
.done-box p{color:var(--muted);margin-bottom:24px}

@media(min-width:768px){
  .nav-links{display:flex}
  .restart-desk{display:grid;grid-template-columns:minmax(238px,292px) minmax(0,1fr);gap:22px;align-items:start}
  .desk-rail{position:sticky;top:88px}
  .story-scroll{margin-top:0}
  .opening-page{grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);padding:54px}
  .turning-page,.faq-page{padding:48px}
  .relief-page{grid-template-columns:.88fr 1.12fr;align-items:stretch}
  .relief-note{padding:48px}
  .relief-copy{display:flex;flex-direction:column;justify-content:center;padding:48px}
  .diagnosis-page{grid-template-columns:1fr 330px;padding:48px}
  .float-cta{display:inline-flex}
  .mbar{display:none}
}

@media(min-width:1040px){
  .opening-page{min-height:calc(100vh - 118px)}
  .story-scroll{gap:22px}
}

@media(max-width:520px){
  .nav-in{height:60px;padding:0 16px}
  .brand{font-size:16px}
  .brand-mark{width:30px;height:30px;border-radius:10px}
  .nav-cta{padding:9px 13px;font-size:13px}
  .restart-desk{padding:18px 12px 66px}
  .desk-rail{padding:20px;border-radius:20px}
  .desk-rail strong{font-size:23px}
  .opening-page,.turning-page,.relief-page,.diagnosis-page,.faq-page{border-radius:22px}
  .opening-page{padding:28px 18px}
  .lead,.section-intro,.relief-copy{font-size:16px}
  .paper-visual{min-height:300px}
  .paper{width:min(80vw,300px);min-height:160px;padding:22px}
  .paper b{font-size:21px}
  .fold-board article{grid-template-columns:40px 1fr;padding:18px}
  .diagnosis-ticket strong{font-size:28px}
  .faq-q{font-size:16px}
  .faq-item.open .faq-a{padding-right:0}
}
