/* ============================================================
   More Bookings v2 — "Midnight & Aurora"
   Design system: tokens, base, header, footer, buttons, forms.
   One edit in :root re-themes the whole site.
   ============================================================ */

:root{
  /* ---- Color ---- */
  --ink:        #0A0E1A;   /* page background */
  --ink-2:      #0E1422;   /* elevated band  */
  --ink-3:      #131B2E;   /* cards          */
  --ink-4:      #18223A;   /* card hover     */
  --platinum:   #E8ECF5;   /* primary text   */
  --muted:      #9DA9BE;   /* secondary text */
  --faint:      #6B788F;   /* tertiary text  */
  --teal:       #38E1C6;   /* accent 1       */
  --teal-deep:  #16B89E;
  --violet:     #8B7CF6;   /* accent 2       */
  --violet-deep:#6D5DE6;
  --line:       rgba(255,255,255,.08);
  --line-2:     rgba(255,255,255,.14);
  --glass:      rgba(255,255,255,.04);
  --glass-2:    rgba(255,255,255,.06);

  /* gradients */
  --grad-accent: linear-gradient(105deg, var(--teal), var(--violet));
  --grad-text:   linear-gradient(105deg, #EAFBF6, #C9D2FF 60%, #B9C6FF);

  /* ---- Type ---- */
  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body:    "Inter", system-ui, -apple-system, sans-serif;

  /* ---- Shape ---- */
  --r-sm: 10px;
  --r:    16px;
  --r-lg: 22px;
  --r-xl: 30px;

  /* ---- Shadow / glow ---- */
  --shadow:    0 18px 50px -20px rgba(0,0,0,.7);
  --shadow-lg: 0 40px 90px -30px rgba(0,0,0,.8);
  --glow-teal: 0 0 0 1px rgba(56,225,198,.22), 0 14px 50px -16px rgba(56,225,198,.35);

  /* ---- Layout ---- */
  --container: 1180px;
  --pad: clamp(1.2rem, 4vw, 2.2rem);
}

/* ============================================================
   Base
   ============================================================ */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
/* Lenis guard — browser smooth-scroll fights Lenis if both run */
html.lenis, html.lenis body{ scroll-behavior:auto !important; }

body{
  margin:0;
  background:var(--ink);
  color:var(--platinum);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* page-wide filmic grain + ambient glows */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(900px 500px at 12% -8%, rgba(56,225,198,.10), transparent 60%),
    radial-gradient(900px 600px at 110% 8%, rgba(139,124,246,.12), transparent 60%);
}
body::after{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.05;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
main{ position:relative; z-index:1; }

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4,h5{ font-family:var(--font-display); font-weight:600; line-height:1.08; letter-spacing:-.02em; margin:0; }
p{ margin:0; }

::selection{ background:rgba(56,225,198,.28); color:#fff; }

.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--pad); }

.skip-link{
  position:absolute; left:12px; top:-60px; z-index:1000;
  background:var(--teal); color:#06231d; padding:10px 16px; border-radius:8px;
  font-weight:600; transition:top .2s;
}
.skip-link:focus{ top:12px; }

/* ---- shared type helpers ---- */
.eyebrow{
  display:inline-block; font-family:var(--font-display); font-size:.74rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; color:var(--teal);
  padding:.4rem .8rem; border:1px solid var(--line-2); border-radius:100px;
  background:var(--glass); backdrop-filter:blur(6px);
}
.eyebrow.centered{ }
.display{ font-size:clamp(2.7rem, 7vw, 5.2rem); }
.section-title{ font-size:clamp(1.9rem, 4.2vw, 3.1rem); }
.lead{ color:var(--muted); font-size:clamp(1.02rem, 1.4vw, 1.18rem); line-height:1.7; }
.grad{ background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.accent{ color:var(--teal); }

.section-pad{ padding:clamp(4.5rem, 9vw, 8rem) 0; position:relative; }
.section-head{ max-width:760px; margin-bottom:clamp(2.2rem,5vw,3.4rem); }
.section-head .eyebrow{ margin-bottom:1.1rem; }
.section-head .section-title{ margin-bottom:1.1rem; }
.section-head.center{ margin-inline:auto; text-align:center; }

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  --bx:1.5rem;
  display:inline-flex; align-items:center; gap:.55rem; cursor:pointer;
  font-family:var(--font-display); font-weight:600; font-size:.98rem; letter-spacing:-.01em;
  padding:.8rem var(--bx); border-radius:100px; border:1px solid transparent;
  position:relative; overflow:hidden; transition:transform .25s, box-shadow .3s, background .3s, color .3s;
  white-space:nowrap;
}
.btn .arrow{ transition:transform .3s; }
.btn:hover .arrow{ transform:translateX(4px); }
.btn-lg{ --bx:1.9rem; padding:1rem var(--bx); font-size:1.04rem; }

.btn-primary{ background:var(--grad-accent); color:#06231d; box-shadow:var(--glow-teal); }
.btn-primary::after{
  content:""; position:absolute; top:0; left:-90%; width:60%; height:100%;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.55), transparent);
  transform:skewX(-18deg); transition:left .6s;
}
.btn-primary:hover{ transform:translateY(-2px); }
.btn-primary:hover::after{ left:130%; }

.btn-ghost{ background:var(--glass); color:var(--platinum); border-color:var(--line-2); backdrop-filter:blur(6px); }
.btn-ghost:hover{ background:var(--glass-2); border-color:var(--teal); transform:translateY(-2px); }

/* ============================================================
   Header
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background .35s, border-color .35s, backdrop-filter .35s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(10,14,26,.72); backdrop-filter:blur(16px) saturate(1.3);
  border-bottom-color:var(--line);
}
.site-header .nav{ display:flex; align-items:center; gap:1.5rem; height:74px; }

.brand{ display:flex; align-items:center; gap:.7rem; margin-right:auto; }
.brand-mark{ display:grid; place-items:center; filter:drop-shadow(0 4px 14px rgba(56,225,198,.4)); }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{ font-family:var(--font-display); font-weight:600; font-size:1.18rem; letter-spacing:-.01em; }
.brand-tag{ font-size:.7rem; color:var(--faint); letter-spacing:.06em; margin-top:.18rem; }

.nav-links{ display:flex; gap:.3rem; list-style:none; margin:0; padding:0; }
.nav-links a{
  font-size:.9rem; color:var(--muted); padding:.5rem .8rem; border-radius:100px;
  transition:color .25s, background .25s;
}
.nav-links a:hover{ color:var(--platinum); background:var(--glass); }

.nav-cta{ display:flex; align-items:center; gap:.6rem; }
.nav-toggle{
  display:none; background:var(--glass); border:1px solid var(--line-2); color:var(--platinum);
  width:44px; height:44px; border-radius:12px; cursor:pointer; padding:9px;
}

.mobile-menu{
  position:fixed; inset:0 0 0 auto; width:min(86vw,360px); z-index:99;
  background:rgba(12,17,30,.97); backdrop-filter:blur(20px);
  border-left:1px solid var(--line); padding:6.5rem 1.6rem 2rem;
  display:flex; flex-direction:column; gap:.4rem;
  transform:translateX(100%); transition:transform .4s cubic-bezier(.5,0,0,1); visibility:hidden;
}
.mobile-menu.open{ transform:none; visibility:visible; }
.mobile-menu a{ padding:.85rem 1rem; border-radius:12px; color:var(--muted); font-size:1.05rem; }
.mobile-menu a:hover{ background:var(--glass); color:var(--platinum); }
.mobile-menu .btn{ margin-top:1rem; justify-content:center; }

/* ============================================================
   Forms (shared)
   ============================================================ */
label{ display:block; font-size:.86rem; font-weight:500; color:var(--platinum); margin-bottom:.45rem; }
input, select, textarea{
  width:100%; font-family:var(--font-body); font-size:1rem; color:var(--platinum);
  background:rgba(255,255,255,.03); border:1px solid var(--line-2); border-radius:var(--r-sm);
  padding:.8rem .9rem; transition:border-color .25s, box-shadow .25s, background .25s;
}
input::placeholder, textarea::placeholder{ color:var(--faint); }
input:focus, select:focus, textarea:focus{
  outline:none; border-color:var(--teal); background:rgba(56,225,198,.04);
  box-shadow:0 0 0 4px rgba(56,225,198,.14);
}
select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%239DA9BE' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right .9rem center; padding-right:2.4rem; }
textarea{ resize:vertical; min-height:120px; }
.req{ color:var(--teal); }

:focus-visible{ outline:2px solid var(--teal); outline-offset:3px; border-radius:4px; }

/* ============================================================
   Footer
   ============================================================ */
.site-footer{ position:relative; z-index:1; background:var(--ink-2); border-top:1px solid var(--line); padding-top:clamp(3.5rem,7vw,5.5rem); overflow:hidden; }
.footer-top{ display:grid; grid-template-columns:1.4fr 2fr; gap:2.5rem; padding-bottom:3rem; }
.footer-brand .brand-name{ font-family:var(--font-display); font-size:1.5rem; font-weight:600; }
.footer-by{ color:var(--teal); font-size:.85rem; margin:.2rem 0 1rem; }
.footer-brand p{ color:var(--muted); max-width:34ch; }
.footer-links{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.footer-col h5{ font-family:var(--font-display); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); margin-bottom:1rem; }
.footer-col a{ display:block; color:var(--muted); font-size:.92rem; padding:.3rem 0; transition:color .2s; }
.footer-col a:hover{ color:var(--teal); }
.footer-bottom{
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  border-top:1px solid var(--line); padding:1.5rem 0 2.2rem; margin-top:1rem;
  color:var(--faint); font-size:.82rem;
}
/* giant outlined watermark wordmark bleeding off the bottom */
.footer-watermark{
  font-family:var(--font-display); font-weight:600; font-size:18vw; line-height:.8;
  color:transparent; -webkit-text-stroke:1px rgba(255,255,255,.06);
  text-align:center; white-space:nowrap; margin-bottom:-3.2vw; user-select:none; pointer-events:none;
}

/* ============================================================
   Mobile sticky CTA bar (phones only)
   ============================================================ */
.mobile-cta-bar{
  position:fixed; left:0; right:0; bottom:0; z-index:90; display:none; gap:.7rem;
  padding:.7rem .9rem calc(.7rem + env(safe-area-inset-bottom));
  background:rgba(10,14,26,.9); backdrop-filter:blur(14px); border-top:1px solid var(--line);
}
.mobile-cta-bar .mcta-call{
  display:flex; align-items:center; gap:.4rem; color:var(--platinum);
  border:1px solid var(--line-2); border-radius:100px; padding:.7rem 1.1rem; font-weight:600; font-size:.9rem;
}
.mcta-call svg{ width:18px; height:18px; }
.mcta-schedule{ flex:1; justify-content:center; }

/* ============================================================
   Custom cursor
   ============================================================ */
.cursor-dot, .cursor-ring{ position:fixed; top:0; left:0; z-index:9000; pointer-events:none; border-radius:50%; mix-blend-mode:screen; opacity:0; transition:opacity .3s; }
.cursor-dot{ width:7px; height:7px; background:var(--teal); margin:-3.5px 0 0 -3.5px; }
.cursor-ring{ width:34px; height:34px; border:1.5px solid var(--violet); margin:-17px 0 0 -17px; transition:width .25s, height .25s, margin .25s, background .25s, border-color .25s, opacity .3s; }
html.has-cursor.cursor-ready .cursor-dot, html.has-cursor.cursor-ready .cursor-ring{ opacity:1; }
html.has-cursor, html.has-cursor a, html.has-cursor button, html.has-cursor summary, html.has-cursor .btn{ cursor:none; }
html.has-cursor input, html.has-cursor textarea, html.has-cursor select{ cursor:auto; }
.cursor-ring.is-hover{ width:54px; height:54px; margin:-27px 0 0 -27px; background:rgba(56,225,198,.10); border-color:var(--teal); }
.cursor-ring.is-down{ width:26px; height:26px; margin:-13px 0 0 -13px; }

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .cursor-dot, .cursor-ring{ display:none !important; }
  html.has-cursor, html.has-cursor *{ cursor:auto !important; }
}

/* ============================================================
   Responsive — header / footer
   ============================================================ */
@media (max-width:980px){
  .nav-links{ display:none; }
  .nav-toggle{ display:grid; place-items:center; }
  .footer-top{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .footer-links{ grid-template-columns:1fr 1fr; }
  .mobile-cta-bar{ display:flex; }
  .nav-cta .btn-primary{ display:none; } /* sticky bar handles CTA on phones */
}
