@charset "utf-8";
/* 치아보험 비교 (toothsmile.co.kr) — 스마일 팝 / 코럴 + 아쿠아 + 크림 (밝고 친근한 버블 카드) */
:root{
  --ink:#3a2e2e;--ink2:#54433f;
  --coral:#ff6b6b;--coral-d:#f24d4d;--coral-dd:#d12f2f;--coral-soft:#ffe1da;--coral-soft2:#ffc2b6;
  --aqua:#2dd4bf;--aqua-d:#14b8a6;--aqua-dd:#0c8f80;--aqua-soft:#d5f6f1;--aqua-soft2:#a0ebe0;
  --sun:#ffb84d;--sun-d:#f59e0b;--sun-dd:#b9750a;--sun-soft:#fff0d6;
  --soft:#8a7a76;--bg:#fff8f1;--bg2:#fdeee2;--paper:#fffdfa;--line:#f5e6da;--line2:#eed7c7;
  --r:18px;--r-lg:26px;--shadow:0 10px 26px rgba(210,110,90,.10);--shadow-lg:0 24px 54px rgba(210,110,90,.16);
  --shadow-coral:0 14px 30px rgba(255,107,107,.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(255,248,241,.9);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:36px;height:36px}.brand .mark svg{width:36px;height:36px;filter:drop-shadow(0 4px 10px rgba(255,107,107,.4))}
.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(--coral-soft);color:var(--coral-dd)}
nav a.active{color:var(--coral-dd);font-weight:700;background:var(--coral-soft)}
.hbtn{background:var(--coral);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-coral)}
.hbtn:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(255,107,107,.5);background:var(--coral-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(58,46,46,.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(58,46,46,.22)}
.mpanel .x{background:var(--coral-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(--coral-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(--coral-dd)}
.mlink.hl{background:var(--coral);color:#fff;text-align:center;border-radius:999px;margin-top:18px;border-bottom:0;box-shadow:var(--shadow-coral)}

/* ---------- 공통 헤딩 ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:12px;letter-spacing:2.5px;color:var(--coral-dd);text-transform:uppercase}
.eyebrow::before{content:"";width:22px;height:3px;border-radius:2px;background:var(--aqua)}
.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 .co{color:var(--coral-d)}.title .aq{color:var(--aqua-dd)}
.desc{margin-top:13px;color:var(--soft);font-size:15.5px;max-width:640px}
.desc b{color:var(--ink)}
.block{padding:64px 0}
.center{text-align:center}.center .desc{margin-left:auto;margin-right:auto}
.center .eyebrow{justify-content:center}

/* ---------- 히어로 (텍스트 + 치아 일러스트, 폼은 아래 가로바) ---------- */
.hero{position:relative;overflow:clip;background:radial-gradient(720px 360px at 92% -40px,rgba(255,107,107,.16),transparent 56%),radial-gradient(560px 320px at 2% 110%,rgba(45,212,191,.14),transparent 60%),linear-gradient(180deg,#fffdfa,var(--bg));padding:50px 0 44px}
.hero::after{content:"";position:absolute;left:42%;top:26px;width:14px;height:14px;border-radius:50%;background:var(--sun);opacity:.55}
.herowrap{position:relative;z-index:1;display:grid;grid-template-columns:1fr 360px;gap:40px;align-items:center}
.hero-l .badge{display:inline-flex;align-items:center;gap:8px;background:var(--aqua-soft);color:var(--aqua-dd);border-radius:999px;padding:7px 16px;font-weight:800;font-size:12.5px;margin-bottom:18px}
.hero-l h2{font-size:clamp(31px,4.6vw,50px);font-weight:800;line-height:1.13;letter-spacing:-1.8px;color:var(--ink)}
.hero-l h2 .co{color:var(--coral-d)}.hero-l h2 .aq{color:var(--aqua-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:3px;height:13px;background:var(--sun-soft);z-index:-1;border-radius:6px}
.hero-l .lead{margin:18px 0 0;font-size:16.5px;color:var(--soft);max-width:540px}
.hero-l .lead b{color:var(--ink);font-weight:700}
.herotrust{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap}
.htchip{display:flex;align-items:center;gap:9px;background:var(--paper);border:1px solid var(--line2);border-radius:14px;padding:10px 15px;box-shadow:var(--shadow)}
.htchip .ic{width:32px;height:32px;border-radius:50%;background:var(--coral-soft);color:var(--coral-dd);display:grid;place-items:center;font-size:16px;flex:none}
.htchip:nth-child(2) .ic{background:var(--aqua-soft);color:var(--aqua-dd)}
.htchip:nth-child(3) .ic{background:var(--sun-soft);color:var(--sun-dd)}
.htchip b{display:block;font-size:13.5px;font-weight:800;color:var(--ink);letter-spacing:-.3px}
.htchip span{font-size:11px;color:var(--soft)}
.heroart{justify-self:center}
.heroart svg{width:300px;height:auto;display:block;filter:drop-shadow(0 18px 30px rgba(255,107,107,.22))}

/* ---------- 가로 폼바 (전체폭, 한 줄 배치) ---------- */
.formbar{position:relative;z-index:2;margin-top:30px;background:var(--paper);border:1px solid var(--line2);border-top:5px solid var(--coral);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:20px 26px 22px;scroll-margin-top:90px}
.fbtop{display:flex;align-items:center;gap:11px;margin-bottom:15px}
.fbtop h3{font-size:17px;font-weight:800;color:var(--ink);letter-spacing:-.3px}
.fbtop h3 span{color:var(--coral-d)}
.fbtop .free{background:var(--coral);color:#fff;font-size:11px;font-weight:800;padding:4px 12px;border-radius:999px}
.fbtop .hint{margin-left:auto;font-size:12.5px;color:var(--soft);font-weight:600;display:flex;align-items:center;gap:6px}
.fbtop .hint b{color:var(--aqua-dd);font-weight:800}
.fbrow{display:grid;grid-template-columns:1.05fr 1.2fr .95fr 1.45fr auto;gap:13px;align-items:end}
.field{margin:0}
.field label{display:block;font-size:12px;font-weight:700;margin-bottom:6px;color:var(--ink);letter-spacing:-.2px}
.txt{width:100%;height:48px;border:1.5px solid var(--line2);background:#fffaf4;border-radius:13px;padding:0 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(--coral);background:#fff;box-shadow:0 0 0 3px rgba(255,107,107,.16)}
.txt::placeholder{color:#c4ab9e}
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='%233a2e2e' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:28px}
.frow2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.seg{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.seg button{height:48px;border:1.5px solid var(--line2);background:#fffaf4;border-radius:13px;font-size:14.5px;font-weight:700;cursor:pointer;color:var(--soft);transition:all .15s}
.seg button:hover{border-color:var(--coral);color:var(--coral-dd)}
.seg button.on{background:var(--coral);border-color:var(--coral);color:#fff}
.phone-row{display:grid;grid-template-columns:64px 1fr;gap:7px}
.submit{height:48px;background:var(--coral);color:#fff;border:0;border-radius:13px;padding:0 30px;font-size:15.5px;font-weight:800;letter-spacing:-.3px;cursor:pointer;box-shadow:var(--shadow-coral);transition:transform .12s,box-shadow .15s;white-space:nowrap}
.submit:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(255,107,107,.5);background:var(--coral-d)}
.submit:active{transform:translateY(1px)}
.fbfoot{margin-top:13px;display:flex;justify-content:flex-end}
.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(--coral)}
.privacy_label{font-weight:600;color:var(--ink)}
.privacy_view{font-weight:700;color:var(--aqua-dd);text-decoration:underline;text-underline-offset:3px}
.privacy_view:hover{color:var(--coral-dd)}
.err{display:none;background:#fdecec;border:1.5px solid #f3bdbd;border-radius:12px;color:#cf3b3b;font-size:13.5px;font-weight:700;padding:10px 14px;margin:12px 0 0;text-align:center}

/* ---------- 마퀴 ---------- */
.insurers{padding:40px 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(--aqua-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}}

/* ---------- ★ 보장 항목 버블 그리드 ---------- */
.bubgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.bubble{background:var(--paper);border:1px solid var(--line2);border-radius:var(--r-lg);padding:30px 28px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}
.bubble:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.bubble::after{content:"";position:absolute;right:-30px;top:-30px;width:96px;height:96px;border-radius:50%;background:var(--coral-soft);opacity:.55;z-index:0}
.bubble:nth-child(3n-1)::after{background:var(--aqua-soft)}
.bubble:nth-child(3n)::after{background:var(--sun-soft)}
.bubble .bic{position:relative;z-index:1;width:62px;height:62px;border-radius:50%;background:var(--coral);color:#fff;display:grid;place-items:center;font-size:30px;margin-bottom:16px;box-shadow:var(--shadow-coral)}
.bubble:nth-child(3n-1) .bic{background:var(--aqua);box-shadow:0 12px 26px rgba(45,212,191,.34)}
.bubble:nth-child(3n) .bic{background:var(--sun);box-shadow:0 12px 26px rgba(255,184,77,.36)}
.bubble h3{position:relative;z-index:1;font-size:19px;font-weight:800;letter-spacing:-.4px;color:var(--ink);margin-bottom:8px}
.bubble p{position:relative;z-index:1;font-size:14.2px;color:var(--soft);line-height:1.66}
.bubble p b{color:var(--ink)}

/* ---------- 비교 체크포인트 ---------- */
.checkrow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px}
.checkcard{background:var(--paper);border:1px solid var(--line2);border-radius:var(--r);padding:24px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.checkcard .cn{width:44px;height:44px;border-radius:14px;background:var(--coral-soft);color:var(--coral-dd);display:grid;place-items:center;font-size:21px;font-weight:800;margin-bottom:14px}
.checkcard:nth-child(2) .cn{background:var(--aqua-soft);color:var(--aqua-dd)}
.checkcard:nth-child(3) .cn{background:var(--sun-soft);color:var(--sun-dd)}
.checkcard:nth-child(4) .cn{background:var(--coral-soft);color:var(--coral-dd)}
.checkcard h3{font-size:16.5px;font-weight:800;letter-spacing:-.3px;color:var(--ink);margin-bottom:6px}
.checkcard p{font-size:13.6px;color:var(--soft);line-height:1.6}
.checkcard p b{color:var(--ink)}

/* ---------- 숫자 밴드 ---------- */
.statband{background:linear-gradient(125deg,var(--coral),var(--coral-d));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(45,212,191,.30)}
.statband::after{content:"";position:absolute;left:-30px;top:-40px;width:120px;height:120px;border-radius:50%;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,.88);line-height:1.5}

/* ---------- 피처(비대칭) ---------- */
.feature{display:grid;grid-template-columns:1fr 1.18fr;gap:48px;align-items:center}
.fart{background:linear-gradient(155deg,#fffdfa,var(--bg2));border:1px solid var(--line2);border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.fart::after{content:"";position:absolute;right:-44px;top:-44px;width:150px;height:150px;border-radius:50%;background:rgba(45,212,191,.13)}
.fart svg{width:100%;height:auto;display:block;position:relative;z-index:1}
.svc{display:grid;gap:13px}
.svc .svci{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:flex-start;padding:17px 4px;border-bottom:1px solid var(--line)}
.svc .svci:last-child{border-bottom:0}
.svc .svci .num{width:42px;height:42px;border-radius:50%;background:var(--coral);color:#fff;display:grid;place-items:center;font-size:19px;font-weight:800;flex:none;box-shadow:var(--shadow-coral)}
.svc .svci:nth-child(2) .num{background:var(--aqua);box-shadow:0 12px 26px rgba(45,212,191,.32)}
.svc .svci:nth-child(3) .num{background:var(--sun);box-shadow:0 12px 26px rgba(255,184,77,.34)}
.svc .svci h3{font-size:17.5px;font-weight:800;letter-spacing:-.4px;color:var(--ink);margin-bottom:4px}
.svc .svci p{font-size:14px;color:var(--soft);line-height:1.62}

/* ---------- 표 ---------- */
.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(--coral-d)}
.gentable th b{color:var(--coral-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:#fff5ee}
.gentable td.pick{background:var(--aqua-soft);color:var(--ink);font-weight:600}

/* ---------- 콜아웃 ---------- */
.callout{background:var(--coral-soft);border:1px solid var(--coral-soft2);border-radius:var(--r);padding:20px 24px;display:flex;gap:15px;align-items:flex-start;box-shadow:var(--shadow)}
.callout.aq{background:var(--aqua-soft);border-color:var(--aqua-soft2)}
.callout.sn{background:var(--sun-soft);border-color:#ffe0a8}
.callout .ci{flex:none;width:38px;height:38px;border-radius:50%;background:var(--paper);color:var(--coral-dd);display:grid;place-items:center;font-size:19px}
.callout.aq .ci{color:var(--aqua-dd)}.callout.sn .ci{color:var(--sun-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(--coral-dd);text-decoration:underline;text-underline-offset:3px;font-weight:700}

/* ---------- 6 메뉴 카드 ---------- */
.mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.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(--coral-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(--coral-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(--aqua-dd)}.mtile:nth-child(3n) .mno{color:var(--sun-dd)}
.mtile .mcap{padding:18px 22px 20px}
.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:space-between;gap:8px}
.mtile .mcap .go{color:var(--coral-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(--coral);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(--coral-d);font-weight:800;margin-right:9px}
.qa .ar{width:27px;height:27px;border-radius:999px;background:var(--coral-soft);color:var(--coral-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(--coral);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(--coral-dd);text-decoration:underline;text-underline-offset:3px}
.faqmore:hover{color:var(--aqua-dd)}

/* ---------- CTA ---------- */
.ctaband{position:relative;background:linear-gradient(120deg,var(--coral),var(--coral-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(45,212,191,.34)}
.ctaband::after{content:"";position:absolute;left:-30px;bottom:-50px;width:150px;height:150px;border-radius:50%;background:rgba(255,255,255,.13)}
.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,.94);font-size:15px}
.ctaband a{position:relative;z-index:1;flex:none;background:#fff;color:var(--coral-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,.18);background:var(--ink);color:#fff}

/* ---------- 서브 히어로 ---------- */
.subhero{position:relative;overflow:clip;padding:54px 0 52px;background:radial-gradient(680px 300px at 84% -20px,rgba(45,212,191,.45),transparent 56%),linear-gradient(125deg,var(--coral) 0%,var(--coral-d) 96%);color:#fff}
.subhero .sgrid2{position:relative;z-index:1;max-width:840px}
.subhero .crumb{font-size:13px;color:rgba(255,255,255,.85);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,.55)}
.subhero .dept{display:inline-block;font-weight:800;font-size:12px;letter-spacing:2.5px;color:var(--coral-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:#fff5cf}
.subhero p{margin:15px 0 0;color:rgba(255,255,255,.92);font-size:15px;max-width:620px}

/* ---------- 본문 아티클 ---------- */
.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(--coral-dd);background:var(--coral-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(--coral-dd);text-decoration:underline;text-underline-offset:3px;font-weight:700}
.article p.t a:hover{color:var(--aqua-dd)}
.article .gentable{margin-top:22px}
.article .callout{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(--coral-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:13px;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(--aqua-dd);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(--coral)}
.pt:nth-child(2)::before{background:var(--aqua)}.pt:nth-child(3)::before{background:var(--sun)}.pt:nth-child(4)::before{background:var(--coral-d)}
.pt .pn{font-size:12.5px;font-weight:800;letter-spacing:1px;color:var(--coral-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(--coral);border-radius:13px;background:var(--paper);box-shadow:var(--shadow);padding:20px 24px}
.dxc:nth-child(even){border-left-color:var(--aqua)}
.dxc h3{font-size:18.5px;font-weight:800;letter-spacing:-.5px;margin-bottom:6px;color:var(--coral-dd)}
.dxc:nth-child(even) h3{color:var(--aqua-dd)}
.dxc p{font-size:14.3px;color:var(--soft)}
.dxc p b{color:var(--ink)}

/* ---------- 푸터 ---------- */
footer{background:#2b2220;color:#fff;padding:0 0 36px;margin-top:0}
footer::before{content:"";display:block;height:5px;margin-bottom:44px;background:linear-gradient(90deg,var(--coral),var(--aqua))}
.fnotes{background:rgba(255,255,255,.06);border-radius:13px;padding:20px 24px;font-size:12.6px;line-height:1.85;color:rgba(255,255,255,.72)}
.fnotes .strong{font-weight:800;color:var(--coral-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:26px;height:26px}.fbrand .mark svg{width:26px;height:26px}
.fcorp{margin-top:8px;font-size:12.4px;color:rgba(255,255,255,.5)}
.flinks{display:flex;gap:18px}
.flinks a{font-size:13.4px;font-weight:700;color:var(--coral-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(58,46,46,.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(--coral-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(--coral-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(--coral-d);color:#fff;border:0;border-radius:13px;padding:12px 24px;font-weight:800;font-size:14.5px;cursor:pointer;transition:background .15s;box-shadow:var(--shadow-coral)}
.mbtn:hover{background:var(--coral-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(--coral-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(--coral-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 34px}
  .herowrap{grid-template-columns:1fr;gap:20px}
  .heroart{display:none}
  .fbrow{grid-template-columns:1fr 1fr}
  .fbrow .submit{grid-column:1 / -1;width:100%}
  .fbtop .hint{display:none}
  .feature{grid-template-columns:1fr;gap:28px}
  .fart{order:2}
  .bubgrid{grid-template-columns:1fr 1fr}
  .checkrow{grid-template-columns:1fr 1fr}
  .sgrid{grid-template-columns:1fr 1fr;gap:24px 18px}
  .mgrid{grid-template-columns:1fr 1fr}
  .ctaband{flex-direction:column;align-items:flex-start;text-align:left}
}
@media (max-width:600px){
  .frow2{grid-template-columns:1fr}
  .fbrow{grid-template-columns:1fr}
  .bubgrid{grid-template-columns:1fr}
  .checkrow{grid-template-columns:1fr}
  .sgrid{grid-template-columns:1fr 1fr}
  .mgrid{grid-template-columns:1fr}
  .pts{grid-template-columns:1fr}
  .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(--coral-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)}
}
