/* CLOUD 9 AV PRODUCTIONS — c9.css  v18
 * Architecture: tokens → global → homepage → interior → footer → responsive → v17
 * Deduplication: single reset, single token block, homepage base before responsive overrides
 */

/* CLOUD 9 AV PRODUCTIONS — c9.css  v5 */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scrollbar-gutter:stable}
body{overflow-x:hidden;overscroll-behavior-y:none}
img,video{max-width:100%;height:auto;display:block}
button{cursor:pointer;font:inherit;border:none;background:none}
ul,ol{list-style:none}
a{text-decoration:none;color:inherit}

/* DESIGN TOKENS — DARK MODE  (root / default) */
:root {
  color-scheme: dark;
  /* Each accent has one primary use case: */
  --cyan:         #f5a623;   /* warm amber gold — inviting event energy   */
  --cyan-dim:     rgba(245,166,35,0.13);
  --cyan-glow:    rgba(245,166,35,0.42);
  --cyan-strong:  rgba(245,166,35,0.60);   /* for focus rings            */

  --magenta:      #ff5e62;   /* warm coral-red — energetic                */
  --mag-dim:      rgba(255,94,98,0.11);
  --mag-glow:     rgba(255,94,98,0.35);

  --gold:         #ffd166;   /* bright warm yellow — celebration          */
  --gold-dim:     rgba(255,209,102,0.14);

  --electric:     #6244f5;   /* richer purple — more blue, less violet    */
  --elec-dim:     rgba(98,68,245,0.12);

  /* Warm dark tones for inviting event-night feel */
  --page:         #100c06;   /* L0 — deepest: warm near-black             */
  --surf:         #181008;   /* L1 — section backgrounds, footer          */
  --surf2:        #201608;   /* L2 — cards, dropdowns, inputs             */
  --surf3:        #2a1e0c;   /* L3 — hover state fill                     */
  --surf4:        #362810;   /* L4 — active / selected state fill         */

  /* Warm-tinted alpha borders */
  --bdr:          rgba(200,150,80,0.12);   /* default subtle separator    */
  --bdr-s:        rgba(200,150,80,0.24);   /* strong / emphasis           */
  --bdr-f:        rgba(245,166,35,0.60);   /* focus ring [NEW]            */

  /* All tones have a slight warm tint that harmonises */
  --t1:           #f2ece0;   /* primary   — headings, key content          */
  --t2:           #9a8e7c;   /* secondary — body text, descriptions        */
  --t3:           #5c5040;   /* tertiary  — meta, labels, captions         */
  --t4:           #3a2e20;   /* muted     — disabled, placeholders [NEW]   */

  /* Used for hover/active background overlays on any surface. */
  --fill-hover:   rgba(245,166,35,0.08);   /* gentle hover bg             */
  --fill-active:  rgba(245,166,35,0.16);   /* pressed/active bg           */

  /* Used only for explicit state communication. */
  --c-ok:         #12c870;   /* success                                    */
  --c-ok-dim:     rgba(18,200,112,0.12);
  --c-err:        #f04055;   /* error                                      */
  --c-err-dim:    rgba(240,64,85,0.12);
  --c-warn:       var(--gold);
  --c-warn-dim:   var(--gold-dim);

  
  --nav-bg:       rgba(16,12,6,0.88);
  --nav-bdr:      rgba(200,150,80,0.12);

  
  --r:            4px;
  --r2:           2px;
  --r3:           6px;
  --f-disp:       'Barlow Condensed', sans-serif;
  --f-body:       'Barlow', sans-serif;
  --f-mono:       'Space Mono', monospace;
  --ease-out:     cubic-bezier(0.16,1,0.3,1);
  --ease-spr:     cubic-bezier(0.34,1.56,0.64,1);
  --nav-h:        66px;
  --wrap:         min(82rem, calc(100% - clamp(2rem,5vw,5rem)));

  
  --text-1:       var(--t1);
  --text-2:       var(--t2);
  --text-3:       var(--t3);
  --nav-glass:    var(--nav-bg);
  --bdr-strong:   var(--bdr-s);
}

/* DESIGN TOKENS — LIGHT MODE */
[data-theme="light"] {
  color-scheme: light;
  /* Darker amber for WCAG AA (4.5:1) on light surfaces. */
  --cyan:         #b86800;   /* AA-compliant deep amber on white          */
  --cyan-dim:     rgba(184,104,0,0.10);
  --cyan-glow:    rgba(184,104,0,0.28);
  --cyan-strong:  rgba(184,104,0,0.50);

  --magenta:      #e03030;   /* warm red on light bg                      */
  --mag-dim:      rgba(224,48,48,0.09);
  --mag-glow:     rgba(224,48,48,0.28);

  --gold:         #c07800;   /* Rich amber, AA on white                   */
  --gold-dim:     rgba(192,120,0,0.10);

  --electric:     #7b4a00;   /* warm brown-orange, AA on white            */
  --elec-dim:     rgba(123,74,0,0.10);

  /* Warm cream tones for a welcoming event-company feel */
  --page:         #fdf8f0;   /* L0 — warm cream page bg                   */
  --surf:         #f5ede0;   /* L1 — section backgrounds                  */
  --surf2:        #ece0cc;   /* L2 — cards, inputs                        */
  --surf3:        #e0d0b8;   /* L3 — hover fills                          */
  --surf4:        #d4c0a0;   /* L4 — active state fill                    */

  /* Warm amber-tinted borders */
  --bdr:          rgba(140,90,20,0.10);
  --bdr-s:        rgba(140,90,20,0.20);
  --bdr-f:        rgba(184,104,0,0.50);

  /* Warm dark tones for text on cream */
  --t1:           #1a0e00;   /* primary   — near black warm               */
  --t2:           #4a3420;   /* secondary — dark brown                    */
  --t3:           #7a6040;   /* tertiary  — medium warm brown             */
  --t4:           #b09070;   /* muted     — disabled/placeholder          */

  --fill-hover:   rgba(184,104,0,0.08);
  --fill-active:  rgba(184,104,0,0.15);

  --c-ok:         #1a8a40;
  --c-ok-dim:     rgba(26,138,64,0.10);
  --c-err:        #d42840;
  --c-err-dim:    rgba(212,40,64,0.10);

  --nav-bg:       rgba(253,248,240,0.94);
  --nav-bdr:      rgba(140,90,20,0.10);

  --text-1:       var(--t1);
  --text-2:       var(--t2);
  --text-3:       var(--t3);
  --nav-glass:    var(--nav-bg);
  --bdr-strong:   var(--bdr-s);
}

/* THEME TRANSITION — only colour properties, never layout */
html { transition: background-color 0.30s ease, color 0.30s ease; }

*:not(.ph-beam):not(.ph-floor):not(.beam):not(.pool):not(.vis-bar):not(.live-dot):not(.stage-line):not(.ticker-track) {
  transition:
    background-color 0.20s ease,
    border-color     0.20s ease,
    color            0.16s ease,
    box-shadow       0.20s ease,
    opacity          0.20s ease;
}

/* NOISE GRAIN — film texture overlay */
body::before {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 9998;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.028;
}
[data-theme="light"] body::before { opacity: 0.016; }

body {
  font-family: var(--f-body); font-size: 17px;
  color: var(--t1); background: var(--page); line-height: 1.6;
}

/* Selection — teal bg with dark text for max legibility */
::selection { background: var(--cyan); color: #000; }
[data-theme="light"] ::selection { background: var(--cyan); color: #000; }

/* SCROLLBAR — themed to match surface palette */
::-webkit-scrollbar              { width: 7px; height: 7px; }
::-webkit-scrollbar-track        { background: var(--page); }
::-webkit-scrollbar-thumb        { background: var(--surf3); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover  { background: var(--cyan); }





/* NAVIGATION */
.nav {
  position: fixed; inset-block-start: 0; inset-inline: 0;
  z-index: 900; height: var(--nav-h);
  display: flex; align-items: center; justify-content: space-between;
  padding-inline: clamp(1.25rem,4vw,3rem);
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom: 1px solid transparent;
  transition: background .35s ease, border-color .35s ease, backdrop-filter .35s ease;
}
.nav.scrolled {
  box-shadow: 0 1px 0 var(--nav-bdr), 0 8px 32px rgba(16,12,6,0.3);
  background: var(--nav-bg);
  backdrop-filter: saturate(180%) blur(24px);
  -webkit-backdrop-filter: saturate(180%) blur(24px);
  border-bottom: 1px solid var(--nav-bdr);
}
[data-theme="light"] .nav.scrolled {
  box-shadow: 0 1px 0 var(--nav-bdr), 0 4px 24px rgba(40,50,120,0.06);
}

/* Logo */
.nav-logo {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--f-disp); font-weight: 800;
  font-size: 1.2rem; letter-spacing: 0.06em; color: var(--t1);
}
.nav-logo-mark {
  width: 36px; height: 36px;
  background: linear-gradient(135deg, var(--cyan), #ff8c00);
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.85rem; font-weight: 900; color: #fff; letter-spacing: 0;
  flex-shrink: 0;
  box-shadow: 0 0 16px var(--cyan-glow);
}
.nav-logo:hover .nav-logo-mark { box-shadow: 0 0 28px var(--cyan-glow); }

/* Desktop links */
.nav-desktop-links {
  display: none; align-items: center; gap: 2rem;
  font-family: var(--f-body); font-weight: 900;
  font-size: 0.9rem; color: var(--t3);
}
@media(min-width:900px){
   .nav-desktop-links { display: flex; } }
.nav-desktop-links > li > a { color: var(--t1); }
.nav-desktop-links > li > a:hover { color: var(--cyan); }

/* Dropdown */
.nav-has-dd { position: relative; }
.nav-dd {
  position: absolute; top: calc(100% + 6px); left: 50%;
  transform: translateX(-50%) translateY(-6px);
  background: var(--surf2);
  border: 1px solid var(--bdr-s); border-radius: var(--r);
  padding: 0.5rem; min-width: 260px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 2px;
  opacity: 0; pointer-events: none;
  box-shadow: 0 20px 60px rgba(16,12,6,0.5), 0 0 0 1px var(--bdr);
  transition: opacity 0.16s var(--ease-out), transform 0.18s var(--ease-out) !important;
}
[data-theme="light"] .nav-dd {
  box-shadow: 0 16px 48px rgba(40,50,120,0.12), 0 0 0 1px var(--bdr);
}
.nav-dd::before { content: ''; position: absolute; top: -10px; left: 0; right: 0; height: 10px; }
.nav-has-dd.dd-open .nav-dd { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.nav-dd a {
  display: flex; align-items: center; gap: 8px;
  padding: 0.52rem 0.75rem; border-radius: var(--r2);
  font-size: 0.84rem; color: var(--t2);
}
.nav-dd a:hover { background: var(--surf3); color: var(--cyan); }
.nav-dd a i { font-size: 0.88rem; color: var(--cyan); flex-shrink: 0; }

/* Nav actions */
.nav-actions { display: flex; align-items: center; gap: 0.6rem; }

/* Theme button */
.theme-btn {
  width: 36px; height: 36px; border-radius: var(--r);
  /* background: var(--surf2); border: 1px solid var(--bdr); */
  color: var(--t3);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.95rem;
}
.theme-btn:hover { background: var(--surf3); color: var(--cyan); border-color: var(--bdr-s); }
.theme-btn:focus-visible { outline: 2px solid var(--bdr-f); outline-offset: 2px; }

/* Book button */
.nav-book-btn {
  display: none;
  padding: 0.5rem 1.15rem;
  background: var(--cyan); color: #1a0e00;
  border-radius: var(--r2);
  font-weight: 700; font-size: 0.875rem;
  font-family: var(--f-body); letter-spacing: 0.04em; text-transform: uppercase;
}
@media(min-width:900px){ .nav-book-btn { display: block; } }
.nav-book-btn:hover { box-shadow: 0 0 24px var(--cyan-glow), 0 4px 16px rgba(16,12,6,0.2); transform: translateY(-1px); }
.nav-book-btn:active { transform: translateY(0) scale(0.98); }
.nav-book-btn:focus-visible { outline: 2px solid var(--bdr-f); outline-offset: 3px; }

/* Hamburger */
.nav-hbg { display: flex; flex-direction: column; gap: 5px; padding: 8px; }
@media(min-width:900px){ .nav-hbg { display: none; } }
.nav-hbg span { display: block; width: 22px; height: 2px; background: var(--t2); border-radius: 1px; transition: transform 0.3s, opacity 0.3s !important; }
.nav-hbg:hover span { background: var(--t1); }
.nav-hbg.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-hbg.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-hbg.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.menu-overlay {
  position: fixed; inset: 0; z-index: 800;
  background: var(--page);
  transform: translateX(100%);
  transition: transform 0.4s var(--ease-out) !important;
  padding: 0 1.5rem 2rem; overflow-y: auto;
  display: flex; flex-direction: column;
}
.menu-overlay.open { transform: translateX(0); }
.menu-top { display: flex; align-items: center; justify-content: space-between; height: var(--nav-h); flex-shrink: 0; }
.menu-close-btn { font-size: 1.4rem; color: var(--t1); padding: 8px; }
.menu-close-btn:hover { color: var(--cyan); }
.menu-body { flex: 1; padding-block: 1.5rem; }
.menu-link {
  display: block; font-family: var(--f-disp); font-weight: 700;
  font-size: clamp(2rem,8vw,2.8rem); letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--t1); padding-block: 0.5rem; border-bottom: 1px solid var(--bdr);
}
.menu-link:hover { color: var(--cyan); padding-left: 0.75rem; }
.menu-svc-toggle {
  display: flex; align-items: center; justify-content: space-between; width: 100%;
  font-family: var(--f-disp); font-weight: 700;
  font-size: clamp(2rem,8vw,2.8rem); letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--t2); padding-block: 0.5rem; border-bottom: 1px solid var(--bdr);
}
.menu-svc-sub { max-height: 0; overflow: hidden; transition: max-height 0.4s var(--ease-out) !important; display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
.menu-svc-sub.open { max-height: 600px; padding-block: 0.75rem; }
.menu-svc-sub a { display: flex; align-items: center; gap: 8px; font-size: 0.875rem; color: var(--t2); padding: 0.6rem 0.75rem; border-radius: var(--r2); background: var(--surf); border: 1px solid var(--bdr); }
.menu-svc-sub a:hover { background: var(--surf3); color: var(--cyan); border-color: var(--bdr-s); }
.menu-footer { border-top: 1px solid var(--bdr); padding-top: 1.5rem; }
.menu-phones { display: flex; gap: 2rem; margin-bottom: 1.5rem; }
.m-ph-lbl { display: block; font-size: 0.7rem; color: var(--t3); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: .25rem; }
.m-ph-num { font-size: 1.1rem; font-weight: 700; color: var(--cyan); }

/* BUTTONS — full state system (default/hover/active/focus/disabled) */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--f-body); font-weight: 700;
  font-size: 0.9rem; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 0.75rem 1.5rem; border-radius: var(--r2);
  cursor: pointer; white-space: nowrap;
  position: relative;
}
.btn:focus-visible { outline: 2px solid var(--bdr-f); outline-offset: 3px; }
.btn:disabled, .btn[aria-disabled="true"] {
  opacity: 0.4; cursor: not-allowed; transform: none !important; box-shadow: none !important;
}

/* Solid — primary CTA */
.btn-solid { background: var(--cyan); color: #1a0e00; font-weight: 800; }
.btn-solid:hover { box-shadow: 0 0 24px var(--cyan-glow), 0 4px 16px rgba(16,12,6,0.25); transform: translateY(-2px); }
.btn-solid:active { transform: translateY(0) scale(0.98); box-shadow: 0 0 12px var(--cyan-glow); }

/* Ghost — secondary action */
.btn-ghost { background: transparent; color: var(--t1); border: 1px solid var(--bdr-s); }
.btn-ghost:hover { border-color: var(--cyan); color: var(--cyan); background: var(--fill-hover); }
.btn-ghost:active { background: var(--fill-active); }

/* Outline — accent CTA */
.btn-outline { background: transparent; color: var(--cyan); border: 1px solid var(--cyan); }
.btn-outline:hover { background: var(--cyan); color: #fff; box-shadow: 0 0 20px var(--cyan-glow); }
.btn-outline:active { transform: scale(0.98); }

/* Dim — tertiary / low-emphasis */
.btn-dim { background: var(--surf2); color: var(--t1); border: 1px solid var(--bdr); }
.btn-dim:hover { background: var(--surf3); border-color: var(--bdr-s); }
.btn-dim:active { background: var(--surf4); }

/* Danger */
.btn-danger { background: var(--c-err); color: #fff; }
.btn-danger:hover { box-shadow: 0 0 20px var(--c-err-dim); transform: translateY(-1px); }

/* FORM ELEMENTS — complete state system */
.c9-label {
  display: block; font-size: 0.8rem; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--t3); margin-bottom: 0.5rem;
}

.c9-input, .c9-textarea, .c9-select {
  width: 100%;
  background: var(--surf2);
  border: 1px solid var(--bdr);
  border-radius: var(--r);
  color: var(--t1);
  font-family: var(--f-body); font-size: 1rem;
  padding: 0.75rem 1rem;
  appearance: none;
}
.c9-input::placeholder, .c9-textarea::placeholder { color: var(--t4); }

.c9-input:hover, .c9-textarea:hover, .c9-select:hover {
  border-color: var(--bdr-s);
  background: var(--surf3);
}
.c9-input:focus, .c9-textarea:focus, .c9-select:focus {
  border-color: var(--cyan);
  box-shadow: 0 0 0 3px var(--bdr-f);
  outline: none;
  background: var(--surf2);
}
.c9-input.is-error, .c9-textarea.is-error {
  border-color: var(--c-err);
}
.c9-input.is-error:focus, .c9-textarea.is-error:focus {
  box-shadow: 0 0 0 3px var(--c-err-dim);
}
.c9-input:disabled, .c9-textarea:disabled {
  opacity: 0.45; cursor: not-allowed; background: var(--surf);
}

.c9-field-msg {
  font-size: 0.78rem; margin-top: 0.35rem; color: var(--t3);
}
.c9-field-msg.is-error { color: var(--c-err); }
.c9-field-msg.is-ok    { color: var(--c-ok);  }

.c9-textarea { min-height: 120px; resize: vertical; }

/* LAYOUT UTILITIES */
.wrap        { width: var(--wrap); margin-inline: auto; }
.section     { padding-block: clamp(5rem,10vw,8rem); }
.bg-surf     { background: var(--surf); }
.text-center { text-align: center; }

/* Eyebrow label */
.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--f-mono); font-size: 0.7rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--cyan); margin-bottom: 1rem;
}
.eyebrow::before { content: ''; display: block; width: 24px; height: 1px; background: var(--cyan); }

/* Section headings */
.sec-title {
  font-family: var(--f-disp); font-weight: 900;
  font-size: clamp(2.8rem,6vw,5.2rem);
  line-height: 0.92; letter-spacing: -0.01em; text-transform: uppercase;
  color: var(--t1);
  text-wrap: balance;
}
.sec-title em  { font-style: normal; color: var(--cyan); }
.sec-sub { font-size: clamp(0.95rem,2vw,1.1rem); color: var(--t2); max-width: 52ch; line-height: 1.75; }

/* Dividers */
.divider { height: 1px; background: var(--bdr); margin-block: 2rem; }
.divider-accent { height: 1px; background: linear-gradient(to right, transparent, var(--cyan), transparent); }

/* Scroll reveal */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.65s var(--ease-out), transform 0.65s var(--ease-out) !important; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.d1{transition-delay:.10s}.d2{transition-delay:.18s}.d3{transition-delay:.26s}.d4{transition-delay:.34s}

/* FOOTER */
.footer { background: var(--surf); border-top: 1px solid var(--bdr); }
.footer-inner { width: var(--wrap); margin-inline: auto; padding-block: clamp(4rem,8vw,6rem); }
.footer-top { display: grid; grid-template-columns: 1fr; gap: 3rem; margin-bottom: 3rem; }
@media(min-width:600px){ .footer-top { grid-template-columns: 1fr 1fr; } }
@media(min-width:900px){ .footer-top { grid-template-columns: 2fr 1fr 1fr 1.5fr; } }

.f-brand { display: flex; align-items: center; gap: 10px; font-family: var(--f-disp); font-weight: 800; font-size: 1.15rem; letter-spacing: 0.06em; color: var(--t1); margin-bottom: 1rem; }
.f-brand-mark { width: 34px; height: 34px; background: linear-gradient(135deg,var(--cyan),var(--electric)); border-radius: 5px; display: flex; align-items: center; justify-content: center; font-size: 0.78rem; font-weight: 900; color: #fff; flex-shrink: 0; }
.f-tagline { font-size: 0.875rem; color: var(--t3); line-height: 1.7; margin-bottom: 1.5rem; max-width: 27ch; }

.f-social { display: flex; gap: .4rem; margin-bottom: 1.5rem; }
.f-soc { width: 34px; height: 34px; background: var(--surf2); border: 1px solid var(--bdr); border-radius: var(--r); display: flex; align-items: center; justify-content: center; font-size: .88rem; color: var(--t3); }
.f-soc:hover { background: var(--surf3); color: var(--cyan); border-color: var(--bdr-s); }
.f-soc:focus-visible { outline: 2px solid var(--bdr-f); outline-offset: 2px; }

.f-badges { display: flex; flex-wrap: wrap; gap: .4rem; }
.f-badge { display: inline-flex; align-items: center; gap: 5px; font-size: .68rem; font-weight: 600; letter-spacing: .04em; padding: .28rem .6rem; background: var(--surf2); border: 1px solid var(--bdr); border-radius: 2px; color: var(--t2); }
.f-badge i { color: var(--cyan); }

.f-col-h { font-family: var(--f-mono); font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--cyan); margin-bottom: 1.1rem; }
.f-links { display: flex; flex-direction: column; gap: .55rem; }
.f-links a { display: flex; align-items: center; gap: 8px; font-size: .875rem; color: var(--t2); }
.f-links a:hover { color: var(--cyan); padding-left: 4px; }
.f-links i { font-size: .78rem; color: var(--t3); }

.f-contact { display: flex; gap: .75rem; margin-bottom: .9rem; font-size: .875rem; color: var(--t2); }
.f-contact i { color: var(--cyan); margin-top: 2px; flex-shrink: 0; }
.f-contact a { color: var(--t2); }
.f-contact a:hover { color: var(--cyan); }

.footer-bot { border-top: 1px solid var(--bdr); padding-top: 1.5rem; display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; justify-content: space-between; }
.f-copy { font-size: .78rem; color: var(--t4); }
.f-bot-nav { display: flex; flex-wrap: wrap; gap: 1.5rem; }
.f-bot-nav a { font-size: .78rem; color: var(--t4); }
.f-bot-nav a:hover { color: var(--t2); }

/* PAGE-LEVEL PADDING */
.page-top { padding-top: calc(var(--nav-h) + clamp(2rem,5vw,4rem)); }

/* PAGE HERO — Base Styles (all interior pages) */
.page-hero {
  position: relative; min-height: 62vh; display: flex; align-items: center;
  padding-top: var(--nav-h); overflow: hidden;
  background: var(--page);
}
.ph-beams { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 1; }
.ph-beam {
  position: absolute; width: 1.5px; bottom: 0; transform-origin: bottom center;
  opacity: 0; animation: phBeam 8s ease-in-out infinite;
}
.ph-beam::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, transparent 0%, rgba(245,166,35,0.55) 40%, transparent);
  filter: blur(1px);
}
.ph-beam.m::after { background: linear-gradient(to top, transparent 0%, rgba(242,0,122,0.50) 40%, transparent); }
.ph-beam.e::after { background: linear-gradient(to top, transparent 0%, rgba(98,68,245,0.50) 40%, transparent); }
.ph-beam:nth-child(1){left:10%;height:50%;animation-delay:0s;--deg:-20deg}
.ph-beam:nth-child(2){left:30%;height:40%;animation-delay:1.5s;--deg:-8deg}
.ph-beam:nth-child(3){left:55%;height:55%;animation-delay:0.8s;--deg:6deg}
.ph-beam:nth-child(4){left:78%;height:42%;animation-delay:2.2s;--deg:22deg}
.ph-beam:nth-child(5){left:92%;height:35%;animation-delay:3.5s;--deg:32deg}
@keyframes phBeam {
  0%  {opacity:0;transform:rotate(var(--deg,0deg)) scaleY(0.4)}
  25% {opacity:0.8}
  60% {opacity:0.4;transform:rotate(calc(var(--deg,0deg)+5deg)) scaleY(1)}
  85% {opacity:0.7}
  100%{opacity:0;transform:rotate(var(--deg,0deg)) scaleY(0.4)}
}

.ph-floor {
  position: absolute; bottom: 0; left: 0; right: 0; height: 1px; z-index: 2;
  background: linear-gradient(to right, transparent, var(--cyan), var(--magenta), transparent);
  animation: stagePulse 4s ease-in-out infinite;
}
@keyframes stagePulse { 0%,100%{opacity:0.3} 50%{opacity:1} }

.ph-inner {
  position: relative; z-index: 3;
  width: var(--wrap); margin-inline: auto;
  padding-block: clamp(3rem,6vw,5rem);
}
.ph-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--f-mono); font-size: 0.68rem; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--cyan); margin-bottom: 1.25rem;
  opacity: 0; animation: fadeUp 0.8s 0.2s var(--ease-out) forwards;
}
.ph-h1 {
  font-family: var(--f-disp); font-weight: 900;
  font-size: clamp(3.5rem,10vw,8rem); line-height: 0.88;
  letter-spacing: -0.02em; text-transform: uppercase; color: var(--t1);
  margin-bottom: 1.25rem;
  opacity: 0; animation: fadeUp 0.9s 0.4s var(--ease-out) forwards;
}
.ph-h1 em   { font-style: normal; color: var(--cyan); }
.ph-h1 .out { color: transparent; -webkit-text-stroke: 2px var(--cyan); }
.ph-sub {
  font-size: clamp(1rem,2vw,1.15rem); color: var(--t2);
  max-width: 50ch; line-height: 1.75;
  opacity: 0; animation: fadeUp 0.9s 0.6s var(--ease-out) forwards;
}
.ph-btns {
  display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 2rem;
  opacity: 0; animation: fadeUp 0.9s 0.78s var(--ease-out) forwards;
}
@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

.ph-icon-bg {
  position: absolute; right: 8%; top: 50%; transform: translateY(-50%);
  font-size: clamp(8rem,20vw,18rem);
  color: var(--cyan); opacity: 0; pointer-events: none; line-height: 1;
  animation: fadeInIcon 1s 0.8s ease forwards; z-index: 2;
}
@keyframes fadeInIcon       { from{opacity:0} to{opacity:0.05} }
@keyframes fadeInIconLight  { from{opacity:0} to{opacity:0.07} }

/* Light mode hero beam tuning */
[data-theme="light"] .ph-beam::after {
  background: linear-gradient(to top, transparent 0%, rgba(184,104,0,0.42) 40%, transparent);
}
[data-theme="light"] .ph-beam.m::after {
  background: linear-gradient(to top, transparent 0%, rgba(204,0,94,0.32) 40%, transparent);
}
[data-theme="light"] .ph-beam.e::after {
  background: linear-gradient(to top, transparent 0%, rgba(64,48,200,0.30) 40%, transparent);
}
[data-theme="light"] .ph-icon-bg { animation: fadeInIconLight 1s 0.8s ease forwards; }

/* Shared hero visual layer */
.page-hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0;
}

.page-hero[data-hero="gallery"]::before {
  background:
    radial-gradient(ellipse 80% 80% at 15% 30%, rgba(245,166,35,0.13) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 80% 20%, rgba(242,0,122,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 50% 70% at 50% 80%, rgba(98,68,245,0.11) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 90% 70%, rgba(240,165,32,0.07) 0%, transparent 50%);
}
[data-theme="light"] .page-hero[data-hero="gallery"]::before {
  background:
    radial-gradient(ellipse 80% 80% at 15% 30%, rgba(184,104,0,0.16) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 80% 20%, rgba(204,0,94,0.11) 0%, transparent 55%),
    radial-gradient(ellipse 50% 70% at 50% 85%, rgba(64,48,200,0.09) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 90% 65%, rgba(158,97,0,0.11) 0%, transparent 50%);
}
.page-hero[data-hero="about"]::before {
  background:
    radial-gradient(ellipse 70% 60% at 80% 40%, rgba(240,165,32,0.09) 0%, transparent 65%),
    radial-gradient(ellipse 60% 50% at 20% 70%, rgba(245,166,35,0.09) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 60% 10%, rgba(98,68,245,0.07) 0%, transparent 55%);
}
[data-theme="light"] .page-hero[data-hero="about"]::before {
  background:
    radial-gradient(ellipse 70% 60% at 80% 40%, rgba(158,97,0,0.13) 0%, transparent 65%),
    radial-gradient(ellipse 60% 50% at 20% 70%, rgba(184,104,0,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 60% 10%, rgba(64,48,200,0.08) 0%, transparent 55%);
}
.page-hero[data-hero="contact"]::before {
  background:
    radial-gradient(ellipse 60% 60% at 70% 50%, rgba(245,166,35,0.13) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 30% 30%, rgba(98,68,245,0.07) 0%, transparent 55%),
    radial-gradient(ellipse 30% 60% at 10% 70%, rgba(245,166,35,0.06) 0%, transparent 50%);
}
[data-theme="light"] .page-hero[data-hero="contact"]::before {
  background:
    radial-gradient(ellipse 60% 60% at 70% 50%, rgba(184,104,0,0.16) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 30% 30%, rgba(64,48,200,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 30% 60% at 10% 70%, rgba(184,104,0,0.09) 0%, transparent 50%);
}
.page-hero[data-hero="services"]::before {
  background:
    radial-gradient(ellipse 50% 60% at 10% 40%, rgba(245,166,35,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 40% 60%, rgba(98,68,245,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 50% 60% at 70% 30%, rgba(242,0,122,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 40% 40% at 95% 70%, rgba(240,165,32,0.07) 0%, transparent 50%);
}
[data-theme="light"] .page-hero[data-hero="services"]::before {
  background:
    radial-gradient(ellipse 50% 60% at 10% 40%, rgba(184,104,0,0.15) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 40% 60%, rgba(64,48,200,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 50% 60% at 70% 30%, rgba(204,0,94,0.11) 0%, transparent 55%),
    radial-gradient(ellipse 40% 40% at 95% 70%, rgba(158,97,0,0.09) 0%, transparent 50%);
}
.page-hero[data-hero="audio"]::before {
  background:
    radial-gradient(ellipse 90% 40% at 50% 100%, rgba(245,166,35,0.17) 0%, transparent 55%),
    radial-gradient(ellipse 65% 25% at 50% 100%, rgba(245,166,35,0.10) 0%, transparent 50%),
    radial-gradient(ellipse 45% 18% at 50% 100%, rgba(245,166,35,0.07) 0%, transparent 45%),
    radial-gradient(ellipse 40% 50% at 85% 30%,  rgba(98,68,245,0.07) 0%, transparent 50%);
}
[data-theme="light"] .page-hero[data-hero="audio"]::before {
  background:
    radial-gradient(ellipse 90% 40% at 50% 100%, rgba(184,104,0,0.20) 0%, transparent 55%),
    radial-gradient(ellipse 65% 25% at 50% 100%, rgba(184,104,0,0.12) 0%, transparent 50%),
    radial-gradient(ellipse 45% 18% at 50% 100%, rgba(184,104,0,0.08) 0%, transparent 45%),
    radial-gradient(ellipse 40% 50% at 85% 30%,  rgba(64,48,200,0.08) 0%, transparent 50%);
}
.page-hero[data-hero="lighting"]::before {
  background:
    radial-gradient(ellipse 30% 80% at 20% 100%, rgba(245,166,35,0.17) 0%, transparent 60%),
    radial-gradient(ellipse 25% 70% at 50% 100%, rgba(240,165,32,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 25% 75% at 75% 100%, rgba(242,0,122,0.14) 0%, transparent 60%),
    radial-gradient(ellipse 20% 50% at 95% 100%, rgba(98,68,245,0.11) 0%, transparent 50%);
}
[data-theme="light"] .page-hero[data-hero="lighting"]::before {
  background:
    radial-gradient(ellipse 30% 80% at 20% 100%, rgba(184,104,0,0.20) 0%, transparent 60%),
    radial-gradient(ellipse 25% 70% at 50% 100%, rgba(158,97,0,0.17) 0%, transparent 55%),
    radial-gradient(ellipse 25% 75% at 75% 100%, rgba(204,0,94,0.17) 0%, transparent 60%),
    radial-gradient(ellipse 20% 50% at 95% 100%, rgba(64,48,200,0.13) 0%, transparent 50%);
}
.page-hero[data-hero="music"]::before {
  background:
    radial-gradient(circle at 75% 50%, rgba(242,0,122,0.17) 0%, transparent 15%),
    radial-gradient(circle at 75% 50%, transparent 15%, rgba(242,0,122,0.04) 16%, transparent 25%),
    radial-gradient(circle at 75% 50%, transparent 25%, rgba(245,166,35,0.05) 26%, transparent 36%),
    radial-gradient(circle at 75% 50%, transparent 36%, rgba(242,0,122,0.03) 37%, transparent 48%),
    radial-gradient(ellipse 60% 70% at 75% 50%, rgba(242,0,122,0.09) 0%, transparent 65%),
    radial-gradient(ellipse 40% 50% at 20% 40%,  rgba(245,166,35,0.08) 0%, transparent 50%);
}
[data-theme="light"] .page-hero[data-hero="music"]::before {
  background:
    radial-gradient(circle at 75% 50%, rgba(204,0,94,0.20) 0%, transparent 15%),
    radial-gradient(circle at 75% 50%, transparent 15%, rgba(204,0,94,0.04) 16%, transparent 25%),
    radial-gradient(circle at 75% 50%, transparent 25%, rgba(184,104,0,0.06) 26%, transparent 36%),
    radial-gradient(ellipse 60% 70% at 75% 50%, rgba(204,0,94,0.11) 0%, transparent 65%),
    radial-gradient(ellipse 40% 50% at 20% 40%,  rgba(184,104,0,0.11) 0%, transparent 50%);
}
.page-hero[data-hero="video"]::before {
  background:
    radial-gradient(ellipse 80% 60% at 70% 40%, rgba(98,68,245,0.15) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 60%, rgba(245,166,35,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 15% 60%, rgba(98,68,245,0.07) 0%, transparent 50%);
}
[data-theme="light"] .page-hero[data-hero="video"]::before {
  background:
    radial-gradient(ellipse 80% 60% at 70% 40%, rgba(64,48,200,0.14) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 60%, rgba(184,104,0,0.11) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 15% 60%, rgba(64,48,200,0.09) 0%, transparent 50%);
}
.page-hero[data-hero="dancefloor"]::before {
  background:
    radial-gradient(ellipse 50% 40% at 20% 80%, rgba(245,166,35,0.17) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 50% 80%, rgba(242,0,122,0.13) 0%, transparent 50%),
    radial-gradient(ellipse 50% 40% at 80% 80%, rgba(98,68,245,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 50% 30%, rgba(240,165,32,0.06) 0%, transparent 60%);
}
[data-theme="light"] .page-hero[data-hero="dancefloor"]::before {
  background:
    radial-gradient(ellipse 50% 40% at 20% 80%, rgba(184,104,0,0.20) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 50% 80%, rgba(204,0,94,0.15) 0%, transparent 50%),
    radial-gradient(ellipse 50% 40% at 80% 80%, rgba(64,48,200,0.15) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 50% 20%, rgba(158,97,0,0.09) 0%, transparent 60%);
}
.page-hero[data-hero="games"]::before {
  background:
    radial-gradient(ellipse 70% 70% at 80% 30%, rgba(242,0,122,0.15) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 20% 60%, rgba(98,68,245,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 40% 40% at 50% 80%, rgba(245,166,35,0.09) 0%, transparent 50%),
    radial-gradient(ellipse 30% 30% at 5%  10%, rgba(242,0,122,0.07) 0%, transparent 45%);
}
[data-theme="light"] .page-hero[data-hero="games"]::before {
  background:
    radial-gradient(ellipse 70% 70% at 80% 30%, rgba(204,0,94,0.16) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 20% 60%, rgba(64,48,200,0.14) 0%, transparent 55%),
    radial-gradient(ellipse 40% 40% at 50% 80%, rgba(184,104,0,0.11) 0%, transparent 50%),
    radial-gradient(ellipse 30% 30% at 5%  10%, rgba(204,0,94,0.09)  0%, transparent 45%);
}
.page-hero[data-hero="photobooths"]::before {
  background:
    radial-gradient(ellipse 50% 50% at 80% 40%, rgba(240,165,32,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 40% 40% at 15% 30%, rgba(240,165,32,0.07) 0%, transparent 50%),
    radial-gradient(ellipse 60% 60% at 50% 80%, rgba(245,166,35,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 30% 30% at 90% 80%, rgba(242,0,122,0.07) 0%, transparent 45%);
}
[data-theme="light"] .page-hero[data-hero="photobooths"]::before {
  background:
    radial-gradient(ellipse 50% 50% at 80% 40%, rgba(158,97,0,0.16)  0%, transparent 55%),
    radial-gradient(ellipse 40% 40% at 15% 30%, rgba(158,97,0,0.11)  0%, transparent 50%),
    radial-gradient(ellipse 60% 60% at 50% 80%, rgba(184,104,0,0.09) 0%, transparent 60%),
    radial-gradient(ellipse 30% 30% at 90% 80%, rgba(204,0,94,0.09)  0%, transparent 45%);
}
.page-hero[data-hero="specialeffects"]::before {
  background:
    radial-gradient(circle at 50% 50%, rgba(240,165,32,0.15) 0%, transparent 18%),
    radial-gradient(ellipse 80% 80% at 50% 50%, rgba(245,166,35,0.07) 0%, transparent 50%),
    radial-gradient(ellipse 40% 60% at 15% 20%, rgba(242,0,122,0.11) 0%, transparent 55%),
    radial-gradient(ellipse 40% 60% at 85% 20%, rgba(98,68,245,0.11) 0%, transparent 55%),
    radial-gradient(ellipse 40% 60% at 15% 80%, rgba(98,68,245,0.07) 0%, transparent 50%),
    radial-gradient(ellipse 40% 60% at 85% 80%, rgba(240,165,32,0.09) 0%, transparent 50%);
}
[data-theme="light"] .page-hero[data-hero="specialeffects"]::before {
  background:
    radial-gradient(circle at 50% 50%, rgba(158,97,0,0.18) 0%, transparent 18%),
    radial-gradient(ellipse 80% 80% at 50% 50%, rgba(184,104,0,0.09) 0%, transparent 50%),
    radial-gradient(ellipse 40% 60% at 15% 20%, rgba(204,0,94,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 40% 60% at 85% 20%, rgba(64,48,200,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 40% 60% at 15% 80%, rgba(64,48,200,0.09) 0%, transparent 50%),
    radial-gradient(ellipse 40% 60% at 85% 80%, rgba(158,97,0,0.11) 0%, transparent 50%);
}
.page-hero[data-hero="staging"]::before {
  background:
    radial-gradient(ellipse 30% 80% at 50%  0%, rgba(240,165,32,0.20) 0%, transparent 65%),
    radial-gradient(ellipse 20% 60% at 25%  0%, rgba(240,165,32,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 20% 60% at 75%  0%, rgba(240,165,32,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 50% 90%, rgba(245,166,35,0.07) 0%, transparent 55%);
}
[data-theme="light"] .page-hero[data-hero="staging"]::before {
  background:
    radial-gradient(ellipse 30% 80% at 50%  0%, rgba(158,97,0,0.24) 0%, transparent 65%),
    radial-gradient(ellipse 20% 60% at 25%  0%, rgba(158,97,0,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 20% 60% at 75%  0%, rgba(158,97,0,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 50% 90%, rgba(184,104,0,0.09) 0%, transparent 55%);
}
.page-hero[data-hero="prints"]::before {
  background:
    radial-gradient(ellipse 60% 60% at 75% 40%, rgba(98,68,245,0.11) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 20% 60%, rgba(245,166,35,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 40% 40% at 60% 80%, rgba(240,165,32,0.07) 0%, transparent 50%);
}
[data-theme="light"] .page-hero[data-hero="prints"]::before {
  background:
    radial-gradient(ellipse 60% 60% at 75% 40%, rgba(64,48,200,0.13) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 20% 60%, rgba(184,104,0,0.11) 0%, transparent 55%),
    radial-gradient(ellipse 40% 40% at 60% 80%, rgba(158,97,0,0.09)  0%, transparent 50%);
}

/* GALLERY — MASONRY LAYOUT */
.gallery-grid { columns: 280px; column-gap: 10px; }
.gal-card {
  position: relative; overflow: hidden; border-radius: var(--r);
  width: 100%; display: block; break-inside: avoid;
  margin-bottom: 10px; cursor: pointer; background: var(--surf2);
  border: 1px solid var(--bdr);
}
.gal-card:hover { border-color: var(--bdr-s); }
.gal-h1{height:200px} .gal-h2{height:270px} .gal-h3{height:340px} .gal-h4{height:420px}

.gal-bg { position: absolute; inset: 0; transition: transform .6s var(--ease-out) !important; }
.gal-card:hover .gal-bg { transform: scale(1.06); }
.gal-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(16,12,6,.9) 0%, transparent 55%); opacity: 0; transition: opacity .3s !important; }
.gal-card:hover .gal-overlay { opacity: 1; }
.gal-info { position: absolute; bottom: 0; left: 0; right: 0; padding: 1.25rem; transform: translateY(10px); transition: transform .3s var(--ease-out) !important; }
.gal-card:hover .gal-info { transform: translateY(0); }
.gal-tag  { font-family: var(--f-mono); font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; margin-bottom: .3rem; }
.gal-name { font-family: var(--f-disp); font-weight: 700; font-size: 1.1rem; text-transform: uppercase; color: #fff; line-height: 1.1; }

/* Gallery gradient backgrounds */
.gc-1 {background:linear-gradient(145deg,#06091a,#0d1535)}
.gc-1::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 70%,rgba(0,100,255,.22),transparent 55%),radial-gradient(circle at 80% 20%,rgba(245,166,35,.10),transparent 50%)}
.gc-2 {background:linear-gradient(145deg,#140810,#2a1020)}
.gc-2::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 60% 40%,rgba(242,0,122,.22),transparent 55%),radial-gradient(circle at 20% 80%,rgba(240,165,32,.10),transparent 50%)}
.gc-3 {background:linear-gradient(145deg,#090618,#16103a)}
.gc-3::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 40% 60%,rgba(98,68,245,.28),transparent 55%),radial-gradient(circle at 85% 20%,rgba(240,165,32,.15),transparent 50%)}
.gc-4 {background:linear-gradient(145deg,#0e0a04,#261808)}
.gc-4::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 65% 50%,rgba(240,165,32,.22),transparent 55%),radial-gradient(circle at 15% 75%,rgba(220,80,0,.13),transparent 50%)}
.gc-5 {background:linear-gradient(145deg,#04100e,#082820)}
.gc-5::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 35% 45%,rgba(245,166,35,.28),transparent 55%),radial-gradient(circle at 75% 70%,rgba(0,200,100,.10),transparent 50%)}
.gc-6 {background:linear-gradient(145deg,#10060e,#220a26)}
.gc-6::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 55% 35%,rgba(160,0,200,.22),transparent 55%),radial-gradient(circle at 25% 75%,rgba(242,0,122,.13),transparent 50%)}
.gc-7 {background:linear-gradient(145deg,#0a0a14,#141428)}
.gc-7::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(245,166,35,.13),transparent 50%),radial-gradient(circle at 80% 80%,rgba(98,68,245,.18),transparent 50%)}
.gc-8 {background:linear-gradient(145deg,#100606,#280808)}
.gc-8::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 60%,rgba(240,80,0,.20),transparent 55%),radial-gradient(circle at 75% 25%,rgba(240,165,32,.15),transparent 50%)}
.gc-9 {background:linear-gradient(145deg,#040a14,#081830)}
.gc-9::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(0,130,240,.22),transparent 55%),radial-gradient(circle at 70% 80%,rgba(245,166,35,.10),transparent 50%)}
.gc-10{background:linear-gradient(145deg,#0e0e06,#202008)}
.gc-10::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 60% 40%,rgba(190,190,0,.18),transparent 55%),radial-gradient(circle at 25% 70%,rgba(240,165,32,.13),transparent 50%)}
.gc-11{background:linear-gradient(145deg,#08040e,#180820)}
.gc-11::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 45% 55%,rgba(120,0,190,.25),transparent 55%),radial-gradient(circle at 80% 30%,rgba(242,0,122,.15),transparent 50%)}
.gc-12{background:linear-gradient(145deg,#040e0c,#082018)}
.gc-12::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 35% 65%,rgba(0,190,140,.22),transparent 55%),radial-gradient(circle at 75% 25%,rgba(245,166,35,.13),transparent 50%)}

.gal-icon { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-size: clamp(3rem,10vw,5rem); opacity: .06; color: #fff; transition: opacity .4s, transform .5s !important; pointer-events: none; }
.gal-card:hover .gal-icon { opacity: .14; transform: translate(-50%,-50%) scale(1.1); }
.gal-card[data-cat].hidden { display: none; }

/* SERVICE PAGE SHARED COMPONENTS */
/* Feature grid */
.feat-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(240px,1fr)); gap: 1px; background: var(--bdr); border: 1px solid var(--bdr); }
.feat-card { background: var(--surf); padding: 1.75rem; position: relative; overflow: hidden; }
.feat-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--c,var(--cyan)); transform: scaleX(0); transition: transform 0.35s var(--ease-out) !important; }
.feat-card:hover { background: var(--surf2); }
.feat-card:hover::before { transform: scaleX(1); }
.feat-icon { font-size: 1.6rem; color: var(--c,var(--cyan)); margin-bottom: .85rem; display: block; transition: transform 0.3s var(--ease-spr) !important; }
.feat-card:hover .feat-icon { transform: scale(1.15) rotate(-5deg); }
.feat-title { font-family: var(--f-disp); font-weight: 700; font-size: 1.1rem; text-transform: uppercase; letter-spacing: .04em; color: var(--t1); margin-bottom: .4rem; }
.feat-desc { font-size: .875rem; color: var(--t2); line-height: 1.6; }

/* Include list */
.inc-list { display: grid; grid-template-columns: repeat(auto-fill,minmax(260px,1fr)); gap: .5rem; }
.inc-item { display: flex; align-items: flex-start; gap: .75rem; padding: .75rem 1rem; background: var(--surf2); border: 1px solid var(--bdr); border-radius: var(--r); font-size: .875rem; color: var(--t2); }
.inc-item:hover { border-color: var(--bdr-s); background: var(--surf3); }
.inc-item i { color: var(--cyan); flex-shrink: 0; margin-top: 2px; }

/* Process steps */
.process-steps { display: grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); gap: 1.5rem; }
.proc-step { text-align: center; padding: 2rem 1.5rem; }
.proc-num { font-family: var(--f-disp); font-weight: 900; font-size: 4rem; line-height: 1; color: var(--cyan); opacity: .14; margin-bottom: .75rem; }
.proc-title { font-family: var(--f-disp); font-weight: 700; font-size: 1.2rem; text-transform: uppercase; color: var(--t1); margin-bottom: .5rem; }
.proc-desc { font-size: .875rem; color: var(--t2); line-height: 1.6; }

/* CTA band */
.cta-band { background: var(--surf); border-top: 1px solid var(--bdr); border-bottom: 1px solid var(--bdr); padding-block: clamp(4rem,8vw,6rem); text-align: center; position: relative; overflow: hidden; }
.cta-band::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 70% 80% at 50% 60%, rgba(245,166,35,0.05), transparent 65%); pointer-events: none; }
[data-theme="light"] .cta-band::before { background: radial-gradient(ellipse 70% 80% at 50% 60%, rgba(184,104,0,0.06), transparent 65%); }
.cta-band-h { font-family: var(--f-disp); font-weight: 900; font-size: clamp(2.5rem,7vw,6rem); line-height: .9; text-transform: uppercase; letter-spacing: -.01em; color: var(--t1); margin-bottom: 1.25rem; }
.cta-band-h em { font-style: normal; color: var(--cyan); }
.cta-band-sub { font-size: clamp(.95rem,2vw,1.1rem); color: var(--t2); max-width: 44ch; margin-inline: auto; margin-bottom: 2rem; line-height: 1.75; }
.cta-band-btns { display: flex; flex-wrap: wrap; gap: .75rem; justify-content: center; }

/* Gallery filter tabs */
.filter-tabs { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 2.5rem; }
.f-tab {
  font-family: var(--f-mono); font-size: .7rem; letter-spacing: .12em; text-transform: uppercase;
  padding: .5rem 1.25rem; border-radius: var(--r2); border: 1px solid var(--bdr);
  color: var(--t3); cursor: pointer; background: var(--surf2);
}
.f-tab:hover { border-color: var(--cyan); color: var(--cyan); background: var(--fill-hover); }
.f-tab:focus-visible { outline: 2px solid var(--bdr-f); outline-offset: 2px; }
.f-tab.active { background: var(--cyan); color: #fff; border-color: var(--cyan); }

/* RESPONSIVE SYSTEM — v6 */

/* GLOBAL — spacing, typography, wrap */

/* Section vertical rhythm: 5rem is too dense on mobile.
   Override the clamp minimum for xs/sm screens. */
@media (max-width: 639px) {
  .section {
    padding-block: clamp(3rem, 8vw, 5rem);
  }
  /* Tighter section heading on mobile */
  .sec-title {
    font-size: clamp(2.2rem, 9vw, 3.6rem);
    line-height: 0.95;
  }
  .sec-sub {
    font-size: 0.975rem;
    max-width: 100%;
  }
  /* Eyebrow labels — slightly smaller on mobile */
  .eyebrow {
    font-size: 0.65rem;
    margin-bottom: 0.75rem;
  }
}

/* Ultra-wide: add comfortable max-width breathing room */
@media (min-width: 1920px) {
  :root {
    --wrap: min(96rem, calc(100% - 8rem));
  }
  .section {
    padding-block: clamp(7rem, 8vw, 10rem);
  }
}

/* NAVIGATION — touch targets, mobile refinements */

/* Ensure hamburger and theme button are always touch-friendly */
.nav-hbg {
  min-width: 44px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 8px;
}

.theme-btn {
  min-width: 44px;
  min-height: 44px;
}

/* On very small screens, tighten nav horizontal padding */
@media (max-width: 479px) {
  .nav {
    padding-inline: 1rem;
  }
  /* Keep logo mark but shrink text if needed */
  .nav-logo span {
    font-size: 1.05rem;
  }
}

/* Mobile menu improvements */
@media (max-width: 899px) {
  /* Ensure mobile menu links are easy to tap */
  .menu-link {
    padding-block: 0.65rem;
    min-height: 52px;
    display: flex;
    align-items: center;
  }
  .menu-svc-sub a {
    min-height: 44px;
  }
  /* Phones stack phone numbers vertically if tight */
  @media (max-width: 479px) {
    .menu-phones {
      flex-direction: column;
      gap: 0.75rem;
    }
  }
}

/* BUTTONS — touch-friendly minimum heights */

.btn {
  min-height: 44px; /* WCAG 2.5.8 touch target */
}

/* On small screens, buttons in a flex row wrap earlier and fill */
@media (max-width: 479px) {
  /* Flex-wrapped button groups become full-width */
  .ph-btns,
  .cta-band-btns,
  .hero-btns {
    flex-direction: column;
  }
  .ph-btns .btn,
  .cta-band-btns .btn,
  .hero-btns .btn {
    width: 100%;
    justify-content: center;
  }
}

/* PAGE HERO (interior pages: about, gallery, services, etc.) */

/* Reduce min-height on mobile — 62vh feels locked-in */
@media (max-width: 639px) {
  .page-hero {
    min-height: 46vh;
  }
  /* Hero heading is already clamped; tighten further on small */
  .ph-h1 {
    font-size: clamp(2.8rem, 12vw, 5rem);
    margin-bottom: 1rem;
  }
  .ph-sub {
    font-size: 0.975rem;
    max-width: 100%;
  }
  /* Hide the large decorative icon on small phones — saves space */
  .ph-icon-bg {
    display: none;
  }
  .ph-inner {
    padding-block: clamp(2rem, 5vw, 3.5rem);
  }
}

/* Tablet: let icon show but smaller */
@media (min-width: 640px) and (max-width: 899px) {
  .page-hero {
    min-height: 52vh;
  }
  .ph-icon-bg {
    font-size: clamp(6rem, 18vw, 12rem);
    right: 4%;
  }
}

/* Ultra-wide: increase hero impact */
@media (min-width: 1440px) {
  .page-hero {
    min-height: 68vh;
  }
}

/* FOOTER — improved multi-column layout */

/* Mobile (< 640px): single column, well-spaced groups */
@media (max-width: 639px) {
  .footer-inner {
    padding-block: clamp(2.5rem, 6vw, 4rem);
  }
  .footer-top {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  /* Footer nav columns use 2-column internal grid on mobile
     to avoid an overwhelming single tall list */
  .f-links {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem 1rem;
  }
  /* Contact info stays single column (address needs full width) */
  .footer-top > div:last-child .f-links {
    grid-template-columns: 1fr;
  }
  /* Bot row: stack on mobile */
  .footer-bot {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }
}

/* Tablet (640–899px): 2-column asymmetric
   Brand wide column | Services+Company stacked */
@media (min-width: 640px) and (max-width: 899px) {
  .footer-top {
    grid-template-columns: 1.4fr 1fr;
    gap: 2.5rem 3rem;
  }
  /* Brand spans full first column, links fill second in sub-grid */
  .footer-top > div:nth-child(2),
  .footer-top > div:nth-child(3) {
    /* These pair into the second column slot naturally */
  }
}

/* Desktop (≥ 900px): original 4-column but refine proportions */
@media (min-width: 900px) {
  .footer-top {
    grid-template-columns: 2fr 1.1fr 0.9fr 1.6fr;
    gap: 3rem;
  }
}

/* Wide (≥ 1440px): more breathing room between columns */
@media (min-width: 1440px) {
  .footer-top {
    gap: 4rem;
  }
}

/* SERVICE PAGE COMPONENTS */

/* FEAT-GRID: the 1px-gap-as-border trick breaks at 1 column.
   On mobile switch to real gap with border per card. */
@media (max-width: 639px) {
  .feat-grid {
    display: flex;
    flex-direction: column;
    gap: 1px;  /* keep the hairline-join look */
    background: var(--bdr);
  }
  .feat-card {
    padding: 1.25rem 1.25rem;
  }
  .feat-icon {
    font-size: 1.4rem;
    margin-bottom: 0.65rem;
  }
}

/* Tablet: 2 columns */
@media (min-width: 640px) and (max-width: 899px) {
  .feat-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* INC-LIST: full single column on mobile, readable */
@media (max-width: 479px) {
  .inc-list {
    grid-template-columns: 1fr;
  }
}

/* PROCESS STEPS: huge proc-num is overwhelming on mobile */
@media (max-width: 639px) {
  .process-steps {
    grid-template-columns: 1fr;
    gap: 0.25rem;
  }
  .proc-step {
    padding: 1.5rem 1rem;
    text-align: left;
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    align-items: center;
    gap: 0 1rem;
  }
  .proc-num {
    font-size: 2.4rem;
    grid-row: span 2;
    margin-bottom: 0;
    opacity: 0.18;
  }
  .proc-title {
    font-size: 1rem;
    align-self: end;
  }
  .proc-desc {
    grid-column: 2;
  }
}

@media (min-width: 640px) and (max-width: 899px) {
  .process-steps {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* CTA BAND: tighten on mobile */
@media (max-width: 639px) {
  .cta-band {
    padding-block: clamp(2.5rem, 7vw, 4rem);
  }
  .cta-band-h {
    font-size: clamp(2rem, 9vw, 3.5rem);
  }
}

/* INC-ITEM: full width, easy tap on mobile */
@media (max-width: 639px) {
  .inc-item {
    padding: 0.875rem 1rem;
  }
}

/* GALLERY MASONRY — responsive column count (c9.css canonical) */

/* Desktop (default): auto-columns via `columns: 280px` in .gallery-grid */

/* Explicitly controlled breakpoints for predictable layout */
@media (min-width: 1200px) {
  .gallery-grid { column-count: 4; columns: unset; column-gap: 10px; }
}
@media (min-width: 900px) and (max-width: 1199px) {
  .gallery-grid { column-count: 3; columns: unset; column-gap: 10px; }
}
@media (min-width: 540px) and (max-width: 899px) {
  .gallery-grid { column-count: 2; columns: unset; column-gap: 8px; }
  .gal-card     { margin-bottom: 8px; }
  /* Scale heights down for 2-col tablet */
  .gal-h1 { height: 160px; }
  .gal-h2 { height: 215px; }
  .gal-h3 { height: 275px; }
  .gal-h4 { height: 340px; }
}
@media (max-width: 539px) {
  .gallery-grid { column-count: 1; columns: unset; column-gap: 0; }
  .gal-card     { margin-bottom: 8px; border-radius: var(--r); }
  /* Single column: all cards at comfortable fixed heights */
  .gal-h1 { height: 210px; }
  .gal-h2 { height: 240px; }
  .gal-h3 { height: 270px; }
  .gal-h4 { height: 300px; }
  /* Show info overlay always on mobile (no hover) */
  .gal-overlay { opacity: 1; }
  .gal-info    { transform: translateY(0); }
}

/* Filter tabs: scrollable on mobile */
@media (max-width: 639px) {
  .filter-tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 4px;
    gap: 0.4rem;
    margin-bottom: 1.5rem;
  }
  .filter-tabs::-webkit-scrollbar { display: none; }
  .f-tab {
    flex-shrink: 0;
    white-space: nowrap;
    padding: 0.5rem 1rem;
    font-size: 0.65rem;
  }
}

/* FORM ELEMENTS — mobile usability */

/* Touch-friendly input height */
.c9-input,
.c9-textarea,
.c9-select,
.form-input,
.form-select {
  min-height: 44px;
  font-size: 1rem; /* prevents iOS zoom on focus (must be ≥ 16px) */
}

/* Full-width submit buttons on mobile already, just ensure padding */
@media (max-width: 639px) {
  .c9-textarea,
  .form-textarea {
    min-height: 100px;
  }
}

/* Prevent auto-zoom on iOS: font-size must be 16px+ in inputs */
@supports (-webkit-touch-callout: none) {
  .c9-input, .c9-textarea, .c9-select,
  .form-input, .form-select, .form-textarea {
    font-size: 16px;
  }
}

/* ULTRA-WIDE (≥ 1920px) — prevent over-stretching */

@media (min-width: 1920px) {
  /* Content columns get comfortable max width */
  .sec-sub    { max-width: 58ch; }
  .cta-band-sub { max-width: 52ch; }
  /* Slightly larger base font on very large monitors */
  body { font-size: 18px; }
  /* Gallery: 5 columns on massive screens */
  .gallery-grid { column-count: 5; }
  .gal-h1 { height: 240px; }
  .gal-h2 { height: 310px; }
  .gal-h3 { height: 390px; }
  .gal-h4 { height: 480px; }
}

/* UTILITY — responsive helpers */

/* Hide/show helpers */
* default visible */
.show-mobile  { display: none; }

@media (max-width: 639px) {
  .hide-mobile { display: none !important; }
  .show-mobile { display: revert; }
}

/* Safe area insets for notched phones */
@supports (padding: max(0px)) {
  .nav {
    padding-inline: max(clamp(1.25rem,4vw,3rem), env(safe-area-inset-left));
  }
  .wrap {
    padding-inline: max(0px, env(safe-area-inset-left));
  }
  .menu-overlay {
    padding-bottom: max(2rem, env(safe-area-inset-bottom));
    padding-left: max(1.5rem, env(safe-area-inset-left));
    padding-right: max(1.5rem, env(safe-area-inset-right));
  }
}

/* MOBILE UX REDESIGN — v7 */

/* SNAP CAROUSEL BASE SYSTEM */

/* The slider viewport token: how much padding bleeds to edges */
:root { --sp: clamp(1rem, 5vw, 1.5rem); }   /* slider edge pad */

@media (max-width: 639px) {
  /* Generic carousel track pattern — applied per-component below */
  .c9-carousel {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    scrollbar-width: none;
    gap: 12px;
    /* Bleed to screen edge for an edge-to-edge feel */
    padding-left: var(--sp);
    padding-right: var(--sp);
    padding-bottom: 1.25rem;   /* room for dots */
    margin-inline: calc(var(--sp) * -1);
  }
  .c9-carousel::-webkit-scrollbar { display: none; }

  /* Slide items snap to start, peek next card */
  .c9-slide {
    flex: 0 0 80vw;             /* ~80% → peek ~15% of next */
    max-width: 300px;
    scroll-snap-align: start;
    scroll-snap-stop: always;   /* prevent fast-swipe over cards */
  }

  /* Dot indicator row (injected by JS) */
  .c9-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 0.75rem;
  }
  .c9-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--bdr-s);
    cursor: pointer;
    transition: background 0.22s, width 0.22s, border-radius 0.22s !important;
    flex-shrink: 0;
  }
  .c9-dot.active {
    width: 20px;
    border-radius: 3px;
    background: var(--cyan);
  }

  /* Drag-hint arrow (auto-injected on first render) */
  .c9-swipe-hint {
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: var(--f-mono);
    font-size: 0.6rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--t3);
    margin-bottom: 0.75rem;
  }
  .c9-swipe-hint i { color: var(--cyan); font-size: 0.75rem; }

  
  .svc-grid {
    display: flex !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    scrollbar-width: none;
    gap: 0;
    padding-left: var(--sp);
    padding-right: var(--sp);
    padding-bottom: 1rem;
    margin-inline: calc(var(--sp) * -1);
    /* Remove grid columns from v6 */
    grid-template-columns: unset !important;
  }
  .svc-grid::-webkit-scrollbar { display: none; }

  .svc-card {
    flex: 0 0 100vw !important;
    width: 100vw !important;
    max-width: none !important;
    scroll-snap-align: center;
    scroll-snap-stop: always;
    /* Full-width card padding */
    padding: 1.75rem var(--sp,1.25rem) !important;
  }
  /* Reveal animations conflict with carousel — disable for slides */
  .svc-grid .reveal { opacity: 1 !important; transform: none !important; }

  
  .events-grid {
    display: flex !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    scrollbar-width: none;
    gap: 0;
    padding-left: var(--sp);
    padding-right: var(--sp);
    padding-bottom: 1rem;
    margin-inline: calc(var(--sp) * -1);
    grid-template-columns: unset !important;
  }
  .events-grid::-webkit-scrollbar { display: none; }

  .ev-card {
    flex: 0 0 100vw !important;
    width: 100vw !important;
    max-width: none !important;
    scroll-snap-align: start;
    scroll-snap-stop: always;
    /* Ensure cards have consistent height in flex context */
    height: 220px !important;
  }
  .events-grid .reveal { opacity: 1 !important; transform: none !important; }

  /* Events: always show overlay info (no hover on touch) */
  .ev-card .ev-card-bg { opacity: 0.7; }
  .ev-card .ev-body { opacity: 1; transform: none; }

  
  .testi-grid {
    display: flex !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    scrollbar-width: none;
    gap: 0;                     /* testimonials use 1px-gap border trick */
    padding-left: var(--sp);
    padding-right: var(--sp);
    padding-bottom: 1rem;
    margin-inline: calc(var(--sp) * -1);
    /* Override 1px background-as-border (breaks in flex) */
    background: transparent !important;
    border: none !important;
    grid-template-columns: unset !important;
  }
  .testi-grid::-webkit-scrollbar { display: none; }

  .testi-card {
    flex: 0 0 100vw !important;
    width: 100vw !important;
    max-width: none !important;
    scroll-snap-align: start;
    scroll-snap-stop: always;
    border: 1px solid var(--bdr) !important;
    border-radius: var(--r) !important;
    /* First card: no left gap; subsequent cards offset by gap */
    margin-right: 10px;
    padding: 1.25rem !important;
    background: var(--surf) !important;
    flex-shrink: 0;
  }
  .testi-card:last-child { margin-right: 0; }
  .testi-grid .reveal { opacity: 1 !important; transform: none !important; }

  /* Quote text slightly smaller for card width */
  .t-quote { font-size: 0.9rem !important; line-height: 1.65 !important; }

  
  .feat-grid {
    display: flex !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    scrollbar-width: none;
    gap: 0;
    padding-left: var(--sp);
    padding-right: var(--sp);
    padding-bottom: 1rem;
    margin-inline: calc(var(--sp) * -1);
    background: transparent !important;
    border: none !important;
    flex-direction: row !important;  /* override v6's flex-direction: column */
    grid-template-columns: unset !important;
  }
  .feat-grid::-webkit-scrollbar { display: none; }

  .feat-card {
    flex: 0 0 100vw !important;
    width: 100vw !important;
    max-width: none !important;
    scroll-snap-align: start;
    scroll-snap-stop: always;
    border: 1px solid var(--bdr) !important;
    border-radius: var(--r) !important;
    flex-shrink: 0;
    padding: 1.25rem !important;
  }
  /* Restore the top-accent line (was stripped by background: transparent) */
  .feat-card::before {
    content: '' !important;
    position: absolute;
    top: 0; left: 0; right: 0; height: 2px;
    background: var(--c, var(--cyan));
    transform: scaleX(1) !important; /* always show on mobile */
  }
  .feat-grid .reveal { opacity: 1 !important; transform: none !important; }

  
  .inc-list {
    grid-template-columns: 1fr !important;
    gap: 6px;
  }
  /* Alternate items get a cyan left-border accent for visual rhythm */
  .inc-item:nth-child(odd) {
    border-left: 2px solid var(--cyan) !important;
    padding-left: 0.875rem;
  }
  .inc-item:nth-child(even) {
    border-left: 2px solid var(--bdr-s) !important;
    padding-left: 0.875rem;
  }

  /* HERO — Mobile reshape */

  /* Reduce hero height — 100svh is too tall on phones */
  .hero {
    min-height: 92svh;
  }

  /* Hero buttons: primary CTA full-width, then a compact 2-button row */
  .hero-btns {
    flex-direction: column;
    gap: 0.6rem;
  }
  .hero-btns .btn:first-child {
    width: 100%;
    justify-content: center;
    font-size: 1rem;
    padding: 0.9rem 1.5rem;
  }
  /* Services + Gallery buttons share a row */
  .hero-btns .btn:nth-child(2),
  .hero-btns .btn:nth-child(3) {
    flex: 1;
    justify-content: center;
    font-size: 0.8rem;
    padding: 0.65rem 0.75rem;
    letter-spacing: 0.02em;
  }
  /* Wrap the 2nd/3rd into a row */
  .hero-btns::after {
    /* handled in JS — see c9.js */
    content: none;
  }

  /* Tighten hero heading on very small phones */
  .hero-h1 {
    font-size: clamp(3rem, 13vw, 6rem) !important;
    margin-bottom: 3cap;
    line-height: 1;
  }
  /* Sub text */
  .hero-sub {
    font-size: 0.95rem !important;
    line-height: 1.65;
    margin-bottom: 1.5rem !important;
    max-width: 100%;
  }

  /* First content section should breathe — reduce top gap */
  .hero + .ticker + .stats-band {
    padding-block: clamp(2rem, 6vw, 3.5rem);
  }

  /* STATS — 2×2 with visible grid lines */

  .stats-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 0;
    border: 1px solid var(--bdr);
  }
  .stat-cell {
    padding: 1.5rem 1rem !important;
    border-right: 1px solid var(--bdr);
    border-bottom: 1px solid var(--bdr);
  }
  /* Remove right/bottom border on edge cells */
  .stat-cell:nth-child(2n) { border-right: none; }
  .stat-cell:nth-child(3),
  .stat-cell:nth-child(4)  { border-bottom: none; }

.bg-fix{

 background: white;
  
}

  .stat-n {
    font-size: clamp(2.4rem, 9vw, 3.2rem) !important;
    line-height: 1;
    margin-bottom: 0.4rem;
  }
  .stat-label { font-size: 0.75rem !important; }

  .stats-band { padding-block: 0 !important; }
  .stats-band .wrap { padding-inline: 0; }

  /* INTRO / SPLIT SECTION — simplify on mobile */

  /* Waveform vis box is decorative — hide entirely on mobile */
  .vis-box { display: none !important; }
  /* Remove split gap when only one column shows */
  .split    { gap: 0 !important; }

  /* INTRO TEXT — tighter on mobile */
  .intro-h {
    font-size: clamp(2.2rem, 9vw, 3.2rem) !important;
    margin-bottom: 1rem;
  }
  .intro-p {
    font-size: 0.95rem !important;
    margin-bottom: 0.85rem;
  }

  /* PROCESS STEPS — Accordion on mobile */

  .process-steps {
    grid-template-columns: 1fr !important;
    gap: 0;
    border: 1px solid var(--bdr);
    border-radius: var(--r);
    overflow: hidden;
  }
  .proc-step {
    padding: 0 !important;
    text-align: left;
    border-bottom: 1px solid var(--bdr);
    background: var(--surf);
    cursor: pointer;
    transition: background 0.2s !important;
  }
  .proc-step:last-child { border-bottom: none; }
  .proc-step:hover { background: var(--surf2); }

  /* Accordion header */
  .proc-step-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.125rem;
  }
  .proc-num {
    font-size: 1.6rem !important;
    opacity: 0.25 !important;
    margin-bottom: 0 !important;
    flex-shrink: 0;
    line-height: 1;
    min-width: 2.4rem;
  }
  .proc-title {
    font-size: 1rem !important;
    flex: 1;
  }
  /* Chevron indicator */
  .proc-chevron {
    font-size: 0.75rem;
    color: var(--t3);
    transition: transform 0.25s !important;
    flex-shrink: 0;
  }
  .proc-step.open .proc-chevron { transform: rotate(180deg); }

  /* Accordion body */
  .proc-step-body {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s cubic-bezier(0.16,1,0.3,1) !important;
  }
  .proc-step.open .proc-step-body { max-height: 200px; }
  .proc-desc {
    padding: 0 1.125rem 1rem 3.6rem;
    font-size: 0.875rem !important;
  }

  /* CTA SECTION — compact on mobile */

  .cta-h {
    font-size: clamp(2rem, 9vw, 3rem) !important;
    margin-bottom: 0.75rem;
  }
  .cta-sub { font-size: 0.9rem !important; max-width: 100%; }
  .cta-btns {
    flex-direction: column;
    gap: 0.6rem;
  }
  .cta-btns .btn {
    width: 100% !important;
    justify-content: center !important;
  }
  /* Phone numbers: compact inline */
  .cta-phones {
    flex-direction: column !important;
    gap: 0.4rem;
    align-items: center;
  }

  /* CTA BAND (service pages) — mobile */

  .cta-band-btns {
    flex-direction: column;
    gap: 0.6rem;
  }
  .cta-band-btns .btn {
    width: 100% !important;
    justify-content: center !important;
  }

  /* FOOTER — mobile-first grouped layout */

  .footer-top {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
    border: 1px solid var(--bdr);
    border-radius: var(--r);
    overflow: hidden;
  }

  /* Each footer column becomes an accordion section on mobile */
  .footer-top > div {
    padding: 1.125rem 1.25rem;
    border-bottom: 1px solid var(--bdr);
  }
  .footer-top > div:last-child { border-bottom: none; }

  /* Brand column stays expanded (always visible) */
  .footer-top > div:first-child {
    padding-bottom: 1.25rem;
  }

  /* Footer nav links: 2 columns in each accordion panel */
  .f-links {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 0.4rem 0.75rem !important;
  }
  .f-links a {
    font-size: 0.82rem !important;
    padding: 0.2rem 0;
    min-height: 36px;
    align-items: center;
  }

  /* Footer contact column stays single col */
  .footer-top > div:last-child .f-links {
    grid-template-columns: 1fr !important;
  }
  .footer-top > div:last-child .f-links a {
    font-size: 0.875rem !important;
  }

  /* Footer badges: inline row */
  .f-badges { gap: 0.3rem; }
  .f-badge  { font-size: 0.64rem; }

  /* Footer bottom: stacked */
  .footer-bot {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
    padding-top: 1rem;
  }
  .f-copy { font-size: 0.72rem; }
  .f-bot-nav { gap: 1rem; }
  .f-bot-nav a { font-size: 0.72rem; }

  .footer-inner { padding-block: 2rem 1.5rem !important; }

  /* Social icons: touch-friendly size */
  .f-soc { width: 40px !important; height: 40px !important; font-size: 1rem !important; }

  /* CONTACT PAGE — stacked mobile layout */

  /* Map: reduce to a glimpse on mobile */
  .map-section { display: none; }

  /* Contact channels: 2-col grid */
  .contact-channels {
    grid-template-columns: 1fr 1fr !important;
    gap: 0;
  }
  .ch-cell {
    padding: 0.875rem !important;
  }

  /* PAGE HERO (interior pages) — mobile compact */

  .page-hero { min-height: 42vh !important; }
  .ph-h1 {
    font-size: clamp(2.6rem, 12vw, 4.5rem) !important;
    line-height: 0.92;
  }
  .ph-sub { display: none; } /* headline is enough on mobile */
  .ph-btns {
    flex-direction: row !important;
    flex-wrap: wrap;
  }
  .ph-btns .btn {
    font-size: 0.78rem !important;
    padding: 0.55rem 0.9rem !important;
  }

  /* SECTION HEADINGS — compact on mobile */

  .sec-title { letter-spacing: -0.01em; }
  /* Reduce margin between heading block and content */
  [style*="margin-bottom:clamp(2.5rem"] {
    margin-bottom: 1.5rem !important;
  }

}   /* end @media (max-width: 639px) */

/* TABLET (640–899px) — carousel for very dense grids only */

@media (min-width: 640px) and (max-width: 899px) {
  /* Service grid: 2-col grid (done in v6), but reveal animations active */
  .svc-grid { grid-template-columns: repeat(2, 1fr); }

  /* Feature grid on service pages: 2-col */
  .feat-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* Events: 2-col */
  .events-grid { grid-template-columns: repeat(2, 1fr); }

  /* Testimonials: 2-col */
  .testi-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* Process steps: 2-col */
  .process-steps { grid-template-columns: repeat(2, 1fr) !important; }

}

/* ═══════════════════════════════════════════════════════════
   HOMEPAGE SECTIONS
═══════════════════════════════════════════════════════════ */

/* HERO */
.hero {
  position:relative; height:100svh; max-height:100svh; min-height:100svh;
  display:flex; align-items:center; justify-content:center;
  padding-top:0;
  overflow:hidden;
  background:var(--page);
}

/* Hero background image container — must fill the whole section */
.hero-bg {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  z-index:1;
  overflow:hidden;
}
.hero-bg img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

/* Theme-aware hero images */
.hero-img--light { display:none; }
.hero-img--dark  { display:block; }
[data-theme="light"] .hero-img--dark  { display:none; }
[data-theme="light"] .hero-img--light { display:block; }

/* Overlay sits above the image, below everything else */
.hero-bg-overlay {
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(
    to bottom,
    rgba(16,12,6,0.55) 0%,
    rgba(16,12,6,0.28) 50%,
    rgba(16,12,6,0.72) 100%
  );
}
[data-theme="light"] .hero-bg-overlay {
  background:linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0.137) 0%,
    rgba(255, 255, 255, 0.233) 50%,
    rgba(255, 255, 255, 0) 100%
  );
}

/* Make sure hero inner content sits above the bg layer */
.hero-inner,
.hero-beams,
.hero-pools,
.hero-fire-left,
.hero-fire-right,
#hero-three,
.stage-line,
.live-badge,
.scroll-hint {
  z-index:10;
}

/* Stage light beams */
.hero-beams { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.beam {
  position:absolute; width:1.5px; height:68%;
  bottom:0; transform-origin:bottom center;
  opacity:0;
  animation:beamFade 7s ease-in-out infinite;
}
.beam::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, transparent 0%, rgba(245,166,35,0.85) 40%, rgba(245,166,35,0.25) 80%, transparent);
  filter:blur(1px);
}
.beam-m::after { background:linear-gradient(to top, transparent 0%, rgba(255,94,98,0.75) 40%, rgba(255,94,98,0.18) 80%, transparent); }
.beam-e::after { background:linear-gradient(to top, transparent 0%, rgba(255,209,102,0.70) 40%, rgba(255,209,102,0.15) 80%, transparent); }

.beam-1{left:12%; animation-delay:0s;   animation-duration:7.5s; --deg:-28deg}
.beam-2{left:25%; animation-delay:1.5s; animation-duration:9s;   --deg:-14deg}
.beam-3{left:38%; animation-delay:0.7s; animation-duration:8s;   --deg:-5deg}
.beam-4{left:52%; animation-delay:2.2s; animation-duration:6.5s; --deg:6deg}
.beam-5{left:66%; animation-delay:0.3s; animation-duration:10s;  --deg:18deg}
.beam-6{left:79%; animation-delay:1.8s; animation-duration:7s;   --deg:28deg}
.beam-7{left:90%; animation-delay:3s;   animation-duration:8.5s; --deg:36deg}
@keyframes beamFade{
  0%   {opacity:0;transform:rotate(var(--deg,0deg)) scaleY(0.5)}
  20%  {opacity:1}
  50%  {opacity:0.6;transform:rotate(calc(var(--deg,0deg) + 7deg)) scaleY(1)}
  80%  {opacity:0.9}
  100% {opacity:0;transform:rotate(var(--deg,0deg)) scaleY(0.5)}
}

/* Light pools */
.hero-pools { position:absolute; bottom:0; left:0; right:0; height:55%; pointer-events:none; }
.pool {
  position:absolute; bottom:-25%; border-radius:50%;
  filter:blur(90px);
  animation:poolPulse 9s ease-in-out infinite alternate;
  will-change: transform, opacity;
}
.pool-1{width:44vw;height:44vw;left:5%; background:radial-gradient(circle,rgba(245,166,35,0.18),transparent 68%);animation-delay:0s}
.pool-2{width:38vw;height:38vw;left:38%;background:radial-gradient(circle,rgba(255,94,98,0.12),transparent 68%);animation-delay:-4s}
.pool-3{width:32vw;height:32vw;right:3%; background:radial-gradient(circle,rgba(255,209,102,0.14),transparent 68%);animation-delay:-7s}
@keyframes poolPulse{
  from{transform:scale(0.88) translateY(0);opacity:0.65}
  to  {transform:scale(1.12) translateY(-18px);opacity:1}
}

/* Stage floor line */
.stage-line {
  position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(to right, transparent, var(--cyan), var(--gold), var(--magenta), transparent);
  animation:stagePulse 4s ease-in-out infinite;
}
@keyframes stagePulse{
  0%,100%{opacity:0.35}
  50%{opacity:1;box-shadow:0 0 18px var(--cyan)}
}

/* Hero inner */
.hero-inner {
  position:relative; z-index:2;
  width:var(--wrap); margin-inline:auto;
  padding-block:clamp(1rem,3vw,2.5rem);
}

.hero-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--f-mono); font-size:0.80rem;
  letter-spacing:0.16em; text-transform:uppercase;
  color:var(--cyan); margin-bottom:0.85rem;
  opacity:0; animation:fadeUp 0.8s 0.3s var(--ease-out) forwards;
}
.pulse-dot {
  width:6px;height:6px;border-radius:50%;
  background:black;
  animation:dotBlink 2s ease-in-out infinite;
}
@keyframes dotBlink{
  0%,100%{opacity:1;box-shadow:0 0 0 0 var(--cyan-glow)}
  50%{opacity:0.6;box-shadow:0 0 0 5px transparent}
}

.hero-h1 {
  font-family:var(--f-disp); font-weight:900;
  font-size:clamp(4rem,10vw,10rem);
  line-height:0.88; letter-spacing:-0.02em; text-transform:uppercase;
  color:greey; 
  margin-bottom:1rem;
  opacity:0; animation:fadeUp 0.9s 0.5s var(--ease-out) forwards;
  text-wrap: balance;
}
.h1-outline {
  color:transparent;
  -webkit-text-stroke:2px var(--cyan);
  display:inline-block;
}
.h1-glow {
  display:inline-block;
  animation:glowCycle 3.5s ease-in-out infinite alternate;
}
@keyframes glowCycle{
  from{text-shadow:0 0 20px rgba(245,166,35,0.30)}
  to  {text-shadow:0 0 50px rgba(245,166,35,0.80),0 0 100px rgba(245,166,35,0.25)}
}

.hero-sub {
  font-size:clamp(0.875rem,1.5vw,1.0rem);
  color:var(--text-1); max-width:80ch; line-height:1.70;
  margin-bottom:1.75rem;
  opacity:0; animation:fadeUp 0.9s 0.7s var(--ease-out) forwards;
}

.hero-btns {
  display:flex; flex-wrap:wrap; gap:0.75rem;
  opacity:0; animation:fadeUp 0.9s 0.88s var(--ease-out) forwards;
}

/* Live badge */
/* .live-badge {
  position:absolute; top:clamp(5rem,15vh,7rem); right:clamp(1.5rem,4vw,3rem);
  display:flex; align-items:center; gap:8px;
  background:var(--mag-dim); border:1px solid rgba(232,0,122,0.28);
  padding:0.45rem 1rem; border-radius:2px;
  font-family:var(--f-mono); font-size:0.68rem; letter-spacing:0.12em;
  color:var(--magenta); z-index:2;
  opacity:0; animation:fadeIn 1s 1.3s var(--ease-out) forwards;
}
.live-dot {
  width:7px;height:7px;border-radius:50%;
  background:var(--magenta);
  animation:livePulse 1.4s ease-in-out infinite;
} */
@keyframes livePulse{
  0%,100%{box-shadow:0 0 0 0 rgba(232,0,122,0.6)}
  50%    {box-shadow:0 0 0 5px rgba(232,0,122,0)}
}

.scroll-hint {
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:6px;
  font-family:var(--f-mono); font-size:0.6rem; letter-spacing:0.12em;
  color:var(--text-3); z-index:2;
  opacity:0; animation:fadeIn 1s 1.6s ease forwards, scrollBounce 2s 2.6s ease-in-out infinite;
}
.scroll-hint i { color:var(--cyan); }
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* TICKER */
.ticker { background:var(--cyan); padding-block:0.65rem; overflow:hidden; position:relative; }
.ticker-track {
  display:flex; gap:2.5rem; white-space:nowrap;
  animation:tickScroll 28s linear infinite;
  width:max-content;
  will-change: transform;
}
.ticker:hover .ticker-track { animation-play-state:paused; }
.t-item {
  display:flex; align-items:center; gap:0.65rem;
  font-family:var(--f-disp); font-weight:700;
  font-size:0.82rem; letter-spacing:0.12em; text-transform:uppercase;
  color:#1a0e00;
}
.t-sep { color:rgba(26,14,0,0.40); font-size:1rem; }
@keyframes tickScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* STATS */
.stats-band {
  padding-block:clamp(3.5rem,7vw,5.5rem);
  background:var(--surf);
  position:relative; overflow:hidden;
}
.stats-band::before,
.stats-band::after {
  content:''; position:absolute; left:0; right:0; height:1px;
}
.stats-band::before {
  top:0;
  background:linear-gradient(to right, transparent, var(--cyan) 30%, var(--magenta) 70%, transparent);
}
.stats-band::after {
  bottom:0;
  background:linear-gradient(to right, transparent, var(--electric) 30%, var(--cyan) 70%, transparent);
}
.stats-grid {
  width:var(--wrap); margin-inline:auto;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:1px; background:var(--bdr);
}
.stat-cell {
  background:var(--surf2);
  padding:clamp(2rem,4vw,3rem) clamp(1.5rem,3vw,2.5rem);
  text-align:center; position:relative; overflow:hidden;
  transition:background 0.25s !important;
  contain: layout style;
}
[data-theme="light"].stat-cell {background: red ;}
.stat-cell::before {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:var(--c,var(--cyan)); transform:scaleX(0);
  transition:transform 0.4s var(--ease-out) !important;
}
.stat-cell:hover { background:var(--surf2); }
.stat-cell:hover::before { transform:scaleX(1); }
.stat-cell:nth-child(2){--c:var(--magenta)}
.stat-cell:nth-child(3){--c:var(--gold)}
.stat-cell:nth-child(4){--c:var(--electric)}
.stat-n {
  font-family:var(--f-disp); font-weight:900;
  font-size:clamp(3.5rem,7vw,5.5rem);
  line-height:1; color:var(--text-1); letter-spacing:-0.02em;
}
.stat-n sup { font-size:0.42em; color:var(--c,var(--cyan)); vertical-align:super; margin-left:2px; }
.stat-n .zero { color:var(--cyan); }
.stat-label { font-size:0.85rem; color:var(--text-2); margin-top:0.5rem; }

/* INTRO SPLIT */
.split {
  display:grid; gap:clamp(3rem,6vw,5rem); align-items:center;
}
@media(min-width:768px){ .split{grid-template-columns:1fr 1fr} }
.intro-h {
  font-family:var(--f-disp); font-weight:900;
  font-size:clamp(2.5rem,5vw,4rem);
  line-height:0.92; text-transform:uppercase; letter-spacing:-0.01em;
  color:var(--text-1); margin-bottom:1.5rem;
}
.intro-h em { font-style:normal; color:var(--cyan); }
.intro-p { font-size:1.0625rem; color:var(--text-2); line-height:1.8; margin-bottom:1rem; }
.link-arrow {
  display:inline-flex; align-items:center; gap:6px;
  font-weight:600; font-size:0.9rem; text-transform:uppercase; letter-spacing:0.06em;
  color:var(--cyan); margin-top:1.25rem;
  border-bottom:1px solid var(--cyan-dim); padding-bottom:3px;
  transition:gap 0.2s, border-color 0.2s !important;
}
.link-arrow:hover { gap:14px; border-color:var(--cyan); }

/* Waveform vis */
.vis-box {
  position:relative;
  height:clamp(260px,38vw,480px);
  border-radius:var(--r); overflow:hidden;
  background:var(--surf2);
  border:1px solid var(--bdr);
}
/* Corner accents instead of rounded */
.vis-box::before,.vis-box::after {
  content:''; position:absolute; width:16px; height:16px;
  border-color:var(--cyan); border-style:solid; z-index:2;
}
.vis-box::before { top:0; left:0; border-width:2px 0 0 2px; }
.vis-box::after  { bottom:0; right:0; border-width:0 2px 2px 0; }
.waveform {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  gap:3px; padding:2.5rem;
}
.w-bar {
  flex:1; max-width:10px; border-radius:1px;
  opacity:0.7; background:var(--cyan);
  animation:wBar 1s ease-in-out infinite alternate;
}
.w-bar:nth-child(2n) { background:var(--magenta); }
.w-bar:nth-child(3n) { background:var(--electric); }
@keyframes wBar{from{height:8%;opacity:0.35}to{height:calc(15% + var(--h,50%) * 0.7);opacity:1}}
.vis-hud {
  position:absolute; bottom:0; left:0; right:0;
  display:flex; align-items:center; justify-content:space-between;
  padding:0.75rem 1.25rem;
  background:linear-gradient(to top, rgba(0,0,0,0.6), transparent);
  font-family:var(--f-mono); font-size:0.62rem; color:var(--text-3); letter-spacing:0.06em;
}
.hud-live { color:var(--magenta); display:flex; align-items:center; gap:5px; }
.hud-dot { width:5px;height:5px;border-radius:50%; background:var(--magenta); animation:livePulse 1.4s infinite; }

/* SERVICES */
.svc-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(250px,1fr));
  gap:1px; background:rgba(31, 31, 31, 0.205);
  border:1px solid var(--bdr); margin-bottom:2.5rem;
}
.svc-card {
  display:block; background:var(--surf);
  padding:1.75rem 2rem;
  position:relative; overflow:hidden;
  transition:background 0.25s !important;
}
/* Colored left bar */
.svc-card::before {
  content:''; position:absolute; top:0; left:0; bottom:0; width:2px;
  background:var(--c,var(--cyan)); transform:scaleY(0);
  transform-origin:bottom; transition:transform 0.35s var(--ease-out) !important;
}
/* Glow overlay */
.svc-card::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(120deg, rgba(0,0,0,0) 60%, transparent);
  opacity:0; transition:opacity 0.3s !important;
}
.svc-card:hover { background:var(--surf2); }
.svc-card:hover::before { transform:scaleY(1); }
.svc-card:hover::after { opacity:1; }
.svc-card:hover .svc-icon { transform:scale(1.08) rotate(-4deg); color:var(--c,var(--cyan)); }
.svc-card:hover .svc-arrow { opacity:1; transform:translateX(0); }

.svc-num { font-family:var(--f-mono); font-size:0.6rem; color:var(--text-3); letter-spacing:0.1em; margin-bottom:1.25rem; }
.svc-icon { font-size:1.9rem; color:var(--c,var(--cyan)); margin-bottom:0.9rem; display:block; transition:transform 0.3s var(--ease-spr), color 0.3s !important; }
.svc-title { font-family:var(--f-disp); font-weight:700; font-size:1.25rem; text-transform:uppercase; letter-spacing:0.04em; color:var(--text-1); margin-bottom:0.4rem; }
.svc-desc { font-size:0.875rem; color:var(--text-2); line-height:1.6; }
.svc-arrow {
  display:inline-flex; align-items:center; gap:5px;
  font-size:0.78rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em;
  color:var(--c,var(--cyan)); margin-top:1rem;
  opacity:0; transform:translateX(-10px);
  transition:opacity 0.25s, transform 0.25s !important;
}

/* EVENTS CARDS */
.events-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:0.75rem;
}
.ev-card {
  position:relative;
  height:clamp(280px,34vw,370px);
  overflow:hidden; display:block;
  border-radius:var(--r);
}
/* Clip-path corner cut for sharp style */
.ev-card-bg {
  position:absolute; inset:0;
  transition:transform 0.6s var(--ease-out) !important;
}
.ev-card:hover .ev-card-bg { transform:scale(1.06); }
.ec-corp { background:linear-gradient(140deg,#060614,#0c1830); }
.ec-corp .ev-card-bg::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 25% 75%, rgba(0,80,255,0.22), transparent 55%),
             radial-gradient(circle at 80% 20%, rgba(245,166,35,0.12), transparent 50%);
}
.ec-wed { background:linear-gradient(140deg,#14060e,#28102a); }
.ec-wed .ev-card-bg::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 60% 40%, rgba(232,0,122,0.22), transparent 55%),
             radial-gradient(circle at 20% 80%, rgba(255,184,0,0.12), transparent 50%);
}
.ec-mitz { background:linear-gradient(140deg,#0a0818,#180e38); }
.ec-mitz .ev-card-bg::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 40% 60%, rgba(94,59,255,0.28), transparent 55%),
             radial-gradient(circle at 85% 20%, rgba(255,184,0,0.18), transparent 50%);
}
.ec-gala { background:linear-gradient(140deg,#0e0a04,#261806); }
.ec-gala .ev-card-bg::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 65% 50%, rgba(255,184,0,0.22), transparent 55%),
             radial-gradient(circle at 15% 75%, rgba(232,80,0,0.14), transparent 50%);
}

/* Big ghost icon */
.ev-icon {
  position:absolute; bottom:3.5rem; right:1.25rem;
  font-size:4.5rem; opacity:0.06; color:#fff;
  transition:opacity 0.4s, transform 0.5s var(--ease-out) !important;
}
.ev-card:hover .ev-icon { opacity:0.13; transform:scale(1.1) rotate(-6deg); }

/* Top accent bar */
.ev-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px; z-index:2;
  opacity:0; transition:opacity 0.3s !important;
}
.ec-corp::before  { background:linear-gradient(to right, #0066ff, var(--cyan)); }
.ec-wed::before   { background:linear-gradient(to right, var(--magenta), var(--gold)); }
.ec-mitz::before  { background:linear-gradient(to right, var(--electric), #b388ff); }
.ec-gala::before  { background:linear-gradient(to right, var(--gold), #ff5500); }
.ev-card:hover::before { opacity:1; }

.ev-body {
  position:absolute; bottom:0; left:0; right:0;
  padding:1.25rem 1.5rem;
  background:linear-gradient(to top, rgba(0,0,0,0.88) 0%, transparent);
  z-index:1;
}
.ev-tag {
  font-family:var(--f-mono); font-size:0.62rem; letter-spacing:0.14em; text-transform:uppercase;
  margin-bottom:0.35rem; display:flex; align-items:center; gap:5px;
}
/* .ev-tag::before { content:'●'; font-size:0.38em; } */
.ec-corp .ev-tag  { color:var(--cyan); }
.ec-wed  .ev-tag  { color:var(--magenta); }
.ec-mitz .ev-tag  { color:#c4a4ff; }
.ec-gala .ev-tag  { color:var(--gold); }
.ev-name {
  font-family:var(--f-disp); font-weight:800;
  font-size:1.55rem; text-transform:uppercase; letter-spacing:0.03em;
  color:#fff; line-height:1; margin-bottom:0.7rem;
}
.ev-link {
  display:inline-flex; align-items:center; gap:5px;
  font-size:0.78rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em;
  color:rgba(255,255,255,0.5);
  opacity:0; transform:translateY(8px);
  transition:opacity 0.3s, transform 0.3s !important;
}
.ev-card:hover .ev-link { opacity:1; transform:translateY(0); }

/* TESTIMONIALS */
.testi-section { background:var(--surf); position:relative; overflow:hidden; }
.testi-section::before {
  content:'"'; position:absolute; top:-2rem; left:3%;
  font-family:var(--f-disp); font-size:18rem; font-weight:900;
  color:var(--cyan); opacity:0.025; line-height:1; user-select:none; pointer-events:none;
}
.testi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(270px,1fr)); gap:1px; background:var(--bdr); }
.testi-card {
  background:var(--surf);
  padding:2rem;
  position:relative; overflow:hidden;
  transition:background 0.25s !important;
}
/* Corner accent on hover */
.testi-card::before,.testi-card::after {
  content:''; position:absolute; width:12px; height:12px;
  border-color:transparent; border-style:solid;
  transition:border-color 0.3s !important;
}
.testi-card::before { top:0; right:0; border-width:0 2px 2px 0; }
.testi-card::after  { bottom:0; left:0; border-width:2px 0 0 2px; }
.testi-card:hover { background:var(--surf2); }
.testi-card:hover::before,.testi-card:hover::after { border-color:var(--cyan); }
.t-stars { display:flex; gap:4px; margin-bottom:1rem; }
.t-stars i { color:var(--gold); font-size:0.82rem; }
.t-quote { font-size:1rem; color:var(--text-1); line-height:1.75; margin-bottom:1.5rem; font-style:italic; }
.t-who { display:flex; align-items:center; gap:0.75rem; }
.t-av {
  width:38px; height:38px; border-radius:var(--r);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:0.875rem; color:#fff; flex-shrink:0;
}
.t-av-a { background:linear-gradient(135deg,var(--cyan),var(--electric)); }
.t-av-b { background:linear-gradient(135deg,var(--magenta),var(--gold)); }
.t-av-c { background:linear-gradient(135deg,var(--gold),#ff5500); }
.t-name { font-weight:700; font-size:0.9rem; color:var(--text-1); }
.t-role { font-size:0.78rem; color:var(--text-3); }

/* CTA */
.cta-section {
  position:relative; overflow:hidden;
  background:var(--page);
  padding-block:clamp(5rem,10vw,8rem);
  text-align:center;
}
.cta-section::before {
  content:''; position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:55vw; height:55vw; border-radius:50%;
  background:radial-gradient(circle, rgba(245,166,35,0.07) 0%, transparent 65%);
  pointer-events:none;
}
.ring {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  border:1px solid rgba(245,166,35,0.07); border-radius:50%;
  animation:ringPulse 5s ease-in-out infinite;
}
.ring:nth-child(1){width:450px;height:450px;animation-delay:0s}
.ring:nth-child(2){width:650px;height:650px;animation-delay:1.5s;border-color:rgba(245,166,35,0.04)}
.ring:nth-child(3){width:850px;height:850px;animation-delay:3s;  border-color:rgba(245,166,35,0.02)}
@keyframes ringPulse{
  0%,100%{transform:translate(-50%,-50%) scale(1);opacity:1}
  50%    {transform:translate(-50%,-50%) scale(1.06);opacity:0.4}
}
.cta-inner { position:relative; z-index:2; }
.cta-h {
  font-family:var(--f-disp); font-weight:900;
  font-size:clamp(3rem,9vw,7.5rem);
  line-height:0.88; text-transform:uppercase; letter-spacing:-0.02em;
  color:var(--text-1); margin-bottom:1.5rem;
  text-wrap: balance;
}
.cta-h em { font-style:normal; color:var(--cyan); }
.cta-sub { font-size:clamp(1rem,2vw,1.175rem); color:var(--text-2); max-width:44ch; margin-inline:auto; margin-bottom:2.5rem; line-height:1.75; }
.cta-btns { display:flex; flex-wrap:wrap; gap:0.75rem; justify-content:center; margin-bottom:3rem; }
.cta-phones {
  display:flex; flex-wrap:wrap; gap:3rem; justify-content:center;
  border-top:1px solid var(--bdr); padding-top:2rem;
}
.ph-lbl { display:block; font-family:var(--f-mono); font-size:0.62rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-3); margin-bottom:0.3rem; }
.ph-num { font-size:1.2rem; font-weight:700; color:var(--text-1); transition:color 0.2s !important; }
.ph-num:hover { color:var(--cyan); }

/* ═══════════════════════════════════════════════════════════
   V17 ADDITIONS
═══════════════════════════════════════════════════════════ */




/* ═══════════ LIGHT MODE HERO TEXT ═══════════ */
[data-theme="light"] .hero-h1 { color: #000000;  }
[data-theme="light"] .h1-outline {
  -webkit-text-stroke: 2px var(--cyan);
  color: transparent;
}
[data-theme="light"] .hero-eyebrow { color: black; }
[data-theme="light"] .hero-sub { color: #000000; ; font-weight: 900; }
[data-theme="light"] .scroll-hint { color: #3a2400; }
[data-theme="light"] .scroll-hint i { color: var(--cyan); }

/* Dark mode scrollbar amber */
::-webkit-scrollbar-thumb:hover { background: var(--cyan); }

/* Ticker amber bar */
.ticker { background: var(--cyan); }
.t-item { color: #1a0e00; }
.t-sep  { color: rgba(26,14,0,0.5); }


/* ═══════════════════════════════════════════════════════════
   V20 OVERHAUL
═══════════════════════════════════════════════════════════ */

/* ── 1. CLEAN AMBER COLOR (no muddy brown mix) ─────────────
   Replace the brownish tokens with pure vivid amber.
   Only touches the primary --cyan token references.        */
:root {
  --cyan:        #F59E0B;   /* pure amber — Tailwind amber-500             */
  --cyan-dim:    rgba(245,158,11,0.13);
  --cyan-glow:   rgba(245,158,11,0.45);
  --cyan-strong: rgba(245,158,11,0.65);
  --bdr-f:       rgba(245,158,11,0.65);
  --fill-hover:  rgba(245,158,11,0.09);
  --fill-active: rgba(245,158,11,0.18);
  /* Warmer-but-not-muddy dark bg */
  --page:   #0C0A06;
  --surf:   #151209;
  --surf2:  #1E190D;
  --surf3:  #272010;
  --surf4:  #322815;
  --bdr:    rgba(245,158,11,0.11);
  --bdr-s:  rgba(245,158,11,0.22);
  --t1:     #F5EDD8;
  --t2:     #9A8860;
  --t3:     #5A4E30;
  --t4:     #352E1A;
  --nav-bg: rgba(12,10,6,0.90);
  --nav-bdr:rgba(245,158,11,0.12);
}
[data-theme="light"] {
  --cyan:        #D97706;   /* amber-600 — WCAG AA on cream bg */
  --cyan-dim:    rgba(217,119,6,0.12);
  --cyan-glow:   rgba(217,119,6,0.30);
  --cyan-strong: rgba(217,119,6,0.52);
  --bdr-f:       rgba(217,119,6,0.52);
  --fill-hover:  rgba(217,119,6,0.09);
  --fill-active: rgba(217,119,6,0.17);
  --page:   #FFFBF2;
  --surf:   #FDF5E4;
  --surf2:  #F8ECCE;
  --surf3:  #F0E0B2;
  --surf4:  #E8D49A;
  --bdr:    rgba(180,120,20,0.12);
  --bdr-s:  rgba(180,120,20,0.22);
  --t1:     #1C1206;
  --t2:     #4A3510;
  --t3:     #7A6030;
  --t4:     #B09060;
  --nav-bg: rgba(255,251,242,0.95);
  --nav-bdr:rgba(180,120,20,0.12);
}

/* ── 2. STATS BAND — remove top/bottom borders, tighten height ── */
.stats-band {
  padding-block: clamp(1.75rem, 3.5vw, 2.75rem) !important;
}
.stats-band::before,
.stats-band::after {
  display: none !important;
}

/* ── 3. vis-box 2D — full height, no border/radius ─────────────── */
.vis-box-2d {
  position: relative;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  align-self: stretch;
  height: 100% !important;
  min-height: 420px;
  overflow: hidden;

}
.vis-box-2d::before,
.vis-box-2d::after { display: none !important; }
.vis-box-2d #spectrum-2d {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}

/* Make the split section align to stretch so vis-box fills height */
.split { align-items: stretch; }
.split > *:first-child { display: flex; flex-direction: column; justify-content: center; }

/* ── 4. SERVICE "NEW" badge ─────────────────────────────────────── */
.svc-new-badge {
  display: inline-block;
  background: var(--cyan);
  color: #1C1206;
  font-size: 0.48rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  padding: 2px 5px;
  border-radius: 2px;
  vertical-align: middle;
  margin-left: 4px;
  font-family: var(--f-mono);
}

/* ── 5. CTA SPLIT — text gets a frosted glass card ──────────────── */
.cta-section--split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 500px;
  padding: 0 !important;
}
@media(max-width:900px) {
  .cta-section--split { grid-template-columns: 1fr; }
  .cta-canvas-col { min-height: 300px; }
}
.cta-text-col {
  display: flex;
  align-items: center;
  padding: clamp(3rem,7vw,6rem) clamp(2rem,5vw,5rem);
  position: relative;
  z-index: 2;
}
.cta-inner {
  background: rgba(12,10,6,0.70);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  border: 1px solid rgba(245,158,11,0.18);
  border-radius: 8px;
  padding: clamp(2rem,4vw,3.5rem);
  max-width: 560px;
  /* box-shadow: 0 8px 48px rgba(0,0,0,0.4); */
}
[data-theme="light"] .cta-inner {
  background: rgba(255,251,242,0.82);
  border-color: rgba(217,119,6,0.22);
  box-shadow: 0 8px 40px rgba(100,60,0,0.12);
}
.cta-canvas-col {
  position: relative;
  overflow: hidden;
}

/* ── 6. Hero image smooth transition ───────────────────────────── */
#hero-bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: opacity 0.6s ease;
}


/* ═══════════════════════════════════════════════════════════
   V21 — FINAL COLOR + LAYOUT POLISH
═══════════════════════════════════════════════════════════ */

/* ── 1. Stronger, purer color palette ─────────────────────
   Drop the brownish amber. Go to vivid yellow-amber + strong
   accent pair. Dark bg → pure near-black. Light → warm white. */
:root {
  --cyan:        #EAB308;   /* Tailwind yellow-500 — vivid, pure, festive  */
  --cyan-dim:    rgba(234,179,8,0.14);
  --cyan-glow:   rgba(234,179,8,0.50);
  --cyan-strong: rgba(234,179,8,0.70);
  --bdr-f:       rgba(234,179,8,0.70);
  --fill-hover:  rgba(234,179,8,0.10);
  --fill-active: rgba(234,179,8,0.20);

  --magenta:     #EC4899;   /* Tailwind pink-500 — vivid, warm, celebratory */
  --mag-dim:     rgba(236,72,153,0.13);
  --mag-glow:    rgba(236,72,153,0.42);

  --gold:        #FBBF24;   /* Tailwind amber-400 — brighter highlight      */
  --gold-dim:    rgba(251,191,36,0.15);

  --electric:    #818CF8;   /* Tailwind indigo-400 — cool contrast accent   */
  --elec-dim:    rgba(129,140,248,0.14);

  /* Pure dark — no brown cast */
  --page:   #09090B;
  --surf:   #111113;
  --surf2:  #1C1C1F;
  --surf3:  #27272A;
  --surf4:  #3F3F46;
  --bdr:    rgba(234,179,8,0.10);
  --bdr-s:  rgba(234,179,8,0.22);

  --t1:     #FAFAFA;
  --t2:     #A1A1AA;
  --t3:     #52525B;
  --t4:     #27272A;

  --nav-bg: rgba(9,9,11,0.90);
  --nav-bdr:rgba(234,179,8,0.12);
}
[data-theme="light"] {
  --cyan:        #CA8A04;   /* Tailwind yellow-600 — AA contrast on cream  */
  --cyan-dim:    rgba(202,138,4,0.12);
  --cyan-glow:   rgba(202,138,4,0.32);
  --cyan-strong: rgba(202,138,4,0.55);
  --bdr-f:       rgba(202,138,4,0.55);
  --fill-hover:  rgba(202,138,4,0.09);
  --fill-active: rgba(202,138,4,0.18);

  --magenta:     #DB2777;
  --mag-dim:     rgba(219,39,119,0.10);
  --mag-glow:    rgba(219,39,119,0.30);

  --gold:        #D97706;
  --gold-dim:    rgba(217,119,6,0.12);

  --electric:    #6366F1;
  --elec-dim:    rgba(99,102,241,0.12);

  --page:   #FFFBEB;
  --surf:   #FEF9E7;
  --surf2:  #FDE68A;
  --surf3:  #FCD34D;
  --surf4:  #FBBF24;
  --bdr:    rgba(202,138,4,0.14);
  --bdr-s:  rgba(202,138,4,0.26);

  --t1:     #0C0A00;
  --t2:     #44403C;
  --t3:     #78716C;
  --t4:     #A8A29E;

  --nav-bg: rgba(255,251,235,0.96);
  --nav-bdr:rgba(202,138,4,0.14);
}

/* ── 2. Hero text — better vertical centering ──────────────
   The hero-inner was anchored too high; add auto margins so
   the text block floats closer to true vertical center.     */
.hero {
  justify-content: center !important;
  align-items: center !important;
}
.hero-inner {
  padding-block: clamp(2rem, 8vh, 6rem) !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* ── 3. CTA split section — fully seamless ─────────────────
   Two halves sit flush edge-to-edge; no visible divider line.
   Text column gets proper scaling; rings column fills fully. */
.cta-section--split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: clamp(460px, 60vh, 640px);
  padding: 0 !important;
  gap: 0 !important;
  border: none !important;
}
.cta-text-col {
  display: flex;
  align-items: center;
  padding: clamp(2.5rem, 5vw, 5rem) clamp(2rem, 4vw, 4.5rem) !important;
  background: var(--page);
  position: relative;
  z-index: 2;
}
.cta-inner {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  max-width: 520px;
  width: 100%;
}
/* Scale the CTA heading to fit its column */
.cta-h {
  font-size: clamp(2rem, 4.5vw, 4rem) !important;
  line-height: 0.92 !important;
  margin-bottom: 1rem !important;
}
.cta-sub {
  font-size: clamp(0.875rem, 1.5vw, 1.05rem) !important;
  margin-bottom: 1.75rem !important;
}
.cta-canvas-col {
  position: relative;
  overflow: hidden;
  background: var(--surf);
}
/* Divider line between columns — subtle amber hairline */
.cta-text-col::after {
  content: '';
  position: absolute;
  top: 8%;
  right: 0;
  bottom: 8%;
  width: 1px;
  background: linear-gradient(to bottom, transparent, var(--bdr-s) 30%, var(--bdr-s) 70%, transparent);
}

/* ═══════════════════════════════════════════════════════════
   EVENT SLIDER v25 — single authoritative block, no overrides
═══════════════════════════════════════════════════════════ */

#ev-section {
  position: relative;
  padding: 0;
  margin: 0;
}

#ev-outer {
  position: relative;
  width: 100%;
  height: 100svh;
  min-height: 580px;
  overflow: hidden;
  background: #000;
}

/* Floating section label */
#ev-label {
  position: absolute;
  top: clamp(5rem, 10vh, 8rem);
  left: clamp(2rem, 8vw, 8rem);
  z-index: 10;
  pointer-events: none;
}
#ev-label .eyebrow { color: var(--cyan); display: block; margin-bottom: 0.4rem; }
.ev-label-title {
  font-family: var(--f-disp);
  font-weight: 900;
  font-size: clamp(1.4rem, 3.2vw, 2.6rem);
  line-height: 1.08;
  text-transform: uppercase;
  color: rgba(255,255,255,0.90);
  text-shadow: 0 2px 24px rgba(0,0,0,0.55);
  margin: 0;
}
.ev-label-title em { font-style: normal; color: var(--cyan); }

/* Track: relative block, fills outer */
#ev-track {
  position: relative;
  width: 100%;
  height: 100%;
}

/* Individual slides — absolutely stacked */
.ev-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.85s ease;
  z-index: 1;
}
/* Active slide is visible */
.ev-slide.ev-on {
  opacity: 1;
  z-index: 2;
}

/* Background photo */
.ev-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}

/* Gradient overlay — heavy left (text side) → transparent right */
.ev-shade {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(100deg,
      rgba(0,0,0,0.80) 0%,
      rgba(0,0,0,0.50) 35%,
      rgba(0,0,0,0.15) 65%,
      transparent 85%),
    linear-gradient(to top,
      rgba(0,0,0,0.55) 0%,
      transparent 45%);
}
[data-theme="light"] .ev-shade {
  background:
    linear-gradient(100deg,
      rgba(255,251,235,0.75) 0%,
      rgba(255,251,235,0.40) 35%,
      rgba(255,251,235,0.10) 60%,
      transparent 80%),
    linear-gradient(to top,
      rgba(0,0,0,0.30) 0%,
      transparent 45%);
}

/* Slide content */
.ev-content {
  position: absolute;
  left:   clamp(2rem, 8vw, 8rem);
  bottom: clamp(4.5rem, 12vh, 8rem);
  z-index: 3;
  max-width: min(580px, 56vw);
}

.ev-icon {
  font-size: clamp(2rem, 4vw, 3.5rem);
  color: var(--cyan);
  display: block;
  margin-bottom: 0.9rem;
  filter: drop-shadow(0 0 10px var(--cyan-glow));
}

.ev-tag {
  font-family: var(--f-mono);
  font-size: 1rem;
  letter-spacing: 0.20em;
  text-transform: uppercase;

  margin-bottom: 0.6rem;

  align-items: center;
  gap: 8px;




   display: inline-block;
      background: linear-gradient(90deg, #ff6a00, #ee0979);
      color: #fff;
      font-size: 1.1rem;
      font-weight: 700;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      padding: 8px 22px;
      border-radius: 4px;
      box-shadow: 0 0 18px rgba(255, 80, 0, 0.55);
      margin-bottom: 14px;
}


.ev-name {
  font-family: var(--f-disp);
  font-weight: 900;
  font-size: clamp(2.8rem, 6.5vw, 6rem);
  line-height: 0.92;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 1.1rem;
}

.ev-sub {
  font-size: clamp(0.88rem, 1.5vw, 1.05rem);
  line-height: 1.68;
  color: rgba(255,255,255,0.70);
  max-width: 44ch;
  margin: 0 0 1.6rem;
}

.ev-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--cyan);
  color: #09090B;
  font-family: var(--f-disp);
  font-weight: 800;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.8rem 1.6rem;
  border-radius: 4px;
  text-decoration: none;
  transition: gap 0.2s, box-shadow 0.2s, background 0.2s;
}
.ev-cta:hover {
  gap: 14px;
  background: var(--gold);
  box-shadow: 0 0 28px var(--cyan-glow);
}

/* Arrow buttons */
.ev-arr {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  width: 50px; height: 50px;
  border-radius: 50%;
  background: rgba(9,9,11,0.65);
  border: 1px solid rgba(234,179,8,0.28);
  color: #fff;
  font-size: 1.2rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(8px);
  transition: background 0.2s, transform 0.2s;
}
.ev-arr:hover {
  background: var(--cyan);
  color: #09090B;
  transform: translateY(-50%) scale(1.08);
}
#ev-prev { left:  clamp(1rem, 3vw, 2.5rem); }
.ev-arr-r { right: clamp(1rem, 3vw, 2.5rem); }

/* Dot indicators */
#ev-dots {
  position: absolute;
  bottom: 1.6rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
  display: flex;
  gap: 8px;
  align-items: center;
}
.ev-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.30);
  border: 1px solid rgba(255,255,255,0.45);
  padding: 0;
  cursor: pointer;
  transition: width 0.35s ease, border-radius 0.35s ease, background 0.25s;
}
.ev-dot.ev-dot-on {
  width: 30px;
  border-radius: 4px;
  background: var(--cyan);
  border-color: var(--cyan);
}

/* Progress bar */
#ev-prog-wrap {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: rgba(255,255,255,0.08);
  z-index: 20;
}
#ev-prog {
  height: 100%;
  width: 0%;
  background: var(--cyan);
}

/* Mobile */
@media (max-width: 639px) {
  #ev-label { top: calc(var(--nav-h, 66px) + 1.2rem); left: 1.25rem; }
  .ev-label-title { font-size: clamp(1.1rem, 5vw, 1.8rem); }
  .ev-content { left: 1.25rem; right: 1.25rem; bottom: 4.5rem; max-width: 100%; }
  .ev-name    { font-size: clamp(2.2rem, 10vw, 3.5rem); }
  .ev-sub     { display: none; }
  .ev-arr     { width: 40px; height: 40px; font-size: 1rem; }
  #ev-prev    { left: 0.75rem; }
  .ev-arr-r   { right: 0.75rem; }
}


/* ── Testimonials ─────────────────────────────────────────── */
.testi-slider-wrap {
  position: relative;
  overflow: hidden;
  margin-inline: -2rem;
}
.testi-slider-wrap #testi-track {
  /* JS sets inline styles; this is the fallback */
  display: flex;
  gap: 20px;
  width: max-content;
}
.testi-card-v2 {
  flex: 0 0 clamp(300px, 30vw, 400px);
}
/* First card left padding so it doesn't hug the edge */
.testi-slider-wrap .testi-card-v2:first-child { margin-left: max(2rem, 8vw); }

/* Arrow buttons */
.testi-arr {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--surf2);
  border: 1px solid var(--bdr-s);
  color: var(--t1);
  font-size: 1.1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, color 0.2s, transform 0.2s;
  box-shadow: 0 4px 18px rgba(0,0,0,0.22);
}
.testi-arr:hover {
  background: var(--cyan);
  color: #09090B;
  transform: translateY(-50%) scale(1.1);
}
.testi-arr-prev { left: 0.5rem; }
.testi-arr-next { right: 0.5rem; }


/* ── CTA unified ──────────────────────────────────────────── */
.cta-unified {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: clamp(500px, 65vh, 720px);
  background: var(--surf);
  padding: 0;
  gap: 0;
}
@media (max-width: 900px) {
  .cta-unified { grid-template-columns: 1fr; }
  .cta-unified-right { min-height: 360px; }
}
.cta-unified--flipped { direction: rtl; }
.cta-unified--flipped > * { direction: ltr; }

.cta-unified-text {
  display: flex;
  align-items: center;
  padding: clamp(2.5rem, 5vw, 5rem) clamp(2rem, 4vw, 4.5rem);
  background: var(--page);
}
.cta-unified-text .cta-inner {
  background: transparent;
  border: none;
  padding: 0;
  box-shadow: none;
  backdrop-filter: none;
  max-width: 520px;
  width: 100%;
}
.cta-unified-text .cta-h {
  font-size: clamp(2rem, 4vw, 3.75rem);
  line-height: 0.92;
  margin-bottom: 1rem;
}

.cta-unified-right {
  display: flex;
  flex-direction: column;
  background: var(--surf);
}
.cta-canvas-wrap {
  flex: 1;
  position: relative;
  min-height: 280px;
}
.cta-canvas-wrap canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.cta-divider-line {
  width: 40%;
  max-width: 160px;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--bdr-s), transparent);
  margin: 0 auto;
}

/* Contact rows — centered */
.cta-right-footer {
  padding: 1.5rem 2rem 2rem;
  border-top: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.85rem;
  background: var(--surf);
}
.cta-rf-row {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  width: 100%;
  max-width: 320px;
}
.cta-rf-icon { color: var(--cyan); font-size: 0.95rem; margin-top: 3px; flex-shrink: 0; }
.cta-rf-label {
  font-family: var(--f-mono);
  font-size: 0.58rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--t3);
  margin-bottom: 2px;
}
.cta-rf-val { font-size: 0.875rem; color: var(--t1); text-decoration: none; line-height: 1.5; }
a.cta-rf-val:hover { color: var(--cyan); }


/* ── Footer polish ────────────────────────────────────────── */
.footer-bot { padding-block: 1.25rem; border-top: 1px solid var(--bdr); }
.f-copy { font-size: 0.78rem; color: var(--t2); }
.f-bot-nav a { font-size: 0.75rem; color: var(--t2); }
.f-bot-nav a:hover { color: var(--cyan); }
.footer-inner { padding-block: clamp(2.5rem, 5vw, 4rem) 0; }


/* ── Testimonials heading size ────────────────────────────── */
.testi-section .sec-title {
  font-size: clamp(2rem, 5vw, 3.5rem);
}


/* ═══════════════════════════════════════════════════════════
   V26 FIXES — Nav · Testi cards · CTA background · Theme
═══════════════════════════════════════════════════════════ */

/* ── 1. Nav: transparent class for slider lock ──────────── */
/* Applied via window.evSliderLocked + inline styles in JS.
   This class is a CSS-only fallback for browsers where
   inline style on backdrop-filter is ignored.             */
.nav.ev-transparent {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border-bottom: 1px solid transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* ── 2. Testimonial card v2 — full restoration ──────────── */
.testi-section {
  background: var(--surf);
}
.testi-header {
  display: flex;
  align-items: flex-start;
  gap: clamp(2rem, 5vw, 5rem);
  margin-bottom: clamp(2rem, 4vw, 3rem);
  flex-wrap: wrap;
}
.testi-aggregate {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  flex-shrink: 0;
}
.testi-big-score {
  font-family: var(--f-disp);
  font-size: clamp(3.5rem, 7vw, 5.5rem);
  font-weight: 900;
  color: var(--t1);
  line-height: 1;
}
.testi-big-stars { display: flex; gap: 3px; margin-bottom: 0.35rem; }
.testi-big-stars i { color: var(--surf); font-size: 1.1rem; }
.testi-total { font-size: 0.82rem; color: var(--t2); margin-bottom: 0.75rem; font-family: var(--f-mono); letter-spacing: 0.04em; }
.testi-bars { display: flex; flex-direction: column; gap: 5px; min-width: 200px; }
.testi-bar-row { display: flex; align-items: center; gap: 8px; font-size: 0.72rem; color: var(--t3); font-family: var(--f-mono); }
.testi-bar-row span:first-child { min-width: 20px; color: var(--cyan); }
.testi-bar-row span:last-child  { min-width: 28px; }
.testi-bar-track { flex: 1; height: 6px; background: var(--surf3); border-radius: 3px; overflow: hidden; }
.testi-bar-fill  { height: 100%; background: var(--cyan); border-radius: 3px; }

.testi-filters { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 2rem; }
.testi-filter {
  padding: 0.45rem 1.1rem;
  border-radius: 100px;
  border: 1px solid var(--bdr-s);
  background: transparent;
  color: var(--t2);
  font-size: 0.8rem;
  font-family: var(--f-mono);
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.testi-filter:hover,
.testi-filter.is-active {
  background: var(--cyan);
  color: #09090B;
  border-color: var(--cyan);
}

/* Card itself */
.testi-card-v2 {
  flex: 0 0 clamp(300px, 32vw, 400px) !important;
  max-width: 400px;
  background: var(--surf2);
  border: 1px solid var(--bdr);
  border-radius: 12px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  transition: border-color 0.25s, transform 0.25s, box-shadow 0.25s;
}
.testi-card-v2:hover {
  border-color: var(--cyan-dim);
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.25), 0 0 0 1px var(--cyan-dim);
}

.tcv2-top {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.tcv2-top .t-av {
  width: 42px; height: 42px;
  border-radius: 50%;
  font-size: 1rem;
  flex-shrink: 0;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
}
.tcv2-verified {
  margin-left: auto;
  font-size: 0.66rem;
  font-family: var(--f-mono);
  letter-spacing: 0.06em;
  color: var(--cyan);
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
.tcv2-tag {
  font-family: var(--f-mono);
  font-size: 0.65rem;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--t3);
  padding: 0.25rem 0.6rem;
  background: var(--surf3);
  border-radius: 4px;
  display: inline-block;
  align-self: flex-start;
}
.t-quote {
  font-size: 0.9375rem;
  color: var(--t1);
  line-height: 1.72;
  font-style: italic;
  flex: 1;
}
.tcv2-helpful {
  font-size: 0.72rem;
  color: var(--t3);
  font-family: var(--f-mono);
  letter-spacing: 0.04em;
  display: flex;
  align-items: center;
  gap: 5px;
  border-top: 1px solid var(--bdr);
  padding-top: 0.75rem;
  margin-top: 0.25rem;
}
.tcv2-helpful i { color: var(--cyan); }
.t-name { font-weight: 700; font-size: 0.9rem; color: var(--t1); }
.t-role { font-size: 0.78rem; color: var(--t3); }
.t-stars { display: flex; gap: 4px; }
.t-stars i { color: var(--gold); font-size: 0.82rem; }
.t-av-a { background: linear-gradient(135deg, var(--cyan), var(--electric)); }
.t-av-b { background: linear-gradient(135deg, var(--magenta), var(--gold)); }
.t-av-c { background: linear-gradient(135deg, var(--gold), #ff5500); }

/* Testi section heading: smaller */
.testi-section .sec-title {
  font-size: clamp(2rem, 5vw, 3.5rem) !important;
}

/* ── 3. CTA: fully unified single background ─────────────── */
/* Both columns get the exact same --surf background         */
.cta-unified {
  background: var(--surf) !important;
}
.cta-unified-text {
  background: var(--surf) !important;  /* was --page, now matches */
  border-right: none !important;
}
.cta-unified-text::after { display: none !important; }  /* remove hairline divider */
.cta-unified-right {
  background: var(--surf) !important;
}
.cta-canvas-wrap,
.cta-right-footer {
  background: var(--surf) !important;
}

/* ── 4. Theme-aware: dark/light image swap ───────────────── */
img[data-src-dark], img[data-src-light] {
  transition: opacity 0.5s ease;
}
img[data-src-dark].theme-img-loading,
img[data-src-light].theme-img-loading {
  opacity: 0;
}

/* ── 5. Cross-browser: no inset shorthand fallback ──────── */
/* (slides now use explicit top/left/right/bottom in JS) */

/* ── 6. Dark/Light mode slider overlay ──────────────────── */
.ev-shade {
  background:
    linear-gradient(100deg,
      rgba(0,0,0,0.80) 0%,
      rgba(0,0,0,0.50) 35%,
      rgba(0,0,0,0.15) 65%,
      transparent 85%),
    linear-gradient(to top,
      rgba(0,0,0,0.55) 0%,
      transparent 45%);
}
[data-theme="light"] .ev-shade {
  background:
    linear-gradient(100deg,
      rgba(255,251,235,0.75) 0%,
      rgba(255,251,235,0.40) 35%,
      rgba(255,251,235,0.10) 60%,
      transparent 80%),
    linear-gradient(to top,
      rgba(0,0,0,0.30) 0%,
      transparent 45%);
}


/* ═══════════════════════════════════════════════════════════
   V27 — REVIEWS CENTER · CTA SWAP · ALT BACKGROUNDS
═══════════════════════════════════════════════════════════ */

/* ── 1. Testimonials header: centered ───────────────────── */
.testi-header--center {
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  gap: 1.5rem !important;
}
.testi-header--center .testi-header-text {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.testi-header--center .testi-aggregate {
  justify-content: center;
}
/* Remove the quotation mark / eyebrow decorative icon */
.testi-section .eyebrow::before {
  display: none !important;
  content: none !important;
}
.testi-section .eyebrow i,
.testi-section .eyebrow svg {
  display: none !important;
}

/* ── 2. CTA: diagram LEFT, contact RIGHT — no direction:rtl needed
   (HTML order is now diagram-first, text-second)            */
.cta-unified {
  direction: ltr !important;   /* reset any previous rtl */
}
.cta-unified--flipped {
  direction: ltr !important;   /* neutralize old class */
}

/* CTA text column: same surface background */
.cta-unified-text {
  background: var(--surf) !important;
}

/* Divider under diagram: slightly thicker, not full-width */
.cta-divider-line {
  width: 55% !important;
  max-width: 220px !important;
  height: 2px !important;        /* slightly taller/thicker */
  background: linear-gradient(to right, transparent, var(--bdr-s) 25%, var(--bdr-s) 75%, transparent) !important;
  margin: 0 auto !important;
}

/* Phone numbers row under CTAs — align divider visually with diagram divider */
.cta-phones {
  padding-top: 1.25rem !important;
  margin-top: 1.25rem !important;
  border-top: 2px solid var(--bdr) !important;  /* same thickness as diagram divider */
}

/* ── 3. Section alternating backgrounds ─────────────────── */
/* Dark mode base values */
:root {
  --sec-a: #09090B;          /* darkest — page base */
  --sec-b: #111115;          /* slightly lighter */
  --sec-c: #0D0D10;          /* mid-dark */
}
[data-theme="light"] {
  --sec-a: #FFFBEB;          /* warm cream */
  --sec-b: #F5F0E0;          /* slightly cooler */
  --sec-c: #FAF5E8;          /* between */
}

/* Apply to sections */
.hero           { background: var(--page) !important; }    /* darkest */
.stats-band     { background: var(--sec-b) !important; }   /* slightly lighter */
.sec-alt-a      { background: var(--sec-a) !important; }   /* back to dark */
#ev-section     { background: #000 !important; }           /* full black for slides */
.sec-alt-b      { background: var(--sec-b) !important; }   /* lighter */
.cta-unified.sec-alt-a { background: var(--sec-c) !important; }  /* mid */
.cta-unified.sec-alt-a .cta-unified-text,
.cta-unified.sec-alt-a .cta-unified-right,
.cta-unified.sec-alt-a .cta-canvas-wrap,
.cta-unified.sec-alt-a .cta-right-footer { background: var(--sec-c) !important; }

.testi-section.sec-alt-b { background: var(--sec-b) !important; }

/* Light mode: more noticeable contrast between sections */
[data-theme="light"] .stats-band     { background: #F0EAD6 !important; }
[data-theme="light"] .sec-alt-a      { background: #FFFBEB !important; }
[data-theme="light"] .sec-alt-b      { background: #F5EDD0 !important; }
[data-theme="light"] .cta-unified.sec-alt-a,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-text,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-right,
[data-theme="light"] .cta-unified.sec-alt-a .cta-canvas-wrap,
[data-theme="light"] .cta-unified.sec-alt-a .cta-right-footer { background: #FAF4DF !important; }
[data-theme="light"] .testi-section.sec-alt-b { background: #F0EAD0 !important; }

/* ── 4. Snap stat that had "zero" class — removed, now count-up ── */
.zero { display: none; }  /* hide if somehow still in DOM */


/* ═══════════════════════════════════════════════════════════
   V28 — STATS STARS · SLIDER HINT · TESTI HEADER · CTA SIZE
═══════════════════════════════════════════════════════════ */

/* ── 1. Stats: 4.9 star rating cell ────────────────────── */
.stat-n--stars {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  font-size: inherit;
}
.stat-score {
  font-family: var(--f-disp);
  font-weight: 900;
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1;
  color: var(--t1);
}
.stat-stars {
  display: flex;
  gap: 3px;
  font-size: 1.1rem;
}
.stat-stars i { color: var(--gold); }

/* ── 2. Arrow hint animation (always-mode) ─────────────── */
@keyframes arrowPulse {
  0%   { transform: translateY(-50%) translateX(0);        box-shadow: 0 0 0 0 var(--cyan-glow); }
  25%  { transform: translateY(-50%) translateX(-6px);      box-shadow: 0 0 16px var(--cyan-glow); }
  50%  { transform: translateY(-50%) translateX(0);        box-shadow: 0 0 0 0 var(--cyan-glow); }
  75%  { transform: translateY(-50%) translateX(-6px);      box-shadow: 0 0 16px var(--cyan-glow); }
  100% { transform: translateY(-50%) translateX(0);        box-shadow: 0 0 0 0 var(--cyan-glow); }
}
.ev-arr-hint {
  animation: arrowPulse 1.1s ease-in-out 2;
  background: var(--cyan) !important;
  color: #09090B !important;
}

/* Progress bar hidden in always-mode (JS sets width:0%) */
body.ev-done #ev-prog-wrap { opacity: 0; }

/* ── 3. Testimonials header: side-by-side, centered ────── */
.testi-header--row-center {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;   /* center the whole row */
  gap: clamp(2rem, 5vw, 5rem) !important;
  flex-wrap: wrap;
  text-align: left !important;
}
.testi-header--row-center .testi-header-text { flex-shrink: 0; }
.testi-header--row-center .testi-aggregate   { flex-shrink: 0; }

/* ── 4. Media filter row ────────────────────────────────── */
.testi-filters--media {
  margin-top: -0.75rem;
  margin-bottom: 1.75rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--bdr);
}
.testi-filter-media {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0.4rem 1rem;
  border-radius: 100px;
  border: 1px solid var(--bdr-s);
  background: transparent;
  color: var(--t2);
  font-size: 0.78rem;
  font-family: var(--f-mono);
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.testi-filter-media i { font-size: 0.85rem; }
.testi-filter-media:hover,
.testi-filter-media.is-active {
  background: var(--cyan);
  color: #09090B;
  border-color: var(--cyan);
}

/* ── 5. CTA section: restore full sizing ───────────────── */
/* The section shrank — restore proper padding + canvas height */
.cta-unified {
  min-height: clamp(540px, 70vh, 800px) !important;
}
.cta-unified-right {
  min-height: clamp(540px, 70vh, 800px) !important;
  display: flex;
  flex-direction: column;
}
.cta-canvas-wrap {
  flex: 1 1 auto !important;
  min-height: clamp(300px, 45vh, 560px) !important;
}
.cta-unified-text {
  padding: clamp(3rem, 6vw, 6rem) clamp(2.5rem, 5vw, 5rem) !important;
}

/* ── 6. Warm gradient bleeds between sections (low-key) ── */
/* Dark mode: subtle amber warmth radiating between sections */
:root {
  --warm-glow-dark: rgba(234,179,8,0.04);   /* very faint amber */
  --warm-glow-lite: rgba(247,37,133,0.04);  /* very faint pink  */
}

.sec-alt-a { box-shadow: 0 -1px 0 var(--bdr), 0 1px 0 var(--bdr); }

/* Section edges: tiny warm gradient "breath" */
.section::after,
.stats-band::after,
.testi-section::after,
.cta-unified::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0; right: 0;
  height: 80px;
  background: linear-gradient(to bottom, transparent, var(--warm-glow-dark));
  pointer-events: none;
  z-index: 0;
}
[data-theme="light"] .section::after,
[data-theme="light"] .stats-band::after,
[data-theme="light"] .testi-section::after,
[data-theme="light"] .cta-unified::after {
  background: linear-gradient(to bottom, transparent, var(--warm-glow-lite));
}

/* Only apply to sections that are position:relative */
.section, .stats-band, .testi-section { position: relative; overflow: visible; }


/* ═══════════════════════════════════════════════════════════
   V29 — COLOR OVERHAUL: WARM SPECTRUM
   Dark mode:  deep black → vivid amber/yellow as primary
   Light mode: warm cream → pink→orange→red→yellow spectrum
═══════════════════════════════════════════════════════════ */

/* DARK MODE — black base, amber/yellow primary */
:root {
  --cyan:        #F59E0B;    /* pure amber — main accent        */
  --cyan-dim:    rgba(245,158,11,0.14);
  --cyan-glow:   rgba(245,158,11,0.50);
  --cyan-strong: rgba(245,158,11,0.70);
  --bdr-f:       rgba(245,158,11,0.70);
  --fill-hover:  rgba(245,158,11,0.10);
  --fill-active: rgba(245,158,11,0.20);

  --magenta:     #FB7185;    /* warm rose-pink                   */
  --mag-dim:     rgba(251,113,133,0.14);
  --mag-glow:    rgba(251,113,133,0.42);

  --gold:        #FCD34D;    /* bright warm yellow               */
  --gold-dim:    rgba(252,211,77,0.15);

  --electric:    #FDBA74;    /* soft orange                      */
  --elec-dim:    rgba(253,186,116,0.14);

  /* True dark backgrounds */
  --page:   #080808;
  --surf:   #0F0F0F;
  --surf2:  #181818;
  --surf3:  #232323;
  --surf4:  #2E2E2E;
  --bdr:    rgba(245,158,11,0.10);
  --bdr-s:  rgba(245,158,11,0.22);

  --t1:   #FAFAFA;
  --t2:   #A3A3A3;
  --t3:   #525252;
  --t4:   #2A2A2A;

  --nav-bg:  rgba(8,8,8,0.92);
  --nav-bdr: rgba(245,158,11,0.12);

  /* Warm glow bleeds between sections */
  --warm-glow-dark: rgba(245,158,11,0.05);
}

/* LIGHT MODE — cream base, pink→orange→red→yellow spectrum */
[data-theme="light"] {
  --cyan:        #EA580C;    /* vivid orange — WCAG AA on cream  */
  --cyan-dim:    rgba(234,88,12,0.12);
  --cyan-glow:   rgba(234,88,12,0.32);
  --cyan-strong: rgba(234,88,12,0.55);
  --bdr-f:       rgba(234,88,12,0.55);
  --fill-hover:  rgba(234,88,12,0.09);
  --fill-active: rgba(234,88,12,0.18);

  --magenta:     #E11D48;    /* vivid red-pink                   */
  --mag-dim:     rgba(225,29,72,0.10);
  --mag-glow:    rgba(225,29,72,0.30);

  --gold:        #D97706;    /* amber-gold                       */
  --gold-dim:    rgba(217,119,6,0.12);

  --electric:    #9333EA;    /* purple contrast accent           */
  --elec-dim:    rgba(147,51,234,0.10);

  /* Warm cream surfaces */
  --page:   #FFF8F0;
  --surf:   #FEF2E4;
  --surf2:  #FDEBD0;
  --surf3:  #FCE3BA;
  --surf4:  #FBCF96;
  --bdr:    rgba(234,88,12,0.12);
  --bdr-s:  rgba(234,88,12,0.24);

  --t1:   #1A0800;
  --t2:   #4D2500;
  --t3:   #7A4020;
  --t4:   #A86040;

  --nav-bg:  rgba(255,248,240,0.96);
  --nav-bdr: rgba(234,88,12,0.12);

  --warm-glow-lite: rgba(247,37,133,0.05);
}

/* Button text on amber/orange bg: dark for contrast */
.btn-solid { color: #1A0800 !important; font-weight: 800; }
[data-theme="light"] .btn-solid { color: #1A0800 !important; }

/* Ticker bar */
.ticker { background: var(--cyan) !important; }
.t-item, .t-sep { color: #1A0800 !important; }

/* Nav book button */
.nav-book-btn { color: #1A0800 !important; }

/* Stat stars gold */
.stat-stars i { color: var(--gold) !important; }
.testi-big-stars i, .t-stars i { color: var(--gold) !important; }

/* Light mode: logo mark gradient warm */
[data-theme="light"] .nav-logo-mark {
  background: linear-gradient(135deg, #EA580C, #E11D48) !important;
}

/* Light mode: eyebrow text */
[data-theme="light"] .eyebrow { color: var(--cyan) !important; }

/* Warm gradient breath between sections */
.section::after,
.stats-band::after,
.testi-section::after {
  content: '';
  position: absolute;
  bottom: -1px; left: 0; right: 0;
  height: 60px;
  background: linear-gradient(to bottom, transparent, var(--warm-glow-dark));
  pointer-events: none;
  z-index: 0;
}
[data-theme="light"] .section::after,
[data-theme="light"] .stats-band::after,
[data-theme="light"] .testi-section::after {
  background: linear-gradient(to bottom, transparent, var(--warm-glow-lite));
}

/* Alternating section backgrounds — warm tones */
.sec-alt-a { background: var(--page) !important; }
.sec-alt-b { background: var(--surf) !important; }

/* CTA section: ensure both halves share same warm surface */
.cta-unified.sec-alt-a,
.cta-unified.sec-alt-a .cta-unified-text,
.cta-unified.sec-alt-a .cta-unified-right,
.cta-unified.sec-alt-a .cta-canvas-wrap,
.cta-unified.sec-alt-a .cta-right-footer {
  background: var(--surf2) !important;
}

/* Light mode section alternation — visible warm contrast */
[data-theme="light"] .sec-alt-b { background: #FEF2E4 !important; }
[data-theme="light"] .stats-band { background: #FDEBD0 !important; }
[data-theme="light"] .cta-unified.sec-alt-a,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-text,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-right,
[data-theme="light"] .cta-unified.sec-alt-a .cta-canvas-wrap,
[data-theme="light"] .cta-unified.sec-alt-a .cta-right-footer {
  background: #FCE3BA !important;
}
[data-theme="light"] .testi-section.sec-alt-b { background: #FEF2E4 !important; }


/* ═══════════════════════════════════════════════════════════
   V30 — ALL 6 FIXES
═══════════════════════════════════════════════════════════ */

/* ── 1. DARK MODE: Strong warm yellow primary ───────────── */
:root {
  --cyan:        #F5C518;    /* vivid warm yellow — electric, bold  */
  --cyan-dim:    rgba(245,197,24,0.14);
  --cyan-glow:   rgba(245,197,24,0.55);
  --cyan-strong: rgba(245,197,24,0.75);
  --bdr-f:       rgba(245,197,24,0.75);
  --fill-hover:  rgba(245,197,24,0.10);
  --fill-active: rgba(245,197,24,0.22);
  --gold:        #FFD60A;    /* even brighter highlight yellow      */
  --gold-dim:    rgba(255,214,10,0.15);
}

/* ── 2. LIGHT MODE: Deep magenta-crimson as primary ────── */
[data-theme="light"] {
  /* Vivid deep magenta — energetic, luxury, event-ready */
  --cyan:        #C2185B;    /* deep magenta-crimson, WCAG AA       */
  --cyan-dim:    rgba(194,24,91,0.12);
  --cyan-glow:   rgba(194,24,91,0.35);
  --cyan-strong: rgba(194,24,91,0.58);
  --bdr-f:       rgba(194,24,91,0.58);
  --fill-hover:  rgba(194,24,91,0.08);
  --fill-active: rgba(194,24,91,0.18);

  /* Secondary: electric coral */
  --magenta:     #D81B60;
  --mag-dim:     rgba(216,27,96,0.12);
  --mag-glow:    rgba(216,27,96,0.32);

  /* Gold accent: vivid amber */
  --gold:        #F57C00;
  --gold-dim:    rgba(245,124,0,0.12);

  /* Electric: deep violet contrast */
  --electric:    #7B1FA2;
  --elec-dim:    rgba(123,31,162,0.12);

  /* Light mode palette — warm champagne-white */
  --page:   #FFFAF5;    /* warm off-white          */
  --surf:   #FFF0E8;    /* peachy cream            */
  --surf2:  #FFE4D6;    /* slightly deeper         */
  --surf3:  #FFD5C0;    /* visible warm contrast   */
  --surf4:  #FFC4A8;    /* active/selected         */

  --bdr:    rgba(194,24,91,0.12);
  --bdr-s:  rgba(194,24,91,0.25);

  --t1:   #1A0010;    /* near-black with magenta hint  */
  --t2:   #5C1040;    /* dark rose                     */
  --t3:   #9E3060;    /* mid rose                      */
  --t4:   #C06080;    /* muted rose                    */

  --nav-bg:  rgba(255,250,245,0.96);
  --nav-bdr: rgba(194,24,91,0.14);
}

/* Light mode: btn-solid text stays dark */
[data-theme="light"] .btn-solid { color: #FFFAF5 !important; }
/* (magenta bg is dark enough for white text) */

/* Ticker in light mode */
[data-theme="light"] .ticker { background: var(--cyan) !important; }
[data-theme="light"] .t-item,
[data-theme="light"] .t-sep  { color: #FFFAF5 !important; }

/* Nav book btn in light mode */
[data-theme="light"] .nav-book-btn { color: #FFFAF5 !important; }

/* Logo mark gradient */
[data-theme="light"] .nav-logo-mark {
  background: linear-gradient(135deg, #C2185B, #F57C00) !important;
}

/* Star color */
[data-theme="light"] .stat-stars i,
[data-theme="light"] .testi-big-stars i,
[data-theme="light"] .t-stars i { color: #F57C00 !important; }

/* ── 3. BIG SLIDE: text adapts to dark/light mode ───────── */
/* Dark mode: white text (default, already set) */
.ev-name { color: #fff; }
.ev-sub  { color: rgba(255,255,255,0.78); }
.ev-tag  { color: rgba(255,255,255,0.90); }
.ev-label-title { color: rgba(255,255,255,0.92); }

/* Light mode: dark text so it reads on cream overlay */
[data-theme="light"] .ev-name         { color: #1A0010 !important; }
[data-theme="light"] .ev-sub          { color: rgba(26,0,16,0.80) !important; }
[data-theme="light"] .ev-tag          { color: var(--cyan) !important; }
[data-theme="light"] .ev-label-title  { color: #1A0010 !important; }
[data-theme="light"] .ev-label-title em { color: var(--cyan) !important; }
[data-theme="light"] .ev-icon         { color: var(--cyan) !important; filter: drop-shadow(0 0 8px var(--cyan-glow)) !important; }
/* Slide CTA button keeps its bg, text adapts */
[data-theme="light"] .ev-cta { color: #FFFAF5 !important; }

/* ── 4. DIAGRAM CIRCLES: darker/more vivid in light mode ── */
/* Done in c9-three.js via LIGHT_COLORS — boost opacity here too */
/* The canvas bg already swaps via three.js; also boost contrast */
[data-theme="light"] #cta-three {
  filter: contrast(1.15) saturate(1.4);
}

/* ── 5. REVIEWS CONTAINER: fix overflow clip + shadow ───── */
/* The testi-slider-wrap clips the hover shadow — fix it */
.testi-slider-wrap {
  overflow: visible !important;   /* allow shadow to bleed out  */
  padding-block: 0.75rem;         /* room for shadow top/bottom */
  margin-block: -0.75rem;         /* compensate so layout unchanged */
}
/* The inner track must also not clip */
.testi-slider-wrap #testi-track,
#testi-track {
  overflow: visible !important;
  padding-block: 0.5rem;
}
/* Clip only horizontally (so conveyor belt still hides off-screen cards) */
.testi-section .wrap {
  overflow-x: hidden;
  overflow-y: visible;
}

/* Card hover shadow: LIGHT glow, not dark shadow */
.testi-card-v2:hover {
  transform: translateY(-3px);
  border-color: var(--cyan-dim) !important;
  /* Soft outward light glow — works in both modes */
  box-shadow:
    0 0 0 1px var(--cyan-dim),
    0 6px 32px rgba(245,197,24,0.18),   /* amber glow in dark */
    0 2px 8px rgba(0,0,0,0.08) !important;
}
[data-theme="light"] .testi-card-v2:hover {
  box-shadow:
    0 0 0 1px var(--cyan-dim),
    0 6px 32px rgba(194,24,91,0.18),    /* magenta glow in light */
    0 2px 8px rgba(0,0,0,0.04) !important;
}

/* ── 6. LIGHT MODE: section backgrounds warm & cohesive ── */
[data-theme="light"] .hero          { background: #FFFAF5 !important; }
[data-theme="light"] .stats-band    { background: #FFF0E8 !important; }
[data-theme="light"] .sec-alt-a     { background: #FFFAF5 !important; }
[data-theme="light"] .sec-alt-b     { background: #FFF0E8 !important; }
[data-theme="light"] .testi-section { background: #FFE4D6 !important; }
[data-theme="light"] .cta-unified.sec-alt-a,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-text,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-right,
[data-theme="light"] .cta-unified.sec-alt-a .cta-canvas-wrap,
[data-theme="light"] .cta-unified.sec-alt-a .cta-right-footer { background: #FFE4D6 !important; }


/* ═══════════════════════════════════════════════════════════
   V31 — ALL 8 FIXES
═══════════════════════════════════════════════════════════ */

/* ── 1. LIGHT MODE: New primary — deep electric teal ────── */
/* Premium, unisex, luxury-event energy. Not pink.          */
[data-theme="light"] {
  --cyan:        #0F766E;    /* deep teal — confident, premium      */
  --cyan-dim:    rgba(15,118,110,0.12);
  --cyan-glow:   rgba(15,118,110,0.35);
  --cyan-strong: rgba(15,118,110,0.58);
  --bdr-f:       rgba(15,118,110,0.58);
  --fill-hover:  rgba(15,118,110,0.08);
  --fill-active: rgba(15,118,110,0.18);

  --magenta:     #B45309;    /* warm amber — second accent          */
  --mag-dim:     rgba(180,83,9,0.12);
  --mag-glow:    rgba(180,83,9,0.32);

  --gold:        #D97706;    /* gold accent                         */
  --gold-dim:    rgba(217,119,6,0.12);

  --electric:    #1D4ED8;    /* electric blue — call to action pop  */
  --elec-dim:    rgba(29,78,216,0.12);

  /* Warm champagne surfaces */
  --page:   #F8F5F0;
  --surf:   #F2EDE6;
  --surf2:  #EAE2D8;
  --surf3:  #DDD3C4;
  --surf4:  #CEC0AC;

  --bdr:    rgba(15,118,110,0.12);
  --bdr-s:  rgba(15,118,110,0.24);

  --t1:   #0A1A18;
  --t2:   #1E3D39;
  --t3:   #4D7A74;
  --t4:   #8AADA9;

  --nav-bg:  rgba(248,245,240,0.96);
  --nav-bdr: rgba(15,118,110,0.12);
}

/* Fix btn text on teal bg */
[data-theme="light"] .btn-solid { color: #fff !important; }
[data-theme="light"] .nav-book-btn { color: #fff !important; }
[data-theme="light"] .ticker { background: var(--cyan) !important; }
[data-theme="light"] .t-item,
[data-theme="light"] .t-sep  { color: #fff !important; }
[data-theme="light"] .ev-cta { background: var(--cyan) !important; color: #fff !important; }
[data-theme="light"] .nav-logo-mark {
  background: linear-gradient(135deg, #0F766E, #1D4ED8) !important;
}
[data-theme="light"] .stat-stars i,
[data-theme="light"] .testi-big-stars i,
[data-theme="light"] .t-stars i { color: var(--gold) !important; }
[data-theme="light"] .eyebrow { color: var(--cyan) !important; }

/* Light mode section backgrounds — clean warm neutrals */
[data-theme="light"] .hero          { background: #F8F5F0 !important; }
[data-theme="light"] .stats-band    { background: #F2EDE6 !important; }
[data-theme="light"] .sec-alt-a     { background: #F8F5F0 !important; }
[data-theme="light"] .sec-alt-b     { background: #EAE2D8 !important; }
[data-theme="light"] .testi-section { background: #F2EDE6 !important; }
[data-theme="light"] .cta-unified.sec-alt-a,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-text,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-right,
[data-theme="light"] .cta-unified.sec-alt-a .cta-canvas-wrap,
[data-theme="light"] .cta-unified.sec-alt-a .cta-right-footer { background: #EAE2D8 !important; }

/* ── 2. BIG SLIDE: lighter overlay in light mode ─────────── */
[data-theme="light"] .ev-shade {
  background:
    linear-gradient(100deg,
      rgba(248,245,240,0.52) 0%,
      rgba(248,245,240,0.28) 35%,
      rgba(248,245,240,0.05) 65%,
      transparent 85%),
    linear-gradient(to top,
      rgba(0,0,0,0.18) 0%,
      transparent 45%) !important;
}

/* ── 3. DIAGRAM: handled in c9-three.js above ─────────────
   Also remove the CSS filter that washed them out           */
#cta-three { filter: none !important; }

/* ── 4. REVIEWS: remove scrollbar, fix height ──────────── */
.testi-section {
  overflow: visible !important;
  /* Add enough height to breathe; JS height was clipping */
}
.testi-section .wrap {
  overflow: visible !important;
  /* No more clip on any axis */
}
.testi-slider-wrap {
  overflow: visible !important;
  padding-block: 1.25rem !important;  /* more room for shadows */
  margin-block: -1.25rem !important;
}
/* Clip only horizontal at a parent level using a mask */
.testi-section {
  --mask-x: 0px;
}
/* Override any overflow:hidden set earlier on testi-section */
.testi-section,
.testi-section * { scrollbar-width: none !important; }
.testi-section::-webkit-scrollbar { display: none !important; }

/* ── 5. REMOVE ALL SECTION SHADOWS / DIVIDERS ──────────── */
.section::after,
.stats-band::after,
.testi-section::after,
.cta-unified::after,
.section::before,
.stats-band::before,
.testi-section::before {
  display: none !important;
  content: none !important;

}
/* Kill the warm-glow gradient bleeds too */
:root { --warm-glow-dark: transparent; }
[data-theme="light"] { --warm-glow-lite: transparent; }

/* ── 6. DARK MODE: reduce hover shadow strength ─────────── */
.testi-card-v2:hover {
  box-shadow:
    0 0 0 1px var(--cyan-dim),
    0 4px 20px rgba(245,197,24,0.10),
    0 1px 4px rgba(0,0,0,0.04) !important;
}
[data-theme="light"] .testi-card-v2:hover {
  box-shadow:
    0 0 0 1px var(--cyan-dim),
    0 4px 20px rgba(15,118,110,0.12),
    0 1px 4px rgba(0,0,0,0.03) !important;
}

/* ── 7. NAVBAR: mobile behavior + transparent btn ────────── */

/* When nav is transparent (over slide), theme-btn should
   also be transparent — just the icon, no bg box.          */
.ev-transparent .theme-btn {
  background: transparent !important;
  border-color: transparent !important;
  color: rgba(255,255,255,0.85) !important;
  box-shadow: none !important;
}
[data-theme="light"] .ev-transparent .theme-btn {
  color: rgba(248,245,240,0.9) !important;
}

/* Ensure nav always returns to normal after slide section */
.nav:not(.ev-transparent) {
  /* Let CSS cascade handle it — inline styles cleared by JS */
}

/* Fix mobile nav z-index stacking after slide */
@media (max-width: 639px) {
  .nav {
    z-index: 950 !important;  /* always above everything */
  }
  /* Transparent btn on mobile too */
  .ev-transparent .theme-btn {
    background: transparent !important;
    border-color: rgba(255,255,255,0.15) !important;
  }
  /* Snap hint arrow on mobile — larger touch target */
  .ev-arr { width: 44px !important; height: 44px !important; }
}

/* ── 8. SLIDE: text colors already handled in v30 ─────────
   Confirm light mode text is dark                          */
[data-theme="light"] .ev-name         { color: #0A1A18 !important; }
[data-theme="light"] .ev-sub          { color: rgba(10,26,24,0.82) !important; }
[data-theme="light"] .ev-tag          { color: var(--cyan) !important; }
[data-theme="light"] .ev-label-title  { color: #0A1A18 !important; }
[data-theme="light"] .ev-label-title em { color: var(--cyan) !important; }
[data-theme="light"] .ev-icon         { color: var(--cyan) !important; filter: none !important; }

/* Also update arrow styling for teal */
[data-theme="light"] .ev-arr:hover {
  background: var(--cyan) !important;
  color: #fff !important;
}
[data-theme="light"] .ev-dot.ev-dot-on {
  background: var(--cyan) !important;
  border-color: var(--cyan) !important;
}
[data-theme="light"] .ev-cta:hover {
  background: var(--electric) !important;
  box-shadow: 0 0 24px rgba(29,78,216,0.35) !important;
}


/* ═══════════════════════════════════════════════════════════
   V32 — LIGHT BLUE · REVIEWS CONTAINER · MOBILE FIXES
═══════════════════════════════════════════════════════════ */

/* ── 1. LIGHT MODE: Perfect crisp light blue ──────────────
   #0284C7 — sky blue 600 from Tailwind. Clean, premium,
   confident, works for everyone, passes WCAG AA on white.  */
[data-theme="light"] {
  --cyan:        #0284C7;    /* sky blue 600 — crisp, confident     */
  --cyan-dim:    rgba(2,132,199,0.12);
  --cyan-glow:   rgba(2,132,199,0.35);
  --cyan-strong: rgba(2,132,199,0.58);
  --bdr-f:       rgba(2,132,199,0.58);
  --fill-hover:  rgba(2,132,199,0.08);
  --fill-active: rgba(2,132,199,0.18);

  --magenta:     #0369A1;    /* deeper blue for secondary           */
  --mag-dim:     rgba(3,105,161,0.12);
  --mag-glow:    rgba(3,105,161,0.30);

  --gold:        #D97706;    /* warm amber contrast accent           */
  --gold-dim:    rgba(217,119,6,0.12);

  --electric:    #0EA5E9;    /* light sky for hover/active          */
  --elec-dim:    rgba(14,165,233,0.12);

  /* Warm off-white surfaces */
  --page:   #F0F7FF;    /* faint blue tint — clean, airy        */
  --surf:   #E6F2FF;    /* light blue-white                     */
  --surf2:  #D1E9FF;    /* card backgrounds                     */
  --surf3:  #BAD8F7;    /* hover fills                          */
  --surf4:  #93C5FD;    /* active state                         */

  --bdr:    rgba(2,132,199,0.12);
  --bdr-s:  rgba(2,132,199,0.24);

  --t1:   #0C1A2E;    /* near-black, blue-tinted               */
  --t2:   #1E3A5F;    /* dark navy                            */
  --t3:   #3B6A9E;    /* mid blue-grey                        */
  --t4:   #7BAED4;    /* muted blue                           */

  --nav-bg:  rgba(240,247,255,0.96);
  --nav-bdr: rgba(2,132,199,0.14);

  --warm-glow-lite: transparent;
}

/* Light blue button text: white on sky blue — fine contrast */
[data-theme="light"] .btn-solid { color: #fff !important; }
[data-theme="light"] .nav-book-btn { color: #fff !important; }
[data-theme="light"] .ticker { background: var(--cyan) !important; }
[data-theme="light"] .t-item,
[data-theme="light"] .t-sep  { color: #fff !important; }
[data-theme="light"] .ev-cta { background: var(--cyan) !important; color: #fff !important; }
[data-theme="light"] .nav-logo-mark {
  background: linear-gradient(135deg, #0284C7, #0EA5E9) !important;
}
[data-theme="light"] .stat-stars i,
[data-theme="light"] .testi-big-stars i,
[data-theme="light"] .t-stars i { color: var(--gold) !important; }
[data-theme="light"] .eyebrow { color: var(--cyan) !important; }

/* Light blue section surfaces */
[data-theme="light"] .hero          { background: #F0F7FF !important; }
[data-theme="light"] .stats-band    { background: #E6F2FF !important; }
[data-theme="light"] .sec-alt-a     { background: #F0F7FF !important; }
[data-theme="light"] .sec-alt-b     { background: #D1E9FF !important; }
[data-theme="light"] .testi-section,
[data-theme="light"] .testi-section.sec-alt-b { background: #E6F2FF !important; }
[data-theme="light"] .cta-unified.sec-alt-a,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-text,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-right,
[data-theme="light"] .cta-unified.sec-alt-a .cta-canvas-wrap,
[data-theme="light"] .cta-unified.sec-alt-a .cta-right-footer { background: #D1E9FF !important; }

/* Light mode slide text */
[data-theme="light"] .ev-name         { color: #0C1A2E !important; }
[data-theme="light"] .ev-sub          { color: rgba(12,26,46,0.80) !important; }
[data-theme="light"] .ev-tag          { color: var(--cyan) !important; }
[data-theme="light"] .ev-label-title  { color: #0C1A2E !important; }
[data-theme="light"] .ev-label-title em { color: var(--cyan) !important; }
[data-theme="light"] .ev-icon         { color: var(--cyan) !important; }
[data-theme="light"] .ev-arr:hover    { background: var(--cyan) !important; color: #fff !important; }
[data-theme="light"] .ev-dot.ev-dot-on { background: var(--cyan) !important; border-color: var(--cyan) !important; }
[data-theme="light"] .ev-cta:hover    { background: #0369A1 !important; box-shadow: 0 0 24px rgba(2,132,199,0.35) !important; }
[data-theme="light"] .ev-shade {
  background:
    linear-gradient(100deg,
      rgba(240,247,255,0.50) 0%,
      rgba(240,247,255,0.25) 35%,
      rgba(240,247,255,0.05) 65%,
      transparent 85%),
    linear-gradient(to top,
      rgba(0,0,0,0.15) 0%,
      transparent 45%) !important;
}

/* Light mode card backgrounds */
[data-theme="light"] .testi-card-v2 { background: #fff !important; border-color: rgba(2,132,199,0.15) !important; }
[data-theme="light"] .tcv2-tag { background: #D1E9FF !important; color: #0284C7 !important; }


/* ── 2. REVIEWS: contained + no horizontal overflow ──────── */

/* The section itself must NEVER overflow horizontally */
.testi-section {
  overflow: hidden !important;   /* clip everything inside */
  position: relative !important;
}

/* The .wrap inside gives the standard page container */
.testi-section .wrap {
  overflow: hidden !important;   /* clip the slider track horizontally */
  position: relative !important;
  /* wrap already has max-width + margin:auto + padding-inline */
}

/* The slider wrapper: contained, no margin-inline bleed */
.testi-slider-wrap {
  position: relative !important;
  overflow: hidden !important;       /* MUST clip horizontally */
  margin-inline: 0 !important;       /* no negative margin bleed */
  margin-block: 0 !important;
  padding-block: 1rem !important;    /* room for shadow */
  /* padding-inline removed — wrap container handles edges */
}

/* Track: position must not overflow body */
#testi-track {
  overflow: visible !important;   /* allow card shadows to bleed inward */
  padding-block: 0.5rem;
}

/* First card: modest left padding (not large viewport-relative) */
.testi-slider-wrap .testi-card-v2:first-child {
  margin-left: 0 !important;     /* wrap padding handles left edge */
}

/* Card min width: prevent overly wide cards on small screens */
.testi-card-v2 {
  flex: 0 0 clamp(280px, 80vw, 400px) !important;
  max-width: 400px;
}


/* ── 3. MOBILE OVERFLOW FIX ────────────────────────────── */
/* Prevent horizontal overflow without breaking vertical scroll.
   overflow-x:hidden on <html> breaks mouse wheel in some browsers — never do it. */
html {
  overflow-x: clip;   /* clip, not hidden — does not create scroll container */
}
/* body: overflow-x hidden is safe here (not the root scroll container) */
body {
  overflow-x: hidden;
  max-width: 100%;
}

/* Every top-level section: clip any overflowing children */
main > section,
main > .ev-slider-section,
#ev-section {
  max-width: 100vw;
  overflow-x: hidden;
}



.hero-inner{

  margin-top: 5rem !important;

}

/* ── 4. NAVBAR MOBILE — Always visible except hero/slide ──
   The ev-transparent class is added by JS only for hero
   and ev-section. This ensures normal nav everywhere else. */

/* Base mobile nav: always has background when NOT transparent */
@media (max-width: 899px) {
  .nav {
    /* Ensure nav is always present and visible */
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 950 !important;
    /* Default: scrolled background on mobile (not transparent by default) */
  }

  /* On mobile, add background even without .scrolled — since mobile
     has less room and text behind nav would clash              */
  .nav:not(.ev-transparent) {
    background: var(--nav-bg) !important;
    backdrop-filter: saturate(180%) blur(20px) !important;
    -webkit-backdrop-filter: saturate(180%) blur(20px) !important;
    box-shadow: 0 1px 0 var(--nav-bdr), 0 4px 16px rgba(0,0,0,0.12) !important;
    border-bottom: 1px solid var(--nav-bdr) !important;
  }

  /* Transparent ONLY when JS has applied the class */
  .nav.ev-transparent {
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
    border-bottom: 1px solid transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* Theme button transparent in slide section */
  .nav.ev-transparent .theme-btn {
    background: transparent !important;
    border-color: transparent !important;
    color: rgba(255,255,255,0.85) !important;
  }
  [data-theme="light"] .nav.ev-transparent .theme-btn {
    color: rgba(255,255,255,0.9) !important;
  }
}

/* ── 5. MOBILE LAYOUT AUDIT: fix overflowing sections ────── */
@media (max-width: 639px) {

  /* Hero: no horizontal overflow */
  .hero, .hero-inner, .hero-beams, .hero-pools { max-width: 100vw; overflow: hidden; }

  /* Stats grid: 2 columns always */
  .stats-grid { grid-template-columns: repeat(2,1fr) !important; }

  /* Intro split: stack vertically */
  .split { grid-template-columns: 1fr !important; }
  .vis-box, .vis-box-2d { display: none !important; }

  /* Services grid: 1 column on small phones, 2 on larger */
  .svc-grid { grid-template-columns: repeat(auto-fill, minmax(280px,1fr)) !important; }

  /* CTA: stack */
  .cta-unified { grid-template-columns: 1fr !important; }
  .cta-unified-right { min-height: 320px !important; }

  /* Reviews: section padding reduce so content fits */
  .testi-section.section { padding-block: 3rem !important; }
  .testi-header { flex-direction: column !important; gap: 1.5rem !important; }
  .testi-header--row-center { flex-direction: column !important; align-items: flex-start !important; }

  /* Event slide: full-height */
  #ev-outer { height: 100svh !important; }

  /* Footer: single column */
  .footer-top { grid-template-columns: 1fr !important; }

  /* No section can overflow the viewport */
  .section, .stats-band, .cta-unified, .testi-section {
    max-width: 100vw !important;
    overflow-x: hidden !important;
    box-sizing: border-box !important;
  }
}


/* ═══════════════════════════════════════════════════════════
   V33 — SCROLL FIX · STATS STAR · SECTION ALT · REVIEWS
═══════════════════════════════════════════════════════════ */

/* ── 1. SCROLL: ensure html never blocks vertical scroll ── */
html {
  overflow-y: auto !important;  /* always allow vertical scroll */
  height: auto !important;
}

/* Remove scrollbar on mobile only */
@media (max-width: 899px) {
  html { scrollbar-width: none; }
  html::-webkit-scrollbar { display: none; }
}

/* ── 2. STATS 4.9 — star suffix, same style as others ───── */
/* data-dec="1" makes count-up display as "4.9" not "49"    */
.stat-star-sup {
  color: var(--gold);
  font-size: 0.55em;    /* matches the <sup>+</sup> visual size */
  vertical-align: super;
  margin-left: 1px;
}
/* Remove the old star layout styles — no longer needed */
.stat-n--stars { all: unset; display: block; }
.stat-score, .stat-stars { display: none !important; }

/* ── 3. SECTION ALTERNATING BACKGROUNDS ─────────────────── */

/* DARK MODE: base → subtly darker → base → darker */
:root {
  --sec-base:   #0A0A0A;   /* very dark, nearly black         */
  --sec-darker: #050505;   /* just one step darker            */
  --sec-lighter:#0F0F0F;   /* one step lighter for variation  */
}
.hero           { background: var(--sec-base) !important; }
.stats-band     { background: var(--sec-darker) !important; }
.sec-alt-a      { background: var(--sec-base) !important; }
.sec-alt-b      { background: var(--sec-lighter) !important; }
.testi-section  { background: var(--sec-darker) !important; }
.cta-unified.sec-alt-a,
.cta-unified.sec-alt-a .cta-unified-text,
.cta-unified.sec-alt-a .cta-unified-right,
.cta-unified.sec-alt-a .cta-canvas-wrap,
.cta-unified.sec-alt-a .cta-right-footer { background: var(--sec-lighter) !important; }

/* LIGHT MODE: pure white ↔ barely-gray
   NOT blue-tinted — just white and whisper-gray             */
[data-theme="light"] {
  --lm-white:   #FFFFFF;   /* pure white                      */
  --lm-gray:    #F5F5F5;   /* barely-there gray — a whisper   */
  --lm-gray2:   #EFEFEF;   /* slightly more visible           */
}
[data-theme="light"] .hero          { background: var(--lm-white) !important; }
[data-theme="light"] .stats-band    { background: var(--lm-gray) !important; }
[data-theme="light"] .sec-alt-a     { background: var(--lm-white) !important; }
[data-theme="light"] .sec-alt-b     { background: var(--lm-gray) !important; }
[data-theme="light"] .testi-section,
[data-theme="light"] .testi-section.sec-alt-b { background: var(--lm-gray2) !important; }
[data-theme="light"] .cta-unified.sec-alt-a,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-text,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-right,
[data-theme="light"] .cta-unified.sec-alt-a .cta-canvas-wrap,
[data-theme="light"] .cta-unified.sec-alt-a .cta-right-footer { background: var(--lm-gray) !important; }

/* Light mode surface tokens — neutral not blue-tinted */
[data-theme="light"] {
  --page:   #FFFFFF;
  --surf:   #F5F5F5;
  --surf2:  #EEEEEE;
  --surf3:  #E0E0E0;
  --surf4:  #CCCCCC;
}

/* Text on light surfaces */
[data-theme="light"] {
  --t1:  #0A0A0A;
  --t2:  #333333;
  --t3:  #666666;
  --t4:  #999999;
}

/* Nav on light mode: white/gray bg */
[data-theme="light"] {
  --nav-bg:  rgba(255,255,255,0.97);
  --nav-bdr: rgba(2,132,199,0.15);
}

/* ── 4. REVIEWS: restore clean look with light blue accent ─ */
[data-theme="light"] .testi-card-v2 {
  background: #FFFFFF !important;
  border-color: rgba(2,132,199,0.15) !important;
}
[data-theme="light"] .testi-card-v2:hover {
  border-color: rgba(2,132,199,0.30) !important;
  box-shadow:
    0 0 0 1px rgba(2,132,199,0.15),
    0 4px 20px rgba(2,132,199,0.12),
    0 1px 4px rgba(0,0,0,0.04) !important;
}
[data-theme="light"] .tcv2-tag {
  background: #EFF8FF !important;
  color: #0284C7 !important;
}
[data-theme="light"] .tcv2-verified { color: #0284C7 !important; }
[data-theme="light"] .testi-filter.is-active,
[data-theme="light"] .testi-filter-media.is-active {
  background: #0284C7 !important;
  border-color: #0284C7 !important;
  color: #fff !important;
}
[data-theme="light"] .testi-filter:hover,
[data-theme="light"] .testi-filter-media:hover {
  background: #0284C7 !important;
  border-color: #0284C7 !important;
  color: #fff !important;
}
[data-theme="light"] .testi-bar-fill { background: #0284C7 !important; }
[data-theme="light"] .testi-big-score { color: #0A0A0A !important; }

/* ── 5. MOBILE: scrollbar hidden, touch scroll enabled ────── */
@media (max-width: 899px) {
  /* Hide scrollbar visually but keep scrolling functional */
  body { scrollbar-width: none !important; }
  body::-webkit-scrollbar { display: none !important; }
  /* Critical: body must scroll */
  body { overflow-y: auto !important; touch-action: pan-y !important; }
  html { touch-action: pan-y !important; }
}

/* Desktop: default browser scrollbar */
@media (min-width: 900px) {
  html { scrollbar-width: auto; }
}


/* ═══════════════════════════════════════════════════════════
   V34 CRITICAL: RESTORE SCROLL — OVERRIDE ALL BAD OVERFLOW
═══════════════════════════════════════════════════════════ */

/* RULE 1: html must never have overflow set — it kills wheel scroll */
html {
  overflow: visible !important;   /* never hidden/clip/auto on html */
  height: auto !important;
  /* scroll-behavior is fine — leave it */
}

/* RULE 2: body scrolls vertically, clips horizontal only */
body {
  overflow-x: hidden !important;
  overflow-y: auto !important;    /* vertical scroll always works */
  height: auto !important;
}

/* RULE 3: touch scrolling always works on mobile */
html, body {
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y !important;
}

/* RULE 4: no section should block body scroll */
main {
  overflow: visible !important;
}

/* Mobile scrollbar: hidden visually, scroll still works */
@media (max-width: 899px) {
  body::-webkit-scrollbar { display: none; }
  body { scrollbar-width: none; }
}


/* ═══════════════════════════════════════════════════════════
   V35 — STAT HOVER · SECTION ALT BG · MOBILE FIXES
═══════════════════════════════════════════════════════════ */

/* ── 1. STATS: ALL cells use same primary cyan underline ── */
/* Remove per-cell color overrides so all use --cyan         */
.stat-cell:nth-child(2) { --c: var(--cyan) !important; }
.stat-cell:nth-child(3) { --c: var(--cyan) !important; }
.stat-cell:nth-child(4) { --c: var(--cyan) !important; }
/* The ::before line uses --c which now equals --cyan everywhere */

/* ── 2. SECTION ALTERNATING BACKGROUNDS — more visible ─── */

/* DARK MODE */
:root {
  --alt-dark-a: #0A0A0A;   /* base dark                    */
  --alt-dark-b: #141414;   /* clearly one step lighter     */
}
.hero           { background: var(--alt-dark-a) !important; }
.stats-band     { background: var(--alt-dark-b) !important; }
.sec-alt-a      { background: var(--alt-dark-a) !important; }
.sec-alt-b      { background: var(--alt-dark-b) !important; }
.testi-section  { background: var(--alt-dark-b) !important; }
.cta-unified.sec-alt-a,
.cta-unified.sec-alt-a .cta-unified-text,
.cta-unified.sec-alt-a .cta-unified-right,
.cta-unified.sec-alt-a .cta-canvas-wrap,
.cta-unified.sec-alt-a .cta-right-footer { background: var(--alt-dark-a) !important; }

/* LIGHT MODE: pure white ↔ visible light gray */
[data-theme="light"] {
  --alt-light-a: #FFFFFF;   /* pure white                   */
  --alt-light-b: #F0F0F0;   /* clearly different light gray */
  --alt-light-c: #333;
}
[data-theme="light"] .hero          { background: var(--alt-light-a) !important; }
[data-theme="light"] .stats-band    { background: var(--alt-light-c) !important; }
[data-theme="light"] .sec-alt-a     { background: var(--alt-light-a) !important; }
[data-theme="light"] .sec-alt-b     { background: var(--alt-light-b) !important; }
[data-theme="light"] .testi-section,
[data-theme="light"] .testi-section.sec-alt-b { background: var(--alt-light-b) !important; }
[data-theme="light"] .cta-unified.sec-alt-a,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-text,
[data-theme="light"] .cta-unified.sec-alt-a .cta-unified-right,
[data-theme="light"] .cta-unified.sec-alt-a .cta-canvas-wrap,
[data-theme="light"] .cta-unified.sec-alt-a .cta-right-footer { background: var(--alt-light-a) !important; }

/* Light mode surface tokens match */
[data-theme="light"] {
  --page:  #FFFFFF;
  --surf:  #F0F0F0;
  --surf2: #E4E4E4;
  --surf3: #D4D4D4;
  --surf4: #BBBBBB;
}

/* ── 3. MOBILE BIG SLIDE ARROWS: no circle, icon only ──── */
@media (max-width: 899px) {
  .ev-arr {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    width: 36px !important;
    height: 36px !important;
    color: rgba(255,255,255,0.90) !important;
    /* Keep arrow functional — just icon + drop shadow for readability */
    text-shadow: 0 1px 6px rgba(0,0,0,0.6);
    filter: drop-shadow(0 1px 4px rgba(0,0,0,0.5));
  }
  [data-theme="light"] .ev-arr {
    color: rgba(15,25,45,0.85) !important;
    text-shadow: 0 1px 4px rgba(255,255,255,0.6);
    filter: drop-shadow(0 1px 3px rgba(255,255,255,0.5));
  }
  .ev-arr:hover {
    background: transparent !important;
    transform: translateY(-50%) !important;
  }
}

/* ── 5. MOBILE CTA/DIAGRAM SECTION — fully responsive ──── */
@media (max-width: 899px) {

  /* Stack diagram above text, both centered */
  .cta-unified {
    grid-template-columns: 1fr !important;
    direction: ltr !important;
    min-height: auto !important;
  }

  /* Diagram side: limit height, center */
  .cta-unified-right {
    min-height: 280px !important;
    max-height: 360px !important;
    width: 100% !important;
    overflow: hidden;
  }
  .cta-canvas-wrap {
    min-height: 220px !important;
    max-height: 280px !important;
  }

  /* Contact info trio: center all items */
  .cta-right-footer {
    padding: 1.25rem 1.25rem 1.5rem !important;
    align-items: center !important;
    text-align: center !important;
  }
  .cta-rf-row {
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.35rem !important;
    max-width: 100% !important;
    text-align: center !important;
  }
  .cta-rf-val {
    font-size: 0.78rem !important;
    text-align: center !important;
  }
  .cta-rf-label { font-size: 0.52rem !important; }

  /* Text side: center and tighten */
  .cta-unified-text {
    padding: 2rem 1.25rem 2rem !important;
    text-align: center !important;
    align-items: center !important;
  }
  .cta-unified-text .cta-inner {
    text-align: center !important;
    max-width: 100% !important;
  }
  .cta-unified-text .cta-h {
    font-size: clamp(1.8rem, 7vw, 2.6rem) !important;
    line-height: 1.05 !important;
  }
  .cta-sub {
    font-size: 0.88rem !important;
  }
  .cta-btns {
    flex-direction: column !important;
    align-items: center !important;
    width: 100% !important;
  }
  .cta-btns .btn {
    width: 100% !important;
    justify-content: center !important;
    font-size: 0.9rem !important;
  }
  .cta-phones {
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.5rem !important;
    text-align: center !important;
  }
  .ph-lbl, .ph-num { display: block; text-align: center; }

  /* Divider line centered */
  .cta-divider-line {
    margin: 0 auto !important;
  }
}

/* ── 4. MOBILE SVC SLIDER: add prev/next arrows ─────────── */
/* The JS-built .m-slider-wrap gets arrow injection via CSS   */
.m-slider-wrap { position: relative; }

/* Arrows injected by JS will use these styles */
.m-arr {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  background: transparent;
  border: none;
  color: var(--t1);
  font-size: 1.2rem;
  cursor: pointer;
  padding: 0.5rem;
  opacity: 0.6;
  transition: opacity 0.2s;
}
.m-arr:hover { opacity: 1; }
.m-arr-prev { left: 0.25rem; }
.m-arr-next { right: 0.25rem; }
.m-arr-hidden { opacity: 0; pointer-events: none; }

[data-theme="light"] .svc-card{



background-color: rgba(255,255,255,0.5);





}


[data-theme="light"] .bi-star-fill{
  color: var(--electric);
}

[data-theme="light"] .footer-hero{
background-color: rgba(255,255,255,0.5);
}

@media (max-width: 639px) {
.hero-h1{

    font-size: clamp(3rem, 13vw, 6rem) !important;
  }
}