/* =====================================================================
   Island Jeep Rental — "Bioluminescent Night" design system
   One edit in :root re-themes the whole site.
   ===================================================================== */
:root{
  /* color */
  --ink:#04141C;        /* page bg, midnight teal-black */
  --ink-2:#072430;      /* raised panels / alt sections */
  --ink-3:#0B313E;      /* cards */
  --line:rgba(123,241,222,.14);
  --line-2:rgba(123,241,222,.28);
  --cyan:#2FE6C8;       /* primary glow accent */
  --cyan-soft:#7BF1DE;
  --ocean:#0E6E78;
  --sand:#E8D9B5;
  --coral:#FF7E54;      /* CTA / sunset */
  --coral-hi:#FF9772;
  --paper:#F3F7F6;      /* primary text */
  --muted:#9FB6B9;      /* secondary text */
  --ink-on-accent:#04141C;

  /* type */
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Figtree',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  /* shape */
  --r:18px; --r-sm:10px; --r-lg:26px;
  --shadow:0 24px 60px -34px rgba(0,0,0,.85);
  --glow:0 0 0 1px rgba(47,230,200,.32), 0 22px 60px -30px rgba(47,230,200,.45);

  /* layout */
  --wrap:1180px; --gut:clamp(1.1rem,4vw,2.4rem);
  --nav-h:74px;
}

/* ---------- reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
html.lenis,html.lenis body{scroll-behavior:auto !important}   /* Lenis guard */
body{
  margin:0;background:var(--ink);color:var(--paper);
  font-family:var(--sans);font-size:clamp(1rem,.55vw + .9rem,1.075rem);
  line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:var(--cyan);text-decoration:none;transition:color .25s}
a:hover{color:var(--cyan-soft)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.06;
  letter-spacing:-.01em;margin:0 0 .5em;font-optical-sizing:auto}
h1{font-size:clamp(2.6rem,6.4vw,5.6rem);font-weight:600}
h2{font-size:clamp(2rem,4.2vw,3.4rem)}
h3{font-size:clamp(1.3rem,2vw,1.7rem)}
p{margin:0 0 1.1em}
strong{color:#fff;font-weight:600}
::selection{background:var(--cyan);color:var(--ink)}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:4px}

.wrap{width:min(100% - 2*var(--gut),var(--wrap));margin-inline:auto}
.wrap-wide{width:min(100% - 2*var(--gut),1380px);margin-inline:auto}
section{position:relative}
.eyebrow{font-family:var(--sans);font-weight:700;text-transform:uppercase;
  letter-spacing:.22em;font-size:.74rem;color:var(--cyan);margin:0 0 1rem;display:inline-flex;
  align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--cyan);opacity:.7}
.lede{font-size:clamp(1.1rem,1.4vw,1.3rem);color:var(--muted);max-width:62ch}
.center{text-align:center}
.center .lede{margin-inline:auto}
.center .eyebrow{justify-content:center}

/* ---------- buttons ---------- */
.btn{--bg:var(--coral);position:relative;display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);font-weight:700;font-size:1rem;line-height:1;cursor:pointer;
  padding:1.05rem 1.7rem;border-radius:999px;border:1px solid transparent;
  background:var(--bg);color:var(--ink-on-accent);overflow:hidden;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s;
  box-shadow:0 14px 34px -16px rgba(255,126,84,.7)}
.btn:hover{transform:translateY(-2px);color:var(--ink-on-accent);
  box-shadow:0 20px 44px -16px rgba(255,126,84,.85)}
.btn::after{content:"";position:absolute;top:0;left:-80%;width:55%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-18deg);transition:left .55s ease}
.btn:hover::after{left:130%}
.btn--ghost{--bg:transparent;color:var(--cyan);border-color:var(--line-2);box-shadow:none}
.btn--ghost:hover{color:var(--ink);background:var(--cyan);border-color:var(--cyan);
  box-shadow:var(--glow)}
.btn--lg{padding:1.2rem 2.1rem;font-size:1.06rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}

/* ---------- header / nav ---------- */
.site-head{position:fixed;inset:0 0 auto;height:var(--nav-h);z-index:120;
  display:flex;align-items:center;transition:background .35s,backdrop-filter .35s,border-color .35s;
  border-bottom:1px solid transparent}
.site-head.scrolled{background:rgba(4,20,28,.82);backdrop-filter:blur(14px) saturate(1.3);
  border-color:var(--line)}
.site-head .wrap-wide{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--serif);font-weight:600;
  font-size:1.15rem;color:#fff;letter-spacing:-.01em}
.brand img{height:42px;width:auto;filter:drop-shadow(0 2px 10px rgba(0,0,0,.5))}
.nav{display:flex;align-items:center;gap:2rem}
.nav a{color:var(--paper);font-weight:500;font-size:.97rem;position:relative;opacity:.86}
.nav a:hover,.nav a[aria-current="page"]{opacity:1;color:#fff}
.nav a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;
  background:var(--cyan);transition:width .3s;border-radius:2px}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-phone{color:var(--paper);font-weight:600;white-space:nowrap}
.nav-phone span{color:var(--cyan)}
.burger{display:none;background:none;border:0;cursor:pointer;width:46px;height:46px;
  border-radius:10px;border:1px solid var(--line);align-items:center;justify-content:center}
.burger span,.burger span::before,.burger span::after{content:"";display:block;width:20px;
  height:2px;background:var(--paper);transition:.3s;position:relative}
.burger span::before{position:absolute;top:-6px}.burger span::after{position:absolute;top:6px}
body.nav-open .burger span{background:transparent}
body.nav-open .burger span::before{top:0;transform:rotate(45deg)}
body.nav-open .burger span::after{top:0;transform:rotate(-45deg)}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:115;background:rgba(4,20,28,.97);
  backdrop-filter:blur(10px);display:flex;flex-direction:column;justify-content:center;
  gap:.4rem;padding:var(--gut);transform:translateX(100%);transition:transform .45s cubic-bezier(.7,0,.2,1);
  visibility:hidden}
body.nav-open .drawer{transform:none;visibility:visible}
.drawer a{font-family:var(--serif);font-size:1.7rem;color:var(--paper);padding:.55rem 0;
  border-bottom:1px solid var(--line)}
.drawer .btn{margin-top:1.4rem;justify-content:center}

/* ---------- sections / cards ---------- */
.pad{padding-block:clamp(4rem,9vw,8rem)}
.pad-sm{padding-block:clamp(3rem,6vw,5rem)}
.alt{background:var(--ink-2)}
.card{position:relative;background:linear-gradient(180deg,var(--ink-3),var(--ink-2));
  border:1px solid var(--line);border-radius:var(--r);padding:1.7rem;overflow:hidden;
  transition:transform .4s,border-color .4s,box-shadow .4s}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(47,230,200,.55),transparent)}
.card:hover{transform:translateY(-5px);border-color:var(--line-2);box-shadow:var(--glow)}
.grid{display:grid;gap:1.3rem}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.icon-badge{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;
  background:rgba(47,230,200,.1);border:1px solid var(--line-2);color:var(--cyan);
  margin-bottom:1.1rem}
.icon-badge svg{width:26px;height:26px}

/* quick-answer + key-facts (AEO) */
.quick-answer{background:rgba(47,230,200,.07);border:1px solid var(--line-2);
  border-left:3px solid var(--cyan);border-radius:var(--r-sm);padding:1.2rem 1.4rem;margin:0 0 1.8rem}
.quick-answer .qa-label{font-family:var(--sans);font-weight:700;text-transform:uppercase;
  letter-spacing:.16em;font-size:.7rem;color:var(--cyan);margin:0 0 .4rem}
.quick-answer p:last-child{margin:0}
table.key-facts{width:100%;border-collapse:collapse;margin:0 0 1.8rem;font-size:.97rem}
table.key-facts th,table.key-facts td{text-align:left;padding:.7rem .9rem;border-bottom:1px solid var(--line)}
table.key-facts th{color:var(--cyan);font-family:var(--sans);font-weight:600;white-space:nowrap;width:38%}
.data-table{width:100%;border-collapse:collapse;font-size:.97rem;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.data-table th,.data-table td{padding:.85rem 1rem;border-bottom:1px solid var(--line);text-align:left}
.data-table thead th{background:var(--ink-3);color:#fff;font-family:var(--sans)}
.data-table tbody tr:hover{background:rgba(47,230,200,.05)}
.data-table tr:last-child td{border-bottom:0}

/* pills / chips */
.chip{display:inline-flex;align-items:center;gap:.45rem;padding:.45rem .85rem;border-radius:999px;
  background:rgba(47,230,200,.08);border:1px solid var(--line);color:var(--cyan-soft);
  font-size:.82rem;font-weight:600}
.spec-list{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.spec-list li{display:flex;justify-content:space-between;gap:1rem;padding-bottom:.55rem;
  border-bottom:1px solid var(--line);font-size:.97rem}
.spec-list li span:first-child{color:var(--muted)}
.spec-list li span:last-child{color:#fff;font-weight:600;text-align:right}

/* testimonial */
.quote{font-family:var(--serif);font-size:clamp(1.15rem,1.7vw,1.45rem);line-height:1.5;color:#fff}
.quote cite{display:block;margin-top:1rem;font-family:var(--sans);font-style:normal;font-size:.92rem;
  color:var(--cyan);font-weight:600}
.stars{color:var(--coral);letter-spacing:2px;margin-bottom:.7rem}

/* stats */
.stats{display:flex;flex-wrap:wrap;gap:0}
.stat{flex:1 1 160px;padding:1.2rem 1.5rem;position:relative}
.stat + .stat::before{content:"";position:absolute;left:0;top:18%;height:64%;width:1px;
  background:linear-gradient(180deg,transparent,var(--line-2),transparent)}
.stat .n{font-family:var(--serif);font-size:clamp(2.2rem,4vw,3.2rem);color:#fff;line-height:1}
.stat .l{color:var(--muted);font-size:.9rem;margin-top:.4rem}

/* breadcrumb + page hero */
.page-hero{position:relative;padding-top:calc(var(--nav-h) + clamp(3rem,7vw,5.5rem));
  padding-bottom:clamp(2.5rem,5vw,4rem);overflow:hidden;isolation:isolate}
.page-hero::before{content:"";position:absolute;inset:0;z-index:-2;
  background:radial-gradient(120% 90% at 80% -10%,rgba(14,110,120,.55),transparent 60%),
    radial-gradient(90% 80% at 0% 110%,rgba(47,230,200,.16),transparent 55%),var(--ink)}
.page-hero.has-img::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(4,20,28,.55),rgba(4,20,28,.92))}
.page-hero .bgimg{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;opacity:.5}
.crumbs{font-size:.85rem;color:var(--muted);margin-bottom:1.1rem;display:flex;gap:.5rem;flex-wrap:wrap}
.crumbs a{color:var(--muted)}.crumbs a:hover{color:var(--cyan)}
.crumbs span[aria-current]{color:var(--paper)}

/* media + figure */
.media{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);position:relative}
.media img{width:100%;height:100%;object-fit:cover}
.media--glow{box-shadow:var(--glow)}
figure{margin:0}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:center}
.split--media-first .media{order:-1}

.updated{color:var(--muted);font-size:.85rem}
.updated time{color:var(--cyan-soft)}

/* FAQ */
.faqs details{border:1px solid var(--line);border-radius:var(--r-sm);padding:.2rem 1.2rem;
  margin-bottom:.8rem;background:var(--ink-2);transition:border-color .3s}
.faqs details[open]{border-color:var(--line-2)}
.faqs summary{cursor:pointer;list-style:none;padding:1.05rem 0;font-weight:600;color:#fff;
  font-size:1.05rem;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faqs summary::-webkit-details-marker{display:none}
.faqs summary::after{content:"+";color:var(--cyan);font-size:1.5rem;transition:transform .3s;line-height:1}
.faqs details[open] summary::after{transform:rotate(45deg)}
.faqs details p{margin:0 0 1.1rem;color:var(--muted)}

/* CTA band */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--ocean),var(--ink-2));
  border:1px solid var(--line-2);border-radius:var(--r-lg);padding:clamp(2.4rem,5vw,4rem);text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 120% at 50% 0%,rgba(47,230,200,.22),transparent 70%);pointer-events:none}
.cta-band h2{position:relative}
.cta-band .btn-row{position:relative;justify-content:center}

/* ---------- footer ---------- */
.site-foot{position:relative;background:var(--ink-2);border-top:1px solid var(--line);
  padding-top:clamp(3.5rem,6vw,5rem);margin-top:0;overflow:hidden}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2rem;
  padding-bottom:3rem;position:relative;z-index:2}
.foot-grid h4{font-family:var(--sans);font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;
  color:var(--cyan);font-weight:700}
.foot-grid ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.foot-grid a{color:var(--muted);font-size:.95rem}.foot-grid a:hover{color:#fff}
.foot-brand p{color:var(--muted);max-width:34ch;font-size:.95rem}
.foot-brand img{height:46px;margin-bottom:1rem}
.foot-contact a{display:block;color:var(--paper);font-weight:600;margin-bottom:.5rem}
.foot-bottom{border-top:1px solid var(--line);padding:1.5rem 0;display:flex;
  justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:var(--muted);
  position:relative;z-index:2}
.foot-watermark{position:absolute;left:50%;bottom:-.18em;transform:translateX(-50%);
  font-family:var(--serif);font-weight:900;font-size:18vw;line-height:.8;white-space:nowrap;
  color:transparent;-webkit-text-stroke:1px rgba(123,241,222,.09);pointer-events:none;z-index:0;user-select:none}

/* ---------- custom cursor ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;
  z-index:9999;mix-blend-mode:screen;opacity:0;transition:opacity .3s}
.cursor-dot{width:7px;height:7px;background:var(--cyan);margin:-3.5px 0 0 -3.5px}
.cursor-ring{width:34px;height:34px;border:1.5px solid var(--coral);margin:-17px 0 0 -17px;
  transition:width .25s,height .25s,border-color .25s,opacity .3s,background .25s}
html.has-cursor,html.has-cursor *{cursor:none !important}
html.has-cursor input,html.has-cursor textarea,html.has-cursor select{cursor:auto !important}
html.has-cursor.cursor-active .cursor-dot,html.has-cursor.cursor-active .cursor-ring{opacity:1}
html.has-cursor .cursor-ring.hover{width:54px;height:54px;border-color:var(--cyan);
  background:rgba(47,230,200,.08)}

/* reveal base */
[data-reveal]{opacity:0}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1 !important;transform:none !important}
  html{scroll-behavior:auto}
  .btn::after{display:none}
}

/* forms */
form label{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;font-weight:600;color:var(--muted)}
form input,form textarea,form select{font-family:var(--sans);font-size:1rem;color:var(--paper);
  background:rgba(4,20,28,.6);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:.8rem .9rem;width:100%;transition:border-color .25s,box-shadow .25s}
form input::placeholder,form textarea::placeholder{color:#5d747a}
form input:focus,form textarea:focus,form select:focus{outline:none;border-color:var(--cyan);
  box-shadow:0 0 0 3px rgba(47,230,200,.18)}
form button[disabled]{opacity:.5;cursor:default}

/* grain atmosphere */
.grain{position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .foot-grid{grid-template-columns:1fr 1fr}
  .g-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .nav,.nav-cta .nav-phone{display:none}
  .burger{display:inline-flex}
  .split{grid-template-columns:1fr}
  .split--media-first .media{order:0}
  .g-3{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .stat + .stat::before{display:none}
}
