/* ============================================================
   サイエンスアゴラ2026 企画詳細ページ ─ 加速キッチン
   「クリーム紙の霧箱ノート」
   生成り紙の上を宇宙線の飛跡（ドットのトラック）が走り、
   光=アンバー / 音=ティール / 振動=コーラル の三色が
   ページ全体を貫くデザインシステム。
   ============================================================ */

:root{
  /* paper */
  --paper:#FCF6E8;
  --paper-2:#F5ECD6;
  --card:#FFFCF4;
  /* ink */
  --ink:#2C2620;
  --ink-2:#594F40;
  --ink-3:#8C8170;
  /* lines */
  --line:#E6DAC0;
  --line-2:#D9CBAA;
  /* accents（光・音・振動 ＋ 宇宙） */
  --amber:#E99A0B;  --amber-deep:#A86E04;  --amber-soft:#FBE7B8;
  --teal:#159C92;   --teal-deep:#0E6E68;   --teal-soft:#D2ECE7;
  --coral:#E4566F;  --coral-deep:#BC3A53;  --coral-soft:#FAD9DF;
  --indigo:#3E4C96; --indigo-deep:#252C55; --indigo-soft:#DDE2F4;
  --granite:#7B7468;
  /* type */
  --f-disp:"Zen Maru Gothic","Hiragino Maru Gothic ProN",sans-serif;
  --f-body:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;
  --f-mono:"Spline Sans Mono",ui-monospace,monospace;
  /* layout */
  --maxw:1060px;
  --pad:clamp(20px,5vw,48px);
  --r:20px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  margin:0;
  font-family:var(--f-body);
  font-size:15.5px;
  line-height:2;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
img{max-width:100%;display:block}
a{color:var(--teal-deep);text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{color:var(--coral-deep)}
:focus-visible{outline:3px solid var(--coral);outline-offset:3px;border-radius:4px}
::selection{background:var(--amber-soft)}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}

/* ---- skip link ---- */
.skip-link{
  position:absolute;left:12px;top:-48px;z-index:50;
  background:var(--ink);color:var(--paper);padding:8px 16px;border-radius:8px;
  font-size:13px;text-decoration:none;transition:top .2s;
}
.skip-link:focus{top:12px;color:var(--paper)}

/* ============================================================
   背景レイヤー：宇宙線の飛跡＋紙のざらつき
   ============================================================ */
.bg-tracks{position:fixed;inset:0;z-index:-2;pointer-events:none}
.bg-tracks svg{width:100%;height:100%}
/* 宇宙線レイン（JSが生成するcanvas。稼働中は静的SVGを隠す） */
.ray-canvas{position:fixed;inset:0;z-index:-2;pointer-events:none}
html.rays .bg-tracks{display:none}
.grain{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.4;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="160" height="160"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency="0.85" numOctaves="2" stitchTiles="stitch"/><feColorMatrix type="saturate" values="0"/><feComponentTransfer><feFuncA type="linear" slope="0.05"/></feComponentTransfer></filter><rect width="160" height="160" filter="url(%23n)"/></svg>');
}

/* ============================================================
   JSTバナー（掲載必須・ページ最上部）
   ============================================================ */
.jst-banner{
  display:flex;align-items:center;justify-content:center;gap:.7em;
  flex-wrap:wrap;text-align:center;
  padding:11px var(--pad);
  background:var(--indigo-deep);color:#F4F1E4;text-decoration:none;
  font-size:13px;letter-spacing:.04em;line-height:1.6;
  position:relative;overflow:hidden;
}
.jst-banner .jst-label{font-weight:700;font-family:var(--f-disp)}
.jst-banner .jst-go{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;
  border:1px solid rgba(244,241,228,.45);border-radius:999px;
  padding:2px 12px;white-space:nowrap;
  transition:background .25s,color .25s;
}
.jst-banner:hover{color:#fff}
.jst-banner:hover .jst-go{background:#F4F1E4;color:var(--indigo-deep)}
.jst-banner .bstar{position:absolute;color:#F2C75C;font-size:9px;opacity:.8;animation:twinkle 2.6s ease-in-out infinite alternate}

/* ============================================================
   ヒーロー
   ============================================================ */
.hero{position:relative;padding:clamp(48px,8vw,96px) 0 clamp(40px,6vw,72px);overflow:visible}
.hero .wrap{position:relative}
.hero-body{position:relative;z-index:1;max-width:660px}

.hero-date{
  display:inline-flex;align-items:center;gap:.8em;flex-wrap:wrap;
  margin:0 0 18px;
  font-family:var(--f-mono);font-size:clamp(12px,1.6vw,14px);
  letter-spacing:.14em;color:var(--indigo);
  border:1.5px solid var(--indigo);border-radius:999px;
  padding:6px 18px;background:var(--card);
}
.hero-date .dsep{color:var(--coral);font-size:.85em}

.hero h1{
  margin:0 0 6px;
  font-family:var(--f-disp);font-weight:900;
  font-size:clamp(30px,7.2vw,62px);line-height:1.42;letter-spacing:.02em;
}
.hero h1 .h1-accent{
  background:linear-gradient(transparent 68%, var(--amber-soft) 68%);
  border-radius:4px;
}
.hero-en{
  margin:0 0 22px;
  font-family:var(--f-mono);font-size:clamp(11px,1.5vw,13px);
  letter-spacing:.26em;text-transform:uppercase;color:var(--ink-3);
}
.hero-en::after{content:" ✦";color:var(--amber)}

.hero-exhibitor{
  display:flex;align-items:center;gap:12px;margin:0 0 20px;
  font-family:var(--f-disp);font-weight:700;font-size:15px;
}
.hero-exhibitor img{height:26px;width:auto}
.hero-exhibitor .ex-en{font-family:var(--f-mono);font-weight:400;font-size:11px;letter-spacing:.1em;color:var(--ink-3)}

.hero-lead{margin:0 0 26px;max-width:36em;font-size:clamp(15px,2vw,16.5px);color:var(--ink-2)}
.hero-lead b{color:var(--ink)}

/* 三感覚チップ：ひかる・なる・ふるえる */
.senses{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 22px;padding:0;list-style:none}
.sense{
  display:flex;align-items:center;gap:9px;
  background:var(--card);border:1.5px solid var(--sc,var(--line-2));
  border-radius:999px;padding:7px 16px 7px 8px;
}
.sense-ico{
  width:34px;height:34px;border-radius:50%;flex:none;
  display:grid;place-items:center;
  background:var(--sc-soft,var(--paper-2));color:var(--sc-deep,var(--ink-2));
}
.sense-ico svg{width:19px;height:19px}
.sense-tx{line-height:1.25}
.sense-tx b{display:block;font-family:var(--f-disp);font-weight:700;font-size:14px;color:var(--sc-deep,var(--ink))}
.sense-tx span{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.18em;color:var(--ink-3)}
.sense.s-light{--sc:var(--amber);--sc-deep:var(--amber-deep);--sc-soft:var(--amber-soft)}
.sense.s-sound{--sc:var(--teal);--sc-deep:var(--teal-deep);--sc-soft:var(--teal-soft)}
.sense.s-vib{--sc:var(--coral);--sc-deep:var(--coral-deep);--sc-soft:var(--coral-soft)}

/* キーワードバッジ */
.badges{display:flex;gap:8px;flex-wrap:wrap;margin:0;padding:0;list-style:none}
.badges li{
  font-size:12px;letter-spacing:.06em;color:var(--ink-2);
  border:1px solid var(--line-2);border-radius:999px;padding:3px 14px;
  background:rgba(255,252,244,.7);
}
.badges li.bd-strong{
  background:var(--coral-soft);border-color:var(--coral);color:var(--coral-deep);font-weight:700;
}

/* 入場無料スタンプ */
.hero-stamp{
  position:absolute;right:calc(var(--pad) - 6px);bottom:-10px;z-index:2;
  width:124px;height:124px;border-radius:50%;
  border:2.5px dashed var(--coral);background:var(--card);
  display:grid;place-content:center;text-align:center;gap:2px;
  rotate:-8deg;
  font-family:var(--f-disp);font-weight:700;color:var(--coral-deep);
  box-shadow:0 10px 24px -14px rgba(188,58,83,.5);
}
.hero-stamp .st-l1{font-size:17px;letter-spacing:.08em}
.hero-stamp .st-l2{font-size:10.5px;letter-spacing:.04em}
.hero-stamp .st-star{font-size:10px;color:var(--amber)}

/* ヒーローのシャワーSVG */
.hero-shower{
  position:absolute;top:-30px;right:-40px;z-index:0;
  width:clamp(280px,42vw,470px);pointer-events:none;
}
.hero-shower svg{width:100%;height:auto;overflow:visible}
.trk{opacity:0;animation:trkIn 1s ease forwards}
.flash{transform-origin:center;transform-box:fill-box;scale:0;animation:pop .8s cubic-bezier(.34,1.56,.64,1) forwards}
.flash.pulse{animation:pop .8s cubic-bezier(.34,1.56,.64,1) forwards, twinkle 2.8s ease-in-out 1.2s infinite alternate}

@keyframes trkIn{from{opacity:0;translate:0 -14px}to{opacity:1;translate:0 0}}
@keyframes pop{from{scale:0}to{scale:1}}
@keyframes twinkle{from{opacity:1}to{opacity:.25}}
@keyframes riseIn{from{opacity:0;translate:0 22px}to{opacity:1;translate:0 0}}

/* ヒーロー読み込み時のステージング */
.hero [data-stage]{opacity:0;animation:riseIn .8s cubic-bezier(.2,.7,.3,1) forwards}
.hero [data-stage="1"]{animation-delay:.05s}
.hero [data-stage="2"]{animation-delay:.18s}
.hero [data-stage="3"]{animation-delay:.30s}
.hero [data-stage="4"]{animation-delay:.42s}
.hero [data-stage="5"]{animation-delay:.54s}
.hero [data-stage="6"]{animation-delay:.66s}

/* ============================================================
   セクション共通
   ============================================================ */
.section{padding:clamp(34px,5.5vw,60px) 0;position:relative}
.section[data-acc="amber"]{--acc:var(--amber);--acc-deep:var(--amber-deep);--acc-soft:var(--amber-soft)}
.section[data-acc="teal"]{--acc:var(--teal);--acc-deep:var(--teal-deep);--acc-soft:var(--teal-soft)}
.section[data-acc="coral"]{--acc:var(--coral);--acc-deep:var(--coral-deep);--acc-soft:var(--coral-soft)}
.section[data-acc="indigo"]{--acc:var(--indigo);--acc-deep:var(--indigo-deep);--acc-soft:var(--indigo-soft)}

.sec-head{margin-bottom:clamp(22px,3.5vw,34px)}
.eyebrow{
  display:block;margin:0 0 6px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--acc-deep,var(--ink-3));
}
.sec-head h2{
  margin:0 0 12px;
  font-family:var(--f-disp);font-weight:700;
  font-size:clamp(23px,4.2vw,33px);line-height:1.5;letter-spacing:.02em;
}
.track-rule{
  position:relative;width:128px;height:3px;border-radius:3px;
  background:repeating-linear-gradient(90deg,var(--acc,var(--line-2)) 0 9px,transparent 9px 17px);
}
.track-rule::after{
  content:"✦";position:absolute;right:-20px;top:50%;translate:0 -58%;
  color:var(--acc,var(--ink-3));font-size:14px;line-height:1;
}
.sec-note{font-size:13px;color:var(--ink-3)}

/* ============================================================
   開催概要：観測チケット
   ============================================================ */
.ticket{
  position:relative;
  background:var(--card);
  border:2px dashed var(--line-2);
  border-radius:var(--r);
  padding:clamp(22px,4vw,40px) clamp(20px,4.5vw,48px);
}
.ticket::before,.ticket::after{
  content:"";position:absolute;top:50%;translate:0 -50%;
  width:24px;height:24px;border-radius:50%;
  background:var(--paper);border:2px dashed var(--line-2);
}
.ticket::before{left:-14px}
.ticket::after{right:-14px}
.ticket-tag{
  position:absolute;top:-12px;left:clamp(18px,4vw,44px);
  font-family:var(--f-mono);font-size:10px;letter-spacing:.24em;
  background:var(--acc,var(--teal));color:#FFFDF6;border-radius:999px;
  padding:3px 14px;
}
.ticket-list{margin:0;display:grid;gap:2px}
.ticket-list .row{
  display:grid;grid-template-columns:8.5em 1fr;gap:8px 18px;
  padding:11px 0;border-bottom:1px dashed var(--line);
  align-items:baseline;
}
.ticket-list .row:last-child{border-bottom:none}
.ticket-list dt{
  font-family:var(--f-disp);font-weight:700;font-size:14px;color:var(--ink-2);
  display:flex;align-items:baseline;gap:8px;
}
.ticket-list dt::before{
  content:"";width:8px;height:8px;border-radius:50%;flex:none;
  background:var(--acc,var(--teal));translate:0 -1px;
}
.ticket-list dd{margin:0;font-size:14.5px}
.ticket-list dd small{display:block;font-size:12px;color:var(--ink-3)}
.ok-pill{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--teal-soft);color:var(--teal-deep);
  border-radius:999px;padding:3px 14px;font-weight:700;font-size:14px;
}
.ok-pill svg{width:15px;height:15px;flex:none}

/* ============================================================
   体験カード
   ============================================================ */
.exp-grid{display:grid;gap:20px;grid-template-columns:1fr}
.exp-card{
  --ec:var(--amber);--ec-deep:var(--amber-deep);--ec-soft:var(--amber-soft);
  background:var(--card);border:1.5px solid var(--line-2);border-radius:var(--r);
  overflow:hidden;display:flex;flex-direction:column;
  transition:translate .3s ease,box-shadow .3s ease,border-color .3s ease;
}
.exp-card.c-teal{--ec:var(--teal);--ec-deep:var(--teal-deep);--ec-soft:var(--teal-soft)}
.exp-card.c-coral{--ec:var(--coral);--ec-deep:var(--coral-deep);--ec-soft:var(--coral-soft)}
.exp-card:hover{translate:0 -5px;border-color:var(--ec);box-shadow:0 22px 36px -24px color-mix(in srgb,var(--ec) 55%,transparent)}
.exp-media{position:relative;aspect-ratio:16/10;background:var(--ec-soft);overflow:hidden}
.exp-media img{width:100%;height:100%;object-fit:cover}
.exp-media .exp-illust{width:100%;height:100%;display:grid;place-items:center}
.exp-media .exp-illust svg{width:74%;height:74%}
.exp-no{
  position:absolute;top:10px;left:10px;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;
  background:rgba(255,252,244,.92);color:var(--ec-deep);
  border:1px solid var(--ec);border-radius:999px;padding:2px 11px;
}
.exp-body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.exp-title{
  display:flex;align-items:center;gap:11px;margin:0;
  font-family:var(--f-disp);font-weight:700;font-size:17px;line-height:1.55;
}
.exp-ico{
  width:38px;height:38px;border-radius:12px;flex:none;
  display:grid;place-items:center;background:var(--ec-soft);color:var(--ec-deep);
}
.exp-ico svg{width:21px;height:21px}
.exp-body p{margin:0;font-size:14px;line-height:1.95;color:var(--ink-2)}

/* 投票・Share Wall チップ */
.extras{display:grid;gap:12px;margin-top:20px;grid-template-columns:1fr}
.extra{
  display:flex;align-items:flex-start;gap:12px;
  border:1.5px dashed var(--line-2);border-radius:16px;
  background:rgba(245,236,214,.55);padding:14px 18px;
  font-size:13.5px;color:var(--ink-2);line-height:1.85;
}
.extra .x-star{flex:none;color:var(--amber);font-size:15px;line-height:1.7}
.extra b{color:var(--ink);font-family:var(--f-disp)}

/* ============================================================
   出展者について
   ============================================================ */
.exhibitor-grid{display:grid;gap:clamp(24px,4vw,44px);grid-template-columns:1fr;align-items:start}
.exhibitor-text p{margin:0 0 16px;font-size:14.5px;color:var(--ink-2);line-height:2.05}
.exhibitor-text p b{color:var(--ink)}
.kek-link{font-size:13.5px}
.ext-arrow::after{content:" ↗";font-family:var(--f-mono);font-size:.85em}

.exhibitor-photo{position:relative}
.exhibitor-photo img{
  border-radius:18px;rotate:1.6deg;
  border:6px solid #fff;
  box-shadow:10px 12px 0 -2px var(--indigo-soft),0 18px 34px -18px rgba(37,44,85,.35);
}
.exhibitor-photo figcaption{
  margin-top:16px;font-size:11.5px;color:var(--ink-3);text-align:right;
  font-family:var(--f-mono);letter-spacing:.06em;
}

.en-note{
  display:flex;gap:12px;align-items:flex-start;
  margin-top:26px;padding:16px 20px;
  background:var(--teal-soft);border:1.5px solid var(--teal);border-radius:16px;
}
.en-note .en-ico{flex:none;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--card);color:var(--teal-deep)}
.en-note .en-ico svg{width:19px;height:19px}
.en-note p{margin:0;font-size:13.5px;line-height:1.9;color:var(--teal-deep)}
.en-note p span[lang="en"]{display:block;font-size:12px;opacity:.85}

/* ============================================================
   物販
   ============================================================ */
.goods-card{
  background:var(--card);border:1.5px solid var(--line-2);border-radius:var(--r);
  padding:clamp(20px,3.5vw,32px);
}
.goods-items{display:grid;gap:12px;grid-template-columns:1fr;margin:0 0 16px;padding:0;list-style:none}
.goods-item{
  display:flex;align-items:center;gap:13px;
  border:1.5px dashed var(--line-2);border-radius:14px;padding:12px 16px;
}
.goods-ico{
  width:40px;height:40px;border-radius:12px;flex:none;
  display:grid;place-items:center;background:var(--acc-soft,var(--amber-soft));color:var(--acc-deep,var(--amber-deep));
}
.goods-ico svg{width:22px;height:22px}
.goods-item b{font-family:var(--f-disp);font-size:14.5px;display:block;line-height:1.6}
.goods-item span{font-size:12px;color:var(--ink-3);display:block;line-height:1.7}
.goods-note{margin:0 0 18px;font-size:13px;color:var(--ink-3)}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-disp);font-weight:700;font-size:14px;
  padding:10px 26px;border-radius:999px;text-decoration:none;
  transition:translate .25s,box-shadow .25s;
}
.btn-ghost{
  color:var(--acc-deep,var(--ink));border:2px solid var(--acc,var(--ink));background:var(--card);
}
.btn-ghost:hover{translate:0 -3px;box-shadow:0 14px 22px -14px color-mix(in srgb,var(--acc,var(--ink)) 60%,transparent);color:var(--acc-deep)}

/* ============================================================
   関連リンク
   ============================================================ */
.links-grid{display:grid;gap:14px;grid-template-columns:1fr}
.link-card{
  display:flex;align-items:center;gap:14px;
  background:var(--card);border:1.5px solid var(--line-2);border-radius:16px;
  padding:15px 20px;text-decoration:none;color:var(--ink);
  transition:translate .25s,border-color .25s,box-shadow .25s;
}
.link-card:hover{translate:0 -3px;border-color:var(--acc,var(--teal));box-shadow:0 16px 26px -18px color-mix(in srgb,var(--acc,var(--teal)) 55%,transparent);color:var(--ink)}
.link-card .lk-star{flex:none;color:var(--acc,var(--teal));font-size:15px}
.link-card .lk-body{flex:1;min-width:0;line-height:1.5}
.link-card .lk-body b{font-family:var(--f-disp);font-size:14.5px;display:block}
.link-card .lk-body span{
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.05em;color:var(--ink-3);
  display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.link-card .lk-arrow{flex:none;font-family:var(--f-mono);color:var(--acc-deep,var(--teal-deep));font-size:13px}

/* ============================================================
   問合せ先（掲載必須・最下部）
   ============================================================ */
.contact-card{
  max-width:680px;margin-inline:auto;text-align:center;
  background:var(--card);border:2px dashed var(--acc,var(--indigo));border-radius:var(--r);
  padding:clamp(26px,4.5vw,44px) clamp(20px,4vw,40px);
}
.contact-card h2{
  margin:0 0 4px;font-family:var(--f-disp);font-weight:700;
  font-size:clamp(17px,3vw,21px);letter-spacing:.02em;
}
.contact-card .c-sub{margin:0 0 22px;font-size:12.5px;color:var(--ink-3)}
.contact-card address{font-style:normal}
.contact-org{
  margin:0 0 18px;font-family:var(--f-disp);font-weight:700;font-size:16.5px;
}
.contact-org small{display:block;font-family:var(--f-mono);font-weight:400;font-size:10.5px;letter-spacing:.16em;color:var(--ink-3);margin-top:2px}
.contact-rows{display:grid;gap:10px;justify-content:center}
.contact-row{
  display:flex;align-items:center;gap:12px;justify-content:center;flex-wrap:wrap;
  font-size:15px;margin:0;
}
.contact-row .c-lbl{
  font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;
  background:var(--acc-soft,var(--indigo-soft));color:var(--acc-deep,var(--indigo-deep));
  border-radius:999px;padding:3px 12px;
}
.contact-row a{font-weight:700;text-decoration-color:var(--line-2)}

/* ============================================================
   フッター：夜のお台場
   ============================================================ */
.foot{
  position:relative;margin-top:clamp(40px,6vw,64px);
  background:var(--indigo-deep);color:#D7DBEF;
  padding:34px var(--pad) 30px;text-align:center;overflow:hidden;
}
.foot .fstar{position:absolute;color:#F2C75C;font-size:10px;animation:twinkle 3s ease-in-out infinite alternate}
.foot-brand{font-family:var(--f-disp);font-weight:700;font-size:15px;color:#F4F1E4;margin:0 0 4px}
.foot-brand .f-en{font-family:var(--f-mono);font-weight:400;font-size:10px;letter-spacing:.2em;color:#8E97C4;display:block;margin-top:2px}
.foot-links{margin:12px 0 14px;display:flex;gap:18px;justify-content:center;flex-wrap:wrap;font-size:13px}
.foot-links a{color:#C3CAE8}
.foot-links a:hover{color:#fff}
.foot-copy{margin:0;font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;color:#7D86B5}

/* ============================================================
   スクロールリビール
   ============================================================ */
/* JS有効時のみ初期非表示（JS無効でも内容が読めるように html.js でゲート） */
html.js .reveal{opacity:0;translate:0 20px;transition:opacity .7s cubic-bezier(.2,.7,.3,1),translate .7s cubic-bezier(.2,.7,.3,1)}
html.js .reveal.is-in{opacity:1;translate:0 0}
.exp-grid .reveal:nth-child(2),.links-grid .reveal:nth-child(2){transition-delay:.1s}
.exp-grid .reveal:nth-child(3),.links-grid .reveal:nth-child(3){transition-delay:.2s}
.links-grid .reveal:nth-child(4){transition-delay:.3s}

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (min-width:640px){
  .extras{grid-template-columns:1fr 1fr}
  .goods-items{grid-template-columns:1fr 1fr}
  .links-grid{grid-template-columns:1fr 1fr}
}
@media (min-width:880px){
  .exp-grid{grid-template-columns:repeat(3,1fr)}
  .exhibitor-grid{grid-template-columns:1.25fr 1fr}
}
@media (max-width:980px){
  .hero-stamp{position:static;rotate:-6deg;margin-top:24px}
}
@media (max-width:760px){
  .hero-shower{opacity:.42;right:-70px;top:-10px}
  .ticket-list .row{grid-template-columns:1fr;gap:2px;padding:12px 0}
  .ticket::before,.ticket::after{display:none}
}

/* ============================================================
   動きを抑える設定の尊重
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .hero [data-stage],.trk{opacity:1}
  .flash{scale:1}
  html.js .reveal{opacity:1;translate:0 0}
}
