:root{
  --fg:#171825;
  --muted:#6c6e84;
  --line:#e3e6ee;

  --accent:#7c3aed;       /* bold purple */
  --accent-dark:#5b21b6;  /* deeper purple */

  /* Background + surfaces */
  --bg-top:#eef2f8;       /* cooler light gray/blue */
  --bg-bot:#f8f6ff;       /* ultralight lilac */
  --panel:#ffffff;        /* cards/sections */
  --panel-soft:#f5f1ff;   /* hero tint */
  --footer:#edf0f6;       /* footer strip */
}

/* Reset-ish */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--fg); line-height:1.6;

  /* >>> BIG CHANGE: visible background gradient + faint texture */
  background:
    radial-gradient(600px 300px at 10% -10%, rgba(124,58,237,0.10), transparent 60%),
    radial-gradient(700px 360px at 110% 0%, rgba(91,33,182,0.08), transparent 55%),
    linear-gradient(180deg, var(--bg-top) 0%, var(--bg-bot) 100%);
}

/* Navbar */
.navbar{
  position:sticky; top:0; z-index:20;
  display:flex; justify-content:space-between; align-items:center;
  padding:16px 24px; background:rgba(255,255,255,0.9);
  backdrop-filter: blur(8px);
  border-bottom:1px solid var(--line);
}
.navbar nav a{margin-left:20px; text-decoration:none; color:var(--fg); font-weight:500}
.navbar nav a.cta-small{
  background:var(--accent); color:#fff; padding:8px 14px; border-radius:10px;
  box-shadow:0 4px 10px rgba(124,58,237,.18);
}
.navbar nav a.cta-small:hover{background:var(--accent-dark)}

/* Layout wrapper */
.wrap{max-width:1100px;margin:0 auto;padding:56px 20px}

/* HERO */
.hero{
  /* >>> BIG CHANGE: brighter card on tinted lilac, stronger shadow */
  background: linear-gradient(135deg, var(--panel-soft), #fff);
  border:1px solid #e7e2ff;
  border-radius:22px; padding:44px;
  box-shadow:
    0 30px 60px rgba(67, 56, 202, .10),
    0 8px 18px rgba(17, 24, 39, .08);
}
.hero-inner{display:grid; gap:28px; grid-template-columns:1.1fr 0.9fr; align-items:center}
.hero h1{font-size:clamp(34px,4.2vw,52px); line-height:1.08; color:#0f1222; margin-bottom:12px; letter-spacing:-.015em}
.hero .sub{font-size:18px;color:#45495f;max-width:640px;margin-bottom:18px}

/* Inline form */
.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.inline-form input{
  padding:14px 16px; min-width:240px; border:1px solid var(--line); border-radius:12px;
  font-size:16px; background:#fff; color:#111;
  box-shadow:0 2px 6px rgba(15,18,34,.03);
}
.inline-form button{
  padding:14px 18px; border:none; border-radius:12px; background:var(--accent); color:#fff;
  font-size:16px; font-weight:800; cursor:pointer;
  box-shadow:0 8px 18px rgba(124,58,237,.22);
  transform:translateY(0); transition:transform .08s ease, box-shadow .15s ease, background .15s ease;
}
.inline-form button:hover{background:var(--accent-dark); transform:translateY(-1px); box-shadow:0 10px 22px rgba(91,33,182,.26)}
.mini{color:var(--muted);font-size:13px;margin-top:6px}

/* Hero aside */
.hero-aside{display:grid;gap:14px;align-content:start}

/* Booking card (desktop only, decorative) */
.booking-card{
  display:none;
  background:#fff; color:#111;
  border-radius:16px; border:1px solid var(--line);
  box-shadow:0 20px 40px rgba(16,19,41,.12);
  overflow:hidden;
  transform:translateY(6px);
  animation: floaty 6s ease-in-out infinite;
}
@keyframes floaty{0%,100%{transform:translateY(6px)}50%{transform:translateY(0)}}
.bc-head{display:flex;gap:6px;align-items:center;padding:10px 12px;border-bottom:1px solid #ececec;background:#f9fafb}
.bc-head .dot{width:8px;height:8px;border-radius:50%;background:#e5e7eb}
.bc-body{padding:14px}
.bc-title{font-weight:800;margin-bottom:8px;color:#0f1222}
.bc-row{display:flex;justify-content:space-between;gap:8px;padding:8px 0;border-bottom:1px dashed #eee}
.bc-row:last-child{border-bottom:none}
.bc-row span{color:#6b7280}
/* Make preview button clearly secondary */
.bc-btn{
  width:100%; margin-top:12px; padding:10px;
  background:#fafafa; color:#555; border:1px solid #dcdfe7; border-radius:10px;
  font-weight:700; cursor:default;
}
.bc-btn:hover{background:#f3f4f7}

/* Benefit chips */
.benefit-chips{list-style:none;display:flex;flex-wrap:wrap;gap:10px}
.benefit-chips li{
  background:#f0ecff;
  border:1px solid #ddd5ff;
  color:#433874; padding:8px 12px; border-radius:999px; font-size:14px; white-space:nowrap;
  opacity:0; transform:translateY(8px);
}
/* Base wordmark */
.logo-type {
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: -0.02em;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  line-height: 1;
}

.logo-type:focus-visible {
  outline: 2px solid var(--accent-dark);
  outline-offset: 2px;
  border-radius: 8px;
}
.logo-type:hover { filter: saturate(1.05) brightness(1.02); }

/* Pill variant */
.nsg-pill { color: var(--neutral-900); }
@media (prefers-color-scheme: dark) {
  .nsg-pill { color: var(--neutral-100); }
}

.nsg-pill .nsg-go {
  color: #fff;
  background: linear-gradient(90deg, var(--accent), var(--accent-dark));
  padding: .2rem .5rem;
  border-radius: .6rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  position: relative;
  transform: translateY(-1px); /* optical alignment */
}

.nsg-pill:hover .nsg-go {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(0,0,0,.12);
}

/* Logos strip */
.logos{text-align:center;margin:26px 0 12px}
.logos p{color:#4d5166;margin-bottom:8px}
.logo-row{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;color:#6a6e86;font-weight:700;letter-spacing:0.02em}

/* Features */
.features{
  display:grid; gap:20px; grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  margin:26px 0;
}
.f-card{
  background:var(--panel); border:1px solid #e7e9f0;
  color:#2a2d3c; border-radius:16px; padding:20px;
  box-shadow:0 10px 24px rgba(16,19,41,.06);
}
.f-ico{font-size:22px; margin-bottom:8px}
.f-card h3{margin-bottom:6px; color:#0f1222}

/* Steps */
.steps{margin: 18px 0 10px}
.steps h2{text-align:center;margin-bottom:16px;font-size:30px;color:#0f1222;letter-spacing:-.01em}
.step-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.step{
  background:var(--panel); border:1px solid #e7e9f0; border-radius:16px; padding:20px; color:#2a2d3c;
  box-shadow:0 10px 24px rgba(16,19,41,.06)
}
.badge{
  width:36px;height:36px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--accent);color:#fff;font-weight:800;margin-bottom:8px
}

/* Metrics */
.metrics{
  display:grid; gap:14px; margin: 24px 0;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); text-align:center
}
.metric{
  background:linear-gradient(180deg, #faf9ff 0%, #f3f5fb 100%);
  border:1px solid #e5e7f1; border-radius:16px; padding:20px
}
.metric strong{display:block;font-size:30px;color:#0f1222;line-height:1.2}
.metric span{color:#53586d}
.asterisk{grid-column:1/-1;text-align:center;color:#7a7f95;font-size:12px;margin-top:2px}

/* Testimonial */
.testimonial{
  background:var(--panel); border:1px solid #e7e9f0; border-radius:18px; padding:26px; margin: 10px 0 22px; color:#2a2d3c;
  box-shadow:0 10px 24px rgba(16,19,41,.06)
}
.testimonial blockquote{font-size:18px;margin-bottom:12px}
.author{display:flex;align-items:center;gap:12px}
.avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;font-weight:800}
.name{font-weight:800}.role{color:#63677f;font-size:14px}

/* FAQ */
.faq{margin: 12px 0 8px}
.faq h2{text-align:center;margin-bottom:12px;font-size:30px;color:#0f1222}
.faq details{
  background:var(--panel); border:1px solid #e7e9f0; border-radius:12px; padding:16px 18px; margin-bottom:12px; color:#2a2d3c;
  box-shadow:0 6px 14px rgba(16,19,41,.05)
}
.faq summary{cursor:pointer;font-weight:800;color:#0f1222}
.faq p{margin-top:8px;color:#4a4f66}

/* Closing CTA */
.closer{
  text-align:center;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  color:#fff; border-radius:18px; padding:34px 22px; margin-top:18px;
  box-shadow:0 16px 40px rgba(124,58,237,0.25);
}
.closer h2{margin-bottom:8px;font-size:30px;letter-spacing:-.01em}
.closer p{margin-bottom:14px;color:#efeaff}

/* Footer */
footer{
  text-align:center;
  padding:24px; color:#61657c; font-size:14px; margin-top:36px;
  border-top:1px solid var(--line);
  background:var(--footer);
}
footer a{color:var(--accent-dark);text-decoration:none}

/* Reveal animation */
.reveal{opacity:0; transform:translateY(14px); transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1; transform:translateY(0)}
.benefit-chips.reveal.in li{
  animation: chip-in .5s ease forwards;
  animation-delay: calc(0.06s * var(--i, 0));
}
@keyframes chip-in{
  from{opacity:0; transform:translateY(8px)}
  to{opacity:1; transform:translateY(0)}
}

/* Accessibility: reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
}

/* Responsive */
@media (min-width: 1000px){.booking-card{display:block}}
@media (max-width:900px){.hero-inner{grid-template-columns:1fr}}
@media (max-width:480px){
  .inline-form{flex-direction:column}
  .inline-form input,.inline-form button{width:100%}
  .navbar nav a{margin-left:12px;font-size:14px}
}
/* === A11y helper for the hamburger label === */
.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;
}

/* === Hamburger button === */
.nav-toggle{
  display:none; /* hidden on desktop */
  background:transparent; border:0; padding:8px; border-radius:10px; cursor:pointer;
}
.nav-toggle .bar{
  display:block; width:22px; height:2px; background:currentColor; margin:5px 0; border-radius:2px;
  transition:transform .2s ease, opacity .2s ease;
}

/* === Mobile behavior === */
@media (max-width:900px){
  .nav-toggle{ display:inline-block; }

  /* Turn the existing nav into a dropdown on small screens */
  #site-nav{
    position:absolute; left:0; right:0; top:100%;
    display:grid; gap:10px; padding:12px 18px 16px;
    background:#fff; /* keeps your header look; change if needed */
    border-bottom:1px solid var(--line);
    transform:translateY(-8px); opacity:0; pointer-events:none; visibility:hidden;
    transition:opacity .18s ease, transform .18s ease, visibility 0s linear .18s;
  }

  /* OPEN state toggled on <html> */
  .nav-open #site-nav{
    transform:translateY(0); opacity:1; pointer-events:auto; visibility:visible;
    transition:opacity .18s ease, transform .18s ease;
  }

  /* Animate icon to 'X' */
  .nav-open .nav-toggle .bar:nth-child(2){ opacity:0; }
  .nav-open .nav-toggle .bar:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-open .nav-toggle .bar:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
}

/* Reduce motion preference */
@media (prefers-reduced-motion: reduce){
  #site-nav, .nav-toggle .bar{ transition:none; }
}
