/*
Theme Name: Glowie Wedding Studio
Theme URI: https://glowiewedding.com
Author: Glowie Wedding Studio
Author URI: https://glowiewedding.com
Description: Premium wedding photography and social coverage studio theme for Glowie Wedding Studio, Jeddah.
Version: 2.3.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: Proprietary
Text Domain: glowie
*/

/* ═══════════════════════════════════════════════════════════════
   GLOWIE WEDDING STUDIO — DESIGN SYSTEM
   WordPress theme stylesheet
   Single source of truth for all tokens, typography, shared
   components: nav, footer, bottom bar, buttons, utilities.
═══════════════════════════════════════════════════════════════ */

/* ── TOKENS — LIGHT MODE ─────────────────────────────────── */
:root {
  --c-primary:      #5B002E;
  --c-primary-dk:   #4f0028;
  --c-primary-dkk:  #400022;
  --c-primary-feat: #240012;
  --c-tint:         #eadfe4;
  --c-white:        #FFFFFF;
  --c-dark:         #04000F;
  --c-bg:           #F9F7F5;
  --c-bg-alt:       #F3EFEA;
  --c-bg-dp:        #E6DED5;
  --c-border:       #E6DED5;
  --c-text:         #04000F;
  --c-card:         #FFFFFF;
  --c-card-bd:      #E6DED5;
  --c-nav-scroll:    rgba(249,247,245,0.97);
  --c-nav-scroll-bd: rgba(4,0,15,0.09);
  --c-nav-logo:      #04000F;
  --c-nav-link:      rgba(4,0,15,0.52);
  --c-nav-link-h:    #04000F;
  --c-port-bg:       #E6DED5;
  --c-port-s1:       #D4C9BC;
  --c-port-s2:       #C4B6A8;
  --c-foot-bg:       #F3EFEA;
  --c-foot-sep:      rgba(4,0,15,0.09);
  --c-foot-logo:     #04000F;
  --c-foot-muted:    rgba(4,0,15,0.42);
  --c-foot-link:     rgba(4,0,15,0.42);
  --c-foot-copy:     rgba(4,0,15,0.28);
  --c-foot-socbd:    rgba(4,0,15,0.14);
  --c-foot-socc:     rgba(4,0,15,0.42);
  --c-svc2:          #F3EFEA;
  --c-svc2-hover:    #E6DED5;
  --ease: cubic-bezier(0.25,0.46,0.45,0.94);
  --max:  1320px;
}

[data-theme="dark"] {
  /* All dark surfaces derived from Mulberry Wood palette */
  /* Base: #04000F (official black) */
  /* Alt:  #090005 (90% shade — pure Mulberry Wood) */
  /* Deep: #120009 (80% shade — pure Mulberry Wood) */
  --c-bg:           #04000F;   /* official black — base */
  --c-bg-alt:       #090005;   /* 90% shade — alt sections */
  --c-bg-dp:        #120009;   /* 80% shade — deep/elevated */
  --c-border:       rgba(255,255,255,0.10);  /* stronger section borders in dark */
  --c-text:         #FFFFFF;
  --c-card:         #090005;   /* cards sit on alt bg */
  --c-card-bd:      rgba(255,255,255,0.12);  /* stronger card borders in dark */
  --c-nav-scroll:    rgba(4,0,15,0.97);
  --c-nav-scroll-bd: rgba(255,255,255,0.05);
  --c-nav-logo:      #FFFFFF;
  --c-nav-link:      rgba(255,255,255,0.52);
  --c-nav-link-h:    #FFFFFF;
  --c-port-bg:       #04000F;
  --c-port-s1:       #090005;  /* portfolio swatches — Mulberry Wood */
  --c-port-s2:       #120009;
  --c-foot-bg:       #090005;  /* footer — 90% shade */
  --c-foot-sep:      rgba(255,255,255,0.06);
  --c-foot-logo:     #FFFFFF;
  --c-foot-muted:    rgba(255,255,255,0.55);  /* raised from 0.32 — AA ✓ */
  --c-foot-link:     rgba(255,255,255,0.55);  /* raised from 0.34 — AA ✓ */
  --c-foot-copy:     rgba(255,255,255,0.46);  /* raised from 0.20 — AA 4.5:1 ✓ */
  --c-foot-socbd:    rgba(255,255,255,0.11);
  --c-foot-socc:     rgba(255,255,255,0.36);
  --c-svc2:          #090005;  /* service card 2 bg */
  --c-svc2-hover:    #120009;  /* hover — 80% shade */
}


/* ── SKIP TO CONTENT ────────────────────────────────────── */
.skip-link{position:absolute;top:-100px;left:24px;z-index:9999;padding:8px 20px;background:var(--c-primary);color:#FFFFFF;font-family:'Nunito Sans',sans-serif;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;transition:top .3s}
.skip-link:focus{top:24px}

/* ── RESET ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Nunito Sans',sans-serif;background:var(--c-bg);color:var(--c-text);overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background .4s,color .4s;padding-bottom:68px}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ── LAYOUT ─────────────────────────────────────────────── */
.container{max-width:var(--max);margin:0 auto;padding:0 48px}
@media(max-width:768px){.container{padding:0 20px}}
.section{padding:112px 0}
@media(max-width:768px){.section{padding:72px 0}}

/* ── TYPOGRAPHY ─────────────────────────────────────────── */
h1,h2,h3,h4{font-family:'Bodoni Moda',Georgia,serif;font-weight:500;line-height:1.12;letter-spacing:0.01em;color:var(--c-text);transition:color .4s}
h1{font-size:clamp(2.5rem,5.5vw,5rem)}
h2{font-size:clamp(1.85rem,3.6vw,3.2rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.9rem)}
h4{font-size:clamp(1.1rem,1.8vw,1.4rem)}
p{font-size:1.05rem;line-height:1.82;color:var(--c-text);font-weight:300;transition:color .4s}

.label{font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:0.28em;text-transform:uppercase;color:var(--c-primary);display:flex;align-items:center;gap:12px;margin-bottom:18px}
.label::before{content:'';display:block;width:28px;height:1px;background:var(--c-primary);flex-shrink:0}
.label--muted{color:rgba(255,255,255,0.45)}
.label--muted::before{background:rgba(255,255,255,0.3)}
[data-theme="light"] .label--muted{color:rgba(4,0,15,0.36)}
[data-theme="light"] .label--muted::before{background:rgba(4,0,15,0.22)}
.label--center{justify-content:center}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:15px 34px;font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;border:none;cursor:pointer;white-space:nowrap;transition:transform .3s var(--ease),box-shadow .3s,background .25s,border-color .25s,color .25s}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-p{background:var(--c-primary);color:#FFFFFF;box-shadow:0 4px 20px rgba(91,0,46,.28)}
.btn-p:hover{background:var(--c-primary-dk);box-shadow:0 8px 32px rgba(91,0,46,.40)}
.btn-ol{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary)}
.btn-ol:hover{background:var(--c-primary);color:#FFFFFF}
[data-theme="dark"] .btn-ol{color:rgba(255,255,255,.82);border-color:rgba(255,255,255,.35)}
[data-theme="dark"] .btn-ol:hover{background:rgba(255,255,255,.08);border-color:#FFFFFF;color:#FFFFFF}
.btn-od{background:transparent;color:#FFFFFF;border:1.5px solid rgba(255,255,255,0.5)}
.btn-od:hover{border-color:#FFFFFF;background:rgba(255,255,255,0.08)}
.btn-consult{background:var(--c-dark);color:#FFFFFF;padding:13px 24px 13px 12px;border-radius:100px;gap:10px;box-shadow:0 4px 20px rgba(4,0,15,.25)}
.btn-consult:hover{background:#090005;box-shadow:0 8px 32px rgba(4,0,15,.4)}
.c-av{width:34px;height:34px;border-radius:50%;background:var(--c-primary);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#FFFFFF;flex-shrink:0;position:relative}
.c-av::after{content:'';position:absolute;bottom:0;right:0;width:9px;height:9px;border-radius:50%;background:#4ade80;border:2px solid var(--c-dark)}
.c-txt{display:flex;flex-direction:column;gap:2px}
.c-txt strong{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.c-txt span{font-size:10px;font-weight:300;opacity:.5;text-transform:none;letter-spacing:0}

/* ── NAV ────────────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:24px 0;transition:background .4s,padding .35s,box-shadow .35s,backdrop-filter .4s}
.nav.scrolled{background:var(--c-nav-scroll);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:14px 0;box-shadow:0 1px 0 var(--c-nav-scroll-bd)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav-logo{font-family:'Bodoni Moda',Georgia,serif;font-size:1.5rem;font-weight:500;letter-spacing:.1em;color:var(--c-nav-logo);transition:color .4s;flex-shrink:0}
[data-theme="light"] .nav-logo{color:#04000F}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--c-nav-link);transition:color .3s;position:relative;padding-bottom:3px}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--c-nav-link-h);transition:width .3s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--c-nav-link-h)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
[data-theme="light"] .nav-links a{color:rgba(4,0,15,0.52)}
[data-theme="light"] .nav-links a:hover,[data-theme="light"] .nav-links a.active{color:#04000F}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-pill{display:flex;align-items:center;gap:8px;padding:7px 14px 7px 7px;border-radius:100px;border:1px solid rgba(4,0,15,0.13);background:rgba(4,0,15,0.04);color:#04000F;transition:background .3s,border-color .3s;text-decoration:none}
[data-theme="dark"] .nav-pill{border-color:rgba(255,255,255,0.12);background:rgba(255,255,255,0.05);color:#FFFFFF}
.nav-pill:hover{background:rgba(91,0,46,.07);border-color:rgba(91,0,46,.22)}

/* ── NAV PILL — WhatsApp icon dot ───────────────────────── */
.np-dot{
  width:28px;height:28px;border-radius:50%;
  background:#25D366; /* WhatsApp green */
  display:flex;align-items:center;justify-content:center;
  color:#FFFFFF;position:relative;flex-shrink:0;
}
.np-dot::after{
  content:'';position:absolute;bottom:-1px;right:-1px;
  width:8px;height:8px;border-radius:50%;
  background:#4ade80;border:1.5px solid var(--c-bg);
  transition:border-color .4s;
}
.np-dot svg{width:14px;height:14px;flex-shrink:0}

.np-name{font-size:10px;font-weight:700;color:inherit}
.np-avail{font-size:9px;font-weight:300;opacity:.48}
.theme-btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(4,0,15,0.13);background:rgba(4,0,15,0.04);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .3s,border-color .3s,color .3s;color:#04000F;flex-shrink:0}
[data-theme="dark"] .theme-btn{border-color:rgba(255,255,255,0.12);background:rgba(255,255,255,0.05);color:#FFFFFF}
.theme-btn:hover{background:var(--c-primary);border-color:var(--c-primary);color:#FFFFFF}
.theme-btn i,.theme-btn svg{width:15px;height:15px;display:block;pointer-events:none}
.icon-sun{display:none}
.icon-moon{display:flex}
[data-theme="dark"] .icon-sun{display:flex}
[data-theme="dark"] .icon-moon{display:none}
.nav-cta{padding:10px 20px;background:var(--c-primary);color:#FFFFFF;font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:background .25s,transform .25s}
.nav-cta:hover{background:var(--c-primary-dk);transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--c-nav-logo);transition:background .4s}
@media(max-width:1200px){.nav-links{gap:18px}}
@media(max-width:1280px){.np-text{display:none}.nav-pill{padding:5px}}
@media(max-width:1100px){.nav-links{display:none}}

/* ── MOBILE NAV — dot only, no text, no reserve button ──── */
@media(max-width:720px){
  .np-text{display:none}
  .nav-cta--desktop{display:none}
  .nav-pill{padding:6px}
  .np-dot{width:36px !important;height:36px !important}
  .np-dot svg{width:18px !important;height:18px !important}
  .hamburger{display:flex}
}


/* ── MOBILE MENU ────────────────────────────────────────── */
.mob-menu{
  display:none;
  position:fixed;inset:0;
  background:var(--c-primary-feat);
  z-index:1100;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:0;
  /* Items start near top, never try to vertically center */
  padding:88px 24px calc(32px + env(safe-area-inset-bottom));
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.mob-menu.open{display:flex}

/* Nav links — tighter on mobile so 7 items fit */
.mob-menu a:not(.mob-wa){
  font-family:'Bodoni Moda',Georgia,serif;
  font-size:clamp(1.4rem,4.5vw,2rem);
  font-weight:500;letter-spacing:.02em;
  color:rgba(255,255,255,.72);
  transition:color .3s;
  padding:8px 0;
}
.mob-menu a:not(.mob-wa):hover{color:#FFFFFF}

/* WhatsApp pill — in flow, separated, properly sized */
.mob-wa{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Nunito Sans',sans-serif !important;
  font-size:11px !important;font-weight:700 !important;
  letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.82);
  background:rgba(91,0,46,.35);
  border:1px solid rgba(91,0,46,.7);
  padding:13px 28px;
  border-radius:100px;
  white-space:nowrap;
  transition:all .3s;
  margin-top:4px;
}
.mob-wa:hover{background:rgba(91,0,46,.6);border-color:var(--c-primary);color:#FFFFFF;transform:translateY(-2px)}
.mob-wa svg{width:15px;height:15px;flex-shrink:0;opacity:.7}

/* Separator — tighter on mobile */
.mob-sep{width:48px;height:1px;background:rgba(255,255,255,.12);margin:14px 0 12px}

/* Close button — top right, never overlaps links */
.mob-close{
  position:fixed;
  top:24px;right:24px;
  width:44px;height:44px;
  border-radius:50%;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:rgba(255,255,255,.65);
  transition:all .3s;
  z-index:1102;
  visibility:hidden;
}
.mob-menu.open .mob-close{visibility:visible}
.mob-close:hover{background:rgba(255,255,255,.14);color:#FFFFFF}
.mob-close i,.mob-close svg{width:18px;height:18px;pointer-events:none;display:block}




/* ── INNER PAGE HERO ────────────────────────────────────── */
.page-hero{background:var(--c-primary-feat);padding:140px 0 64px;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 70% 60% at 20% 80%,rgba(91,0,46,.35) 0%,transparent 60%),radial-gradient(ellipse 40% 50% at 80% 20%,rgba(91,0,46,.15) 0%,transparent 55%)}
.page-hero::after{content:'';position:absolute;inset:0;opacity:.02;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.page-hero-inner{position:relative;z-index:1}
.page-hero-eye{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:#E6DED5;opacity:.6;display:flex;align-items:center;gap:12px;margin-bottom:18px}
.page-hero-eye::before{content:'';display:block;width:28px;height:1px;background:#E6DED5;opacity:.5;flex-shrink:0}
.page-hero h1{font-family:'Bodoni Moda',Georgia,serif;font-size:clamp(2.2rem,4.5vw,4rem);font-weight:500;letter-spacing:.01em;color:#FFFFFF;margin-bottom:16px;line-height:1.1}
.page-hero-bc{font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:300;color:rgba(255,255,255,.35);letter-spacing:.06em}
.page-hero-bc a{color:rgba(255,255,255,.35);transition:color .3s}
.page-hero-bc a:hover{color:#FFFFFF}
.page-hero-bc span{color:#E6DED5}
.page-hero-sep{width:100%;height:1px;background:linear-gradient(to right,rgba(255,255,255,.15),transparent);margin-top:32px}

/* ── TRUST BAR ──────────────────────────────────────────── */
.trust-bar{background:#04000F;border-bottom:1px solid rgba(255,255,255,.05);padding:18px 0}
.trust-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.trust-item{
  font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.52);
  padding:9px 32px;position:relative;transition:color .3s;
  text-decoration:none;cursor:pointer;
  display:inline-flex;align-items:center;
}
.trust-item:hover{color:rgba(255,255,255,.88)}
.trust-item strong{color:#FFFFFF;font-weight:700}
.trust-item:not(:last-child)::after{content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:14px;background:rgba(255,255,255,.14)}
@media(max-width:900px){.trust-item{padding:7px 18px;font-size:9px;letter-spacing:.13em}}
@media(max-width:600px){.trust-item:nth-child(n+4){display:none}.trust-item:nth-child(3)::after{display:none}}


/* ── FEATURED PACKAGE CARD ──────────────────────────────── */
.pkg-card--feat{background:#240012 !important;border-color:transparent}
.pkg-card--feat::before{background:var(--c-primary)}
.pkg-card--feat:hover{box-shadow:0 22px 56px rgba(36,0,18,.45);border-color:transparent}
.pkg-card--feat .pkg-name{color:#FFFFFF}
.pkg-card--feat .pkg-sep{background:rgba(255,255,255,.14)}
.pkg-card--feat .pkg-hrs{color:rgba(255,255,255,.45)}
.pkg-card--feat .pkg-section-title{color:rgba(230,222,213,.7)}
.pkg-card--feat .pkg-spec,.pkg-card--feat .pkg-li{color:rgba(255,255,255,.6)}
.pkg-card--feat .pkg-spec::before,.pkg-card--feat .pkg-li::before{background:rgba(230,222,213,.55)}
.pkg-card--feat .pkg-note{color:#FFFFFF;opacity:.28}

/* ── FOOTER ─────────────────────────────────────────────── */
.footer{background:var(--c-foot-bg);padding:72px 0 32px;transition:background .4s}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:52px;border-bottom:1px solid var(--c-foot-sep);margin-bottom:32px;transition:border-color .4s}
@media(max-width:960px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:760px){
  .footer-grid{grid-template-columns:1fr;gap:0;padding-bottom:32px}
  .footer-brand{padding-bottom:32px;border-bottom:1px solid var(--c-foot-sep);margin-bottom:8px}
  .footer-col{padding:18px 0;border-bottom:1px solid var(--c-foot-sep)}
  .footer-col:last-child{border-bottom:none}
  .footer-col h4{display:flex;align-items:center;justify-content:space-between;cursor:pointer;margin-bottom:0;user-select:none}
  .footer-col h4 .fc-arrow{font-size:14px;font-weight:300;transition:transform .3s;display:block}
  .footer-col.open h4 .fc-arrow{transform:rotate(45deg)}
  .footer-col ul{display:none;margin-top:14px;flex-direction:column;gap:12px}
  .footer-col.open ul{display:flex}
}
.footer-logo{font-family:'Bodoni Moda',Georgia,serif;font-size:1.75rem;font-weight:500;color:var(--c-foot-logo);letter-spacing:.1em;margin-bottom:14px;display:block;transition:color .4s}
.footer-tag{font-size:13px;color:var(--c-foot-muted);line-height:1.72;max-width:240px;margin-bottom:22px;font-weight:300;transition:color .4s}
.footer-soc{display:flex;gap:9px}
.footer-soc a{width:34px;height:34px;border-radius:50%;border:1px solid var(--c-foot-socbd);display:flex;align-items:center;justify-content:center;color:var(--c-foot-socc);transition:all .3s}
.footer-soc a:hover{border-color:var(--c-primary);background:var(--c-primary);color:#FFFFFF}
.footer-soc a svg{width:14px;height:14px;flex-shrink:0}
.footer-col h4{font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--c-foot-logo);margin-bottom:18px;transition:color .4s}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:13px;color:var(--c-foot-link);transition:color .3s;font-weight:300}
.footer-col ul a:hover{color:var(--c-foot-logo)}
.footer-btm{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.footer-copy{font-size:11px;color:var(--c-foot-copy);font-weight:300;transition:color .4s}
.footer-fl{display:flex;gap:20px}
.footer-fl a{font-size:11px;color:var(--c-foot-copy);transition:color .3s;font-weight:300}
.footer-fl a:hover{color:var(--c-foot-logo)}

/* ── BOTTOM BAR ─────────────────────────────────────────── */
.bottom-bar{position:fixed;bottom:0;left:0;right:0;z-index:900;background:rgba(4,0,15,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid rgba(255,255,255,.06);padding:12px 0}
.bar-inner{display:flex;align-items:center;justify-content:space-between;gap:14px}
.bar-left{display:flex;align-items:center;gap:11px}
.bar-av{width:38px;height:38px;border-radius:50%;background:var(--c-primary);display:flex;align-items:center;justify-content:center;font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:800;color:#FFFFFF;flex-shrink:0;position:relative}
.bar-av::after{content:'';position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;background:#4ade80;border:2px solid #04000F}
.bar-txt{display:flex;flex-direction:column;gap:2px}
.bar-title{font-family:'Nunito Sans',sans-serif;font-size:12px;font-weight:700;color:#FFFFFF}
.bar-sub{font-family:'Nunito Sans',sans-serif;font-size:10px;color:rgba(255,255,255,.4);font-weight:300}
.bar-btn{padding:11px 24px;background:var(--c-primary);color:#FFFFFF;border:none;cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:background .25s;white-space:nowrap;flex-shrink:0;text-decoration:none;display:inline-flex;align-items:center}
.bar-btn:hover{background:var(--c-primary-dk)}
@media(max-width:480px){.bar-sub{display:none}.bar-btn{padding:10px 16px}}

/* ── SCROLL ANIMATIONS — reduced CLS ─────────────────── */
.fade-up{opacity:0;transform:translateY(12px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up:nth-child(2){transition-delay:.1s}
.fade-up:nth-child(3){transition-delay:.2s}
.fade-up:nth-child(4){transition-delay:.3s}
.scroll-top{position:fixed;bottom:96px;right:24px;z-index:800;width:40px;height:40px;border-radius:50%;background:var(--c-bg-alt);border:1px solid var(--c-border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--c-primary);transition:all .3s;opacity:0;pointer-events:none}
.scroll-top.show{opacity:1;pointer-events:auto}
.scroll-top:hover{background:var(--c-primary);color:#FFFFFF;border-color:var(--c-primary)}
.scroll-top i,.scroll-top svg{width:15px;height:15px;pointer-events:none;display:block}


/* ── DARK MODE TEXT CONTRAST FIXES ─────────────────────────
   #5B002E as text on dark bg = 1.46:1 (fails WCAG AA)
   Replace with #9d6682 (Mulberry Wood tint, 4.6:1 on dark) ✓
─────────────────────────────────────────────────────────── */
[data-theme="dark"] .label{color:#9d6682}
[data-theme="dark"] .label::before{background:#9d6682}
[data-theme="dark"] .svc-tag{color:#9d6682;border-color:rgba(157,102,130,0.35);background:rgba(157,102,130,0.08)}
[data-theme="dark"] .page-hero-eye{color:rgba(255,255,255,0.60)}
[data-theme="dark"] .filter-btn{color:rgba(255,255,255,0.65);border-color:rgba(255,255,255,0.20)}
[data-theme="dark"] .testi-stars{color:#9d6682}
[data-theme="dark"] .testi-q{color:#9d6682}
[data-theme="dark"] .acc-f{color:#9d6682}
[data-theme="dark"] .addon-price{color:#9d6682}
[data-theme="dark"] .event-hours{color:#9d6682}
[data-theme="dark"] .footer-col h4{color:rgba(255,255,255,0.65)}

/* Badge on featured (dark) card — white bg with primary text for contrast */
.pkg-card--feat .pkg-badge{background:#FFFFFF;color:var(--c-primary)}


main{display:block}
:focus-visible{outline:2px solid var(--c-primary);outline-offset:3px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}}

/* ── HOMEPAGE HERO — specific overrides for #240012 bg ──────
   Hero bg is var(--c-primary-feat) = #240012 in both modes.
   All text is white since the bg is always dark.
─────────────────────────────────────────────────────────── */
.hero{min-height:100vh;background:var(--c-bg-alt);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:160px 20px 130px}
[data-theme="dark"] .hero{background:var(--c-primary-feat)}
.hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 68% 55% at 18% 72%,rgba(91,0,46,.07) 0%,transparent 58%),radial-gradient(ellipse 48% 40% at 82% 28%,rgba(91,0,46,.04) 0%,transparent 52%)}
[data-theme="dark"] .hero::before{background:radial-gradient(ellipse 68% 55% at 25% 65%,rgba(91,0,46,.48) 0%,transparent 60%),radial-gradient(ellipse 48% 40% at 75% 35%,rgba(91,0,46,.2) 0%,transparent 55%)}
.hero::after{content:'';position:absolute;inset:0;opacity:.022;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero-vline{position:absolute;left:48px;top:50%;transform:translateY(-50%);width:1px;height:130px;background:linear-gradient(to bottom,transparent,rgba(4,0,15,.15),transparent)}
[data-theme="dark"] .hero-vline{background:linear-gradient(to bottom,transparent,rgba(255,255,255,.2),transparent)}
@media(max-width:768px){.hero-vline{display:none}}
.hero-content{position:relative;z-index:2;text-align:center;max-width:960px;width:100%}
.hero-eyebrow{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.32em;text-transform:uppercase;color:var(--c-primary);display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:28px;opacity:0;animation:fadeUp .9s .2s var(--ease) forwards}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';display:block;width:36px;height:1px;background:var(--c-primary);opacity:.55;flex-shrink:0}
[data-theme="dark"] .hero-eyebrow{color:#E6DED5}
[data-theme="dark"] .hero-eyebrow::before,[data-theme="dark"] .hero-eyebrow::after{background:#E6DED5}
.hero-title{font-family:'Bodoni Moda',Georgia,serif;font-size:clamp(2.6rem,6.5vw,6rem);font-weight:500;letter-spacing:.015em;line-height:1.08;color:#04000F;margin-bottom:22px;opacity:0;animation:fadeUp .9s .35s var(--ease) forwards}
[data-theme="dark"] .hero-title{color:#FFFFFF}
.hero-title .accent{color:var(--c-primary)}
[data-theme="dark"] .hero-title .accent{color:#F3EFEA}
.hero-sub{font-family:'Nunito Sans',sans-serif;font-size:1.08rem;font-weight:300;color:rgba(4,0,15,.58);max-width:460px;margin:0 auto 48px;line-height:1.78;opacity:0;animation:fadeUp .9s .5s var(--ease) forwards}
[data-theme="dark"] .hero-sub{color:rgba(255,255,255,.65)}
.hero-cta{display:flex;justify-content:center;opacity:0;animation:fadeUp .9s .62s var(--ease) forwards}
.date-wrap{margin-top:52px;width:100%;max-width:460px;margin-left:auto;margin-right:auto;opacity:0;animation:fadeUp .9s .78s var(--ease) forwards}
.date-box{display:flex;align-items:center;border:1.5px solid var(--c-border);background:var(--c-card)}
[data-theme="dark"] .date-box{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.06)}
.date-box:focus-within{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(91,0,46,.1)}
[data-theme="dark"] .date-box:focus-within{border-color:rgba(255,255,255,.45);box-shadow:0 0 0 3px rgba(255,255,255,.08)}
.date-lbl{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(4,0,15,.55);white-space:nowrap;padding:0 14px 0 18px}
[data-theme="dark"] .date-lbl{color:rgba(255,255,255,.65)}
.date-box input[type="date"]{flex:1;min-width:0;background:none;border:none;outline:none;font-family:'Nunito Sans',sans-serif;font-size:14px;font-weight:400;color:#04000F;cursor:pointer;padding:14px 10px 14px 0}
[data-theme="dark"] .date-box input[type="date"]{color:#FFFFFF}
.date-box input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.45;flex-shrink:0}
[data-theme="dark"] .date-box input::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.55}
.date-btn{padding:14px 20px;background:var(--c-primary);color:#FFFFFF;border:none;cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;transition:background .25s;flex-shrink:0}
.date-btn:hover{background:var(--c-primary-dk)}
.date-note{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:300;color:rgba(255,255,255,.45);text-align:center;margin-top:9px;letter-spacing:.04em}
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:9px;opacity:0;animation:fadeUp .9s 1.05s var(--ease) forwards}
.hero-scroll-lbl{font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(4,0,15,.25)}
[data-theme="dark"] .hero-scroll-lbl{color:rgba(255,255,255,.35)}
.hero-scroll-line{width:1px;height:44px;background:linear-gradient(to bottom,rgba(4,0,15,.25),transparent);animation:scrollPulse 2.4s ease-in-out infinite}
[data-theme="dark"] .hero-scroll-line{background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent)}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:.3}50%{opacity:.9}}

/* ── HOMEPAGE SECTIONS ────────────────────────────────────── */
.dual-svc{padding:0;background:var(--c-bg)}
.dual-grid{display:grid;grid-template-columns:1fr 1fr}
@media(max-width:768px){.dual-grid{grid-template-columns:1fr}}
.svc-card{padding:88px 60px;position:relative;overflow:hidden;border-right:1px solid var(--c-border);background:var(--c-bg);transition:background .4s,border-color .4s}
.svc-card:first-child:hover{background:var(--c-bg-alt)}
.svc-card:last-child{border-right:none;background:var(--c-svc2)}
.svc-card:last-child:hover{background:var(--c-svc2-hover)}
.svc-num{font-family:'Bodoni Moda',Georgia,serif;font-size:8rem;font-weight:400;color:rgba(91,0,46,.045);position:absolute;top:-16px;right:32px;line-height:1;pointer-events:none;user-select:none}
.svc-tag{display:inline-flex;align-items:center;gap:6px;font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:5px 12px;border-radius:100px;margin-bottom:24px;border:1px solid rgba(91,0,46,.2);background:rgba(91,0,46,.06);color:var(--c-primary)}
.svc-tag-dot{width:5px;height:5px;border-radius:50%;background:currentColor}
.svc-title{font-family:'Bodoni Moda',Georgia,serif;font-size:clamp(1.5rem,2.7vw,2.2rem);font-weight:500;letter-spacing:.01em;color:var(--c-text);margin-bottom:16px;line-height:1.15}
.svc-body{font-size:1rem;line-height:1.82;margin-bottom:36px;max-width:400px;font-weight:300}
[data-theme="light"] .svc-body{color:rgba(4,0,15,.6)}
[data-theme="dark"] .svc-body{color:rgba(255,255,255,.52)}
.svc-btn{display:inline-flex;align-items:center;padding:13px 28px;font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;transition:all .25s}
[data-theme="light"] .svc-btn{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary)}
[data-theme="light"] .svc-btn:hover{background:var(--c-primary);color:#FFFFFF}
[data-theme="dark"] .svc-btn{background:transparent;color:#FFFFFF;border:1.5px solid rgba(255,255,255,.52)}
[data-theme="dark"] .svc-btn:hover{border-color:#FFFFFF;background:rgba(255,255,255,.08)}
@media(max-width:768px){.svc-card{padding:60px 24px}.svc-num{font-size:5.5rem}}
.packages-sec{background:var(--c-bg-alt)}
.pkg-hdr{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:56px;gap:24px;flex-wrap:wrap}
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:1024px){.pkg-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}}
.pkg-card{background:var(--c-card);border:1px solid var(--c-card-bd);padding:44px 36px;position:relative;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s,border-color .3s,background .4s;display:flex;flex-direction:column}
.pkg-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--c-border);transition:background .3s}
.pkg-card:hover{transform:translateY(-5px);box-shadow:0 18px 48px rgba(91,0,46,.11);border-color:rgba(91,0,46,.22)}
.pkg-card:hover::before{background:var(--c-primary)}
.pkg-badge{position:absolute;top:16px;right:16px;background:var(--c-primary);color:#FFFFFF;font-family:'Nunito Sans',sans-serif;font-size:8px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;padding:4px 12px;border-radius:100px}
.pkg-name{font-family:'Bodoni Moda',Georgia,serif;font-size:1.9rem;font-weight:500;letter-spacing:.02em;color:var(--c-text);margin-bottom:20px}
.pkg-sep{width:32px;height:1px;background:var(--c-border);margin-bottom:20px}
.pkg-specs{display:flex;flex-direction:column;gap:10px;margin-bottom:32px;flex:1}
.pkg-spec{display:flex;align-items:center;gap:10px;font-family:'Nunito Sans',sans-serif;font-size:13px;color:var(--c-text);font-weight:300}
.pkg-spec::before{content:'';display:block;width:4px;height:4px;border-radius:50%;background:var(--c-primary);flex-shrink:0}
.pkg-cta{display:block;width:100%;padding:13px;background:var(--c-primary);color:#FFFFFF;border:none;cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;transition:background .25s,transform .25s;margin-top:auto}
.pkg-cta:hover{background:var(--c-primary-dk);transform:translateY(-2px)}
.pkg-note{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:300;color:var(--c-text);opacity:.34;text-align:center;margin-top:10px}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px}
@media(max-width:1024px){.testi-grid{grid-template-columns:1fr;max-width:460px;margin:56px auto 0}}
.testi-card{background:var(--c-card);border:1px solid var(--c-card-bd);padding:40px 32px;transition:transform .4s var(--ease),box-shadow .4s,border-color .3s,background .4s}
.testi-card:hover{transform:translateY(-4px);box-shadow:0 14px 44px rgba(91,0,46,.09);border-color:rgba(91,0,46,.2)}
.testi-stars{color:var(--c-primary);font-size:12px;letter-spacing:2px;margin-bottom:16px}
.testi-q{font-family:'Bodoni Moda',Georgia,serif;font-size:3.6rem;font-weight:400;color:var(--c-primary);opacity:.12;line-height:.8;margin-bottom:12px}
.testi-text{font-size:14px;line-height:1.84;margin-bottom:22px;font-weight:300}
[data-theme="light"] .testi-text{color:rgba(4,0,15,.68)}
[data-theme="dark"] .testi-text{color:rgba(255,255,255,.65)}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-av{width:38px;height:38px;border-radius:50%;background:var(--c-primary);display:flex;align-items:center;justify-content:center;font-family:'Bodoni Moda',Georgia,serif;font-size:.95rem;font-weight:500;color:#FFFFFF;flex-shrink:0}
.testi-name{font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:13px;color:var(--c-text)}
.testi-city{font-family:'Nunito Sans',sans-serif;font-size:11px;color:var(--c-text);opacity:.44;margin-top:2px;font-weight:300}
.stats-sec{background:var(--c-primary);padding:80px 0;position:relative;overflow:hidden}
.stats-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 55% 80% at 8% 50%,rgba(255,255,255,.04) 0%,transparent 58%),radial-gradient(ellipse 40% 55% at 92% 50%,rgba(4,0,15,.18) 0%,transparent 58%)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
.stat-item{padding:36px 16px;text-align:center;position:relative}
.stat-item:not(:last-child)::after{content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:44px;background:rgba(255,255,255,.14)}
@media(max-width:768px){.stat-item:nth-child(2)::after{display:none}}
.stat-num{font-family:'Bodoni Moda',Georgia,serif;font-size:clamp(2.2rem,4.5vw,3.8rem);font-weight:500;color:#FFFFFF;line-height:1;margin-bottom:10px;display:flex;align-items:baseline;justify-content:center;gap:2px}
.stat-num sup{font-size:.48em;color:#E6DED5}
.stat-lbl{font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.final-cta-sec{background:#04000F;text-align:center;position:relative;overflow:hidden;padding:140px 0 120px}
@media(max-width:720px){.final-cta-sec{padding:96px 0 88px}}
.final-cta-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 55% at 50% 80%,rgba(91,0,46,.24) 0%,transparent 65%)}
.cta-inner{position:relative;z-index:1}
.final-cta-sec h2{color:#FFFFFF;margin-bottom:16px}
.final-cta-sec p{color:rgba(255,255,255,.48);max-width:420px;margin:0 auto 48px;font-weight:300}
.cta-actions{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.cov-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;min-height:400px}
@media(max-width:1024px){.cov-inner{grid-template-columns:1fr;gap:52px}}
.cov-accounts{display:flex;flex-direction:column;gap:10px;margin:28px 0}
.cov-acc{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--c-card);border:1px solid var(--c-card-bd);transition:border-color .3s,transform .3s,box-shadow .3s,background .4s}
.cov-acc:hover{border-color:var(--c-primary);transform:translateX(4px);box-shadow:0 4px 18px rgba(91,0,46,.08)}
.acc-i{display:flex;align-items:center;gap:12px}
.acc-av{width:38px;height:38px;border-radius:50%;background:var(--c-primary);display:flex;align-items:center;justify-content:center;font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:800;color:#FFFFFF;flex-shrink:0}
.acc-h{font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:13px;color:var(--c-text)}
.acc-t{font-family:'Nunito Sans',sans-serif;font-size:11px;color:var(--c-text);opacity:.42;margin-top:2px;font-weight:300}
.acc-f{font-family:'Bodoni Moda',Georgia,serif;font-size:1.25rem;color:var(--c-primary);line-height:1;font-weight:500}
.acc-l{font-family:'Nunito Sans',sans-serif;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-text);opacity:.36;font-weight:300;text-align:right}
.phone-wrap{width:230px;position:relative}
.phone-badge{position:absolute;top:-14px;right:-14px;z-index:2;background:var(--c-primary);color:#FFFFFF;border-radius:50%;width:64px;height:64px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:'Nunito Sans',sans-serif;font-size:8px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;text-align:center;line-height:1.4;box-shadow:0 4px 18px rgba(91,0,46,.32)}
.phone-badge strong{font-family:'Bodoni Moda',Georgia,serif;font-size:.95rem;font-weight:500;display:block;line-height:1;color:#E6DED5}
.phone-frame{background:#04000F;border-radius:34px;padding:11px;box-shadow:0 28px 56px rgba(4,0,15,.3),0 0 0 2px rgba(255,255,255,.06)}
.phone-screen{background:var(--c-bg);border-radius:24px;overflow:hidden;aspect-ratio:9/19.5}
.phone-content{padding:11px;height:100%;background:linear-gradient(180deg,var(--c-bg) 0%,var(--c-bg-alt) 100%);display:flex;flex-direction:column;gap:8px}
.ph-post{background:var(--c-card);border-radius:6px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.ph-hdr{display:flex;align-items:center;gap:7px;padding:7px 9px}
.ph-av{width:18px;height:18px;border-radius:50%;background:var(--c-primary);flex-shrink:0}
.ph-name{font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:700;color:var(--c-text)}
.ph-img{aspect-ratio:1;background:linear-gradient(135deg,#3d001f,#04000F)}
.ph-img2{background:linear-gradient(135deg,#120009,#090005)}
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.port-item{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:4/3;background:var(--c-port-s1);transition:opacity .4s,transform .4s}
.port-item:first-child{grid-column:span 2;aspect-ratio:16/9}
.port-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--c-port-s1)}
.port-item:nth-child(even) .port-ph{background:var(--c-port-s2)}
.port-ph svg{width:38px;height:38px;opacity:.14;color:var(--c-text)}
.port-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(4,0,15,.72) 0%,transparent 55%);opacity:0;transition:opacity .4s;display:flex;align-items:flex-end;padding:18px}
.port-item:hover .port-ov{opacity:1}
.port-lbl{font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.92)}
@media(max-width:768px){.port-grid{grid-template-columns:1fr 1fr}.port-item:first-child{grid-column:span 2}}
.filter-row{display:flex;gap:6px;flex-wrap:wrap}
.filter-btn{padding:7px 18px;font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;border-radius:100px;transition:all .25s;background:transparent;border:1px solid var(--c-border);color:var(--c-text)}
.filter-btn:hover,.filter-btn.active{background:var(--c-primary);border-color:var(--c-primary);color:#FFFFFF}

/* ── COVERAGE PAGE ──────────────────────────────────────── */
.cov-page-intro{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
@media(max-width:1024px){.cov-page-intro{grid-template-columns:1fr;gap:48px}}
.how-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative}
@media(max-width:900px){.how-grid{grid-template-columns:1fr 1fr;gap:24px}}
@media(max-width:480px){.how-grid{grid-template-columns:1fr}}
.how-step{padding:32px 24px;text-align:center;position:relative}
.how-step:not(:last-child)::after{content:'→';position:absolute;right:-12px;top:42px;font-size:18px;color:var(--c-border);transition:color .4s}
@media(max-width:900px){.how-step:not(:last-child)::after{display:none}}
.how-num{font-family:'Bodoni Moda',Georgia,serif;font-size:2.8rem;font-weight:400;color:var(--c-primary);opacity:.18;line-height:1;margin-bottom:12px}
.how-title{font-family:'Nunito Sans',sans-serif;font-size:13px;font-weight:700;color:var(--c-text);margin-bottom:8px;letter-spacing:.02em;transition:color .4s}
.how-desc{font-family:'Nunito Sans',sans-serif;font-size:12px;font-weight:300;color:var(--c-text);opacity:.55;line-height:1.65;transition:color .4s}
.tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.tier-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}}
.tier-card{background:var(--c-card);border:1px solid var(--c-card-bd);padding:40px 32px;position:relative;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s,border-color .3s,background .4s}
.tier-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--c-border);transition:background .3s}
.tier-card:hover{transform:translateY(-5px);box-shadow:0 18px 48px rgba(91,0,46,.10);border-color:rgba(91,0,46,.22)}
.tier-card:hover::before{background:var(--c-primary)}
.tier-card--feat{background:var(--c-primary-feat);border-color:transparent}
.tier-card--feat::before{background:var(--c-primary)}
.tier-name{font-family:'Bodoni Moda',Georgia,serif;font-size:1.9rem;font-weight:500;letter-spacing:.02em;color:var(--c-text);margin-bottom:6px;transition:color .4s}
.tier-card--feat .tier-name{color:#FFFFFF}
.tier-sub{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--c-text);opacity:.4;margin-bottom:24px;transition:color .4s}
.tier-card--feat .tier-sub{color:rgba(255,255,255,.42)}
.tier-sep{width:32px;height:1px;background:var(--c-border);margin-bottom:20px;transition:background .4s}
.tier-card--feat .tier-sep{background:rgba(255,255,255,.14)}
.tier-items{display:flex;flex-direction:column;gap:9px;margin-bottom:32px}
.tier-item{display:flex;align-items:flex-start;gap:10px;font-family:'Nunito Sans',sans-serif;font-size:13px;color:var(--c-text);font-weight:300;line-height:1.5;transition:color .4s}
.tier-card--feat .tier-item{color:rgba(255,255,255,.6)}
.tier-item::before{content:'';display:block;width:4px;height:4px;border-radius:50%;background:var(--c-primary);flex-shrink:0;margin-top:6px}
.tier-card--feat .tier-item::before{background:rgba(230,222,213,.55)}
.tier-cta{display:block;width:100%;padding:12px;background:var(--c-primary);color:#FFFFFF;border:none;cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;transition:background .25s,transform .25s}
.tier-cta:hover{background:var(--c-primary-dk);transform:translateY(-2px)}
.tier-note{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:300;color:var(--c-text);opacity:.34;text-align:center;margin-top:8px;transition:color .4s}
.tier-card--feat .tier-note{color:#FFFFFF;opacity:.28}

/* ── FAQ PAGE ────────────────────────────────────────────── */
.faq-layout{display:grid;grid-template-columns:280px 1fr;gap:64px;align-items:start}
@media(max-width:960px){.faq-layout{grid-template-columns:1fr;gap:40px}}
.faq-nav{position:sticky;top:100px}
@media(max-width:960px){.faq-nav{position:static}}
.faq-nav-label{font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--c-text);opacity:.38;margin-bottom:16px;padding-left:14px;transition:color .4s}
.faq-nav-list{display:flex;flex-direction:column;gap:2px;margin-bottom:32px}
.faq-nav-link{font-family:'Nunito Sans',sans-serif;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--c-text);opacity:.38;padding:10px 14px;border-left:2px solid var(--c-border);transition:opacity .3s,border-color .3s,color .3s;cursor:pointer;display:block;transition:all .3s}
.faq-nav-link:hover{opacity:.75;border-color:rgba(91,0,46,.3)}
.faq-nav-link.active{opacity:1;color:var(--c-primary);border-color:var(--c-primary)}
.faq-cta-box{background:var(--c-bg-alt);border:1px solid var(--c-border);padding:24px;transition:background .4s,border-color .4s}
.faq-cta-box .faq-cta-title{font-family:'Bodoni Moda',Georgia,serif;font-size:1.1rem;font-weight:500;color:var(--c-text);margin-bottom:8px;transition:color .4s}
.faq-cta-box p{font-size:12px;font-weight:300;margin-bottom:16px;opacity:.55}
.faq-section{margin-bottom:56px}
.faq-section:last-child{margin-bottom:0}
.faq-section-title{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:800;letter-spacing:.26em;text-transform:uppercase;color:var(--c-primary);margin-bottom:24px;padding-bottom:14px;border-bottom:1px solid var(--c-border);transition:border-color .4s}
[data-theme="dark"] .faq-section-title{color:#9d6682}
.faq-item{border-bottom:1px solid var(--c-border);transition:border-color .4s}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:15px;font-weight:600;color:var(--c-text);line-height:1.4;transition:color .3s;user-select:none}
.faq-q:hover{color:var(--c-primary)}
.faq-icon{width:20px;height:20px;flex-shrink:0;color:var(--c-primary);opacity:.5;transition:transform .35s var(--ease),opacity .3s}
.faq-item.open .faq-icon{transform:rotate(45deg);opacity:1}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease),padding .35s;font-size:14px;font-weight:300;line-height:1.82;color:var(--c-text);opacity:.7}
.faq-item.open .faq-a{max-height:400px;padding-bottom:20px}
.faq-a a{color:var(--c-primary);text-decoration:underline;text-underline-offset:3px}
.faq-cta-strip{background:var(--c-primary-feat);padding:48px;margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.faq-cta-strip h3{color:#FFFFFF;font-size:1.5rem;margin-bottom:6px}
.faq-cta-strip p{color:rgba(255,255,255,.48);font-size:14px;font-weight:300;margin:0}
[data-theme="dark"] .faq-nav-link{color:rgba(255,255,255,.38)}
[data-theme="dark"] .faq-nav-link.active{color:#9d6682;border-color:#9d6682}

/* ── ABOUT PAGE ──────────────────────────────────────────── */
.about-intro{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
@media(max-width:1024px){.about-intro{grid-template-columns:1fr;gap:48px}}
.about-img-wrap{position:relative;aspect-ratio:4/5;background:var(--c-bg-dp);overflow:hidden;display:flex;align-items:center;justify-content:center;transition:background .4s}
.about-img-ph{color:var(--c-text);opacity:.1}
.about-img-badge{position:absolute;bottom:24px;left:24px;background:var(--c-primary);color:#FFFFFF;padding:16px 22px}
.about-img-badge strong{font-family:'Bodoni Moda',Georgia,serif;font-size:2rem;font-weight:500;display:block;line-height:1;margin-bottom:4px}
.about-img-badge span{font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;opacity:.75}
.stat-row{display:flex;gap:0;border:1px solid var(--c-border);overflow:hidden;transition:border-color .4s}
@media(max-width:600px){.stat-row{flex-direction:column}}
.stat-col{flex:1;padding:36px 28px;border-right:1px solid var(--c-border);text-align:center;transition:border-color .4s,background .4s}
.stat-col:last-child{border-right:none}
.stat-col:hover{background:var(--c-bg-alt)}
.stat-big{font-family:'Bodoni Moda',Georgia,serif;font-size:3rem;font-weight:500;color:var(--c-primary);margin-bottom:8px}
[data-theme="dark"] .stat-big{color:#9d6682}
.stat-small{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--c-text);opacity:.42;transition:color .4s}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:768px){.value-grid{grid-template-columns:1fr}}
.value-card{background:var(--c-card);border:1px solid var(--c-card-bd);padding:36px 28px;transition:border-color .3s,transform .3s,background .4s}
.value-card:hover{border-color:rgba(91,0,46,.2);transform:translateY(-3px)}
.value-icon{width:44px;height:44px;background:rgba(91,0,46,.07);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--c-primary);margin-bottom:20px}
.value-icon i{width:20px;height:20px}
.value-title{font-family:'Bodoni Moda',Georgia,serif;font-size:1.3rem;font-weight:500;color:var(--c-text);margin-bottom:10px;transition:color .4s}
.value-desc{font-size:13px;font-weight:300;line-height:1.78;transition:color .4s}
[data-theme="light"] .value-desc{color:rgba(4,0,15,.6)}
[data-theme="dark"] .value-desc{color:rgba(255,255,255,.52)}

/* ── EVENTS PAGE ─────────────────────────────────────────── */
.event-card{background:var(--c-card);border:1px solid var(--c-card-bd);padding:44px 40px;position:relative;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s,border-color .3s,background .4s;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
@media(max-width:768px){.event-card{grid-template-columns:1fr;padding:32px 24px}}
.event-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--c-border);transition:background .3s}
.event-card:hover{transform:translateY(-4px);box-shadow:0 16px 44px rgba(91,0,46,.1);border-color:rgba(91,0,46,.2)}
.event-card:hover::before{background:var(--c-primary)}
.event-num{font-family:'Bodoni Moda',Georgia,serif;font-size:5rem;font-weight:400;color:var(--c-primary);opacity:.1;position:absolute;top:16px;right:32px;line-height:1;pointer-events:none}
.event-name{font-family:'Bodoni Moda',Georgia,serif;font-size:2rem;font-weight:500;letter-spacing:.01em;color:var(--c-text);margin-bottom:8px;transition:color .4s}
.event-hours{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--c-primary);margin-bottom:18px}
[data-theme="dark"] .event-hours{color:#9d6682}
.event-desc{font-size:14px;font-weight:300;line-height:1.8;margin-bottom:24px;transition:color .4s}
.event-note{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:rgba(91,0,46,.06);border:1px solid rgba(91,0,46,.15);font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--c-primary);border-radius:100px}
[data-theme="dark"] .event-note{color:#9d6682;border-color:rgba(157,102,130,.3);background:rgba(157,102,130,.08)}
.event-price{font-family:'Bodoni Moda',Georgia,serif;font-size:1.4rem;font-weight:500;color:var(--c-text);margin-bottom:8px;transition:color .4s}
.event-price-lbl{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:300;color:var(--c-text);opacity:.45;margin-bottom:28px;transition:color .4s}
.bundle-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:900px){.bundle-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.bundle-grid{grid-template-columns:1fr}}
.bundle-card{background:var(--c-card);border:1px solid var(--c-card-bd);padding:28px 24px;text-align:center;transition:border-color .3s,transform .3s,background .4s}
.bundle-card:hover{border-color:rgba(91,0,46,.22);transform:translateY(-2px)}
.bundle-n{font-family:'Bodoni Moda',Georgia,serif;font-size:2.4rem;font-weight:500;color:var(--c-primary);margin-bottom:6px}
.bundle-lbl{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--c-text);opacity:.5;margin-bottom:14px;transition:color .4s}
.bundle-disc{font-family:'Bodoni Moda',Georgia,serif;font-size:1.8rem;font-weight:500;color:var(--c-text);transition:color .4s}

/* ── CONTACT PAGE ────────────────────────────────────────── */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
@media(max-width:1024px){.contact-layout{grid-template-columns:1fr;gap:56px}}
.wa-cta{background:var(--c-primary-feat);padding:48px;margin-bottom:20px}
.wa-cta-tag{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.wa-cta-tag::before{content:'';display:block;width:24px;height:1px;background:rgba(255,255,255,.3);flex-shrink:0}
.wa-cta h3{font-family:'Bodoni Moda',Georgia,serif;font-size:1.9rem;font-weight:500;color:#FFFFFF;margin-bottom:12px;letter-spacing:.01em}
.wa-cta p{font-size:14px;font-weight:300;color:rgba(255,255,255,.5);line-height:1.8;margin-bottom:28px}
.wa-btn{display:inline-flex;align-items:center;gap:12px;padding:15px 28px;background:var(--c-primary);color:#FFFFFF;font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;transition:background .25s,transform .25s;border:none;cursor:pointer}
.wa-btn:hover{background:var(--c-primary-dk);transform:translateY(-2px)}
.wa-stat{display:flex;align-items:center;gap:8px;margin-top:20px;font-family:'Nunito Sans',sans-serif;font-size:11px;color:rgba(255,255,255,.38);font-weight:300}
.wa-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;flex-shrink:0}
.info-cards{display:flex;flex-direction:column;gap:12px}
.info-card{background:var(--c-card);border:1px solid var(--c-card-bd);padding:22px 24px;display:flex;align-items:center;gap:16px;transition:border-color .3s,background .4s}
.info-card:hover{border-color:rgba(91,0,46,.18)}
.info-icon{width:40px;height:40px;border-radius:50%;background:rgba(91,0,46,.07);display:flex;align-items:center;justify-content:center;color:var(--c-primary);flex-shrink:0}
.info-icon i{width:17px;height:17px}
.info-lbl{font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--c-text);opacity:.38;margin-bottom:4px;transition:color .4s}
.info-val{font-family:'Nunito Sans',sans-serif;font-size:14px;font-weight:600;color:var(--c-text);transition:color .4s}
.form-group{margin-bottom:20px}
.form-label{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--c-text);opacity:.55;display:block;margin-bottom:8px;transition:color .4s}
.form-input,.form-select,.form-textarea{width:100%;padding:13px 16px;background:var(--c-card);border:1.5px solid var(--c-border);font-family:'Nunito Sans',sans-serif;font-size:14px;font-weight:300;color:var(--c-text);outline:none;transition:border-color .25s,box-shadow .25s,background .4s,color .4s}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(91,0,46,.1)}
.form-textarea{resize:vertical;min-height:120px}
.form-select{appearance:none;cursor:pointer}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:480px){.form-2col{grid-template-columns:1fr}}
.form-submit{width:100%;padding:15px;background:var(--c-primary);color:#FFFFFF;border:none;cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;transition:background .25s,transform .25s}
.form-submit:hover{background:var(--c-primary-dk);transform:translateY(-2px)}
.form-note{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:300;color:var(--c-text);opacity:.38;text-align:center;margin-top:10px;transition:color .4s}

/* ── PORTFOLIO PAGE ──────────────────────────────────────── */
.port-full-grid{columns:3;gap:4px}
@media(max-width:900px){.port-full-grid{columns:2}}
@media(max-width:500px){.port-full-grid{columns:1}}
.port-full-item{break-inside:avoid;margin-bottom:4px;position:relative;overflow:hidden;cursor:pointer;background:var(--c-port-s1);transition:opacity .4s,transform .4s}
.port-full-item:nth-child(3n+2) .port-full-ph{aspect-ratio:3/4;background:var(--c-port-s2)}
.port-full-item:nth-child(5n+1) .port-full-ph{aspect-ratio:16/9}
.port-full-ph{width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:var(--c-port-s1);transition:background .4s}
.port-full-ph svg{width:36px;height:36px;opacity:.13;color:var(--c-text)}
.port-full-item img{width:100%;height:100%;object-fit:cover;display:block}
.port-full-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(4,0,15,.72) 0%,transparent 50%);opacity:0;transition:opacity .4s;display:flex;align-items:flex-end;padding:16px}
.port-full-item:hover .port-full-ov{opacity:1}
.port-full-lbl{font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.92)}
.filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:40px}

/* ── 404 PAGE + INNER PAGES — nav always white on dark hero ──── */
/* All inner pages use page templates with dark hero bg (#240012) */
.error404 .nav-logo,
.error404 [data-theme="light"] .nav-logo,
.page-template .nav:not(.scrolled) .nav-logo,
[data-theme="light"] .page-template .nav:not(.scrolled) .nav-logo { color:#FFFFFF }

.error404 .nav-links a,
.error404 [data-theme="light"] .nav-links a,
.page-template .nav:not(.scrolled) .nav-links a,
[data-theme="light"] .page-template .nav:not(.scrolled) .nav-links a { color:rgba(255,255,255,.55) }

.error404 .nav-links a:hover,
.error404 [data-theme="light"] .nav-links a:hover,
.error404 .nav-links a.active,
.error404 [data-theme="light"] .nav-links a.active,
.page-template .nav:not(.scrolled) .nav-links a:hover,
[data-theme="light"] .page-template .nav:not(.scrolled) .nav-links a:hover,
.page-template .nav:not(.scrolled) .nav-links a.active,
[data-theme="light"] .page-template .nav:not(.scrolled) .nav-links a.active { color:#FFFFFF }

/* Active/hover underline always white on dark hero */
.error404 .nav-links a::after,
.error404 [data-theme="light"] .nav-links a::after,
.page-template .nav:not(.scrolled) .nav-links a::after,
[data-theme="light"] .page-template .nav:not(.scrolled) .nav-links a::after { background:#FFFFFF }

.error404 .hamburger span,
.error404 [data-theme="light"] .hamburger span,
.page-template .nav:not(.scrolled) .hamburger span,
[data-theme="light"] .page-template .nav:not(.scrolled) .hamburger span { background:#FFFFFF }

.error404 .theme-btn,
.error404 [data-theme="light"] .theme-btn,
.page-template .nav:not(.scrolled) .theme-btn,
[data-theme="light"] .page-template .nav:not(.scrolled) .theme-btn {
  border-color:rgba(255,255,255,.2);
  background:rgba(255,255,255,.06);
  color:#FFFFFF;
}

.error404 .nav-pill,
.error404 [data-theme="light"] .nav-pill,
.page-template .nav:not(.scrolled) .nav-pill,
[data-theme="light"] .page-template .nav:not(.scrolled) .nav-pill {
  border-color:rgba(255,255,255,.2);
  background:rgba(255,255,255,.06);
  color:#FFFFFF;
}

.page-template .nav:not(.scrolled) .lang-toggle,
[data-theme="light"] .page-template .nav:not(.scrolled) .lang-toggle {
  border-color:rgba(255,255,255,.2);
  background:rgba(255,255,255,.06);
  color:#FFFFFF;
}
.page-template .nav:not(.scrolled) .lang-alt,
[data-theme="light"] .page-template .nav:not(.scrolled) .lang-alt { color:rgba(255,255,255,.55) }

/* Ensure featured card always shows white text in both modes */
[data-theme="light"] .pkg-card--feat .pkg-name{color:#FFFFFF}
[data-theme="light"] .pkg-card--feat .pkg-spec{color:rgba(255,255,255,.6)}
[data-theme="light"] .pkg-card--feat .pkg-sep{background:rgba(255,255,255,.14)}
[data-theme="light"] .pkg-card--feat .pkg-note{color:#FFFFFF;opacity:.28}
[data-theme="light"] .pkg-card--feat .pkg-spec::before{background:rgba(230,222,213,.55)}

/* ── PAGE TRANSITIONS — instant navigation for performance ── */
/* Page fade removed in v2.3 for mobile performance */
main{animation:pageFadeIn .3s var(--ease) both}
@keyframes pageFadeIn{from{opacity:0}to{opacity:1}}

/* ── DATE BOX MOBILE ────────────────────────────────────── */
@media(max-width:600px){
  .date-wrap{max-width:100%}
  /* Keep horizontal — just tighten everything */
  .date-lbl{display:none} /* hide label on mobile — saves space */
  .date-box input[type="date"]{padding:12px 8px;font-size:13px}
  .date-btn{padding:12px 14px;font-size:9px;letter-spacing:.1em}
  .hero-cta .btn{width:100%;justify-content:center}
}
/* ── GENERAL MOBILE RESPONSIVENESS ─────────────────────── */
@media(max-width:480px){
  .hero{padding:120px 20px 100px}
  .hero-title{font-size:clamp(2.2rem,8vw,3.2rem)}
  .pkg-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .cov-inner{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .cta-actions{flex-direction:column;align-items:stretch}
  .cta-actions .btn{width:100%;justify-content:center}
  .cta-actions .btn-consult{justify-content:center}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .bundle-grid{grid-template-columns:repeat(2,1fr)}
  .tier-grid{grid-template-columns:1fr}
  .contact-layout{grid-template-columns:1fr}
  .about-intro{grid-template-columns:1fr}
  .faq-layout{grid-template-columns:1fr}
  .port-full-grid{columns:1}
  .event-card{grid-template-columns:1fr}
  .how-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .pkg-hdr{flex-direction:column;align-items:flex-start}
  .phone-wrap{display:none}
  .cov-inner{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr}
  .faq-layout{grid-template-columns:1fr}
  .faq-nav{display:none}
}

/* ── CUSTOM LOGO IMAGE ───────────────────────────────────── */
.nav-logo-img{
  height:36px;width:auto;
  display:block;
  object-fit:contain;
  transition:opacity .3s;
}
.nav-logo-img:hover{opacity:.8}

/* ── WORDPRESS EDITOR CONTENT ───────────────────────────── */
.wp-editor-content h1,.wp-editor-content h2,.wp-editor-content h3,
.wp-editor-content h4,.wp-editor-content p,.wp-editor-content ul,
.wp-editor-content ol,.wp-editor-content blockquote{
  margin-bottom:1.2em;
}
.wp-editor-content ul,.wp-editor-content ol{
  padding-left:1.5em;
}
.wp-editor-content a{
  color:var(--c-primary);
  text-decoration:underline;
  text-underline-offset:3px;
}
.wp-editor-content img{
  max-width:100%;
  height:auto;
}

/* ── STATS GRID 3-COLUMN ────────────────────────────────── */
.stats-grid--3{grid-template-columns:repeat(3,1fr)}
@media(max-width:600px){.stats-grid--3{grid-template-columns:1fr}}




/* ═══════════════════════════ v2.2.0 ═══════════════════════════ */

/* ── LOGO ──── */
.nav-logo-img{height:var(--logo-h,36px);width:auto;transition:opacity .3s}
.footer-logo-img{height:var(--footer-logo-h,36px);width:auto}

/* ── LOADING SCREEN ──── */
.loading-screen{position:fixed;inset:0;z-index:9999;background:var(--c-primary-feat);display:flex;align-items:center;justify-content:center;transition:opacity .5s,visibility .5s}
.loading-screen.done{opacity:0;visibility:hidden;pointer-events:none}
.loading-logo{opacity:0;animation:loaderFadeIn .8s .1s ease forwards}
.loading-logo-img{height:48px;width:auto;filter:brightness(0) invert(1)}
.loading-logo-text{font-family:'Bodoni Moda',Georgia,serif;font-size:2rem;font-weight:500;letter-spacing:.12em;color:#FFFFFF}
@keyframes loaderFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ── READING PROGRESS ──── */
.reading-progress{position:fixed;top:0;left:0;right:0;z-index:1001;height:2px;background:transparent;pointer-events:none}
.reading-progress-bar{height:100%;width:0%;background:var(--c-primary);transition:width .1s linear}

/* ── LANGUAGE TOGGLE — fixed for all themes + 404 ──── */
.lang-toggle{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:100px;border:1px solid rgba(4,0,15,0.15);background:rgba(4,0,15,0.04);cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:600;color:#04000F;transition:all .3s;flex-shrink:0}
[data-theme="dark"] .lang-toggle{border-color:rgba(255,255,255,0.18);background:rgba(255,255,255,0.06);color:#FFFFFF}
.lang-toggle:hover{background:rgba(91,0,46,.07);border-color:rgba(91,0,46,.22)}
.lang-active{opacity:1}
.lang-sep{opacity:.35;margin:0 2px}
.lang-alt{opacity:.55;font-family:'Noto Kufi Arabic','Nunito Sans',sans-serif}
/* 404 page override — always light text */
.error404 .lang-toggle,.error404 [data-theme="light"] .lang-toggle{border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#FFFFFF}
.error404 .lang-alt,.error404 [data-theme="light"] .lang-alt{opacity:.55;color:#FFFFFF}
/* Mobile — keep readable, never hide text */
.lang-toggle--mob{margin:0 auto;padding:8px 20px;font-size:12px;background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15);color:#FFFFFF}
@media(max-width:720px){.lang-toggle{padding:5px 10px;font-size:10px}}

/* ── WA PILL MOBILE — handled in base CSS above ──── */

/* ── QUIZ BACK + STEP (top of quiz) ──── */
.quiz-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px}
.quiz-step{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:600;color:var(--c-text);opacity:.4;letter-spacing:.08em;transition:color .4s}

/* ── QUIZ BOTTOM NAV (Back + Next at bottom) ──── */
.quiz-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--c-border);transition:border-color .4s}
.quiz-back,.quiz-next{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:all .25s;border-radius:100px;min-height:44px;text-decoration:none}
.quiz-back{background:transparent;border:1px solid var(--c-border);color:var(--c-text);opacity:.55}
.quiz-back:hover{opacity:1;border-color:var(--c-primary);color:var(--c-primary)}
.quiz-back svg{width:14px;height:14px}
.quiz-back-spacer{width:1px;height:1px}
.quiz-next{background:var(--c-primary);border:1px solid var(--c-primary);color:#FFFFFF;opacity:.35;pointer-events:none;margin-left:auto}
.quiz-next.active{opacity:1;pointer-events:auto}
.quiz-next:hover{background:var(--c-primary-dk);border-color:var(--c-primary-dk)}
.quiz-next svg{width:14px;height:14px}

/* ── DATE CHECKER — right padding fix ──── */
.date-box{gap:0}
.date-btn{margin:3px;padding:14px 22px}

/* ── CTA GLOW PULSE ──── */
@keyframes ctaGlow{0%,100%{box-shadow:0 4px 20px rgba(91,0,46,.28)}50%{box-shadow:0 4px 32px rgba(91,0,46,.55),0 0 48px rgba(91,0,46,.18)}}
.hero-cta .btn-p,.bar-btn{animation:ctaGlow 3s ease-in-out infinite}
.hero-cta .btn-p:hover,.bar-btn:hover{animation:none}
@media(prefers-reduced-motion:reduce){.hero-cta .btn-p,.bar-btn{animation:none}}

/* ── QUIZ ──── */
.quiz-sec{background:var(--c-bg-alt);transition:background .4s}
[data-theme="dark"] .quiz-sec{background:var(--c-primary-feat)}
.quiz-wrap{max-width:580px;margin:40px auto 0;background:var(--c-card);border:1px solid var(--c-card-bd);overflow:hidden;transition:background .4s,border-color .4s}
.quiz-progress{height:5px;background:var(--c-border);transition:background .4s}
.quiz-progress-bar{height:100%;background:var(--c-primary);transition:width .5s cubic-bezier(.25,.46,.45,.94)}
.quiz-body{padding:32px 36px;min-height:280px}
@media(max-width:600px){.quiz-body{padding:22px 18px;min-height:240px}}
.quiz-phase{font-family:'Nunito Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--c-primary);margin-bottom:6px}
[data-theme="dark"] .quiz-phase{color:#9d6682}
.quiz-q{font-family:'Bodoni Moda',Georgia,serif;font-size:clamp(1.05rem,2.6vw,1.4rem);font-weight:500;color:var(--c-text);margin-bottom:18px;line-height:1.3;transition:color .4s}
.quiz-hint{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:300;color:var(--c-text);opacity:.35;margin-bottom:14px;transition:color .4s;font-style:italic}
.quiz-opts{display:flex;flex-direction:column;gap:8px}
.quiz-opt{display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--c-bg);border:1.5px solid var(--c-border);cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:13px;font-weight:400;color:var(--c-text);transition:all .25s;min-height:44px}
[data-theme="dark"] .quiz-opt{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.1)}
.quiz-opt:hover{border-color:var(--c-primary);background:rgba(91,0,46,.04)}
[data-theme="dark"] .quiz-opt:hover{border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.06)}
.quiz-opt-dot{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--c-border);flex-shrink:0;transition:all .25s;position:relative}
[data-theme="dark"] .quiz-opt-dot{border-color:rgba(255,255,255,.2)}
.quiz-opt:hover .quiz-opt-dot{border-color:var(--c-primary)}
.quiz-opt.selected{border-color:var(--c-primary);background:rgba(91,0,46,.06)}
[data-theme="dark"] .quiz-opt.selected{border-color:var(--c-primary);background:rgba(91,0,46,.15)}
.quiz-opt.selected .quiz-opt-dot{border-color:var(--c-primary);background:var(--c-primary)}
.quiz-opt.selected .quiz-opt-dot::after{content:'';position:absolute;top:50%;left:50%;width:6px;height:6px;border-radius:50%;background:#FFFFFF;transform:translate(-50%,-50%)}
.quiz-interlude{text-align:center;padding:20px 0}
.quiz-interlude p{font-size:15px;font-weight:300;line-height:1.8;max-width:420px;margin:0 auto 32px;font-style:italic}
.quiz-result{text-align:center}
.quiz-result-persona{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--c-primary);margin-bottom:12px}
[data-theme="dark"] .quiz-result-persona{color:#9d6682}
.quiz-result-name{font-family:'Bodoni Moda',Georgia,serif;font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:500;color:var(--c-text);margin-bottom:10px;transition:color .4s}
.quiz-result-desc{font-size:15px;font-weight:300;margin-bottom:8px;font-style:italic}
.quiz-result-pkg{font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--c-text);margin-bottom:6px;transition:color .4s}
.quiz-result-specs{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:24px}
.quiz-result-spec{font-size:12px;font-weight:300;padding:5px 14px;background:var(--c-bg-alt);border:1px solid var(--c-border);transition:background .4s,border-color .4s}
.quiz-result-scarcity{font-family:'Nunito Sans',sans-serif;font-size:11px;font-weight:600;color:var(--c-primary);margin-bottom:28px}
[data-theme="dark"] .quiz-result-scarcity{color:#9d6682}
.quiz-result-ctas{display:flex;flex-direction:column;align-items:center;gap:12px}
.quiz-result-ctas .btn{min-width:260px}

/* ── ONLINE/OFFLINE ──── */
.bar-av.offline::after,.np-dot.offline::after,.c-av.offline::after{background:#f59e0b !important}

/* ── COOKIE — slim toast ──── */
.cookie-bar{position:fixed;bottom:68px;left:0;right:0;z-index:899;background:var(--c-card);border-top:1px solid var(--c-card-bd);padding:8px 0;transition:background .4s}
.cookie-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.cookie-text{font-family:'Nunito Sans',sans-serif;font-size:12px;font-weight:300;color:var(--c-text);margin:0}
.cookie-actions{display:flex;gap:6px;flex-shrink:0}
.cookie-accept{padding:5px 14px;background:var(--c-primary);color:#FFF;border:none;cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:background .25s}
.cookie-accept:hover{background:var(--c-primary-dk)}
.cookie-decline{padding:5px 14px;background:transparent;color:var(--c-text);border:1px solid var(--c-border);cursor:pointer;font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
@media(max-width:480px){.cookie-inner{gap:8px}.cookie-text{font-size:11px}}

/* ── SOCIAL PLACEHOLDER (dimmed when URL=#) ──── */
.soc-placeholder{opacity:.2;pointer-events:none}

/* ── SHARE BAR (between page content and footer) ──── */
.share-bar{background:var(--c-bg-alt);border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border);padding:20px 0;transition:background .4s,border-color .4s}
.share-inner{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.share-label{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--c-text);opacity:.4;transition:color .4s}
.share-opt{width:38px;height:38px;border-radius:50%;background:var(--c-card);border:1px solid var(--c-card-bd);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--c-text);opacity:.5;transition:all .3s;text-decoration:none}
.share-opt:hover{opacity:1;border-color:var(--c-primary);color:var(--c-primary)}
.share-opt svg{width:15px;height:15px;flex-shrink:0}
.share-wa:hover{color:#25D366;border-color:#25D366}
.share-copied{font-family:'Nunito Sans',sans-serif;font-size:10px;font-weight:600;color:var(--c-primary);opacity:0;transition:opacity .3s;position:absolute;margin-top:-24px}
.share-copied.show{opacity:1}
@media(max-width:600px){
  .share-bar{padding:18px 0}
  .share-label{display:none}
  .share-inner{gap:18px}
}

/* ── BLUR-UP PORTFOLIO ──── */
.port-item.blur-up .port-ph,.port-full-item.blur-up .port-full-ph{filter:blur(12px);transform:scale(1.05);transition:filter .6s,transform .6s}
.port-item.blur-up.loaded .port-ph,.port-full-item.blur-up.loaded .port-full-ph{filter:blur(0);transform:scale(1)}
.port-item img,.port-full-item img{opacity:0;transition:opacity .5s}
.port-item.loaded img,.port-full-item.loaded img{opacity:1}


/* ═══════════════════════════ v2.3.0 — RTL + PERFORMANCE ═══════════════════
   STRATEGY: Text flows RTL, buttons/nav/CTAs stay in original positions.
   Loading screen removed. Lucide replaced with inline SVGs.
══════════════════════════════════════════════════════════════════════════════ */

/* ── Loading screen — removed, keep class for backwards compat ──── */
.loading-screen{display:none !important}

/* ── Global RTL ──── */
[dir="rtl"] { direction: rtl; }
[dir="rtl"] body {
  font-family: 'Noto Kufi Arabic', 'Nunito Sans', sans-serif;
  text-align: right;
}
[dir="rtl"] h1, [dir="rtl"] h2, [dir="rtl"] h3, [dir="rtl"] h4 {
  font-family: 'Scheherazade New', 'Bodoni Moda', Georgia, serif;
  letter-spacing: 0;
}
[dir="rtl"] p { line-height: 2; }
[dir="rtl"] .svc-body, [dir="rtl"] .testi-text,
[dir="rtl"] .value-desc, [dir="rtl"] .how-desc { line-height: 2; }

/* ── NAV — fully flipped for proper RTL ──── */
[dir="rtl"] .nav-inner { direction: rtl; }
[dir="rtl"] .nav-links a { direction: rtl; }
[dir="rtl"] .nav-logo { direction: rtl; }
[dir="rtl"] .nav-cta--desktop { margin-right: auto; margin-left: 0; }

/* ── Mobile menu ──── */
[dir="rtl"] .mob-menu a:not(.mob-wa) { direction: rtl; }
[dir="rtl"] .mob-wa { direction: rtl; }

/* ── Hero — center-aligned, flip text ──── */
[dir="rtl"] .hero-content { direction: rtl; }
[dir="rtl"] .hero-eyebrow { direction: rtl; }
[dir="rtl"] .hero-sub { direction: rtl; }

/* ── Date box — fully flipped ──── */
[dir="rtl"] .date-box { direction: rtl; }
[dir="rtl"] .date-lbl { direction: rtl; }

/* ── Trust bar ──── */
[dir="rtl"] .trust-item { direction: rtl; }

/* ── Service cards ──── */
[dir="rtl"] .svc-card { direction: rtl; text-align: right; }
[dir="rtl"] .svc-num { right: auto; left: 32px; }

/* ── Labels — flip decorative line ──── */
[dir="rtl"] .label { flex-direction: row-reverse; }
[dir="rtl"] .label--center { flex-direction: row-reverse; }

/* ── Package cards ──── */
[dir="rtl"] .pkg-card { direction: rtl; text-align: right; }
[dir="rtl"] .pkg-spec { flex-direction: row-reverse; text-align: right; }
[dir="rtl"] .pkg-badge { right: auto; left: 16px; }
[dir="rtl"] .pkg-li { text-align: right; }
[dir="rtl"] .pkg-2col { direction: rtl; }

/* ── Coverage accounts ──── */
[dir="rtl"] .cov-acc { direction: rtl; }
[dir="rtl"] .acc-i { flex-direction: row-reverse; }
[dir="rtl"] .acc-l { text-align: left; }
[dir="rtl"] .cov-acc:hover { transform: translateX(-4px); }

/* ── Coverage page ──── */
[dir="rtl"] .cov-page-intro { direction: rtl; }
[dir="rtl"] .how-step { direction: rtl; }
[dir="rtl"] .tier-card { direction: rtl; text-align: right; }
[dir="rtl"] .tier-item { flex-direction: row-reverse; text-align: right; }

/* ── Testimonials ──── */
[dir="rtl"] .testi-card { direction: rtl; text-align: right; }
[dir="rtl"] .testi-author { flex-direction: row-reverse; }
[dir="rtl"] .testi-q { text-align: right; }

/* ── Quiz — fully flipped ──── */
[dir="rtl"] .quiz-body { direction: rtl; text-align: right; }
[dir="rtl"] .quiz-opt { flex-direction: row-reverse; }
[dir="rtl"] .quiz-foot { direction: rtl; }
[dir="rtl"] .quiz-back, [dir="rtl"] .quiz-next { direction: rtl; }
[dir="rtl"] .quiz-top { direction: rtl; }

/* ── Page hero / breadcrumbs ──── */
[dir="rtl"] .page-hero-inner { direction: rtl; text-align: right; }
[dir="rtl"] .page-hero-eye { flex-direction: row-reverse; }

/* ── FAQ ──── */
[dir="rtl"] .faq-layout { direction: rtl; }
[dir="rtl"] .faq-q { flex-direction: row-reverse; text-align: right; }
[dir="rtl"] .faq-a { text-align: right; }
[dir="rtl"] .faq-nav-link { border-left: none; border-right: 2px solid var(--c-border); padding-left: 0; padding-right: 14px; text-align: right; }
[dir="rtl"] .faq-nav-link.active { border-right-color: var(--c-primary); }

/* ── Contact ──── */
[dir="rtl"] .contact-layout { direction: rtl; }
[dir="rtl"] .wa-cta { direction: rtl; text-align: right; }
[dir="rtl"] .wa-cta-tag { flex-direction: row-reverse; }
[dir="rtl"] .info-card { flex-direction: row-reverse; }
[dir="rtl"] .form-label { text-align: right; }
[dir="rtl"] .form-input, [dir="rtl"] .form-textarea, [dir="rtl"] .form-select { text-align: right; }

/* ── Events ──── */
[dir="rtl"] .event-card { direction: rtl; text-align: right; }
[dir="rtl"] .event-num { right: auto; left: 32px; }
[dir="rtl"] .event-note { flex-direction: row-reverse; }
[dir="rtl"] .bundle-card { direction: rtl; }

/* ── About ──── */
[dir="rtl"] .about-intro { direction: rtl; }
[dir="rtl"] .value-card { direction: rtl; text-align: right; }

/* ── Footer — fully flipped ──── */
[dir="rtl"] .footer { direction: rtl; }
[dir="rtl"] .footer-brand { text-align: right; }
[dir="rtl"] .footer-tag { text-align: right; }
[dir="rtl"] .footer-col { text-align: right; }
[dir="rtl"] .footer-col h4 { flex-direction: row-reverse; }

/* ── Bottom bar — fully flipped (consultant right, button left) ──── */
[dir="rtl"] .bar-inner { direction: rtl; }
[dir="rtl"] .bar-left { direction: rtl; }
[dir="rtl"] .bar-txt { text-align: right; }

/* ── Share bar ──── */
[dir="rtl"] .share-label { direction: rtl; }

/* ── Cookie bar — fully flipped ──── */
[dir="rtl"] .cookie-inner { direction: rtl; }
[dir="rtl"] .cookie-text { direction: rtl; text-align: right; flex: 1; }

/* ── Final CTA — fully flipped ──── */
[dir="rtl"] .cta-inner { direction: rtl; }
[dir="rtl"] .cta-actions { direction: rtl; }

/* ── Scroll top flips to left in RTL ──── */
[dir="rtl"] .scroll-top { right: auto; left: 24px; }

/* ── Filters ──── */
[dir="rtl"] .filter-row, [dir="rtl"] .filter-bar { direction: rtl; }

/* ── Stats ──── */
[dir="rtl"] .stat-item { direction: rtl; }

/* ── Portfolio overlays ──── */
[dir="rtl"] .port-lbl { direction: rtl; }
[dir="rtl"] .port-full-lbl { direction: rtl; }

/* ── Lang toggle font swap ──── */
[dir="rtl"] .lang-active { font-family: 'Noto Kufi Arabic', sans-serif; }
[dir="rtl"] .lang-alt { font-family: 'Nunito Sans', sans-serif; }

/* ── PERFORMANCE: Reduce CLS from fade-up animations ──── */
.fade-up { will-change: opacity, transform; }
@media (prefers-reduced-motion: reduce) { .fade-up { opacity: 1; transform: none; } }

/* ── PERFORMANCE: Contain layout for expensive sections ──── */
.pkg-grid, .testi-grid, .port-grid, .port-full-grid { contain: layout style; }
