:root{
    --navy-1:#1E2A44; --navy-2:#2C355E; --navy-3:#2E4C7A; --blue:#347EBB; --blue-soft:#B8C7D4;
    --ink:#1F2430; --muted:#5A6171; --muted-2:#828A99;
    --white:#fff; --paper:#F6F7F8; --paper-2:#EEEFF1; --line:#E6E8EC; --line-2:#D9DCE2;
    --footer:#161A24;
    --ink-2:#384356; --ink-3:#46516A;
    --navy-card:#243151; --navy-card-line:#324168;
    --on-navy:#E7ECF5; --on-navy-muted:#AEBBD0; --on-navy-faint:#9FACC4;
    --blue-dark:#2C6CA6; --on-dark-soft:#C6D0E2;
    --footer-text:#9AA3B5; --footer-text-muted:#7E8799; --footer-text-dim:#6B7385; --footer-line:#262C3A;
    --sans:'Pretendard',system-ui,-apple-system,sans-serif;
    --wrap:1160px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:var(--sans);color:var(--ink);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;letter-spacing:-.01em}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
  .section{padding:clamp(60px,8vw,104px) 0}
  :focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:3px}
  .eyebrow{font-size:13px;font-weight:700;letter-spacing:.14em;color:var(--blue);text-transform:uppercase}
  .sec-head{text-align:center;max-width:40em;margin:0 auto clamp(40px,5vw,56px)}
  .sec-head h2{font-size:clamp(25px,3vw,36px);font-weight:800;letter-spacing:-.03em;line-height:1.32;margin-top:14px}
  .sec-head h2 em{font-style:normal;color:var(--blue)}
  .sec-head p{color:var(--muted);margin-top:14px;font-size:16px;line-height:1.7}

  .btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:700;font-size:15px;border:none;cursor:pointer;border-radius:10px;padding:13px 22px;background:var(--blue);color:var(--white);transition:transform .15s,background .15s;letter-spacing:-.01em}
  .btn:hover{background:var(--blue-dark);transform:translateY(-1px)}
  .btn .kk{width:17px;height:17px;border-radius:5px;background:var(--white);color:var(--blue);display:grid;place-items:center;font-size:11px;font-weight:800}
  .btn-line{background:var(--white);color:var(--navy-1);border:1px solid var(--line-2)}
  .btn-line:hover{background:var(--white);border-color:var(--navy-3);transform:translateY(-1px)}

  .nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line)}
  .nav .wrap{display:flex;align-items:center;justify-content:space-between;height:70px}
  .nav .logo{height:26px;width:auto;display:block}
  .nav-links{display:flex;gap:32px;align-items:center}
  .nav-links a{font-size:15px;color:var(--ink);opacity:.82;font-weight:600}
  .nav-links a:hover{opacity:1;color:var(--blue)}
  .nav-cta{display:flex;gap:12px;align-items:center}
  .hamburger{display:none;width:42px;height:42px;border:1px solid var(--line-2);background:var(--white);border-radius:10px;cursor:pointer}
  .hamburger span,.hamburger span::before,.hamburger span::after{content:"";display:block;width:18px;height:1.6px;background:var(--navy-1);margin:0 auto;position:relative}
  .hamburger span::before{position:absolute;top:-6px}
  .hamburger span::after{position:absolute;top:6px}

  .hero{background:var(--white);position:relative;overflow:hidden}
  .hero .wrap{padding-top:clamp(56px,7vw,96px);padding-bottom:clamp(56px,7vw,96px)}
  .hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(36px,4.5vw,64px);align-items:center}
  .hero h1{font-size:clamp(30px,4.2vw,50px);font-weight:800;line-height:1.26;letter-spacing:-.035em;color:var(--navy-1);margin-top:14px}
  .hero h1 .hl{color:var(--navy-3)}
  .hero p.lead{margin-top:22px;font-size:clamp(16px,1.3vw,18px);color:var(--ink-2);max-width:29em;line-height:1.72}
  .hero .cta-row{margin-top:30px;display:flex;gap:12px;flex-wrap:wrap}
  .creds{margin-top:34px;display:flex;background:var(--blue-soft);border:1px solid rgba(30,42,68,.16);border-radius:14px;overflow:hidden;max-width:560px}
  .cred{flex:1;padding:16px 14px;text-align:center;border-right:1px solid rgba(30,42,68,.14)}
  .cred:last-child{border-right:none}
  .cred .v{display:block;font-weight:800;font-size:15px;color:var(--navy-1);letter-spacing:-.02em}
  .cred .k{display:block;font-size:11.5px;color:var(--ink-3);margin-top:4px;font-weight:600}

  .mcard{background:var(--white);border-radius:18px;box-shadow:0 30px 60px -30px rgba(30,42,68,.45);border:1px solid rgba(255,255,255,.7);overflow:hidden}
  .mcard-top{padding:16px 22px;background:var(--navy-1);color:var(--white)}
  .mcard-top .t{font-weight:700;font-size:14.5px;letter-spacing:-.01em}
  .mcard-top .s{font-size:12px;color:var(--on-navy-muted);margin-top:2px}
  .mcard-body{padding:8px 22px 18px}
  .mstep{display:flex;gap:16px;padding:15px 0;border-bottom:1px solid var(--line)}
  .mstep:last-child{border-bottom:none}
  .mstep .n{font-weight:800;font-size:13px;color:var(--blue);width:22px;flex:none;padding-top:2px}
  .mstep .nm{font-weight:700;font-size:16px;color:var(--navy-1)}
  .mstep .ds{font-size:13.5px;color:var(--muted);margin-top:3px;line-height:1.55}

  .band{background:var(--navy-1);color:var(--white);text-align:center;padding:26px 20px}
  .band p{font-size:clamp(17px,2vw,21px);font-weight:700;letter-spacing:-.02em}
  .band p .dot{color:var(--blue-soft)}

  .worry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  .worry{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:26px 24px;display:flex;gap:14px;align-items:flex-start;min-height:132px}
  .worry .ix{width:30px;height:30px;border-radius:8px;background:var(--white);border:1px solid var(--line-2);color:var(--blue);font-weight:800;display:grid;place-items:center;flex:none;font-size:14px}
  .worry p{font-size:15.5px;line-height:1.6;color:var(--ink)}
  .worry-turn{margin-top:30px;text-align:center;color:var(--muted);font-size:16px;max-width:44em;margin-left:auto;margin-right:auto;line-height:1.7}
  .worry-turn b{color:var(--navy-1);font-weight:700}

  .method{background:var(--paper)}
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  .step{background:var(--white);border:1px solid var(--line);border-radius:14px;overflow:hidden}
  .step .sh{background:var(--navy-1);color:var(--white);padding:13px 18px;font-weight:700;font-size:14px;display:flex;align-items:center;gap:9px}
  .step .sh .num{color:var(--blue-soft);font-size:12px;font-weight:800}
  .step .sb{padding:18px 18px 22px}
  .step .sb .nm{font-weight:800;font-size:17px;color:var(--navy-1)}
  .step .sb .ds{font-size:14px;color:var(--muted);margin-top:9px;line-height:1.6}
  .method-note{margin-top:30px;background:var(--white);border:1px solid var(--line);border-left:3px solid var(--blue);border-radius:12px;padding:22px 26px;max-width:760px;margin-left:auto;margin-right:auto}
  .method-note p{font-size:15.5px;color:var(--ink);line-height:1.7}
  .method-note b{color:var(--navy-1);font-weight:700}

  .voices{background:var(--navy-1);color:var(--white)}
  .voices .sec-head h2{color:var(--white)}
  .voices .sec-head .eyebrow{color:var(--blue-soft)}
  .voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .voice{background:var(--navy-card);border:1px solid var(--navy-card-line);border-radius:14px;padding:26px 24px;display:flex;flex-direction:column}
  .voice .qm{font-weight:800;color:var(--blue-soft);font-size:30px;line-height:.7;height:20px}
  .voice blockquote{font-size:15.5px;line-height:1.7;color:var(--on-navy);margin-top:8px;flex:1}
  .voice .who{margin-top:20px;padding-top:14px;border-top:1px solid var(--navy-card-line);font-size:13px;color:var(--on-navy-muted);font-weight:600}
  .voice .who .ex{display:inline-block;font-size:10.5px;font-weight:800;color:var(--navy-1);background:var(--blue-soft);border-radius:5px;padding:1px 6px;margin-right:7px;vertical-align:middle;letter-spacing:.02em}
  .voice .who b{color:var(--white);font-weight:700}
  .voices .more{text-align:center;margin-top:34px}
  .voices .more a{color:var(--blue-soft);font-weight:700;font-size:15px}

  .faq .wrap{max-width:860px}
  .qa{border-top:1px solid var(--line-2)}
  .qa:last-child{border-bottom:1px solid var(--line-2)}
  .qa summary{list-style:none;cursor:pointer;padding:23px 4px;display:flex;align-items:center;gap:16px;font-weight:700;font-size:16.5px}
  .qa summary::-webkit-details-marker{display:none}
  .qa summary .q{color:var(--blue);font-weight:800;flex:none}
  .qa summary .plus{margin-left:auto;flex:none;width:20px;height:20px;position:relative}
  .qa summary .plus::before,.qa summary .plus::after{content:"";position:absolute;background:var(--navy-1);inset:0;margin:auto}
  .qa summary .plus::before{width:13px;height:1.6px}
  .qa summary .plus::after{width:1.6px;height:13px;transition:transform .25s}
  .qa details[open] summary .plus::after{transform:rotate(90deg);opacity:0}
  .qa .ans{padding:0 4px 24px 42px;color:var(--muted);font-size:15.5px;line-height:1.72;max-width:54em}

  .final{background:linear-gradient(150deg,var(--navy-1),var(--navy-3));color:var(--white);text-align:center}
  .final .wrap{max-width:720px}
  .final .eyebrow{color:var(--blue-soft)}
  .final h2{font-size:clamp(26px,3.4vw,40px);font-weight:800;letter-spacing:-.03em;line-height:1.34;margin-top:16px}
  .final p{color:var(--on-dark-soft);margin-top:18px;font-size:16.5px;line-height:1.7}
  .final .btn{margin-top:30px;font-size:16px;padding:15px 28px}
  .final .small{margin-top:14px;font-size:13px;color:var(--on-navy-faint)}

  footer.f{background:var(--footer);color:var(--footer-text);padding:54px 0 38px}
  .f-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
  footer.f .logo{height:24px;width:auto;display:block;margin-bottom:16px}
  footer.f .desc{font-size:13.5px;line-height:1.7;color:var(--footer-text-muted)}
  .f-col h4{color:var(--on-navy);font-size:14px;font-weight:700;margin-bottom:14px}
  .f-col a,.f-col p{display:block;font-size:14px;color:var(--footer-text);margin-bottom:9px;line-height:1.5}
  .f-col a:hover{color:var(--white)}
  .f-bottom{border-top:1px solid var(--footer-line);margin-top:34px;padding-top:22px;font-size:12.5px;color:var(--footer-text-dim);line-height:1.7}

  .mobile-cta{display:none}
  .reveal{opacity:0;transform:translateY(16px);transition:opacity .7s,transform .7s}
  .reveal.in{opacity:1;transform:none}

  @media (max-width:920px){
    .hero-grid{grid-template-columns:1fr;gap:34px}
    .worry-grid,.steps,.voice-grid{grid-template-columns:1fr 1fr}
    .nav-links{display:none}
    .nav-cta .btn:not(.hamburger){display:none}
    .hamburger{display:block}
    .f-top{grid-template-columns:1fr 1fr}
    .f-col.brand{grid-column:1/-1}
  }
  @media (max-width:600px){
    .wrap{padding:0 18px}
    .worry-grid,.steps,.voice-grid{grid-template-columns:1fr}
    .creds{flex-wrap:wrap}
    .cred{flex:1 1 50%;border-bottom:1px solid rgba(30,42,68,.14)}
    body{padding-bottom:72px}
    .mobile-cta{display:block;position:fixed;left:0;right:0;bottom:0;z-index:60;padding:11px 16px calc(11px + env(safe-area-inset-bottom));background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
    .mobile-cta .btn{width:100%;justify-content:center;padding:14px}
    .f-top{grid-template-columns:1fr}
  }
  @media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}.reveal{opacity:1;transform:none}}

/* ===== inner-page 컴포넌트 ===== */
.brandlink{display:inline-flex;align-items:center}
@media (max-width:920px){.nav.open .nav-links{display:flex;position:absolute;top:70px;left:0;right:0;flex-direction:column;gap:0;background:var(--white);border-bottom:1px solid var(--line);padding:6px 0;box-shadow:0 18px 30px -22px rgba(30,42,68,.4)}.nav.open .nav-links a{padding:14px 28px}}
.nav-links a.on{color:var(--blue);opacity:1}
.page-hero{background:var(--paper);border-bottom:1px solid var(--line)}
.page-hero .wrap{padding-top:clamp(46px,6vw,80px);padding-bottom:clamp(38px,5vw,60px)}
.page-hero .eyebrow{display:block;margin-bottom:14px}
.page-hero h1{font-size:clamp(27px,3.6vw,42px);font-weight:800;letter-spacing:-.03em;color:var(--navy-1);line-height:1.28}
.page-hero p{margin-top:16px;color:var(--muted);font-size:17px;line-height:1.7;max-width:44em}
.prose p{font-size:16px;line-height:1.8;color:var(--ink);margin-bottom:16px}.prose p:last-child{margin-bottom:0}
.lead-2{font-size:19px;line-height:1.6;color:var(--navy-1);font-weight:700;letter-spacing:-.02em;margin-bottom:18px}
.info{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:26px 24px}
.info h3{font-size:17px;font-weight:800;color:var(--navy-1);margin-bottom:10px}
.info p{font-size:14.5px;color:var(--muted);line-height:1.65}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:840px){.info-grid{grid-template-columns:1fr}}
.tl{display:flex;gap:18px}
.tl .tl-time{flex:none;width:74px;font-weight:800;color:var(--blue);font-size:13px;padding-top:3px}
.tl .tl-body{border-left:2px solid var(--line-2);padding:0 0 26px 22px;position:relative;flex:1}
.tl:last-child .tl-body{padding-bottom:2px}
.tl .tl-body::before{content:"";position:absolute;left:-7px;top:5px;width:12px;height:12px;border-radius:50%;background:var(--blue);border:3px solid var(--white);box-shadow:0 0 0 1px var(--line-2)}
.tl .tl-body h4{font-size:16px;font-weight:700;color:var(--navy-1)}
.tl .tl-body p{font-size:14px;color:var(--muted);margin-top:5px;line-height:1.6}
.search{display:flex;align-items:center;gap:10px;border:1px solid var(--line-2);border-radius:10px;padding:11px 15px;background:var(--white);max-width:420px}
.search input{border:none;outline:none;font:inherit;width:100%;color:var(--ink);background:transparent}
.search .ico{color:var(--muted-2);font-size:15px}
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:20px 0 0}
.tabs a{padding:12px 14px;font-size:14.5px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px}
.tabs a.on{color:var(--navy-1);border-bottom-color:var(--blue)}
.board{width:100%;border-collapse:collapse}
.board th{text-align:left;font-size:13px;color:var(--muted-2);font-weight:700;padding:14px 12px;border-bottom:1px solid var(--line-2)}
.board td{padding:16px 12px;border-bottom:1px solid var(--line);font-size:15px;vertical-align:middle}
.board tr:hover td{background:var(--paper)}
.board .b-date{color:var(--muted-2);font-size:13.5px;white-space:nowrap;width:118px}
.board .b-title a{color:var(--ink);font-weight:500}.board .b-title a:hover{color:var(--blue)}
.cat{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:5px;margin-right:9px;vertical-align:middle}
.cat-notice{background:var(--navy-1);color:var(--white)}.cat-column{background:var(--blue-soft);color:var(--navy-1)}.cat-book{background:var(--paper-2);color:var(--muted)}
.pin{color:var(--blue);font-weight:800}
.more-btn{display:inline-block;border:1px solid var(--line-2);background:var(--white);color:var(--ink);font-weight:600;font-size:14px;padding:11px 28px;border-radius:999px}
.more-btn:hover{border-color:var(--navy-3);color:var(--navy-1)}
.center{text-align:center;margin-top:30px}
.pagination{display:flex;gap:6px;justify-content:center;margin-top:28px}
.pagination a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--line-2);border-radius:8px;font-size:14px;font-weight:600;color:var(--muted)}
.pagination a:hover{border-color:var(--navy-3);color:var(--navy-1)}
.pagination a.on{background:var(--blue);border-color:var(--blue);color:var(--white)}
.rev-list{border-top:1px solid var(--line-2)}
.rev{display:flex;gap:16px;align-items:center;padding:18px 6px;border-bottom:1px solid var(--line)}
.rev .rn{flex:none;width:26px;color:var(--muted-2);font-weight:700;font-size:14px;text-align:center}
.rev .rt{flex:1;font-size:15.5px;color:var(--ink);font-weight:500}
.rev .rt .ex{display:inline-block;font-size:10.5px;font-weight:800;color:var(--navy-1);background:var(--blue-soft);border-radius:5px;padding:1px 6px;margin-right:8px;vertical-align:middle;letter-spacing:.02em}
.rev .rd{flex:none;color:var(--muted-2);font-size:13.5px;white-space:nowrap}
.note{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--blue);border-radius:12px;padding:16px 20px;color:var(--muted);font-size:14px;line-height:1.65;margin-top:26px}
.note b{color:var(--navy-1)}

/* ===== profile 페이지 ===== */
/* 프로필 사진이 있는 page-hero (profile.html 전용) */
.page-hero.has-photo .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,60px);align-items:center}
.page-hero.has-photo .ph-text{min-width:0}
.page-hero .photo{justify-self:end;width:100%}
.page-hero .photo img{display:block;width:100%;max-width:360px;height:auto;margin-left:auto;border-radius:16px;border:1px solid var(--line-2);box-shadow:0 26px 54px -30px rgba(30,42,68,.5)}
@media(max-width:840px){
  .page-hero.has-photo .wrap{grid-template-columns:1fr}
  .page-hero .photo{justify-self:start;margin-top:18px}
  .page-hero .photo img{max-width:240px;margin-left:0}
}
