/* Mission Teeth Dental Clinic — demo rebuild
   Warm clinical noir: near-black charcoal, medical cyan, warm amber.
   Type: Bricolage Grotesque (display) / DM Sans (body) / Newsreader italic (accent) */

:root{
  --bg:#0a0e11;
  --bg-2:#0e151a;
  --panel:#121b21;
  --panel-2:#16222a;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --ink:#eef4f6;
  --muted:#9bacb4;
  --muted-2:#6f8089;
  --cyan:#37d4d0;
  --cyan-deep:#1da7b4;
  --amber:#f6b873;
  --amber-deep:#e89a4d;
  --glow-cyan:rgba(55,212,208,.22);
  --radius:18px;
  --radius-lg:26px;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --font-display:"Bricolage Grotesque",system-ui,sans-serif;
  --font-body:"DM Sans",system-ui,sans-serif;
  --font-serif:"Newsreader",Georgia,serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--cyan);color:#04181a}

/* atmospheric background */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(900px 600px at 78% -8%, rgba(55,212,208,.16), transparent 60%),
    radial-gradient(700px 520px at 8% 12%, rgba(246,184,115,.08), transparent 60%),
    linear-gradient(180deg,#0a0e11,#0a0e11);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
  opacity:.5;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:var(--font-body);
  font-size:.78rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--cyan);display:inline-flex;align-items:center;gap:.55rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--cyan);opacity:.6}
h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:1.02;letter-spacing:-.02em}
.serif{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:0}

/* ---------- nav ---------- */
header.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(10,14,17,.66);
  border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s;
}
header.nav.scrolled{border-bottom-color:var(--line);background:rgba(10,14,17,.85)}
.nav-in{display:flex;align-items:center;justify-content:space-between;min-height:74px;gap:18px}
.brand{display:flex;align-items:center;gap:.65rem;font-family:var(--font-display);font-weight:700;font-size:1.12rem;letter-spacing:-.01em}
.brand .mark{width:34px;height:34px;flex:none}
.brand small{display:block;font-family:var(--font-body);font-weight:500;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);margin-top:1px}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{font-size:.95rem;color:var(--muted);transition:color .2s;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--cyan);transition:width .25s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:.7rem;flex:none}
.nav-cta .btn{padding:.6rem 1.05rem;font-size:.9rem;line-height:1}
.btn{
  font-family:var(--font-body);font-weight:600;font-size:.95rem;
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;line-height:1;white-space:nowrap;
  padding:.72rem 1.25rem;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:transform .2s var(--ease),box-shadow .25s,background .25s,border-color .25s;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--cyan),var(--cyan-deep));color:#04181a;box-shadow:0 10px 30px -8px var(--glow-cyan)}
.btn-primary:hover{box-shadow:0 16px 40px -8px var(--glow-cyan)}
.btn-ghost{border-color:var(--line-2);color:var(--ink);background:rgba(255,255,255,.02)}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan)}
.menu-toggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer;padding:6px}

/* ---------- hero ---------- */
.hero{position:relative;padding:64px 0 88px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.7rem,6vw,4.6rem);margin:1.3rem 0 0}
.hero h1 .serif{color:var(--amber);display:block;font-size:.82em}
.hero p.lead{color:var(--muted);font-size:1.12rem;max-width:46ch;margin:1.5rem 0 0}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.1rem}
.hero-stats{display:flex;gap:1.8rem;margin-top:2.6rem;flex-wrap:wrap}
.stat .n{font-family:var(--font-display);font-weight:700;font-size:1.7rem;line-height:1;color:var(--ink)}
.stat .n b{color:var(--cyan);font-weight:700}
.stat .l{font-size:.82rem;color:var(--muted-2);margin-top:.35rem;letter-spacing:.02em}

/* hero portrait */
.hero-figure{position:relative}
.portrait{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--line-2);
  box-shadow:0 40px 80px -30px rgba(0,0,0,.8);
  aspect-ratio:5/4;
}
.portrait img{width:100%;height:100%;object-fit:cover;object-position:62% 32%;filter:saturate(1.02) contrast(1.02)}
.portrait::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(8,12,14,.78))}
.portrait-cap{
  position:absolute;left:18px;bottom:16px;z-index:2;
}
.portrait-cap .dn{font-family:var(--font-display);font-weight:700;font-size:1.18rem}
.portrait-cap .dr{font-size:.82rem;color:var(--cyan);letter-spacing:.04em}
.hero-badge{
  position:absolute;top:-16px;right:-10px;z-index:3;
  background:var(--panel);border:1px solid var(--line-2);border-radius:16px;
  padding:.7rem 1rem;display:flex;align-items:center;gap:.6rem;
  box-shadow:0 20px 40px -18px rgba(0,0,0,.7);
}
.hero-badge .pulse{width:10px;height:10px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 0 rgba(246,184,115,.6);animation:pulse 2.2s infinite}
.hero-badge span{font-size:.82rem;font-weight:600}
.hero-badge small{display:block;color:var(--muted-2);font-size:.7rem;font-weight:500}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(246,184,115,.55)}70%{box-shadow:0 0 0 12px rgba(246,184,115,0)}100%{box-shadow:0 0 0 0 rgba(246,184,115,0)}}
.hero-glow{position:absolute;inset:-12% -6% -6% -6%;z-index:-1;background:radial-gradient(closest-side,var(--glow-cyan),transparent 72%);filter:blur(8px)}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);overflow:hidden;padding:16px 0}
.marquee-track{display:flex;gap:3.5rem;white-space:nowrap;width:max-content;animation:scroll 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{display:inline-flex;align-items:center;gap:1rem;font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--muted)}
.marquee-track span i{color:var(--cyan);font-style:normal}
.marquee-track .dot{width:6px;height:6px;border-radius:50%;background:var(--amber);opacity:.7}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
section.block{padding:104px 0;position:relative}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head h2{font-size:clamp(2rem,4.2vw,3.1rem);margin-top:1rem}
.sec-head p{color:var(--muted);margin-top:1rem;font-size:1.08rem}

/* about */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-copy .serif{font-size:1.5rem;color:var(--ink);line-height:1.4;display:block;margin-bottom:1.4rem}
.about-copy p{color:var(--muted);margin-bottom:1.1rem}
.about-copy p strong{color:var(--ink);font-weight:600}
.cred-row{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.8rem}
.cred{border:1px solid var(--line);border-radius:14px;padding:.85rem 1.1rem;background:var(--panel);flex:1;min-width:150px}
.cred b{display:block;font-family:var(--font-display);font-size:1.05rem}
.cred span{font-size:.8rem;color:var(--muted-2)}
.about-photo{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line-2);aspect-ratio:4/5;box-shadow:0 40px 80px -34px rgba(0,0,0,.8)}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-quote{position:absolute;left:16px;right:16px;bottom:16px;background:rgba(10,14,17,.72);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:14px;padding:.9rem 1.1rem;font-family:var(--font-serif);font-style:italic;font-size:1rem}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{
  border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);
  padding:30px 26px;position:relative;overflow:hidden;
  transition:transform .3s var(--ease),border-color .3s,background .3s;
}
.svc::before{content:"";position:absolute;inset:0;background:radial-gradient(420px 180px at 80% -20%,rgba(55,212,208,.10),transparent 70%);opacity:0;transition:opacity .3s}
.svc:hover{transform:translateY(-5px);border-color:var(--line-2);background:var(--panel-2)}
.svc:hover::before{opacity:1}
.svc .ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:rgba(55,212,208,.10);border:1px solid rgba(55,212,208,.25);color:var(--cyan);margin-bottom:18px}
.svc h3{font-size:1.28rem;margin-bottom:.55rem}
.svc p{color:var(--muted);font-size:.96rem}
.svc .tag{position:absolute;top:24px;right:24px;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2)}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gal{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:var(--panel)}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);filter:saturate(.96) brightness(.94)}
.gal:hover img{transform:scale(1.06);filter:saturate(1.05) brightness(1)}
.gal::after{content:attr(data-cap);position:absolute;left:14px;bottom:12px;font-size:.78rem;font-weight:600;letter-spacing:.04em;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.8);opacity:0;transform:translateY(6px);transition:.3s}
.gal:hover::after{opacity:1;transform:none}
.gal.tall{grid-row:span 2}
.gal.wide{grid-column:span 2}

/* wall mottos */
.mottos{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.mottos .wrap{padding-top:70px;padding-bottom:70px}
.mottos .lab{text-align:center;color:var(--muted-2);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:34px}
.motto-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.motto{font-family:var(--font-serif);font-style:italic;font-size:1.4rem;line-height:1.4;text-align:center;color:var(--ink);padding:0 1rem;position:relative}
.motto::before{content:"“";color:var(--amber);font-size:2.4rem;font-family:var(--font-serif);display:block;line-height:.6;margin-bottom:.4rem}

/* why / amenities */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.amen{border:1px solid var(--line);border-radius:14px;background:var(--panel);padding:22px;display:flex;gap:.9rem;align-items:flex-start}
.amen svg{flex:none;color:var(--cyan);margin-top:2px}
.amen b{display:block;font-family:var(--font-display);font-size:1.02rem}
.amen span{font-size:.86rem;color:var(--muted)}

/* visit / hours+map */
.visit-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:36px;align-items:stretch}
.hours-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:32px}
.hours-card h3{font-size:1.4rem;margin-bottom:1.2rem}
.hrow{display:flex;justify-content:space-between;padding:.7rem 0;border-bottom:1px solid var(--line);font-size:.98rem}
.hrow:last-of-type{border-bottom:0}
.hrow .d{color:var(--muted)}
.hrow .t{font-weight:600}
.hrow.now{color:var(--cyan)}
.addr{margin-top:1.6rem;padding-top:1.4rem;border-top:1px solid var(--line);font-size:.96rem;color:var(--muted);line-height:1.7}
.addr b{color:var(--ink);font-weight:600}
.map-card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;min-height:360px;background:var(--panel)}
.map-card iframe{width:100%;height:100%;min-height:360px;border:0;filter:grayscale(.3) invert(.92) hue-rotate(170deg) contrast(.9)}

/* contact CTA */
.cta{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line-2);
  background:linear-gradient(135deg,var(--panel-2),var(--panel));padding:64px;margin:0 auto}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 320px at 85% 0%,var(--glow-cyan),transparent 65%)}
.cta-in{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.cta h2{font-size:clamp(2rem,4vw,2.9rem)}
.cta p{color:var(--muted);margin-top:1rem;max-width:42ch}
.cta-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.form{display:grid;gap:14px}
.form input,.form textarea{
  width:100%;background:rgba(0,0,0,.25);border:1px solid var(--line-2);border-radius:12px;
  padding:.9rem 1rem;color:var(--ink);font-family:var(--font-body);font-size:.96rem;transition:border-color .2s
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--cyan)}
.form textarea{min-height:96px;resize:vertical}
.form .hint{font-size:.78rem;color:var(--muted-2)}

/* footer */
footer{border-top:1px solid var(--line);background:var(--bg-2);padding:64px 0 36px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.foot-grid h4{font-family:var(--font-display);font-size:1rem;margin-bottom:1rem;letter-spacing:.02em}
.foot-grid p,.foot-grid a{color:var(--muted);font-size:.93rem;line-height:1.9;display:block}
.foot-grid a:hover{color:var(--cyan)}
.socials{display:flex;gap:.7rem;margin-top:1rem}
.socials a{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:.2s}
.socials a:hover{color:var(--cyan);border-color:var(--cyan);transform:translateY(-2px)}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:var(--muted-2);font-size:.84rem}
.demo-note{background:rgba(246,184,115,.08);border:1px solid rgba(246,184,115,.22);color:var(--amber);border-radius:10px;padding:.5rem .8rem;font-size:.8rem}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-figure{max-width:460px}
  .about-grid,.visit-grid,.cta-in{grid-template-columns:1fr;gap:32px}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .motto-row{grid-template-columns:1fr;gap:32px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .cta{padding:40px}
}
@media(max-width:680px){
  body{font-size:16px}
  .nav-links{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;gap:0;
    background:rgba(10,14,17,.97);border-bottom:1px solid var(--line);
    padding:8px 24px 20px;transform:translateY(-120%);transition:transform .35s var(--ease);
  }
  .nav-links.open{transform:none}
  .nav-links li{width:100%;border-bottom:1px solid var(--line)}
  .nav-links a{display:block;padding:16px 0}
  .nav-links a::after{display:none}
  .menu-toggle{display:block}
  .nav-cta .btn-ghost{display:none}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .gal.wide{grid-column:span 2}
  .svc-grid,.why-grid,.foot-grid{grid-template-columns:1fr}
  section.block{padding:72px 0}
  .hero-stats{gap:1.4rem}
}
