/* ============================================================
   LALALAND HOLIDAYS — DESIGN SYSTEM
   Warm ivory editorial · deep forest green · terracotta accent
   ============================================================ */
:root{
  /* Cool-blue palette: navy · periwinkle · lavender-grey · pale-blue · cream */
  --paper:linear-gradient(168deg,#f7f2ea 0%,#eef0f8 100%);
  --paper-2:linear-gradient(168deg,#edeff8 0%,#e1e6f4 100%);
  --paper-solid:#f4efe6;
  --paper-2-solid:#e8ebf4;
  --cream:#fbf9f4;
  --ink:#15224f;
  --ink-soft:#3a4670;
  --moss:#5f6a90;
  --moss-2:#929bbb;
  --forest:#15256d;        /* navy (dark sections) */
  --forest-2:#1d3585;
  --forest-3:#2a4aa0;
  --royal:#3f63b4;
  --terra:#4f6fc0;         /* periwinkle accent */
  --terra-bright:#6b8ed1;
  --terra-soft:#cadefb;    /* pale blue */
  --sand:#cadefb;
  --sky:#6b8ed1;
  --accent-blue:#2f6bf0;
  --gold:#f3a93a;
  /* gradient tokens */
  --grad-dark:linear-gradient(150deg,#13205f 0%,#23429a 58%,#2f56be 100%);
  --grad-dark-soft:linear-gradient(155deg,#1a2c73 0%,#2a4aa0 100%);
  --grad-accent:linear-gradient(135deg,#3f63b4 0%,#6b8ed1 100%);
  --grad-gold:linear-gradient(135deg,#f3a93a 0%,#e8852f 100%);
  --line:rgba(21,34,79,.12);
  --line-strong:rgba(21,34,79,.2);
  --line-light:rgba(251,249,244,.16);
  --shadow-sm:0 2px 10px rgba(21,34,79,.07);
  --shadow:0 24px 60px -28px rgba(21,34,79,.4);
  --shadow-lg:0 50px 110px -40px rgba(21,34,79,.5);
  --ease:cubic-bezier(.6,.01,.05,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --maxw:1400px;
  --nav-h:84px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  line-height:1.55;
  overflow-x:hidden;
  letter-spacing:-.01em;
}
::selection{background:var(--terra);color:var(--cream)}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
input,textarea,select{font-family:inherit}

/* ---- film grain overlay ---- */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;
  opacity:.045;mix-blend-mode:multiply;
  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='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- typography ---- */
.mono{font-family:'JetBrains Mono',monospace;font-weight:400;letter-spacing:.02em}
.eyebrow{
  font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--terra);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow.muted{color:var(--moss)}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;opacity:.6}
.eyebrow.no-tick::before{display:none}
/* eyebrow / kicker sub-labels removed site-wide per request */
.eyebrow,.jl-eyebrow,.jr-eyebrow{display:none !important}

h1,h2,h3{font-weight:700;line-height:1.02;letter-spacing:-.035em}
.display{
  font-size:clamp(52px,9.2vw,150px);line-height:.92;font-weight:800;
  letter-spacing:-.045em;
}
.h1{font-size:clamp(40px,6vw,86px);font-weight:800;letter-spacing:-.04em;line-height:.98}
.h2{font-size:clamp(32px,4.6vw,62px);font-weight:700;line-height:1.0}
.h3{font-size:clamp(22px,2.4vw,32px);font-weight:600;letter-spacing:-.02em;line-height:1.1}
.lead{font-size:clamp(18px,1.5vw,22px);line-height:1.5;color:var(--ink-soft);font-weight:400}
.serif-it{font-style:italic;font-weight:500}
.tcolor{color:var(--terra)}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 80px;width:100%}
.section{padding:clamp(72px,11vw,160px) 0;position:relative}
.section.tight{padding:clamp(56px,7vw,104px) 0}
/* responsive container system: large-desktop 1400/80 · desktop 1280/60 · tablet 40 · mobile 20 */
@media(max-width:1440px){.wrap{max-width:1280px;padding:0 60px}}
@media(max-width:1024px){.wrap{padding:0 40px}}
@media(max-width:760px){.wrap{padding:0 32px}}
@media(max-width:560px){
  body{font-size:16px}
  .nav-cta{padding:10px 15px;font-size:13px}
  .h2{font-size:clamp(28px,8vw,40px)}
  .section{padding:clamp(54px,13vw,96px) 0}
  .wrap{padding:0 20px}
}
html{scroll-padding-top:90px}

/* ---- buttons ---- */
.btn{
  --bg:var(--grad-dark);--fg:var(--cream);
  position:relative;display:inline-flex;align-items:center;gap:.7em;
  padding:17px 30px;border-radius:100px;font-weight:600;font-size:15px;
  letter-spacing:-.01em;background:var(--bg);color:var(--fg);
  overflow:hidden;isolation:isolate;transition:transform .5s var(--ease-out),color .4s ease;
  will-change:transform;
}
.btn span{position:relative;z-index:2;display:inline-flex;align-items:center;gap:.6em}
.btn::after{
  content:"";position:absolute;inset:0;z-index:1;border-radius:inherit;
  background:var(--grad-accent);transform:translateY(101%);transition:transform .55s var(--ease-out);
}
.btn:hover::after{transform:translateY(0)}
.btn:hover{color:#fff}
.btn:active{transform:scale(.97)}
.btn.terra{--bg:var(--grad-accent);--fg:#fff}
.btn.terra::after{background:var(--grad-dark)}
.btn.ghost{--bg:transparent;--fg:var(--ink);border:1px solid var(--line-strong)}
.btn.ghost::after{background:var(--grad-dark)}
.btn.ghost:hover{color:var(--cream)}
.btn.on-dark{--bg:var(--cream);--fg:var(--ink)}
.btn.on-dark.ghost{--bg:transparent;--fg:var(--cream);border-color:var(--line-light)}
.btn.on-dark.ghost::after{background:var(--cream)}
.btn.on-dark.ghost:hover{color:var(--ink)}
.btn .arrow{transition:transform .5s var(--ease-out)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-sm{padding:12px 22px;font-size:14px}

.textlink{
  display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:15px;
  position:relative;padding-bottom:3px;
}
.textlink::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:100%;
  background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease-out)}
.textlink:hover::after{transform:scaleX(1)}
.textlink .arrow{transition:transform .45s var(--ease-out)}
.textlink:hover .arrow{transform:translateX(4px)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);
  display:flex;align-items:center;
  transition:background .5s var(--ease),backdrop-filter .5s,border-color .5s,height .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav.scrolled{
  height:68px;background:rgba(243,237,225,.72);backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);border-color:var(--line);
}
.nav.on-dark{color:var(--cream)}
.nav.on-dark.scrolled{background:rgba(21,33,25,.6);border-color:var(--line-light);color:var(--cream)}
.logo{display:flex;align-items:center;gap:12px;font-weight:800;font-size:19px;letter-spacing:-.04em;z-index:2}
.logo-img{height:46px;width:auto;object-fit:contain;flex:0 0 auto;transition:transform .5s var(--ease-out)}
.logo:hover .logo-img{transform:scale(1.06) rotate(-3deg)}
.nav.scrolled .logo-img{height:38px}
.logo-word{display:flex;flex-direction:column;line-height:1}
.logo-word small{font-family:'JetBrains Mono',monospace;font-weight:400;font-size:9px;letter-spacing:.16em;
  opacity:.55;display:block;margin-top:3px;text-transform:uppercase}
.footer-logo .logo-img{width:auto;height:62px;background:#fff;border-radius:14px;padding:7px 9px}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  position:relative;padding:9px 16px;font-size:15px;font-weight:500;border-radius:100px;
  transition:background .35s,color .35s;opacity:.85;
}
.nav-links a:hover{opacity:1;background:rgba(25,28,24,.06)}
.nav.on-dark:not(.scrolled) .nav-links a:hover{background:rgba(245,240,231,.1)}
.nav-links a.active{opacity:1;font-weight:600}
.nav-links a.active::after{content:"";position:absolute;left:16px;right:16px;bottom:2px;height:2px;border-radius:2px;background:var(--terra)}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-cta{padding:11px 22px;border-radius:100px;background:var(--grad-dark);color:var(--cream);font-weight:600;font-size:14px;white-space:nowrap;
  transition:transform .4s var(--ease-out),filter .4s}
.nav-cta:hover{transform:translateY(-2px);filter:saturate(1.3) brightness(1.08)}
.nav.on-dark:not(.scrolled) .nav-cta{background:var(--cream);color:var(--ink)}
.nav.on-dark:not(.scrolled) .nav-cta:hover{background:var(--terra);color:#fff}
.burger{display:none;width:44px;height:44px;border-radius:50%;align-items:center;justify-content:center;flex-direction:column;gap:5px;border:1px solid var(--line-strong)}
.burger i{display:block;width:18px;height:1.6px;background:currentColor;transition:transform .4s var(--ease),opacity .3s}
.nav.on-dark:not(.scrolled) .burger{border-color:var(--line-light)}
.mobile-open .burger i:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.mobile-open .burger i:nth-child(2){opacity:0}
.mobile-open .burger i:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}
@media(max-width:920px){
  .nav-links,.nav-right .btn{display:none}
  .burger{display:flex}
}
/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:999;background:var(--grad-dark);color:var(--cream);
  display:flex;flex-direction:column;justify-content:center;padding:0 28px;gap:6px;
  clip-path:inset(0 0 100% 0);transition:clip-path .7s var(--ease);pointer-events:none;
}
.mobile-open .mobile-menu{clip-path:inset(0 0 0 0);pointer-events:auto}
.mobile-menu a{font-size:clamp(34px,9vw,60px);font-weight:700;letter-spacing:-.03em;padding:10px 0;
  border-bottom:1px solid var(--line-light);display:flex;justify-content:space-between;align-items:center;
  opacity:0;transform:translateY(20px);transition:opacity .5s,transform .6s var(--ease-out)}
.mobile-open .mobile-menu a{opacity:1;transform:none}
.mobile-open .mobile-menu a:nth-child(1){transition-delay:.18s}
.mobile-open .mobile-menu a:nth-child(2){transition-delay:.25s}
.mobile-open .mobile-menu a:nth-child(3){transition-delay:.32s}
.mobile-open .mobile-menu a:nth-child(4){transition-delay:.39s}
.mobile-open .mobile-menu a:nth-child(5){transition-delay:.46s}
.mobile-menu a .mono{font-size:14px;opacity:.5}

/* ============================================================
   LOADER
   ============================================================ */
#loader{
  position:fixed;inset:0;z-index:10000;background:var(--grad-dark);color:var(--cream);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;
  transition:opacity .8s ease,visibility .8s;
}
#loader.done{opacity:0;visibility:hidden}
/* ---- route loader: a plane orbiting a destination pin ---- */
.trip-loader{position:relative;display:inline-block;width:160px;height:160px;max-width:58vw;
  animation:loaderRise .7s var(--ease-out) both}
.tl-ring{position:absolute;inset:5%;border-radius:50%;border:1.6px dashed rgba(202,222,251,.3);
  animation:tlSpin 16s linear infinite}
.tl-orbit{position:absolute;inset:0;animation:tlSpin 3s linear infinite}
.tl-plane{position:absolute;top:0;left:50%;width:30px;height:30px;margin:-2px 0 0 -15px;
  filter:drop-shadow(0 3px 6px rgba(0,0,0,.45))}
.tl-plane svg{display:block;transform:rotate(90deg)}
.tl-pin{position:absolute;top:50%;left:50%;width:40px;height:40px;transform:translate(-50%,-58%)}
.tl-pin svg{position:relative;z-index:2;display:block;width:100%;height:100%;
  filter:drop-shadow(0 4px 7px rgba(0,0,0,.4));animation:tlBob 2.4s ease-in-out infinite}
.tl-pulse{position:absolute;left:50%;bottom:2px;width:18px;height:6px;transform:translateX(-50%);
  border-radius:50%;background:rgba(8,16,46,.5);animation:tlShadow 2.4s ease-in-out infinite}
.tl-halo{position:absolute;top:50%;left:50%;width:30px;height:30px;transform:translate(-50%,-50%);
  border-radius:50%;background:rgba(202,222,251,.22);animation:tlHalo 2.2s ease-out infinite}
@keyframes tlSpin{to{transform:rotate(360deg)}}
@keyframes tlBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes tlShadow{0%,100%{transform:translateX(-50%) scale(1);opacity:.5}50%{transform:translateX(-50%) scale(.7);opacity:.3}}
@keyframes tlHalo{0%{transform:translate(-50%,-50%) scale(.5);opacity:.7}70%{transform:translate(-50%,-50%) scale(2.1);opacity:0}100%{opacity:0}}
.loader-word-row{font-weight:800;font-size:clamp(22px,4.5vw,34px);letter-spacing:.42em;
  padding-left:.42em;color:var(--cream);animation:loaderRise .8s var(--ease-out) both}
@keyframes loaderRise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes loaderFade{to{opacity:1}}
.loader-meta{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;
  color:var(--terra-soft);text-transform:uppercase;opacity:0;animation:loaderFade .8s ease .7s forwards}

/* ============================================================
   PAGE CURTAIN TRANSITION
   ============================================================ */
#curtain{position:fixed;inset:0;z-index:8000;pointer-events:none;display:flex;flex-direction:column}
#curtain .panel{flex:1;background:var(--grad-dark);transform:scaleY(0);transform-origin:bottom}
#curtain.cover .panel{transform:scaleY(1);transform-origin:bottom;transition:transform .55s var(--ease)}
#curtain.reveal .panel{transform:scaleY(0);transform-origin:top;transition:transform .55s var(--ease)}
#curtain .brand{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:var(--cream);font-weight:800;font-size:clamp(30px,6vw,60px);letter-spacing:-.05em;opacity:0;transition:opacity .4s}
#curtain.cover .brand{opacity:1;transition:opacity .4s .3s}

/* ============================================================
   REVEAL & PARALLAX UTILITIES
   ============================================================ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease-out),transform 1.1s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal.up-sm{transform:translateY(20px)}
.reveal.fade{transform:none}
.reveal.scale{transform:scale(1.06);transition:opacity 1.1s var(--ease-out),transform 1.3s var(--ease-out)}
.reveal.scale.in{transform:scale(1)}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important}
  .tline > span{transform:none!important}
}
/* clip-mask reveal for images */
.mask-rise{clip-path:inset(0 0 100% 0);transition:clip-path 1.2s var(--ease)}
.mask-rise.in{clip-path:inset(0 0 0 0)}
/* line-by-line text reveal */
.tline{display:block;overflow:hidden}
.tline > span{display:block;transform:translateY(110%);transition:transform 1s var(--ease-out)}
.tline.in > span{transform:none}

/* ============================================================
   IMAGE PLACEHOLDER (cinematic tonal stand-in)
   ============================================================ */
.frame{
  position:relative;overflow:hidden;border-radius:18px;background:var(--grad-dark-soft);
  isolation:isolate;color:var(--cream);
}
.frame .ph-grad{position:absolute;inset:0;z-index:0}
.frame .ph-grain{position:absolute;inset:0;z-index:1;opacity:.5;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")}
.frame .ph-label{
  position:absolute;left:14px;bottom:13px;z-index:3;font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:.04em;color:rgba(255,255,255,.9);display:flex;align-items:center;gap:7px;
  background:rgba(10,16,12,.32);backdrop-filter:blur(4px);padding:6px 10px;border-radius:100px;
  border:1px solid rgba(255,255,255,.14);
}
.frame .ph-label::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--terra-bright);flex:0 0 auto}
.frame .ph-tag{position:absolute;right:14px;top:13px;z-index:3;font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7)}
/* image text overlays (tags / captions) removed site-wide per request */
.ph-tag,.ph-label{display:none !important}
.frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}

/* tonal gradient presets (cinematic fallbacks behind photos — blue/cream family) */
.t-forest{background:radial-gradient(120% 95% at 25% 0%,#3f63b4 0%,#1d3585 45%,#15256d 100%)}
.t-sunset{background:radial-gradient(110% 100% at 70% 8%,#9db4e0 0%,#4f6fc0 42%,#1d3585 78%,#15256d 100%)}
.t-himalaya{background:radial-gradient(120% 95% at 30% 6%,#e8ebf4 0%,#cadefb 36%,#6b8ed1 68%,#1d3585 100%)}
.t-desert{background:radial-gradient(120% 100% at 60% 0%,#f4efe6 0%,#cadefb 46%,#6b8ed1 78%,#2a4aa0 100%)}
.t-ocean{background:radial-gradient(120% 110% at 40% 0%,#cadefb 0%,#6b8ed1 40%,#2a4aa0 72%,#15256d 100%)}
.t-night{background:radial-gradient(120% 100% at 50% 0%,#2a4aa0 0%,#1d3585 42%,#101b48 100%)}
.t-rose{background:radial-gradient(120% 100% at 30% 0%,#e8ebf4 0%,#9db4e0 42%,#4f6fc0 74%,#1d3585 100%)}
.t-emerald{background:radial-gradient(120% 100% at 70% 0%,#cadefb 0%,#6b8ed1 42%,#2a4aa0 78%,#15256d 100%)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--grad-dark);color:var(--cream);position:relative;overflow:hidden;padding:clamp(70px,9vw,120px) 0 36px}
.footer .wrap{position:relative;z-index:2}
.footer-cta{display:grid;grid-template-columns:1.3fr .9fr;gap:40px;align-items:end;
  padding-bottom:64px;border-bottom:1px solid var(--line-light)}
.footer-cta .big{font-size:clamp(40px,6.5vw,92px);font-weight:800;letter-spacing:-.045em;line-height:.95}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding:56px 0}
.footer-col h5{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  opacity:.5;margin-bottom:18px;font-weight:500}
.footer-col a,.footer-col p{display:block;opacity:.82;padding:5px 0;font-size:15px;transition:opacity .3s,transform .4s var(--ease-out)}
.footer-col a:hover{opacity:1;transform:translateX(4px);color:var(--terra-soft)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding-top:28px;border-top:1px solid var(--line-light);font-size:13px;opacity:.6;flex-wrap:wrap}
.footer .ghost-word{position:absolute;left:0;right:0;bottom:-3%;z-index:1;text-align:center;
  font-size:clamp(80px,22vw,330px);font-weight:800;letter-spacing:-.05em;line-height:.7;
  color:rgba(245,240,231,.035);pointer-events:none;white-space:nowrap}
.footer-mapbg{position:absolute;left:50%;top:48%;transform:translate(-50%,-50%);z-index:0;
  width:min(1500px,108%);opacity:.42;pointer-events:none;
  -webkit-mask-image:radial-gradient(ellipse 70% 80% at 50% 50%,#000 55%,transparent 100%);
  mask-image:radial-gradient(ellipse 70% 80% at 50% 50%,#000 55%,transparent 100%)}
@media(max-width:920px){
  .footer-cta{grid-template-columns:1fr;gap:28px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* ---- generic helpers ---- */
.divider{height:1px;background:var(--line);width:100%}
.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 15px;border-radius:100px;border:1px solid var(--line-strong);
  font-size:13px;font-weight:500;background:var(--cream);transition:all .4s var(--ease-out)}
.col-moss{color:var(--moss)}
.center{text-align:center}
.stat-num{font-size:clamp(40px,5vw,68px);font-weight:800;letter-spacing:-.04em;line-height:1}

/* dark section */
.dark{background:var(--grad-dark);color:var(--cream)}
.dark .lead{color:rgba(245,240,231,.72)}
.dark .eyebrow.muted{color:var(--terra-soft)}
.dark .divider{background:var(--line-light)}

#app{position:relative;z-index:1;min-height:100vh}
.page-pad{padding-top:var(--nav-h)}

/* ---- page enter animation ---- */
.page-enter > *{animation:pageIn .9s var(--ease-out) both}
@keyframes pageIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
