/* ============================================================
   AVI COHN JIU JITSU — psychedelic leg-lock gig-poster site
   Fighter Websites preview. Written from scratch.
   ============================================================ */

:root{
  --ink:#120A1C;          /* ultraviolet near-black base */
  --ink-2:#180E26;        /* slightly raised panel */
  --ink-3:#1F1330;        /* card */
  --violet:#A05CFF;       /* electric purple primary accent */
  --violet-deep:#6E33C9;
  --violet-glow:rgba(160,92,255,.55);
  --yellow:#F2C94C;       /* acid-yellow sticker accent */
  --bone:#EFEAF4;         /* off-white text */
  --bone-dim:#B4A9C4;     /* muted */
  --line:rgba(160,92,255,.22);
  --magenta:#E14BC2;      /* duotone highlight */

  --f-display:"Syne", system-ui, sans-serif;
  --f-body:"Outfit", system-ui, sans-serif;
  --f-sticker:"Titan One", system-ui, sans-serif;

  --maxw:1220px;
  --gutter:clamp(20px, 5vw, 72px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }

body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--f-body);
  font-weight:300;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ---- ambient background: deep purple glow field ---- */
body::before{
  content:"";
  position:fixed; inset:0;
  z-index:-2;
  background:
    radial-gradient(1200px 900px at 78% -8%, rgba(160,92,255,.16), transparent 60%),
    radial-gradient(900px 700px at 10% 108%, rgba(110,51,201,.16), transparent 62%),
    var(--ink);
  pointer-events:none;
}
/* subtle grain */
body::after{
  content:"";
  position:fixed; inset:0;
  z-index:-1; opacity:.05; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   TYPE HELPERS
   ============================================================ */
.label{
  font-family:var(--f-body);
  font-weight:500;
  font-size:.72rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--violet);
}
.index{
  font-family:var(--f-display);
  font-weight:800;
  color:var(--violet);
  opacity:.85;
}
.sticker{
  font-family:var(--f-sticker);
  color:var(--yellow);
  text-transform:uppercase;
  letter-spacing:.01em;
  -webkit-text-stroke:1.5px rgba(18,10,28,.85);
  text-shadow:3px 3px 0 rgba(18,10,28,.6);
  line-height:.95;
}

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
section{position:relative}
.section-pad{padding-block:clamp(80px,11vw,150px)}

/* torn-paper divider */
.torn{
  display:block; width:100%; height:44px; color:var(--ink-2);
  margin-top:-1px;
}
.torn svg{display:block;width:100%;height:100%}

/* section head with strobe reveal */
.sec-head{
  display:flex; align-items:baseline; gap:1rem; flex-wrap:wrap;
  margin-bottom:clamp(28px,4vw,52px);
}
.sec-head .index{font-size:clamp(1.1rem,2.2vw,1.6rem)}
.sec-head h2{
  font-family:var(--f-display);
  font-weight:800;
  font-size:clamp(2.2rem,6.5vw,4.6rem);
  line-height:.95;
  letter-spacing:-.02em;
  text-transform:uppercase;
}
.sec-head .kicker{
  font-family:var(--f-body); font-weight:300; color:var(--bone-dim);
  font-size:clamp(.95rem,1.6vw,1.15rem); max-width:44ch;
}
.lightning{
  height:2px; width:100%;
  background:linear-gradient(90deg,transparent,var(--violet) 12%,var(--yellow) 50%,var(--violet) 88%,transparent);
  opacity:.5; margin:0;
  clip-path:polygon(0 40%,6% 0,12% 60%,20% 10%,30% 55%,42% 5%,54% 60%,66% 8%,78% 58%,88% 6%,94% 55%,100% 40%,100% 60%,0 60%);
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px var(--gutter);
  transition:background .3s ease, backdrop-filter .3s ease, border-color .3s ease;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(18,10,28,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:12px}
.brand svg{width:34px;height:34px;flex:none}
.brand .wordmark{
  font-family:var(--f-display); font-weight:800;
  letter-spacing:.02em; font-size:1.05rem; text-transform:uppercase;
}
.brand .wordmark span{color:var(--violet)}

.nav{display:flex;gap:1.6rem;align-items:center}
.nav a{
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  font-weight:400; color:var(--bone-dim); position:relative; padding:4px 0;
  transition:color .2s;
}
.nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--violet); transition:width .25s ease;
}
.nav a:hover{color:var(--bone)}
.nav a:hover::after{width:100%}

.hamburger{display:none;width:40px;height:40px;flex-direction:column;gap:5px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:8px}
.hamburger span{display:block;width:20px;height:2px;background:var(--bone);transition:transform .3s,opacity .3s}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile overlay menu */
.mobile-menu{
  position:fixed; inset:0; z-index:99;
  background:rgba(18,10,28,.97);
  backdrop-filter:blur(10px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:1.6rem;
  transform:translateY(-100%);
  transition:transform .4s cubic-bezier(.7,0,.2,1);
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{
  font-family:var(--f-display); font-weight:700; font-size:1.9rem;
  text-transform:uppercase; letter-spacing:.02em; color:var(--bone);
}
.mobile-menu a .idx{color:var(--violet);font-size:1rem;margin-right:.6rem;vertical-align:middle}
.mobile-menu .mm-owl{width:52px;height:52px;opacity:.7;margin-bottom:.5rem}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:min(100svh,1000px);
  display:flex; align-items:center;
  padding-top:96px; padding-bottom:48px;
  overflow:hidden;
}
/* glow-breathe ambient */
.hero__glow{
  position:absolute; z-index:0; pointer-events:none;
  width:min(90vw,900px); height:min(90vw,900px);
  right:-8%; top:38%; transform:translateY(-50%);
  background:radial-gradient(circle, rgba(160,92,255,.35), rgba(160,92,255,.08) 42%, transparent 68%);
  filter:blur(10px);
}
html[data-anim="on"] .hero__glow{ animation:breathe 7s ease-in-out infinite; }
@keyframes breathe{
  0%,100%{opacity:.6; transform:translateY(-50%) scale(.96)}
  50%{opacity:1; transform:translateY(-50%) scale(1.06)}
}

.hero .wrap{position:relative;z-index:2;width:100%}
.hero__grid{
  display:grid;
  /* minmax(0,…) lets the giant-title column shrink instead of crushing the
     photo column; the photo column is guaranteed a real collage width */
  grid-template-columns:minmax(0,1.15fr) minmax(380px,.85fr);
  gap:clamp(24px,4vw,56px);
  align-items:center;
}
.hero__lead{position:relative;z-index:2;min-width:0}

.hero__meta{
  display:flex; gap:.6rem; align-items:center; flex-wrap:wrap;
  font-size:.68rem; letter-spacing:.24em; text-transform:uppercase;
  color:var(--bone-dim); margin-bottom:1.4rem;
}
.hero__meta .dot{color:var(--violet)}

.hero__title{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(3.6rem,15vw,11rem);
  line-height:.82; letter-spacing:-.03em; text-transform:uppercase;
  color:var(--bone);
  text-shadow:0 0 42px rgba(160,92,255,.55), 0 0 90px rgba(160,92,255,.28);
}
.hero__title .line2{display:block}
.hero__jj{
  display:inline-block; margin-top:.35em;
  font-family:var(--f-sticker); font-size:clamp(1.6rem,6vw,4.4rem);
  color:var(--yellow); text-transform:uppercase; letter-spacing:.02em;
  -webkit-text-stroke:2px rgba(18,10,28,.9);
  text-shadow:4px 4px 0 rgba(18,10,28,.55);
  transform:rotate(-2deg);
}

.hero__quote{
  margin:1.6rem 0 1.8rem;
  border-left:2px solid var(--violet);
  padding-left:1rem;
}
.hero__quote blockquote{
  font-family:var(--f-display); font-weight:700;
  font-size:clamp(1.15rem,2.5vw,1.7rem); line-height:1.15;
  color:var(--bone); font-style:italic;
}
.hero__quote cite{
  display:block; margin-top:.5rem; font-style:normal;
  font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--bone-dim);
}
.hero__quote .watch{color:var(--yellow);border-bottom:1px solid rgba(242,201,76,.5)}
.hero__quote .watch:hover{color:var(--bone)}

.hero__cta{display:flex;gap:1rem;flex-wrap:wrap}

/* buttons */
.btn{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--f-body); font-weight:500;
  font-size:.82rem; letter-spacing:.14em; text-transform:uppercase;
  padding:.95rem 1.6rem; border-radius:999px;
  transition:transform .2s, box-shadow .25s, background .25s, color .2s;
  white-space:nowrap;
}
.btn--primary{
  background:var(--violet); color:#fff;
  box-shadow:0 0 0 rgba(160,92,255,0);
}
.btn--primary:hover{
  background:#b678ff;
  box-shadow:0 8px 34px var(--violet-glow);
  transform:translateY(-2px);
}
.btn--ghost{
  border:1px solid var(--violet); color:var(--bone);
}
.btn--ghost:hover{
  background:rgba(160,92,255,.14);
  box-shadow:0 8px 30px rgba(160,92,255,.28);
  transform:translateY(-2px);
}
.btn--yellow{ background:var(--yellow); color:#241a06; font-weight:700 }
.btn--yellow:hover{ background:#ffd85f; transform:translateY(-2px); box-shadow:0 8px 30px rgba(242,201,76,.32) }

/* hero photo chunk — torn-edge duotone */
.hero__photo{
  position:relative; z-index:1; justify-self:end; width:100%; max-width:460px;
  /* pull left under the giant type so the chunk reads collaged, not floating */
  margin-left:clamp(-72px,-4vw,-24px);
}
.hero__photo .frame{
  position:relative; transform:rotate(2.5deg);
  filter:drop-shadow(0 24px 60px rgba(0,0,0,.6));
}
.duotone{position:relative;overflow:hidden}
.duotone img{
  width:100%; height:100%; object-fit:cover; display:block;
  filter:grayscale(1) contrast(1.12) brightness(.92);
  mix-blend-mode:luminosity;
}
.duotone::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(150deg, #2A0E4A 0%, #7B2FD0 42%, #E14BC2 100%);
  mix-blend-mode:color;
}
.duotone::after{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(150deg, rgba(42,14,74,.35), rgba(225,75,194,.18));
  mix-blend-mode:screen; opacity:.55; transition:opacity .4s, filter .4s;
}
.duotone.hoverable{cursor:default}
.duotone.hoverable:hover::after{opacity:.9}
.duotone.hoverable:hover img{filter:grayscale(.7) contrast(1.2) brightness(1)}

/* torn mask via clip-path (irregular) */
.torn-mask{
  -webkit-mask:var(--torn-svg) center/100% 100% no-repeat;
          mask:var(--torn-svg) center/100% 100% no-repeat;
}
.hero__photo .tag{
  position:absolute; bottom:-14px; left:-14px; z-index:5;
  font-family:var(--f-sticker); font-size:.9rem; color:var(--yellow);
  background:var(--ink-2); border:1px solid var(--line);
  padding:.35rem .7rem; border-radius:6px; transform:rotate(-3deg);
  -webkit-text-stroke:0; text-shadow:none; letter-spacing:.02em;
}

/* side vertical text */
.hero__side{
  position:absolute; right:calc(var(--gutter) * .35); top:50%;
  transform:translateY(-50%) rotate(180deg);
  writing-mode:vertical-rl;
  font-size:.62rem; letter-spacing:.4em; text-transform:uppercase;
  color:var(--bone-dim); opacity:.5; z-index:2;
}

/* scroll cue */
.hero__cue{
  position:absolute; bottom:22px; left:50%; transform:translateX(-50%);
  font-size:.6rem; letter-spacing:.3em; text-transform:uppercase; color:var(--bone-dim);
  display:flex; flex-direction:column; align-items:center; gap:.4rem; z-index:2; opacity:.7;
}
.hero__cue span{animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ============================================================
   ABOUT
   ============================================================ */
.about{background:var(--ink-2)}
.about__grid{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,64px); align-items:center;
}
.about__body p{margin-bottom:1.1rem; color:var(--bone-dim); font-size:clamp(1rem,1.6vw,1.15rem)}
.about__body p strong{color:var(--bone);font-weight:500}
.about__stats{display:flex;gap:2rem;margin-top:1.8rem;flex-wrap:wrap}
.about__stats .stat b{display:block;font-family:var(--f-display);font-weight:800;font-size:2rem;color:var(--violet)}
.about__stats .stat span{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-dim)}

.about__photo{position:relative}
.about__photo .frame{transform:rotate(-2deg);filter:drop-shadow(0 24px 60px rgba(0,0,0,.55))}
.about__photo .cap{
  margin-top:1rem; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--bone-dim);
}
.about__photo .cap b{color:var(--violet)}

/* ghosted owl watermark */
.owl-ghost{
  position:absolute; z-index:0; pointer-events:none; opacity:.05;
  width:min(60vw,620px); color:var(--violet);
  right:-8%; bottom:-6%;
}
.owl-ghost svg{width:100%;height:auto}

/* ============================================================
   PRIVATES
   ============================================================ */
.cards{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px);
}
.card{
  background:var(--ink-3); border:1px solid var(--line); border-radius:16px;
  padding:clamp(22px,3vw,34px);
  position:relative; overflow:hidden;
  transition:transform .25s, border-color .25s, box-shadow .3s;
}
.card:hover{transform:translateY(-4px);border-color:var(--violet);box-shadow:0 18px 46px rgba(160,92,255,.16)}
.card__name{font-family:var(--f-display);font-weight:700;font-size:1.15rem;text-transform:uppercase;letter-spacing:.02em;margin-bottom:.4rem}
.price-chip{
  display:inline-block; font-family:var(--f-sticker);
  font-size:2.4rem; color:var(--yellow); line-height:1;
  -webkit-text-stroke:1.5px rgba(18,10,28,.85); text-shadow:3px 3px 0 rgba(18,10,28,.5);
  transform:rotate(-2deg); margin:.3rem 0 .2rem;
}
.card__unit{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bone-dim);display:block;margin-bottom:1rem}
.card__desc{color:var(--bone-dim);font-size:.95rem}
.card--feature{border-color:var(--violet);box-shadow:0 0 0 1px var(--violet), 0 18px 46px rgba(160,92,255,.14)}
.card--feature::before{content:"MOST BOOKED";position:absolute;top:14px;right:-30px;transform:rotate(38deg);background:var(--violet);color:#fff;font-size:.56rem;letter-spacing:.14em;padding:3px 34px;font-weight:600}

.topics{margin-top:clamp(28px,4vw,44px)}
.topics h3{font-family:var(--f-body);font-weight:500;font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--violet);margin-bottom:1rem}
.topics__grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:.5rem 1rem;
}
.topics__grid li{
  list-style:none; font-size:.86rem; letter-spacing:.06em; color:var(--bone);
  padding:.55rem .2rem; border-bottom:1px solid var(--line);
  display:flex; align-items:center; gap:.5rem;
}
.topics__grid li::before{content:"";width:6px;height:6px;background:var(--violet);border-radius:1px;flex:none;transform:rotate(45deg)}
.fineprint{margin-top:1.4rem;font-size:.78rem;color:var(--bone-dim);letter-spacing:.02em}
.privates__cta{margin-top:2rem;display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.privates__cta .note{font-size:.8rem;color:var(--yellow);letter-spacing:.04em}

/* ============================================================
   SEMINARS — tour block
   ============================================================ */
.seminars{background:var(--ink-2)}
.tour__list{border-top:1px solid var(--line)}
.tour__row{
  display:grid; grid-template-columns:auto 1fr auto auto; gap:1.4rem; align-items:center;
  padding:1.4rem 0; border-bottom:1px solid var(--line);
  transition:background .25s;
}
.tour__row:hover{background:rgba(160,92,255,.06)}
.tour__date{
  font-family:var(--f-sticker); color:var(--yellow); font-size:1.5rem; line-height:1;
  -webkit-text-stroke:1px rgba(18,10,28,.85); text-shadow:2px 2px 0 rgba(18,10,28,.5);
  min-width:120px;
}
.tour__where b{display:block;font-family:var(--f-display);font-weight:700;font-size:1.2rem;text-transform:uppercase;letter-spacing:.01em}
.tour__where span{font-size:.86rem;color:var(--bone-dim)}
.tour__time{font-size:.86rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-dim);white-space:nowrap}
.tour__price{
  font-family:var(--f-sticker); font-size:1rem; color:var(--yellow); white-space:nowrap;
  -webkit-text-stroke:0; text-shadow:none;
}
.tour__price a{color:var(--violet);text-decoration:underline;font-family:var(--f-body);font-size:.78rem;display:block;text-transform:uppercase;letter-spacing:.1em;margin-top:.2rem}
.tour__price .free{color:var(--yellow)}

.seminars__foot{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,56px); align-items:center;
  margin-top:clamp(36px,5vw,64px);
}
.seminars__pitch p{color:var(--bone-dim);margin-bottom:1.2rem;font-size:clamp(1rem,1.6vw,1.15rem)}
.seminars__pitch h3{font-family:var(--f-display);font-weight:800;font-size:clamp(1.6rem,3.5vw,2.4rem);text-transform:uppercase;line-height:1;margin-bottom:1rem}
.seminars__proof .frame{transform:rotate(1.5deg);filter:drop-shadow(0 20px 50px rgba(0,0,0,.5))}
.seminars__proof .cap{margin-top:.8rem;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-dim)}

/* flyer wall */
.flyer-wall{display:flex;gap:1.2rem;margin-top:clamp(30px,4vw,50px);flex-wrap:wrap;justify-content:center}
.flyer-wall figure{width:200px;transition:transform .3s}
.flyer-wall figure img{border-radius:8px;border:1px solid var(--line);box-shadow:0 16px 40px rgba(0,0,0,.5)}
.flyer-wall figure:nth-child(1){transform:rotate(-4deg)}
.flyer-wall figure:nth-child(2){transform:rotate(3deg)}
.flyer-wall figure:hover{transform:rotate(0) scale(1.04);z-index:3}
.flyer-wall figcaption{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-dim);text-align:center;margin-top:.5rem}

/* ============================================================
   INSTRUCTIONALS — coming soon
   ============================================================ */
.instr__inner{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px);align-items:center;
}
.stamp{
  font-family:var(--f-sticker); font-size:clamp(2.4rem,7vw,5rem);
  color:var(--yellow); text-transform:uppercase; line-height:.9;
  -webkit-text-stroke:2px rgba(18,10,28,.9); text-shadow:5px 5px 0 rgba(18,10,28,.5);
  transform:rotate(-3deg); display:inline-block;
  border:4px solid rgba(242,201,76,.5); padding:.2em .3em; border-radius:10px;
}
.instr__teaser p{color:var(--bone-dim);margin:1.4rem 0;font-size:clamp(1rem,1.6vw,1.15rem)}
.notify{display:flex;gap:.6rem;flex-wrap:wrap;max-width:440px}
.notify input{
  flex:1 1 200px; background:var(--ink-3); border:1px solid var(--line); color:var(--bone);
  padding:.9rem 1.1rem; border-radius:999px; font-family:inherit; font-size:.9rem;
}
.notify input:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(160,92,255,.18)}
.notify .demo-note{width:100%;font-size:.72rem;color:var(--bone-dim);letter-spacing:.04em;margin-top:.3rem}
.form-success{color:var(--yellow);font-weight:500;letter-spacing:.02em;margin-top:.6rem;display:none}
.form-success.show{display:block}

/* ============================================================
   REELS
   ============================================================ */
.reels__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2.4vw,28px)}
.reel{
  position:relative; background:var(--ink-3); border:1px solid var(--line); border-radius:16px;
  overflow:hidden; min-height:220px;
  transition:border-color .25s, box-shadow .3s, transform .25s;
}
.reel__facade{
  display:flex;flex-direction:column;justify-content:space-between;
  padding:clamp(20px,3vw,30px); min-height:220px; width:100%; text-align:left;
  position:relative;
}
.reel:hover{border-color:var(--violet);box-shadow:0 18px 46px rgba(160,92,255,.16);transform:translateY(-3px)}
.reel__facade .glyph{
  width:56px;height:56px;border-radius:50%;border:1px solid var(--violet);
  display:flex;align-items:center;justify-content:center;color:var(--violet);
  transition:background .25s,color .25s,box-shadow .25s;
}
.reel:hover .glyph{background:var(--violet);color:#fff;box-shadow:0 0 24px var(--violet-glow)}
.reel__facade .glyph svg{width:22px;height:22px;margin-left:3px}
.reel__label{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--violet);margin-top:auto}
.reel__title{font-family:var(--f-display);font-weight:700;font-size:1.15rem;line-height:1.15;margin-top:.3rem}
.reel__open{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-dim);margin-top:.7rem;display:inline-block}
.reel__open:hover{color:var(--yellow)}
.reel--proof{border-color:var(--yellow)}
.reel--proof .reel__label{color:var(--yellow)}
.reel__badge{position:absolute;top:14px;right:14px;font-family:var(--f-sticker);font-size:.62rem;color:var(--yellow);background:var(--ink-2);border:1px solid rgba(242,201,76,.4);padding:.25rem .5rem;border-radius:5px;-webkit-text-stroke:0;text-shadow:none;letter-spacing:.06em}
.reel iframe{width:100%;height:670px;border:0;display:block;background:#000}
.reel.playing{min-height:670px}

/* ============================================================
   MERCH
   ============================================================ */
.merch__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,4vw,48px);align-items:center}
.merch__item{position:relative;text-align:center}
.merch__item .glow{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(circle at 50% 45%, rgba(160,92,255,.28), transparent 62%);
  filter:blur(6px);transition:opacity .35s;opacity:.7;
}
.merch__item:hover .glow{opacity:1}
.merch__item img{position:relative;z-index:1;margin:0 auto;max-height:420px;width:auto;filter:drop-shadow(0 20px 50px rgba(0,0,0,.6))}
.merch__item figcaption{position:relative;z-index:1;margin-top:1rem;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-dim)}
.merch__buy{text-align:center;margin-top:clamp(30px,4vw,50px)}
.merch__price{font-family:var(--f-sticker);font-size:clamp(1.8rem,4vw,2.8rem);color:var(--yellow);-webkit-text-stroke:1.5px rgba(18,10,28,.85);text-shadow:3px 3px 0 rgba(18,10,28,.5);display:inline-block;transform:rotate(-1.5deg)}
.merch__buy p{color:var(--bone-dim);margin-top:1rem}
.merch__buy .soon{font-size:.78rem;color:var(--bone-dim);margin-top:.5rem;letter-spacing:.06em}

/* ============================================================
   CONTACT / FOOTER
   ============================================================ */
.contact{background:var(--ink-2)}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px)}
.contact__links a.big{
  display:flex;align-items:center;gap:.8rem;
  font-family:var(--f-display);font-weight:700;font-size:clamp(1.3rem,3vw,2rem);
  text-transform:uppercase;padding:1rem 0;border-bottom:1px solid var(--line);
  transition:color .2s,padding-left .2s;
}
.contact__links a.big:hover{color:var(--violet);padding-left:.6rem}
.contact__links a.big .arrow{margin-left:auto;color:var(--violet)}
.contact__news h3{font-family:var(--f-display);font-weight:700;font-size:1.4rem;text-transform:uppercase;margin-bottom:1rem}
.contact__news p{color:var(--bone-dim);margin-bottom:1.2rem;font-size:.95rem}

.site-footer{padding:clamp(40px,6vw,64px) var(--gutter);border-top:1px solid var(--line);text-align:center}
.site-footer .fowl{width:46px;height:46px;margin:0 auto 1rem;opacity:.6}
.site-footer .disc{font-size:.78rem;color:var(--bone-dim);max-width:60ch;margin:0 auto 1rem;line-height:1.7}
.site-footer .by{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--violet)}

/* ============================================================
   ENTRANCE / SCROLL REVEAL (gated)
   ============================================================ */
/* scroll reveals only apply when JS added data-io */
html[data-io] .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
html[data-io] .reveal.in{opacity:1;transform:none}

/* strobe-flash for section heads (only under entrance mode) */
html[data-entrance="js"] .sec-head{opacity:0}
html[data-entrance="js"] .sec-head.strobe{animation:strobe .5s steps(1) forwards}
@keyframes strobe{
  0%{opacity:0}
  12%{opacity:1}
  24%{opacity:0}
  36%{opacity:1}
  48%{opacity:.2}
  60%{opacity:1}
  100%{opacity:1}
}

/* hero entrance (gated) */
html[data-entrance="js"] .hero__title,
html[data-entrance="js"] .hero__jj,
html[data-entrance="js"] .hero__meta,
html[data-entrance="js"] .hero__quote,
html[data-entrance="js"] .hero__cta,
html[data-entrance="js"] .hero__photo{
  opacity:0; transform:translateY(20px);
}
html[data-anim="on"] .hero__title,
html[data-anim="on"] .hero__jj,
html[data-anim="on"] .hero__meta,
html[data-anim="on"] .hero__quote,
html[data-anim="on"] .hero__cta,
html[data-anim="on"] .hero__photo{
  animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards;
}
html[data-anim="on"] .hero__meta{animation-delay:.05s}
html[data-anim="on"] .hero__title{animation-delay:.12s}
html[data-anim="on"] .hero__jj{animation-delay:.34s}
html[data-anim="on"] .hero__quote{animation-delay:.5s}
html[data-anim="on"] .hero__cta{animation-delay:.62s}
html[data-anim="on"] .hero__photo{animation-delay:.28s}
@keyframes rise{to{opacity:1;transform:none}}

/* flash-pulse when nav-targeted */
.flash-pulse{animation:flashpulse .6s ease}
@keyframes flashpulse{
  0%{box-shadow:inset 0 0 0 2000px rgba(160,92,255,0)}
  30%{box-shadow:inset 0 0 0 2000px rgba(160,92,255,.12)}
  100%{box-shadow:inset 0 0 0 2000px rgba(160,92,255,0)}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .nav{display:none}
  .hamburger{display:flex}
  .hero__grid{grid-template-columns:1fr;gap:2rem}
  .hero__photo{max-width:340px;justify-self:start;margin-top:1rem;margin-left:0}
  .hero__side{display:none}
  .about__grid,.instr__inner,.seminars__foot,.merch__grid,.contact__grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .topics__grid{grid-template-columns:repeat(2,1fr)}
  .reels__grid{grid-template-columns:1fr}
}
@media (max-width:600px){
  .hero{padding-top:88px}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{justify-content:center}
  .tour__row{grid-template-columns:1fr;gap:.4rem;text-align:left}
  .tour__date{font-size:1.7rem}
  .topics__grid{grid-template-columns:1fr}
  .hero__cue{display:none}
  .flyer-wall figure{width:150px}
}
