/* ===========================================================================
   Restoration Dental — Design System ("Porcelain Luxe")
   Tokens in :root re-theme the whole site. Fraunces (display) + Figtree (body).
   =========================================================================== */

:root{
  /* palette */
  --porcelain:#F7F4EF;
  --warm-white:#FCFAF6;
  --ink:#14202E;
  --ink-2:#1c2c3d;
  --slate:#41505F;
  --slate-2:#5e6c79;
  --brass:#B8893E;
  --brass-deep:#9A6E2E;
  --brass-soft:#e2c79a;
  --sage:#DCE6E1;
  --sand:#E6DFD3;
  --line:#E6DFD3;
  --line-2:#ddd3c4;

  /* semantic */
  --bg:var(--porcelain);
  --surface:var(--warm-white);
  --text:var(--ink);
  --text-soft:var(--slate);
  --accent:var(--brass);
  --accent-deep:var(--brass-deep);

  /* type */
  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --body:"Figtree",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;

  /* shape */
  --r-sm:10px; --r:15px; --r-lg:22px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(20,32,46,.05), 0 6px 18px -10px rgba(20,32,46,.18);
  --shadow:0 10px 40px -16px rgba(20,32,46,.22);
  --shadow-lg:0 30px 80px -28px rgba(20,32,46,.35);

  /* layout */
  --maxw:1200px;
  --gutter:clamp(1.1rem,4vw,2.4rem);
  --section-y:clamp(4rem,9vw,7.5rem);
  --header-h:74px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
html.lenis,html.lenis body{ scroll-behavior:auto !important; }
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--body); font-size:1.0625rem; line-height:1.65;
  font-weight:400; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; }
button{ font-family:inherit; }

/* ---------- typography ---------- */
h1,h2,h3,h4{ font-family:var(--display); font-weight:500; line-height:1.08;
  letter-spacing:-.01em; color:var(--ink); margin:0 0 .5em;
  font-optical-sizing:auto; }
h1{ font-size:clamp(2.5rem,6vw,4.7rem); font-weight:480; letter-spacing:-.02em; }
h2{ font-size:clamp(1.95rem,3.6vw,3rem); }
h3{ font-size:clamp(1.3rem,2vw,1.6rem); }
p{ margin:0 0 1.1rem; color:var(--text-soft); }
.lead{ font-size:clamp(1.12rem,1.7vw,1.32rem); color:var(--slate); line-height:1.6; }
.serif{ font-family:var(--display); }
.eyebrow{ font-family:var(--body); font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  font-size:.74rem; color:var(--brass-deep); display:inline-flex; align-items:center; gap:.6rem; margin:0 0 1.1rem; }
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--brass); display:inline-block; }
.eyebrow.center::after{ content:""; width:26px; height:1px; background:var(--brass); display:inline-block; }
.eyebrow.center{ justify-content:center; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.wrap-narrow{ max-width:820px; }
.section{ padding-block:var(--section-y); }
.section--tint{ background:linear-gradient(180deg,var(--surface),#f1ede4); }
.section--mist{ background:linear-gradient(180deg,#eef3ef,var(--bg)); }
.center{ text-align:center; }
.muted{ color:var(--slate-2); }
.grid{ display:grid; gap:clamp(1rem,2.4vw,1.7rem); }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
@media(max-width:900px){ .cols-3,.cols-4{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:620px){ .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr; } }

/* ---------- buttons ---------- */
.btn{ --b:var(--brass); position:relative; display:inline-flex; align-items:center; gap:.6rem;
  font-weight:600; font-size:1rem; padding:.92rem 1.6rem; border-radius:var(--r-pill);
  border:1px solid transparent; cursor:pointer; transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,background .3s,color .3s;
  overflow:hidden; isolation:isolate; line-height:1; }
.btn svg{ width:1.05em; height:1.05em; }
.btn-primary{ background:var(--ink); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(110deg,transparent 20%,rgba(255,255,255,.22) 50%,transparent 80%);
  transform:translateX(-130%) skewX(-18deg); transition:transform .6s ease; }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
.btn-primary:hover::after{ transform:translateX(130%) skewX(-18deg); }
.btn-gold{ background:var(--brass); color:#fff; box-shadow:0 10px 30px -12px rgba(184,137,62,.7); }
.btn-gold::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(110deg,transparent 20%,rgba(255,255,255,.35) 50%,transparent 80%);
  transform:translateX(-130%) skewX(-18deg); transition:transform .6s ease; }
.btn-gold:hover{ transform:translateY(-2px); background:var(--brass-deep); }
.btn-gold:hover::after{ transform:translateX(130%) skewX(-18deg); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover{ border-color:var(--ink); transform:translateY(-2px); }
.btn-light{ background:#fff; color:var(--ink); box-shadow:var(--shadow-sm); }
.btn-light:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
@media(prefers-reduced-motion:reduce){ .btn,.btn::after{ transition:none !important; transform:none !important; } }
.link-arrow{ font-weight:600; color:var(--brass-deep); display:inline-flex; align-items:center; gap:.4rem; }
.link-arrow svg{ width:1em; transition:transform .3s; }
.link-arrow:hover svg{ transform:translateX(4px); }

/* ---------- header ---------- */
.site-header{ position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--header-h);
  display:flex; align-items:center; transition:background .4s,box-shadow .4s,backdrop-filter .4s; }
.site-header.scrolled{ background:rgba(247,244,239,.82); backdrop-filter:blur(14px) saturate(1.3);
  box-shadow:0 1px 0 rgba(20,32,46,.06); }
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.brand{ display:flex; align-items:center; gap:.7rem; font-family:var(--display); font-weight:500;
  font-size:1.3rem; letter-spacing:-.01em; color:var(--ink); z-index:2; }
.brand .mono{ display:grid; place-items:center; width:40px; height:40px; border-radius:11px;
  background:var(--ink); color:#fff; font-size:.95rem; font-weight:600; letter-spacing:.02em;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12); }
.brand .mono b{ color:var(--brass-soft); font-weight:600; }
.brand small{ display:block; font-family:var(--body); font-size:.62rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--brass-deep); margin-top:2px; }

.nav{ display:flex; align-items:center; gap:.3rem; }
.nav-item{ position:relative; }
.nav-link{ display:inline-flex; align-items:center; gap:.3rem; padding:.55rem .8rem; border-radius:var(--r-pill);
  font-weight:500; font-size:.95rem; color:var(--ink-2); transition:color .25s,background .25s; }
.nav-link:hover{ color:var(--brass-deep); }
.nav-link svg{ width:.7em; opacity:.6; transition:transform .3s; }
.nav-item:hover .nav-link svg{ transform:rotate(180deg); }
.mega{ position:absolute; top:calc(100% + 10px); left:50%; transform:translateX(-50%) translateY(8px);
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:1rem;
  box-shadow:var(--shadow-lg); opacity:0; visibility:hidden; transition:opacity .3s,transform .3s;
  min-width:300px; }
.mega.wide{ min-width:560px; }
.nav-item:hover .mega,.nav-item:focus-within .mega{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.mega-grid{ display:grid; gap:.15rem; }
.mega.wide .mega-grid{ grid-template-columns:1fr 1fr; gap:.15rem .8rem; }
.mega a{ display:block; padding:.6rem .75rem; border-radius:10px; transition:background .2s; }
.mega a:hover{ background:#f1ece2; }
.mega a strong{ display:block; font-weight:600; font-size:.95rem; color:var(--ink); }
.mega a span{ font-size:.82rem; color:var(--slate-2); }
.mega .mega-head{ grid-column:1/-1; font-family:var(--display); font-size:.95rem; color:var(--brass-deep);
  padding:.3rem .75rem .5rem; }

.header-cta{ display:flex; align-items:center; gap:.8rem; }
.header-phone{ font-weight:600; color:var(--ink); display:inline-flex; align-items:center; gap:.4rem; font-size:.95rem; }
.header-phone svg{ width:1em; color:var(--brass); }
.nav-toggle{ display:none; width:44px; height:44px; border:1px solid var(--line-2); border-radius:12px;
  background:var(--surface); cursor:pointer; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.nav-toggle span{ width:20px; height:2px; background:var(--ink); border-radius:2px; transition:.3s; }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media(max-width:1040px){
  .nav-toggle{ display:flex; }
  .header-phone{ display:none; }
  .nav{ position:fixed; inset:0 0 0 auto; width:min(380px,86vw); background:var(--surface);
    flex-direction:column; align-items:stretch; gap:0; padding:calc(var(--header-h) + 1rem) 1.4rem 2rem;
    transform:translateX(100%); transition:transform .42s cubic-bezier(.5,0,.1,1); overflow-y:auto;
    box-shadow:var(--shadow-lg); }
  .nav.open{ transform:translateX(0); }
  .nav-link{ padding:.85rem .4rem; font-size:1.05rem; border-bottom:1px solid var(--line); border-radius:0; justify-content:space-between; }
  .nav-item{ width:100%; }
  .mega{ position:static; transform:none; opacity:1; visibility:visible; box-shadow:none; border:none;
    min-width:0; padding:.2rem .4rem .6rem; display:none; background:transparent; }
  .mega.wide{ min-width:0; }
  .mega.wide .mega-grid{ grid-template-columns:1fr; }
  .nav-item.expanded .mega{ display:block; }
  .nav-drawer-cta{ margin-top:1.2rem; }
}
.nav-overlay{ position:fixed; inset:0; background:rgba(20,32,46,.4); backdrop-filter:blur(2px);
  opacity:0; visibility:hidden; transition:.3s; z-index:999; }
.nav-overlay.show{ opacity:1; visibility:visible; }

/* ---------- cards ---------- */
.card{ position:relative; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:1.7rem; box-shadow:var(--shadow-sm); transition:transform .4s,box-shadow .4s,border-color .4s; overflow:hidden; }
.card::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(184,137,62,.5),transparent); opacity:0; transition:opacity .4s; }
.card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); border-color:var(--line-2); }
.card:hover::before{ opacity:1; }
.card .ico{ width:50px; height:50px; border-radius:13px; display:grid; place-items:center; margin-bottom:1.1rem;
  background:linear-gradient(150deg,#f3ead9,#fff); border:1px solid var(--sand); color:var(--brass-deep); }
.card .ico svg{ width:24px; height:24px; }
.card h3{ font-size:1.22rem; margin-bottom:.4rem; }
.card p{ font-size:.96rem; margin-bottom:.9rem; }
a.card{ color:inherit; }

/* service-link card variant */
.svc-card{ display:flex; flex-direction:column; }
.svc-card .tag{ font-size:.72rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--brass-deep); margin-bottom:.7rem; }
.svc-card .link-arrow{ margin-top:auto; }

/* ---------- AEO blocks ---------- */
.quick-answer{ background:linear-gradient(160deg,#f4ecdd,#fbf8f1); border:1px solid var(--sand);
  border-left:4px solid var(--brass); border-radius:var(--r); padding:1.4rem 1.6rem; margin:0 0 2rem; }
.quick-answer .qa-label{ font-weight:700; letter-spacing:.1em; text-transform:uppercase; font-size:.72rem;
  color:var(--brass-deep); margin:0 0 .5rem; }
.quick-answer p{ margin:0; color:var(--ink-2); font-size:1.08rem; line-height:1.6; }
.key-facts{ width:100%; border-collapse:collapse; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r); overflow:hidden; margin:1.5rem 0; }
.key-facts th,.key-facts td{ text-align:left; padding:.85rem 1.1rem; font-size:.96rem; border-bottom:1px solid var(--line); }
.key-facts tr:last-child th,.key-facts tr:last-child td{ border-bottom:none; }
.key-facts th{ width:38%; font-weight:600; color:var(--ink); background:#f3efe6; font-family:var(--body); }
.key-facts td{ color:var(--slate); }
.key-facts tr:hover td,.key-facts tr:hover th{ background:#f6f0e4; }
.toc{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:1.1rem 1.3rem; margin:0 0 2rem; }
.toc p{ font-weight:600; color:var(--ink); margin:0 0 .5rem; font-size:.9rem; letter-spacing:.04em; text-transform:uppercase; }
.toc ul{ list-style:none; display:flex; flex-wrap:wrap; gap:.4rem .9rem; }
.toc a{ color:var(--brass-deep); font-weight:500; font-size:.95rem; }
.toc a:hover{ text-decoration:underline; }
.updated{ font-size:.85rem; color:var(--slate-2); }

/* ---------- FAQ ---------- */
.faqs{ max-width:880px; margin-inline:auto; }
.faqs details{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  margin-bottom:.8rem; overflow:hidden; transition:border-color .3s,box-shadow .3s; }
.faqs details[open]{ border-color:var(--line-2); box-shadow:var(--shadow-sm); }
.faqs summary{ list-style:none; cursor:pointer; padding:1.15rem 1.4rem; font-weight:600; color:var(--ink);
  font-size:1.06rem; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faqs summary::-webkit-details-marker{ display:none; }
.faqs summary::after{ content:"+"; font-family:var(--display); font-size:1.5rem; color:var(--brass); transition:transform .3s; line-height:1; }
.faqs details[open] summary::after{ transform:rotate(45deg); }
.faqs details p{ padding:0 1.4rem 1.3rem; margin:0; }

/* ---------- testimonials ---------- */
.quote-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:1.8rem;
  box-shadow:var(--shadow-sm); position:relative; }
.quote-card .stars{ color:var(--brass); letter-spacing:2px; font-size:.95rem; margin-bottom:.8rem; }
.quote-card blockquote{ margin:0 0 1rem; font-family:var(--display); font-size:1.18rem; line-height:1.5; color:var(--ink); font-weight:430; }
.quote-card cite{ font-style:normal; font-weight:600; color:var(--slate); font-size:.92rem; }

/* ---------- stats ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line);
  border-radius:var(--r-lg); overflow:hidden; background:var(--surface); }
.stat{ padding:1.8rem 1.2rem; text-align:center; border-right:1px solid var(--line); }
.stat:last-child{ border-right:none; }
.stat .num{ font-family:var(--display); font-size:clamp(2.2rem,4vw,3rem); color:var(--ink); font-weight:480; line-height:1; }
.stat .num b{ color:var(--brass); font-weight:480; }
.stat .lbl{ font-size:.85rem; color:var(--slate-2); margin-top:.5rem; letter-spacing:.02em; }
@media(max-width:740px){ .stats{ grid-template-columns:1fr 1fr; } .stat:nth-child(2){ border-right:none; } .stat:nth-child(1),.stat:nth-child(2){ border-bottom:1px solid var(--line); } }

/* ---------- page hero (inner pages) ---------- */
.page-hero{ position:relative; padding-top:calc(var(--header-h) + clamp(2.4rem,6vw,4.5rem));
  padding-bottom:clamp(2.4rem,5vw,3.6rem); background:linear-gradient(170deg,#eef3ef 0%,var(--porcelain) 60%);
  overflow:hidden; }
.page-hero::after{ content:""; position:absolute; right:-10%; top:-30%; width:55%; height:160%;
  background:radial-gradient(circle at center,rgba(184,137,62,.14),transparent 65%); pointer-events:none; }
.page-hero .crumbs{ font-size:.85rem; color:var(--slate-2); margin-bottom:1rem; display:flex; gap:.5rem; flex-wrap:wrap; }
.page-hero .crumbs a:hover{ color:var(--brass-deep); }
.page-hero h1{ max-width:18ch; }
.page-hero .lead{ max-width:60ch; }

/* ---------- prose ---------- */
.prose h2{ margin-top:2.4rem; scroll-margin-top:100px; }
.prose h3{ margin-top:1.8rem; color:var(--ink); }
.prose ul,.prose ol{ margin:0 0 1.3rem; padding-left:1.2rem; color:var(--text-soft); }
.prose li{ margin-bottom:.5rem; }
.prose li::marker{ color:var(--brass); }
.checklist{ list-style:none; padding:0; }
.checklist li{ position:relative; padding-left:2rem; margin-bottom:.8rem; color:var(--slate); }
.checklist li::before{ content:""; position:absolute; left:0; top:.15rem; width:1.3rem; height:1.3rem;
  border-radius:50%; background:var(--brass); -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/68% no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/68% no-repeat; }

/* split layout */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(1.6rem,4vw,3.5rem); align-items:center; }
.split.reverse .split-media{ order:-1; }
@media(max-width:880px){ .split{ grid-template-columns:1fr; } .split.reverse .split-media{ order:0; } }
.media-frame{ position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--sand);
  box-shadow:var(--shadow); background:linear-gradient(150deg,#efe6d6,#f9f5ee); aspect-ratio:4/3; }
.media-frame.tall{ aspect-ratio:3/4; }
.media-frame img{ width:100%; height:100%; object-fit:cover; }
.media-frame .ph-fill{ position:absolute; inset:0; display:grid; place-content:center; text-align:center; gap:.5rem; color:var(--brass-deep); }
.media-frame .ph-fill svg{ width:42px; height:42px; margin-inline:auto; opacity:.7; }
.media-frame .ph-fill span{ font-size:.82rem; letter-spacing:.04em; color:var(--slate-2); }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; background:linear-gradient(150deg,var(--ink) 0%,#0e1925 100%); color:#fff; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 80% 20%,rgba(184,137,62,.28),transparent 55%); }
.cta-band::after{ content:"RD"; position:absolute; right:2%; bottom:-26%; font-family:var(--display);
  font-size:30vw; font-weight:600; color:transparent; -webkit-text-stroke:1px rgba(255,255,255,.06);
  pointer-events:none; line-height:.8; }
.cta-band .wrap{ position:relative; z-index:1; text-align:center; }
.cta-band h2{ color:#fff; max-width:20ch; margin-inline:auto; }
.cta-band p{ color:rgba(255,255,255,.78); max-width:54ch; margin-inline:auto 0; margin-inline:auto; }
.cta-actions{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:1.8rem; }

/* ---------- footer ---------- */
.site-footer{ position:relative; background:var(--ink); color:rgba(255,255,255,.72); padding-top:clamp(3.5rem,7vw,5.5rem); overflow:hidden; }
.site-footer a{ color:rgba(255,255,255,.72); transition:color .25s; }
.site-footer a:hover{ color:var(--brass-soft); }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:2.2rem; position:relative; z-index:1; }
@media(max-width:880px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:2rem; } }
@media(max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }
.footer-brand .brand{ color:#fff; margin-bottom:1rem; }
.footer-brand p{ color:rgba(255,255,255,.6); font-size:.95rem; max-width:34ch; }
.footer-col h4{ color:#fff; font-family:var(--body); font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:1rem; }
.footer-col ul{ list-style:none; display:grid; gap:.55rem; font-size:.95rem; }
.footer-contact li{ display:flex; gap:.6rem; margin-bottom:.7rem; font-size:.95rem; align-items:flex-start; }
.footer-contact svg{ width:1.1em; color:var(--brass); flex-shrink:0; margin-top:.2rem; }
.footer-socials{ display:flex; gap:.6rem; margin-top:1.2rem; }
.footer-socials a{ width:38px; height:38px; border-radius:50%; border:1px solid rgba(255,255,255,.16);
  display:grid; place-items:center; transition:.3s; }
.footer-socials a:hover{ background:var(--brass); border-color:var(--brass); color:#fff; transform:translateY(-2px); }
.footer-socials svg{ width:17px; height:17px; }
.footer-watermark{ position:absolute; left:0; right:0; bottom:-3.5vw; text-align:center; font-family:var(--display);
  font-size:19vw; font-weight:600; color:transparent; -webkit-text-stroke:1px rgba(255,255,255,.05);
  line-height:.8; pointer-events:none; white-space:nowrap; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:clamp(2.5rem,5vw,4rem);
  padding:1.6rem 0; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  font-size:.84rem; color:rgba(255,255,255,.5); position:relative; z-index:1; }
.footer-bottom a:hover{ color:var(--brass-soft); }

/* ---------- forms ---------- */
.form-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(1.5rem,3vw,2.4rem); box-shadow:var(--shadow); }
.field{ margin-bottom:1.1rem; }
.field label{ display:block; font-weight:600; font-size:.9rem; color:var(--ink); margin-bottom:.4rem; }
.field input,.field select,.field textarea{ width:100%; padding:.85rem 1rem; border:1px solid var(--line-2);
  border-radius:var(--r-sm); background:#fff; font-family:inherit; font-size:1rem; color:var(--ink); transition:border-color .25s,box-shadow .25s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--brass);
  box-shadow:0 0 0 3px rgba(184,137,62,.16); }
.field textarea{ min-height:130px; resize:vertical; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
@media(max-width:560px){ .form-row{ grid-template-columns:1fr; } }
.form-note{ font-size:.82rem; color:var(--slate-2); margin-top:.6rem; }
.form-success{ display:none; padding:1.2rem 1.4rem; background:#e9f3ec; border:1px solid #bcd9c4;
  border-radius:var(--r); color:#22613a; font-weight:500; margin-bottom:1rem; }
.form-success.show{ display:block; }

/* ---------- misc ---------- */
.badge-row{ display:flex; flex-wrap:wrap; gap:.6rem; }
.badge{ display:inline-flex; align-items:center; gap:.5rem; padding:.5rem 1rem; border-radius:var(--r-pill);
  background:var(--surface); border:1px solid var(--line); font-size:.86rem; font-weight:500; color:var(--ink-2); }
.badge svg{ width:1.05em; color:var(--brass); }
.divider{ height:1px; background:linear-gradient(90deg,transparent,var(--line-2),transparent); margin:var(--section-y) 0; border:0; }
.reveal-on-scroll[data-reveal]{ opacity:0; }
@media(prefers-reduced-motion:reduce){ [data-reveal]{ opacity:1 !important; transform:none !important; } }

/* custom cursor */
html.has-cursor,html.has-cursor *{ cursor:none; }
html.has-cursor input,html.has-cursor textarea,html.has-cursor select{ cursor:auto; }
.cursor-dot,.cursor-ring{ position:fixed; top:0; left:0; pointer-events:none; z-index:99999; border-radius:50%;
  transform:translate(-50%,-50%); opacity:0; transition:opacity .3s; }
.cursor-dot{ width:7px; height:7px; background:var(--ink); }
.cursor-ring{ width:34px; height:34px; border:1.5px solid rgba(184,137,62,.8); }
html.has-cursor.cursor-active .cursor-dot,html.has-cursor.cursor-active .cursor-ring{ opacity:1; }
.cursor-ring.hovering{ width:52px; height:52px; border-color:var(--brass); background:rgba(184,137,62,.08); }

.skip-link{ position:absolute; left:-999px; top:0; background:var(--ink); color:#fff; padding:.7rem 1.2rem;
  border-radius:0 0 8px 0; z-index:10000; }
.skip-link:focus{ left:0; }
:focus-visible{ outline:2px solid var(--brass); outline-offset:3px; border-radius:4px; }
