/* ============================================================
   THE KOOLZEUM ARCHIVES
   Dark, minimal, editorial — modeled on Epidemic Sound's layout
   language, carrying Koolzeum's real photography & graffiti brand.
   ============================================================ */

:root{
  --bg:#0C0C0E;
  --bg-2:#111114;
  --bg-soft:#121216;
  --card:#161619;
  --line:rgba(255,255,255,.09);
  --line-2:rgba(255,255,255,.14);

  --text:#F6F5F3;
  --muted:#9A9AA2;
  --faint:#6B6B73;

  --blue:#2C6BEA;        /* Cleve Blue — primary accent */
  --blue-hi:#4F87FF;
  --green:#1FB263;       /* Koolzeum Green */
  --lime:#C8E94B;        /* original hero title green */
  --gold:#D8AC54;

  --r:16px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,1,.36,1);

  --f-display:"Schibsted Grotesk", system-ui, sans-serif;
  --f-body:"Hanken Grotesk", system-ui, sans-serif;
  --f-serif:"Newsreader", Georgia, serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--text);
  font-family:var(--f-body);font-weight:400;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-style:normal}

/* ---- type helpers ---- */
.eyebrow{
  font-family:var(--f-display);font-weight:700;font-size:.9rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--blue-hi);
  margin-bottom:1rem;
}
.eyebrow.center{text-align:center;color:var(--gold)}

/* Section identifiers (01 —, 02 — …) — large & bold so each hall is clearly marked */
.block-head .eyebrow{
  font-weight:800;font-size:clamp(1.05rem,2vw,1.5rem);
  letter-spacing:.06em;color:var(--text);line-height:1.2;
  display:inline-flex;align-items:center;gap:.6em;margin-bottom:1.1rem;
}
.block-head .eyebrow::before{
  content:"";width:clamp(28px,4vw,52px);height:3px;border-radius:2px;
  background:var(--blue-hi);flex-shrink:0;
}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--f-body);font-weight:600;font-size:.92rem;
  padding:.7em 1.25em;border-radius:999px;border:1px solid transparent;
  transition:transform .25s var(--ease),background .25s,border-color .25s,color .25s;
  white-space:nowrap;cursor:pointer;
}
.btn-lg{font-size:1rem;padding:.95em 1.7em}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-hi)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--text);background:rgba(255,255,255,.05)}

/* ============================================================
   HEADER
   ============================================================ */
.head{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;gap:2rem;
  padding:.85rem clamp(1rem,4vw,2.4rem);
  transition:background .4s,backdrop-filter .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.head.scrolled{
  background:rgba(12,12,14,.82);backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line);
}
.brand{margin-right:auto;display:flex;align-items:center}
.brand img{height:38px;width:auto;border-radius:7px}
.nav{display:flex;gap:1.7rem}
.nav a{font-weight:500;font-size:.94rem;color:var(--muted);transition:color .25s}
.nav a:hover{color:var(--text)}
.head-actions{display:flex;gap:.6rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--text);transition:.3s var(--ease)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;overflow:hidden;isolation:isolate;background:#08080c;
  min-height:clamp(600px,94svh,1000px);display:flex;align-items:center;
  padding:7rem clamp(1.2rem,5vw,4.5rem) 4rem;
}
/* Sub-pages use a slimmed-down hero so it's obvious you navigated off the home page */
.hero.hero-compact{
  min-height:clamp(280px,42svh,420px);
  padding:6rem clamp(1.2rem,5vw,4.5rem) 2.4rem;
}
.hero-compact .hero-sub{display:none}
.hero-compact .hero-title{font-size:clamp(1.9rem,4.4vw,3.3rem)}
.hero-compact .hero-pills{margin-top:1.3rem}
/* original site's full-bleed hero photo: Cleve & the gold-records wall.
   Subject is centered in the frame, so we zoom + slide him to the RIGHT,
   keeping his face clear of the left-aligned text on every screen size. */
.hero-photo{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-photo img{
  width:100%;height:100%;object-fit:cover;object-position:50% 26%;
  transform:scale(1.22) translateX(15%);transform-origin:center;
}
.hero::after{ /* legibility veil anchored to the left */
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg, rgba(8,8,12,.88) 0%, rgba(8,8,12,.66) 34%, rgba(8,8,12,.20) 58%, transparent 78%);
}
.hero-inner{position:relative;z-index:2;max-width:600px;width:100%}
.hero-title{
  font-family:var(--f-display);font-weight:800;color:var(--lime);
  font-size:clamp(2.3rem,5.4vw,5rem);line-height:1.0;letter-spacing:-.03em;
  max-width:13ch;text-shadow:0 4px 30px rgba(0,0,0,.6);overflow-wrap:break-word;
}
.hero-title em{font-family:var(--f-serif);font-style:italic;font-weight:500;color:var(--lime)}
.hero-sub{
  max-width:410px;margin:1.5rem 0 0;color:#fff;font-weight:500;
  font-size:clamp(1rem,1.5vw,1.18rem);line-height:1.5;
  background:rgba(4,4,181,.62);backdrop-filter:blur(2px);
  border-left:3px solid var(--lime);
  padding:1rem 1.2rem;border-radius:0 10px 10px 0;
}
.hero-pills{display:flex;flex-direction:column;align-items:flex-start;gap:.85rem;margin-top:2.2rem}
.hero-pills a{
  font-family:var(--f-display);font-weight:600;font-size:.95rem;
  letter-spacing:.06em;text-transform:uppercase;color:#fff;
  padding:.8em 1.7em;border-radius:999px;
  border:1.5px solid rgba(255,255,255,.85);
  background:rgba(12,12,16,.34);backdrop-filter:blur(6px);
  transition:background .25s var(--ease),color .25s,border-color .25s,transform .25s var(--ease);
}
.hero-pills a:hover{background:var(--lime);color:#10120a;border-color:var(--lime);transform:translateX(5px)}
/* ============================================================
   SECTION TILES (Epidemic genre-card row)
   ============================================================ */
.tiles{
  padding:clamp(2.5rem,5vh,4rem) clamp(1rem,4vw,2.4rem) clamp(3rem,6vh,4.5rem);
  background:
    linear-gradient(180deg, rgba(8,8,12,.55) 0%, rgba(20,14,6,.40) 50%, rgba(8,8,12,.58) 100%),
    url("assets/img/cheetah.jpg") repeat;
  background-size:auto, 300px auto;
}
.tiles-row{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;
}
.tile{
  display:flex;flex-direction:column;
  background:rgba(10,11,14,.94);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  box-shadow:0 18px 44px -24px rgba(0,0,0,.95);
}
.tile-img{
  position:relative;
  border-radius:0;overflow:hidden;aspect-ratio:1;
  background:var(--card);border:0;border-bottom:1px solid var(--line);
}
.tile-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.tile:hover .tile-img img{transform:scale(1.06)}
.tile-play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:62px;height:62px;border-radius:50%;
  background:rgba(0,0,0,.55);backdrop-filter:blur(2px);
  border:2px solid rgba(255,255,255,.92);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 26px -8px rgba(0,0,0,.7);
  transition:transform .3s var(--ease),background .3s var(--ease);
}
.tile-play::before{content:"";border-left:20px solid #fff;border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:5px}
.tile:hover .tile-play{transform:translate(-50%,-50%) scale(1.1);background:var(--lime)}
.tile:hover .tile-play::before{border-left-color:#10120a}
.tile h3{font-family:var(--f-display);font-weight:700;font-size:1.1rem;margin:0;padding:.75rem .9rem .15rem;color:#fff}
.tile span{color:var(--lime);font-size:.85rem;padding:0 .9rem .9rem;display:block}

/* ============================================================
   FROM THE ARCHIVES (original homepage content, masonry)
   ============================================================ */
.archives{
  padding:clamp(3rem,7vh,5rem) clamp(1rem,4vw,2.4rem) clamp(3.5rem,8vh,5.5rem);
  background:
    linear-gradient(180deg, rgba(8,8,14,.20) 0%, rgba(8,12,26,.10) 50%, rgba(8,8,14,.24) 100%),
    url("assets/img/blueleopard.jpg") repeat;
  background-size:auto, 300px auto;
}
/* Section header glass panel — a unique element with a lime accent bar,
   echoing the site's card + lime-accent system, kept legible on the bold prints.
   Shared by the Archives and Kool Pages headers. */
.head-panel{
  display:inline-block;width:auto;max-width:min(100%,640px);
  position:relative;
  background:linear-gradient(180deg, rgba(12,14,22,.82), rgba(10,12,20,.74));
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.14);border-left:5px solid var(--lime);
  border-radius:18px;
  padding:clamp(1rem,2.4vw,1.5rem) clamp(1.2rem,3vw,1.9rem);
  box-shadow:0 22px 50px -24px rgba(0,0,0,.85), inset 0 1px 0 rgba(255,255,255,.06);
}
.head-panel .eyebrow{color:var(--lime);margin-bottom:.5rem;text-shadow:none}
.head-panel h1,.head-panel h2{color:#fff;text-shadow:none;margin:0}
/* Heroes block-head heading uses the shared panel; tame the big block eyebrow
   so it reads as a clean lime small-caps line and wraps inside the panel */
#heroes .head-panel,#videos .head-panel,#glass .head-panel{max-width:100%}
#heroes .head-panel .eyebrow,#videos .head-panel .eyebrow,#glass .head-panel .eyebrow{
  display:block;white-space:normal;
  font-size:.85rem;font-weight:700;letter-spacing:.1em;line-height:1.3;
  color:var(--lime);margin-bottom:.5rem;
}
#heroes .head-panel .eyebrow::before,#videos .head-panel .eyebrow::before,#glass .head-panel .eyebrow::before{display:none}
#glass .head-panel .block-desc,#heroes .head-panel .block-desc{color:#E7E7EC;font-weight:500;text-shadow:none;margin-top:.7rem;max-width:none}
.arc-grid{max-width:var(--maxw);margin:0 auto;columns:3;column-gap:1.3rem}
.arc-card{
  break-inside:avoid;margin:0 0 1.3rem;display:block;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  transition:border-color .3s,transform .3s var(--ease);
}
a.arc-card:hover{border-color:var(--line-2);transform:translateY(-3px)}
.arc-media{position:relative;display:block;background:#000}
.arc-media img,.arc-media video{width:100%;display:block}
.arc-media img{transition:transform .6s var(--ease)}
a.arc-card:hover .arc-media img{transform:scale(1.04)}
.arc-card h3{
  font-family:var(--f-display);font-weight:700;color:var(--lime);
  font-size:1.12rem;line-height:1.18;padding:1rem 1.1rem .3rem;
}
.arc-card p{color:var(--muted);font-size:.9rem;padding:.1rem 1.1rem 1.1rem}
.arc-card.text-only{padding:1.5rem 1.3rem;border-left:3px solid var(--gold)}
.arc-card.text-only h3{color:var(--gold-hi,#EBCB80);padding:0 0 .7rem}
.arc-card.text-only p{padding:0;font-size:.95rem}
.arc-card.text-only p + p{margin-top:.85rem}
@media(max-width:1000px){.arc-grid{columns:2}}
@media(max-width:640px){.arc-grid{columns:1}}

/* ============================================================
   TRUST / PARTNER STRIP
   ============================================================ */
.trust{
  padding:clamp(3.5rem,8vh,6rem) clamp(1rem,4vw,2.4rem);
  text-align:center;
  /* candy apple red — glossy */
  background:radial-gradient(130% 150% at 50% -25%, #FF2540 0%, #DA021E 42%, #A60017 100%);
  border-top:2px solid rgba(0,0,0,.35);border-bottom:2px solid rgba(0,0,0,.35);
}
.trust-label{
  color:#fff;font-family:var(--f-display);font-weight:800;
  font-size:clamp(1.1rem,2.6vw,1.7rem);letter-spacing:.16em;text-transform:uppercase;
  margin-bottom:clamp(2rem,4vh,3rem);text-shadow:0 2px 10px rgba(0,0,0,.3);
}
.trust-row{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;justify-content:center;gap:clamp(2rem,6vw,4.5rem);
  flex-wrap:wrap;
}
.trust-row img{
  height:clamp(120px,16vw,180px);width:auto;object-fit:contain;
  background:#fff;padding:12px 18px;border-radius:16px;
  box-shadow:0 12px 30px -12px rgba(0,0,0,.55);transition:transform .25s var(--ease);
}
.trust-row img:hover{transform:translateY(-3px) scale(1.03)}
.trust-row img.trust-tall{height:clamp(240px,30vw,340px);padding:10px}
.trust-feature{display:flex;flex-direction:column;align-items:center;gap:.9rem;max-width:340px}
.trust-feature figcaption{
  color:#fff;font-family:var(--f-body);font-weight:500;
  font-size:.92rem;line-height:1.45;text-align:center;
  text-shadow:0 1px 6px rgba(0,0,0,.45);
}
.trust-word{
  font-family:var(--f-display);font-weight:800;
  font-size:clamp(1.5rem,3.6vw,2.6rem);letter-spacing:.03em;line-height:1.05;
  color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.35);transition:transform .25s var(--ease);
}
.trust-word:hover{color:#fff;transform:translateY(-2px)}

/* ============================================================
   CONTENT BLOCKS
   ============================================================ */
.block{padding:clamp(3.5rem,8vh,6rem) clamp(1rem,4vw,2.4rem)}
/* Heroes section — African mud cloth (bògòlanfini) ground */
#heroes{
  background:
    linear-gradient(180deg, rgba(6,6,7,.74) 0%, rgba(6,6,7,.66) 50%, rgba(6,6,7,.78) 100%),
    url("assets/img/mudcloth.jpg") repeat;
  background-size:auto, 360px auto;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
#heroes .block-desc{color:#EDEDF0;font-weight:500;text-shadow:0 1px 6px rgba(0,0,0,.95)}
/* hero cards become solid dark cards so captions read on the mud cloth */
#heroes .card{
  background:rgba(10,11,14,.94);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  box-shadow:0 18px 44px -24px rgba(0,0,0,.95);
}
#heroes .card .card-img{border:0;border-radius:0;border-bottom:1px solid var(--line)}
#heroes .card h3{margin:0;padding:.7rem .85rem .1rem}
#heroes .card span{color:var(--lime);padding:0 .85rem .85rem;text-shadow:none}
.block.alt{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.block-head{
  max-width:var(--maxw);margin:0 auto clamp(2rem,4vh,3rem);
  display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;
}
.block-head h2{
  font-family:var(--f-display);font-weight:800;
  font-size:clamp(1.9rem,4.2vw,3rem);line-height:1.04;letter-spacing:-.02em;
}
.block-head h2 em{font-family:var(--f-serif);font-style:italic;font-weight:500;color:var(--green)}
.block-desc{max-width:38ch;color:var(--muted);font-size:1rem}

/* ---- section "view all" link ---- */
.block-link{
  align-self:flex-end;flex-shrink:0;
  display:inline-flex;align-items:center;gap:.45em;
  font-family:var(--f-display);font-weight:600;font-size:.92rem;
  letter-spacing:.01em;color:var(--text);
  padding:.55rem .95rem;border:1px solid var(--line-2);border-radius:999px;
  background:rgba(12,12,14,.55);backdrop-filter:blur(4px);
  transition:border-color .3s,color .3s,background .3s,transform .3s var(--ease);
}
.block-link span{transition:transform .3s var(--ease)}
.block-link:hover{border-color:var(--blue-hi);color:var(--blue-hi);background:rgba(12,12,14,.8)}
.block-link:hover span{transform:translateX(4px)}

/* ---- zebra-print section background ---- */
/* Organic, animal-like stripes: low-frequency vertical SVG turbulence
   thresholded into hard-edged bone bands — irregular & tapering, not uniform. */
.block.zebra{position:relative;background:var(--bg);overflow:hidden;isolation:isolate}
.block.zebra::before{ /* the real zebra hide, bright */
  content:"";position:absolute;inset:0;z-index:-2;pointer-events:none;opacity:1;
  background:url("assets/img/zebra.jpg") repeat;
  background-size:540px auto;
}
.block.zebra::after{ /* light veil — keeps it bright while protecting header text */
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(8,8,11,.30) 0%, rgba(8,8,11,.18) 50%, rgba(8,8,11,.34) 100%);
}
/* readable header over the texture */
.block.zebra .block-head h2{text-shadow:0 2px 18px rgba(0,0,0,.85)}
.block.zebra .block-head .eyebrow{text-shadow:0 2px 14px rgba(0,0,0,.9)}
.block.zebra .block-desc{color:#E2E2E6;font-size:1.06rem;font-weight:500;text-shadow:0 1px 12px rgba(0,0,0,.85)}
/* stained-glass cards become solid dark cards so captions read on the bright zebra */
.block.zebra .card{
  background:rgba(10,11,14,.94);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  box-shadow:0 18px 44px -24px rgba(0,0,0,.95);
}
.block.zebra .card .card-img{border:0;border-radius:0;border-bottom:1px solid var(--line)}
.block.zebra .card h3{margin:0;padding:.7rem .85rem .1rem}
.block.zebra .card span{padding:0 .85rem .85rem;color:var(--lime)}

/* ---- card grids ---- */
.card-grid{max-width:var(--maxw);margin:0 auto;display:grid;gap:1.1rem}
.g5{grid-template-columns:repeat(5,1fr)}
.g6{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{display:block}
.card-img{border-radius:var(--r);overflow:hidden;background:var(--card);border:1px solid var(--line)}
.card-img.r45{aspect-ratio:4/5}
.card-img.r1{aspect-ratio:1}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card-img img{transform:scale(1.05)}
.card h3{font-family:var(--f-display);font-weight:700;font-size:1.02rem;margin:.8rem 0 .12rem}
.card span{color:var(--muted);font-size:.85rem}

/* ---- masonry (KoolPics) ---- */
.masonry{max-width:var(--maxw);margin:0 auto;columns:3;column-gap:1.1rem}
.m-item{display:block;break-inside:avoid;margin-bottom:1.1rem;position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.m-item img{width:100%;transition:transform .6s var(--ease)}
.m-item:hover img{transform:scale(1.04)}
.m-item b{
  position:absolute;left:0;right:0;bottom:0;padding:1.6rem .9rem .8rem;
  font-size:.82rem;font-weight:600;color:#fff;
  background:linear-gradient(transparent,rgba(0,0,0,.82));
  opacity:0;transform:translateY(6px);transition:.35s var(--ease);
}
.m-item:hover b{opacity:1;transform:none}

/* ---- videos ---- */
.video-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr;gap:1.1rem}
.video-grid.tour{grid-template-columns:1fr 1fr}
/* tour cards become solid dark cards with captions below the thumbnail (like other sections) */
.video-grid.tour .video-feat{
  display:flex;flex-direction:column;min-height:0;
  background:rgba(10,11,14,.95);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  box-shadow:0 18px 44px -24px rgba(0,0,0,.95);
}
.video-grid.tour .video-feat::after{display:none}
.video-grid.tour .v-media{position:relative;display:block;aspect-ratio:16/9;overflow:hidden;background:#000}
.video-grid.tour .v-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.video-grid.tour .video-cap{position:static;padding:.9rem 1.05rem 1.1rem}
.video-grid.tour .video-cap b{font-size:1.12rem;color:#fff}
.video-grid.tour .video-cap i{color:var(--lime);font-size:.9rem}

/* Videos section — African dashiki print ground (dark overlay keeps text clear) */
#videos{
  background:
    linear-gradient(180deg, rgba(7,7,9,.42) 0%, rgba(7,7,9,.30) 50%, rgba(7,7,9,.46) 100%),
    url("assets/img/dashiki.jpg") repeat;
  background-size:auto, 320px auto;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
#videos .block-head h2{text-shadow:0 2px 8px rgba(0,0,0,.92),0 1px 3px rgba(0,0,0,.9)}
#videos .block-head .eyebrow{text-shadow:0 1px 5px rgba(0,0,0,.95)}
#videos .head-panel .block-desc{color:#E7E7EC;font-weight:500;text-shadow:none;margin-top:.7rem;max-width:none}
.video-feat{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);min-height:320px}
.video-feat img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .7s var(--ease)}
.video-feat:hover img{transform:scale(1.04)}
.video-side{display:flex;flex-direction:column;gap:1.1rem}
.video-min{position:relative;flex:1;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);min-height:150px}
.video-min img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .7s var(--ease)}
.video-min:hover img{transform:scale(1.05)}
.video-feat::after,.video-min::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(0,0,0,.78))}
.play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;
  width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.92);
  display:grid;place-items:center;transition:transform .3s var(--ease),background .3s;
}
.play.sm{width:46px;height:46px}
.play::before{content:"";border-left:18px solid var(--bg);border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:5px}
.play.sm::before{border-left-width:13px;border-top-width:8px;border-bottom-width:8px}
.video-feat:hover .play,.video-min:hover .play{transform:translate(-50%,-50%) scale(1.08);background:#fff}
.video-cap{position:absolute;left:0;bottom:0;z-index:3;padding:1.5rem;color:#fff}
.video-cap b{display:block;font-family:var(--f-display);font-weight:700;font-size:1.3rem}
.video-cap i{font-style:normal;color:rgba(255,255,255,.75);font-size:.9rem}
.video-min b{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:1.3rem .9rem .85rem;color:#fff;font-weight:600;font-size:.92rem}

/* ---- shop ---- */
.shop-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.product{
  display:flex;flex-direction:column;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  transition:border-color .3s,transform .3s var(--ease);
}
.product:hover{border-color:var(--line-2);transform:translateY(-4px)}
.product-img{aspect-ratio:1;background:#fff}
.product-img img{width:100%;height:100%;object-fit:cover}
.product-meta{padding:1.1rem 1.2rem .4rem}
.product-meta h3{font-family:var(--f-display);font-weight:700;font-size:1.2rem}
.dotrow{display:flex;align-items:center;gap:.5em;color:var(--muted);font-size:.88rem;margin-top:.3rem}
.dotrow i{width:14px;height:14px;border-radius:4px;display:inline-block}
.product-cta{padding:.6rem 1.2rem 1.2rem;color:var(--blue-hi);font-weight:600;font-size:.92rem}

/* ============================================================
   DEDICATIONS
   ============================================================ */
.memoriam{
  padding:clamp(4rem,9vh,7rem) clamp(1rem,4vw,2.4rem);
  background:radial-gradient(70% 60% at 50% 0%, rgba(216,172,84,.08), transparent 70%),var(--bg);
  text-align:center;
}
.mem-title{
  font-family:var(--f-display);font-weight:800;
  font-size:clamp(1.8rem,4vw,2.8rem);letter-spacing:-.02em;margin-bottom:3rem;
}
.mem-grid{max-width:980px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.mem-card{
  display:flex;gap:1.2rem;text-align:left;padding:1.2rem;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
}
.mem-img{flex:0 0 130px;border-radius:12px;overflow:hidden}
.mem-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/4}
.mem-body h3{font-family:var(--f-display);font-weight:700;font-size:1.4rem}
.mem-aka{font-family:var(--f-serif);font-style:italic;color:var(--gold);margin:.1rem 0 .8rem}
.mem-body p{color:var(--muted);font-size:.92rem}
.mem-body strong{color:var(--text);font-weight:700}

/* ============================================================
   MISSION
   ============================================================ */
.mission{
  max-width:920px;margin:0 auto;text-align:center;
  padding:clamp(4rem,9vh,7rem) clamp(1.2rem,5vw,2.4rem);
}
.mission p:first-child{
  font-family:var(--f-serif);font-weight:400;font-style:italic;
  font-size:clamp(1.4rem,3.2vw,2.2rem);line-height:1.35;color:var(--text);
}
.mission em{color:var(--green);font-style:italic}
.mission-mark{font-family:var(--f-serif);color:var(--green);font-size:1.4em;line-height:0}
.mission-by{margin-top:1.6rem;color:var(--faint);font-size:.95rem}

/* ===== Koolzeum Mission — full statement on blue-leopard ground ===== */
/* ===== Statement (Estella) — black card + two photos on blue leopard ===== */
.koolstatement{
  background:
    linear-gradient(180deg, rgba(8,8,16,.22) 0%, rgba(8,8,16,.12) 50%, rgba(8,8,16,.28) 100%),
    url("assets/img/blueleopard.jpg") repeat;
  background-size:auto, 360px auto;
  padding:clamp(2.5rem,6vh,4.5rem) clamp(1rem,4vw,2rem);
  border-top:1px solid var(--line);
}
.ks-inner{max-width:940px;margin:0 auto;display:flex;flex-direction:column;gap:clamp(1.6rem,4vw,2.4rem)}
.ks-card{max-width:100%;width:100%}
.ks-card p{margin:0;color:#EDEDF0;font-weight:500;font-size:clamp(1rem,1.5vw,1.15rem);line-height:1.6;text-align:center}
.ks-photos{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,3vw,1.6rem)}
.ks-photo{
  margin:0;border-radius:16px;overflow:hidden;
  background:#0c0e16;border:1px solid rgba(255,255,255,.14);
  box-shadow:0 22px 50px -24px rgba(0,0,0,.85);
}
.ks-photo img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:3/4;transition:transform .6s var(--ease)}
.ks-photo:hover img{transform:scale(1.03)}
@media(max-width:620px){.ks-photos{grid-template-columns:1fr;max-width:340px;margin:0 auto}}

.koolmission{
  background:
    linear-gradient(180deg, rgba(8,8,16,.20) 0%, rgba(8,8,16,.12) 50%, rgba(8,8,16,.26) 100%),
    url("assets/img/blueleopard.jpg") repeat;
  background-size:auto, 360px auto;
  padding:clamp(2.5rem,6vh,4.5rem) clamp(1rem,4vw,2rem);
  border-top:1px solid var(--line);
}
.km-inner{max-width:940px;margin:0 auto;display:flex;flex-direction:column;gap:1.3rem}
.km-head{
  background:linear-gradient(180deg, rgba(12,14,22,.92), rgba(10,12,20,.86));
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.14);border-left:5px solid var(--lime);
  color:var(--lime);text-align:left;
  font-family:var(--f-display);font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  font-size:clamp(1rem,2.4vw,1.35rem);padding:.95rem 1.3rem;border-radius:14px;
  box-shadow:0 18px 44px -22px rgba(0,0,0,.85);margin:0;
}
.km-box{
  background:linear-gradient(180deg, rgba(12,14,22,.93), rgba(10,12,20,.9));
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  color:#EDEDF0;border-radius:16px;
  padding:clamp(1.4rem,3.6vw,2.4rem);
  box-shadow:0 20px 50px -22px rgba(0,0,0,.85);
  border:1px solid rgba(255,255,255,.12);
}
.km-box p{margin:0 0 1.1rem;line-height:1.6;font-size:clamp(.96rem,1.4vw,1.05rem);text-align:left}
.km-box p:last-child{margin-bottom:0}
.km-box .km-quote{font-family:var(--f-serif);font-style:italic;font-size:clamp(1.15rem,2.4vw,1.4rem);margin-top:.4rem;color:var(--lime)}
.km-box .km-sign{font-weight:700;letter-spacing:.04em;color:var(--lime)}
.km-keepers{margin:0;display:flex;flex-direction:column}
.km-keepers img{width:100%;display:block;border-radius:16px 16px 0 0;border:1px solid rgba(255,255,255,.12);border-bottom:0}
.km-keepers figcaption{
  background:linear-gradient(180deg, rgba(12,14,22,.93), rgba(10,12,20,.9));
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  color:#EDEDF0;text-align:left;border-radius:0 0 16px 16px;
  border:1px solid rgba(255,255,255,.12);border-top:0;
  padding:clamp(1rem,2.6vw,1.4rem) clamp(1.2rem,3vw,1.8rem);
  line-height:1.55;font-weight:500;font-size:clamp(.95rem,1.4vw,1.05rem);
  box-shadow:0 20px 50px -22px rgba(0,0,0,.85);
}
.km-keepers figcaption span{display:block;margin-top:.5rem;font-weight:800;letter-spacing:.03em;color:var(--lime)}

/* Erskine & Brown ventures — emblem cards */
.km-ventures{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.km-venture{margin:0;display:flex;flex-direction:column}
.km-venture-img{
  background:#ECEAE3;border:1px solid rgba(255,255,255,.12);border-bottom:0;
  border-radius:16px 16px 0 0;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  aspect-ratio:4/3;padding:clamp(.9rem,2.4vw,1.6rem);
}
.km-venture-img img{width:100%;height:100%;object-fit:contain;transition:transform .6s var(--ease)}
.km-venture:hover .km-venture-img img{transform:scale(1.04)}
.km-venture figcaption{
  background:linear-gradient(180deg, rgba(12,14,22,.93), rgba(10,12,20,.9));
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  color:#EDEDF0;text-align:left;border-radius:0 0 16px 16px;
  border:1px solid rgba(255,255,255,.12);border-top:0;
  padding:clamp(1rem,2.6vw,1.4rem) clamp(1.2rem,3vw,1.7rem);
  box-shadow:0 20px 50px -22px rgba(0,0,0,.85);
}
.km-venture figcaption b{display:block;font-family:var(--f-display);font-weight:800;font-size:1.05rem;letter-spacing:.02em;color:var(--lime)}
.km-venture figcaption span{display:block;margin-top:.4rem;font-size:.9rem;color:var(--muted)}
@media(max-width:560px){
  .km-keepers img{border-radius:14px 14px 0 0}
  .km-ventures{grid-template-columns:1fr}
}

/* ============================================================
   KOOLZEUM ADVERTISEMENT
   ============================================================ */
.koolads{
  background:
    linear-gradient(180deg, rgba(8,8,16,.32) 0%, rgba(8,8,16,.18) 50%, rgba(8,8,16,.36) 100%),
    url("assets/img/blueleopard.jpg") repeat;
  background-size:auto, 360px auto;
  padding:clamp(2.5rem,6vh,4.5rem) clamp(1rem,4vw,2rem);
  border-top:1px solid var(--line);
}
.ka-inner{max-width:940px;margin:0 auto;display:flex;flex-direction:column;gap:1.3rem}
.ka-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.ka-ad{margin:0;display:flex;flex-direction:column;transition:transform .3s var(--ease)}
.ka-ad:hover{transform:translateY(-4px)}
.ka-ad-head{
  position:relative;overflow:hidden;
  background:linear-gradient(165deg, rgba(20,22,32,.97), rgba(10,12,18,.97));
  border:1px solid rgba(255,255,255,.12);border-bottom:0;border-left:5px solid var(--acc);
  border-radius:16px 16px 0 0;
  padding:clamp(1.4rem,3.5vw,2rem) clamp(1.1rem,3vw,1.5rem);
  display:flex;flex-direction:column;justify-content:flex-end;gap:.6rem;
  min-height:150px;
}
.ka-ad-kicker{
  font-family:var(--f-display);font-weight:700;font-size:.72rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--acc);
}
.ka-ad-head b{
  font-family:var(--f-display);font-weight:800;line-height:1.05;color:#fff;
  font-size:clamp(1.4rem,2.6vw,1.8rem);letter-spacing:-.01em;
}
/* image variant — sponsor supplied artwork */
.ka-ad-img{
  background:#fff;border:1px solid rgba(255,255,255,.12);border-bottom:0;
  border-left:5px solid var(--acc);border-radius:16px 16px 0 0;overflow:hidden;
}
.ka-ad-img img{width:100%;height:auto;display:block;transition:transform .6s var(--ease)}
.ka-ad.has-img:hover .ka-ad-img img{transform:scale(1.03)}
.ka-ad figcaption{
  background:linear-gradient(180deg, rgba(12,14,22,.93), rgba(10,12,20,.9));
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  color:#EDEDF0;text-align:left;border-radius:0 0 16px 16px;
  border:1px solid rgba(255,255,255,.12);border-top:0;
  padding:clamp(1rem,2.6vw,1.3rem) clamp(1rem,2.6vw,1.4rem);
  box-shadow:0 20px 50px -22px rgba(0,0,0,.85);
  flex:1;
}
.ka-ad figcaption b{display:block;font-family:var(--f-display);font-weight:800;font-size:1rem;letter-spacing:.02em}
.ka-ad figcaption span{display:block;margin-top:.4rem;font-size:.85rem;color:var(--muted);line-height:1.5}
.ka-ad figcaption .ka-ad-tag{margin-top:0;font-family:var(--f-serif);font-style:italic;font-size:1.02rem;color:#EDEDF0}
.ka-ad figcaption a{color:var(--lime);text-decoration:none;font-weight:700}
.ka-ad figcaption a:hover{text-decoration:underline}
@media(max-width:760px){
  .ka-grid{grid-template-columns:1fr}
}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{border-top:1px solid var(--line);padding:clamp(3rem,6vh,4.5rem) clamp(1rem,4vw,2.4rem) 2rem}
.foot-top{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr;gap:3rem;padding-bottom:2.6rem;border-bottom:1px solid var(--line)}
.foot-brand img{height:54px;width:auto;border-radius:8px;margin-bottom:1rem}
.foot-brand p{color:var(--muted);max-width:34ch}
.foot-cols{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.foot-cols h4{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;font-weight:600}
.foot-cols a{display:block;color:var(--muted);font-size:.94rem;padding:.28em 0;transition:color .25s}
.foot-cols a:hover{color:var(--text)}
.foot-bottom{max-width:var(--maxw);margin:1.6rem auto 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;color:var(--faint);font-size:.82rem}
.foot-powered{display:flex;align-items:center;gap:.6rem}
.foot-powered img{height:22px;width:auto;opacity:.7}

/* ============================================================
   REVEAL (graceful without JS)
   ============================================================ */
.reveal{transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js .reveal{opacity:0;transform:translateY(20px)}
html.js .reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1000px){
  .tiles-row{grid-template-columns:repeat(3,1fr)}
  .g5{grid-template-columns:repeat(3,1fr)}
  .masonry{columns:2}
}
@media(max-width:820px){
  .nav,.head-actions{display:none}
  .burger{display:flex}
  .head.open{flex-direction:column;align-items:flex-start;gap:1.3rem;height:100svh;background:rgba(12,12,14,.97);backdrop-filter:blur(16px);padding-top:5rem}
  .head.open .nav{display:flex;flex-direction:column;gap:1.4rem}
  .head.open .nav a{font-size:1.5rem;color:var(--text)}
  .head.open .head-actions{display:flex;flex-direction:column;width:100%;gap:.8rem}
  .head.open .btn{width:100%}
  .head.open .burger{position:absolute;top:1rem;right:1.2rem}
  .video-grid{grid-template-columns:1fr}
  .mem-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr;gap:2rem}
  .hero{align-items:flex-start}
  .hero-inner{padding-top:1rem}
  .hero::after{background:linear-gradient(180deg, rgba(8,8,12,.72) 0%, rgba(8,8,12,.40) 30%, rgba(8,8,12,.55) 70%, rgba(8,8,12,.85) 100%)}
  .hero-photo img{object-position:50% 14%;transform:scale(1.32) translateX(7%) translateY(-15%)}
  .hero-sub{max-width:300px}
  .hero-pills a{font-size:.86rem;padding:.75em 1.4em}
}
@media(max-width:680px){
  .tiles-row{grid-template-columns:repeat(2,1fr)}
  .g5,.g6,.g4{grid-template-columns:repeat(2,1fr)}
  .shop-grid{grid-template-columns:1fr}
  .masonry{columns:1}
  .block-head{flex-direction:column;align-items:flex-start;gap:1rem}
  .block-link{align-self:flex-start}
  .mem-card{flex-direction:column}
  .mem-img{flex-basis:auto;max-width:160px}
}
@media(max-width:420px){
  .tiles-row{grid-template-columns:1fr 1fr}
  .g5,.g6,.g4{grid-template-columns:1fr 1fr}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  html.js .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   MOTION & MOBILE-NATIVE LAYER
   ============================================================ */
*{ -webkit-tap-highlight-color:transparent; }
html{ -webkit-text-size-adjust:100%; }
body{ overscroll-behavior-y:none; }
:focus-visible{ outline:2px solid var(--lime); outline-offset:3px; border-radius:5px; }

/* anchor offset under the sticky header */
section[id], header[id]{ scroll-margin-top:80px; }

/* scroll progress bar */
.scroll-progress{
  position:fixed; inset:0 0 auto 0; height:3px; z-index:1200;
  background:linear-gradient(90deg, var(--blue), var(--green) 55%, var(--lime));
  transform:scaleX(0); transform-origin:0 50%;
  transition:transform .08s linear;
}

/* richer staggered reveals */
html.js .reveal{
  opacity:0; transform:translateY(26px);
  transition:opacity .7s var(--ease) var(--d,0ms), transform .7s var(--ease) var(--d,0ms);
}
html.js .reveal.in{ opacity:1; transform:none; }

/* image fade-in on load */
.img-fade{ opacity:0; transition:opacity .55s var(--ease); }
.img-fade.loaded{ opacity:1; }

/* button sheen + press */
.btn{ position:relative; overflow:hidden; }
.btn::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(120deg, transparent 32%, rgba(255,255,255,.22), transparent 68%);
  transform:translateX(-130%); transition:transform .65s var(--ease);
}
.btn:hover::after{ transform:translateX(130%); }
.btn:active{ transform:translateY(0) scale(.96); }

/* tactile press on touchable cards */
.arc-card:active,.tile:active,.card:active,.product:active,.m-item:active,
.g-item:active,.hero-pills a:active,.wing:active,.video-feat:active,.video-min:active{
  transform:scale(.985);
}

/* play-button pulse on hover/focus */
.arc-card:hover .play,.video-feat:hover .play,.video-min:hover .play{
  animation:pulse 1.5s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(255,255,255,.5); }
  70%{ box-shadow:0 0 0 16px rgba(255,255,255,0); }
}

/* marquee band */
.marquee{ overflow:hidden; background:var(--lime); color:#10120a; border-block:1.5px solid #000; }
.marquee-track{
  display:flex; align-items:center; gap:1.8rem; width:max-content; padding:.7rem 0;
  font-family:var(--f-display); font-weight:800; font-size:1.15rem;
  text-transform:uppercase; letter-spacing:.02em; white-space:nowrap;
  animation:marq 34s linear infinite;
}
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track b{ color:rgba(16,18,10,.4); font-size:.85em; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* mobile menu link stagger */
.head.open .nav a{ animation:menuIn .45s var(--ease) both; }
.head.open .nav a:nth-child(1){ animation-delay:.06s; }
.head.open .nav a:nth-child(2){ animation-delay:.12s; }
.head.open .nav a:nth-child(3){ animation-delay:.18s; }
.head.open .nav a:nth-child(4){ animation-delay:.24s; }
.head.open .nav a:nth-child(5){ animation-delay:.30s; }
.head.open .head-actions{ animation:menuIn .45s var(--ease) .36s both; }
@keyframes menuIn{ from{ opacity:0; transform:translateX(-18px); } to{ opacity:1; transform:none; } }

/* ===== MOBILE-NATIVE: bottom tab bar + swipe tiles ===== */
.bottom-nav{ display:none; }
@media(max-width:820px){
  .bottom-nav{
    display:grid; grid-auto-flow:column; grid-auto-columns:minmax(0,1fr);
    position:fixed; left:0; right:0; bottom:0; z-index:1100;
    background:rgba(11,11,14,.85); backdrop-filter:blur(20px) saturate(150%);
    border-top:1px solid var(--line);
    padding:.45rem .1rem calc(.45rem + env(safe-area-inset-bottom));
  }
  .bottom-nav a{
    min-width:0; display:flex; flex-direction:column; align-items:center; gap:3px;
    padding:.35rem 0; color:var(--faint);
    font-size:.56rem; font-weight:600; letter-spacing:.01em; text-transform:uppercase;
    transition:color .25s;
  }
  .bottom-nav a span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .bottom-nav svg{ width:21px; height:21px; stroke:currentColor; fill:none;
    stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round;
    transition:transform .28s var(--ease); }
  .bottom-nav a.active{ color:var(--lime); }
  .bottom-nav a.active svg{ transform:translateY(-2px) scale(1.1); }
  .bottom-nav a:active svg{ transform:scale(.88); }
  body{ padding-bottom:calc(62px + env(safe-area-inset-bottom)); }
  .head.open{ padding-bottom:0; }

  /* section tiles become a native horizontal snap carousel */
  .tiles-row{
    display:flex; gap:.9rem; overflow-x:auto; padding:.2rem .2rem .8rem;
    scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .tiles-row::-webkit-scrollbar{ display:none; }
  .tile{ flex:0 0 68%; scroll-snap-align:center; }
}

@media(prefers-reduced-motion:reduce){
  .marquee-track{ animation:none; }
  .btn::after{ display:none; }
  .scroll-progress{ display:none; }
  .arc-card:hover .play,.video-feat:hover .play,.video-min:hover .play{ animation:none; }
  .head.open .nav a,.head.open .head-actions{ animation:none; }
  html.js .reveal{ opacity:1; transform:none; transition:none; }
}

/* ============================================================
   SUB-PAGE TITLE BAND + ACTIVE NAV
   ============================================================ */
.page-head{
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(2.6rem,6vh,4.2rem) clamp(1rem,4vw,2.4rem) clamp(.5rem,2vh,1rem);
}
.crumb{
  display:inline-block;margin-bottom:1.4rem;color:var(--muted);
  font-weight:600;font-size:.85rem;letter-spacing:.02em;transition:color .25s,transform .25s var(--ease);
}
.crumb:hover{color:var(--lime);transform:translateX(-3px)}
.page-head h1{
  font-family:var(--f-display);font-weight:800;color:var(--lime);
  font-size:clamp(2.4rem,6.5vw,4.6rem);line-height:1;letter-spacing:-.03em;
}
.page-head .page-desc{margin-top:1.1rem;max-width:58ch;color:var(--muted);font-size:clamp(1rem,1.5vw,1.15rem)}

/* active nav states */
.nav a.active{color:var(--lime)}
.nav a.active::after{width:100%;background:var(--lime)}

/* ============================================================
   STAINED GLASS GALLERY WALL
   ============================================================ */
.glass-wall{max-width:var(--maxw);margin:0 auto;columns:4;column-gap:1rem}
.gw{
  display:block;break-inside:avoid;margin:0 0 1rem;
  border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#000;
  transition:border-color .3s,transform .3s var(--ease);
}
.gw:hover{border-color:var(--line-2);transform:translateY(-3px)}
.gw img{width:100%;display:block;transition:transform .6s var(--ease)}
.gw:hover img{transform:scale(1.05)}
@media(max-width:980px){.glass-wall{columns:3}}
@media(max-width:640px){.glass-wall{columns:2}}

/* ============================================================
   SECTION HEADER (.sec-head) — archives, tiles, galleries
   ============================================================ */
.sec-head{max-width:var(--maxw);margin:0 auto;padding:0 0 clamp(1.4rem,3vh,2.2rem)}
.sec-head .eyebrow{margin-bottom:.6rem}
.sec-head h1,.sec-head h2{
  font-family:var(--f-display);font-weight:800;color:var(--text);
  font-size:clamp(1.9rem,4.6vw,3rem);line-height:1.04;letter-spacing:-.02em;
}
.sec-head .block-desc{margin-top:.6rem;max-width:48ch}

/* ============================================================
   MOBILE-APP FEED POLISH (archives column + cards)
   ============================================================ */
@media(max-width:640px){
  .archives{
    background:
      linear-gradient(180deg, rgba(8,8,14,.18) 0%, rgba(8,12,26,.08) 50%, rgba(8,8,14,.22) 100%),
      url("assets/img/blueleopard.jpg") repeat;
    background-size:auto, 230px auto;
    padding:clamp(1.8rem,4vh,2.6rem) .8rem calc(1.5rem + env(safe-area-inset-bottom));
  }
  .head-panel{display:block;width:auto;max-width:100%;margin-bottom:1.1rem}
  .head-panel h1,.head-panel h2{overflow-wrap:break-word}
  .arc-grid{column-gap:0}

  /* elevated, inset "widget" cards */
  .arc-card{
    margin:0 0 1rem;
    background:#15151b;
    border:1px solid rgba(255,255,255,.06);
    border-radius:22px;
    padding:7px;
    box-shadow:0 14px 34px -18px rgba(0,0,0,.9), 0 2px 8px -4px rgba(0,0,0,.55);
  }
  .arc-media{border-radius:16px;overflow:hidden}
  .arc-card h3{font-size:1.16rem;line-height:1.2;padding:.8rem .7rem .2rem}
  .arc-card p{font-size:.92rem;padding:0 .7rem .55rem}

  /* text-only dedication cards: comfy reading card */
  .arc-card.text-only{padding:1.5rem 1.35rem;border-left-width:4px}
  .arc-card.text-only h3{padding:0 0 .7rem}
  .arc-card.text-only p{padding:0}

  /* tappable affordance + press feedback on link cards */
  a.arc-card h3{position:relative;padding-right:2rem}
  a.arc-card h3::after{
    content:"\203A";position:absolute;right:.7rem;top:.78rem;
    color:var(--lime);font-weight:700;font-size:1.45em;line-height:1;opacity:.85;
    transition:transform .25s var(--ease);
  }
  a.arc-card:active{transform:scale(.975);box-shadow:0 6px 16px -10px rgba(0,0,0,.85)}
  a.arc-card:active h3::after{transform:translateX(3px)}

  /* slightly larger play button reads better on phones */
  .arc-card .play{width:58px;height:58px}

  /* give the section heading app-like weight */
  .head-panel{padding:1rem 1.05rem}
  .head-panel h1,.head-panel h2{font-size:clamp(1.5rem,6vw,2rem)}
}

/* ============================================================
   MOBILE ARCHIVES — DOUBLE-COLUMN MASONRY FEED
   ============================================================ */
@media(max-width:640px){
  .arc-grid{columns:2;column-gap:.7rem}
  .arc-card{border-radius:16px;padding:5px;margin:0 0 .7rem}
  .arc-media{border-radius:11px}
  .arc-card h3{font-size:.9rem;line-height:1.18;padding:.55rem .45rem .12rem;padding-right:.45rem}
  .arc-card p{font-size:.76rem;line-height:1.4;padding:0 .45rem .5rem}
  a.arc-card h3::after{display:none}          /* chevron too tight in 2-col */

  /* smaller play button for compact thumbs */
  .arc-card .play{width:44px;height:44px}
  .arc-card .play::before{border-left-width:13px;border-top-width:8px;border-bottom-width:8px;margin-left:4px}

  /* long dedication text cards break out to full width */
  .arc-card.text-only{
    column-span:all;-webkit-column-span:all;
    padding:1.4rem 1.3rem;margin-bottom:.9rem;
  }
  .arc-card.text-only h3{font-size:1.15rem}
  .arc-card.text-only p{font-size:.92rem}
}

/* ============================================================
   SECTION CTA PILL (.block-link) — bright yellow, site-wide
   ============================================================ */
.block-link{
  flex:0 0 100%; max-width:max-content; margin-top:1.4rem;
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--f-body); font-weight:700; font-size:.95rem; letter-spacing:.01em;
  padding:.8em 1.7em; border-radius:999px;
  background:var(--lime); color:#10120a; border:1.5px solid var(--lime);
  transition:transform .25s var(--ease), background .25s, box-shadow .25s;
}
.block-link:hover{
  transform:translateY(-2px); background:#d6f15e;
  box-shadow:0 14px 28px -12px rgba(200,233,75,.5);
}
.block-link span{transition:transform .25s var(--ease)}
.block-link:hover span{transform:translateX(4px)}
.block-link:active{transform:scale(.97)}

/* ============================================================
   TAKE A TOUR TO THE COZY INN
   ============================================================ */
.cozy{
  padding:clamp(3rem,7vh,5rem) clamp(1rem,4vw,2.4rem) clamp(3.5rem,8vh,5.5rem);
  /* New York graffiti-wall backdrop (Unsplash, free for commercial use) */
  background:
    linear-gradient(180deg, rgba(8,8,12,.80) 0%, rgba(8,8,12,.74) 45%, rgba(8,8,12,.90) 100%),
    url("assets/img/graffiti.jpg") center center / cover no-repeat;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.cozy-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;
}
.cozy-card{
  display:block;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;
  box-shadow:0 18px 40px -22px rgba(0,0,0,.85);
  transition:border-color .3s,transform .3s var(--ease);
}
.cozy-card:hover{border-color:var(--line-2);transform:translateY(-4px)}
.cozy-media{position:relative;display:block;background:#000;aspect-ratio:16/9;overflow:hidden}
.cozy-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.cozy-card:hover .cozy-media img{transform:scale(1.05)}
.cozy-card:hover .play{animation:pulse 1.5s ease-in-out infinite}
.cozy-card h3{
  font-family:var(--f-display);font-weight:700;color:var(--lime);
  font-size:clamp(1.15rem,2vw,1.5rem);line-height:1.15;padding:1.1rem 1.2rem .3rem;
}
.cozy-card p{color:var(--muted);font-size:.95rem;padding:0 1.2rem 1.2rem}
@media(max-width:760px){
  .cozy-grid{grid-template-columns:1fr;gap:1rem}
  .cozy-card{border-radius:18px}
}

/* ============================================================
   DEDICATIONS (Khalis & Dee Tee) — below the awards
   ============================================================ */
.dedications{
  padding:clamp(3.5rem,8vh,6rem) clamp(1rem,4vw,2.4rem);
  background:
    radial-gradient(70% 60% at 50% 0%, rgba(216,172,84,.10), transparent 70%),
    var(--bg);
  border-top:1px solid var(--line);
}
.ded-head{text-align:center}
.ded-head .eyebrow{color:var(--gold)}
.ded-grid{
  max-width:1080px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;align-items:start;
}
.ded-card{
  background:var(--card);border:1px solid var(--line);
  border-top:3px solid var(--gold);border-radius:var(--r);overflow:hidden;
  box-shadow:0 18px 44px -24px rgba(0,0,0,.85);
}
.ded-photo{aspect-ratio:16/10;overflow:hidden;background:#000}
.ded-photo img{width:100%;height:100%;object-fit:cover;object-position:center 28%}
.ded-body{padding:1.5rem 1.6rem 1.9rem}
.ded-body h3{font-family:var(--f-display);font-weight:800;font-size:clamp(1.5rem,3vw,2rem);line-height:1}
.ded-aka{font-family:var(--f-serif);font-style:italic;color:var(--gold);font-size:1.1rem;margin:.25rem 0 1.1rem}
.ded-body p:not(.ded-aka){color:var(--muted);font-size:.95rem}
.ded-body p:not(.ded-aka) + p{margin-top:.85rem}
.ded-video{
  position:relative;display:block;margin:1.4rem 0 .9rem;
  border-radius:12px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9;
}
.ded-video img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.ded-video::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(0,0,0,.45));pointer-events:none}
.ded-video:hover img{transform:scale(1.04)}
.ded-note{color:var(--muted);font-size:.92rem;line-height:1.5;font-weight:500;margin-top:.6rem}
@media(max-width:760px){
  .ded-grid{grid-template-columns:1fr;gap:1.1rem}
  .ded-photo{aspect-ratio:16/9}
}

/* two-photo dedication header (Ronald Bell) */
.ded-photos{
  aspect-ratio:16/10;display:grid;
  grid-auto-flow:column;grid-auto-columns:minmax(0,1fr);gap:2px;
  overflow:hidden;background:#000;
}
.ded-photos img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
@media(max-width:760px){.ded-photos{aspect-ratio:16/9}}

/* ============================================================
   CONTRIBUTORS TO THE KOOLZEUM
   ============================================================ */
.contributors{
  padding:clamp(3rem,7vh,5rem) clamp(1rem,4vw,2.4rem) clamp(3.5rem,8vh,5.5rem);
  background:
    linear-gradient(180deg, rgba(8,8,10,.14) 0%, rgba(8,8,12,.05) 50%, rgba(8,8,10,.18) 100%),
    url("assets/img/zebra.jpg") repeat;
  background-size:auto, 540px auto;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.contrib-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:1.1rem;
}
.contrib{
  display:flex;flex-direction:column;
  background:rgba(10,11,16,.92);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  box-shadow:0 18px 44px -24px rgba(0,0,0,.95);
}
.contrib-img{
  border-radius:0;overflow:hidden;aspect-ratio:4/5;
  background:#0c0c0e;border:0;border-bottom:1px solid var(--line);
}
.contrib-img img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .6s var(--ease)}
.contrib:hover .contrib-img img{transform:scale(1.05)}
.contrib figcaption{padding:.8rem .9rem 1rem}
.contrib figcaption b{display:block;font-family:var(--f-display);font-weight:700;font-size:1rem;line-height:1.2}
.contrib figcaption span{display:block;color:var(--lime);font-weight:600;font-size:.92rem;margin-top:.2rem}
@media(max-width:900px){.contrib-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.contrib-grid{grid-template-columns:repeat(2,1fr);gap:.8rem}}

/* ============================================================
   HEROES GALLERY WALL (heroes.html — all 204, in order)
   ============================================================ */
/* row-major grid so the sequence reads left→right, top→bottom (matches the original order) */
.hero-wall{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(6,1fr);gap:.7rem}
.hw{
  display:block;aspect-ratio:1;overflow:hidden;
  border-radius:10px;border:1px solid var(--line);background:#000;
  transition:border-color .3s,transform .3s var(--ease);
}
.hw:hover{border-color:var(--line-2);transform:translateY(-2px)}
.hw img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.hw:hover img{transform:scale(1.05)}
@media(max-width:1100px){.hero-wall{grid-template-columns:repeat(5,1fr)}}
@media(max-width:800px){.hero-wall{grid-template-columns:repeat(4,1fr)}}
@media(max-width:520px){.hero-wall{grid-template-columns:repeat(3,1fr);gap:.5rem}}

/* ============================================================
   KOOL VIDEOS GALLERY (videos.html — all 50)
   ============================================================ */
.video-wall{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.vid-card{
  display:block;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;
  transition:border-color .3s,transform .3s var(--ease);
}
.vid-card:hover{border-color:var(--line-2);transform:translateY(-4px)}
.vid-media{position:relative;display:block;aspect-ratio:16/9;background:#000;overflow:hidden}
.vid-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.vid-card:hover .vid-media img{transform:scale(1.06)}
.vid-card:hover .play{animation:pulse 1.5s ease-in-out infinite}
.vid-card h3{
  font-family:var(--f-display);font-weight:700;color:var(--lime);
  font-size:1.02rem;line-height:1.2;padding:.9rem 1rem 1.05rem;
}
@media(max-width:900px){.video-wall{grid-template-columns:repeat(2,1fr);gap:1rem}}
@media(max-width:560px){.video-wall{grid-template-columns:1fr}}

/* ============================================================
   VIDEO BROWSING — search + filter toolbar, mobile-first
   ============================================================ */
.vid-toolbar{
  max-width:var(--maxw);margin:0 auto clamp(1.4rem,3vh,2rem);
  position:sticky;top:56px;z-index:60;
  background:linear-gradient(180deg,rgba(12,12,14,.96) 70%,rgba(12,12,14,0));
  backdrop-filter:blur(10px);padding:.9rem 0 1rem;
}
.vid-search{position:relative;max-width:520px}
.vid-search svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:18px;height:18px;stroke:var(--muted);fill:none;stroke-width:2;stroke-linecap:round}
.vid-search input{
  width:100%;background:var(--card);border:1px solid var(--line);border-radius:999px;
  color:var(--text);font-family:var(--f-body);font-size:1rem;padding:.8em 1em .8em 2.7em;
  transition:border-color .25s,background .25s;
}
.vid-search input::placeholder{color:var(--faint)}
.vid-search input:focus{outline:none;border-color:var(--blue);background:var(--bg-soft)}
.vid-chips{display:flex;gap:.5rem;margin-top:.85rem;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:3px}
.vid-chips::-webkit-scrollbar{display:none}
.vid-chip{
  flex:0 0 auto;background:var(--card);border:1px solid var(--line);color:var(--muted);
  font-family:var(--f-body);font-weight:600;font-size:.88rem;letter-spacing:.01em;
  padding:.55em 1.15em;border-radius:999px;cursor:pointer;white-space:nowrap;
  transition:background .2s var(--ease),color .2s,border-color .2s,transform .15s var(--ease);
}
.vid-chip:hover{color:var(--text);border-color:var(--line-2)}
.vid-chip:active{transform:scale(.95)}
.vid-chip.active{background:var(--lime);color:#10120a;border-color:var(--lime)}
.vid-count{margin-top:.75rem;color:var(--faint);font-size:.85rem;letter-spacing:.02em}
.vid-empty{max-width:var(--maxw);margin:0 auto;text-align:center;color:var(--muted);padding:3rem 1rem}
/* filter motion */
.vid-card{transition:border-color .3s,transform .3s var(--ease),opacity .3s var(--ease)}
.vid-card.hide{display:none}
/* scroll-to-top button */
.to-top{
  position:fixed;right:16px;bottom:calc(72px + env(safe-area-inset-bottom));z-index:90;
  width:46px;height:46px;border-radius:50%;background:var(--lime);color:#10120a;border:0;cursor:pointer;
  display:grid;place-items:center;opacity:0;transform:translateY(12px) scale(.9);pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease);box-shadow:0 10px 24px -10px rgba(0,0,0,.8);
}
.to-top svg{width:22px;height:22px;stroke:#10120a;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:active{transform:scale(.92)}
@media(min-width:821px){.to-top{bottom:24px}}

/* ===== KoolPics masonry gallery ===== */
.pics-count{display:inline-block;margin-left:.5rem;color:var(--lime);font-weight:600}
.pics-wall{max-width:var(--maxw);margin:0 auto;columns:4;column-gap:.9rem}
.pic{
  display:block;break-inside:avoid;margin:0 0 .9rem;position:relative;cursor:zoom-in;
  border-radius:14px;overflow:hidden;border:1px solid var(--line);background:var(--card);
  box-shadow:0 8px 22px -16px rgba(0,0,0,.9);
}
.pic img{width:100%;display:block;transition:transform .6s var(--ease)}
.pic::after{
  content:"";position:absolute;inset:0;border-radius:14px;
  background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(0,0,0,.28));
  opacity:0;transition:opacity .3s var(--ease);pointer-events:none;
}
.pic:hover img{transform:scale(1.05)}
.pic:hover::after{opacity:1}
@media(max-width:1100px){.pics-wall{columns:3}}
@media(max-width:760px){.pics-wall{columns:2;column-gap:.6rem}.pic{margin-bottom:.6rem}}

/* ===== Lightbox ===== */
.lightbox{
  position:fixed;inset:0;z-index:200;display:none;
  align-items:center;justify-content:center;
  background:rgba(6,6,9,.94);backdrop-filter:blur(6px);
  opacity:0;transition:opacity .3s var(--ease);
  padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom);
}
.lightbox.open{display:flex;opacity:1}
.lb-img{
  max-width:92vw;max-height:88vh;object-fit:contain;border-radius:10px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.9);
  transform:scale(.96);transition:transform .3s var(--ease);
}
.lightbox.open .lb-img{transform:scale(1)}
.lb-close,.lb-nav{
  position:absolute;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);
  color:#fff;cursor:pointer;display:grid;place-items:center;
  border-radius:50%;transition:background .2s var(--ease),transform .2s var(--ease);
}
.lb-close{top:16px;right:16px;width:46px;height:46px;font-size:1.7rem;line-height:1}
.lb-nav{top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:2rem;line-height:1}
.lb-prev{left:14px}
.lb-next{right:14px}
.lb-close:hover,.lb-nav:hover{background:var(--lime);color:#10120a;border-color:var(--lime)}
.lb-nav:hover{transform:translateY(-50%) scale(1.08)}
.lb-counter{
  position:absolute;bottom:18px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.85);font-family:var(--f-display);font-weight:600;
  font-size:.9rem;letter-spacing:.05em;background:rgba(0,0,0,.4);
  padding:.35rem .8rem;border-radius:999px;
}
@media(max-width:560px){
  .lb-nav{width:44px;height:44px;font-size:1.6rem}
  .lb-prev{left:8px}.lb-next{right:8px}
  .lb-img{max-width:96vw;max-height:80vh}
}
@media(prefers-reduced-motion:reduce){
  .lightbox,.lb-img,.pic img{transition:none}
}
/* compact 2-up grid on phones for faster sifting */
@media(max-width:560px){
  .video-wall{grid-template-columns:repeat(2,1fr);gap:.7rem}
  .vid-card h3{font-size:.8rem;line-height:1.15;padding:.55rem .6rem .7rem}
  .vid-toolbar{top:54px}
}

/* candy-apple-red trust strip — mobile fit */
@media(max-width:680px){
  .trust{padding:clamp(2.5rem,6vh,4rem) 1rem}
  .trust-label{font-size:1.05rem;letter-spacing:.08em;line-height:1.4;max-width:22ch;margin-left:auto;margin-right:auto}
  .trust-row{flex-direction:column;gap:1.5rem}
  .trust-word{font-size:1.7rem;letter-spacing:.02em}
  .trust-row img{height:clamp(110px,34vw,150px)}
  .trust-row img.trust-tall{height:clamp(280px,80vw,360px)}
}

/* ===== PWA install button + iOS Add-to-Home-Screen sheet ===== */
.install-btn{
  position:fixed;left:16px;bottom:calc(78px + env(safe-area-inset-bottom));z-index:95;
  display:inline-flex;align-items:center;gap:.5em;
  background:var(--lime);color:#10120a;border:0;cursor:pointer;
  font-family:var(--f-display);font-weight:800;font-size:.9rem;letter-spacing:.02em;
  padding:.72em 1.15em;border-radius:999px;
  box-shadow:0 14px 32px -10px rgba(0,0,0,.75);
  opacity:0;transform:translateY(14px) scale(.95);pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease);
}
.install-btn.show{opacity:1;transform:none;pointer-events:auto}
.install-btn:active{transform:scale(.94)}
.install-btn svg{width:18px;height:18px;fill:none;stroke:#10120a;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
@media(min-width:821px){.install-btn{left:24px;bottom:24px}}
@media(prefers-reduced-motion:reduce){.install-btn{transition:none}}

.install-sheet{
  position:fixed;inset:0;z-index:210;display:flex;align-items:flex-end;justify-content:center;
  background:rgba(6,6,9,.62);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  opacity:0;transition:opacity .25s var(--ease);
}
.install-sheet.open{opacity:1}
.install-sheet-card{
  position:relative;width:100%;max-width:440px;
  background:linear-gradient(180deg, rgba(18,20,28,.98), rgba(12,13,18,.98));
  border:1px solid rgba(255,255,255,.14);border-bottom:0;
  border-radius:20px 20px 0 0;padding:1.6rem 1.4rem calc(1.8rem + env(safe-area-inset-bottom));
  transform:translateY(100%);transition:transform .3s var(--ease);
  box-shadow:0 -20px 50px -20px rgba(0,0,0,.8);
}
.install-sheet.open .install-sheet-card{transform:none}
.install-sheet-x{position:absolute;top:.9rem;right:1rem;background:rgba(255,255,255,.1);border:0;color:#fff;
  width:34px;height:34px;border-radius:50%;font-size:1.4rem;line-height:1;cursor:pointer}
.install-sheet-icon{width:60px;height:60px;border-radius:14px;display:block;margin-bottom:.9rem;border:1px solid rgba(255,255,255,.12)}
.install-sheet-card h3{font-family:var(--f-display);font-weight:800;font-size:1.3rem;color:#fff;margin:0 0 .35rem}
.install-sheet-card p{color:var(--muted);font-size:.95rem;line-height:1.5;margin:0 0 1rem}
.install-sheet-card ol{margin:0;padding-left:1.2rem;color:#EDEDF0;font-size:.95rem;line-height:1.9}
.install-sheet-card ol b{color:var(--lime)}
.ios-share{display:inline-block;width:15px;height:18px;vertical-align:-3px;
  border:2px solid var(--lime);border-top:0;border-radius:0 0 3px 3px;position:relative}
.ios-share::before{content:"";position:absolute;left:50%;top:-9px;transform:translateX(-50%);
  width:2px;height:9px;background:var(--lime)}
.ios-share::after{content:"";position:absolute;left:50%;top:-9px;transform:translateX(-50%) rotate(45deg);
  width:6px;height:6px;border-top:2px solid var(--lime);border-left:2px solid var(--lime)}
