/*
  ============================================================
  UNITED KITES — "FLY FREE"
  Modern menswear · Bangalore · Edappal · Calicut
  ------------------------------------------------------------
  Built from the brand's REAL identity (Instagram @unitedkitesofficial
  + storefront + online store shop.unitedkites.in):
    • Logo  — black upward arrow inside a coral ring
    • Tag   — FLY FREE · "No limits, no boundaries"
    • Voice — bold, confident, young, clean
    • Goods — abstract-print casual shirts (₹899–₹1,299), trousers
  ------------------------------------------------------------
  Palette:
    --coral (#D67A60)   signature — from the logo ring + promos
    --ink   (#1A1714)   near-black (logo black is #1F1B1C)
    --paper (#FAF6F0)   warm off-white (their promo background)
  Type:
    Clash Display (Fontshare) — bold geometric headlines
    General Sans  (Fontshare) — clean body
    JetBrains Mono            — labels / codes
  ------------------------------------------------------------
  Hard rules (CLAUDE.md): NO Lenis · Arabic numerals · 16px min body
  ============================================================
*/

/* ===================== TOKENS ===================== */
:root{
  --paper:      #FAF6F0;
  --paper-2:    #F1EAE0;   /* alt surface */
  --paper-3:    #FCFAF6;   /* lightest card */
  --line:       rgba(26,23,20,0.12);
  --line-2:     rgba(26,23,20,0.07);

  --ink:        #1A1714;
  --ink-2:      #2B2620;
  --graphite:   #6E655B;
  --graphite-2: #938A7E;

  --coral:      #D67A60;
  --coral-deep: #B85B40;
  --coral-soft: #E8A48F;
  --coral-tint: rgba(214,122,96,0.12);

  --cream-card: #FFFFFF;

  --f-head: "Clash Display", "Archivo", -apple-system, sans-serif;
  --f-body: "General Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --f-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;

  --max: 1480px;
  --gutter: clamp(1.4rem, 4vw, 4rem);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out-back: cubic-bezier(.34,1.4,.64,1);
  --t-fast: 200ms var(--ease);
  --t: 440ms var(--ease);
  --t-slow: 800ms var(--ease);

  --radius: 4px;
}

/* ===================== RESET ===================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--f-body);
  font-size:16.5px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--coral);color:#fff}
:focus-visible{outline:2px solid var(--coral);outline-offset:3px}

/* ===================== TYPE ===================== */
.head{font-family:var(--f-head);font-weight:600;letter-spacing:-0.01em;line-height:0.98}
.h-hero{
  font-family:var(--f-head);font-weight:600;
  font-size:clamp(3.4rem, 10.5vw, 9.5rem);
  letter-spacing:-0.025em;line-height:0.9;text-transform:uppercase;
}
.h-section{
  font-family:var(--f-head);font-weight:600;
  font-size:clamp(2.2rem, 5.4vw, 4.4rem);
  letter-spacing:-0.02em;line-height:0.98;text-transform:uppercase;
}
.h-sub{
  font-family:var(--f-head);font-weight:500;
  font-size:clamp(1.5rem, 2.8vw, 2.2rem);
  letter-spacing:-0.01em;line-height:1.1;
}
.eyebrow{
  font-family:var(--f-mono);font-size:.72rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--coral);
  display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:22px;height:1px;background:currentColor;display:inline-block}
.eyebrow--plain::before{display:none}
.eyebrow--muted{color:var(--graphite)}

p{font-size:1.0625rem;line-height:1.68;color:var(--ink-2)}
.lede{
  font-size:clamp(1.12rem,1.5vw,1.35rem);line-height:1.55;
  color:var(--ink);font-weight:400;
}
.mono{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite)}

.coral{color:var(--coral)}

/* ===================== LAYOUT ===================== */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
.section{padding:clamp(4.5rem,8vw,8.5rem) 0;position:relative}

/* ===================== KITE / FLY-FREE MOTIF ===================== */
/* thin coral flight-path divider with a kite at the end */
.flightline{
  display:flex;align-items:center;gap:1rem;padding:2.5rem 0;color:var(--coral);
}
.flightline::before{
  content:"";flex:1;height:1px;
  background:repeating-linear-gradient(90deg, var(--coral) 0 7px, transparent 7px 14px);
  opacity:.5;
}
.flightline svg{width:22px;height:22px;flex-shrink:0}

/* ===================== NAV ===================== */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem;
  padding:1rem var(--gutter);
  background:rgba(250,246,240,0.82);
  backdrop-filter:blur(16px) saturate(150%);
  -webkit-backdrop-filter:blur(16px) saturate(150%);
  border-bottom:1px solid transparent;
  transition:border-color var(--t), padding var(--t), background var(--t);
}
.nav.is-scrolled{border-bottom-color:var(--line);padding-top:.65rem;padding-bottom:.65rem}
.nav__brand{display:flex;align-items:center;gap:.7rem;color:var(--ink)}
.nav__brand .logo{width:38px;height:38px;flex-shrink:0}
.nav__brand .wm{
  font-family:var(--f-head);font-weight:600;font-size:1.1rem;
  letter-spacing:.02em;text-transform:uppercase;line-height:1;
}
.nav__brand .wm span{
  display:block;font-family:var(--f-mono);font-weight:400;font-size:.55rem;
  letter-spacing:.42em;color:var(--coral);margin-top:.22rem;
}
.nav__links{display:flex;gap:2.4rem;justify-content:center}
.nav__links a{
  font-family:var(--f-body);font-size:.9rem;font-weight:500;color:var(--ink);
  position:relative;padding:.4rem 0;display:inline-flex;align-items:baseline;gap:.4rem;
}
.nav__links a .n{font-family:var(--f-mono);font-size:.6rem;color:var(--coral);letter-spacing:.1em}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:.05rem;height:2px;background:var(--coral);transition:right var(--t)}
.nav__links a:hover::after,.nav__links a.is-active::after{right:0}
.nav__cta{
  display:inline-flex;align-items:center;gap:.55rem;padding:.72rem 1.2rem;
  background:var(--ink);color:var(--paper);border:1px solid var(--ink);
  font-family:var(--f-body);font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  transition:background var(--t),border-color var(--t),transform var(--t-fast);
}
.nav__cta:hover{background:var(--coral);border-color:var(--coral)}
.nav__cta .arrow{transition:transform var(--t)}
.nav__cta:hover .arrow{transform:translate(3px,-3px)}
.nav__burger{display:none;width:38px;height:38px;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav__burger span{display:block;width:23px;height:2px;background:var(--ink);transition:transform var(--t),opacity var(--t-fast)}
.nav.is-open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.is-open .nav__burger span:nth-child(2){opacity:0}
.nav.is-open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobilenav{
  position:fixed;inset:0;z-index:55;background:var(--paper);
  display:flex;flex-direction:column;justify-content:center;padding:6rem var(--gutter) 3rem;gap:1.3rem;
  transform:translateY(-100%);transition:transform .55s var(--ease);pointer-events:none;
}
.mobilenav.is-open{transform:translateY(0);pointer-events:auto}
.mobilenav a{
  font-family:var(--f-head);font-weight:600;text-transform:uppercase;
  font-size:clamp(2.2rem,9vw,3.4rem);letter-spacing:-0.015em;color:var(--ink);
  line-height:1;display:flex;align-items:baseline;gap:1rem;
}
.mobilenav a .n{font-family:var(--f-mono);font-size:.7rem;color:var(--coral)}
.mobilenav__foot{
  position:absolute;left:var(--gutter);right:var(--gutter);bottom:2rem;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.6rem;
  font-family:var(--f-mono);font-size:.66rem;letter-spacing:.16em;color:var(--graphite);text-transform:uppercase;
}

/* ===================== BUTTONS ===================== */
.btn{
  display:inline-flex;align-items:center;gap:.7rem;padding:1.05rem 1.7rem;
  font-family:var(--f-body);font-size:.84rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
  background:var(--ink);color:var(--paper);border:1px solid var(--ink);
  transition:background var(--t),border-color var(--t),color var(--t),transform var(--t-fast);cursor:pointer;
}
.btn:hover{background:var(--coral);border-color:var(--coral);color:#fff}
.btn .arrow{transition:transform var(--t)}
.btn:hover .arrow{transform:translate(4px,-4px)}
.btn--coral{background:var(--coral);border-color:var(--coral);color:#fff}
.btn--coral:hover{background:var(--coral-deep);border-color:var(--coral-deep)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn--light{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn--light:hover{background:var(--coral);border-color:var(--coral);color:#fff}
.btn--inv-ghost{background:transparent;color:var(--paper);border-color:rgba(250,246,240,.5)}
.btn--inv-ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

.lnk{
  display:inline-flex;align-items:center;gap:.5rem;color:var(--ink);
  font-family:var(--f-mono);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;
  position:relative;padding-bottom:.2rem;
}
.lnk::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--ink);transform-origin:right;transition:transform var(--t)}
.lnk:hover::after{transform:scaleX(0);transform-origin:left}
.lnk--coral{color:var(--coral)}
.lnk--coral::after{background:var(--coral)}

/* ===================== HERO ===================== */
.hero{
  position:relative;min-height:100dvh;display:grid;
  grid-template-columns:1.15fr .85fr;gap:0;
  padding-top:5rem;overflow:hidden;background:var(--paper);
}
.hero__left{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(2rem,5vw,5rem) clamp(1.4rem,4vw,4rem) clamp(3rem,5vw,5rem);
  position:relative;z-index:2;
}
.hero__eyebrow{margin-bottom:1.6rem}
.hero__title{
  font-family:var(--f-head);font-weight:600;text-transform:uppercase;
  font-size:clamp(3.2rem,8.5vw,7.6rem);letter-spacing:-0.025em;line-height:0.88;
  color:var(--ink);
}
.hero__title .ln{display:block;overflow:hidden}
.hero__title .ln > span{display:inline-block;will-change:transform}
.hero__title .fly{color:var(--coral);position:relative;display:inline-block}
.hero__sub{
  margin-top:1.7rem;max-width:44ch;font-size:1.12rem;line-height:1.6;color:var(--ink-2);
}
.hero__ctas{margin-top:2.3rem;display:flex;gap:.7rem;flex-wrap:wrap}
.hero__meta{
  margin-top:2.8rem;display:flex;gap:2.4rem;flex-wrap:wrap;
  padding-top:1.6rem;border-top:1px solid var(--line);
}
.hero__meta .item .v{font-family:var(--f-head);font-weight:600;font-size:1.5rem;letter-spacing:-0.01em;display:block;line-height:1}
.hero__meta .item .v .coral{color:var(--coral)}
.hero__meta .item .l{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.16em;color:var(--graphite);text-transform:uppercase;margin-top:.4rem;display:block}
.hero__right{position:relative;overflow:hidden;background:var(--ink)}
.hero__right img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__badge{
  position:absolute;left:0;bottom:2rem;z-index:3;
  background:var(--coral);color:#fff;padding:.85rem 1.3rem;
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  display:flex;align-items:center;gap:.6rem;
}
.hero__badge svg{width:16px;height:16px}
/* floating kite glyph in hero */
.hero__kite{
  position:absolute;right:8%;top:16%;z-index:1;width:60px;height:60px;color:var(--coral);opacity:.9;
  animation:floaty 6s ease-in-out infinite;
}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-16px) rotate(4deg)}}

/* ===================== MARQUEE ===================== */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;padding:1.3rem 0;background:var(--ink);
}
.marquee__track{
  display:flex;gap:2.6rem;white-space:nowrap;animation:marquee 34s linear infinite;
  font-family:var(--f-head);font-weight:600;text-transform:uppercase;
  font-size:clamp(1.3rem,2.6vw,2rem);letter-spacing:0;color:var(--paper);
}
.marquee__track span{display:inline-flex;align-items:center;gap:2.6rem}
.marquee__track .dot{color:var(--coral)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===================== INTRO / MANIFESTO ===================== */
.intro{
  display:grid;grid-template-columns:1fr 1.7fr;gap:clamp(2rem,5vw,5rem);
  padding:clamp(4.5rem,8vw,8rem) var(--gutter);align-items:start;
}
.intro__side .eyebrow{margin-bottom:1.4rem}
.intro__body p{
  font-family:var(--f-head);font-weight:400;font-size:clamp(1.5rem,2.9vw,2.5rem);
  line-height:1.18;letter-spacing:-0.01em;color:var(--ink);
}
.intro__body p + p{margin-top:1.3rem}
.intro__body .coral{color:var(--coral)}

/* ===================== SHOWCASE (asymmetric product/store mosaic) ===================== */
.showcase{padding:clamp(4rem,7vw,7rem) var(--gutter)}
.showcase__head{display:grid;grid-template-columns:1.4fr 1fr;gap:2rem;align-items:end;margin-bottom:3rem}
.showcase__head h2{max-width:16ch}
.showcase__head .right{display:flex;flex-direction:column;align-items:flex-start;gap:1rem}
.showcase__head .right p{color:var(--graphite);max-width:38ch}
.mosaic{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:auto;gap:1.1rem}
.tile{position:relative;overflow:hidden;background:var(--paper-2);cursor:pointer}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.tile:hover img{transform:scale(1.05)}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(26,23,20,.78) 0%,rgba(26,23,20,0) 55%)}
.tile__tag{
  position:absolute;top:1rem;left:1rem;z-index:2;
  font-family:var(--f-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  color:#fff;background:rgba(26,23,20,.55);padding:.35rem .6rem;backdrop-filter:blur(8px);
}
.tile__cap{position:absolute;left:1.2rem;right:1.2rem;bottom:1.1rem;z-index:2;color:#fff;display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}
.tile__cap .name{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:clamp(1.2rem,1.9vw,1.7rem);letter-spacing:-0.01em;line-height:1}
.tile__cap .meta{font-family:var(--f-mono);font-size:.64rem;letter-spacing:.12em;color:rgba(255,255,255,.82);text-transform:uppercase}
.tile--a{grid-column:span 7;aspect-ratio:16/12}
.tile--b{grid-column:span 5;aspect-ratio:3/4}
.tile--c{grid-column:span 4;aspect-ratio:4/5}
.tile--d{grid-column:span 4;aspect-ratio:4/5}
.tile--e{grid-column:span 4;aspect-ratio:4/5}
.tile--note{
  grid-column:span 5;aspect-ratio:16/12;background:var(--coral);color:#fff;
  display:flex;flex-direction:column;justify-content:space-between;padding:1.8rem;
}
.tile--note::after{display:none}
.tile--note .eyebrow{color:#fff}
.tile--note .nt{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:clamp(1.5rem,2.4vw,2.2rem);line-height:1;letter-spacing:-0.01em;margin-top:.6rem}
.tile--note .lnk{color:#fff;align-self:flex-start;margin-top:auto}
.tile--note .lnk::after{background:#fff}

/* ===================== SPLIT FEATURE (real photo + body) ===================== */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.split__img{position:relative;min-height:560px;overflow:hidden;background:var(--ink)}
.split__img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.split__img .tag{position:absolute;left:1.2rem;top:1.2rem;font-family:var(--f-mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:rgba(26,23,20,.6);padding:.45rem .7rem;backdrop-filter:blur(8px)}
.split__body{
  background:var(--paper-2);padding:clamp(3rem,6vw,5.5rem) clamp(2rem,5vw,4.5rem);
  display:flex;flex-direction:column;justify-content:center;gap:1.4rem;
}
.split__body h2{max-width:15ch}
.split__body p{max-width:46ch;color:var(--ink-2)}
.split--rev .split__img{order:2}

/* ===================== PRODUCT CARDS ===================== */
.prodwrap{padding:clamp(3rem,5vw,4rem) var(--gutter) clamp(5rem,8vw,7rem)}
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem 1.3rem}
.prod{display:flex;flex-direction:column;gap:.95rem;cursor:pointer;position:relative}
.prod__img{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--paper-2)}
.prod__img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.prod:hover .prod__img img{transform:scale(1.045)}
.prod__no{position:absolute;top:.7rem;left:.8rem;z-index:2;font-family:var(--f-mono);font-size:.58rem;letter-spacing:.14em;color:#fff;background:rgba(26,23,20,.55);padding:.3rem .5rem;backdrop-filter:blur(6px);text-transform:uppercase}
.prod__tag{position:absolute;top:.7rem;right:.8rem;z-index:2;font-family:var(--f-mono);font-size:.58rem;letter-spacing:.14em;color:#fff;background:var(--coral);padding:.3rem .5rem;text-transform:uppercase}
.prod__body{display:flex;flex-direction:column;gap:.4rem}
.prod__name{font-family:var(--f-body);font-weight:600;font-size:1.02rem;color:var(--ink);line-height:1.3}
.prod__spec{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.05em;color:var(--graphite);text-transform:uppercase}
.prod__row{display:flex;justify-content:space-between;align-items:center;margin-top:.35rem;padding-top:.6rem;border-top:1px solid var(--line)}
.prod__price{font-family:var(--f-head);font-weight:600;font-size:1.05rem;color:var(--ink)}
.prod__see{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.12em;color:var(--coral);text-transform:uppercase}

/* category break header */
.cat-break{padding:clamp(3rem,5vw,4.5rem) var(--gutter) clamp(1.5rem,3vw,2.5rem);display:grid;grid-template-columns:auto 1fr auto;gap:1.5rem;align-items:end;border-top:1px solid var(--line)}
.cat-break .num{font-family:var(--f-head);font-weight:600;font-size:clamp(2.2rem,4vw,3.4rem);color:var(--coral);line-height:.8}
.cat-break h3{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:clamp(1.5rem,3vw,2.4rem);letter-spacing:-0.01em;color:var(--ink)}
.cat-break .count{font-family:var(--f-mono);font-size:.68rem;letter-spacing:.14em;color:var(--graphite);text-transform:uppercase;white-space:nowrap}

/* filter chips */
.filters{position:sticky;top:62px;z-index:20;display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;padding:1.2rem var(--gutter);background:rgba(250,246,240,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.filters .lbl{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--graphite);margin-right:.5rem}
.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.55rem .9rem;border:1px solid var(--line);background:var(--paper-3);font-family:var(--f-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);cursor:pointer;transition:all var(--t)}
.chip:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip.is-on{background:var(--coral);color:#fff;border-color:var(--coral)}
.chip .n{font-size:.6rem;color:inherit;opacity:.7}

/* ===================== STORES / CITY CARDS ===================== */
.cities{padding:clamp(4.5rem,8vw,8rem) var(--gutter)}
.cities__head{display:grid;grid-template-columns:1.4fr 1fr;gap:2rem;align-items:end;margin-bottom:3rem}
.cities__head h2{max-width:16ch}
.cities__head p{color:var(--graphite);max-width:36ch;justify-self:end;text-align:right}
.city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.city{position:relative;overflow:hidden;background:var(--ink);color:#fff;display:flex;flex-direction:column;justify-content:flex-end;min-height:360px;padding:1.8rem}
.city img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;transition:transform 1.2s var(--ease),opacity var(--t)}
.city:hover img{transform:scale(1.06);opacity:.62}
.city::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(26,23,20,.85) 0%,rgba(26,23,20,.2) 70%)}
.city > *{position:relative;z-index:2}
.city .num{font-family:var(--f-head);font-weight:600;font-size:2.6rem;color:var(--coral);line-height:.8;margin-bottom:auto}
.city .nm{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:1.9rem;letter-spacing:-0.01em;margin-top:1.5rem}
.city .det{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.1em;color:rgba(255,255,255,.78);text-transform:uppercase;margin-top:.6rem;line-height:1.6}
.city .lnk{color:var(--coral-soft);margin-top:1.1rem}
.city .lnk::after{background:var(--coral-soft)}

/* ===================== STORE PAIR CARDS ===================== */
.store-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.store{display:flex;flex-direction:column;background:var(--cream-card);border:1px solid var(--line);overflow:hidden}
.store__img{position:relative;aspect-ratio:16/11;overflow:hidden;background:var(--ink)}
.store__img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.store__pin{position:absolute;top:1rem;left:1rem;display:inline-flex;align-items:center;gap:.45rem;font-family:var(--f-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(26,23,20,.65);padding:.45rem .65rem;backdrop-filter:blur(8px)}
.store__pin svg{width:11px;height:11px;color:var(--coral-soft)}
.store__no{position:absolute;right:1.2rem;bottom:.7rem;font-family:var(--f-head);font-weight:600;font-size:3rem;color:#fff;line-height:.8;text-shadow:0 2px 14px rgba(0,0,0,.4)}
.store__body{padding:1.8rem;display:flex;flex-direction:column;gap:1rem;flex:1}
.store__name{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:clamp(1.4rem,2.3vw,1.85rem);letter-spacing:-0.01em;line-height:1.05}
.store__name .coral{color:var(--coral)}
.store__addr{color:var(--graphite);font-size:.95rem;line-height:1.55}
.store__rows{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.store__rows .r .lbl{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.14em;color:var(--graphite);text-transform:uppercase;display:block;margin-bottom:.3rem}
.store__rows .r .val{font-size:.92rem;color:var(--ink);font-weight:500}
.store__cta{display:inline-flex;align-items:center;gap:.5rem;color:var(--coral);font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;align-self:flex-start;padding-bottom:.15rem;border-bottom:1px solid var(--coral)}
.store__cta:hover{color:var(--ink);border-color:var(--ink)}

/* ===================== STAT STRIP ===================== */
.stats{background:var(--ink);color:var(--paper);padding:clamp(3.5rem,6vw,5.5rem) var(--gutter)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.stat{display:flex;flex-direction:column;gap:.5rem}
.stat .v{font-family:var(--f-head);font-weight:600;font-size:clamp(2.4rem,4.5vw,3.6rem);letter-spacing:-0.02em;line-height:.9;color:var(--paper)}
.stat .v .coral{color:var(--coral)}
.stat .l{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.14em;color:rgba(250,246,240,.6);text-transform:uppercase}

/* ===================== QUOTE / FLY FREE BAND ===================== */
.flyband{background:var(--coral);color:#fff;padding:clamp(5rem,9vw,8.5rem) var(--gutter);text-align:center;position:relative;overflow:hidden}
.flyband svg.kite{position:absolute;opacity:.18;width:160px;height:160px}
.flyband svg.kite.k1{top:-30px;left:5%;transform:rotate(-12deg)}
.flyband svg.kite.k2{bottom:-40px;right:6%;transform:rotate(18deg)}
.flyband q{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:clamp(2rem,5vw,4rem);line-height:1.02;letter-spacing:-0.015em;color:#fff;max-width:20ch;display:block;margin:0 auto;quotes:none}
.flyband q::before,.flyband q::after{content:""}
.flyband .cite{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.82);margin-top:2.2rem;display:block}

/* ===================== LEDGER / REVIEWS ===================== */
.reviews{padding:clamp(4.5rem,8vw,8rem) var(--gutter);background:var(--paper-2)}
.reviews__head{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end;margin-bottom:3rem}
.reviews__head h2{max-width:18ch}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.rev{background:var(--cream-card);border:1px solid var(--line);padding:1.8rem 1.6rem;display:flex;flex-direction:column;gap:1rem;min-height:260px;position:relative}
.rev__no{position:absolute;top:1.2rem;right:1.4rem;font-family:var(--f-mono);font-size:.6rem;letter-spacing:.16em;color:var(--coral)}
.rev__stars{color:var(--coral);font-size:.9rem;letter-spacing:.1em}
.rev__q{font-size:1.02rem;line-height:1.5;color:var(--ink);flex:1}
.rev__who{font-family:var(--f-head);font-weight:600;font-size:1.02rem;color:var(--ink);padding-top:1rem;border-top:1px solid var(--line)}
.rev__who span{display:block;font-family:var(--f-mono);font-weight:400;font-size:.62rem;letter-spacing:.12em;color:var(--graphite);text-transform:uppercase;margin-top:.25rem}

/* ===================== IG GRID ===================== */
.ig{padding:clamp(4rem,7vw,7rem) var(--gutter)}
.ig__head{display:flex;justify-content:space-between;align-items:end;gap:2rem;margin-bottom:2.2rem;flex-wrap:wrap}
.ig__head h2{max-width:18ch}
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.6rem}
.ig-grid > a{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--paper-2)}
.ig-grid img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter var(--t)}
.ig-grid > a:hover img{transform:scale(1.06);filter:brightness(.8)}
.ig-grid > a::after{content:"↗";position:absolute;inset:auto auto 8px 10px;font-family:var(--f-mono);color:rgba(255,255,255,0);transition:color var(--t)}
.ig-grid > a:hover::after{color:#fff}

/* ===================== DISPATCH / CTA ===================== */
.dispatch{background:var(--ink);color:var(--paper);padding:clamp(4.5rem,8vw,8rem) var(--gutter);display:grid;grid-template-columns:1.5fr 1fr;gap:2.5rem;align-items:center;position:relative;overflow:hidden}
.dispatch::after{content:"";position:absolute;right:-6%;top:-30%;bottom:-30%;width:46%;background:radial-gradient(ellipse at center,rgba(214,122,96,.3),transparent 62%);pointer-events:none}
.dispatch .eyebrow{color:var(--coral-soft);margin-bottom:1rem}
.dispatch h2{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:clamp(2.3rem,5.2vw,4.4rem);letter-spacing:-0.02em;line-height:.95;color:var(--paper);max-width:15ch}
.dispatch h2 .coral{color:var(--coral)}
.dispatch p{margin-top:1.1rem;color:rgba(250,246,240,.78);max-width:36ch}
.dispatch__r{display:flex;flex-direction:column;gap:.8rem;align-items:flex-start;position:relative;z-index:2}

/* ===================== FOOTER ===================== */
.footer{background:#14110E;color:var(--paper);padding:clamp(4rem,7vw,6rem) var(--gutter) 2rem;border-top:1px solid rgba(250,246,240,.08)}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.5rem;margin-bottom:4rem}
.footer__brand{display:flex;flex-direction:column;gap:1.2rem}
.footer__brand .mark{display:flex;align-items:center;gap:.7rem}
.footer__brand .mark .logo{width:42px;height:42px}
.footer__brand .mark .wm{font-family:var(--f-head);font-weight:600;font-size:1.15rem;letter-spacing:.02em;text-transform:uppercase}
.footer__brand .mark .wm span{display:block;font-family:var(--f-mono);font-weight:400;font-size:.55rem;letter-spacing:.42em;color:var(--coral);margin-top:.2rem}
.footer__brand p{color:rgba(250,246,240,.6);max-width:32ch;font-size:.95rem;line-height:1.55}
.footer__col h4{font-family:var(--f-mono);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--coral-soft);margin-bottom:1.2rem}
.footer__col a,.footer__col span{display:block;font-size:.95rem;color:var(--paper);padding:.3rem 0;transition:color var(--t)}
.footer__col a:hover{color:var(--coral-soft)}
.footer__col .small{font-family:var(--f-mono);font-size:.68rem;letter-spacing:.04em;color:rgba(250,246,240,.5);line-height:1.6;text-transform:none}
.footer__bot{display:flex;justify-content:space-between;gap:1rem;padding-top:1.5rem;border-top:1px solid rgba(250,246,240,.1);font-family:var(--f-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(250,246,240,.45);flex-wrap:wrap}
.footer__bot a{color:rgba(250,246,240,.45)}
.footer__bot a:hover{color:var(--coral-soft)}

/* ===================== PAGE HERO (sub-pages) ===================== */
.page-hero{padding:8.5rem var(--gutter) 3.5rem;border-bottom:1px solid var(--line);display:grid;grid-template-columns:1fr 2.2fr;gap:clamp(2rem,5vw,5rem);align-items:end}
.page-hero__l .eyebrow{margin-bottom:1rem}
.page-hero__l .num{font-family:var(--f-head);font-weight:600;font-size:clamp(3rem,5vw,4.6rem);color:var(--coral);line-height:.82}
.page-hero__r h1{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:clamp(2.6rem,6.5vw,5.6rem);letter-spacing:-0.025em;line-height:.92;max-width:16ch}
.page-hero__r h1 .coral{color:var(--coral)}
.page-hero__r .lede{margin-top:1.6rem;max-width:52ch;color:var(--ink-2)}

/* ===================== STORY MAGAZINE ===================== */
.fb-photo{position:relative;width:100%;aspect-ratio:21/9;overflow:hidden;background:var(--ink)}
.fb-photo img{width:100%;height:100%;object-fit:cover}
.fb-photo .cap{position:absolute;bottom:1rem;left:var(--gutter);font-family:var(--f-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;padding:.45rem .7rem;background:rgba(26,23,20,.6);backdrop-filter:blur(8px)}
.story-block{padding:clamp(4rem,7vw,6.5rem) var(--gutter);display:grid;grid-template-columns:1fr 2fr;gap:clamp(2rem,6vw,6rem);align-items:start;border-bottom:1px solid var(--line)}
.story-block:nth-of-type(even){background:var(--paper-2)}
.story-block .num{font-family:var(--f-head);font-weight:600;font-size:clamp(2.4rem,4.5vw,3.6rem);color:var(--coral);line-height:.8}
.story-block h2{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:clamp(1.8rem,3.5vw,2.7rem);letter-spacing:-0.015em;line-height:1.05;margin-bottom:1.4rem;max-width:18ch}
.story-block h2 .coral{color:var(--coral)}
.story-block p{font-size:1.075rem;line-height:1.7;color:var(--ink-2);max-width:62ch}
.story-block p + p{margin-top:1rem}
.inline-quote{margin:1.8rem 0;padding:1.4rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-family:var(--f-head);font-weight:500;font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.15;color:var(--coral);text-transform:uppercase;letter-spacing:-0.01em}

/* ===================== LOOKBOOK ===================== */
.lb-chapter{padding:clamp(4.5rem,8vw,7.5rem) var(--gutter);border-bottom:1px solid var(--line)}
.lb-chapter:nth-child(even){background:var(--paper-2)}
.lb-chapter__head{display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:end;margin-bottom:2.5rem}
.lb-chapter__head .num{font-family:var(--f-head);font-weight:600;font-size:clamp(3rem,6vw,5rem);color:var(--coral);line-height:.8}
.lb-chapter__head h2{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:clamp(1.8rem,3.5vw,2.8rem);letter-spacing:-0.015em;line-height:1.05}
.lb-chapter__head p{max-width:60ch;color:var(--graphite);grid-column:1/-1;margin-top:.4rem}
.lb-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}
.lbf{position:relative;overflow:hidden;background:var(--paper-2)}
.lbf img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.lbf:hover img{transform:scale(1.04)}
.lbf__cap{position:absolute;left:.9rem;bottom:.8rem;font-family:var(--f-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(26,23,20,.55);padding:.35rem .55rem;backdrop-filter:blur(6px)}
.lbf--xl{grid-column:span 8;aspect-ratio:16/10}
.lbf--md{grid-column:span 4;aspect-ratio:4/5}
.lbf--tall{grid-column:span 4;aspect-ratio:3/4}
.lbf--wide{grid-column:span 8;aspect-ratio:5/4}
.lbf--sq{grid-column:span 4;aspect-ratio:1/1}

/* ===================== PROCESS / SERVICE STEPS ===================== */
.process{padding:clamp(4.5rem,8vw,8rem) var(--gutter)}
.process__head{margin-bottom:3rem;max-width:46ch}
.process__head h2{max-width:16ch}
.process__head p{margin-top:1.1rem;color:var(--graphite)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);background:var(--paper-3)}
.step{padding:2rem 1.6rem 2.2rem;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:.7rem;min-height:280px}
.step:last-child{border-right:0}
.step .num{font-family:var(--f-head);font-weight:600;font-size:2.6rem;color:var(--coral);line-height:.8}
.step .nm{font-family:var(--f-head);font-weight:600;text-transform:uppercase;font-size:1.25rem;color:var(--ink);margin-top:.5rem;letter-spacing:-0.005em}
.step p{font-size:.95rem;color:var(--graphite);line-height:1.55}
.step .tm{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.14em;color:var(--coral);text-transform:uppercase;margin-top:auto;padding-top:1rem;border-top:1px dashed var(--line)}

.menu{padding:clamp(4rem,7vw,7rem) var(--gutter);background:var(--paper-2)}
.menu__head{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:end;margin-bottom:2.5rem}
.menu__head h2{max-width:14ch}
.menu__head p{color:var(--graphite);max-width:42ch;text-align:right;justify-self:end}
.menu-list{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);background:var(--paper-3)}
.mi{display:grid;grid-template-columns:1fr auto;gap:1.5rem;padding:1.4rem 1.6rem;border-bottom:1px solid var(--line);align-items:baseline}
.mi:nth-child(odd){border-right:1px solid var(--line)}
.mi:nth-last-child(-n+2){border-bottom:0}
.mi__name{font-family:var(--f-body);font-weight:600;font-size:1.02rem;color:var(--ink);line-height:1.3}
.mi__name span{display:block;font-family:var(--f-mono);font-weight:400;font-size:.62rem;letter-spacing:.1em;color:var(--graphite);text-transform:uppercase;margin-top:.25rem}
.mi__price{font-family:var(--f-head);font-weight:600;font-size:.98rem;color:var(--coral);white-space:nowrap}

/* payment row */
.payments{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-top:1.4rem}
.payments .pill{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--graphite);border:1px solid var(--line);padding:.4rem .6rem}

/* ===================== REVEAL =====================
   FAIL-OPEN: content is visible by default. Hiding is only applied
   when JS adds `.anim` to <html> (so no-JS / JS-error = fully visible),
   per CLAUDE.md hard rule. */
.reveal{opacity:1;transform:none;transition:opacity .85s var(--ease),transform .85s var(--ease)}
.reveal-stagger > *{opacity:1;transform:none;transition:opacity .8s var(--ease),transform .8s var(--ease)}
html.anim .reveal{opacity:0;transform:translateY(30px)}
html.anim .reveal.is-in{opacity:1;transform:translateY(0)}
html.anim .reveal-stagger > *{opacity:0;transform:translateY(26px)}
html.anim .reveal-stagger.is-in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.is-in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.is-in > *:nth-child(2){transition-delay:.11s}
.reveal-stagger.is-in > *:nth-child(3){transition-delay:.17s}
.reveal-stagger.is-in > *:nth-child(4){transition-delay:.23s}
.reveal-stagger.is-in > *:nth-child(5){transition-delay:.29s}
.reveal-stagger.is-in > *:nth-child(6){transition-delay:.35s}
.reveal-stagger.is-in > *:nth-child(7){transition-delay:.41s}
.reveal-stagger.is-in > *:nth-child(8){transition-delay:.47s}
.reveal-stagger.is-in > *:nth-child(n+9){transition-delay:.5s}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal,.reveal-stagger > *{opacity:1!important;transform:none!important}
  .hero__kite{animation:none!important}
}

/* ===================== RESPONSIVE ===================== */
@media (max-width:1080px){
  .footer__top{grid-template-columns:1fr 1fr;gap:2.5rem}
  .prod-grid{grid-template-columns:repeat(3,1fr)}
  .rev-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:repeat(2,1fr)}
  .step:nth-child(2){border-right:0}
  .step:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .city-grid{grid-template-columns:1fr}
  .city{min-height:300px}
}
@media (max-width:900px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero__right{min-height:60vh;order:-1}
  .hero__left{padding-top:7rem}
  .hero__kite{display:none}
  .intro,.showcase__head,.cities__head,.menu__head,.reviews__head{grid-template-columns:1fr;gap:1.2rem}
  .cities__head p,.menu__head p{text-align:left;justify-self:start}
  .split,.split--rev .split__img{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .split--rev .split__img{order:0}
  .split__img{min-height:auto;aspect-ratio:16/11}
  .store-grid{grid-template-columns:1fr}
  .page-hero{grid-template-columns:1fr;gap:1.2rem}
  .story-block{grid-template-columns:1fr;gap:1rem}
  .mosaic{gap:.8rem}
  .tile--a,.tile--b,.tile--c,.tile--d,.tile--e,.tile--note{grid-column:span 12;aspect-ratio:16/11}
  .lbf--xl,.lbf--md,.lbf--tall,.lbf--wide,.lbf--sq{grid-column:span 12;aspect-ratio:4/5}
  .stats__grid{grid-template-columns:1fr 1fr;gap:2rem 1rem}
  .dispatch{grid-template-columns:1fr;gap:1.6rem}
  .lb-chapter__head{grid-template-columns:1fr;gap:.6rem}
}
@media (max-width:720px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .prod-grid{grid-template-columns:repeat(2,1fr);gap:1.6rem .8rem}
  .rev-grid{grid-template-columns:1fr}
  .ig-grid{grid-template-columns:repeat(3,1fr)}
  .steps{grid-template-columns:1fr}
  .step{border-right:0;border-bottom:1px solid var(--line)}
  .step:last-child{border-bottom:0}
  .menu-list{grid-template-columns:1fr}
  .mi{border-right:0!important}
  .footer__top{grid-template-columns:1fr;gap:2rem}
  .footer__bot{flex-direction:column;gap:.6rem}
  .cat-break{grid-template-columns:1fr;gap:.5rem}
  .hero__meta{gap:1.4rem}
}
@media (max-width:460px){
  :root{--gutter:1.25rem}
  .hero__title{font-size:3rem}
  .stats__grid{grid-template-columns:1fr 1fr}
}
