/* ============================================================
   MORE BOOKINGS — "Midnight Concierge" design system
   Dark luxe hospitality-technology. Tokens live here; one edit re-themes.
   ============================================================ */

:root{
  /* Surfaces */
  --bg:        #0B0E11;
  --bg-2:      #11161C;
  --bg-3:      #161C23;
  --bg-glass:  rgba(20,26,33,.62);

  /* Ink */
  --ink:       #F4EFE7;   /* warm ivory */
  --ink-soft:  #C7CDd4;
  --muted:     #8C949D;
  --faint:     #5C636B;

  /* Brand accents */
  --gold:      #D9B26A;
  --gold-2:    #ECCE92;
  --teal:      #5FB7AE;
  --teal-2:    #7FD0C7;

  /* Lines / shadows */
  --line:      rgba(244,239,231,.10);
  --line-2:    rgba(244,239,231,.06);
  --shadow:    0 24px 60px -24px rgba(0,0,0,.7);
  --shadow-sm: 0 8px 24px -12px rgba(0,0,0,.6);

  /* Geometry */
  --radius:    18px;
  --radius-sm: 12px;
  --radius-lg: 26px;
  --container: 1200px;

  /* Type */
  --font-display: "Bricolage Grotesque", system-ui, sans-serif;
  --font-body:    "Inter", system-ui, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
html.lenis, html.lenis body{ scroll-behavior:auto !important; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:17px; line-height:1.65;
  font-weight:400; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
/* keyboard focus ring — visible even under the custom cursor */
:focus-visible{ outline:2px solid var(--gold); outline-offset:2px; border-radius:4px; }
html.has-cursor :focus-visible{ outline:2px solid var(--gold); }
h1,h2,h3,h4,h5{ font-family:var(--font-display); font-weight:600; line-height:1.05; margin:0;
  letter-spacing:-.02em; }

/* grain atmosphere */
body::after{
  content:""; position:fixed; inset:0; z-index:9998; pointer-events:none; opacity:.035;
  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='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

.container{ width:min(100% - 40px, var(--container)); margin-inline:auto; }
.section-pad{ padding:clamp(64px,9vw,128px) 0; }

/* ---------- Helpers ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:.55em;
  font-size:.74rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold); margin-bottom:1.1rem;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:linear-gradient(90deg,var(--gold),transparent); }
.eyebrow.centered{ justify-content:center; }
.eyebrow.centered::before{ display:none; }

.display{ font-size:clamp(2.6rem,7vw,5.2rem); letter-spacing:-.03em; }
.section-title{ font-size:clamp(1.9rem,4vw,3rem); }
.lead{ font-size:clamp(1.05rem,1.4vw,1.22rem); color:var(--ink-soft); line-height:1.6; max-width:62ch; }

.section-head{ max-width:720px; margin-bottom:3rem; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head.center .lead{ margin-inline:auto; }
.accent{ color:var(--gold); }
.accent-teal{ color:var(--teal); }

/* gradient text for key headline words */
.grad{
  background:linear-gradient(100deg,var(--gold-2),var(--gold) 40%,var(--teal));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ---------- Buttons ---------- */
.btn{
  --b:var(--gold);
  position:relative; display:inline-flex; align-items:center; gap:.55em;
  padding:.92em 1.5em; border-radius:999px; font-weight:600; font-size:.98rem;
  border:1px solid transparent; cursor:pointer; overflow:hidden;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s;
  white-space:nowrap;
}
.btn .arrow{ transition:transform .25s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }
.btn-lg{ padding:1.05em 1.8em; font-size:1.04rem; }

.btn-primary{
  background:linear-gradient(120deg,var(--gold),var(--gold-2));
  color:#1A1407; box-shadow:0 10px 30px -10px rgba(217,178,106,.55);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 40px -12px rgba(217,178,106,.7); }
/* sheen sweep */
.btn-primary::after{
  content:""; position:absolute; top:0; left:-80%; width:55%; height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-18deg); transition:left .6s var(--ease);
}
.btn-primary:hover::after{ left:130%; }

.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }

/* ---------- Header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:200;
  padding:18px 0; transition:padding .3s var(--ease), background .3s, border-color .3s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  padding:10px 0; background:var(--bg-glass);
  backdrop-filter:blur(16px) saturate(140%); border-bottom-color:var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand-mark{ display:grid; place-items:center; }
.brand-text{ display:flex; flex-direction:column; line-height:1.05; }
.brand-name{ font-family:var(--font-display); font-weight:600; font-size:1.18rem; letter-spacing:-.02em; }
.brand-tag{ font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }

.nav-links{ display:flex; gap:1.6rem; list-style:none; margin:0; padding:0; }
.nav-links a{ font-size:.92rem; color:var(--ink-soft); position:relative; padding:.2em 0; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:1.5px;
  background:var(--gold); transition:width .28s var(--ease); }
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:.8rem; }
.nav-toggle{ display:none; background:none; border:1px solid var(--line); border-radius:10px;
  width:42px; height:42px; color:var(--ink); cursor:pointer; padding:9px; }

.mobile-menu{
  position:fixed; inset:0; z-index:190; background:var(--bg); padding:96px 28px 40px;
  display:flex; flex-direction:column; gap:.4rem; transform:translateY(-100%);
  transition:transform .4s var(--ease); visibility:hidden;
}
.mobile-menu.open{ transform:translateY(0); visibility:visible; }
.mobile-menu a{ font-family:var(--font-display); font-size:1.5rem; padding:.6rem 0; border-bottom:1px solid var(--line-2); }
.mobile-menu .btn{ margin-top:1.2rem; justify-content:center; }

.skip-link{ position:absolute; left:-999px; top:0; background:var(--gold); color:#000; padding:.6em 1em; z-index:999; }
.skip-link:focus{ left:8px; top:8px; }

/* ---------- Hero ---------- */
.hero{ position:relative; isolation:isolate; min-height:100svh; display:flex; align-items:center;
  padding:140px 0 80px; overflow:hidden; }
.hero__poster, #hero-gl{ position:absolute; inset:0; width:100%; height:100%; }
.hero__poster{
  z-index:0;
  background:
    radial-gradient(60% 50% at 75% 20%, rgba(95,183,174,.18), transparent 60%),
    radial-gradient(55% 50% at 20% 80%, rgba(217,178,106,.16), transparent 60%),
    linear-gradient(180deg,#0B0E11,#0C1116 60%,#0B0E11);
}
#hero-gl{ z-index:1; }
.hero::before{ /* vignette + readability scrim */
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:radial-gradient(120% 90% at 50% 40%, transparent 40%, rgba(11,14,17,.55));
}
.hero .container{ position:relative; z-index:3; }
.hero-inner{ max-width:880px; }
.hero h1{ margin:.4rem 0 1.4rem; }
.hero .lead{ max-width:60ch; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:1rem; margin:2.2rem 0 0; }

.hero-trust{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; margin-top:3.4rem;
  background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.hero-trust > div{ background:var(--bg-2); padding:1.3rem 1.2rem; }
.stat-num{ font-family:var(--font-display); font-size:clamp(1.5rem,2.6vw,2.1rem); font-weight:600; color:var(--gold-2); }
.stat-label{ font-size:.8rem; color:var(--muted); margin-top:.25rem; }

/* ---------- Audience marquee ---------- */
.audience{ border-block:1px solid var(--line); background:var(--bg-2); padding:1.6rem 0; overflow:hidden; }
.audience-label{ text-align:center; font-size:.74rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); margin:0 0 1rem; }
.audience-row{ display:flex; flex-wrap:wrap; gap:.7rem; justify-content:center; }
.chip{ font-size:.86rem; color:var(--ink-soft); border:1px solid var(--line); border-radius:999px;
  padding:.45em 1.1em; background:var(--bg-3); }

/* ---------- Reveal base ---------- */
[data-reveal]{ opacity:0; }

/* ---------- Premium card ---------- */
.card-hairline{ position:relative; }
.card-hairline::before{
  content:""; position:absolute; inset:0 0 auto 0; height:1px; border-radius:inherit;
  background:linear-gradient(90deg,transparent,rgba(217,178,106,.5),transparent);
}

/* ---------- Leaks ---------- */
.leaks-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.leak{ background:var(--bg-2); padding:1.7rem 1.6rem; transition:background .3s; }
.leak:hover{ background:var(--bg-3); }
.leak-num{ font-family:var(--font-display); font-size:.9rem; color:var(--gold); letter-spacing:.05em; margin-bottom:.7rem; }
.leak h4{ font-size:1.12rem; margin-bottom:.45rem; }
.leak p{ font-size:.94rem; color:var(--muted); margin:0; line-height:1.55; }

/* ---------- Philosophy ---------- */
.philosophy{ background:var(--bg-2); border-block:1px solid var(--line); }
.philosophy-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:3.5rem; align-items:center; }
.not-list{ list-style:none; padding:0; margin:1.8rem 0 0; display:grid; gap:.9rem; }
.not-list li{ display:flex; gap:.8rem; align-items:flex-start; color:var(--ink-soft); }
.mark{ flex:0 0 auto; width:26px; height:26px; border-radius:8px; display:grid; place-items:center; }
.mark svg{ width:15px; height:15px; }
.mark.no{ background:rgba(232,113,76,.14); color:#E8714C; }
.mark.yes{ background:rgba(95,183,174,.16); color:var(--teal); }
.not-list .is-yes{ color:var(--ink); font-weight:500; }
.pull-card{ background:linear-gradient(160deg,var(--bg-3),var(--bg-2)); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:2.4rem; box-shadow:var(--shadow); }
.pull-card blockquote{ margin:0; font-family:var(--font-display); font-size:1.35rem; line-height:1.4; letter-spacing:-.01em; }
.pull-card cite{ display:block; margin-top:1.4rem; color:var(--gold); font-style:normal; font-weight:600; }

/* ---------- Services ---------- */
.services-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.2rem; }
.service-card{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius);
  padding:1.9rem; transition:transform .35s var(--ease), border-color .35s; }
.service-card:hover{ transform:translateY(-5px); border-color:rgba(217,178,106,.4); }
.service-icon{ width:48px; height:48px; border-radius:12px; display:grid; place-items:center;
  background:rgba(217,178,106,.12); color:var(--gold); margin-bottom:1.2rem; }
.service-icon svg{ width:24px; height:24px; }
.service-card h3{ font-size:1.22rem; margin-bottom:.6rem; }
.service-card p{ font-size:.95rem; color:var(--muted); margin:0 0 1.1rem; line-height:1.55; }
.service-tag{ font-size:.74rem; font-weight:600; letter-spacing:.04em; color:var(--teal);
  border:1px solid rgba(95,183,174,.3); border-radius:999px; padding:.3em .85em; display:inline-block; }

/* ---------- Spotlight ---------- */
.spotlight-row{ display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center; }
.spotlight-row.reverse .spotlight-media{ order:2; }
.media-frame{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line);
  box-shadow:var(--shadow); background:var(--bg-3); aspect-ratio:4/3; position:relative; }
.media-frame img{ width:100%; height:100%; object-fit:cover; }
.media-badge{ display:inline-flex; align-items:center; gap:.5em; margin-top:1.1rem; font-size:.82rem;
  color:var(--ink-soft); background:var(--bg-3); border:1px solid var(--line); border-radius:999px; padding:.45em 1em; }
.media-badge .dot{ width:8px; height:8px; border-radius:50%; background:var(--teal); box-shadow:0 0 10px var(--teal); }
.feature-list{ list-style:none; padding:0; margin:1.6rem 0; display:grid; gap:.95rem; }
.feature-list li{ display:flex; gap:.8rem; align-items:flex-start; }
.tick{ flex:0 0 auto; width:24px; height:24px; border-radius:7px; background:rgba(95,183,174,.15);
  color:var(--teal); display:grid; place-items:center; }
.tick svg{ width:14px; height:14px; }
.feature-list span:last-child{ color:var(--ink-soft); }

.itin-mock{ margin-top:1.4rem; background:var(--bg-3); border:1px solid var(--line); border-radius:var(--radius);
  padding:1.4rem; box-shadow:var(--shadow-sm); }
.itin-head{ font-size:.78rem; color:var(--gold); letter-spacing:.08em; text-transform:uppercase; }
.itin-title{ font-family:var(--font-display); font-size:1.15rem; margin:.3rem 0 1rem; }
.itin-item{ display:flex; align-items:center; gap:.7rem; padding:.55rem 0; border-top:1px solid var(--line-2); font-size:.92rem; color:var(--ink-soft); }
.itin-item .ico{ color:var(--teal); }
.itin-item .ico svg{ width:18px; height:18px; }

/* ---------- Results ---------- */
.results{ background:var(--bg-2); border-block:1px solid var(--line); }
.stats-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.2rem; }
.stat-block{ background:var(--bg-3); border:1px solid var(--line); border-radius:var(--radius); padding:1.8rem; }
.stat-block .big{ font-family:var(--font-display); font-size:clamp(2rem,3.4vw,2.7rem); color:var(--gold-2); font-weight:600; }
.stat-block .desc{ margin-top:.4rem; font-weight:500; }
.stat-block .src{ font-size:.8rem; color:var(--faint); margin-top:.5rem; }
.results-note{ font-size:.84rem; color:var(--faint); max-width:75ch; margin:2rem auto 0; text-align:center; }

/* ---------- Compare ---------- */
.compare-table{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.compare-row{ display:grid; grid-template-columns:1.1fr 1fr 1fr; }
.compare-row > div{ padding:1.1rem 1.4rem; border-top:1px solid var(--line); }
.compare-row.head > div{ border-top:none; font-family:var(--font-display); font-size:.95rem; background:var(--bg-3); }
.compare-row .label{ color:var(--muted); font-size:.92rem; background:var(--bg-2); }
.compare-row .alt{ color:var(--muted); }
.compare-row .me{ background:rgba(217,178,106,.06); color:var(--ink); font-weight:500; }
.compare-row.head .me{ color:var(--gold); background:rgba(217,178,106,.1); }

/* ---------- About ---------- */
.about{ background:var(--bg-2); border-block:1px solid var(--line); }
.about-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:3.5rem; align-items:center; }
.about-portrait{ position:relative; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line);
  box-shadow:var(--shadow); aspect-ratio:3/4; background:var(--bg-3); }
.about-portrait img{ width:100%; height:100%; object-fit:cover; }
.ribbon{ position:absolute; left:14px; right:14px; bottom:14px; background:var(--bg-glass);
  backdrop-filter:blur(10px); border:1px solid var(--line); border-radius:12px; padding:.7rem 1rem; font-size:.84rem; color:var(--ink-soft); }
.ribbon strong{ display:block; color:var(--ink); font-family:var(--font-display); }
.about p{ color:var(--ink-soft); }
.creds{ list-style:none; padding:0; margin:1.6rem 0 0; display:grid; gap:.7rem; }
.creds li{ display:flex; gap:.6rem; align-items:center; font-size:.95rem; color:var(--ink-soft); }
.creds svg{ width:17px; height:17px; color:var(--teal); flex:0 0 auto; }

/* ---------- Steps ---------- */
.steps-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.step{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:1.9rem; }
.step-num{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center;
  font-family:var(--font-display); font-weight:600; background:linear-gradient(120deg,var(--gold),var(--gold-2));
  color:#1A1407; margin-bottom:1.1rem; }
.step h3{ font-size:1.18rem; margin-bottom:.5rem; }
.step p{ color:var(--muted); font-size:.95rem; margin:0; }

/* ---------- Calculator ---------- */
.calc{ background:var(--bg-2); border-block:1px solid var(--line); }
.calc-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:2.2rem; align-items:start; }
.calc-form{ background:var(--bg-3); border:1px solid var(--line); border-radius:var(--radius); padding:2rem; display:grid; gap:1.3rem; }
.calc-field label{ display:block; font-size:.92rem; margin-bottom:.5rem; color:var(--ink-soft); }
.calc-field input[type=number], .calc-field select{
  width:100%; background:var(--bg); border:1px solid var(--line); border-radius:10px; color:var(--ink);
  padding:.75em .9em; font-size:1rem; font-family:inherit; }
.calc-field input:focus, .calc-field select:focus{ outline:none; border-color:var(--gold); }
.calc-affix{ display:flex; align-items:center; background:var(--bg); border:1px solid var(--line); border-radius:10px; overflow:hidden; }
.calc-affix .affix{ padding:0 .8em; color:var(--muted); }
.calc-affix input{ border:none !important; background:transparent !important; }
.calc-field input[type=range]{ width:100%; accent-color:var(--gold); }
.opt{ color:var(--faint); font-weight:400; }

.calc-results{ background:linear-gradient(160deg,var(--bg-3),var(--bg-2)); border:1px solid rgba(217,178,106,.3);
  border-radius:var(--radius-lg); padding:2.2rem; box-shadow:var(--shadow); position:sticky; top:90px; }
.calc-result-label{ font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); }
.calc-added{ margin:.6rem 0 1.4rem; }
#calcAddedRange{ font-family:var(--font-display); font-size:clamp(2.2rem,5vw,3.2rem); font-weight:600; color:var(--gold-2); display:block; }
.calc-per{ color:var(--muted); font-size:.9rem; }
.calc-rows{ display:grid; gap:.1rem; border:1px solid var(--line); border-radius:12px; overflow:hidden; margin-bottom:1.4rem; }
.calc-row{ display:flex; justify-content:space-between; padding:.75rem 1rem; background:var(--bg); border-top:1px solid var(--line-2); font-size:.92rem; }
.calc-row:first-child{ border-top:none; }
.calc-row span{ color:var(--muted); }
.calc-row.fee strong{ color:var(--teal); }
.calc-cta{ width:100%; justify-content:center; }
.calc-disclaimer{ font-size:.78rem; color:var(--faint); margin:1rem 0 0; }

/* ---------- FAQ ---------- */
.faq-list{ max-width:820px; margin-inline:auto; display:grid; gap:.8rem; }
.faq-item{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius-sm); overflow:hidden; }
.faq-item summary{ cursor:pointer; list-style:none; padding:1.2rem 1.4rem; font-family:var(--font-display);
  font-size:1.08rem; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-icon{ flex:0 0 auto; width:22px; height:22px; position:relative; }
.faq-icon::before,.faq-icon::after{ content:""; position:absolute; inset:0; margin:auto; background:var(--gold); transition:transform .3s var(--ease); }
.faq-icon::before{ width:13px; height:1.5px; }
.faq-icon::after{ width:1.5px; height:13px; }
.faq-item[open] .faq-icon::after{ transform:rotate(90deg); opacity:0; }
.faq-body{ padding:0 1.4rem 1.3rem; }
.faq-body p{ margin:0; color:var(--muted); }

/* ---------- Contact ---------- */
.contact{ background:var(--bg-2); border-top:1px solid var(--line); }
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:3.5rem; align-items:start; }
.contact-points{ list-style:none; padding:0; margin:2rem 0 0; display:grid; gap:1.3rem; }
.contact-points li{ display:flex; gap:1rem; align-items:center; }
.cp-ico{ flex:0 0 auto; width:44px; height:44px; border-radius:12px; background:rgba(217,178,106,.12);
  color:var(--gold); display:grid; place-items:center; }
.cp-ico svg{ width:20px; height:20px; }
.cp-label{ font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.cp-value{ font-size:1.05rem; color:var(--ink); }

.contact-form{ background:var(--bg-3); border:1px solid var(--line); border-radius:var(--radius-lg); padding:2.2rem; }
.contact-form h3{ font-size:1.4rem; margin-bottom:.4rem; }
.form-sub{ color:var(--muted); margin:0 0 1.6rem; font-size:.95rem; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field{ margin-bottom:1rem; }
.field label{ display:block; font-size:.88rem; margin-bottom:.45rem; color:var(--ink-soft); }
.req{ color:var(--gold); }
.field input, .field select, .field textarea{
  width:100%; background:var(--bg); border:1px solid var(--line); border-radius:10px; color:var(--ink);
  padding:.78em .9em; font-size:1rem; font-family:inherit; }
.field textarea{ min-height:120px; resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--gold); }
.contact-form .btn{ width:100%; justify-content:center; margin-top:.4rem; }
.form-note{ font-size:.82rem; color:var(--faint); margin:.9rem 0 0; text-align:center; }
.form-success{ display:none; background:rgba(95,183,174,.12); border:1px solid rgba(95,183,174,.4);
  color:var(--teal-2); border-radius:10px; padding:1rem 1.2rem; margin-bottom:1.2rem; font-size:.95rem; }
.form-success.show{ display:block; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--bg); border-top:1px solid var(--line); padding:4rem 0 2rem; position:relative; overflow:hidden; }
.footer-top{ display:grid; grid-template-columns:1.4fr 2fr; gap:3rem; padding-bottom:2.5rem; border-bottom:1px solid var(--line); }
.footer-brand .brand-name{ font-family:var(--font-display); font-size:1.4rem; }
.footer-by{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:1rem; }
.footer-brand p{ color:var(--muted); font-size:.92rem; max-width:36ch; }
.footer-links{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.footer-col h5{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin:0 0 1rem; }
.footer-col a{ display:block; color:var(--ink-soft); font-size:.92rem; padding:.3rem 0; transition:color .2s; }
.footer-col a:hover{ color:var(--gold); }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; padding-top:1.6rem;
  font-size:.84rem; color:var(--faint); }
.footer-watermark{ position:absolute; left:0; bottom:-3vw; width:100%; text-align:center;
  font-family:var(--font-display); font-weight:700; font-size:18vw; line-height:.8;
  color:transparent; -webkit-text-stroke:1px rgba(244,239,231,.05); pointer-events:none; user-select:none; }

/* ---------- Mobile sticky CTA ---------- */
.mobile-cta-bar{ display:none; position:fixed; left:0; right:0; bottom:0; z-index:150; gap:.7rem; padding:.7rem 1rem;
  background:var(--bg-glass); backdrop-filter:blur(14px); border-top:1px solid var(--line); }
.mcta-call{ display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px;
  width:58px; border:1px solid var(--line); border-radius:12px; color:var(--ink); font-size:.7rem; }
.mcta-call svg{ width:20px; height:20px; }
.mcta-schedule{ flex:1; justify-content:center; }

/* ---------- 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; z-index:10000; pointer-events:none;
  border-radius:50%; transform:translate(-50%,-50%); }
.cursor-dot{ width:7px; height:7px; background:var(--gold); }
.cursor-ring{ width:34px; height:34px; border:1.5px solid var(--teal); transition:width .25s,height .25s,background .25s,border-color .25s; }
.cursor-ring.bloom{ width:54px; height:54px; background:rgba(95,183,174,.1); border-color:var(--gold); }
.cursor-hide{ opacity:0; }

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .philosophy-grid,.spotlight-row,.about-grid,.calc-grid,.contact-grid,.footer-top{ grid-template-columns:1fr; gap:2.5rem; }
  .spotlight-row.reverse .spotlight-media{ order:0; }
  .steps-grid{ grid-template-columns:1fr; }
  .compare-row{ grid-template-columns:1fr; }
  .compare-row > div{ border-top:1px solid var(--line); }
  .compare-row.head{ display:none; }
}
@media (max-width:860px){
  .nav-links, .nav-cta .btn-primary{ display:none; }
  .nav-toggle{ display:block; }
  .hero-trust{ grid-template-columns:repeat(2,1fr); }
  .footer-links{ grid-template-columns:1fr 1fr; }
  .mobile-cta-bar{ display:flex; }
  body{ padding-bottom:70px; }
}
@media (max-width:520px){
  .form-row{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  [data-reveal]{ opacity:1 !important; }
}
