/* =========================================================================
   Enchanted Entertainment — design system
   Aesthetic: fairytale, elegant, premium. Not cheesy, not childish.
   Palette: plum, royal purple, lavender, blush, champagne gold, cream.
   Built mobile-first. Honours prefers-reduced-motion throughout.
   ========================================================================= */

:root{
  /* Brand palette */
  --plum-deep:    #1f1230;
  --plum:         #2a1a3e;
  --plum-soft:    #3d2956;
  --royal:        #6b3fa0;
  --royal-bright: #8757c2;
  --lavender:     #b599d4;
  --lavender-soft:#e6dcf0;
  --blush:        #f7d4dc;
  --blush-deep:   #e8a8b6;
  --gold:         #d4a55a;
  --gold-bright:  #e8c280;
  --gold-soft:    #f0dcb0;
  --cream:        #faf6ef;
  --cream-deep:   #f2ebdb;
  --paper:        #ffffff;
  --ink:          #1a0e26;
  --ink-2:        #3d2956;
  --muted:        #7a6e87;
  --line:         #ebe4d6;
  --line-soft:    #f5efe2;

  /* Shadows */
  --shadow-sm:  0 1px 2px rgba(31,18,48,.06), 0 2px 8px rgba(31,18,48,.05);
  --shadow:     0 2px 6px rgba(31,18,48,.08), 0 12px 32px rgba(31,18,48,.10);
  --shadow-lg:  0 12px 32px rgba(31,18,48,.16), 0 30px 80px rgba(31,18,48,.18);
  --shadow-glow: 0 0 0 1px rgba(212,165,90,.25), 0 8px 28px rgba(107,63,160,.22);

  /* Radii */
  --r-sm: 8px;
  --r:    14px;
  --r-lg: 22px;
  --r-pill: 999px;

  /* Motion */
  --ease: cubic-bezier(.2,.8,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  /* Layout */
  --container: 1200px;
  --container-narrow: 980px;
  --container-wide: 1320px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  font-size:16px;
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  /* Offset anchor scrolls by the sticky header height so #targets aren't
     clipped behind it when arriving via cross-page hash navigation. */
  scroll-padding-top:96px;
}
/* Belt and braces: also apply scroll-margin-top to common anchor targets */
.character-card,
.package-card,
[id]{
  scroll-margin-top:96px;
}
body{
  font-family:'Nunito Sans','Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  font-size:16px;line-height:1.65;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
svg{display:block}
a{color:var(--royal);text-decoration:none;font-weight:600;transition:color 160ms var(--ease)}
a:hover{color:var(--plum)}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
  border-radius:4px;
}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,textarea,select{font:inherit;color:inherit}

h1,h2,h3,h4,h5{
  font-family:'Cormorant Garamond','Playfair Display',Georgia,serif;
  font-weight:500;
  color:var(--plum-deep);
  line-height:1.15;
  letter-spacing:-0.005em;
}
h1{font-size:clamp(2.4rem, 6vw, 4.4rem);font-weight:500}
h2{font-size:clamp(1.8rem, 4.2vw, 2.8rem);font-weight:500;margin-bottom:.5em}
h3{font-size:clamp(1.25rem, 2.6vw, 1.65rem);font-weight:600;margin-bottom:.4em}
h4{font-size:1.1rem;font-weight:600;margin-bottom:.3em}
p{margin-bottom:1em;color:var(--ink-2)}
p.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--ink-2);line-height:1.6}

.script{
  font-family:'Allura','Great Vibes',cursive;
  font-weight:400;
  letter-spacing:.005em;
  color:var(--royal);
  font-size:1.5em;
  line-height:1;
  text-shadow:
    0 0 16px rgba(232,194,128,.35),
    0 0 32px rgba(181,153,212,.25);
  animation:scriptGlow 4.2s ease-in-out infinite;
}
@keyframes scriptGlow{
  0%,100%{
    text-shadow:
      0 0 14px rgba(232,194,128,.30),
      0 0 28px rgba(181,153,212,.20);
  }
  50%{
    text-shadow:
      0 0 24px rgba(232,194,128,.70),
      0 0 48px rgba(212,165,90,.40),
      0 0 70px rgba(181,153,212,.30);
  }
}
@media (prefers-reduced-motion: reduce){
  .script{animation:none}
}
/* On dark hero backgrounds, switch script to gold for contrast + warmer glow */
.hero .script,
.page-hero .script,
.section-dark .script,
.cta-strip .script{
  color:var(--gold-bright);
  animation-name:scriptGlowWarm;
}
@keyframes scriptGlowWarm{
  0%,100%{
    text-shadow:
      0 0 20px rgba(232,194,128,.45),
      0 0 36px rgba(212,165,90,.25);
  }
  50%{
    text-shadow:
      0 0 32px rgba(232,194,128,.85),
      0 0 60px rgba(212,165,90,.55),
      0 0 88px rgba(247,212,220,.30);
  }
}
.eyebrow{
  font-family:'Nunito Sans',sans-serif;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold);
}

.skip-link{
  position:absolute;left:-9999px;top:0;
  background:var(--plum);color:#fff;
  padding:.75rem 1.25rem;border-radius:0 0 var(--r) 0;
  z-index:100;font-weight:700;
}
.skip-link:focus{left:0}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 24px}
.container-wide{max-width:var(--container-wide);margin:0 auto;padding:0 24px}

.section{padding:80px 0}
.section-tight{padding:48px 0}
@media(max-width:768px){
  .section{padding:56px 0}
  .section-tight{padding:36px 0}
}
.section-cream{background:var(--cream)}
.section-paper{background:var(--paper)}
.section-soft{background:linear-gradient(180deg,var(--cream) 0%,var(--lavender-soft) 100%)}
.section-blush{background:linear-gradient(135deg,var(--blush) 0%,var(--lavender-soft) 100%)}
.section-dark{
  background:linear-gradient(135deg,var(--plum-deep) 0%,var(--plum) 60%,var(--royal) 100%);
  color:#fff;
}
.section-dark h1,.section-dark h2,.section-dark h3,.section-dark h4{color:#fff}
.section-dark p{color:rgba(255,255,255,.88)}
.section-dark a{color:var(--gold-bright)}
.section-dark .eyebrow{color:var(--gold-bright)}

/* =========================================================================
   BUTTONS
   ========================================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:14px 26px;
  font-family:'Nunito Sans',sans-serif;
  font-size:.95rem;font-weight:700;
  letter-spacing:.02em;
  border-radius:var(--r-pill);
  cursor:pointer;
  transition:all 200ms var(--ease);
  text-align:center;
  white-space:nowrap;
  border:1.5px solid transparent;
  position:relative;
  overflow:hidden;
}
.btn-primary{
  background:linear-gradient(135deg,var(--royal) 0%,var(--royal-bright) 100%);
  color:#fff;
  box-shadow:0 6px 20px rgba(107,63,160,.32);
  animation:btnPulseRoyal 2.6s ease-out infinite;
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 28px rgba(107,63,160,.5);
  color:#fff;
  animation-play-state:paused;
}
.btn-gold{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-bright) 100%);
  color:var(--plum-deep);
  box-shadow:0 6px 20px rgba(212,165,90,.32);
  animation:btnPulseGold 2.6s ease-out infinite;
}
.btn-gold:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 28px rgba(212,165,90,.5);
  color:var(--plum-deep);
  animation-play-state:paused;
}
@keyframes btnPulseRoyal{
  0%   {box-shadow:0 6px 20px rgba(107,63,160,.32),0 0 0 0 rgba(107,63,160,.55)}
  60%  {box-shadow:0 6px 20px rgba(107,63,160,.32),0 0 0 14px rgba(107,63,160,0)}
  100% {box-shadow:0 6px 20px rgba(107,63,160,.32),0 0 0 0 rgba(107,63,160,0)}
}
@keyframes btnPulseGold{
  0%   {box-shadow:0 6px 20px rgba(212,165,90,.32),0 0 0 0 rgba(212,165,90,.65)}
  60%  {box-shadow:0 6px 20px rgba(212,165,90,.32),0 0 0 14px rgba(212,165,90,0)}
  100% {box-shadow:0 6px 20px rgba(212,165,90,.32),0 0 0 0 rgba(212,165,90,0)}
}
@media (prefers-reduced-motion: reduce){
  .btn-primary,.btn-gold{animation:none}
}
/* Disabled buttons shouldn't pulse */
.btn:disabled,.btn[disabled]{animation:none}
.btn-ghost{
  background:transparent;color:var(--plum);
  border-color:var(--plum);
}
.btn-ghost:hover{
  background:var(--plum);color:#fff;
  transform:translateY(-2px);
}
.btn-ghost-light{
  background:transparent;color:#fff;
  border-color:rgba(255,255,255,.5);
}
.btn-ghost-light:hover{
  background:#fff;color:var(--plum);
  border-color:#fff;
}
.btn-sm{padding:10px 18px;font-size:.85rem}
.btn-lg{padding:18px 36px;font-size:1.05rem}
.btn-block{width:100%}
.btn-icon{width:18px;height:18px;flex-shrink:0}

/* =========================================================================
   HEADER + NAV
   ========================================================================= */
.site-header{
  position:sticky;top:0;z-index:60;
  /* Dark plum background so the gold logo + cursive wordmark pops.
     Same family as the hero gradient — feels like the brand identity
     continues right into the top chrome. */
  background:linear-gradient(180deg, var(--plum-deep) 0%, var(--plum) 100%);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(232,194,128,.18);
  transition:background 200ms var(--ease);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;height:74px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  font-family:'Cormorant Garamond',serif;
  font-size:1.6rem;font-weight:600;
  color:var(--plum-deep);
  line-height:1;
}
.brand .script{font-size:1.6rem;color:var(--royal);margin-right:2px}
.brand img{height:42px;width:auto}

/* New brand mark: crown icon + cursive wordmark side by side in the header. */
.brand-logo-icon{
  height:42px;width:auto;flex-shrink:0;
}
.brand-logo-wordmark{
  height:34px;width:auto;flex-shrink:1;
  max-width:240px;
  object-fit:contain;
}
@media (max-width:640px){
  .brand-logo-icon{height:34px}
  .brand-logo-wordmark{height:26px;max-width:160px}
}

.nav-primary{flex:1}
.nav-primary ul{
  display:flex;align-items:center;justify-content:center;gap:6px;
  list-style:none;
}
.nav-primary > ul > li > a,
.nav-primary > ul > li > button{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 14px;
  font-size:.92rem;font-weight:600;
  color:var(--cream);
  border-radius:var(--r-pill);
  transition:all 160ms var(--ease);
}
.nav-primary > ul > li > a:hover,
.nav-primary > ul > li > button:hover{
  color:var(--gold-bright);background:rgba(232,194,128,.12);
}
.nav-primary .has-dropdown{position:relative}
.nav-primary .dropdown-menu{
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-4px);
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  padding:8px;min-width:230px;
  opacity:0;pointer-events:none;
  transition:opacity 160ms var(--ease),transform 160ms var(--ease);
  list-style:none;
  /* Override the flex cascade from .nav-primary ul so items stack */
  display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;
}
.nav-primary .dropdown-menu li{display:block;width:100%}
.nav-primary [aria-expanded="true"] > .dropdown-menu{
  opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);
}
.dropdown-menu li a{
  display:block;padding:10px 14px;
  font-size:.9rem;color:var(--ink-2);font-weight:500;
  border-radius:8px;
}
.dropdown-menu li a:hover{background:var(--lavender-soft);color:var(--royal)}

.chev{transition:transform 160ms var(--ease)}
.nav-primary [aria-expanded="true"] .chev{transform:rotate(180deg)}

.header-right{display:flex;align-items:center;gap:10px}
.header-cta{display:inline-flex}
.menu-toggle{
  display:none;
  width:42px;height:42px;
  align-items:center;justify-content:center;
  border-radius:var(--r-pill);
  color:var(--cream);
}
.menu-toggle:hover{background:var(--lavender-soft)}

@media (max-width: 1024px){
  .nav-primary{display:none}
  .menu-toggle{display:inline-flex}
  .header-cta{display:none}
}

/* Mobile drawer */
.mobile-drawer{
  position:fixed;inset:0;z-index:80;
  pointer-events:none;
}
.mobile-drawer[data-open="true"]{pointer-events:auto}
.drawer-scrim{
  position:absolute;inset:0;
  background:rgba(31,18,48,.5);
  opacity:0;transition:opacity 200ms var(--ease);
}
.mobile-drawer[data-open="true"] .drawer-scrim{opacity:1}
.drawer-panel{
  position:absolute;top:0;right:0;bottom:0;
  width:min(360px,86vw);
  background:var(--cream);
  transform:translateX(100%);
  transition:transform 280ms var(--ease-out);
  display:flex;flex-direction:column;
  box-shadow:-12px 0 40px rgba(31,18,48,.2);
}
.mobile-drawer[data-open="true"] .drawer-panel{transform:translateX(0)}
.drawer-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;
  /* Match the main header's dark plum chrome so the gold logo reads */
  background:linear-gradient(180deg, var(--plum-deep) 0%, var(--plum) 100%);
  border-bottom:1px solid rgba(232,194,128,.18);
}
.drawer-head .brand{font-size:1.4rem}
/* Override the global brand img/icon sizes for the tighter drawer */
.drawer-head .brand-logo-icon{height:34px}
.drawer-head .brand-logo-wordmark{height:24px;max-width:170px}
.drawer-head .drawer-close{color:var(--cream)}
.drawer-close{
  width:38px;height:38px;border-radius:var(--r-pill);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--plum);
}
.drawer-close:hover{background:var(--lavender-soft)}
.drawer-nav{flex:1;overflow-y:auto;padding:18px 0}
.drawer-nav ul{list-style:none}
.drawer-nav > ul > li > a{
  display:block;
  padding:14px 22px;
  font-size:1.05rem;font-weight:600;
  color:var(--ink);
  border-bottom:1px solid var(--line-soft);
}
.drawer-nav > ul > li > a:hover,
.drawer-nav > ul > li > a:focus{
  background:var(--lavender-soft);color:var(--royal);
}
.drawer-group-label{
  display:block;padding:14px 22px 6px;
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);font-weight:700;
}
.drawer-sub{padding-bottom:8px;border-bottom:1px solid var(--line-soft)}
.drawer-sub li a{
  display:block;padding:10px 22px 10px 36px;
  font-size:.95rem;color:var(--ink-2);font-weight:500;
}
.drawer-sub li a:hover{background:var(--lavender-soft);color:var(--royal)}
.drawer-foot{
  display:flex;flex-direction:column;gap:10px;
  padding:18px 22px;border-top:1px solid var(--line);
}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{
  position:relative;
  background:linear-gradient(135deg,var(--plum-deep) 0%,var(--plum) 45%,var(--royal) 100%);
  color:#fff;
  overflow:hidden;
  padding:120px 0 100px;
}
.hero::before{
  content:"";position:absolute;
  top:-200px;right:-200px;width:700px;height:700px;
  background:radial-gradient(circle,rgba(212,165,90,.22) 0%,transparent 60%);
  pointer-events:none;
}
.hero::after{
  content:"";position:absolute;
  bottom:-200px;left:-200px;width:600px;height:600px;
  background:radial-gradient(circle,rgba(247,212,220,.18) 0%,transparent 60%);
  pointer-events:none;
}
.hero-inner{position:relative;z-index:2;text-align:center}
.hero .eyebrow{color:var(--gold-bright);margin-bottom:20px}
.hero h1{
  color:#fff;
  font-size:clamp(2.6rem,7vw,5.4rem);
  margin-bottom:24px;
  letter-spacing:-0.01em;
}
.hero h1 .script{
  display:block;
  color:var(--gold-bright);
  font-size:clamp(2.4rem,6.5vw,5rem);
  line-height:1.1;
  font-weight:400;
  margin:-.1em 0;
}
.hero p.lead{
  color:rgba(255,255,255,.92);
  max-width:680px;margin:0 auto 36px;
  font-size:clamp(1.05rem,1.8vw,1.3rem);
}
.hero-cta{
  display:flex;flex-wrap:wrap;gap:14px;justify-content:center;
  margin-top:8px;
}
.hero-trust{
  margin-top:48px;
  display:flex;flex-wrap:wrap;gap:28px;justify-content:center;
  font-size:.85rem;
  color:rgba(255,255,255,.78);
  letter-spacing:.02em;
}
.hero-trust span{display:inline-flex;align-items:center;gap:8px}
.hero-trust svg{color:var(--gold-bright);flex-shrink:0}

/* Page hero (sub-pages) */
.page-hero{
  position:relative;
  background:linear-gradient(135deg,var(--plum) 0%,var(--royal) 100%);
  color:#fff;
  padding:80px 0 60px;
  overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;
  top:-100px;right:-100px;width:400px;height:400px;
  background:radial-gradient(circle,rgba(212,165,90,.22),transparent 60%);
  pointer-events:none;
}
.page-hero-inner{position:relative;z-index:2;text-align:center;max-width:780px;margin:0 auto}
.page-hero h1{color:#fff;margin-bottom:20px}
.page-hero p.lead{color:rgba(255,255,255,.88);margin:0 auto}
.crumbs{
  font-size:.8rem;color:rgba(255,255,255,.7);
  letter-spacing:.04em;margin-bottom:16px;
}
.crumbs a{color:var(--gold-bright);font-weight:500}
.crumbs .sep{margin:0 8px;color:rgba(255,255,255,.4)}

/* =========================================================================
   SPARKLES (decorative SVG)
   ========================================================================= */
.sparkle{
  position:absolute;
  pointer-events:none;
  opacity:0;
  animation:sparkle 4s var(--ease-out) infinite;
}
@keyframes sparkle{
  0%,100%{opacity:0;transform:scale(.5)}
  50%{opacity:.9;transform:scale(1)}
}
.sparkle--1{top:14%;left:8%;width:24px;animation-delay:0s}
.sparkle--2{top:62%;right:12%;width:18px;animation-delay:1.4s}
.sparkle--3{top:28%;right:24%;width:14px;animation-delay:2.6s}
.sparkle--4{bottom:18%;left:22%;width:20px;animation-delay:.8s}
.sparkle--5{top:48%;left:46%;width:12px;animation-delay:3.2s}
@media (prefers-reduced-motion: reduce){
  .sparkle{display:none}
}

/* =========================================================================
   CARDS
   ========================================================================= */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}

.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:28px;
  box-shadow:var(--shadow-sm);
  transition:transform 280ms var(--ease),box-shadow 280ms var(--ease);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card-icon{
  width:54px;height:54px;
  border-radius:var(--r-pill);
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--lavender-soft) 0%,var(--blush) 100%);
  color:var(--royal);
  margin-bottom:18px;
}
.card-icon svg{width:26px;height:26px}
.card h3{margin-bottom:8px}
.card p{font-size:.95rem;margin-bottom:0}

/* Character card */

/* Character-card city availability strip (links to Acuity per character per city) */
.char-avail{
  position:absolute;left:0;right:0;bottom:0;
  display:flex;flex-direction:column;gap:0;
  background:linear-gradient(180deg,transparent 0%,rgba(31,18,48,.85) 30%,rgba(31,18,48,.95) 100%);
  padding:60px 14px 14px;
  opacity:0;transform:translateY(8px);
  transition:opacity 240ms var(--ease),transform 240ms var(--ease);
  pointer-events:none;
  z-index:3;
}
.character-card:hover .char-avail,
.character-card:focus-within .char-avail{
  opacity:1;transform:none;pointer-events:auto;
}
.char-avail-city{
  display:block;
  padding:8px 12px;
  font-size:.78rem;font-weight:700;letter-spacing:.04em;
  color:#fff;background:rgba(212,165,90,.18);
  border:1px solid rgba(232,194,128,.4);
  border-radius:var(--r-pill);
  text-align:center;
  margin-bottom:5px;
  text-decoration:none;
  transition:background 140ms var(--ease),color 140ms var(--ease);
}
.char-avail-city:hover{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-bright) 100%);
  color:var(--plum-deep);
  border-color:transparent;
}
.char-avail--unavailable{
  font-size:.72rem;color:rgba(255,255,255,.85);text-align:center;
  background:rgba(31,18,48,.7);padding:10px 14px;border-radius:8px;
}

.character-card{
  background:var(--paper);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform 320ms var(--ease),box-shadow 320ms var(--ease);
  position:relative;
  cursor:pointer;
}
.character-card:hover,
.character-card:focus-within{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
}
.character-card-media{
  aspect-ratio:3/4;
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg,var(--lavender-soft),var(--blush));
}
.character-card-media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 600ms var(--ease);
}
.character-card:hover .character-card-media img{transform:scale(1.06)}
.character-card-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(31,18,48,.7) 100%);
}
.character-card-body{
  position:absolute;left:0;right:0;bottom:0;
  padding:22px 22px 24px;
  color:#fff;
  z-index:2;
}
.character-card-body h3{color:#fff;margin-bottom:2px;font-size:1.4rem}
.character-card-body p{color:rgba(255,255,255,.9);margin-bottom:0;font-size:.88rem;line-height:1.4}
.character-card-tag{
  display:inline-block;
  font-family:'Allura',cursive;font-size:1.5rem;
  color:var(--gold-bright);line-height:1;
  margin-bottom:4px;
}

/* Package card */
.package-card{
  background:var(--paper);
  border:1.5px solid var(--line);
  border-radius:var(--r-lg);
  padding:36px 28px;
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
  transition:transform 280ms var(--ease),box-shadow 280ms var(--ease),border-color 280ms var(--ease);
  position:relative;
}
.package-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--lavender)}
.package-card[data-featured="true"]{
  border-color:var(--gold);
  background:linear-gradient(180deg,var(--paper) 0%,var(--cream) 100%);
}
/* Selected state inside the booking flow — gold border + check, no "Most loved" badge */
.package-card[aria-pressed="true"]{
  border-color:var(--gold);
  box-shadow:0 0 0 1px rgba(212,165,90,.4),0 12px 32px rgba(212,165,90,.22);
  background:linear-gradient(180deg,var(--paper) 0%,var(--gold-soft) 100%);
}
.package-card[aria-pressed="true"]::after{
  content:"";
  position:absolute;top:14px;right:14px;
  width:30px;height:30px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-bright) 100%);
  box-shadow:0 4px 12px rgba(212,165,90,.4);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231f1230' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:62%;
}

.package-card[data-featured="true"]::before{
  content:"Most loved";
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-bright) 100%);
  color:var(--plum-deep);
  font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:6px 14px;border-radius:var(--r-pill);
  box-shadow:0 4px 12px rgba(212,165,90,.4);
}
.package-card h3{
  font-size:1.5rem;
  margin-bottom:4px;
  color:var(--plum-deep);
}
.package-card .package-tag{
  font-family:'Allura',cursive;
  font-size:1.5rem;color:var(--royal);
  display:block;line-height:1;margin-bottom:8px;
}
.package-card .package-price{
  font-size:2.6rem;
  font-family:'Cormorant Garamond',serif;
  font-weight:500;color:var(--plum);
  line-height:1;margin:14px 0 6px;
}
.package-card .package-price small{
  font-size:.95rem;color:var(--muted);font-family:'Nunito Sans',sans-serif;font-weight:500;
}
.package-card .package-duration{
  font-size:.85rem;color:var(--muted);
  letter-spacing:.04em;text-transform:uppercase;font-weight:600;
  margin-bottom:18px;
}
.package-card ul{
  list-style:none;
  border-top:1px solid var(--line);
  padding-top:18px;
  margin-bottom:24px;
  flex:1;
}
.package-card ul li{
  padding:8px 0 8px 30px;
  position:relative;
  font-size:.94rem;color:var(--ink-2);
  line-height:1.5;
}
.package-card ul li::before{
  content:"";
  position:absolute;left:0;top:12px;
  width:18px;height:18px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b3fa0' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/contain no-repeat;
}
.package-card .btn{margin-top:auto}

/* =========================================================================
   GALLERY
   ========================================================================= */
.gallery-filter{
  display:flex;flex-wrap:wrap;justify-content:center;gap:8px;
  margin-bottom:36px;
}
.gallery-filter button{
  padding:8px 18px;
  font-size:.85rem;font-weight:600;
  color:var(--ink-2);
  background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r-pill);
  transition:all 160ms var(--ease);
}
.gallery-filter button:hover{background:var(--lavender-soft);color:var(--royal);border-color:var(--lavender)}
.gallery-filter button[aria-pressed="true"]{
  background:linear-gradient(135deg,var(--royal),var(--royal-bright));
  color:#fff;border-color:transparent;
}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:12px;
}
.gallery-item{
  aspect-ratio:1/1;
  border-radius:var(--r);
  overflow:hidden;
  cursor:pointer;
  background:var(--lavender-soft);
  position:relative;
  transition:transform 280ms var(--ease);
}
.gallery-item:hover{transform:scale(1.02)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 600ms var(--ease)}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item[data-orient="portrait"]{aspect-ratio:3/4;grid-row:span 2}
@media (max-width:600px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .gallery-item[data-orient="portrait"]{grid-row:auto;aspect-ratio:1/1}
}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:100;
  background:rgba(15,8,24,.96);
  display:none;align-items:center;justify-content:center;
  padding:20px;
}
.lightbox[data-open="true"]{display:flex}
.lightbox img{max-width:96vw;max-height:88vh;border-radius:var(--r);box-shadow:var(--shadow-lg)}
.lightbox-close,.lightbox-nav{
  position:absolute;
  background:rgba(255,255,255,.1);backdrop-filter:blur(8px);
  border-radius:var(--r-pill);
  width:46px;height:46px;
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;
  transition:background 160ms var(--ease);
}
.lightbox-close:hover,.lightbox-nav:hover{background:rgba(255,255,255,.22)}
.lightbox-close{top:24px;right:24px}
.lightbox-nav{top:50%;transform:translateY(-50%)}
.lightbox-nav[data-dir="prev"]{left:24px}
.lightbox-nav[data-dir="next"]{right:24px}

/* =========================================================================
   FORMS
   ========================================================================= */
.field{margin-bottom:22px}
.field + .btn,.field + button[type="submit"]{margin-top:8px}
form > .btn,form > button[type="submit"]{margin-top:12px}
.field-label{
  display:block;
  font-size:.85rem;font-weight:700;
  letter-spacing:.02em;
  color:var(--plum);
  margin-bottom:6px;
}
.field-hint{
  display:block;
  font-size:.78rem;color:var(--muted);
  margin-top:6px;
}
.input,.textarea,.select{
  width:100%;
  padding:13px 16px;
  font-size:1rem;
  background:var(--paper);
  border:1.5px solid var(--line);
  border-radius:var(--r);
  color:var(--ink);
  transition:border-color 160ms var(--ease),box-shadow 160ms var(--ease);
}
.input:focus,.textarea:focus,.select:focus{
  outline:none;
  border-color:var(--gold);
  box-shadow:
    0 0 0 4px rgba(212,165,90,.18),
    0 0 18px rgba(232,194,128,.35);
  background:#fffefb;
}
.textarea{min-height:130px;resize:vertical;font-family:inherit;line-height:1.5;margin-bottom:4px}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237a6e87' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;background-size:18px;padding-right:44px}

.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.field-row{grid-template-columns:1fr}}

.chip-group{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  padding:9px 16px;
  font-size:.88rem;font-weight:600;
  background:var(--paper);
  border:1.5px solid var(--line);
  border-radius:var(--r-pill);
  color:var(--ink-2);
  transition:all 160ms var(--ease);
}
.chip:hover{border-color:var(--lavender);background:var(--lavender-soft);color:var(--royal)}
.chip[aria-pressed="true"]{
  background:linear-gradient(135deg,var(--royal),var(--royal-bright));
  color:#fff;border-color:transparent;
  box-shadow:0 4px 12px rgba(107,63,160,.3);
}

.form-message{
  padding:14px 18px;border-radius:var(--r);
  font-size:.92rem;font-weight:600;
  margin-bottom:18px;
}
.form-message[data-state="success"]{
  background:rgba(94,193,69,.1);color:#2e7d3a;border:1px solid rgba(94,193,69,.3);
}
.form-message[data-state="error"]{
  background:rgba(192,57,43,.1);color:#c0392b;border:1px solid rgba(192,57,43,.3);
}

/* =========================================================================
   BOOKING CALENDAR + FLOW
   ========================================================================= */
.booking-shell{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:32px;
  align-items:start;
}
@media (max-width:980px){
  .booking-shell{grid-template-columns:1fr}
}
.booking-main{
  background:var(--paper);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);
  padding:32px;
  border:1px solid var(--line);
}
.booking-summary{
  background:linear-gradient(180deg,var(--paper) 0%,var(--cream) 100%);
  border:1.5px solid var(--gold);
  border-radius:var(--r-lg);
  padding:28px;
  box-shadow:var(--shadow);
  position:sticky;top:96px;
}
.booking-step{display:none}
.booking-step[data-active="true"]{display:block}
.booking-step h3{margin-bottom:16px}
.booking-progress{
  display:flex;align-items:center;gap:6px;
  margin-bottom:32px;
  font-size:.78rem;
  letter-spacing:.04em;
}
.progress-step{
  display:flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:var(--r-pill);
  background:var(--lavender-soft);color:var(--muted);
  font-weight:700;
  white-space:nowrap;
}
.progress-step[data-active="true"]{background:var(--royal);color:#fff}
.progress-step[data-done="true"]{background:var(--gold-soft);color:var(--plum)}
.progress-sep{flex:1;height:2px;background:var(--lavender-soft);border-radius:2px;min-width:8px}

/* Calendar */
.calendar{
  border:1px solid var(--line);
  border-radius:var(--r);
  background:var(--paper);
  padding:18px;
  max-width:480px;
  width:100%;
  margin:0 auto;
  box-sizing:border-box;
}
.calendar-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}
.calendar-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.35rem;font-weight:600;color:var(--plum);
}
.calendar-nav{
  width:36px;height:36px;
  border-radius:var(--r-pill);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--plum);
  transition:background 160ms var(--ease);
}
.calendar-nav:hover{background:var(--lavender-soft)}
.calendar-nav:disabled{opacity:.3;cursor:not-allowed}
.calendar-grid{
  display:grid;grid-template-columns:repeat(7,minmax(0,1fr));
  gap:4px;
}
.calendar-dow{
  text-align:center;
  font-size:.65rem;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--muted);
  padding:6px 0 8px;
  min-width:0;
}
.calendar-day,
.calendar-grid > div:not(.calendar-dow){
  height:42px;
  max-height:42px;
  min-width:0;
  aspect-ratio:auto !important;
}
.calendar-day{
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;font-weight:500;
  border-radius:8px;
  background:var(--paper);
  color:var(--ink);
  border:1px solid transparent;
  cursor:pointer;
  transition:all 140ms var(--ease);
  position:relative;
}
.calendar-day:hover:not([disabled]){
  background:var(--lavender-soft);
  color:var(--royal);
}
.calendar-day[disabled]{
  color:var(--line);
  cursor:not-allowed;
  background:transparent;
}
.calendar-day[data-state="unavailable"]{
  color:var(--muted);text-decoration:line-through;background:var(--line-soft);
  cursor:not-allowed;
}
.calendar-day[data-state="available"]{
  background:rgba(94,193,69,.08);
  color:var(--plum);
}
.calendar-day[data-state="available"]::after{
  content:"";position:absolute;bottom:5px;left:50%;
  transform:translateX(-50%);
  width:4px;height:4px;border-radius:50%;
  background:#5ec145;
}
.calendar-day[aria-selected="true"]{
  background:linear-gradient(135deg,var(--royal),var(--royal-bright));
  color:#fff;
  font-weight:700;
  box-shadow:0 4px 12px rgba(107,63,160,.4);
}
.calendar-day[aria-selected="true"]::after{background:#fff}
.calendar-day[data-today="true"]{
  border-color:var(--gold);
}

/* Time slots */
.timeslot-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));
  gap:10px;
  margin-top:18px;
}
.timeslot{
  padding:12px 14px;
  font-size:.9rem;font-weight:600;
  background:var(--paper);
  border:1.5px solid var(--line);
  border-radius:var(--r);
  color:var(--ink);
  text-align:center;
  cursor:pointer;
  transition:all 160ms var(--ease);
}
.timeslot:hover{border-color:var(--lavender);background:var(--lavender-soft)}
.timeslot[aria-pressed="true"]{
  background:linear-gradient(135deg,var(--royal),var(--royal-bright));
  color:#fff;border-color:transparent;
  box-shadow:0 4px 12px rgba(107,63,160,.3);
}
.timeslot[disabled]{opacity:.4;cursor:not-allowed}

.summary-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:10px 0;
  border-bottom:1px dashed var(--line);
  font-size:.92rem;
}
.summary-row:last-of-type{border-bottom:none}
.summary-row span:first-child{color:var(--muted);font-weight:500}
.summary-row span:last-child{color:var(--plum);font-weight:600;text-align:right}
.summary-total{
  display:flex;justify-content:space-between;
  margin-top:14px;padding-top:14px;
  border-top:2px solid var(--gold);
  font-family:'Cormorant Garamond',serif;
  font-size:1.6rem;color:var(--plum-deep);
  font-weight:600;
}
.summary-deposit{
  background:var(--gold-soft);
  border-radius:var(--r);
  padding:12px 14px;
  margin-top:16px;
  font-size:.88rem;
  color:var(--plum-deep);
}
.summary-deposit strong{color:var(--plum-deep)}


/* Booking flow: character picker grid */
.character-pick-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(120px,1fr));
  gap:14px;
  margin-bottom:8px;
}
.char-pick{
  position:relative;
  display:flex;flex-direction:column;align-items:stretch;
  padding:0;background:var(--paper);
  border:1.5px solid var(--line);border-radius:var(--r);
  overflow:hidden;cursor:pointer;
  transition:transform 200ms var(--ease),border-color 200ms var(--ease),box-shadow 200ms var(--ease);
}
.char-pick:hover{transform:translateY(-3px);border-color:var(--lavender);box-shadow:var(--shadow-sm)}
.char-pick[aria-pressed="true"]{
  border-color:var(--gold);
  box-shadow:0 0 0 2px rgba(212,165,90,.35),var(--shadow);
  background:linear-gradient(180deg,var(--paper) 0%,var(--gold-soft) 100%);
}
.char-pick img{
  width:100%;aspect-ratio:3/4;object-fit:cover;display:block;
}
.char-pick-placeholder{
  display:flex;align-items:center;justify-content:center;
  aspect-ratio:3/4;
  background:linear-gradient(135deg,var(--lavender-soft),var(--blush));
  color:var(--plum-deep);font-family:'Cormorant Garamond',serif;
  font-size:1.1rem;font-weight:500;padding:8px;text-align:center;
}
.char-pick span{
  display:block;padding:8px 10px;
  font-size:.85rem;font-weight:600;color:var(--plum-deep);text-align:center;
  background:var(--paper);
}
.char-pick[aria-pressed="true"] span{background:transparent}

/* "+ Add a 2nd character" CTA + the 2nd-character picker panel.
   Visually distinct from the primary grid so customers understand it's
   an optional upgrade, not a required next step. */
.char-pick-add-cta{
  margin-top:24px;
  padding:18px 20px;
  background:linear-gradient(135deg,var(--lavender-soft) 0%,var(--gold-soft) 100%);
  border:1.5px dashed var(--gold);
  border-radius:var(--r);
  text-align:center;
}
.char-pick-add-cta button{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;
  background:var(--paper);
  border:1.5px solid var(--gold);
  border-radius:999px;
  font-family:inherit;font-size:.92rem;font-weight:600;
  color:var(--plum-deep);cursor:pointer;
  transition:background 180ms var(--ease),transform 180ms var(--ease);
}
.char-pick-add-cta button:hover{
  background:var(--gold-soft);transform:translateY(-1px);
}
.char-pick-add-cta button .plus{
  font-size:1.2rem;font-weight:400;line-height:1;color:var(--gold-bright);
}
.char-pick-add-cta .cta-help{
  margin:10px 0 0;font-size:.82rem;color:var(--muted);
}

.char-pick-second{
  margin-top:24px;
  padding:20px;
  background:var(--paper-mid,#fbf6ed);
  border:1.5px solid var(--gold);
  border-radius:var(--r);
}
.char-pick-second-head{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:14px;gap:12px;flex-wrap:wrap;
}
.char-pick-second-head h3{
  margin:0;font-size:1.05rem;color:var(--plum-deep);
  font-family:'Cormorant Garamond',serif;font-weight:600;
}
.char-pick-second-head .upcharge{
  font-family:inherit;font-size:.85rem;font-weight:600;color:var(--gold-bright);
  margin-left:6px;
}
.char-pick-second-head button{
  background:none;border:none;color:var(--muted);
  font-size:.82rem;cursor:pointer;text-decoration:underline;
  padding:4px 6px;
}
.char-pick-second-head button:hover{color:var(--plum-deep)}

/* =========================================================================
   TESTIMONIALS
   ========================================================================= */
.testimonial{
  background:var(--paper);
  border-radius:var(--r-lg);
  padding:32px;
  box-shadow:var(--shadow-sm);
  border-top:4px solid var(--gold);
  position:relative;
}
.testimonial::before{
  content:"\201C";
  font-family:'Cormorant Garamond',serif;
  font-size:7rem;line-height:.6;
  color:var(--lavender-soft);
  position:absolute;top:18px;right:24px;
  pointer-events:none;
}
.testimonial blockquote{
  font-family:'Cormorant Garamond',serif;
  font-size:1.2rem;
  font-style:italic;
  font-weight:500;
  line-height:1.5;
  color:var(--plum-deep);
  margin-bottom:18px;
  position:relative;z-index:2;
}
.testimonial cite{
  display:flex;align-items:center;gap:12px;
  font-style:normal;font-size:.88rem;
  color:var(--muted);
}
.testimonial-author{
  display:flex;flex-direction:column;line-height:1.3;
}
.testimonial-author strong{color:var(--plum);font-weight:700}
.testimonial-stars{
  display:inline-flex;gap:1px;color:var(--gold);
  font-size:1.1rem;letter-spacing:1px;
}

/* =========================================================================
   LOCATION CARDS
   ========================================================================= */
.location-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;
}
.location-card{
  background:var(--paper);
  border-radius:var(--r-lg);
  padding:28px 24px;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--line);
  text-align:center;
  transition:all 280ms var(--ease);
  display:flex;flex-direction:column;
  position:relative;
  overflow:hidden;
}
.location-card::before{
  content:"";position:absolute;
  top:-40px;right:-40px;width:120px;height:120px;
  background:radial-gradient(circle,var(--lavender-soft),transparent 70%);
  pointer-events:none;
  transition:transform 400ms var(--ease);
}
.location-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
  border-color:var(--lavender);
}
.location-card:hover::before{transform:scale(1.3)}
.location-card h3{
  font-size:1.5rem;color:var(--plum-deep);
  margin-bottom:6px;
  position:relative;z-index:2;
}
.location-card p{
  font-size:.9rem;color:var(--muted);
  margin-bottom:18px;
  position:relative;z-index:2;
}
.location-card .btn-sm{align-self:center;position:relative;z-index:2}

/* =========================================================================
   FAQ
   ========================================================================= */
.faq-item{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--r);
  margin-bottom:10px;
  overflow:hidden;
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:20px 24px;
  font-family:'Cormorant Garamond',serif;
  font-size:1.15rem;font-weight:600;
  color:var(--plum-deep);
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  transition:background 140ms var(--ease);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"";
  width:24px;height:24px;flex-shrink:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b3fa0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") center/contain no-repeat;
  transition:transform 200ms var(--ease);
}
.faq-item[open] summary::after{transform:rotate(180deg)}
.faq-item summary:hover{background:var(--lavender-soft)}
.faq-item-body{padding:0 24px 22px;color:var(--ink-2);line-height:1.65}
.faq-item-body p:last-child{margin-bottom:0}

/* =========================================================================
   CTA STRIP
   ========================================================================= */
.cta-strip{
  background:linear-gradient(135deg,var(--plum-deep) 0%,var(--royal) 100%);
  color:#fff;
  padding:64px 0;
  text-align:center;
  position:relative;overflow:hidden;
}
.cta-strip::before{
  content:"";position:absolute;
  top:-100px;right:-100px;width:300px;height:300px;
  background:radial-gradient(circle,rgba(212,165,90,.22),transparent 60%);
}
.cta-strip h2{color:#fff;font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:14px}
.cta-strip p{color:rgba(255,255,255,.88);max-width:580px;margin:0 auto 28px}
.cta-strip .hero-cta{justify-content:center}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{
  background:var(--plum-deep);
  color:rgba(255,255,255,.78);
  padding:64px 0 28px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:40px;
  margin-bottom:48px;
}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .brand{color:#fff;font-size:1.8rem;margin-bottom:14px;display:inline-flex}
.footer-brand .brand .script{color:var(--gold-bright)}
.footer-brand p{color:rgba(255,255,255,.75);font-size:.92rem;line-height:1.55;max-width:340px}

/* Composed footer logo (crown + cursive + tagline, all baked into one PNG). */
.footer-logo-link{
  display:inline-block;margin-bottom:16px;
  transition:opacity 200ms var(--ease);
}
.footer-logo-link:hover{opacity:.85}
.footer-logo{
  width:240px;max-width:100%;height:auto;display:block;
}
.footer-col h4{color:#fff;font-family:'Nunito Sans',sans-serif;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;font-weight:700}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{color:rgba(255,255,255,.78);font-weight:500;font-size:.92rem;transition:color 140ms var(--ease)}
.footer-col a:hover{color:var(--gold-bright)}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social a{
  width:38px;height:38px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.08);
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;
  transition:all 160ms var(--ease);
}
.footer-social a:hover{background:var(--gold);color:var(--plum-deep);transform:translateY(-2px)}
.footer-disclaimer{
  border-top:1px solid rgba(255,255,255,.12);
  padding:18px 0 0;
  margin-bottom:18px;
  font-size:.78rem;
  color:rgba(255,255,255,.78);
  text-align:center;
  line-height:1.55;
  max-width:760px;
  margin-left:auto;margin-right:auto;
}
.footer-disclaimer a{color:var(--gold-bright);text-decoration:underline;font-weight:600}
.footer-disclaimer a:hover{color:#fff}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  flex-wrap:wrap;
  font-size:.82rem;
  color:rgba(255,255,255,.55);
}
.footer-bottom a{color:rgba(255,255,255,.75);font-weight:500}
.footer-bottom a:hover{color:var(--gold-bright)}
/* Plain Black signature mark: pulsing green icon, swaps the text link */
.footer-pb{
  position:relative;
  display:inline-block;
  width:32px;height:32px;
  flex-shrink:0;
  transition:transform 160ms var(--ease);
}
.footer-pb:hover{transform:scale(1.08)}
.footer-pb:focus-visible{
  outline:2px solid var(--gold-bright);
  outline-offset:4px;
  border-radius:4px;
}
.footer-pb-icon{
  position:absolute;inset:0;
  background-color:var(--gold-bright);
  -webkit-mask:url('../assets/badges/plainblack-icon.webp') center/contain no-repeat;
          mask:url('../assets/badges/plainblack-icon.webp') center/contain no-repeat;
  -webkit-mask-size:82%;
          mask-size:82%;
}
.footer-pb-pulse{
  opacity:.7;
  animation:pbPulse 2.6s ease-out infinite;
  will-change:transform,opacity;
  transform-origin:center;
}
@keyframes pbPulse{
  0%  {transform:scale(1);    opacity:.7}
  70% {transform:scale(1.55); opacity:0}
  100%{transform:scale(1.55); opacity:0}
}
@media (prefers-reduced-motion: reduce){
  .footer-pb-pulse{animation:none}
}

/* =========================================================================
   UTILITY + ANIMATION
   ========================================================================= */
.text-center{text-align:center}
.text-balance{text-wrap:balance}
.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}
.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}

.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity 700ms var(--ease-out),transform 700ms var(--ease-out);
}
.reveal.is-in{opacity:1;transform:none}
.reveal-delay-1{transition-delay:80ms}
.reveal-delay-2{transition-delay:160ms}
.reveal-delay-3{transition-delay:240ms}
.reveal-delay-4{transition-delay:320ms}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{opacity:1;transform:none}
}

/* Inline section dividers */
.divider-ornate{
  display:flex;align-items:center;justify-content:center;
  margin:28px auto;color:var(--gold);max-width:200px;
}
.divider-ornate::before,
.divider-ornate::after{
  content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold) 50%,transparent);
}
.divider-ornate svg{margin:0 12px;width:18px;height:18px;flex-shrink:0}

/* Two-up split */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;align-items:center;
}
@media (max-width:880px){.split{grid-template-columns:1fr;gap:36px}}
.split-media{
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  aspect-ratio:4/5;
  background:linear-gradient(135deg,var(--lavender-soft),var(--blush));
}
.split-media img{width:100%;height:100%;object-fit:cover}

/* Marquee strip (trust badges / city names) */
.marquee{
  background:var(--cream-deep);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:18px 0;
  overflow:hidden;
}
.marquee-track{
  display:flex;gap:48px;align-items:center;
  font-family:'Cormorant Garamond',serif;
  font-size:1.2rem;
  color:var(--plum);
  white-space:nowrap;
  animation:marquee 36s linear infinite;
}
.marquee-track svg{flex-shrink:0;color:var(--gold)}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@media (prefers-reduced-motion: reduce){
  .marquee-track{animation:none}
}

/* Polaroid divider strips — scattered, slow-moving photo bands between
   home page sections. Pure CSS marquee, no JS. Each photo is wrapped in
   a classic polaroid frame (thick white border, thicker bottom, slight
   rotation, soft drop shadow). nth-child rotations give the strip an
   organic "scattered on the floor" feel. */
/* Native horizontal scroll + JS rAF for the auto-advance, NOT a CSS
   transform animation. Same pattern as the cast carousel. The
   transform-based version kept dropping the layer under iOS Safari
   memory pressure -- polaroids would vanish mid-scroll. */
.polaroid-strip{
  overflow-x:scroll;
  overflow-y:hidden;
  scrollbar-width:none;
  -ms-overflow-style:none;
  -webkit-overflow-scrolling:touch;
  padding:48px 0;
  background:linear-gradient(180deg, var(--cream) 0%, var(--blush) 50%, var(--cream) 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  min-height:340px;
}
.polaroid-strip::-webkit-scrollbar{display:none}
.polaroid-track{
  display:flex;gap:36px;align-items:center;
  width:max-content;
  padding:24px 0;
}
.polaroid{
  flex:0 0 200px;
  background:#fff;
  padding:14px 14px 44px;
  margin:0;
  box-shadow:0 8px 22px rgba(31,18,48,.18), 0 2px 4px rgba(31,18,48,.10);
  border-radius:3px;
  transform:rotate(-2deg);
  transition:transform 240ms var(--ease);
}
.polaroid:nth-child(2n){transform:rotate(2.5deg)}
.polaroid:nth-child(3n){transform:rotate(-3.5deg) translateY(8px)}
.polaroid:nth-child(4n){transform:rotate(1.5deg) translateY(-10px)}
.polaroid:nth-child(5n){transform:rotate(-1deg)}
.polaroid:nth-child(7n){transform:rotate(3deg) translateY(4px)}
.polaroid img{
  width:100%;aspect-ratio:1/1;object-fit:cover;display:block;
  background:var(--cream);
}
@media (prefers-reduced-motion: reduce){
  .polaroid-track--left,
  .polaroid-track--right{animation:none}
}
@media (max-width:640px){
  .polaroid{flex:0 0 140px;padding:10px 10px 32px}
  .polaroid-strip{padding:32px 0;min-height:240px}
  .polaroid-track{gap:24px}
}

/* Cast carousel — infinite-scroll horizontal band on the home page.
   Mixes auto-scroll (rAF in JS) with native overflow-x scroll so touch
   swipe + mouse wheel "just work", plus click-and-drag on desktop. */
.cast-section{padding-bottom:80px}
.cast-carousel{
  overflow-x:scroll;
  overflow-y:hidden;
  scrollbar-width:none;          /* Firefox */
  -ms-overflow-style:none;       /* IE/Edge */
  padding:24px 0;
  cursor:grab;
  user-select:none;
  -webkit-user-select:none;
  -webkit-overflow-scrolling:touch;
  /* Fade edges so cards don't crash against the viewport boundary */
  mask-image:linear-gradient(90deg, transparent 0, #000 60px, #000 calc(100% - 60px), transparent 100%);
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 60px, #000 calc(100% - 60px), transparent 100%);
}
.cast-carousel::-webkit-scrollbar{display:none}
.cast-carousel.is-grabbing{cursor:grabbing}
.cast-track{
  display:flex;gap:16px;
  width:max-content;
  padding:8px 60px;              /* matches the mask fade so first/last card has room */
}
.cast-card{
  flex:0 0 260px;
  display:flex;flex-direction:column;
  background:var(--paper);
  border:1.5px solid var(--line);
  border-radius:var(--r);
  overflow:hidden;
  text-decoration:none;
  transition:transform 200ms var(--ease),border-color 200ms var(--ease),box-shadow 200ms var(--ease);
  -webkit-user-drag:none;
}
.cast-card:hover{
  transform:translateY(-4px);
  border-color:var(--lavender);
  box-shadow:var(--shadow-sm);
}
.cast-card img{
  width:100%;aspect-ratio:3/4;object-fit:cover;display:block;
  -webkit-user-drag:none;pointer-events:none;
}
.cast-name{
  display:block;padding:10px 12px;
  text-align:center;
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;font-weight:600;
  color:var(--plum-deep);
}
@media (max-width:640px){
  .cast-card{flex:0 0 200px}
  .cast-name{font-size:.95rem;padding:8px 10px}
}

/* AI-assist launcher placeholder (we'll wire later if needed) */
.ai-launcher{display:none}

/* Sharing module */
.share-block{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;
  background:var(--lavender-soft);
  border-radius:var(--r-pill);
  font-size:.88rem;color:var(--plum);
  font-weight:600;
}
.share-block svg{color:var(--royal);flex-shrink:0}
.share-buttons{display:flex;gap:8px;margin-left:auto}
.share-buttons a{
  width:34px;height:34px;border-radius:var(--r-pill);
  background:var(--paper);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--royal);
  transition:all 140ms var(--ease);
}
.share-buttons a:hover{background:var(--royal);color:#fff;transform:scale(1.08)}

/* Tag / pill */
.pill{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 16px;
  min-height:44px;
  border-radius:var(--r-pill);
  background:var(--lavender-soft);color:var(--royal);
  font-size:.78rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  text-align:center;
  transition:transform 200ms var(--ease),background 200ms var(--ease),box-shadow 200ms var(--ease);
  cursor:default;
  border:1px solid transparent;
}
.pill:hover{
  transform:translateY(-2px) scale(1.02);
  background:linear-gradient(135deg,var(--lavender-soft) 0%,var(--blush) 100%);
  box-shadow:0 6px 16px rgba(107,63,160,.18);
  border-color:rgba(107,63,160,.18);
}
.pill-gold{background:var(--gold-soft);color:var(--plum-deep)}
.pill-gold:hover{background:linear-gradient(135deg,var(--gold-soft) 0%,var(--gold-bright) 100%);box-shadow:0 6px 16px rgba(212,165,90,.28)}

/* =========================================================================
   VISUAL FLOURISH: shimmer, float, glow, decorated sections
   ========================================================================= */

/* Animated gold shimmer on price text */
.shimmer{
  background:linear-gradient(90deg,var(--plum-deep) 0%,var(--royal) 40%,var(--gold) 50%,var(--royal) 60%,var(--plum-deep) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;
          background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:shimmerSweep 5.5s linear infinite;
}
@keyframes shimmerSweep{
  0%   {background-position:0% center}
  100% {background-position:200% center}
}
@media (prefers-reduced-motion: reduce){
  .shimmer{animation:none}
}

/* Slow floating drift for sparkles */
@keyframes floatY{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%    {transform:translateY(-14px) rotate(8deg)}
}
.float-y{animation:floatY 6s ease-in-out infinite}
.float-y-2{animation:floatY 8s ease-in-out infinite;animation-delay:1.4s}
.float-y-3{animation:floatY 7s ease-in-out infinite;animation-delay:2.6s}
@media (prefers-reduced-motion: reduce){
  .float-y,.float-y-2,.float-y-3{animation:none}
}

/* Decorated section: soft glowing blobs in corners */
.section-decorated{position:relative;overflow:hidden}
.section-decorated::before{
  content:"";position:absolute;
  top:-180px;left:-180px;width:520px;height:520px;
  background:radial-gradient(circle,rgba(181,153,212,.25) 0%,transparent 65%);
  pointer-events:none;
}
.section-decorated::after{
  content:"";position:absolute;
  bottom:-220px;right:-160px;width:540px;height:540px;
  background:radial-gradient(circle,rgba(247,212,220,.32) 0%,transparent 60%);
  pointer-events:none;
}
.section-decorated > *{position:relative;z-index:1}

/* Gold-edge frame for hero-style emphasis on minute-grid */
.minute-grid--ornate{
  border:1px solid var(--gold);
  box-shadow:0 0 0 1px rgba(212,165,90,.18),0 18px 40px rgba(31,18,48,.08);
}

/* Section sparkle layer (decorative SVGs sprinkled across a section) */
.sparkle-layer{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.sparkle-layer svg{position:absolute}
.sparkle-layer > *{animation:sparkle 4.8s var(--ease-out) infinite}

/* Gentle pulse halo for spotlight cards */
@keyframes glowPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(212,165,90,.0),0 12px 32px rgba(31,18,48,.16)}
  50%    {box-shadow:0 0 0 6px rgba(212,165,90,.18),0 18px 44px rgba(31,18,48,.22)}
}
.glow-pulse{animation:glowPulse 4.2s ease-in-out infinite}
@media (prefers-reduced-motion: reduce){
  .glow-pulse{animation:none}
}

/* Tilt-on-hover for cards that should feel a little playful */
.tilt{
  transition:transform 320ms var(--ease),box-shadow 320ms var(--ease);
  transform-origin:center;
}
.tilt:hover{
  transform:translateY(-6px) rotate(-.4deg);
  box-shadow:var(--shadow);
}

/* Marquee accent for section heads */
.heading-accent{
  display:inline-flex;align-items:center;gap:14px;
  color:var(--gold);
}
.heading-accent::before,.heading-accent::after{
  content:"";display:block;height:1px;width:48px;
  background:linear-gradient(90deg,transparent,var(--gold) 50%,transparent);
}

/* Price shimmer: applied to every $ price display across the site */
.package-card .package-price,
.pkg-meta .price,
.compare-price,
.shimmer-price{
  background:linear-gradient(90deg,var(--plum-deep) 0%,var(--royal) 30%,var(--gold-bright) 50%,var(--royal) 70%,var(--plum-deep) 100%);
  background-size:240% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:shimmerSweep 5.5s linear infinite;
}
.package-card .package-price small,
.pkg-meta .price small{
  -webkit-text-fill-color:var(--muted);
  background:none;
  animation:none;
}
@media (prefers-reduced-motion: reduce){
  .package-card .package-price,.pkg-meta .price,.compare-price,.shimmer-price{animation:none}
}

/* Visually hidden but readable to AT */
.sr-only{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* =========================================================================
   ENCHANTED PHOTO FRAME (about page: Serena's portrait)
   ========================================================================= */
.photo-frame{
  position:relative;
  border-radius:var(--r-lg);
  overflow:visible;
  isolation:isolate;
}
.photo-frame > img,
.photo-frame .split-media{
  display:block;width:100%;
  border-radius:var(--r-lg);
  overflow:hidden;
}
.photo-frame--enchanted{
  padding:14px;
  background:
    linear-gradient(135deg,rgba(212,165,90,.7) 0%,rgba(232,194,128,.4) 35%,rgba(247,212,220,.5) 65%,rgba(181,153,212,.5) 100%);
  border-radius:calc(var(--r-lg) + 6px);
  box-shadow:
    0 0 0 1px rgba(212,165,90,.4),
    0 24px 60px rgba(31,18,48,.18),
    0 0 80px rgba(232,194,128,.18);
}
.photo-frame--enchanted::before,
.photo-frame--enchanted::after{
  content:"";
  position:absolute;
  inset:-14px;
  border-radius:inherit;
  pointer-events:none;
  z-index:-1;
}
.photo-frame--enchanted::before{
  background:radial-gradient(ellipse at 30% 20%,rgba(232,194,128,.5),transparent 60%),
             radial-gradient(ellipse at 70% 90%,rgba(247,212,220,.45),transparent 60%);
  filter:blur(20px);
  animation:framePulse 5.4s ease-in-out infinite;
}
.photo-frame--enchanted::after{
  background:conic-gradient(from 180deg at 50% 50%,
    rgba(212,165,90,.45),rgba(181,153,212,.30),rgba(247,212,220,.45),rgba(212,165,90,.45));
  filter:blur(28px);
  opacity:.45;
  animation:frameRotate 24s linear infinite;
}
@keyframes framePulse{
  0%,100%{opacity:.7;transform:scale(.98)}
  50%    {opacity:1;  transform:scale(1.04)}
}
@keyframes frameRotate{
  to{transform:rotate(360deg)}
}
.photo-frame--enchanted .photo-inner{
  position:relative;
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.4),0 8px 24px rgba(31,18,48,.16);
}
.photo-frame--enchanted .photo-inner img{
  display:block;width:100%;height:auto;
  transition:transform 8s var(--ease-out);
}
.photo-frame--enchanted:hover .photo-inner img{
  transform:scale(1.05) translateY(-6px);
}

/* Corner sparkles on the enchanted frame */
.photo-frame--enchanted .frame-sparkle{
  position:absolute;
  width:28px;height:28px;
  pointer-events:none;
  filter:drop-shadow(0 0 10px rgba(232,194,128,.8));
  animation:sparkle 4s ease-in-out infinite;
  z-index:2;
}
.photo-frame--enchanted .frame-sparkle--tl{top:-14px;left:-14px;animation-delay:0s}
.photo-frame--enchanted .frame-sparkle--tr{top:-8px;right:-12px;animation-delay:1.4s;width:22px;height:22px}
.photo-frame--enchanted .frame-sparkle--br{bottom:-12px;right:-14px;animation-delay:2.6s}
.photo-frame--enchanted .frame-sparkle--bl{bottom:-8px;left:-10px;animation-delay:.8s;width:20px;height:20px}

@media (prefers-reduced-motion: reduce){
  .photo-frame--enchanted::before,
  .photo-frame--enchanted::after,
  .photo-frame--enchanted .frame-sparkle,
  .photo-frame--enchanted .photo-inner img{
    animation:none;
  }
}

/* Stat cards on the about page: hover glow */
.section-cream .card{
  transition:transform 280ms var(--ease),box-shadow 280ms var(--ease),border-color 280ms var(--ease);
}
.section-cream .card:hover{
  transform:translateY(-4px);
  border-color:var(--gold);
  box-shadow:0 12px 32px rgba(212,165,90,.22),0 0 0 1px rgba(212,165,90,.3);
}
.counter{
  background:linear-gradient(120deg,var(--royal) 0%,var(--gold-bright) 50%,var(--royal-bright) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:shimmerSweep 6s linear infinite;
}
@media (prefers-reduced-motion: reduce){
  .counter{animation:none}
}

/* Contact page: form + "other ways" card side-by-side, stack with comfortable gap */
.contact-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:48px;
  align-items:start;
}
@media (max-width: 880px){
  .contact-layout{
    grid-template-columns:1fr;
    gap:56px;
  }
}

/* Page transition mask for booking step changes */
.fade-swap{animation:fade-in 320ms var(--ease-out)}
@keyframes fade-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* =========================================================================
   DELIGHT LAYER: magic dust, scroll progress, cursor trail, nav underline,
                  button shimmer, Ken Burns, wave dividers, confetti canvas
   ========================================================================= */

/* =========================================================================
   MAX GLOW-UP: animated checkmarks, wave dividers, ornaments,
                scroll-staggered grid reveals, eyebrow shimmer
   ========================================================================= */

/* Animated checkmark on inclusion lists — draws in on scroll into view */
.package-card ul li,
.section ul.fancy-list li{
  animation:none;
}
.package-card.is-in ul li::before,
.is-in ul.fancy-list li::before,
.package-card.in-view ul li::before{
  animation:checkDraw 600ms var(--ease-out) both;
}
@keyframes checkDraw{
  0%   {transform:scale(.2) rotate(-30deg);opacity:0}
  60%  {transform:scale(1.2) rotate(0deg);opacity:1}
  100% {transform:scale(1) rotate(0deg);opacity:1}
}
.package-card ul li::before{
  transform-origin:center;
}
.package-card.is-in ul li:nth-child(1)::before{animation-delay:80ms}
.package-card.is-in ul li:nth-child(2)::before{animation-delay:160ms}
.package-card.is-in ul li:nth-child(3)::before{animation-delay:240ms}
.package-card.is-in ul li:nth-child(4)::before{animation-delay:320ms}
.package-card.is-in ul li:nth-child(5)::before{animation-delay:400ms}
.package-card.is-in ul li:nth-child(6)::before{animation-delay:480ms}
.package-card.is-in ul li:nth-child(7)::before{animation-delay:560ms}
.package-card.is-in ul li:nth-child(8)::before{animation-delay:640ms}

/* Stagger children when a .grid-stagger enters view */
.grid-stagger > *{
  opacity:0;
  transform:translateY(24px);
  transition:opacity 700ms var(--ease-out),transform 700ms var(--ease-out);
}
.grid-stagger.is-in > *{
  opacity:1;transform:none;
}
.grid-stagger.is-in > *:nth-child(1){transition-delay:0ms}
.grid-stagger.is-in > *:nth-child(2){transition-delay:80ms}
.grid-stagger.is-in > *:nth-child(3){transition-delay:160ms}
.grid-stagger.is-in > *:nth-child(4){transition-delay:240ms}
.grid-stagger.is-in > *:nth-child(5){transition-delay:320ms}
.grid-stagger.is-in > *:nth-child(6){transition-delay:400ms}
.grid-stagger.is-in > *:nth-child(7){transition-delay:480ms}
.grid-stagger.is-in > *:nth-child(8){transition-delay:560ms}
.grid-stagger.is-in > *:nth-child(9){transition-delay:640ms}
.grid-stagger.is-in > *:nth-child(10){transition-delay:720ms}
.grid-stagger.is-in > *:nth-child(11){transition-delay:800ms}
.grid-stagger.is-in > *:nth-child(12){transition-delay:880ms}
@media (prefers-reduced-motion: reduce){
  .grid-stagger > *{opacity:1;transform:none;transition:none}
}

/* Eyebrow with subtle shimmering left line */
.eyebrow.eyebrow--lined{
  display:inline-flex;align-items:center;gap:14px;
}
.eyebrow.eyebrow--lined::before{
  content:"";display:block;height:1.5px;width:36px;
  background:linear-gradient(90deg,transparent,var(--gold) 80%);
  border-radius:2px;
}
.eyebrow.eyebrow--lined::after{
  content:"";display:block;height:1.5px;width:36px;
  background:linear-gradient(90deg,var(--gold) 20%,transparent);
  border-radius:2px;
}

/* SVG wave divider helper (use as <div class="wave-divider"><svg>...</svg></div>) */
.wave-divider--gold path,
.wave-divider--lav path{
  animation:waveBreathe 6s ease-in-out infinite;
}
@keyframes waveBreathe{
  0%,100%{opacity:.7}
  50%    {opacity:1}
}

/* Section ornament: floating SVG that pulses subtly */
.section-ornament{
  position:absolute;
  pointer-events:none;
  opacity:.16;
  z-index:0;
  animation:ornamentFloat 12s ease-in-out infinite;
}
@keyframes ornamentFloat{
  0%,100%{transform:translateY(0) rotate(-2deg)}
  50%    {transform:translateY(-18px) rotate(2deg)}
}
@media (prefers-reduced-motion: reduce){
  .section-ornament{animation:none}
}

/* Booking flow: little win when a date is picked or a slot selected */
.calendar-day[aria-selected="true"]::before{
  content:"";position:absolute;inset:-2px;
  border-radius:10px;
  box-shadow:0 0 0 0 rgba(212,165,90,.5);
  animation:pickPulse 700ms ease-out;
  pointer-events:none;
}
@keyframes pickPulse{
  0%   {box-shadow:0 0 0 0 rgba(212,165,90,.6)}
  100% {box-shadow:0 0 0 12px rgba(212,165,90,0)}
}
.timeslot[aria-pressed="true"]{
  position:relative;
}
.timeslot[aria-pressed="true"]::after{
  content:"";position:absolute;inset:-3px;
  border-radius:calc(var(--r) + 3px);
  box-shadow:0 0 0 0 rgba(107,63,160,.5);
  animation:pickPulse 700ms ease-out;
  pointer-events:none;
}

/* Form group focus halo */
.field:focus-within .field-label{
  color:var(--royal);
}

/* Scroll progress bar (fixed at top of viewport) */
.scroll-progress{
  position:fixed;top:0;left:0;
  height:3px;width:100%;
  background:linear-gradient(90deg,var(--royal) 0%,var(--gold-bright) 50%,var(--royal) 100%);
  transform-origin:left center;
  transform:scaleX(0);
  z-index:200;
  pointer-events:none;
  box-shadow:0 0 12px rgba(212,165,90,.5);
}
@media (prefers-reduced-motion: reduce){
  .scroll-progress{transition:none}
}

/* Touch tap feedback — clean, fast, never blocks navigation */
@media (hover: none) and (pointer: coarse){
  .character-card:active,
  .package-card:active,
  .card:active,
  .location-card:active,
  .testimonial:active{
    transform:scale(.98);
    transition:transform 90ms var(--ease-out);
  }
}

/* Card click-burst (DESKTOP/mouse only) */
.is-tapped{
  animation:cardTap 700ms var(--ease-out);
}
@keyframes cardTap{
  0%   {transform:scale(1)}
  18%  {transform:scale(.97)}
  45%  {transform:scale(1.04);box-shadow:0 18px 44px rgba(212,165,90,.4),0 0 0 4px rgba(232,194,128,.25)}
  100% {transform:scale(1)}
}
.character-card.is-tapped{animation-name:characterCardTap}
@keyframes characterCardTap{
  0%   {transform:translateY(0) scale(1)}
  18%  {transform:translateY(-2px) scale(.97)}
  45%  {transform:translateY(-10px) scale(1.04);box-shadow:0 28px 60px rgba(31,18,48,.32),0 0 0 4px rgba(232,194,128,.3)}
  100% {transform:translateY(-6px) scale(1)}
}
.card-burst-spark{
  position:absolute;
  pointer-events:none;
  z-index:5;
  transform:translate(-50%,-50%);
  opacity:0;
  animation:cardBurstFly 900ms cubic-bezier(.2,.7,.3,1) forwards;
  filter:drop-shadow(0 0 6px rgba(232,194,128,.7));
}
.card-burst-spark svg{width:100%;height:100%}
@keyframes cardBurstFly{
  0%   {opacity:0;transform:translate(-50%,-50%) scale(.2) rotate(0deg)}
  30%  {opacity:1}
  100% {
    opacity:0;
    transform:translate(calc(-50% + var(--tx,0)),calc(-50% + var(--ty,0))) scale(1) rotate(180deg);
  }
}
@media (prefers-reduced-motion: reduce){
  .is-tapped,.card-burst-spark{animation:none}
}

/* Cursor sparkle trail (spawned by effects.js) */
.sparkle-trail{
  position:absolute;
  pointer-events:none;
  z-index:2;
  animation:sparkleTrailFade 1100ms ease-out forwards;
  transform:translate(-50%, -50%);
  filter:drop-shadow(0 0 6px rgba(232,194,128,.6));
}
.sparkle-trail svg{width:100%;height:100%}
@keyframes sparkleTrailFade{
  0%   {opacity:0;transform:translate(-50%, -50%) scale(.2) rotate(0deg)}
  40%  {opacity:1;transform:translate(-50%, -50%) scale(1)   rotate(60deg)}
  100% {opacity:0;transform:translate(-50%, -60%) scale(.6)  rotate(180deg)}
}

/* Magic dust particles (CSS-only, ambient background in hero) */
.magic-dust{
  position:absolute;inset:0;
  pointer-events:none;
  overflow:hidden;
  z-index:1;
}
.magic-dust .dust{
  position:absolute;
  bottom:-30px;
  width:6px;height:6px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #ffe8a8, rgba(232,194,128,0) 70%);
  opacity:0;
  animation:dustRise 12s linear infinite;
}
@keyframes dustRise{
  0%   {opacity:0;transform:translateY(0) translateX(0)}
  10%  {opacity:.85}
  90%  {opacity:.85}
  100% {opacity:0;transform:translateY(-120vh) translateX(40px)}
}
.magic-dust .dust:nth-child(1){left:6%;animation-delay:0s;animation-duration:11s;width:4px;height:4px}
.magic-dust .dust:nth-child(2){left:14%;animation-delay:2s;animation-duration:14s}
.magic-dust .dust:nth-child(3){left:22%;animation-delay:4s;animation-duration:10s;background:radial-gradient(circle at 30% 30%, #f7d4dc, rgba(247,212,220,0) 70%)}
.magic-dust .dust:nth-child(4){left:31%;animation-delay:1s;animation-duration:13s;width:5px;height:5px}
.magic-dust .dust:nth-child(5){left:42%;animation-delay:5s;animation-duration:12s;background:radial-gradient(circle at 30% 30%, #d4b3ff, rgba(181,153,212,0) 70%)}
.magic-dust .dust:nth-child(6){left:54%;animation-delay:3s;animation-duration:15s;width:7px;height:7px}
.magic-dust .dust:nth-child(7){left:64%;animation-delay:6s;animation-duration:11s}
.magic-dust .dust:nth-child(8){left:73%;animation-delay:2s;animation-duration:13s;background:radial-gradient(circle at 30% 30%, #f7d4dc, rgba(247,212,220,0) 70%)}
.magic-dust .dust:nth-child(9){left:82%;animation-delay:4s;animation-duration:12s;width:4px;height:4px}
.magic-dust .dust:nth-child(10){left:91%;animation-delay:1s;animation-duration:14s}
.magic-dust .dust:nth-child(11){left:78%;animation-delay:7s;animation-duration:10s;background:radial-gradient(circle at 30% 30%, #d4b3ff, rgba(181,153,212,0) 70%)}
.magic-dust .dust:nth-child(12){left:36%;animation-delay:8s;animation-duration:13s}
@media (prefers-reduced-motion: reduce){
  .magic-dust{display:none}
}

/* Animated nav-link underline */
.nav-primary > ul > li > a,
.nav-primary > ul > li > button{
  position:relative;overflow:visible;
}
.nav-primary > ul > li > a::after,
.nav-primary > ul > li > button::after{
  content:"";
  position:absolute;left:14px;right:14px;bottom:4px;
  height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--royal) 0%,var(--gold-bright) 100%);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform 260ms var(--ease-out);
}
.nav-primary > ul > li > a:hover::after,
.nav-primary > ul > li > button:hover::after,
.nav-primary > ul > li > a[aria-current="page"]::after{
  transform:scaleX(1);
}

/* Button shimmer sweep on hover */
.btn{position:relative;overflow:hidden;isolation:isolate}
.btn::after{
  content:"";
  position:absolute;
  top:0;bottom:0;
  left:-60%;width:60%;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);
  transform:skewX(-20deg);
  transition:left 600ms var(--ease-out);
  pointer-events:none;
  z-index:1;
}
.btn:hover::after{left:120%}
.btn > *{position:relative;z-index:2}
@media (prefers-reduced-motion: reduce){
  .btn::after{display:none}
}

/* Ken Burns slow zoom on gallery images on hover */
.gallery-item{position:relative}
.gallery-item img{
  transition:transform 4s var(--ease-out), filter 600ms var(--ease);
}
.gallery-item:hover img{
  transform:scale(1.12) translateY(-4px);
}

/* Wave divider SVG holder */
.wave-divider{
  display:block;width:100%;height:48px;line-height:0;
  margin-top:-1px;margin-bottom:-1px;
  pointer-events:none;
}
.wave-divider svg{display:block;width:100%;height:100%}
.wave-divider--up{transform:rotate(180deg)}

/* Confetti canvas overlay (booking confirmation) */
.confetti-canvas{
  position:fixed;inset:0;
  pointer-events:none;
  z-index:90;
}

/* Counter targets — give them gold accent */
.counter{
  font-family:'Cormorant Garamond',serif;
  color:var(--royal);
  display:inline-block;
}

/* Hero deep parallax: two layers move at different speeds */
.hero,.page-hero{position:relative;overflow:hidden}
.hero-bg-layer{
  position:absolute;inset:-10% -10% -20% -10%;
  pointer-events:none;
  z-index:0;
}
