/* Dentfix ad landing pages — focused, fast, conversion-first. Isolated from the main site. */
*{margin:0;padding:0;box-sizing:border-box}
:root{--navy:#15274d;--navy2:#0d1c3a;--royal:#2556d6;--royal2:#1c45b8;--sky:#eef3fc;--ink:#0f1b33;--slate:#5a6a86;--bg2:#f6f9ff;--line:#e5ebf6;--gold:#caa14e;--wa:#0b7a45;--r:16px}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;background:#fff}
h1,h2,h3{font-family:'Sora',sans-serif;font-weight:700;line-height:1.12;letter-spacing:-.02em;color:var(--navy)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1120px;margin:0 auto;padding:0 20px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:700;font-size:1rem;padding:.95em 1.6em;border-radius:100px;cursor:pointer;border:0;font-family:inherit;transition:.25s;white-space:nowrap}
.btn-pri{background:var(--royal);color:#fff}.btn-pri:hover{background:var(--royal2);transform:translateY(-2px)}
.btn-wa{background:var(--wa);color:#fff}.btn-wa:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-block{width:100%}
.btn svg{width:1.15em;height:1.15em;flex:none;fill:currentColor}
/* top bar */
.lp-bar{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.lp-bar .wrap{display:flex;align-items:center;justify-content:space-between;height:62px;gap:1rem}
.lp-bar img{height:34px;width:auto}
.lp-bar .btn{padding:.6em 1.1em;font-size:.9rem}
/* hero */
.lp-hero{background:linear-gradient(160deg,var(--navy),var(--navy2));color:#fff;padding:2.6rem 0 3rem}
.lp-hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:2.4rem;align-items:start}
.lp-eyebrow{color:#9bc0ff;font-weight:700;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase}
.lp-hero h1{color:#fff;font-size:clamp(1.7rem,3.4vw,2.55rem);margin:.5rem 0 .7rem}
.lp-hero h1 em{color:#9bc0ff;font-style:normal}
.lp-hero .sub{color:#cdd9f2;font-size:1.06rem;max-width:32em}
.lp-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem}
.lp-chip{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:100px;padding:.45em .9em;font-size:.82rem;font-weight:600;color:#eaf1ff}
.lp-chip b{color:#ffd98a}
.lp-hero-cta{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.4rem}
/* form card */
.lp-form{background:#fff;color:var(--ink);border-radius:var(--r);padding:1.5rem;box-shadow:0 30px 70px -30px rgba(0,0,0,.5)}
.lp-form h2{font-size:1.2rem;margin-bottom:.25rem}
.lp-form .note{color:var(--slate);font-size:.85rem;margin-bottom:1rem}
.lp-form label{display:block;font-size:.8rem;font-weight:600;color:var(--navy);margin:.6rem 0 .25rem}
.lp-form input,.lp-form select,.lp-form textarea{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:.7em .8em;font-family:inherit;font-size:.95rem;color:var(--ink);background:#fcfdff}
.lp-form input:focus,.lp-form select:focus,.lp-form textarea:focus{outline:0;border-color:var(--royal)}
.lp-form button{margin-top:1rem}
.lp-msg{margin-top:.7rem;font-size:.88rem;font-weight:600;display:none}
.lp-msg.ok{display:block;color:#0b7a45}.lp-msg.err{display:block;color:#c0392b}
.lp-or{text-align:center;color:var(--slate);font-size:.8rem;margin:.8rem 0 .2rem}
/* honeypot (global — inline form + modal) */
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0}
/* trust strip */
.lp-trust{background:var(--bg2);border-bottom:1px solid var(--line);padding:1rem 0}
.lp-trust .wrap{display:flex;flex-wrap:wrap;gap:1.4rem 2.2rem;align-items:center;justify-content:center;text-align:center}
.lp-trust span{font-size:.85rem;font-weight:600;color:var(--navy);display:inline-flex;align-items:center;gap:.4rem}
.lp-trust .g{color:var(--gold)}
/* sections */
section.pad{padding:3rem 0}
.lp-h2{text-align:center;font-size:clamp(1.4rem,2.6vw,1.9rem);margin-bottom:.4rem}
.lp-sec-sub{text-align:center;color:var(--slate);max-width:38em;margin:0 auto 1.8rem}
.lp-benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.lp-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.3rem;box-shadow:0 14px 36px -28px rgba(21,39,77,.5)}
.lp-card .ic{width:42px;height:42px;border-radius:11px;background:var(--sky);color:var(--royal);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:800;margin-bottom:.7rem}
.lp-card h3{font-size:1.02rem;margin-bottom:.3rem}
.lp-card p{font-size:.9rem;color:var(--slate)}
/* gallery */
.lp-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:.9rem}
.lp-gallery img{border-radius:14px;width:100%;height:auto;display:block;border:1px solid var(--line);cursor:zoom-in;background:#fff}
/* lightbox — view the full before/after case */
.lp-lb{position:fixed;inset:0;z-index:1100;display:none;align-items:center;justify-content:center;background:rgba(8,16,36,.88);padding:3vh 3vw;cursor:zoom-out}
.lp-lb.open{display:flex}
.lp-lb img{max-width:100%;max-height:94vh;width:auto;height:auto;border-radius:12px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7)}
.lp-lb-x{position:fixed;top:16px;right:20px;width:42px;height:42px;border:0;background:rgba(255,255,255,.16);color:#fff;border-radius:50%;font-size:1.6rem;line-height:1;cursor:pointer}
/* steps */
.lp-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.lp-step{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r);padding:1.3rem}
.lp-step .n{width:32px;height:32px;border-radius:50%;background:var(--royal);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:.6rem;font-family:'Sora'}
.lp-step h3{font-size:.98rem;margin-bottom:.25rem}
.lp-step p{font-size:.86rem;color:var(--slate)}
/* doctor + price */
.lp-split{background:var(--bg2);border-block:1px solid var(--line)}
.lp-doctor{display:grid;grid-template-columns:200px 1fr;gap:1.6rem;align-items:center}
.lp-doctor img{border-radius:var(--r);aspect-ratio:3/4;object-fit:cover}
.lp-doctor .badge{display:inline-block;background:var(--gold);color:#1c1503;font-weight:700;font-size:.78rem;padding:.3em .7em;border-radius:100px;margin-bottom:.5rem}
.lp-price-box{background:linear-gradient(160deg,var(--navy),var(--navy2));color:#fff;border-radius:var(--r);padding:1.8rem;text-align:center}
.lp-price-box .from{font-size:.85rem;color:#9bc0ff;text-transform:uppercase;letter-spacing:.06em}
.lp-price-box .amt{font-family:'Sora';font-weight:800;font-size:2.4rem;margin:.2rem 0}
.lp-price-box ul{list-style:none;text-align:left;max-width:22em;margin:1rem auto 0}
.lp-price-box li{padding:.35rem 0 .35rem 1.7rem;position:relative;font-size:.92rem;color:#e4ecfb}
.lp-price-box li:before{content:"✓";position:absolute;left:0;color:#7ee0a8;font-weight:800}
/* faq */
.lp-faq{max-width:760px;margin:0 auto}
.lp-fitem{border:1px solid var(--line);border-radius:12px;margin-bottom:.6rem;overflow:hidden;background:#fff}
.lp-fq{padding:1rem 1.1rem;font-weight:700;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;gap:1rem;font-size:.98rem}
.lp-fq:after{content:"+";color:var(--royal);font-weight:800}
.lp-fitem.open .lp-fq:after{content:"–"}
.lp-fa{padding:0 1.1rem;max-height:0;overflow:hidden;transition:.3s;color:var(--slate);font-size:.92rem}
.lp-fitem.open .lp-fa{padding:0 1.1rem 1.1rem;max-height:400px}
/* final cta */
.lp-cta{background:linear-gradient(160deg,var(--royal),var(--royal2));color:#fff;text-align:center}
.lp-cta h2{color:#fff}
.lp-cta p{color:#dbe6ff;max-width:34em;margin:.5rem auto 1.4rem}
.lp-cta .btn-pri{background:#fff;color:var(--royal)}
.lp-cta-row{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
/* footer */
.lp-foot{background:var(--navy2);color:#aebfe0;padding:2rem 0;font-size:.85rem}
.lp-foot .wrap{display:flex;flex-wrap:wrap;gap:1rem 2rem;align-items:center;justify-content:space-between}
.lp-foot a{color:#cdd9f2}
.lp-foot .dis{width:100%;font-size:.78rem;color:#7e90b8;border-top:1px solid rgba(255,255,255,.1);padding-top:1rem;margin-top:.4rem}
/* floating WA */
.wa-fab{position:fixed;right:20px;bottom:20px;z-index:60;width:56px;height:56px;border-radius:50%;background:var(--wa);display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px -8px rgba(11,122,69,.6);transition:.25s}
.wa-fab:hover{transform:scale(1.08)}.wa-fab svg{width:30px;height:30px;fill:#fff}
/* consent */
.lp-consent{position:fixed;left:12px;right:12px;bottom:12px;z-index:90;background:var(--navy2);color:#dbe6ff;border:1px solid rgba(255,255,255,.15);border-radius:14px;padding:.9rem 1.1rem;display:flex;flex-wrap:wrap;gap:.7rem;align-items:center;justify-content:center;font-size:.85rem;box-shadow:0 20px 50px -20px rgba(0,0,0,.6)}
.lp-consent button{border:0;border-radius:8px;padding:.5rem 1.15rem;font-weight:700;cursor:pointer;font-size:.82rem;font-family:inherit}
.lp-consent .lp-acc{background:var(--royal);color:#fff}
.lp-consent .lp-dec{background:transparent;color:#9fb6e6;border:1px solid rgba(255,255,255,.3)}
/* WhatsApp pre-chat modal — captures the lead, then continues to WhatsApp (mirrors main site) */
.lp-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:5vh 1rem 2rem;overflow-y:auto}
.lp-modal.open{display:flex}
.lpm-backdrop{position:fixed;inset:0;background:rgba(10,20,45,.62);backdrop-filter:blur(4px)}
.lpm-dialog{position:relative;z-index:1;width:100%;max-width:460px;background:#fff;border-radius:20px;box-shadow:0 40px 100px -30px rgba(10,20,45,.6);padding:1.6rem 1.4rem 1.7rem;animation:lpmIn .28s cubic-bezier(.22,.61,.36,1)}
@keyframes lpmIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.lpm-x{position:absolute;top:.7rem;right:.8rem;width:36px;height:36px;border:0;background:var(--sky);color:var(--navy);border-radius:50%;font-size:1.4rem;line-height:1;cursor:pointer}
.lpm-x:hover{background:var(--line)}
.lpm-head{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:1rem;padding-right:1.6rem}
.lpm-icon{width:40px;height:40px;flex:none;color:var(--wa)}
.lpm-icon svg{width:40px;height:40px;fill:currentColor}
.lpm-head h3{font-size:1.15rem;margin-bottom:.15rem}
.lpm-head p{font-size:.88rem;color:var(--slate)}
.lpm-form label{display:block;font-size:.8rem;font-weight:600;color:var(--navy);margin:.55rem 0 .25rem}
.lpm-form input,.lpm-form select,.lpm-form textarea{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:.7em .8em;font-family:inherit;font-size:.95rem;background:#fcfdff;color:var(--ink)}
.lpm-form input:focus,.lpm-form select:focus,.lpm-form textarea:focus{outline:0;border-color:var(--royal)}
.lpm-dialog{max-height:92vh;overflow-y:auto}
.lpm-btn{margin-top:1.1rem}
/* message from your dentist + team photo */
.lp-note-sec .wrap{max-width:920px}
.lp-team img{width:100%;height:auto;border-radius:var(--r);box-shadow:0 24px 60px -30px rgba(0,0,0,.5);display:block}
.lp-team figcaption{text-align:center;color:var(--slate);font-size:.82rem;margin-top:.6rem}
.lp-note{margin-top:1.6rem;background:var(--bg2);border:1px solid var(--line);border-left:4px solid var(--royal);border-radius:14px;padding:1.5rem 1.7rem}
.lp-note h2{font-size:1.15rem;color:var(--navy);margin-bottom:.7rem}
.lp-note p{color:var(--slate);line-height:1.75;margin-bottom:.75rem;font-size:.95rem}
.lp-note p:last-child{margin-bottom:0}
/* reveal */
.reveal{opacity:0;transform:translateY(18px);transition:.6s cubic-bezier(.22,.61,.36,1)}
.reveal.in{opacity:1;transform:none}
/* responsive */
@media(max-width:880px){
 .lp-hero-grid{grid-template-columns:1fr;gap:1.6rem}
 .lp-benefits,.lp-steps{grid-template-columns:1fr 1fr}
 .lp-gallery{grid-template-columns:1fr 1fr}
 .lp-doctor{grid-template-columns:1fr;text-align:center}
 .lp-doctor img{max-width:200px;margin:0 auto}
}
@media(max-width:560px){
 .lp-benefits,.lp-steps,.lp-gallery{grid-template-columns:1fr 1fr}
 .lp-bar .btn span{display:none}
 .lp-hero h1{font-size:1.6rem}
}
