/* ═══════════════════════════════════════════════════════════════
   STOJANKA METHODOLOGY — GLOBAL DESIGN SYSTEM
   One shared stylesheet for the entire website.
   Every page links this file — edit here to change the whole site.
═══════════════════════════════════════════════════════════════ */

:root{
  /* ---- BRAND PALETTE (black / white / rose gold / silver) ---- */
  --bg:         #FAF8F5;
  --bg-warm:    #F5EFE7;
  --panel:      #EDE6DA;
  --ink:        #1C1410;
  --ink-mid:    #5C5048;
  --ink-soft:   #9E9488;
  --gold:       #C9956A;
  --gold-deep:  #A67550;
  --gold-pale:  #E8D0BA;
  --silver:     #C7CCD1;
  --silver-deep:#9AA1A8;
  --line:       #E4D8C8;
  --white:      #FFFFFF;
  --black:      #100C0A;

  --ease:   cubic-bezier(.22,1,.36,1);
  --fast:   180ms;
  --med:    350ms;

  --maxw: 1280px;
}

/* ---- RESET ---- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;font-weight:300;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.65}
h1,h2,h3,h4{font-family:'DM Serif Display',Georgia,serif;font-weight:400;line-height:1.12;letter-spacing:-.01em}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%;height:auto}
button{font-family:inherit;cursor:pointer;border:none;background:none;font-size:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}
ul,ol{list-style:none}
:focus-visible{outline:2px solid var(--gold-deep);outline-offset:3px;border-radius:2px}

/* ---- UTILITIES ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
@media(min-width:768px){.wrap{padding:0 48px}}
@media(min-width:1200px){.wrap{padding:0 64px}}
.ey{font-size:10px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-deep)}
.ey--silver{color:var(--silver-deep)}
[id]{scroll-margin-top:88px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:var(--bg);padding:14px 22px;z-index:1000;font-size:13px;letter-spacing:.06em}
.skip-link:focus{left:16px;top:16px}

section{padding:100px 0}
@media(max-width:600px){section{padding:70px 0}}
.sec-head{margin-bottom:56px}
.sec-head .ey{margin-bottom:14px}
.sec-head h2{font-size:clamp(26px,3.6vw,42px)}
.sec-head p{font-size:15px;color:var(--ink-mid);line-height:1.85;max-width:540px;margin-top:12px}
.sec-head.center{text-align:center;margin-left:auto;margin-right:auto}

/* ---- REVEAL ANIMATION (fade + gentle rise, used site-wide) ---- */
.rv{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.on{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}

/* ═══════════════════════════
   BUTTONS — identical styling everywhere (spec 2.5)
═══════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 30px;font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  border-radius:2px;transition:background var(--fast) var(--ease),color var(--fast) var(--ease),
  transform var(--fast) var(--ease),border-color var(--fast) var(--ease);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--gold-deep)}
.btn-secondary{border:1px solid var(--ink);color:var(--ink)}
.btn-secondary:hover{background:var(--ink);color:var(--bg)}
.btn-gold{background:var(--gold-deep);color:var(--bg)}
.btn-gold:hover{background:var(--ink)}
.btn-ghost{border:1px solid rgba(250,248,245,.45);color:var(--bg)}
.btn-ghost:hover{background:rgba(250,248,245,.1)}
.btn-sm{padding:11px 22px;font-size:10px}
.btn-block{width:100%}
.btn[disabled]{opacity:.5;pointer-events:none}

/* ═══════════════════════════
   CARDS — identical system for services/gallery/reviews/education (spec 2.6)
═══════════════════════════ */
.card{
  background:var(--white);border:1px solid var(--line);border-radius:3px;
  overflow:hidden;transition:transform var(--med) var(--ease),box-shadow var(--med) var(--ease),border-color var(--med) var(--ease);
}
.card:hover{transform:translateY(-4px);box-shadow:0 24px 48px -20px rgba(28,20,16,.18);border-color:var(--gold-pale)}
.card-img{aspect-ratio:5/4;background:linear-gradient(145deg,var(--panel),var(--bg-warm));position:relative;overflow:hidden}
.card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card-img img{transform:scale(1.045)}
.card-body{padding:28px}
.card-eyebrow{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:10px}
.card h3{font-size:19px;margin-bottom:10px;line-height:1.25}
.card p{font-size:13.5px;color:var(--ink-soft);line-height:1.75}
.card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.card-price{font-family:'DM Serif Display',serif;font-style:italic;font-size:17px;color:var(--gold-deep)}

/* ═══════════════════════════
   GLOBAL NAV — sticky, consistent on every page (Ch 3 / 14.2)
═══════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;height:80px;border-bottom:1px solid transparent;
  background:rgba(250,248,245,.0);
  transition:background var(--med) var(--ease),border-color var(--med) var(--ease),
  height var(--med) var(--ease),backdrop-filter var(--med) var(--ease);
}
@media(min-width:768px){.nav{padding:0 48px}}
@media(min-width:1200px){.nav{padding:0 64px}}
.nav.on{background:rgba(250,248,245,.94);backdrop-filter:blur(16px) saturate(1.4);border-bottom-color:var(--line);height:66px;box-shadow:0 1px 0 rgba(28,20,16,.02)}
/* non-transparent variant for interior pages (no dark hero underneath) */
.nav.solid{background:rgba(250,248,245,.96);backdrop-filter:blur(16px) saturate(1.4);border-bottom-color:var(--line)}

.nav-logo{display:flex;align-items:center}
.nav-logo img{height:42px;width:auto;transition:height var(--med) var(--ease)}
.nav.on .nav-logo img{height:34px}

.nav-links{display:none;gap:30px;font-size:12px;letter-spacing:.05em;color:var(--ink-mid)}
@media(min-width:960px){.nav-links{display:flex}}
.nav-links a{position:relative;padding:6px 0;transition:color var(--fast)}
.nav-links a:hover,.nav-links a.act{color:var(--ink)}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width var(--med) var(--ease)}
.nav-links a:hover::after,.nav-links a.act::after{width:100%}

.nav-right{display:flex;align-items:center;gap:16px}
.nav-book{padding:10px 22px;font-size:10.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);border:1px solid var(--ink);transition:background var(--fast),color var(--fast);border-radius:2px}
.nav-book:hover{background:var(--ink);color:var(--bg)}
.nav-ham{display:flex;flex-direction:column;gap:5px;padding:8px;min-width:44px;min-height:44px;align-items:center;justify-content:center}
.nav-ham span{display:block;width:22px;height:1px;background:var(--ink);transition:transform var(--fast),opacity var(--fast)}
@media(min-width:960px){.nav-ham{display:none}}

/* Mobile drawer — every nav item present, spec 3.3 / 9.1 */
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(340px,88vw);background:var(--bg);z-index:600;
  transform:translateX(100%);transition:transform var(--med) var(--ease);
  padding:86px 36px 40px;border-left:1px solid var(--line);overflow-y:auto;
}
.drawer.open{transform:translateX(0)}
.drawer-logo{margin-bottom:30px}
.drawer-logo img{height:60px;width:auto}
.drawer a{display:block;font-family:'DM Serif Display',serif;font-size:22px;color:var(--ink);margin-bottom:18px;transition:color var(--fast)}
.drawer a:hover{color:var(--gold-deep)}
.drawer-close{position:absolute;top:24px;right:24px;font-size:20px;color:var(--ink-mid);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
.drawer-cta{margin-top:20px}
.drawer-contacts{margin-top:28px;padding-top:28px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:11px}
.drawer-contacts a{font-family:'Inter',sans-serif;font-size:13px;color:var(--ink-soft);margin-bottom:0;letter-spacing:.03em}
.drawer-contacts a:hover{color:var(--gold-deep)}
.ov{position:fixed;inset:0;background:rgba(16,12,10,.45);z-index:590;opacity:0;pointer-events:none;transition:opacity var(--med)}
.ov.open{opacity:1;pointer-events:auto}

/* ═══════════════════════════
   PAGE HERO (interior pages — About/Services/Education/Gallery/etc.)
═══════════════════════════ */
.pg-hero{padding:168px 0 90px;background:var(--bg);position:relative;overflow:hidden}
.pg-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 70% at 75% 20%,rgba(201,149,106,.08),transparent);pointer-events:none}
.pg-hero .ey{margin-bottom:18px}
.pg-hero h1{font-size:clamp(32px,5vw,58px);max-width:780px}
.pg-hero h1 em{font-style:italic;color:var(--gold-deep)}
.pg-hero p{font-size:15.5px;color:var(--ink-mid);line-height:1.85;max-width:560px;margin-top:20px}
.pg-hero-acts{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px}
.pg-crumb{display:flex;gap:8px;align-items:center;font-size:11px;color:var(--ink-soft);letter-spacing:.04em;margin-bottom:22px}
.pg-crumb a{transition:color var(--fast)}
.pg-crumb a:hover{color:var(--gold-deep)}

/* Dark image hero (for service/education detail pages, spec 6.3/8.3) */
.dhero{background:var(--black);color:var(--bg);padding:160px 0 80px;position:relative;overflow:hidden}
.dhero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 25% 30%,rgba(201,149,106,.10),transparent);pointer-events:none}
.dhero-grid{display:grid;grid-template-columns:1fr;gap:44px;align-items:center;position:relative;z-index:1}
@media(min-width:860px){.dhero-grid{grid-template-columns:1.05fr .95fr;gap:64px}}
.dhero .ey{color:var(--gold);margin-bottom:18px}
.dhero h1{font-size:clamp(30px,4.6vw,52px);color:var(--bg)}
.dhero .sub{font-family:'DM Serif Display',serif;font-style:italic;font-size:16px;color:var(--gold-pale);margin-top:14px}
.dhero p{font-size:14.5px;color:#B8AFA6;line-height:1.85;max-width:460px;margin-top:18px}
.dhero-img{aspect-ratio:4/5;background:linear-gradient(150deg,#2A231D,#1A1512);border:1px solid rgba(255,255,255,.08);position:relative;overflow:hidden}
.dhero-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.dhero-acts{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}

/* ═══════════════════════════
   TRUST BADGES (spec 4.2 / 11.11) — elegant text, not oversized icons
═══════════════════════════ */
.trust-strip{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 0}
.trust-row{display:flex;flex-wrap:wrap;gap:14px 34px;justify-content:center;align-items:center}
.trust-item{display:flex;align-items:center;gap:9px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mid);white-space:nowrap}
.trust-item::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0}

/* ═══════════════════════════
   PROCESS / TIMELINE (numbered steps — used where order is real, e.g. appointment flow)
═══════════════════════════ */
.steps{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(min-width:600px){.steps{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.steps.cols-4{grid-template-columns:repeat(4,1fr)}}
.step{background:var(--panel);padding:36px 26px;display:flex;flex-direction:column;gap:12px}
.step-n{font-family:'DM Serif Display',serif;font-style:italic;font-size:32px;color:var(--line);line-height:1}
.step h3{font-size:16px;line-height:1.3}
.step p{font-size:13px;color:var(--ink-soft);line-height:1.75}

/* ═══════════════════════════
   FAQ ACCORDION (shared across services/education/contact/about)
═══════════════════════════ */
.faq-item{border-bottom:1px solid var(--line)}
.faq-btn{width:100%;text-align:left;display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding:22px 0;font-size:clamp(14px,1.6vw,15.5px);color:var(--ink);line-height:1.4;transition:color var(--fast)}
.faq-btn:hover{color:var(--gold-deep)}
.faq-icon{width:24px;height:24px;flex-shrink:0;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--gold-deep);transition:transform var(--med) var(--ease),background var(--fast),border-color var(--fast),color var(--fast);margin-top:1px}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--gold-deep);color:var(--bg);border-color:var(--gold-deep)}
.faq-ans{max-height:0;overflow:hidden;transition:max-height var(--med) var(--ease)}
.faq-item.open .faq-ans{max-height:600px}
.faq-ai{padding:0 40px 24px 0}
.faq-ai p{font-size:14px;color:var(--ink-mid);line-height:1.85;margin-bottom:12px;max-width:600px}
.faq-ai p:last-child{margin-bottom:0}
.faq-ul{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.faq-ul li{display:flex;gap:11px;font-size:13px;color:var(--ink-mid);line-height:1.7}
.faq-ul li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:7px}
.faq-hi{background:var(--bg-warm);border:1px solid var(--line);border-left:3px solid var(--gold);padding:14px 18px;margin-top:14px;font-size:13px;color:var(--ink-mid);line-height:1.75;max-width:580px}
.faq-hi strong{color:var(--ink);font-weight:500}

/* ═══════════════════════════
   GALLERY / LIGHTBOX (unlimited photos, filter, swipe — Ch 10)
═══════════════════════════ */
.gal-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px}
.gal-filter{padding:10px 20px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);border:1px solid var(--line);border-radius:2px;transition:all var(--fast)}
.gal-filter:hover{border-color:var(--gold);color:var(--gold-deep)}
.gal-filter.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.gal-grid{columns:2;column-gap:12px}
@media(min-width:700px){.gal-grid{columns:3}}
@media(min-width:1100px){.gal-grid{columns:4}}
.gal-item{break-inside:avoid;margin-bottom:12px;position:relative;overflow:hidden;cursor:pointer;background:linear-gradient(150deg,var(--panel),#DDD4C0)}
.gal-item img{width:100%;display:block;transition:transform .5s var(--ease)}
.gal-item:hover img{transform:scale(1.04)}
.gal-item .gal-cap{position:absolute;left:0;right:0;bottom:0;padding:14px;background:linear-gradient(to top,rgba(16,12,10,.75),transparent);opacity:0;transition:opacity var(--fast);color:var(--bg);font-size:11px;letter-spacing:.06em}
.gal-item:hover .gal-cap{opacity:1}
.gal-ph{aspect-ratio:4/5;position:relative;overflow:hidden}

/* ═══════════════════════════
   PHOTO-PENDING PLACEHOLDER — intentional design state, not an empty box
   Used everywhere a real photo will eventually go.
═══════════════════════════ */
.ph-slot{
  position:absolute;inset:0;width:100%;height:100%;
  background:linear-gradient(150deg,var(--panel) 0%,var(--bg-warm) 55%,#E4D9C8 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  text-align:center;padding:20px;
}
.ph-slot::before{
  content:'';position:absolute;inset:10px;border:1px solid rgba(201,149,106,.25);pointer-events:none;
}
.ph-slot-icon{
  width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(201,149,106,.4);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-deep);font-size:15px;position:relative;z-index:1;
  background:rgba(255,255,255,.4);
}
.ph-slot-label{
  font-family:'DM Serif Display',serif;font-style:italic;
  font-size:13px;color:var(--gold-deep);position:relative;z-index:1;line-height:1.3;
}
.ph-slot-sub{
  font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);
  position:relative;z-index:1;
}
/* size variants */
.ph-slot.sm .ph-slot-icon{width:30px;height:30px;font-size:12px}
.ph-slot.sm .ph-slot-label{font-size:11px}
.ph-slot.sm .ph-slot-sub{display:none}
/* dark variant — for use on dhero / dark backgrounds */
.ph-slot.dark{
  background:linear-gradient(150deg,#241D18 0%,#1A1512 55%,#150F0C 100%);
}
.ph-slot.dark::before{border-color:rgba(201,149,106,.2)}
.ph-slot.dark .ph-slot-icon{border-color:rgba(201,149,106,.3);background:rgba(255,255,255,.03);color:var(--gold)}
.ph-slot.dark .ph-slot-label{color:var(--gold-pale)}
.ph-slot.dark .ph-slot-sub{color:#7A7268}

.lightbox{position:fixed;inset:0;background:rgba(10,8,6,.96);z-index:1000;display:none;align-items:center;justify-content:center;padding:24px}
.lightbox.open{display:flex}
.lightbox img{max-width:min(92vw,1100px);max-height:82vh;object-fit:contain}
.lb-cap{position:absolute;bottom:28px;left:0;right:0;text-align:center;color:#D8CFC4;font-size:13px;letter-spacing:.04em}
.lb-close,.lb-prev,.lb-next{position:absolute;color:var(--bg);font-size:22px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;transition:opacity var(--fast);opacity:.7}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{opacity:1}
.lb-close{top:18px;right:18px}
.lb-prev{left:8px;top:50%;transform:translateY(-50%);font-size:30px}
.lb-next{right:8px;top:50%;transform:translateY(-50%);font-size:30px}
.lb-count{position:absolute;top:24px;left:24px;color:#B8AFA6;font-size:12px;letter-spacing:.08em}

/* ═══════════════════════════
   BEFORE/AFTER SLIDER (spec 6.11/8.9)
═══════════════════════════ */
.ba{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--panel);cursor:ew-resize;user-select:none}
.ba-after{position:absolute;inset:0}
.ba-before{position:absolute;inset:0;overflow:hidden;width:50%}
.ba-before-inner{position:absolute;inset:0;width:200%;max-width:none}
.ba-before-inner img,.ba-after img{width:100%;height:100%;object-fit:cover;display:block}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--white);transform:translateX(-50%)}
.ba-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.25);font-size:13px;color:var(--ink)}
.ba-lbl{position:absolute;top:12px;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--white);background:rgba(16,12,10,.55);padding:5px 10px;border-radius:2px}
.ba-lbl.before{left:12px}.ba-lbl.after{right:12px}

/* ═══════════════════════════
   FORMS (contact / booking / education inquiry — Ch 12 / 9.7)
═══════════════════════════ */
.form{display:flex;flex-direction:column}
.frow{display:grid;grid-template-columns:1fr}
@media(min-width:520px){.frow{grid-template-columns:1fr 1fr;gap:0 22px}}
.fg{position:relative;margin-bottom:26px}
.fg label{display:block;font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:9px;transition:color var(--fast)}
.fg:focus-within label{color:var(--gold-deep)}
.fg input,.fg select,.fg textarea{width:100%;padding:11px 0;border:none;border-bottom:1px solid var(--line);background:transparent;font-size:14px;color:var(--ink);transition:border-color var(--fast);-webkit-appearance:none;border-radius:0}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-bottom-color:var(--gold-deep)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--ink-soft);font-size:13px}
.fg textarea{resize:none;min-height:88px;line-height:1.7}
.fg select{cursor:pointer}
.fg-note{font-size:11.5px;color:var(--ink-soft);margin-top:-16px;margin-bottom:22px}
.form-ok{display:none;text-align:center;padding:46px 18px}
.form-ok.on{display:block;animation:fdUp .6s var(--ease) forwards}
.form-ok-ic{width:52px;height:52px;border-radius:50%;background:var(--bg-warm);border:1px solid var(--gold-pale);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;color:var(--gold-deep);font-size:20px}
.form-ok h3{font-size:24px;margin-bottom:10px}
.form-ok p{font-size:14px;color:var(--ink-mid);line-height:1.75;max-width:340px;margin:0 auto}
@keyframes fdUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* radio/pill group for "preferred contact method" etc */
.pill-group{display:flex;flex-wrap:wrap;gap:8px}
.pill{padding:9px 16px;font-size:12px;border:1px solid var(--line);border-radius:20px;color:var(--ink-mid);cursor:pointer;transition:all var(--fast)}
.pill input{position:absolute;opacity:0;pointer-events:none}
.pill:has(input:checked){background:var(--ink);color:var(--bg);border-color:var(--ink)}
.pill:hover{border-color:var(--gold)}

/* ═══════════════════════════
   MARQUEE
═══════════════════════════ */
.mq{overflow:hidden;white-space:nowrap;border-bottom:1px solid var(--line);background:var(--white);padding:15px 0}
.mq-track{display:inline-flex;animation:mqR 40s linear infinite}
.mqi{display:inline-flex;align-items:center;gap:22px;padding:0 22px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
.mqi::after{content:'';width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0}
@keyframes mqR{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════
   FINAL CTA BAND (identical component on every page — spec 14.6)
═══════════════════════════ */
.fcta{background:var(--ink);color:var(--bg);padding:100px 24px;text-align:center;position:relative;overflow:hidden}
.fcta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(201,149,106,.07),transparent);pointer-events:none}
.fcta .ey{color:var(--gold);margin-bottom:24px}
.fcta h2{font-size:clamp(26px,4.4vw,50px);color:var(--bg);max-width:680px;margin:0 auto 16px;position:relative;z-index:1}
.fcta h2 em{font-style:italic;color:var(--gold)}
.fcta p{font-size:14.5px;color:#A89F96;max-width:400px;margin:0 auto 38px;line-height:1.8;position:relative;z-index:1}
.fcta-acts{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;position:relative;z-index:1}

/* ═══════════════════════════
   FOOTER — identical across every page (Ch 14.3 / 4.12)
═══════════════════════════ */
footer{background:var(--black);color:var(--bg);padding:76px 24px 26px}
@media(min-width:768px){footer{padding:92px 48px 30px}}
@media(min-width:1200px){footer{padding:92px 64px 30px}}
.ft-g{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr;gap:42px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.1)}
@media(min-width:600px){.ft-g{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.ft-g{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.ft-logo img{height:54px;width:auto}
.ft-brand p{font-size:13px;color:#8C8278;line-height:1.75;max-width:270px;margin-top:14px}
.ft-social{display:flex;gap:12px;margin-top:20px}
.ft-social a{width:34px;height:34px;border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;color:#C8C0B4;transition:all var(--fast)}
.ft-social a:hover{border-color:var(--gold);color:var(--gold)}
.ft-col h5{font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:#8C8278;margin-bottom:18px}
.ft-col a{display:block;font-size:13px;color:#C8C0B4;margin-bottom:11px;transition:color var(--fast)}
.ft-col a:hover{color:var(--gold)}
.ft-b{max-width:var(--maxw);margin:24px auto 0;display:flex;flex-direction:column;gap:8px;font-size:11px;color:#5A544E}
@media(min-width:768px){.ft-b{flex-direction:row;justify-content:space-between}}
.ft-b a{color:#5A544E;transition:color var(--fast)}
.ft-b a:hover{color:#8C8278}

/* ═══════════════════════════
   MISC SHARED BLOCKS
═══════════════════════════ */
.manifesto{background:var(--ink);color:var(--bg);padding:100px 24px;text-align:center}
.manifesto .ey{color:var(--gold);margin-bottom:34px}
.manifesto blockquote{font-family:'DM Serif Display',serif;font-style:italic;font-size:clamp(19px,3vw,36px);line-height:1.4;max-width:780px;margin:0 auto 36px;color:var(--bg)}
.mf-line{width:32px;height:1px;background:var(--gold);margin:0 auto 20px}
.mf-cr{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#8C8278}

.stat-row{display:flex;flex-wrap:wrap;gap:34px}
.stat-n{font-family:'DM Serif Display',serif;font-style:italic;font-size:32px;color:var(--gold-deep);line-height:1}
.stat-l{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-top:5px}

.rev-card{background:var(--white);border:1px solid var(--line);padding:34px 30px;border-radius:3px}
.rev-stars{color:var(--gold);font-size:13px;letter-spacing:2px;margin-bottom:16px}
.rev-q{font-family:'DM Serif Display',serif;font-style:italic;font-size:15px;line-height:1.7;color:var(--ink);margin-bottom:18px}
.rev-auth{display:flex;justify-content:space-between;align-items:center;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
.rev-auth a{color:var(--gold-deep);text-transform:none;letter-spacing:0;font-size:12px}
.rev-tag{display:inline-block;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);background:var(--bg-warm);padding:4px 10px;border-radius:20px;margin-bottom:14px}

.map-frame{position:relative;width:100%;aspect-ratio:16/9;border:1px solid var(--line);overflow:hidden;background:var(--panel)}
.map-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
@media(min-width:768px){.map-frame{aspect-ratio:16/7}}

.badge-row{display:flex;flex-wrap:wrap;gap:8px}
.badge{font-size:10.5px;letter-spacing:.06em;color:var(--ink-soft);border:1px solid var(--line);padding:6px 14px;border-radius:20px;transition:all var(--fast)}
.badge:hover{border-color:var(--gold);color:var(--gold-deep)}

.divider{width:100%;height:1px;background:var(--line);border:none;margin:0}
.center-line{width:36px;height:1px;background:var(--gold);margin:0 auto}

/* future-service placeholder card */
.card-soon{opacity:.55;position:relative}
.card-soon::after{content:'Coming Soon';position:absolute;top:14px;right:14px;font-size:9px;letter-spacing:.12em;text-transform:uppercase;background:var(--ink);color:var(--bg);padding:5px 10px;border-radius:20px}
