/* Bedside Dental — design system. Palette carried from the proven HVD sites. */
:root{
  --navy:#15324F; --navy-d:#0F2540; --blue:#0B5AA6; --blue-2:#046BD2;
  --green:#1FAA52; --green-d:#17853f; --tint:#F0F6FC; --tint-2:#EAF2FB;
  --line:#D6E4F5; --ink:#1A2733; --mut:#59708A; --bg:#fff; --amber:#FFF3CD;
  --radius:12px; --wrap:1140px; --shadow:0 6px 24px rgba(15,37,64,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font:400 17px/1.65 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
h1,h2,h3{color:var(--navy);line-height:1.2;margin:.2em 0 .4em;font-weight:800}
h1{font-size:2.15rem} h2{font-size:1.6rem} h3{font-size:1.2rem}
p{margin:.5em 0 1em}
a{color:var(--blue);text-decoration:none} a:hover{text-decoration:underline}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.muted{color:var(--mut)} .center{text-align:center}
img{max-width:100%;height:auto}
section{padding:56px 0}
.skip{position:absolute;left:-999px} .skip:focus{left:8px;top:8px;background:#fff;padding:8px;z-index:100}

/* buttons */
.btn{display:inline-block;padding:14px 22px;border-radius:10px;font-weight:700;font-size:1.02rem;cursor:pointer;border:2px solid transparent;transition:.15s;text-align:center}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--green);color:#fff} .btn-primary:hover{background:var(--green-d);color:#fff}
.btn-ghost{background:#fff;color:var(--blue);border-color:var(--line)} .btn-ghost:hover{border-color:var(--blue)}
.btn-call{background:var(--navy);color:#fff} .btn-call:hover{background:var(--navy-d);color:#fff}
.btn-lg{padding:16px 28px;font-size:1.1rem}
.cta-sub{font-size:.9rem;color:var(--mut);margin:.4rem 0 0}

/* header */
.hdr{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;gap:18px;height:72px}
.logo{font-weight:800;font-size:1.35rem;color:var(--navy);white-space:nowrap;letter-spacing:-.02em}
.logo span{color:var(--green)}
.logo small{display:block;font-size:.62rem;font-weight:600;color:var(--mut);letter-spacing:.02em;margin-top:-2px}
.nav{display:flex;align-items:center;gap:2px;margin-left:8px}
.nav > li{list-style:none;position:relative}
.nav > li > a{display:block;padding:12px 12px;color:var(--navy);font-weight:600;font-size:.98rem;border-radius:8px}
.nav > li > a:hover{background:var(--tint);text-decoration:none}
.nav .caret::after{content:"▾";font-size:.7em;margin-left:5px;color:var(--mut)}
.mega{position:absolute;top:100%;left:0;min-width:250px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);transition:.15s}
.nav > li:hover .mega,.nav > li:focus-within .mega{opacity:1;visibility:visible;transform:translateY(0)}
.mega a{display:block;padding:9px 12px;border-radius:8px;color:var(--ink);font-size:.95rem}
.mega a:hover{background:var(--tint);text-decoration:none}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.city-chip{display:inline-flex;align-items:center;gap:6px;padding:9px 12px;border:1px solid var(--line);border-radius:999px;font-weight:600;color:var(--navy);font-size:.92rem;background:#fff;cursor:pointer;position:relative}
.city-chip .menu{position:absolute;top:110%;right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:8px;min-width:180px;opacity:0;visibility:hidden;transition:.15s;z-index:60}
.city-chip:hover .menu,.city-chip:focus-within .menu{opacity:1;visibility:visible}
.city-chip .menu a{display:block;padding:8px 12px;border-radius:8px;color:var(--ink)} .city-chip .menu a:hover{background:var(--tint);text-decoration:none}
.hdr-phone{font-weight:800;color:var(--navy);white-space:nowrap} .hdr-phone:hover{text-decoration:none;color:var(--blue)}
.hamb{display:none;font-size:1.6rem;background:none;border:0;color:var(--navy);cursor:pointer}

/* hero */
.hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-d) 60%,#0b1f38 100%);color:#fff;position:relative;overflow:hidden}
.hero.has-img{background-size:cover;background-position:center 35%}
.hero .veil{position:absolute;inset:0;background:linear-gradient(120deg,rgba(15,37,64,.92),rgba(15,37,64,.62))}
.hero-in{position:relative;padding:60px 0}
.hero h1{color:#fff;max-width:20ch}
.hero-in{padding:64px 0}
.hero p.sub{font-size:1.2rem;color:#dbe8f7;max-width:52ch}
.hero .btns{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px;align-items:center}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;padding:7px 13px;border-radius:999px;font-size:.86rem;font-weight:600}

/* trust bar */
.trust{background:var(--tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust ul{display:flex;flex-wrap:wrap;gap:8px 26px;list-style:none;margin:0;padding:16px 0;justify-content:center}
.trust li{font-weight:600;color:var(--navy);font-size:.95rem}
.trust li::before{content:"✓";color:var(--green);font-weight:800;margin-right:8px}

/* grids & cards */
.grid{display:grid;gap:18px}
.g2{grid-template-columns:repeat(2,1fr)} .g3{grid-template-columns:repeat(3,1fr)} .g4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;transition:.15s}
.card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.card h3{margin-top:0}
.card .ico{font-size:1.7rem;margin-bottom:6px}
.card.tint{background:var(--tint)}
.area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.area-grid a{display:block;padding:12px 14px;background:var(--tint);border:1px solid var(--line);border-radius:10px;color:var(--navy);font-weight:600;font-size:.95rem}
.area-grid a:hover{background:var(--tint-2);text-decoration:none;border-color:var(--blue)}
.lead{font-size:1.15rem;color:#33465a}
ul.ticks{list-style:none;padding:0} ul.ticks li{padding:6px 0 6px 30px;position:relative}
ul.ticks li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:800}
.pricebox{display:inline-flex;gap:10px;align-items:baseline;background:var(--tint);border:1px solid var(--line);border-radius:12px;padding:14px 20px}
.pricebox b{font-size:1.6rem;color:var(--navy)}
.callbanner{background:var(--amber);border:1px solid #e4c86b;border-radius:12px;padding:16px 20px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.faq{border:1px solid var(--line);border-radius:12px;padding:6px 18px;margin:10px 0}
.faq summary{font-weight:700;color:var(--navy);cursor:pointer;padding:12px 0}
.crumbs{font-size:.85rem;color:var(--mut);padding:14px 0 0}
.crumbs a{color:var(--mut)} .section-tint{background:var(--tint)}

/* footer */
.ft{background:var(--navy);color:#c9d8ea;margin-top:20px}
.ft a{color:#c9d8ea} .ft a:hover{color:#fff}
.ft-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.4fr;gap:26px;padding:44px 0 28px}
.ft h4{color:#fff;font-size:.95rem;margin:0 0 12px;letter-spacing:.02em}
.ft ul{list-style:none;padding:0;margin:0} .ft li{padding:5px 0;font-size:.94rem}
.ft .badges{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.ft .badge{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:8px 10px;font-size:.78rem;color:#fff;font-weight:600}
.ft-bar{border-top:1px solid rgba(255,255,255,.15);padding:16px 0;font-size:.82rem;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

/* sticky mobile call bar */
.mbar{position:fixed;bottom:0;left:0;right:0;z-index:70;display:none;gap:8px;padding:8px;background:#fff;border-top:1px solid var(--line);box-shadow:0 -4px 18px rgba(15,37,64,.12)}
.mbar a{flex:1}

/* responsive */
@media(max-width:900px){
  .g4{grid-template-columns:repeat(2,1fr)} .g3{grid-template-columns:1fr} .g2{grid-template-columns:1fr}
  .ft-grid{grid-template-columns:1fr 1fr}
  .nav,.hdr-phone{display:none}
  .hamb{display:block;margin-left:auto}
  .hero-in{padding:40px 0}
  h1{font-size:1.8rem}
  .mbar{display:flex}
  body{padding-bottom:70px}
}
@media(max-width:560px){.ft-grid{grid-template-columns:1fr}}
/* mobile nav (toggled) */
.mnav{display:none;border-top:1px solid var(--line);background:#fff}
.mnav.open{display:block}
.mnav a{display:block;padding:13px 20px;border-bottom:1px solid var(--tint);color:var(--navy);font-weight:600}

/* header polish */
.city-chip{white-space:nowrap}
.hdr .btn-primary{white-space:nowrap}
.nav>li>a{padding:12px 10px;font-size:.95rem}
.hdr-in{gap:14px}
@media(max-width:1240px){.hdr-phone{display:none}}

/* header fit (v4) — give the bar room + stop right-side items shrinking */
header.hdr .wrap{max-width:1340px}
.hdr-in{gap:10px}
.logo{flex:0 0 auto}
.nav>li>a{padding:11px 8px;font-size:.92rem}
.hdr-right{gap:10px}
.city-chip{white-space:nowrap;flex:0 0 auto}
.hdr .btn-primary{white-space:nowrap;flex:0 0 auto}
.hdr-phone{flex:0 0 auto}
@media(max-width:1300px){.hdr-phone{display:none}}
@media(max-width:1120px){.nav>li>a{padding:10px 6px;font-size:.88rem}}

/* privacy notice */
.bsd-notice{position:fixed;left:12px;right:12px;bottom:12px;z-index:80;max-width:760px;margin:0 auto;background:var(--navy);color:#e6eef8;border-radius:12px;box-shadow:0 8px 30px rgba(15,37,64,.28);padding:12px 16px;display:flex;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap;font-size:.9rem}
.bsd-notice a{color:#8fc0e8}
.bsd-notice button{background:var(--green);color:#fff;border:0;border-radius:8px;padding:9px 16px;font-weight:700;cursor:pointer;white-space:nowrap}
.bsd-notice button:hover{background:var(--green-d)}
@media(max-width:560px){.bsd-notice{bottom:70px}}
