@charset "utf-8";
/* 치아보험 추천 (toothhappy.co.kr) — 추천 카드덱 / 퍼플 + 민트 + 크림 (넘기는 추천 카드) */
:root{
  --ink:#332a52;--ink2:#473c66;
  --pur:#7c5cff;--pur-d:#5e3fe0;--pur-dd:#4527b8;--pur-soft:#f1edff;--pur-soft2:#d9ceff;
  --mint:#2ec5a8;--mint-d:#16a98c;--mint-dd:#0c7a64;--mint-soft:#dcf7f0;--mint-soft2:#b3ecde;
  --amber:#ffb938;--amber-d:#e89a10;--amber-dd:#a86c05;--amber-soft:#fff2d6;
  --soft:#8b84a8;--bg:#f7f5ff;--bg2:#efebff;--paper:#ffffff;--line:#eee9fc;--line2:#e2dbf7;
  --r:18px;--r-lg:24px;--shadow:0 12px 28px rgba(124,92,255,.12);--shadow-lg:0 24px 52px rgba(124,92,255,.2);
  --shadow-pur:0 12px 26px rgba(124,92,255,.38);--shadow-mint:0 12px 26px rgba(46,197,168,.34);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Pretendard',system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.74;-webkit-font-smoothing:antialiased;overflow-x:clip}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;color:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}

/* ---------- 헤더 ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(247,245,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line2)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:10px}
.brand .mark{width:37px;height:37px}.brand .mark svg{width:37px;height:37px;filter:drop-shadow(0 4px 10px rgba(124,92,255,.42))}
.brand h1{font-size:20px;font-weight:800;letter-spacing:-.6px;line-height:1;margin:0;color:var(--ink)}
nav ul{display:flex;gap:2px;list-style:none}
nav a{font-weight:600;font-size:14.5px;color:var(--ink);padding:9px 15px;border-radius:999px;transition:background .15s,color .15s}
nav a:hover{background:var(--pur-soft);color:var(--pur-dd)}
nav a.active{color:var(--pur-dd);font-weight:700;background:var(--pur-soft)}
.hbtn{background:var(--pur);color:#fff;border-radius:999px;padding:11px 22px;font-weight:800;font-size:14px;display:inline-flex;align-items:center;gap:6px;transition:transform .15s,box-shadow .15s;letter-spacing:-.2px;box-shadow:var(--shadow-pur)}
.hbtn:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(124,92,255,.52);background:var(--pur-d)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:0}
.burger span{width:24px;height:2.5px;background:var(--ink);border-radius:2px}
.mmenu{display:none;position:fixed;inset:0;z-index:80;background:rgba(51,42,82,.5)}
.mmenu.open{display:block}
.mpanel{position:absolute;right:0;top:0;height:100%;width:78%;max-width:320px;background:var(--paper);padding:26px 24px;overflow-y:auto;box-shadow:-12px 0 32px rgba(51,42,82,.22)}
.mpanel .x{background:var(--pur-soft);border:0;width:38px;height:38px;border-radius:50%;font-size:20px;font-weight:800;cursor:pointer;display:block;margin-left:auto;color:var(--pur-dd)}
.mpanel ul{list-style:none;margin-top:18px}
.mpanel li{border-bottom:1px solid var(--line)}
.mlink{display:block;padding:14px 6px;font-weight:700;font-size:16px;color:var(--ink)}
.mlink:hover{color:var(--pur-dd)}
.mlink.hl{background:var(--pur);color:#fff;text-align:center;border-radius:999px;margin-top:18px;border-bottom:0;box-shadow:var(--shadow-pur)}

/* ---------- 공통 헤딩 ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:12px;letter-spacing:2.5px;color:var(--pur-dd);text-transform:uppercase}
.eyebrow::before{content:"";width:22px;height:3px;border-radius:2px;background:var(--mint)}
.title{font-size:clamp(26px,3.6vw,38px);font-weight:800;letter-spacing:-1.2px;line-height:1.26;color:var(--ink);margin-top:14px}
.title .pu{color:var(--pur-d)}.title .mt{color:var(--mint-dd)}.title .am{color:var(--amber-dd)}
.desc{margin-top:13px;color:var(--soft);font-size:15.5px;max-width:660px}
.desc b{color:var(--ink)}
.block{padding:62px 0}
.center{text-align:center}.center .desc{margin-left:auto;margin-right:auto}.center .eyebrow{justify-content:center}
.tspot{vertical-align:-6px;margin:0 2px}

/* ---------- 히어로 (폼 카드 좌 / 추천 카드덱 우) ---------- */
.hero{position:relative;overflow:clip;background:radial-gradient(680px 360px at 6% -40px,rgba(124,92,255,.18),transparent 56%),radial-gradient(620px 340px at 100% 120%,rgba(46,197,168,.16),transparent 60%),linear-gradient(180deg,#fbfaff,var(--bg));padding:50px 0 52px}
.herowrap{position:relative;z-index:1;display:grid;grid-template-columns:400px 1fr;gap:48px;align-items:center}
.hero-l .badge{display:inline-flex;align-items:center;gap:8px;background:var(--mint-soft);color:var(--mint-dd);border-radius:999px;padding:7px 16px;font-weight:800;font-size:12.5px;margin-bottom:16px}
.hero-l h2{font-size:clamp(29px,4.2vw,46px);font-weight:800;line-height:1.15;letter-spacing:-1.5px;color:var(--ink);margin-bottom:18px}
.hero-l h2 .pu{color:var(--pur-d)}.hero-l h2 .mt{color:var(--mint-dd)}
.hero-l h2 em{font-style:normal;position:relative;white-space:nowrap}
.hero-l h2 em::after{content:"";position:absolute;left:-2px;right:-2px;bottom:2px;height:12px;background:var(--amber-soft);z-index:-1;border-radius:6px}

/* 맨 앞 입력 폼 카드 (덱의 front card) */
.qcard{position:relative;background:var(--paper);border:1px solid var(--line2);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);scroll-margin-top:90px}
.qcard::before{content:"";position:absolute;inset:0 0 0 0;top:14px;left:10px;right:-10px;background:var(--pur-soft);border:1px solid var(--pur-soft2);border-radius:var(--r-lg);z-index:-1;transform:rotate(3deg)}
.qcard .qtab{position:relative;background:linear-gradient(120deg,var(--pur),var(--pur-d));color:#fff;padding:16px 24px;border-radius:var(--r-lg) var(--r-lg) 0 0;display:flex;align-items:center;justify-content:space-between}
.qcard .qtab .rno{font-size:11px;font-weight:700;letter-spacing:2px;color:var(--pur-soft2);display:block;margin-bottom:2px}
.qcard .qtab h3{font-size:17px;font-weight:800;letter-spacing:-.3px}
.qcard .qtab h3 span{color:#ffe6a8}
.qcard .qtab .free{background:#fff;color:var(--pur-dd);font-size:11px;font-weight:800;padding:4px 11px;border-radius:999px}
.qcard .qbody{padding:22px 24px 26px}
.field{margin-bottom:13px}
.field label{display:block;font-size:12.5px;font-weight:700;margin-bottom:6px;color:var(--ink);letter-spacing:-.2px}
.txt{width:100%;border:1.5px solid var(--line2);background:#faf9ff;border-radius:12px;padding:12px 14px;font-size:15px;font-family:inherit;color:var(--ink);appearance:none;-webkit-appearance:none;transition:border .15s,box-shadow .15s,background .15s}
.txt:focus{outline:none;border-color:var(--pur);background:#fff;box-shadow:0 0 0 3px rgba(124,92,255,.16)}
.txt::placeholder{color:#b5addb}
select.txt{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23332a52' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:30px}
.frow2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.seg{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.seg button{border:1.5px solid var(--line2);background:#faf9ff;border-radius:12px;padding:11px 0;font-size:14.5px;font-weight:700;cursor:pointer;color:var(--soft);transition:all .15s}
.seg button:hover{border-color:var(--pur);color:var(--pur-dd)}
.seg button.on{background:var(--pur);border-color:var(--pur);color:#fff}
.phone-row{display:grid;grid-template-columns:70px 1fr;gap:8px}
.submit{width:100%;background:var(--pur);color:#fff;border:0;border-radius:14px;padding:15px 0;font-size:16.5px;font-weight:800;letter-spacing:-.3px;cursor:pointer;box-shadow:var(--shadow-pur);transition:transform .12s,box-shadow .15s;margin-top:6px}
.submit:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(124,92,255,.52);background:var(--pur-d)}
.submit:active{transform:translateY(1px)}
.cfoot{margin-top:13px}
.privacy_wrap{display:flex;align-items:center;gap:7px;font-size:12.5px}
.privacy_wrap input[type=checkbox]{width:16px;height:16px;accent-color:var(--pur)}
.privacy_label{font-weight:600;color:var(--ink)}
.privacy_view{font-weight:700;color:var(--mint-dd);text-decoration:underline;text-underline-offset:3px}
.privacy_view:hover{color:var(--pur-dd)}
.err{display:none;background:#fcebf0;border:1.5px solid #f2c0d2;border-radius:12px;color:#c43a6a;font-size:13.5px;font-weight:700;padding:10px 14px;margin:10px 0 0;text-align:center}

/* 추천 카드덱 (히어로 우측 비주얼) */
.deck{position:relative;height:330px}
.deck .dcard{position:absolute;width:230px;background:var(--paper);border:1px solid var(--line2);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:20px}
.deck .d1{left:46px;top:30px;transform:rotate(-9deg);background:var(--pur-soft);border-color:var(--pur-soft2)}
.deck .d2{left:120px;top:14px;transform:rotate(6deg);background:var(--mint-soft);border-color:var(--mint-soft2)}
.deck .d3{left:84px;top:58px;transform:rotate(-1deg);box-shadow:var(--shadow-lg);z-index:2}
.deck .dchip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:800;padding:4px 11px;border-radius:999px;margin-bottom:13px}
.deck .d3 .dchip{background:var(--mint);color:#fff}
.deck .dco{width:58px;height:58px;margin-bottom:12px}
.deck .dco svg{width:58px;height:58px}
.deck .dl{font-size:16px;font-weight:800;color:var(--ink);letter-spacing:-.3px;margin-bottom:8px}
.deck .dbar{height:8px;border-radius:6px;background:var(--pur-soft2);margin-bottom:6px}
.deck .dbar.s{width:72%;background:var(--mint-soft2)}
.deck .dfly{position:absolute;right:18px;top:0;width:46px;height:46px;border-radius:14px;background:var(--amber);box-shadow:var(--shadow);display:grid;place-items:center;transform:rotate(12deg);font-size:22px}

/* ---------- 마퀴 ---------- */
.insurers{padding:42px 0 6px}
.insurers .cap{text-align:center;font-size:11.5px;font-weight:800;color:var(--soft);letter-spacing:3px;margin-bottom:15px}
.marquee{overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.track{display:flex;gap:10px;list-style:none;width:max-content;animation:marquee 30s linear infinite;padding:4px 0}
.marquee:hover .track{animation-play-state:paused}
.track li{background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:9px 22px;font-weight:700;font-size:14px;color:var(--pur-dd);white-space:nowrap}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important}}

/* ---------- 추천 매칭 스텝 ---------- */
.match{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.mstep{background:var(--paper);border:1px solid var(--line2);border-radius:var(--r-lg);padding:26px 24px;box-shadow:var(--shadow);position:relative;text-align:center}
.mstep .mn{width:46px;height:46px;border-radius:14px;background:var(--pur);color:#fff;display:grid;place-items:center;font-size:20px;font-weight:800;margin:0 auto 13px;box-shadow:var(--shadow-pur)}
.mstep:nth-child(2) .mn{background:var(--mint);box-shadow:var(--shadow-mint)}
.mstep:nth-child(3) .mn{background:var(--amber);box-shadow:0 12px 26px rgba(255,185,56,.4)}
.mstep h3{font-size:17px;font-weight:800;letter-spacing:-.3px;color:var(--ink);margin-bottom:6px}
.mstep p{font-size:13.8px;color:var(--soft);line-height:1.62}
.mstep p b{color:var(--ink)}

/* ---------- 보장 카드 그리드 ---------- */
.cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:38px}
.ccard{background:var(--paper);border:1px solid var(--line2);border-radius:var(--r-lg);padding:26px 24px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;text-align:center}
.ccard:hover{transform:translateY(-6px)}
.ccard::after{content:"";position:absolute;right:-24px;top:-24px;width:84px;height:84px;border-radius:50%;background:var(--pur-soft);opacity:.6}
.ccard:nth-child(3n-1)::after{background:var(--mint-soft)}
.ccard:nth-child(3n)::after{background:var(--amber-soft)}
.ccard .cco{position:relative;z-index:1;width:88px;height:88px;margin:0 auto 13px}
.ccard .cco svg{width:88px;height:88px}
.ccard h3{position:relative;z-index:1;font-size:18px;font-weight:800;letter-spacing:-.4px;color:var(--ink);margin-bottom:7px}
.ccard p{position:relative;z-index:1;font-size:14px;color:var(--soft);line-height:1.64}
.ccard p b{color:var(--ink)}

/* ---------- 추천 유형 카드 (시그니처) ---------- */
.types{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:38px}
.tcard{position:relative;background:var(--paper);border:1px solid var(--line2);border-radius:var(--r-lg);padding:26px 24px 24px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;overflow:hidden}
.tcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.tcard::before{content:"";position:absolute;top:0;left:0;width:100%;height:6px;background:var(--pur)}
.tcard:nth-child(2)::before{background:var(--mint)}
.tcard:nth-child(3)::before{background:var(--amber)}
.tcard .tbadge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:800;background:var(--pur-soft);color:var(--pur-dd);border-radius:999px;padding:5px 12px;margin-bottom:13px}
.tcard:nth-child(2) .tbadge{background:var(--mint-soft);color:var(--mint-dd)}
.tcard:nth-child(3) .tbadge{background:var(--amber-soft);color:var(--amber-dd)}
.tcard h3{font-size:18.5px;font-weight:800;letter-spacing:-.4px;color:var(--ink);margin-bottom:6px}
.tcard .who{font-size:13px;font-weight:700;color:var(--pur-d);margin-bottom:11px}
.tcard:nth-child(2) .who{color:var(--mint-dd)}.tcard:nth-child(3) .who{color:var(--amber-dd)}
.tcard ul{list-style:none;display:grid;gap:8px}
.tcard li{position:relative;padding-left:23px;font-size:13.8px;color:var(--soft);line-height:1.55}
.tcard li::before{content:"✓";position:absolute;left:0;top:0;color:var(--mint-d);font-weight:800}
.tcard li b{color:var(--ink)}

/* ---------- 가입 전 체크 ---------- */
.checks{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:34px}
.chk{display:grid;grid-template-columns:auto 1fr;gap:15px;align-items:flex-start;background:var(--paper);border:1px solid var(--line2);border-radius:18px;padding:20px 22px;box-shadow:var(--shadow)}
.chk .cn{width:42px;height:42px;border-radius:13px;background:var(--pur-soft);color:var(--pur-dd);display:grid;place-items:center;font-size:20px;font-weight:800;flex:none}
.chk:nth-child(2n) .cn{background:var(--mint-soft);color:var(--mint-dd)}
.chk h3{font-size:16.5px;font-weight:800;letter-spacing:-.3px;color:var(--ink);margin-bottom:4px}
.chk p{font-size:13.8px;color:var(--soft);line-height:1.62}
.chk p b{color:var(--ink)}

/* ---------- 숫자 밴드 ---------- */
.statband{background:linear-gradient(125deg,var(--pur),var(--mint));border-radius:var(--r-lg);padding:38px 30px;box-shadow:var(--shadow-lg);position:relative;overflow:clip}
.statband::before{content:"";position:absolute;right:-40px;bottom:-50px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.16)}
.statband::after{content:"";position:absolute;left:-30px;top:-40px;width:120px;height:120px;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;background:rgba(255,255,255,.12)}
.sgrid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.scell{text-align:center;color:#fff}
.scell .pi{font-size:26px;margin-bottom:8px;display:block}
.scell b{display:block;font-size:18px;font-weight:800;color:#fff;letter-spacing:-.3px;margin-bottom:3px}
.scell span{font-size:12.5px;color:rgba(255,255,255,.95);line-height:1.5}

/* ---------- 콜아웃 ---------- */
.callout{background:var(--pur-soft);border:1px solid var(--pur-soft2);border-radius:var(--r);padding:20px 24px;display:flex;gap:15px;align-items:flex-start;box-shadow:var(--shadow)}
.callout.mt{background:var(--mint-soft);border-color:var(--mint-soft2)}
.callout.am{background:var(--amber-soft);border-color:#fadd9c}
.callout .ci{flex:none;width:40px;height:40px;border-radius:50%;background:var(--paper);color:var(--pur-dd);display:grid;place-items:center;font-size:20px}
.callout.mt .ci{color:var(--mint-dd)}.callout.am .ci{color:var(--amber-dd)}
.callout h3{font-size:16px;font-weight:800;margin-bottom:5px;color:var(--ink)}
.callout p{font-size:14px;color:var(--soft)}
.callout p a{color:var(--pur-dd);text-decoration:underline;text-underline-offset:3px;font-weight:700}

/* ---------- 표 ---------- */
.gentable{margin:0;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);background:var(--paper);border:1px solid var(--line2)}
.gentable table{width:100%;border-collapse:collapse;font-size:14.3px}
.gentable th{background:var(--ink);color:#fff;font-weight:700;padding:13px 16px;text-align:left;word-break:keep-all}
.gentable th.hl{background:var(--pur-d)}
.gentable th b{color:var(--pur-soft2)}
.gentable td{padding:12px 16px;border-top:1px solid var(--line);color:var(--soft);vertical-align:top;line-height:1.6;word-break:keep-all}
.gentable td b{color:var(--ink)}
.gentable tr:nth-child(even) td{background:#faf9ff}
.gentable td.pick{background:var(--mint-soft);color:var(--ink);font-weight:600}

/* ---------- 6 메뉴 카드 ---------- */
.mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:38px}
.mtile{background:var(--paper);border:1px solid var(--line2);border-radius:var(--r-lg);box-shadow:var(--shadow);display:block;overflow:hidden;transition:transform .2s,box-shadow .2s;position:relative}
.mtile:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.mtile .mthumb{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--pur-soft);position:relative}
.mtile .mthumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.mtile:hover .mthumb img{transform:scale(1.05)}
.mtile .mno{position:absolute;left:14px;top:14px;z-index:2;background:#fff;color:var(--pur-d);font-size:13px;font-weight:800;letter-spacing:.5px;padding:6px 13px;border-radius:999px;box-shadow:var(--shadow)}
.mtile:nth-child(3n-1) .mno{color:var(--mint-dd)}.mtile:nth-child(3n) .mno{color:var(--amber-dd)}
.mtile .mcap{padding:18px 22px 20px;text-align:center}
.mtile .mcap b{display:block;font-size:17px;font-weight:800;color:var(--ink);letter-spacing:-.3px;margin-bottom:3px}
.mtile .mcap .ct{font-size:13.2px;color:var(--soft);display:flex;align-items:center;justify-content:center;gap:6px}
.mtile .mcap .go{color:var(--pur-d);font-weight:800;transition:transform .2s}
.mtile:hover .mcap .go{transform:translateX(4px)}

/* ---------- FAQ ---------- */
.faq{margin-top:30px;max-width:940px}
.faqcenter{margin-left:auto;margin-right:auto}
.qa{background:var(--paper);border:1px solid var(--line2);border-radius:var(--r);margin-bottom:11px;box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .2s,border .2s}
.qa.open{border-color:var(--pur);box-shadow:var(--shadow-lg)}
.qa .q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;background:none;border:0;text-align:left;padding:18px 22px;font-size:15.5px;font-weight:700;cursor:pointer;color:var(--ink)}
.qa .q:hover{background:var(--bg)}
.qa .qmark{color:var(--pur-d);font-weight:800;margin-right:9px}
.qa .ar{width:27px;height:27px;border-radius:999px;background:var(--pur-soft);color:var(--pur-dd);display:grid;place-items:center;font-size:16px;font-weight:800;flex:none;transition:transform .25s,background .2s,color .2s}
.qa.open .ar{transform:rotate(45deg);background:var(--pur);color:#fff}
.qa .a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--soft);font-size:14.6px}
.qa .a > div{padding:0 22px 19px;border-top:1px solid var(--line);padding-top:14px}
.faqmore{display:inline-block;margin-top:16px;font-weight:700;font-size:14.5px;color:var(--pur-dd);text-decoration:underline;text-underline-offset:3px}
.faqmore:hover{color:var(--mint-dd)}

/* ---------- CTA ---------- */
.ctaband{position:relative;background:linear-gradient(120deg,var(--pur),var(--pur-d));color:#fff;padding:50px 46px;border-radius:var(--r-lg);overflow:clip;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.ctaband::before{content:"";position:absolute;right:-40px;top:-50px;width:210px;height:210px;border-radius:50%;background:rgba(255,255,255,.16)}
.ctaband::after{content:"";position:absolute;left:-30px;bottom:-50px;width:150px;height:150px;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;background:rgba(46,197,168,.4)}
.ctaband .ctxt{position:relative;z-index:1}
.ctaband .ctxt h2{font-size:clamp(22px,3.2vw,33px);font-weight:800;line-height:1.2;letter-spacing:-.8px;color:#fff}
.ctaband .ctxt h2 b{color:#fff;text-decoration:underline;text-decoration-color:rgba(255,255,255,.55);text-underline-offset:5px}
.ctaband .ctxt p{margin-top:10px;color:rgba(255,255,255,.95);font-size:15px}
.ctaband a{position:relative;z-index:1;flex:none;background:#fff;color:var(--pur-dd);border-radius:999px;padding:16px 40px;font-weight:800;font-size:16.5px;transition:transform .15s,box-shadow .15s}
.ctaband a:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,.16);background:var(--ink);color:#fff}

/* ---------- 서브 히어로 ---------- */
.subhero{position:relative;overflow:clip;padding:52px 0 50px;background:radial-gradient(660px 300px at 86% -20px,rgba(46,197,168,.45),transparent 56%),linear-gradient(125deg,var(--pur) 0%,var(--pur-d) 96%);color:#fff}
.subhero .sgrid2{position:relative;z-index:1;max-width:850px}
.subhero .crumb{font-size:13px;color:rgba(255,255,255,.9);margin-bottom:16px;font-weight:500}
.subhero .crumb a{color:#fff;text-decoration:underline;text-underline-offset:3px;font-weight:600}
.subhero .crumb span{margin:0 7px;color:rgba(255,255,255,.6)}
.subhero .dept{display:inline-block;font-weight:800;font-size:12px;letter-spacing:2.5px;color:var(--pur-dd);margin-bottom:14px;background:#fff;padding:7px 16px;border-radius:999px}
.subhero h2{font-size:clamp(28px,4.5vw,46px);font-weight:800;line-height:1.14;letter-spacing:-1.4px;color:#fff}
.subhero h2 .cc{color:#ffe6a8}
.subhero p{margin:15px 0 0;color:rgba(255,255,255,.93);font-size:15px;max-width:640px}
.subhero .smasc{position:absolute;right:5%;bottom:-6px;z-index:1;width:126px;height:auto;opacity:.97;filter:drop-shadow(0 12px 20px rgba(0,0,0,.14))}

/* ---------- 본문 아티클 ---------- */
.article{padding:54px 22px 72px}
.article .inner{max-width:940px;margin:0 auto}
.article .sec{margin-bottom:50px}
.article h3.h{font-size:23px;font-weight:800;letter-spacing:-.6px;color:var(--ink);display:flex;align-items:center;gap:13px;margin-bottom:15px}
.article h3.h .hn{font-size:13px;font-weight:800;letter-spacing:1px;color:var(--pur-dd);background:var(--pur-soft);border-radius:8px;padding:4px 10px;flex:none}
.article p.t{color:var(--soft);font-size:15.6px;margin-bottom:12px;line-height:1.8}
.article p.t b{color:var(--ink)}
.article p.t a{color:var(--pur-dd);text-decoration:underline;text-underline-offset:3px;font-weight:700}
.article p.t a:hover{color:var(--mint-dd)}
.article .gentable,.article .callout,.article .types{margin-top:22px}
.steps{counter-reset:st;display:grid;gap:0;margin-top:22px;border:1px solid var(--line2);border-radius:var(--r);overflow:hidden;background:var(--paper);box-shadow:var(--shadow)}
.step{padding:22px 24px 22px 76px;position:relative;counter-increment:st;border-top:1px solid var(--line)}
.step:first-child{border-top:0}
.step::before{content:"0" counter(st);position:absolute;left:22px;top:20px;font-size:20px;font-weight:800;color:var(--pur-d);letter-spacing:-1px}
.step h3{font-size:17px;font-weight:800;letter-spacing:-.4px;margin-bottom:4px;color:var(--ink)}
.step p{font-size:14.2px;color:var(--soft)}
.step p b{color:var(--ink)}
.checklist{list-style:none;display:grid;gap:10px;margin-top:18px}
.checklist li{background:var(--paper);border:1px solid var(--line2);border-radius:14px;padding:13px 17px 13px 46px;position:relative;font-size:14.4px;color:var(--soft);box-shadow:var(--shadow)}
.checklist li::before{content:"✓";position:absolute;left:16px;top:12px;color:var(--mint-d);font-weight:800}
.checklist li b{color:var(--ink)}
.pts{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}
.pt{background:var(--paper);border:1px solid var(--line2);border-radius:var(--r);box-shadow:var(--shadow);padding:24px;position:relative;overflow:hidden}
.pt::before{content:"";position:absolute;top:0;left:0;width:100%;height:5px;background:var(--pur)}
.pt:nth-child(2)::before{background:var(--mint)}.pt:nth-child(3)::before{background:var(--amber)}.pt:nth-child(4)::before{background:var(--pur-d)}
.pt .pn{font-size:12.5px;font-weight:800;letter-spacing:1px;color:var(--pur-dd);margin-bottom:10px}
.pt h4{font-size:17.5px;font-weight:800;color:var(--ink);margin-bottom:7px;letter-spacing:-.3px}
.pt p{font-size:13.9px;color:var(--soft);line-height:1.62}
.dx{display:grid;gap:14px;margin-top:24px}
.dxc{border:1px solid var(--line2);border-left-width:5px;border-left-color:var(--pur);border-radius:14px;background:var(--paper);box-shadow:var(--shadow);padding:20px 24px}
.dxc:nth-child(even){border-left-color:var(--mint)}
.dxc h3{font-size:18.5px;font-weight:800;letter-spacing:-.5px;margin-bottom:6px;color:var(--pur-dd)}
.dxc:nth-child(even) h3{color:var(--mint-dd)}
.dxc p{font-size:14.3px;color:var(--soft)}
.dxc p b{color:var(--ink)}

/* ---------- 푸터 ---------- */
footer{background:#2a2342;color:#fff;padding:0 0 36px;margin-top:0}
footer::before{content:"";display:block;height:5px;margin-bottom:44px;background:linear-gradient(90deg,var(--pur),var(--mint),var(--amber))}
.fnotes{background:rgba(255,255,255,.06);border-radius:14px;padding:20px 24px;font-size:12.6px;line-height:1.85;color:rgba(255,255,255,.74)}
.fnotes .strong{font-weight:800;color:var(--pur-soft2);margin-bottom:6px}
.fbot{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-top:26px;flex-wrap:wrap}
.fbrand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:19px;letter-spacing:-.5px;color:#fff}
.fbrand .mark{width:27px;height:27px}.fbrand .mark svg{width:27px;height:27px}
.fcorp{margin-top:8px;font-size:12.4px;color:rgba(255,255,255,.52)}
.flinks{display:flex;gap:18px}
.flinks a{font-size:13.4px;font-weight:700;color:var(--pur-soft2);text-decoration:underline;text-underline-offset:3px}
.flinks a:hover{color:#fff}

/* ---------- 모달 ---------- */
.modal{display:none;position:fixed;inset:0;z-index:120;background:rgba(51,42,82,.55);padding:20px}
.modal.open{display:flex;align-items:center;justify-content:center}
.mbox{background:var(--paper);width:100%;max-width:480px;border-radius:var(--r-lg);box-shadow:0 30px 70px rgba(0,0,0,.4);animation:rise .25s ease;overflow:hidden}
#termsModal .mbox{max-width:760px}
@keyframes rise{from{transform:translateY(18px);opacity:0}to{transform:none;opacity:1}}
.mtop{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:var(--pur-d)}
.mtop h3{font-size:18px;font-weight:800;color:#fff}
.mclose{background:rgba(255,255,255,.22);border:0;width:32px;height:32px;border-radius:50%;font-size:18px;font-weight:900;cursor:pointer;line-height:1;color:#fff}
.mclose:hover{background:#fff;color:var(--pur-dd)}
.mbody{padding:22px 24px;max-height:60vh;overflow-y:auto}
.mbody.nopad{padding:0;max-height:none;overflow:hidden}
.terms-frame{width:100%;height:65vh;border:0;display:block;background:#fff}
.mfoot{display:flex;gap:10px;justify-content:flex-end;padding:14px 22px;border-top:1px solid var(--line);background:var(--bg)}
.mbtn{background:var(--pur-d);color:#fff;border:0;border-radius:14px;padding:12px 24px;font-weight:800;font-size:14.5px;cursor:pointer;transition:background .15s;box-shadow:var(--shadow-pur)}
.mbtn:hover{background:var(--pur-dd)}
.mbtn.ghost{background:var(--paper);color:var(--ink);border:1.5px solid var(--line2);box-shadow:none}
.mbtn.ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.mbtn.full{width:100%}
.smsinfo{font-size:15px;text-align:center;margin-bottom:16px;color:var(--soft)}
.smsinfo b{color:var(--pur-dd)}
.resend{display:block;margin:13px auto 0;background:none;border:0;font-size:13.5px;font-weight:600;color:var(--soft);text-decoration:underline;text-underline-offset:3px;cursor:pointer}
.resend:hover{color:var(--pur-dd)}
.field.mfield{margin-top:18px}
.mfield label{display:block;font-size:13px;font-weight:700;margin-bottom:4px;color:var(--ink)}
.demohint{display:none}

.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- 반응형 ---------- */
@media (max-width:980px){
  nav{display:none}
  header .hbtn{display:none}
  .burger{display:flex}
  .hero{padding:30px 0 38px}
  .herowrap{grid-template-columns:1fr;gap:30px}
  .deck{display:none}
  .match{grid-template-columns:1fr}
  .cgrid{grid-template-columns:1fr 1fr}
  .types{grid-template-columns:1fr}
  .checks{grid-template-columns:1fr}
  .sgrid{grid-template-columns:1fr 1fr;gap:24px 18px}
  .mgrid{grid-template-columns:1fr 1fr}
  .subhero .smasc{display:none}
  .ctaband{flex-direction:column;align-items:flex-start;text-align:left}
}
@media (max-width:600px){
  .frow2{grid-template-columns:1fr}
  .cgrid{grid-template-columns:1fr}
  .sgrid{grid-template-columns:1fr 1fr}
  .mgrid{grid-template-columns:1fr}
  .pts{grid-template-columns:1fr}
  .qcard::before{display:none}
  .gentable table,.gentable tbody,.gentable tr,.gentable td{display:block;width:100%}
  .gentable thead{display:none}
  .gentable tr{border-top:2px solid var(--line2);padding:4px 0}
  .gentable tr:first-child{border-top:0}
  .gentable td{border-top:0;padding:8px 16px}
  .gentable td:first-child{padding-top:14px}
  .gentable td b{display:inline-block;margin-bottom:2px;color:var(--pur-dd)}
  .gentable.gen{overflow-x:auto}
  .gentable.gen table,.gentable.gen tbody,.gentable.gen tr,.gentable.gen thead,.gentable.gen th,.gentable.gen td{display:revert}
  .gentable.gen table{display:table;min-width:560px}
  .gentable.gen td{font-size:13px;padding:10px 12px}
  .gentable.gen td b{display:inline;margin:0;color:var(--ink)}
}
