/* ============================================================
   加速キッチンキャンプ 詳細ページ ─ 加速キッチン
   「クリーム紙の霧箱ノート」（event/agora と共通のデザイン言語）
   生成り紙の上を宇宙線の飛跡が走り、夜の合宿らしく
   ティール=測る / インディゴ=宇宙 を主軸に、アンバー・コーラルを差し色に。
   ============================================================ */

: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(--teal-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%}
.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>');
}

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

.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:.12em;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-kicker{
  margin:0 0 12px;font-family:var(--f-mono);font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--teal-deep);
}

.hero h1{
  margin:0 0 8px;
  font-family:var(--f-disp);font-weight:900;
  font-size:clamp(31px,7.4vw,64px);line-height:1.4;letter-spacing:.02em;
}
.hero h1 .h1-accent{
  background:linear-gradient(transparent 66%, var(--teal-soft) 66%);
  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(--teal)}

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

/* キーワードバッジ */
.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(--teal-soft);border-color:var(--teal);color:var(--teal-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:18px;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;
}
.sec-head .sec-sub{margin:0;font-size:14px;color:var(--ink-3);line-height:1.85}
.track-rule{
  position:relative;width:128px;height:3px;border-radius:3px;margin-top:4px;
  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;
}

/* ============================================================
   開催概要：観測チケット
   ============================================================ */
.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)}
.free-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;
}

/* ============================================================
   目的：散文＋プルクオート
   ============================================================ */
.purpose{max-width:780px}
.purpose p{margin:0 0 18px;font-size:15px;line-height:2.1;color:var(--ink-2)}
.purpose p:last-of-type{margin-bottom:0}
.purpose p b{color:var(--ink)}
.pull{
  position:relative;margin:26px 0 0;padding:22px 26px 22px 30px;
  border-left:4px solid var(--acc,var(--indigo));border-radius:0 16px 16px 0;
  background:var(--acc-soft,var(--indigo-soft));
  font-family:var(--f-disp);font-size:15px;line-height:2;color:var(--acc-deep,var(--indigo-deep));
}
.pull::before{
  content:"✦";position:absolute;left:-12px;top:18px;
  width:22px;height:22px;border-radius:50%;display:grid;place-items:center;
  background:var(--card);border:2px solid var(--acc,var(--indigo));
  color:var(--acc,var(--indigo));font-size:10px;
}

/* ============================================================
   スケジュール：タイムライン
   ============================================================ */
.schedule-days{display:grid;gap:clamp(24px,4vw,38px);grid-template-columns:1fr}
.tl-day{
  background:var(--card);border:1.5px solid var(--line-2);border-radius:var(--r);
  padding:clamp(22px,3.2vw,30px);
}
.tl-day.d1{--acc:var(--amber);--acc-deep:var(--amber-deep);--acc-soft:var(--amber-soft)}
.tl-day.d2{--acc:var(--teal);--acc-deep:var(--teal-deep);--acc-soft:var(--teal-soft)}
.tl-day-h{
  display:flex;align-items:baseline;gap:11px;flex-wrap:wrap;margin:0 0 20px;
  font-family:var(--f-disp);font-weight:700;font-size:18px;
}
.tl-day-no{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;
  background:var(--acc);color:#FFFDF6;border-radius:999px;padding:3px 13px;
}
.tl-day-h small{font-family:var(--f-body);font-weight:400;font-size:12.5px;color:var(--ink-3)}

.timeline{list-style:none;margin:0;padding:0;position:relative}
.timeline::before{
  content:"";position:absolute;left:5.4em;top:9px;bottom:12px;
  width:2px;translate:-1px 0;
  background:repeating-linear-gradient(var(--acc) 0 5px,transparent 5px 11px);
}
.tl-item{
  position:relative;display:grid;grid-template-columns:5.4em 1fr;
  padding:0 0 18px;
}
.tl-item:last-child{padding-bottom:0}
.tl-time{
  font-family:var(--f-mono);font-size:13px;line-height:1.55;color:var(--acc-deep);
  text-align:right;padding-right:22px;white-space:nowrap;
}
.tl-time small{display:block;font-size:10.5px;color:var(--ink-3);letter-spacing:.01em}
.tl-body{
  position:relative;padding-left:22px;
  font-size:13.8px;line-height:1.8;color:var(--ink-2);
}
.tl-body::before{
  content:"";position:absolute;left:0;top:6px;translate:-50% 0;
  width:12px;height:12px;border-radius:50%;z-index:1;
  background:var(--card);border:2.5px solid var(--acc);
}
.tl-body b{color:var(--ink);font-family:var(--f-disp)}
.tl-tag{
  display:inline-block;margin-left:8px;font-family:var(--f-mono);font-size:10px;
  letter-spacing:.08em;color:var(--acc-deep);background:var(--acc-soft);
  border-radius:999px;padding:1px 9px;vertical-align:2px;
}

/* ============================================================
   内容：画像＋特徴の交互ブロック
   ============================================================ */
.content-list{display:grid;gap:clamp(20px,3vw,28px)}
.content-block{
  --ec:var(--teal);--ec-deep:var(--teal-deep);--ec-soft:var(--teal-soft);
  display:grid;grid-template-columns:1fr;
  background:var(--card);border:1.5px solid var(--line-2);border-radius:var(--r);
  overflow:hidden;transition:translate .3s ease,box-shadow .3s ease,border-color .3s ease;
}
.content-block.c-coral{--ec:var(--coral);--ec-deep:var(--coral-deep);--ec-soft:var(--coral-soft)}
.content-block.c-indigo{--ec:var(--indigo);--ec-deep:var(--indigo-deep);--ec-soft:var(--indigo-soft)}
.content-block:hover{translate:0 -4px;border-color:var(--ec);box-shadow:0 22px 38px -26px color-mix(in srgb,var(--ec) 55%,transparent)}
.cb-media{
  margin:0;background:var(--ec-soft);display:grid;place-items:center;
  padding:clamp(20px,3vw,28px);min-height:184px;position:relative;
}
.cb-media img{
  width:auto;max-width:100%;max-height:230px;border-radius:10px;
  box-shadow:0 10px 22px -12px rgba(44,38,32,.45);
}
.cb-media .cb-illust{width:100%;max-width:260px;height:auto;box-shadow:none;border-radius:0}
.cb-no{
  position:absolute;top:12px;left:12px;
  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;
}
.cb-body{padding:clamp(22px,3vw,30px);display:flex;flex-direction:column}
.cb-title{
  display:flex;align-items:center;gap:12px;margin:0 0 10px;
  font-family:var(--f-disp);font-weight:700;font-size:17.5px;line-height:1.5;
}
.cb-ico{
  width:40px;height:40px;border-radius:12px;flex:none;
  display:grid;place-items:center;background:var(--ec-soft);color:var(--ec-deep);
}
.cb-ico svg{width:22px;height:22px}
.cb-lead{margin:0 0 14px;font-size:14px;color:var(--ink-2);line-height:1.95}
.cb-lead b{color:var(--ink)}
.feat-list{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.feat-list li{position:relative;padding-left:24px;font-size:13.5px;line-height:1.7;color:var(--ink-2)}
.feat-list li::before{content:"✦";position:absolute;left:0;top:1px;color:var(--ec);font-size:12px}
.feat-list li b{color:var(--ink);font-family:var(--f-disp)}
.cb-note{margin:16px 0 0;font-size:12.5px;color:var(--ink-3);line-height:1.8}
.cb-note a{font-weight:700}

/* ============================================================
   その他：注意書きノート
   ============================================================ */
.notes{
  list-style:none;margin:0;padding:clamp(22px,3.5vw,32px);display:grid;gap:14px;
  background:var(--card);border:2px dashed var(--acc,var(--indigo));border-radius:var(--r);
}
.notes li{display:flex;align-items:flex-start;gap:13px;font-size:14px;line-height:1.85;color:var(--ink-2)}
.notes .nt-ico{flex:none;color:var(--acc,var(--indigo));font-size:15px;line-height:1.7}
.notes li b{color:var(--ink);font-family:var(--f-disp)}

/* ============================================================
   参加申し込みフォーム
   ============================================================ */
.apply-inner{max-width:680px;margin-inline:auto}

/* 受付開始前のお知らせ */
.apply-notice{
  display:flex;gap:14px;align-items:flex-start;
  background:var(--amber-soft);border:1.5px solid var(--amber);border-radius:16px;
  padding:16px 20px;margin:0 0 24px;
}
.apply-notice-ico{color:var(--amber-deep);font-size:15px;line-height:1.7;flex:none}
.apply-notice-title{margin:0 0 4px;font-family:var(--f-disp);font-weight:700;font-size:15px;color:var(--amber-deep)}
.apply-notice-body{margin:0;font-size:13.5px;color:var(--ink-2);line-height:1.85}

/* フォーム本体 */
.apply-form{
  background:var(--card);border:1.5px solid var(--line-2);border-radius:var(--r);
  padding:clamp(22px,4vw,38px);
}
.apply-form .field{margin:0 0 20px}
.apply-form .field-fieldset{border:none;padding:0;min-inline-size:auto}
.apply-form .field-fieldset legend{padding:0}

.apply-form label,.apply-form .field-label{
  display:block;margin:0 0 8px;
  font-family:var(--f-disp);font-weight:700;font-size:14px;color:var(--ink-2);
}
.apply-form .req{
  display:inline-block;margin-left:8px;vertical-align:2px;
  font-family:var(--f-body);font-weight:700;font-size:10.5px;letter-spacing:.04em;
  color:#fff;background:var(--coral);border-radius:999px;padding:1px 9px;
}
.apply-form .field-hint{
  display:block;margin-top:4px;
  font-family:var(--f-body);font-weight:400;font-size:11.5px;color:var(--ink-3);line-height:1.6;
}

.apply-form input[type=text],
.apply-form input[type=date],
.apply-form input[type=email],
.apply-form select{
  width:100%;font-family:var(--f-body);font-size:15px;color:var(--ink);
  background:var(--paper);border:1.5px solid var(--line-2);border-radius:12px;
  padding:11px 14px;transition:border-color .2s,box-shadow .2s;
}
.apply-form input:focus,.apply-form select:focus{
  outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft);
}
.apply-form input::placeholder{color:var(--ink-3)}
.apply-form input:user-invalid,
.apply-form select:user-invalid{border-color:var(--coral)}

/* 氏名の2分割 */
.apply-form .name-split{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.apply-form .name-sub{margin:0 0 5px;font-family:var(--f-mono);font-weight:500;font-size:11px;letter-spacing:.08em;color:var(--ink-3)}

/* 参加日トグル */
.day-toggles{display:flex;gap:12px;flex-wrap:wrap}
.day-toggle{flex:1 1 140px;margin:0;cursor:pointer}
.day-toggle input{position:absolute;opacity:0;width:0;height:0}
.day-toggle span{
  display:flex;flex-direction:column;gap:3px;align-items:center;justify-content:center;text-align:center;
  font-family:var(--f-disp);font-weight:700;font-size:15.5px;color:var(--ink-2);
  border:1.5px solid var(--line-2);border-radius:14px;padding:15px 12px;background:var(--paper);
  transition:border-color .2s,background .2s,color .2s,translate .2s;
}
.day-toggle span small{font-family:var(--f-mono);font-weight:400;font-size:11px;color:var(--ink-3)}
.day-toggle:hover span{translate:0 -2px;border-color:var(--teal)}
.day-toggle input:checked+span{border-color:var(--teal);background:var(--teal-soft);color:var(--teal-deep)}
.day-toggle input:checked+span small{color:var(--teal-deep)}
.day-toggle input:focus-visible+span{outline:3px solid var(--coral);outline-offset:2px}

/* 同意 */
.consent{
  margin:24px 0 4px;background:var(--paper);
  border:1.5px dashed var(--line-2);border-radius:14px;padding:16px 18px;
}
.consent-row{display:flex;gap:12px;align-items:flex-start;margin:0;cursor:pointer}
.consent-row input{margin:3px 0 0;width:18px;height:18px;flex:none;accent-color:var(--teal)}
.consent-title{display:block;margin:0 0 3px;font-family:var(--f-disp);font-weight:700;font-size:14px;color:var(--ink)}
.consent-desc{display:block;font-family:var(--f-body);font-weight:400;font-size:12.5px;color:var(--ink-2);line-height:1.8}

/* 送信 */
.form-actions{margin:22px 0 0;text-align:center}
.btn-submit{
  width:100%;font-family:var(--f-disp);font-weight:700;font-size:16px;color:#fff;
  background:var(--teal);border:none;border-radius:14px;padding:15px 24px;cursor:pointer;
  box-shadow:0 12px 24px -14px rgba(21,156,146,.7);
  transition:background .2s,translate .2s,box-shadow .2s;
}
.btn-submit:hover:not(:disabled){background:var(--teal-deep);translate:0 -2px}
.btn-submit:disabled{background:var(--line-2);color:var(--ink-3);cursor:not-allowed;box-shadow:none}
.form-actions-note{margin:10px 0 0;font-size:12px;color:var(--ink-3)}

.recaptcha-note{margin:14px 0 0;font-size:11px;color:var(--ink-3);line-height:1.7}
.recaptcha-note a{color:var(--ink-3);border-bottom:1px dashed currentColor;text-decoration:none}

/* 送信完了 */
.apply-success{
  background:var(--card);border:1.5px solid var(--teal);border-radius:var(--r);
  padding:clamp(28px,5vw,46px);text-align:center;
}
.apply-success .sx-mark{font-size:30px;color:var(--teal);line-height:1}
.apply-success h3{margin:10px 0 8px;font-family:var(--f-disp);font-weight:700;font-size:20px}
.apply-success p{margin:0;font-size:14px;color:var(--ink-2);line-height:1.95}

@media (max-width:430px){
  .apply-form .name-split{grid-template-columns:1fr}
}

/* ============================================================
   トップへ戻る
   ============================================================ */
.page-back{text-align:center;padding:clamp(30px,5vw,52px) var(--pad) 0}
.page-back a{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--f-disp);font-weight:700;font-size:14px;
  color:var(--ink-2);text-decoration:none;
  border:2px solid var(--line-2);border-radius:999px;padding:9px 24px;background:var(--card);
  transition:translate .25s,border-color .25s,box-shadow .25s;
}
.page-back a:hover{translate:0 -3px;border-color:var(--indigo);color:var(--indigo-deep);box-shadow:0 14px 22px -14px rgba(62,76,150,.5)}
.page-back a::before{content:"←";font-family:var(--f-mono)}

/* ============================================================
   フッター：夜空
   ============================================================ */
.foot{
  position:relative;margin-top:clamp(34px,5vw,56px);
  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}

/* ============================================================
   スクロールリビール
   ============================================================ */
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}
.content-list .reveal:nth-child(2){transition-delay:.08s}
.content-list .reveal:nth-child(3){transition-delay:.16s}
.schedule-days .reveal:nth-child(2){transition-delay:.1s}

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (min-width:760px){
  .content-block{grid-template-columns:minmax(0,300px) 1fr}
  .content-block.alt{grid-template-columns:1fr minmax(0,300px)}
  .content-block.alt .cb-media{order:2}
}
@media (min-width:880px){
  .schedule-days{grid-template-columns:1fr 1fr}
}
@media (max-width:980px){
  .hero-stamp{position:static;rotate:-6deg;margin-top:26px}
}
@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 (max-width:430px){
  .timeline::before{left:4.6em}
  .tl-item{grid-template-columns:4.6em 1fr}
}

/* ============================================================
   動きを抑える設定の尊重
   ============================================================ */
@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}
}
