@charset "utf-8";
/* 치아보험 다이렉트 (dentalsmile.kr) — 베이비 핑크 젤리 / 베이비핑크 + 라벤더 + 크림 (말랑말랑 큐트) */
:root{
  --ink:#4a3340;--ink2:#5e4453;
  --pink:#fb84b6;--pink-d:#f25f9c;--pink-dd:#d23f7c;--pink-soft:#ffe3ef;--pink-soft2:#ffc4dd;
  --lav:#a78bf0;--lav-d:#8b6be0;--lav-dd:#6f4cc4;--lav-soft:#ece4fc;--lav-soft2:#d3c2f5;
  --mint:#54d6bf;--mint-d:#22b9a0;--mint-dd:#0f9684;--mint-soft:#d6f6f0;
  --soft:#8c7682;--bg:#fff5fa;--bg2:#fdeaf3;--paper:#fffdfc;--line:#fbe3ee;--line2:#f3d3e2;
  --r:22px;--r-lg:30px;--shadow:0 12px 28px rgba(242,95,156,.12);--shadow-lg:0 26px 56px rgba(242,95,156,.18);
  --shadow-pink:0 14px 30px rgba(251,132,182,.4);
}
*{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,245,250,.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:37px;height:37px}.brand .mark svg{width:37px;height:37px;filter:drop-shadow(0 4px 10px rgba(251,132,182,.45))}
.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(--pink-soft);color:var(--pink-dd)}
nav a.active{color:var(--pink-dd);font-weight:700;background:var(--pink-soft)}
.hbtn{background:var(--pink);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-pink)}
.hbtn:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(251,132,182,.55);background:var(--pink-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(74,51,64,.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(74,51,64,.22)}
.mpanel .x{background:var(--pink-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(--pink-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(--pink-dd)}
.mlink.hl{background:var(--pink);color:#fff;text-align:center;border-radius:999px;margin-top:18px;border-bottom:0;box-shadow:var(--shadow-pink)}

/* ---------- 공통 헤딩 ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:12px;letter-spacing:2.5px;color:var(--pink-dd);text-transform:uppercase}
.eyebrow::before{content:"";width:22px;height:3px;border-radius:2px;background:var(--lav)}
.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 .pk{color:var(--pink-d)}.title .lv{color:var(--lav-dd)}.title .mt{color:var(--mint-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 5% -40px,rgba(251,132,182,.2),transparent 56%),radial-gradient(620px 340px at 100% 120%,rgba(167,139,240,.16),transparent 60%),linear-gradient(180deg,#fffdfc,var(--bg));padding:52px 0 50px}
.hero::before{content:"";position:absolute;right:8%;top:40px;width:120px;height:120px;border-radius:46% 54% 58% 42%/52% 44% 56% 48%;background:rgba(167,139,240,.12)}
.herowrap{position:relative;z-index:1;display:grid;grid-template-columns:382px 1fr;gap:46px;align-items:center}
.hero-r2{order:2}
.hero-r2 .badge{display:inline-flex;align-items:center;gap:8px;background:var(--lav-soft);color:var(--lav-dd);border-radius:999px;padding:7px 16px;font-weight:800;font-size:12.5px;margin-bottom:17px}
.hero-r2 h2{font-size:clamp(30px,4.4vw,48px);font-weight:800;line-height:1.14;letter-spacing:-1.6px;color:var(--ink)}
.hero-r2 h2 .pk{color:var(--pink-d)}.hero-r2 h2 .lv{color:var(--lav-dd)}
.hero-r2 h2 em{font-style:normal;position:relative;white-space:nowrap}
.hero-r2 h2 em::after{content:"";position:absolute;left:-2px;right:-2px;bottom:2px;height:13px;background:var(--mint-soft);z-index:-1;border-radius:6px}
.hero-r2 .lead{margin:16px 0 0;font-size:16.5px;color:var(--soft);max-width:520px}
.hero-r2 .lead b{color:var(--ink);font-weight:700}
.heromascot{margin-top:22px;display:flex;align-items:flex-end;gap:8px}
.heromascot svg{display:block;filter:drop-shadow(0 14px 22px rgba(251,132,182,.28))}
.heromascot .m1{width:118px;height:auto}
.heromascot .m2{width:78px;height:auto;margin-bottom:6px}
.heromascot .m3{width:62px;height:auto;margin-bottom:2px}

/* ---------- 젤리 폼 카드 (좌측) ---------- */
.qcard{order:1;position:relative;background:var(--paper);border:1px solid var(--line2);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;scroll-margin-top:90px}
.qcard .qtab{background:linear-gradient(120deg,var(--pink),var(--pink-d));color:#fff;padding:17px 24px;display:flex;align-items:center;justify-content:space-between}
.qcard .qtab h3{font-size:17px;font-weight:800;letter-spacing:-.3px}
.qcard .qtab h3 span{color:#fff0bd}
.qcard .qtab .free{background:#fff;color:var(--pink-dd);font-size:11px;font-weight:800;padding:4px 11px;border-radius:999px}
.qcard .qbody{padding:22px 24px 24px}
.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:#fff8fb;border-radius:15px;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(--pink);background:#fff;box-shadow:0 0 0 3px rgba(251,132,182,.18)}
.txt::placeholder{color:#cdaebd}
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='%234a3340' 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:#fff8fb;border-radius:15px;padding:11px 0;font-size:14.5px;font-weight:700;cursor:pointer;color:var(--soft);transition:all .15s}
.seg button:hover{border-color:var(--pink);color:var(--pink-dd)}
.seg button.on{background:var(--pink);border-color:var(--pink);color:#fff}
.phone-row{display:grid;grid-template-columns:70px 1fr;gap:8px}
.submit{width:100%;background:var(--pink);color:#fff;border:0;border-radius:16px;padding:15px 0;font-size:16.5px;font-weight:800;letter-spacing:-.3px;cursor:pointer;box-shadow:var(--shadow-pink);transition:transform .12s,box-shadow .15s;margin-top:6px}
.submit:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(251,132,182,.55);background:var(--pink-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(--pink)}
.privacy_label{font-weight:600;color:var(--ink)}
.privacy_view{font-weight:700;color:var(--lav-dd);text-decoration:underline;text-underline-offset:3px}
.privacy_view:hover{color:var(--pink-dd)}
.err{display:none;background:#fdecf2;border:1.5px solid #f5bcd2;border-radius:14px;color:#cf3b6e;font-size:13.5px;font-weight:700;padding:10px 14px;margin:10px 0 0;text-align:center}

/* ---------- 마퀴 ---------- */
.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(--lav-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}}

/* ---------- 스토리 인트로 (다이렉트란) ---------- */
.story{display:grid;grid-template-columns:1.05fr 1fr;gap:46px;align-items:center}
.story .sart{background:linear-gradient(160deg,#fff,var(--bg2));border:1px solid var(--line2);border-radius:var(--r-lg);padding:34px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;text-align:center}
.story .sart::after{content:"";position:absolute;left:-40px;bottom:-40px;width:150px;height:150px;border-radius:46% 54% 58% 42%/52% 44% 56% 48%;background:rgba(167,139,240,.12)}
.story .sart svg{position:relative;z-index:1;display:block;margin:0 auto}
.story .sart .cap{position:relative;z-index:1;margin-top:14px;font-size:13.5px;font-weight:700;color:var(--lav-dd)}
.storypoints{display:grid;gap:13px;margin-top:20px}
.spt{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:16px 18px;box-shadow:var(--shadow)}
.spt .si{width:44px;height:44px;border-radius:50%;background:var(--pink-soft);color:var(--pink-dd);display:grid;place-items:center;font-size:22px;flex:none}
.spt:nth-child(2) .si{background:var(--lav-soft);color:var(--lav-dd)}
.spt:nth-child(3) .si{background:var(--mint-soft);color:var(--mint-dd)}
.spt h3{font-size:16.5px;font-weight:800;letter-spacing:-.3px;color:var(--ink);margin-bottom:3px}
.spt p{font-size:13.8px;color:var(--soft);line-height:1.6}

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

/* ---------- 다이렉트 장점 (둥근 칩) ---------- */
.adv{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px}
.advcard{background:var(--paper);border:1px solid var(--line2);border-radius:var(--r);padding:24px;box-shadow:var(--shadow);text-align:center}
.advcard .ai{width:54px;height:54px;margin:0 auto 13px;border-radius:50%;background:var(--pink);color:#fff;display:grid;place-items:center;font-size:25px;box-shadow:var(--shadow-pink)}
.advcard:nth-child(2) .ai{background:var(--lav);box-shadow:0 12px 26px rgba(167,139,240,.4)}
.advcard:nth-child(3) .ai{background:var(--mint);box-shadow:0 12px 26px rgba(84,214,191,.4)}
.advcard:nth-child(4) .ai{background:var(--pink-d);box-shadow:var(--shadow-pink)}
.advcard h3{font-size:16.5px;font-weight:800;letter-spacing:-.3px;color:var(--ink);margin-bottom:6px}
.advcard p{font-size:13.6px;color:var(--soft);line-height:1.6}

/* ---------- 가입 전 체크 (말풍선 리스트) ---------- */
.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:20px;padding:20px 22px;box-shadow:var(--shadow);position:relative}
.chk .cn{width:42px;height:42px;border-radius:14px;background:var(--lav-soft);color:var(--lav-dd);display:grid;place-items:center;font-size:20px;font-weight:800;flex:none}
.chk:nth-child(2n) .cn{background:var(--pink-soft);color:var(--pink-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(--pink),var(--lav));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:46% 54% 58% 42%/52% 44% 56% 48%;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,.9);line-height:1.5}

/* ---------- 콜아웃 ---------- */
.callout{background:var(--pink-soft);border:1px solid var(--pink-soft2);border-radius:var(--r);padding:20px 24px;display:flex;gap:15px;align-items:flex-start;box-shadow:var(--shadow)}
.callout.lv{background:var(--lav-soft);border-color:var(--lav-soft2)}
.callout.mt{background:var(--mint-soft);border-color:#b6ecdf}
.callout .ci{flex:none;width:40px;height:40px;border-radius:50%;background:var(--paper);color:var(--pink-dd);display:grid;place-items:center;font-size:20px}
.callout.lv .ci{color:var(--lav-dd)}.callout.mt .ci{color:var(--mint-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(--pink-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(--pink-d)}
.gentable th b{color:var(--pink-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:#fff5fa}
.gentable td.pick{background:var(--lav-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(--pink-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(--pink-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(--lav-dd)}.mtile:nth-child(3n) .mno{color:var(--mint-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(--pink-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(--pink);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(--pink-d);font-weight:800;margin-right:9px}
.qa .ar{width:27px;height:27px;border-radius:999px;background:var(--pink-soft);color:var(--pink-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(--pink);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(--pink-dd);text-decoration:underline;text-underline-offset:3px}
.faqmore:hover{color:var(--lav-dd)}

/* ---------- CTA ---------- */
.ctaband{position:relative;background:linear-gradient(120deg,var(--pink),var(--lav));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,.18)}
.ctaband::after{content:"";position:absolute;left:-30px;bottom:-50px;width:150px;height:150px;border-radius:46% 54% 58% 42%/52% 44% 56% 48%;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,.95);font-size:15px}
.ctaband a{position:relative;z-index:1;flex:none;background:#fff;color:var(--pink-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(167,139,240,.5),transparent 56%),linear-gradient(125deg,var(--pink) 0%,var(--pink-d) 96%);color:#fff}
.subhero .sgrid2{position:relative;z-index:1;max-width:850px}
.subhero .crumb{font-size:13px;color:rgba(255,255,255,.88);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(--pink-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:#fff0bd}
.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:128px;height:auto;opacity:.96;filter:drop-shadow(0 12px 20px rgba(0,0,0,.12))}

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

/* ---------- 푸터 ---------- */
footer{background:#3a2a33;color:#fff;padding:0 0 36px;margin-top:0}
footer::before{content:"";display:block;height:5px;margin-bottom:44px;background:linear-gradient(90deg,var(--pink),var(--lav))}
.fnotes{background:rgba(255,255,255,.06);border-radius:15px;padding:20px 24px;font-size:12.6px;line-height:1.85;color:rgba(255,255,255,.74)}
.fnotes .strong{font-weight:800;color:var(--pink-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(--pink-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(74,51,64,.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(--pink-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(--pink-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(--pink-d);color:#fff;border:0;border-radius:15px;padding:12px 24px;font-weight:800;font-size:14.5px;cursor:pointer;transition:background .15s;box-shadow:var(--shadow-pink)}
.mbtn:hover{background:var(--pink-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(--pink-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(--pink-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 36px}
  .herowrap{grid-template-columns:1fr;gap:24px}
  .qcard{order:2}
  .hero-r2{order:1}
  .heromascot{display:none}
  .story{grid-template-columns:1fr;gap:26px}
  .story .sart{order:2}
  .toothgrid{grid-template-columns:1fr 1fr}
  .adv{grid-template-columns:1fr 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}
  .toothgrid{grid-template-columns:1fr}
  .adv{grid-template-columns:1fr 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(--pink-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)}
}
