/* ===== NIPUN — shared styles ===== */
:root{
  --ink:#1b1f24;
  --void:#0a0c0e;
  --white:#ffffff;
  --muted:#c5c5c5;
  --line:rgba(255,255,255,.14);
  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1320px;
  /* Figma active-state gradient underline (teal → cyan → purple → gold → magenta) */
  --accent-line:linear-gradient(90deg,#187870 0%,#2dddcf 23%,#6e2dde 46%,#dca52d 71%,#990552 100%);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:"Space Grotesk",sans-serif;
  background:var(--void);
  color:var(--white);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}

/* film grain overlay */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:90;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
  opacity:.05;mix-blend-mode:overlay;
}

/* ===== HERO SHELL (every page) ===== */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;
  padding:clamp(22px,3.2vw,46px) clamp(20px,4vw,64px);
  isolation:isolate;overflow:hidden;
}
.hero__bg{
  position:absolute;inset:0;z-index:-2;
  background:url("./hero-bg.jpg") center top/cover no-repeat;
  transform-origin:50% 0%;transform:scale(1.01);will-change:transform;
  animation:slowzoom 28s var(--ease) infinite alternate;
}
@keyframes slowzoom{from{transform:scale(1.01)}to{transform:scale(1.06)}}
.hero__scrim{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(10,12,14,.55) 0%,rgba(10,12,14,.12) 14%,transparent 38%,rgba(10,12,14,.30) 70%,rgba(10,12,14,.86) 100%);
}

/* plain dark-gradient hero (Tour / Music / About / News — no photo, per Figma) */
.hero.plain{
  background:
    radial-gradient(120% 70% at 50% -8%,rgba(44,50,58,.55),transparent 55%),
    linear-gradient(180deg,#1b1f24 0%,#15181d 42%,#0d0f12 78%,var(--void) 100%);
}
.hero.plain .hero__bg,.hero.plain .hero__scrim{display:none}

/* top bar */
.bar{display:flex;align-items:center;justify-content:space-between;gap:24px;position:relative;z-index:100}
.logo{width:clamp(180px,16vw,250px);height:auto}
.logo img{width:100%;height:auto;filter:drop-shadow(0 2px 18px rgba(0,0,0,.4))}

.nav{display:flex;gap:clamp(22px,2.6vw,42px);align-items:center}
.nav a{
  font-weight:600;font-size:20px;line-height:1.276;letter-spacing:-1.2px;color:var(--white);text-transform:uppercase;
  position:relative;padding:6px 0;opacity:.88;transition:opacity .3s var(--ease);
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:-4px;height:2px;width:100%;
  background:var(--accent-line);border-radius:2px;
  transform:scaleX(0);transform-origin:right;
  transition:transform .45s var(--ease);
}
.nav a:hover{opacity:1}
.nav a:hover::after{transform:scaleX(1);transform-origin:left}
.nav a.active{opacity:1}
.nav a.active::after{transform:scaleX(1);transform-origin:left}

.burger{display:none;flex-direction:column;justify-content:center;gap:5px;
  background:none;border:0;cursor:pointer;width:44px;height:44px;padding:9px;z-index:101}
.burger span{display:block;height:3px;width:100%;background:#e9e9e9;border-radius:3px;
  transition:transform .35s var(--ease),opacity .25s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* center content area */
.hero__center{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;position:relative;z-index:5;padding:48px 0;width:100%;
}
.hero__center::before{
  content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:min(960px,92vw);height:60%;z-index:-1;pointer-events:none;
  background:radial-gradient(60% 60% at 50% 50%,rgba(10,12,14,.55),transparent 72%);
  filter:blur(8px);
}
.hero__eyebrow{
  font-weight:600;font-size:12px;letter-spacing:5px;text-transform:uppercase;
  color:var(--muted);margin-bottom:26px;opacity:.9;text-shadow:0 1px 10px rgba(0,0,0,.8);
}
.hero__tag{
  font-weight:400;font-size:clamp(19px,2vw,26px);line-height:1.36;
  max-width:620px;text-wrap:balance;padding:0 6px;
  text-shadow:0 2px 24px rgba(0,0,0,.85),0 1px 3px rgba(0,0,0,.7);
}

/* hero bottom row (tagline + social) */
.hero__foot{
  display:flex;align-items:flex-end;justify-content:space-between;gap:28px;
  position:relative;z-index:10;
}
.foot__tag{
  font-weight:400;font-size:clamp(17px,1.7vw,24px);line-height:1.25;max-width:600px;
  color:rgba(255,255,255,.92);text-shadow:0 2px 18px rgba(0,0,0,.7);
}
.foot__links{display:flex;gap:30px}
.foot__links a{
  font-weight:600;font-size:20px;letter-spacing:-1.2px;
  color:var(--white);opacity:.78;transition:opacity .3s var(--ease),transform .3s var(--ease);
}
.foot__links a:hover{opacity:1;transform:translateY(-2px)}

/* social icons — per Figma (78:202): filled circle normal → outlined circle on hover, white glyphs */
.social{display:flex;gap:clamp(8px,1.1vw,14px);align-items:center;flex-wrap:wrap}
.social a{
  width:clamp(42px,3.3vw,48px);height:clamp(42px,3.3vw,48px);
  display:grid;place-items:center;border-radius:50%;
  background:rgba(255,255,255,.14);border:1.5px solid transparent;
  transition:background .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease);
}
.social a img{width:46%;height:46%;filter:brightness(0) invert(1)}
.social a:hover{
  background:transparent;border-color:rgba(255,255,255,.85);
  transform:translateY(-3px);
}

/* scroll hint (home) */
.scrollhint{
  position:absolute;left:50%;bottom:108px;transform:translateX(-50%);z-index:6;
  width:1px;height:54px;background:linear-gradient(var(--white),transparent);opacity:.5;
}
.scrollhint::after{
  content:"";position:absolute;left:50%;top:0;width:4px;height:14px;border-radius:4px;
  background:var(--white);transform:translateX(-50%);
  animation:drop 2.2s var(--ease) infinite;
}
@keyframes drop{0%{transform:translate(-50%,0);opacity:0}30%{opacity:1}100%{transform:translate(-50%,40px);opacity:0}}

/* ===== PAGE CONTENT (tour / about / news) ===== */
.page{
  flex:1;display:flex;flex-direction:column;justify-content:center;
  position:relative;z-index:5;width:100%;max-width:var(--maxw);margin:0 auto;
  padding:clamp(40px,6vw,90px) 0 clamp(30px,4vw,60px);
}
.page__head{display:flex;align-items:baseline;gap:20px;margin-bottom:clamp(26px,3vw,44px)}
.page__head h1{font-weight:700;font-size:clamp(28px,3.4vw,46px);letter-spacing:-1.7px;line-height:1;text-transform:uppercase}
.page__head .rule{flex:1;height:1px;background:var(--line);transform:translateY(-6px)}
.page__head .idx{font-weight:600;font-size:14px;letter-spacing:2px;color:var(--muted);opacity:.7;white-space:nowrap}

/* tour empty state — per Figma (91:2000): full-bleed framed area, top-aligned */
.page.tour-empty{
  max-width:none;width:auto;
  margin:clamp(16px,2.4vw,30px) calc(-1 * clamp(20px,4vw,64px)) clamp(28px,3.4vw,44px);
  padding:clamp(26px,3.4vw,44px) clamp(20px,4vw,64px) 0;
  border-top:1px solid rgba(255,255,255,.22);
  border-bottom:1px solid rgba(255,255,255,.22);
  align-items:center;justify-content:flex-start;text-align:center;
  gap:clamp(48px,10vw,144px);
}
.tour-empty__title{
  position:relative;padding-bottom:12px;
  font-weight:700;font-size:clamp(22px,2.6vw,28px);letter-spacing:-1.68px;line-height:1.276;
  text-transform:uppercase;color:var(--white);
}
.tour-empty__title::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:var(--accent-line);border-radius:2px;
}
.tour-empty__sub{
  font-weight:400;font-size:clamp(17px,1.7vw,24px);line-height:1.276;letter-spacing:0;
  text-transform:capitalize;color:#737373;max-width:500px;
}

/* tour list — centered, per Figma (22:417) */
.tour-heading{
  display:block;width:max-content;max-width:100%;margin:0 auto clamp(26px,4vw,52px);
  text-align:center;font-weight:700;font-size:clamp(28px,3.4vw,46px);letter-spacing:-1.7px;
  line-height:1;text-transform:uppercase;position:relative;padding-bottom:12px;
}
.tour-heading::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:var(--accent-line);border-radius:2px;
}
.tours{display:flex;flex-direction:column}
.tour{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:baseline;gap:4px 14px;text-align:center;
  padding:clamp(14px,1.7vw,22px) 4px;border-bottom:1px solid rgba(255,255,255,.2);
  transition:background .4s var(--ease);
}
.tour:hover{background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent)}
.tour__date{font-weight:600;font-size:clamp(17px,1.55vw,24px);letter-spacing:-1px}
.tour__venue{font-weight:400;font-size:clamp(16px,1.5vw,22px);letter-spacing:-.8px;color:rgba(255,255,255,.9)}
.tour__label{
  position:relative;font-weight:600;font-size:clamp(15px,1.4vw,22px);letter-spacing:-1px;
  color:rgba(255,255,255,.85);margin-left:6px;padding-bottom:5px;white-space:nowrap;
}
.tour__label::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;border-radius:2px;
  background:rgba(255,255,255,.85);transition:background .35s var(--ease);
}
.tour:hover .tour__label{color:#fff}
.tour:hover .tour__label::after{background:var(--accent-line)}
.tour__more{text-align:center;margin-top:clamp(26px,3.5vw,46px);font-weight:700;font-size:clamp(18px,2vw,28px);letter-spacing:-1.5px;color:var(--muted)}

/* about header — plain dark nav strip, EXACTLY like the tour-dates header:
   same charcoal gradient (matched to the top slice of .hero.plain, so it doesn't
   compress to black) + a full-width divider line under the nav */
.hero.about-hero{
  min-height:auto;padding-bottom:clamp(16px,2.4vw,30px);
  /* render the EXACT .hero.plain (tour) gradient; 100vh background-size stops the short
     strip from compressing it, so the nav area matches the tour header pixel-for-pixel */
  background:
    radial-gradient(120% 70% at 50% -8%,rgba(44,50,58,.55),transparent 55%),
    linear-gradient(180deg,#1b1f24 0%,#15181d 42%,#0d0f12 78%,var(--void) 100%);
  background-size:100% 100vh;background-repeat:no-repeat;
  border-bottom:1px solid rgba(255,255,255,.22);
}
/* full-width photo banner below the header — homepage-style cover background
   (same technique as nipun-main .hero__bg, which renders the photo cleanly per Figma) */
.about-banner{
  position:relative;overflow:hidden;height:clamp(420px,46vw,720px);
  background:url("about-hero1.jpg") 50% 14% / cover no-repeat;
}
.about-banner::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:34%;pointer-events:none;
  background:linear-gradient(180deg,transparent,var(--void));
}

/* about bio section (dark) under the hero */
.about-section{
  background:var(--void);
  padding:clamp(40px,6vw,86px) clamp(20px,4vw,64px) clamp(40px,5vw,72px);
}
.about{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%}

/* about footer — divider + space above, tagline + CONTACT/IMPRINT (underlined), per Figma */
.about-foot{
  background:var(--void);border-top:1px solid rgba(255,255,255,.22);
  padding:clamp(34px,4vw,52px) clamp(20px,4vw,64px) clamp(40px,4vw,56px);
}
.about-foot .hero__foot{max-width:var(--maxw);margin:0 auto}
.foot__links a{position:relative;padding-bottom:5px}
.foot__links a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:rgba(255,255,255,.92);border-radius:2px;
}
.about__title{
  position:relative;padding-bottom:12px;
  font-weight:700;font-size:clamp(24px,2.6vw,28px);letter-spacing:-1.68px;line-height:1.276;
  text-transform:uppercase;margin:clamp(34px,5vw,64px) 0 clamp(20px,2vw,28px);
}
.about__title::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:var(--accent-line);border-radius:2px;
}
.about__body{max-width:926px;display:flex;flex-direction:column;gap:clamp(16px,1.4vw,18px)}
.about__body p{
  font-weight:400;font-size:clamp(16px,1.7vw,24px);line-height:1.3;letter-spacing:0;
  color:var(--white);text-align:center;
}

/* generic note (music / news placeholder) */
.note{font-weight:400;font-size:clamp(16px,1.6vw,22px);letter-spacing:-.6px;color:rgba(255,255,255,.7);max-width:560px}

/* ===== MUSIC PAGE ===== */
.music-block{margin-bottom:clamp(56px,8vw,110px)}
.music-block:last-child{margin-bottom:0}
.block__head{display:flex;align-items:baseline;gap:20px;margin-bottom:clamp(24px,3vw,40px)}
.block__head h2{font-weight:700;font-size:clamp(22px,2.6vw,34px);letter-spacing:-1.4px;line-height:1;text-transform:uppercase;white-space:nowrap}
.block__head .rule{flex:1;height:1px;background:var(--line);transform:translateY(-6px)}
.block__head .count{font-weight:600;font-size:13px;letter-spacing:2px;color:var(--muted);opacity:.7;white-space:nowrap}

/* streaming players (Spotify + SoundCloud) */
.streams{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.2vw,30px)}
.player-wrap{border-radius:14px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5);background:#0d0f12}
.player-wrap iframe{display:block;width:100%;border:0}
@media(max-width:820px){.streams{grid-template-columns:1fr}}

/* carousel (Sets / Music Videos — like the real site) */
.carousel{position:relative}
.carousel__track{
  display:flex;gap:clamp(16px,1.6vw,24px);
  overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:2px 2px 18px;margin:0 -2px;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.22) transparent;
}
.carousel__track::-webkit-scrollbar{height:6px}
.carousel__track::-webkit-scrollbar-track{background:transparent}
.carousel__track::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:6px}
.carousel__track > .vid{flex:0 0 clamp(280px,31.5%,380px);scroll-snap-align:start}
.carousel__nav{display:flex;gap:10px;align-self:center}
.cbtn{
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;cursor:pointer;
  background:rgba(13,15,18,.7);border:1px solid var(--line);
  transition:border-color .3s var(--ease),background .3s var(--ease),transform .3s var(--ease);
}
.cbtn:hover{border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.08);transform:translateY(-2px)}
.cbtn::before{content:"";width:9px;height:9px;border-top:2px solid #e9e9e9;border-right:2px solid #e9e9e9}
.cbtn[data-dir="-1"]::before{transform:rotate(-135deg);margin-left:4px}
.cbtn[data-dir="1"]::before{transform:rotate(45deg);margin-right:4px}
@media(max-width:620px){
  .carousel__nav{display:none}
  .carousel__track > .vid{flex:0 0 82%}
}

/* video grid (legacy / fallback) */
.vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.2vw,30px)}
.vid{display:flex;flex-direction:column;gap:14px;color:inherit;text-decoration:none}
.vid__meta{display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.vid__thumb{
  position:relative;aspect-ratio:16/9;overflow:hidden;border-radius:10px;background:#15181d;
  box-shadow:0 16px 40px rgba(0,0,0,.4);
}
.vid__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),opacity .4s var(--ease)}
.vid__thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,10,12,.55));opacity:.7;transition:opacity .4s var(--ease)}
.vid__play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.9);z-index:2;
  width:58px;height:58px;border-radius:50%;display:grid;place-items:center;
  background:rgba(10,12,14,.5);border:1.5px solid rgba(255,255,255,.7);backdrop-filter:blur(2px);
  opacity:0;transition:opacity .4s var(--ease),transform .4s var(--ease);
}
.vid__play::before{content:"";margin-left:3px;border-style:solid;border-width:9px 0 9px 15px;border-color:transparent transparent transparent #fff}
.vid:hover .vid__thumb img{transform:scale(1.06)}
.vid:hover .vid__thumb::after{opacity:.9}
.vid:hover .vid__play{opacity:1;transform:translate(-50%,-50%) scale(1)}
.vid__title{font-weight:600;font-size:clamp(15px,1.15vw,17px);letter-spacing:-.5px;line-height:1.3;color:#fff;
  position:relative;display:inline-block;padding-bottom:6px}
.vid__title::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;background:var(--accent-line);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.vid:hover .vid__title::after{transform:scaleX(1)}
.vid__thumb.is-playing::after{opacity:0}
.vid__thumb.is-playing .vid__play{display:none}
.vid__tag{font-weight:600;font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted);opacity:.75}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:24px;
  background:rgba(5,6,8,.92);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox__frame{position:relative;width:min(1100px,100%);aspect-ratio:16/9;box-shadow:0 40px 120px rgba(0,0,0,.7)}
.lightbox__frame iframe{width:100%;height:100%;border:0;border-radius:10px;background:#000}
.lightbox__close{position:absolute;top:-46px;right:0;width:40px;height:40px;background:none;border:0;cursor:pointer}
.lightbox__close::before,.lightbox__close::after{content:"";position:absolute;left:50%;top:50%;width:30px;height:2px;background:#fff;transform-origin:center;border-radius:2px}
.lightbox__close::before{transform:translate(-50%,-50%) rotate(45deg)}
.lightbox__close::after{transform:translate(-50%,-50%) rotate(-45deg)}

@media(max-width:1024px){.vid-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.vid-grid{grid-template-columns:1fr}}

/* about/standalone section under a hero */
.section{
  position:relative;
  background:linear-gradient(180deg,var(--void) 0%,var(--ink) 30%,var(--ink) 70%,var(--void) 100%);
  padding:clamp(70px,9vw,150px) clamp(20px,4vw,64px) clamp(80px,10vw,160px);
}
.wrap{max-width:var(--maxw);margin:0 auto}

/* mini footer */
.end{
  border-top:1px solid var(--line);padding:34px clamp(20px,4vw,64px);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;background:var(--void);
  font-weight:600;font-size:13px;letter-spacing:1px;color:var(--muted);position:relative;z-index:5;
}
.end a:hover{color:#fff}

/* mobile menu — left-aligned UPPERCASE list over the dimmed hero (per Figma) */
.panel{
  position:fixed;inset:0;z-index:70;
  background:linear-gradient(180deg,rgba(8,10,12,.88),rgba(8,10,12,.72));
  backdrop-filter:blur(5px);
  display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;
  gap:clamp(12px,2vh,20px);
  padding:clamp(76px,18vw,112px) clamp(20px,4vw,64px) 0;
  opacity:0;pointer-events:none;transition:opacity .4s var(--ease);
}
.panel.open{opacity:1;pointer-events:auto}
.panel a{
  font-weight:600;font-size:clamp(30px,8.5vw,42px);letter-spacing:-1.5px;color:#fff;
  text-transform:uppercase;position:relative;padding-bottom:10px;
  opacity:0;transform:translateX(-16px);
  transition:opacity .45s var(--ease),transform .45s var(--ease);
}
.panel.open a{opacity:1;transform:none}
.panel.open a:nth-of-type(1){transition-delay:.06s}
.panel.open a:nth-of-type(2){transition-delay:.12s}
.panel.open a:nth-of-type(3){transition-delay:.18s}
.panel.open a:nth-of-type(4){transition-delay:.24s}
.panel a.active::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:var(--accent-line);border-radius:2px;
}
/* clean ✕ close button, top-right, inside the overlay */
.panel__close{
  position:absolute;top:clamp(20px,3.2vw,40px);right:clamp(18px,4vw,44px);
  width:42px;height:42px;background:none;border:0;cursor:pointer;
  opacity:0;transition:opacity .35s var(--ease) .1s,transform .35s var(--ease);
}
.panel.open .panel__close{opacity:1}
.panel__close::before,.panel__close::after{
  content:"";position:absolute;left:50%;top:50%;width:30px;height:2px;border-radius:2px;
  background:#f1f1f1;transform-origin:center;
}
.panel__close::before{transform:translate(-50%,-50%) rotate(45deg)}
.panel__close::after{transform:translate(-50%,-50%) rotate(-45deg)}
.panel__close:hover{transform:rotate(90deg)}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
[data-stagger]{transition-delay:var(--d,0s)}

@media(max-width:860px){
  .nav{display:none}
  .burger{display:flex}
  .about__cols{grid-template-columns:1fr;gap:22px}
  /* about photo banner — EXACT same mobile crop as nipun-main's homepage hero (.hero__bg),
     which centers this same photo perfectly per Figma. Same image aspect → same result. */
  .about-banner{
    height:clamp(500px,150vw,660px);
    background-size:297.6% auto;
    background-position:45.3% 0.3%;
  }
  /* mobile footer: tagline left, CONTACT/IMPRINT centered below (per Figma mobile) */
  .about-foot .hero__foot{flex-direction:column;align-items:stretch;gap:clamp(18px,4.5vw,30px)}
  .about-foot .foot__links{justify-content:center}
  /* mobile photo crop — matches Figma frame 10:133 (central slice, top-aligned) */
  .hero__bg{
    background-size:297.6% auto;
    background-position:45.3% 0.3%;
    transform:none;animation:none;
  }
  .hero__foot{flex-direction:column;align-items:stretch;text-align:left;gap:clamp(20px,5vw,30px)}
  .foot__tag{max-width:100%;font-size:14px;line-height:1.22;text-align:left;overflow-wrap:break-word}
  /* social right-aligned below the tagline, per Figma mobile (91:1365) */
  .social{align-self:flex-end;gap:14px}
  .scrollhint{display:none}
  .tour{grid-template-columns:1fr;gap:4px;text-align:left}
  .tour__date{min-width:0}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
@media print{.reveal{opacity:1!important;transform:none!important}}
