/*
 * Pacific East Dental Care — styles
 * Plain CSS (no preprocessor). Structure: design tokens in :root,
 * then components, page sections, and responsive breakpoints.
 */

  :root{
    --bone:#FBFAF6;
    --ink:#16302E;
    --ink-soft:#3F5957;
    --pacific:#0F4C5C;
    --pacific-deep:#0A3A45;
    --tide:#2E8A93;
    --seafoam:#E9F2EF;
    --seafoam-2:#DCEBE5;
    --sun:#E0A458;
    --sun-deep:#C2812F;
    --line:rgba(15,76,92,.14);
    --shadow:0 18px 50px -22px rgba(10,58,69,.4);
    --shadow-sm:0 8px 26px -16px rgba(10,58,69,.45);
    --r:18px;
  }

  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0;
    font-family:"Inter",system-ui,sans-serif;
    color:var(--ink);
    background:var(--bone);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:500;line-height:1.08;letter-spacing:-.01em;margin:0;}
  p{margin:0;}
  a{color:inherit;text-decoration:none;}
  img,svg{display:block;max-width:100%;}
  .wrap{width:min(1140px,92vw);margin-inline:auto;}

  /* Buttons */
  .btn{
    display:inline-flex;align-items:center;justify-content:center;gap:.5em;
    font-family:"Inter";font-weight:600;font-size:.96rem;
    padding:.85em 1.4em;border-radius:999px;cursor:pointer;border:1px solid transparent;
    transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
    white-space:nowrap;
  }
  .btn-sun{background:var(--sun);color:#3a2a10;box-shadow:var(--shadow-sm);}
  .btn-sun:hover{background:var(--sun-deep);color:#fff;transform:translateY(-2px);}
  .btn-pacific{background:var(--pacific);color:#fff;}
  .btn-pacific:hover{background:var(--pacific-deep);transform:translateY(-2px);}
  .btn-ghost{background:transparent;color:var(--pacific);border-color:var(--line);}
  .btn-ghost:hover{border-color:var(--pacific);background:rgba(15,76,92,.04);}

  /* Header */
  header{position:sticky;top:0;z-index:60;background:rgba(251,250,246,.82);backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:border-color .25s, box-shadow .25s;}
  header.scrolled{border-color:var(--line);box-shadow:0 6px 24px -20px rgba(10,58,69,.6);}
  .nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:.8rem 0;}
  .brand{display:flex;align-items:center;gap:.65rem;font-family:"Fraunces";font-weight:600;font-size:1.16rem;color:var(--pacific);letter-spacing:-.01em;line-height:1.1;}
  .brand small{display:block;font-family:"Inter";font-weight:500;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--tide);}
  .mark{flex:0 0 auto;}
  .nav-links{display:flex;align-items:center;gap:1.7rem;font-weight:500;font-size:.95rem;}
  .nav-links a{color:var(--ink-soft);position:relative;padding:.2rem 0;}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--sun);transition:width .25s ease;}
  .nav-links a:hover{color:var(--ink);}
  .nav-links a:hover::after{width:100%;}
  .nav-cta{display:flex;align-items:center;gap:1rem;}
  .nav-phone{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--pacific);font-size:.95rem;}
  .burger{display:none;background:none;border:none;cursor:pointer;padding:.4rem;color:var(--pacific);}

  /* Hero */
  .hero{position:relative;overflow:hidden;padding:clamp(2.5rem,6vw,5.5rem) 0 clamp(3rem,7vw,6rem);}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center;}
  .eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--tide);margin-bottom:1.3rem;}
  .eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--sun);}
  .hero h1{font-size:clamp(2.5rem,5.6vw,4.1rem);}
  .hero h1 em{font-style:italic;color:var(--tide);}
  .hero .lede{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--ink-soft);max-width:34ch;margin-top:1.4rem;}
  .hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem;}
  .hero-trust{display:flex;flex-wrap:wrap;gap:1.4rem 2rem;margin-top:2.6rem;padding-top:1.8rem;border-top:1px solid var(--line);}
  .hero-trust div{display:flex;align-items:center;gap:.55rem;font-size:.9rem;font-weight:500;color:var(--ink-soft);}
  .hero-trust svg{color:var(--tide);flex:0 0 auto;}

  /* hero art panel */
  .scene{position:relative;border-radius:26px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:5/5.6;background:linear-gradient(180deg,#FBEFD9 0%, #EFE3D0 24%, var(--seafoam) 60%, var(--seafoam-2) 100%);}
  .scene svg{position:absolute;inset:0;width:100%;height:100%;}
  .float-card{position:absolute;left:1.1rem;bottom:1.1rem;right:1.1rem;background:rgba(251,250,246,.94);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:14px;padding:.85rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;box-shadow:var(--shadow-sm);}
  .float-card .hrs{font-size:.82rem;color:var(--ink-soft);}
  .float-card .hrs b{display:block;font-family:"Fraunces";font-size:1.02rem;color:var(--ink);font-weight:600;}
  .open-pill{display:inline-flex;align-items:center;gap:.45rem;font-size:.78rem;font-weight:600;color:#1f6b4a;background:#dff1e6;border:1px solid #bfe3cd;padding:.35rem .7rem;border-radius:999px;}
  .open-pill .ping{width:8px;height:8px;border-radius:50%;background:#27a567;box-shadow:0 0 0 0 rgba(39,165,103,.5);animation:ping 2.2s infinite;}
  @keyframes ping{0%{box-shadow:0 0 0 0 rgba(39,165,103,.5);}70%{box-shadow:0 0 0 8px rgba(39,165,103,0);}100%{box-shadow:0 0 0 0 rgba(39,165,103,0);}}
  .est-badge{position:absolute;top:1rem;right:1rem;background:var(--pacific);color:#fff;border-radius:14px;padding:.6rem .8rem;text-align:center;box-shadow:var(--shadow-sm);}
  .est-badge b{display:block;font-family:"Fraunces";font-size:1.4rem;font-weight:600;line-height:1;}
  .est-badge span{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;opacity:.85;}

  /* Tide divider */
  .tide{display:block;width:100%;height:48px;color:var(--seafoam);}
  .tide.flip{transform:scaleY(-1);}

  /* Section base */
  section{padding:clamp(3.2rem,6vw,5.5rem) 0;}
  .sec-head{max-width:60ch;margin-bottom:2.8rem;}
  .sec-eyebrow{font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--tide);margin-bottom:.9rem;}
  .sec-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem);}
  .sec-head p{color:var(--ink-soft);margin-top:1rem;font-size:1.05rem;}

  .band{background:var(--seafoam);}

  /* trust strip */
  .strip{background:var(--pacific);color:#fff;}
  .strip .wrap{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.4rem;padding:1.5rem 0;}
  .strip .item{display:flex;align-items:center;gap:.7rem;font-weight:500;font-size:.98rem;}
  .strip .item svg{color:var(--sun);flex:0 0 auto;}

  /* services */
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;}
  .card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.7rem 1.5rem;transition:transform .22s ease,box-shadow .22s ease,border-color .22s;}
  .card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent;}
  .card .ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--seafoam);color:var(--pacific);margin-bottom:1.1rem;}
  .card h3{font-size:1.25rem;}
  .card p{color:var(--ink-soft);font-size:.96rem;margin-top:.5rem;}

  /* about + steps */
  .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;}
  .values{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:2rem;}
  .value h3{font-family:"Inter";font-weight:700;font-size:1rem;display:flex;align-items:center;gap:.5rem;}
  .value p{color:var(--ink-soft);font-size:.94rem;margin-top:.3rem;}
  .value .tick{color:var(--tide);}
  .about-portrait{background:linear-gradient(165deg,var(--seafoam),var(--seafoam-2));border-radius:24px;padding:2.4rem;position:relative;overflow:hidden;}
  .about-portrait::after{content:"";position:absolute;right:-40px;bottom:-50px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(224,164,88,.22),transparent 70%);pointer-events:none;}
  .motto-eyebrow{font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--tide);margin-bottom:1rem;}
  .motto{font-family:"Fraunces";font-weight:500;font-size:clamp(2.4rem,5vw,3.1rem);line-height:1.02;color:var(--pacific-deep);letter-spacing:-.015em;}
  .motto em{font-style:italic;color:var(--sun-deep);}
  .motto-sub{margin-top:1rem;color:var(--ink-soft);font-size:1.02rem;max-width:30ch;}
  .motto-rule{height:1px;background:var(--line);margin:1.7rem 0 1.4rem;}
  .quote{font-family:"Fraunces";font-size:1.12rem;line-height:1.4;color:var(--pacific-deep);font-weight:400;font-style:italic;position:relative;}
  .quote-by{margin-top:1rem;font-size:.85rem;color:var(--ink-soft);font-weight:500;}
  .quote-by b{color:var(--ink);display:block;font-size:.95rem;}

  /* dentists */
  .team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;}
  .doc-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2.2rem 1.6rem;text-align:center;transition:transform .22s ease,box-shadow .22s ease,border-color .22s;}
  .doc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent;}
  .doc-av{width:94px;height:94px;border-radius:50%;margin:0 auto 1.3rem;display:grid;place-items:center;background:linear-gradient(160deg,var(--tide),var(--pacific));color:var(--bone);font-family:"Fraunces",serif;font-weight:600;font-size:2rem;letter-spacing:.02em;border:2px solid var(--sun);box-shadow:0 0 0 5px var(--seafoam);}
  .doc-name{font-family:"Fraunces",serif;font-weight:600;font-size:1.32rem;color:var(--ink);}
  .doc-role{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--tide);font-weight:600;margin-top:.4rem;}
  .doc-bio{color:var(--ink-soft);font-size:.95rem;margin-top:1rem;}
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;counter-reset:step;}
  .step{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.6rem;position:relative;}
  .step .num{font-family:"Fraunces";font-size:.95rem;font-weight:600;color:var(--sun-deep);letter-spacing:.05em;}
  .step h3{font-size:1.2rem;margin-top:.5rem;}
  .step p{color:var(--ink-soft);font-size:.95rem;margin-top:.4rem;}

  /* Appointment */
  #appointment{background:var(--pacific);color:#fff;position:relative;overflow:hidden;}
  #appointment .sec-eyebrow{color:var(--sun);}
  #appointment .deco{position:absolute;inset:0;opacity:.5;pointer-events:none;}
  .appt-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,3.5rem);align-items:start;position:relative;}
  .appt-info h2{font-size:clamp(1.9rem,3.6vw,2.7rem);color:#fff;}
  .appt-info > p{color:rgba(255,255,255,.82);margin-top:1rem;font-size:1.05rem;max-width:36ch;}
  .info-list{margin-top:2rem;display:flex;flex-direction:column;gap:1.2rem;}
  .info-row{display:flex;gap:.9rem;align-items:flex-start;}
  .info-row .ico{flex:0 0 auto;width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.1);display:grid;place-items:center;color:var(--sun);}
  .info-row .lbl{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6);}
  .info-row .val{font-weight:600;font-size:1.02rem;}
  .info-row .val a:hover{color:var(--sun);}
  .info-row .val span{display:block;font-weight:400;font-size:.9rem;color:rgba(255,255,255,.7);}
  .emergency{margin-top:1.8rem;font-size:.85rem;color:rgba(255,255,255,.7);border-top:1px solid rgba(255,255,255,.18);padding-top:1.2rem;}
  .amenities{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem;}
  .amenity{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:500;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:.4rem .75rem;}
  .amenity svg{color:var(--sun);flex:0 0 auto;}

  /* form card */
  .form-card{background:var(--bone);color:var(--ink);border-radius:24px;padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow);}
  .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;}
  .field{display:flex;flex-direction:column;gap:.4rem;}
  .field.full{grid-column:1 / -1;}
  .field label{font-size:.84rem;font-weight:600;color:var(--ink);}
  .field label .req{color:#c2410c;}
  .field input,.field select,.field textarea{
    font-family:"Inter";font-size:.97rem;color:var(--ink);background:#fff;
    border:1px solid var(--line);border-radius:11px;padding:.72rem .85rem;width:100%;
    transition:border-color .18s, box-shadow .18s;
  }
  .field textarea{resize:vertical;min-height:96px;}
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--tide);box-shadow:0 0 0 3px rgba(46,138,147,.18);}
  .field.error input,.field.error select,.field.error textarea{border-color:#d9534f;box-shadow:0 0 0 3px rgba(217,83,79,.12);}
  .err-msg{font-size:.78rem;color:#c0392b;min-height:0;display:none;}
  .field.error .err-msg{display:block;}
  .consent{display:flex;gap:.65rem;align-items:flex-start;font-size:.86rem;color:var(--ink-soft);grid-column:1/-1;}
  .privacy-note{display:flex;gap:.6rem;align-items:flex-start;font-size:.84rem;line-height:1.5;color:var(--ink-soft);background:var(--seafoam);border:1px solid var(--line);border-radius:12px;padding:.8rem .9rem;margin:0;}
  .privacy-note svg{color:var(--tide);flex:0 0 auto;margin-top:.15rem;}
  .choice-group{display:flex;gap:.6rem;flex-wrap:wrap;}
  .choice{flex:1 1 0;min-width:120px;cursor:pointer;}
  .choice input{position:absolute;opacity:0;width:0;height:0;}
  .choice span{display:flex;align-items:center;justify-content:center;gap:.45rem;font-size:.92rem;font-weight:500;color:var(--ink-soft);background:#fff;border:1px solid var(--line);border-radius:11px;padding:.7rem .6rem;transition:border-color .18s,background .18s,color .18s,box-shadow .18s;}
  .choice span svg{color:var(--tide);}
  .choice:hover span{border-color:var(--tide);}
  .choice input:checked + span{background:var(--pacific);color:#fff;border-color:var(--pacific);box-shadow:var(--shadow-sm);}
  .choice input:checked + span svg{color:var(--sun);}
  .choice input:focus-visible + span{outline:2px solid var(--tide);outline-offset:2px;}
  .consent input{width:auto;margin-top:.25rem;accent-color:var(--pacific);}
  .form-submit{grid-column:1/-1;display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-top:.4rem;}
  .form-note{font-size:.82rem;color:var(--ink-soft);}

  .form-success{display:none;text-align:center;padding:1.5rem 1rem;}
  .form-success.show{display:block;animation:rise .5s ease;}

  /* secure Open Dental booking hand-off card */
  .book-card{display:flex;flex-direction:column;align-items:flex-start;}
  .book-secure{display:inline-flex;align-items:center;gap:.45rem;font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--tide);margin-bottom:1rem;}
  .book-title{font-size:clamp(1.6rem,3vw,2rem);color:var(--pacific);}
  .book-lede{color:var(--ink-soft);margin-top:.8rem;font-size:1.02rem;}
  .book-list{list-style:none;padding:0;margin:1.5rem 0 .4rem;display:flex;flex-direction:column;gap:.7rem;width:100%;}
  .book-list li{display:flex;align-items:flex-start;gap:.6rem;font-size:.96rem;color:var(--ink);}
  .book-list li svg{color:var(--tide);flex:0 0 auto;margin-top:.15rem;}
  .book-btn{margin-top:1.6rem;font-size:1.02rem;padding:1em 1.7em;}
  .book-setup{font-size:.9rem;color:var(--ink-soft);margin-top:1rem;}
  .book-setup a{color:var(--pacific);font-weight:600;text-decoration:underline;}
  .book-call{margin-top:1.1rem;font-size:.95rem;color:var(--ink-soft);}
  .book-call strong{color:var(--pacific);}
  .book-call:hover strong{color:var(--tide);}
  .book-trust{display:flex;align-items:flex-start;gap:.5rem;font-size:.8rem;line-height:1.5;color:var(--ink-soft);margin-top:1.5rem;padding-top:1.2rem;border-top:1px solid var(--line);width:100%;}
  .book-trust svg{color:var(--tide);flex:0 0 auto;margin-top:.15rem;}
  .form-success .check{width:64px;height:64px;border-radius:50%;background:#dff1e6;color:#1f6b4a;display:grid;place-items:center;margin:0 auto 1.2rem;}
  .form-success h3{font-size:1.6rem;color:var(--pacific);}
  .form-success p{color:var(--ink-soft);margin-top:.6rem;max-width:38ch;margin-inline:auto;}
  @keyframes rise{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}

  /* footer */
  footer{background:var(--pacific-deep);color:rgba(255,255,255,.78);padding:3.5rem 0 2rem;}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;}
  .foot-brand-row{display:flex;align-items:center;gap:.8rem;}
  .foot-brand{font-family:"Fraunces";font-size:1.4rem;color:#fff;font-weight:600;line-height:1.1;}
  .foot-brand small{display:block;font-family:"Inter";font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sun);margin-top:.2rem;}
  footer p{font-size:.92rem;margin-top:1rem;max-width:34ch;}
  .foot-col h4{font-family:"Inter";font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);margin:0 0 1rem;}
  .foot-col a,.foot-col span{display:block;font-size:.95rem;margin-bottom:.6rem;color:rgba(255,255,255,.82);}
  .foot-col a:hover{color:var(--sun);}
  .foot-bottom{margin-top:2.6rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.14);display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:.82rem;color:rgba(255,255,255,.55);}

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

  /* Responsive */
  @media (max-width:900px){
    .hero-grid,.about-grid,.appt-grid{grid-template-columns:1fr;}
    .scene{max-width:440px;margin-inline:auto;}
    .cards,.steps,.team-grid{grid-template-columns:1fr 1fr;}
    .foot-grid{grid-template-columns:1fr 1fr;}
    .nav-links,.nav-phone{display:none;}
    .burger{display:block;}
    .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;gap:.2rem;background:var(--bone);border-bottom:1px solid var(--line);padding:1rem 4vw 1.4rem;box-shadow:var(--shadow-sm);}
    .nav-links.open a{width:100%;padding:.7rem 0;border-bottom:1px solid var(--line);}
  }
  @media (max-width:560px){
    .cards,.steps,.values,.form-grid,.foot-grid,.strip .wrap,.team-grid{grid-template-columns:1fr;}
    .strip .wrap{gap:.9rem;}
    .float-card{flex-direction:column;align-items:flex-start;gap:.6rem;}
  }
  @media (prefers-reduced-motion:reduce){
    *{animation:none!important;}
    .reveal{opacity:1;transform:none;transition:none;}
    html{scroll-behavior:auto;}
  }
