/* ============================================================================
   Ladakh Mountain Tour & Travels — concept site
   Art direction: WARM RETRO-TRAVEL / POSTCARD
   Palette derived from base teal #1b7b9d (hue ~195/220) → faded petrol-teal brand
   + sun-bleached terracotta complement, on warm cream paper.
   Fonts: Cormorant Garamond (display serif) + Oswald (condensed caps) + Caveat (1 script flourish).
   ============================================================================ */

/* ---- self-hosted fonts ---------------------------------------------------- */
@font-face{
  font-family:"Cormorant Garamond";font-style:normal;font-weight:500 700;
  font-display:swap;src:url("vendor/fonts/cormorant-upright.woff2") format("woff2");
}
@font-face{
  font-family:"Cormorant Garamond";font-style:italic;font-weight:500 600;
  font-display:swap;src:url("vendor/fonts/cormorant-italic.woff2") format("woff2");
}
@font-face{
  font-family:"Oswald";font-style:normal;font-weight:300 700;
  font-display:swap;src:url("vendor/fonts/oswald-var.woff2") format("woff2");
}
@font-face{
  font-family:"Caveat";font-style:normal;font-weight:600 700;
  font-display:swap;src:url("vendor/fonts/caveat-var.woff2") format("woff2");
}

/* ---- tokens --------------------------------------------------------------- */
:root{
  /* base + brand (faded petrol-teal) */
  --base:        oklch(0.55 0.10 222);
  --brand:       oklch(0.50 0.072 220);
  --brand-deep:  oklch(0.38 0.082 222);
  --brand-soft:  oklch(0.62 0.055 218);

  /* sun-bleached terracotta complement — stamps, tickets, marks */
  --accent-2:    oklch(0.605 0.095 42);
  --accent-2-dp: oklch(0.50 0.10 40);
  --gold:        oklch(0.745 0.085 78);

  /* paper + ink */
  --page:        oklch(0.945 0.020 86);
  --page-2:      oklch(0.928 0.024 84);
  --paper-2:     oklch(0.910 0.028 82);
  --card:        oklch(0.972 0.015 88);
  --card-2:      oklch(0.962 0.018 85);
  --ink:         oklch(0.255 0.026 58);
  --ink-2:       oklch(0.405 0.026 56);
  --muted:       oklch(0.545 0.020 56);
  --rule:        oklch(0.775 0.030 70);
  --rule-soft:   oklch(0.840 0.024 74);
  --rule-strong: oklch(0.330 0.028 56);

  --grain-opacity: 0.055;
  --ease: cubic-bezier(0.2,0.8,0.2,1);
  --ease-press: cubic-bezier(0.34,1.56,0.64,1);

  /* type scale */
  --t-hero:  clamp(2.7rem, 1rem + 7.4vw, 6rem);
  --t-h2:    clamp(1.95rem, 1.1rem + 2.9vw, 3.3rem);
  --t-h3:    clamp(1.22rem, 1rem + 0.85vw, 1.55rem);
  --t-body:  clamp(1.04rem, 0.99rem + 0.3vw, 1.18rem);
  --t-kicker: 0.8rem;

  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --cond:"Oswald","Arial Narrow", system-ui, sans-serif;
  --script:"Caveat", cursive;

  --wrap: 1200px;
  --sec-pad: clamp(68px, 8.5vw, 140px);
  --radius: 5px;

  --photo-wash: sepia(0.26) saturate(0.84) contrast(0.95) brightness(1.045);
  --hard-shadow: 7px 7px 0 var(--rule);
}

/* dark mode = "lamplight / aged leather" — honoured but light is home */
:root[data-theme="dark"]{
  --page:        oklch(0.205 0.024 60);
  --page-2:      oklch(0.225 0.026 58);
  --paper-2:     oklch(0.250 0.028 56);
  --card:        oklch(0.255 0.030 58);
  --card-2:      oklch(0.275 0.030 56);
  --ink:         oklch(0.915 0.028 84);
  --ink-2:       oklch(0.760 0.026 72);
  --muted:       oklch(0.660 0.022 66);
  --rule:        oklch(0.430 0.030 60);
  --rule-soft:   oklch(0.360 0.028 60);
  --rule-strong: oklch(0.780 0.030 78);
  --brand:       oklch(0.66 0.085 218);
  --brand-deep:  oklch(0.74 0.075 216);
  --brand-soft:  oklch(0.58 0.07 220);
  --accent-2:    oklch(0.68 0.10 44);
  --hard-shadow: 7px 7px 0 oklch(0.16 0.02 60);
}

/* ---- reset ---------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0}
img{display:block;max-width:100%;height:auto}
a{color:inherit}
button{font:inherit;color:inherit}
h1,h2,h3,p,figure,blockquote,ol,address{margin:0}
ol{padding:0;list-style:none}

html{
  background:var(--page);
  color:var(--ink);
  font-family:var(--serif);
  font-size:clamp(17px,16px + 0.2vw,19px);
  line-height:1.62;
  font-variant-numeric:oldstyle-nums;
  scroll-behavior:auto; /* Lenis handles smooth; never both */
}
body{
  position:relative;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* paper grain over EVERYTHING — the single most important retro cue */
body::after{
  content:"";position:fixed;inset:0;z-index:9000;pointer-events:none;
  opacity:var(--grain-opacity);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

::selection{background:color-mix(in oklab,var(--accent-2) 30%,transparent);color:var(--ink)}

.wrap{width:min(100% - 2.4rem,var(--wrap));margin-inline:auto}

/* ---- shared type ---------------------------------------------------------- */
.kicker{
  font-family:var(--cond);font-weight:500;text-transform:uppercase;
  letter-spacing:0.22em;font-size:var(--t-kicker);color:var(--brand);
  margin:0;line-height:1.2;
}
h1,h2,h3{font-family:var(--serif);font-weight:600;letter-spacing:-0.012em;line-height:1.04;color:var(--ink)}
em{font-style:italic}
.section{padding-block:var(--sec-pad)}

/* banded sections sit on deeper paper, fenced by rules */
.section--banded{
  background:var(--page-2);
  border-block:1.5px solid var(--rule);
  position:relative;
}
.section--banded::before,.section--banded::after{
  content:"";position:absolute;left:0;right:0;height:1px;background:var(--rule-soft);
}
.section--banded::before{top:4px}
.section--banded::after{bottom:4px}

/* ---- ruled section header ------------------------------------------------- */
.rule-head{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:clamp(14px,3vw,34px);
  margin-bottom:clamp(34px,4.5vw,60px);
}
.rule-head__line{height:0;border-top:1.5px solid var(--rule);position:relative}
.rule-head__line::after{content:"";position:absolute;top:3px;left:0;right:0;border-top:1px solid var(--rule-soft)}
.rule-head__txt{text-align:center;max-width:42ch}
.rule-head__txt .kicker{margin-bottom:0.5rem}
.rule-head h2{font-size:var(--t-h2)}
.rule-head__note{font-size:0.96rem;color:var(--ink-2);margin-top:0.85rem;text-wrap:pretty;line-height:1.55}

/* ---- buttons -------------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:0.55em;
  font-family:var(--cond);font-weight:500;text-transform:uppercase;letter-spacing:0.12em;
  font-size:0.86rem;line-height:1;text-decoration:none;cursor:pointer;
  padding:0.92em 1.5em;border:1.5px solid var(--rule-strong);border-radius:var(--radius);
  background:var(--card);color:var(--ink);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
  box-shadow:3px 3px 0 var(--rule);
}
.btn:hover{transform:translate(-1px,-1px);box-shadow:5px 5px 0 var(--rule)}
.btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--rule)}
.btn:focus-visible{outline:2.5px solid var(--accent-2);outline-offset:3px}
.btn--wa{background:var(--brand);color:oklch(0.97 0.02 86);border-color:var(--brand-deep);box-shadow:3px 3px 0 var(--brand-deep)}
.btn--wa:hover{background:var(--brand-deep);box-shadow:5px 5px 0 var(--brand-deep)}
.btn--wa:active{box-shadow:1px 1px 0 var(--brand-deep)}
.btn--ghost{background:transparent;box-shadow:3px 3px 0 var(--rule-soft)}
.btn--ghost:hover{background:var(--card)}
.btn--lg{padding:1.05em 1.7em;font-size:0.94rem}
.btn--sm{padding:0.7em 1.1em;font-size:0.78rem;box-shadow:2px 2px 0 var(--brand-deep)}
.btn--sm.btn--wa:hover{box-shadow:4px 4px 0 var(--brand-deep)}

/* ---- demo banner ---------------------------------------------------------- */
.demo-banner{
  background:var(--ink);color:oklch(0.92 0.02 84);
  display:flex;align-items:center;gap:clamp(8px,2vw,18px);
  padding:0.55rem clamp(0.9rem,3vw,1.6rem);
  font-family:var(--cond);font-size:0.78rem;letter-spacing:0.04em;
  position:relative;z-index:1000;
}
.demo-banner p{margin:0;text-align:center;flex:1;line-height:1.4;font-weight:300}
.demo-banner strong{font-weight:600;text-transform:uppercase;letter-spacing:0.14em;color:var(--gold)}
.demo-banner a{color:oklch(0.93 0.02 84);text-decoration:underline;text-underline-offset:2px;font-weight:500;white-space:nowrap}
.demo-banner a:hover{color:oklch(0.99 0.01 86)}
.demo-banner__rule{flex:1;height:1px;background:oklch(0.5 0.02 70 / .5);max-width:120px}
@media(max-width:640px){.demo-banner__rule{display:none}.demo-banner{font-size:0.74rem;padding:0.5rem 0.85rem}}

/* ---- scroll progress ------------------------------------------------------ */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:3px;z-index:1001;
  background:var(--accent-2);transform:scaleX(0);transform-origin:0 50%;
  transition:transform .08s linear;
}

/* ---- nav ------------------------------------------------------------------ */
.nav{position:sticky;top:0;z-index:900;background:color-mix(in oklab,var(--page) 90%,transparent);
  border-bottom:1.5px solid transparent;transition:background .3s var(--ease),border-color .3s var(--ease)}
.nav.scrolled{background:color-mix(in oklab,var(--page) 96%,transparent);border-bottom-color:var(--rule);backdrop-filter:blur(6px)}
.nav__inner{width:min(100% - 2.4rem,var(--wrap));margin-inline:auto;display:flex;align-items:center;gap:1.4rem;padding-block:0.7rem;min-height:64px}

.wordmark{display:inline-flex;align-items:center;gap:0.6rem;text-decoration:none;color:var(--ink)}
.wordmark__pin{display:grid;place-items:center;width:38px;height:38px;border:1.5px solid var(--rule-strong);border-radius:50%;color:var(--brand);flex:none;background:var(--card)}
.wordmark__txt{display:flex;flex-direction:column;line-height:0.98}
.wordmark__line1{font-family:var(--cond);font-weight:600;text-transform:uppercase;letter-spacing:0.14em;font-size:0.86rem;color:var(--ink)}
.wordmark__line2{font-family:var(--serif);font-style:italic;font-weight:600;font-size:1.06rem;color:var(--brand)}

.nav-links{display:flex;gap:clamp(0.8rem,2vw,1.7rem);margin-left:auto}
.nav-links a{font-family:var(--cond);font-weight:500;text-transform:uppercase;letter-spacing:0.13em;font-size:0.8rem;text-decoration:none;color:var(--ink-2);padding:0.4rem 0;position:relative;transition:color .2s var(--ease)}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;background:var(--accent-2);transition:right .28s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:0}
.nav__cta{margin-left:0}
.nav-burger{display:none;flex-direction:column;gap:4px;width:44px;height:44px;align-items:center;justify-content:center;background:none;border:1.5px solid var(--rule);border-radius:var(--radius);cursor:pointer;margin-left:auto}
.nav-burger span{display:block;width:20px;height:1.7px;background:var(--ink);transition:transform .3s var(--ease),opacity .3s var(--ease)}
.nav.open .nav-burger span:nth-child(1){transform:translateY(5.7px) rotate(45deg)}
.nav.open .nav-burger span:nth-child(2){opacity:0}
.nav.open .nav-burger span:nth-child(3){transform:translateY(-5.7px) rotate(-45deg)}

@media(max-width:880px){
  .nav__cta{display:none}
  .nav-burger{display:flex}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--page);border-bottom:1.5px solid var(--rule);
    max-height:0;overflow:hidden;transition:max-height .38s var(--ease);margin-left:0}
  .nav.open .nav-links{max-height:60vh}
  .nav-links a{padding:1rem 1.2rem;border-top:1px solid var(--rule-soft);width:min(100% - 2.4rem,var(--wrap));margin-inline:auto;font-size:0.92rem}
  .nav-links a::after{display:none}
}

/* ---- page frame (double rule just inside viewport) ------------------------ */
.page-frame{position:absolute;inset:14px;border:1.5px solid var(--rule);pointer-events:none;z-index:1}
.page-frame::before{content:"";position:absolute;inset:4px;border:1px solid var(--rule-soft)}
@media(max-width:760px){.page-frame{inset:8px}}

/* ============================================================================
   HERO — asymmetric: copy column + offset arched photo
   ============================================================================ */
.hero{position:relative;padding-top:clamp(40px,6vw,84px);padding-bottom:clamp(48px,7vw,96px);overflow:hidden}
.hero__grid{
  position:relative;z-index:2;
  width:min(100% - 2.4rem,var(--wrap));margin-inline:auto;
  display:grid;grid-template-columns:minmax(0,1.02fr) minmax(0,1.18fr);
  align-items:center;gap:clamp(28px,5vw,72px);
  padding-top:clamp(18px,3vw,40px);
}
.hero__copy{max-width:36rem}
.hero__kicker{display:inline-block;padding-bottom:0.6rem;border-bottom:1.5px solid var(--rule);margin-bottom:1.4rem}
.hero__title{font-size:var(--t-hero);font-weight:600;line-height:0.98}
.hero__title em{display:block;color:var(--brand);font-weight:600;margin-top:0.06em}
.hero__lead{font-size:var(--t-body);color:var(--ink-2);margin-top:1.4rem;max-width:38ch;text-wrap:pretty;line-height:1.6}
.hero__script{display:block;font-family:var(--script);font-size:1.5em;color:var(--accent-2-dp);line-height:1;margin-top:0.5rem;transform:rotate(-2deg);transform-origin:left}
.hero__cta{display:flex;flex-wrap:wrap;gap:0.85rem;margin-top:1.9rem}
.hero__addr{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.1em;font-size:0.74rem;color:var(--muted);margin-top:1.7rem;display:flex;align-items:center;gap:0.5rem}
.hero__addr span{color:var(--accent-2)}

.hero__figure{position:relative;margin:0;justify-self:end;width:100%}

/* framed photo with mat + caption */
.frame{position:relative;background:var(--card);padding:clamp(10px,1.4vw,16px);border:1.5px solid var(--rule);box-shadow:var(--hard-shadow)}
.frame__mat{padding:clamp(6px,0.9vw,10px);border:1px solid var(--rule-soft);background:var(--card-2)}
.frame__photo{position:relative;overflow:hidden;border:1px solid var(--rule-strong)}
.frame__photo img{width:100%;height:100%;object-fit:cover}
.frame__cap{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.2em;font-size:0.72rem;color:var(--ink-2);text-align:center;padding-top:0.7rem}

.frame--arch .frame__photo{border-radius:48% 48% 6px 6px / 30% 30% 6px 6px}
.hero__frame .frame__photo{aspect-ratio:4/3.35}
.hero__frame .frame__photo img{transform:scale(1.04)} /* room for slight parallax drift */

/* the wash applied to all photos */
.photo-wash{position:relative}
.photo-wash img{filter:var(--photo-wash)}
.photo-wash::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,color-mix(in oklab,var(--brand) 8%,transparent),color-mix(in oklab,var(--accent-2) 9%,transparent));
  mix-blend-mode:multiply;opacity:0.55}
.photo-wash--sepia img{filter:sepia(0.45) saturate(0.8) contrast(0.96) brightness(1.04)}

/* rating stamp on hero */
.stamp{
  position:absolute;background:var(--card);border-radius:3px;
  box-shadow:3px 4px 0 color-mix(in oklab,var(--accent-2) 55%,transparent);
}
.stamp__perf,.quote__perf{
  position:absolute;inset:-6px;border-radius:5px;
  background:
    radial-gradient(circle at center, transparent 3px, var(--card) 3.4px) 0 0 / 9px 9px;
  -webkit-mask:linear-gradient(#111,#111) content-box,linear-gradient(#111,#111);
  mask:linear-gradient(#111,#111) content-box,linear-gradient(#111,#111);
  -webkit-mask-composite:xor;mask-composite:exclude;padding:6px;
  pointer-events:none;
}
.stamp--rating{
  bottom:clamp(-18px,-1vw,-10px);left:clamp(-18px,-1.5vw,-8px);
  padding:14px 16px;transform:rotate(-6deg);border:1.5px dashed var(--accent-2);
}
.stamp__inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:2px;border:1px solid color-mix(in oklab,var(--accent-2) 40%,transparent);padding:8px 12px}
.stamp__big{font-family:var(--serif);font-weight:700;font-size:1.9rem;line-height:0.9;color:var(--accent-2-dp)}
.stamp__star{font-size:0.7em;vertical-align:0.18em;margin-left:1px}
.stamp__small{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.13em;font-size:0.58rem;color:var(--ink-2);max-width:11ch;line-height:1.3}

/* ============================================================================
   TRUST — torn ticket
   ============================================================================ */
.trust{padding-block:clamp(34px,4.5vw,56px);background:var(--page)}
.ticket{
  position:relative;background:var(--card);border:1.5px solid var(--rule-strong);
  box-shadow:var(--hard-shadow);border-radius:var(--radius);
  padding:clamp(20px,3vw,30px) clamp(18px,3vw,40px);
}
.ticket__head{text-align:center;padding-bottom:0.9rem;margin-bottom:1.2rem;border-bottom:1.5px dashed var(--rule);position:relative}
/* notches at the dashed seam */
.ticket__head::before,.ticket__head::after{
  content:"";position:absolute;bottom:-9px;width:18px;height:18px;border-radius:50%;
  background:var(--page);border:1.5px solid var(--rule-strong);
}
.ticket__head::before{left:-32px}
.ticket__head::after{right:-32px}
.ticket__stubs{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2.5vw,30px)}
.tstat{text-align:center;position:relative}
.tstat+.tstat::before{content:"";position:absolute;left:calc(-1 * clamp(7px,1.25vw,15px));top:10%;bottom:10%;border-left:1px solid var(--rule-soft)}
.tstat__n{display:block;font-family:var(--serif);font-weight:700;font-size:clamp(1.9rem,1rem + 2.6vw,2.9rem);line-height:0.95;color:var(--brand-deep);letter-spacing:-0.01em}
.tstat__l{display:block;font-family:var(--cond);text-transform:uppercase;letter-spacing:0.12em;font-size:0.68rem;color:var(--ink-2);margin-top:0.55rem;line-height:1.35;text-wrap:balance}
@media(max-width:640px){.ticket__stubs{grid-template-columns:1fr 1fr;gap:22px 14px}.tstat:nth-child(odd)::before{display:none}.ticket__head::before,.ticket__head::after{display:none}}

/* ============================================================================
   STORY
   ============================================================================ */
.story__body{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:clamp(28px,5vw,68px);align-items:start}
.story__lead{max-width:62ch}
.story__lead p{font-size:var(--t-body);color:var(--ink);line-height:1.66;text-wrap:pretty}
.story__lead p+p{margin-top:1.1rem;color:var(--ink-2)}
.story__lead em{color:var(--brand);font-style:italic}
.story__seal{justify-self:end}

.seal{position:relative;width:clamp(140px,16vw,178px);aspect-ratio:1;display:grid;place-items:center}
.seal__ring{position:absolute;inset:0;width:100%;height:100%;animation:spin 60s linear infinite}
.seal__text{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.18em;font-size:7.4px;fill:var(--accent-2-dp);font-weight:500}
.seal__core{display:grid;place-items:center;width:54%;aspect-ratio:1;border:1.5px solid var(--accent-2);border-radius:50%;color:var(--brand);background:var(--card)}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:760px){.story__body{grid-template-columns:1fr}.story__seal{justify-self:center;margin-top:0.5rem}}

/* ============================================================================
   DESTINATIONS — masonry postcard wall
   ============================================================================ */
.masonry{columns:3;column-gap:clamp(16px,2vw,26px)}
.pcard{
  break-inside:avoid;margin-bottom:clamp(16px,2vw,26px);
  background:var(--card);border:1.5px solid var(--rule);box-shadow:var(--hard-shadow);
  padding:clamp(9px,1vw,13px);border-radius:var(--radius);
}
.pcard__photo{overflow:hidden;border:1px solid var(--rule-strong);aspect-ratio:5/4}
.pcard--tall .pcard__photo{aspect-ratio:4/5.2}
.pcard__photo img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.pcard:hover .pcard__photo img{transform:scale(1.045)}
.pcard__cap{display:flex;flex-direction:column;padding:0.75rem 0.4rem 0.35rem;text-align:center;border-top:1px dashed var(--rule);margin-top:0.65rem}
.pcard__name{font-family:var(--serif);font-weight:600;font-size:1.18rem;color:var(--ink);line-height:1.1}
.pcard__sub{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.16em;font-size:0.64rem;color:var(--accent-2-dp);margin-top:0.3rem}
@media(max-width:900px){.masonry{columns:2}}
@media(max-width:540px){.masonry{columns:1;max-width:420px;margin-inline:auto}.pcard--tall .pcard__photo,.pcard__photo{aspect-ratio:5/4}}

/* ============================================================================
   PACKAGES — ticketed cards
   ============================================================================ */
.pkg__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,340px),1fr));gap:clamp(22px,3vw,38px)}
.pticket{
  display:flex;flex-direction:column;background:var(--card);
  border:1.5px solid var(--rule-strong);border-radius:var(--radius);
  box-shadow:var(--hard-shadow);overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.pticket:hover{transform:translate(-2px,-2px) rotate(-0.4deg);box-shadow:10px 10px 0 var(--rule)}
.pticket__photo{position:relative;aspect-ratio:3/2;overflow:hidden;border-bottom:1.5px dashed var(--rule)}
.pticket__photo img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.pticket:hover .pticket__photo img{transform:scale(1.05)}
.tag{
  position:absolute;top:12px;left:12px;font-family:var(--cond);text-transform:uppercase;
  letter-spacing:0.14em;font-size:0.66rem;font-weight:600;padding:0.35em 0.7em;
  background:var(--brand);color:oklch(0.97 0.02 86);border-radius:2px;
  box-shadow:2px 2px 0 var(--brand-deep);
}
.tag--feature{background:var(--accent-2-dp);box-shadow:2px 2px 0 oklch(0.38 0.08 38)}
.tag--alt{background:var(--gold);color:var(--ink);box-shadow:2px 2px 0 oklch(0.58 0.07 76)}

/* perforation between photo and body */
.pticket__perf{position:relative;height:0}
.pticket__perf::before,.pticket__perf::after{
  content:"";position:absolute;top:-9px;width:18px;height:18px;border-radius:50%;
  background:var(--page);border:1.5px solid var(--rule-strong);
}
.section--banded .pticket__perf::before,.section--banded .pticket__perf::after{background:var(--page-2)}
.pticket__perf::before{left:-10px}
.pticket__perf::after{right:-10px}

.pticket__body{display:flex;flex-direction:column;flex:1;padding:clamp(16px,2vw,22px) clamp(16px,2vw,22px) clamp(16px,2vw,20px)}
.pticket__meta{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.12em;font-size:0.68rem;color:var(--accent-2-dp);margin-bottom:0.5rem}
.pticket__title{font-size:var(--t-h3);font-weight:600;line-height:1.06}
.pticket__desc{font-size:0.98rem;color:var(--ink-2);margin-top:0.7rem;line-height:1.55;text-wrap:pretty;flex:1}
.pticket__foot{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-top:1.2rem;padding-top:1rem;border-top:1px dashed var(--rule)}
.price{display:flex;flex-direction:column;line-height:1}
.price__from{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.14em;font-size:0.6rem;color:var(--muted)}
.price__n{font-family:var(--serif);font-weight:700;font-size:1.7rem;color:var(--brand-deep);margin-top:0.12rem;letter-spacing:-0.01em}
.price__pp{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.1em;font-size:0.6rem;color:var(--muted);margin-top:0.18rem}

/* ============================================================================
   PLAN — route line
   ============================================================================ */
.route{position:relative;max-width:760px;margin-inline:auto;padding-left:clamp(48px,8vw,84px)}
.route__line{position:absolute;left:clamp(20px,3.4vw,34px);top:6px;bottom:6px;width:12px;height:calc(100% - 12px);overflow:visible}
.route__path{fill:none;stroke:var(--accent-2);stroke-width:2;stroke-dasharray:7 8;stroke-linecap:round;
  /* drawn-in handled by JS via dashoffset on a second layer; static dashes here read as a map route */
}
.route__step{position:relative;padding-bottom:clamp(26px,4vw,46px)}
.route__step:last-child{padding-bottom:0}
.route__pin{
  position:absolute;left:calc(-1 * clamp(48px,8vw,84px));top:0;
  width:clamp(42px,7vw,58px);height:clamp(42px,7vw,58px);
  display:grid;place-items:center;background:var(--card);
  border:1.5px solid var(--accent-2);border-radius:50% 50% 50% 2px;transform:rotate(-45deg);
  box-shadow:3px 3px 0 color-mix(in oklab,var(--accent-2) 45%,transparent);
}
.route__pin span{transform:rotate(45deg);font-family:var(--serif);font-weight:700;font-size:1.15rem;color:var(--accent-2-dp)}
.route__card{background:var(--card);border:1.5px solid var(--rule);border-radius:var(--radius);padding:clamp(16px,2.2vw,24px);box-shadow:5px 5px 0 var(--rule-soft)}
.route__card h3{font-size:var(--t-h3);font-weight:600}
.route__card p{font-size:0.99rem;color:var(--ink-2);margin-top:0.5rem;line-height:1.55;text-wrap:pretty}
@media(max-width:540px){.route{padding-left:58px}.route__pin{left:-58px;width:46px;height:46px}.route__line{left:18px}}

/* ============================================================================
   WHY — ruled cards
   ============================================================================ */
.why__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,278px),1fr));gap:clamp(0px,0px,0px)}
.wcard{
  padding:clamp(22px,2.6vw,32px);border:1.5px solid var(--rule);margin:-0.75px;
  background:var(--page);transition:background .3s var(--ease);
}
.wcard:hover{background:var(--card)}
.wcard__icn{display:grid;place-items:center;width:50px;height:50px;border:1.5px solid var(--rule-strong);border-radius:50%;color:var(--brand);margin-bottom:1rem;background:var(--card)}
.wcard h3{font-size:1.3rem;font-weight:600}
.wcard p{font-size:0.97rem;color:var(--ink-2);margin-top:0.55rem;line-height:1.55;text-wrap:pretty}

/* ============================================================================
   REVIEWS — stamped quotes
   ============================================================================ */
.reviews__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,310px),1fr));gap:clamp(20px,2.6vw,32px)}
.quote{
  position:relative;background:var(--card);border:1.5px solid var(--rule);border-radius:var(--radius);
  box-shadow:var(--hard-shadow);padding:clamp(22px,2.8vw,30px);padding-top:clamp(30px,3.4vw,40px);
}
.quote__stamp{
  position:absolute;top:-14px;right:18px;background:var(--card);
  padding:0.5rem 0.7rem;border:1.5px dashed var(--accent-2);border-radius:3px;
  transform:rotate(-5deg);color:var(--accent-2-dp);font-size:0.86rem;letter-spacing:0.12em;
  box-shadow:2px 3px 0 color-mix(in oklab,var(--accent-2) 50%,transparent);
}
.quote blockquote p{font-family:var(--serif);font-size:1.16rem;font-style:italic;line-height:1.5;color:var(--ink);text-wrap:pretty}
.quote blockquote p::before{content:"\201C";color:var(--accent-2);font-size:1.4em;line-height:0;vertical-align:-0.25em;margin-right:0.05em}
.quote figcaption{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.16em;font-size:0.68rem;color:var(--muted);margin-top:1rem;padding-top:0.8rem;border-top:1px solid var(--rule-soft)}

/* ============================================================================
   CONTACT — postcard / return address
   ============================================================================ */
.postcard{
  background:var(--card);border:1.5px solid var(--rule-strong);border-radius:var(--radius);
  box-shadow:var(--hard-shadow);
  display:grid;grid-template-columns:1.25fr auto 0.95fr;
  gap:clamp(20px,3.5vw,52px);align-items:center;
  padding:clamp(26px,4vw,50px);
}
.postcard__h{font-size:var(--t-h2);font-weight:600;margin-top:0.6rem;line-height:1.02}
.postcard__body{font-size:var(--t-body);color:var(--ink-2);margin-top:1rem;max-width:42ch;text-wrap:pretty}
.postcard__cta{display:flex;flex-wrap:wrap;gap:0.85rem;margin-top:1.7rem}
.postcard__divider{align-self:stretch;border-left:1.5px dashed var(--rule)}
.postcard__right{display:grid;justify-items:center;text-align:center;gap:1.1rem}
.postmark{width:clamp(118px,14vw,138px);color:var(--accent-2-dp);opacity:0.92}
.postmark__o{fill:none;stroke:var(--accent-2);stroke-width:1.5}
.postmark__o--in{stroke-dasharray:3 4;opacity:0.7}
.postmark__t{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.14em;font-size:8px;fill:var(--accent-2-dp);font-weight:500}
.postmark__c{font-family:var(--serif);font-weight:700;font-size:24px;fill:var(--brand-deep);text-anchor:middle}
.postmark__c2{font-family:var(--serif);font-weight:700;font-size:16px;fill:var(--accent-2-dp);text-anchor:middle}
.addr{font-style:normal;line-height:1.55}
.addr__role{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.2em;font-size:0.62rem;color:var(--muted);margin-bottom:0.4rem}
.addr__name{font-family:var(--serif);font-style:italic;font-weight:600;font-size:1.24rem;color:var(--brand);margin-bottom:0.35rem}
.addr p{font-size:0.94rem;color:var(--ink-2)}
.addr__links{margin-top:0.7rem}
.addr__links a{color:var(--brand-deep);text-decoration:none;border-bottom:1px solid var(--rule);transition:border-color .2s,color .2s}
.addr__links a:hover{color:var(--accent-2-dp);border-bottom-color:var(--accent-2)}
@media(max-width:820px){
  .postcard{grid-template-columns:1fr}
  .postcard__divider{border-left:none;border-top:1.5px dashed var(--rule);height:0}
}

/* ============================================================================
   FOOTER
   ============================================================================ */
.foot{position:relative;background:var(--ink);color:oklch(0.88 0.02 84);padding-top:clamp(48px,6vw,80px);padding-bottom:2rem;margin-top:0;overflow:hidden}
.page-frame--foot{border-color:oklch(0.5 0.02 70 / .45)}
.page-frame--foot::before{border-color:oklch(0.5 0.02 70 / .3)}
.foot__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.4fr 1fr auto;gap:clamp(24px,4vw,56px);align-items:start;padding-bottom:clamp(28px,4vw,48px);border-bottom:1px solid oklch(0.5 0.02 70 / .4)}
.wordmark--foot .wordmark__line1{color:oklch(0.9 0.02 84)}
.wordmark--foot .wordmark__line2{color:var(--gold)}
.foot__tag{font-size:0.96rem;color:oklch(0.78 0.02 80);margin-top:0.9rem;max-width:38ch;line-height:1.55;text-wrap:pretty}
.foot__nav{display:flex;flex-direction:column;gap:0.6rem}
.foot__nav a{font-family:var(--cond);text-transform:uppercase;letter-spacing:0.13em;font-size:0.78rem;color:oklch(0.8 0.02 80);text-decoration:none;transition:color .2s}
.foot__nav a:hover{color:var(--gold)}
.foot__post{display:flex;gap:0.7rem;flex-wrap:wrap}
.foot__base{position:relative;z-index:2;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:1.4rem;font-family:var(--cond);text-transform:uppercase;letter-spacing:0.08em;font-size:0.7rem;color:oklch(0.66 0.02 78)}
.foot__base p{margin:0}
.foot__disclaimer{color:oklch(0.6 0.02 78)}
@media(max-width:760px){.foot__inner{grid-template-columns:1fr}}

/* ============================================================================
   MOTION — reveal/settle + stamp press (paired in app.js)
   ============================================================================ */
[data-reveal]{opacity:0;transform:translateY(16px) rotate(-0.6deg);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-hero-el]{opacity:0;transform:translateY(14px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-hero-el].in{opacity:1;transform:none}
.hero__figure[data-hero-el]{transform:translateY(20px) rotate(-1deg)}
.hero__figure[data-hero-el].in{transform:none}

/* stamp press: starts slightly small + rotated, presses in */
[data-stamp]{transition:transform .35s var(--ease-press),opacity .35s var(--ease)}
[data-stamp]:not(.pressed){opacity:0}
.stamp--rating[data-stamp]:not(.pressed){transform:rotate(-18deg) scale(0.8)}
.stamp--rating.pressed{transform:rotate(-6deg) scale(1)}
.quote__stamp[data-stamp]:not(.pressed){transform:rotate(-16deg) scale(0.82)}
.quote__stamp.pressed{transform:rotate(-5deg) scale(1)}

/* stagger handled inline via transition-delay set in JS; default subtle */

/* ============================================================================
   REDUCED MOTION — everything visible & beautiful at rest
   ============================================================================ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  html{scroll-behavior:auto}
  [data-reveal],[data-hero-el],.hero__figure[data-hero-el]{opacity:1 !important;transform:none !important}
  [data-stamp]{opacity:1 !important}
  .stamp--rating[data-stamp]{transform:rotate(-6deg) scale(1) !important}
  .quote__stamp[data-stamp]{transform:rotate(-5deg) scale(1) !important}
  .seal__ring{animation:none !important}
  .pcard__photo img,.pticket__photo img{transition:none !important}
}

/* ---- print --------------------------------------------------------------- */
@media print{
  .nav,.demo-banner,.scroll-progress,.page-frame{display:none}
  body::after{display:none}
  *{box-shadow:none !important}
}
