/* =========================================================
   たべっ子どうぶつ MIRAI LAB ～星降るキラリウム～ 入力側アプリ
   コード構築版：背景 #002878 ベタ＋部品をCSS描画。見出しはブランドPNGを重ねる。
   ハブ／クイズは実DOM。スタート/エリアTOP/エンドは既存アートを可変表示＋実ボタン。
   ========================================================= */
:root{
  --bg:#002878;          /* ブランド紺＝見出しPNGの地色と一致 */
  --maxw:460px;
  --yellow:#ffe600;
  --ink:#001134;
  --navH:56px;           /* 固定下部ナビの高さ */
  --topinset:calc(env(safe-area-inset-top) + 6px);  /* 全画面共通の上開始位置（時間表示を避ける） */
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}
[hidden]{display:none !important}
html,body{height:100%}
body{
  background:var(--bg);color:#fff;
  font-family:'Kosugi Maru',"Hiragino Maru Gothic ProN","Hiragino Sans","Noto Sans JP",sans-serif;
  -webkit-font-smoothing:antialiased;overscroll-behavior:none;
}
#app{
  position:relative;width:100%;max-width:var(--maxw);
  height:100vh;height:100dvh;          /* 動的ビューポート高でアドレスバー伸縮に追従 */
  margin:0 auto;background:var(--bg);overflow:hidden;
}
/* コンテンツ領域は固定ナビ分を除外（ナビに被らない） */
#screen{position:absolute;left:0;right:0;top:0;bottom:calc(var(--navH) + env(safe-area-inset-bottom));overflow:hidden}

/* 共通：星空＋下グロー（コード画面の背景演出） */
.stage{
  position:relative;width:100%;height:100%;overflow:hidden;isolation:isolate;
  background:
    radial-gradient(80% 42% at 50% 80%, rgba(40,86,190,.35), rgba(0,40,120,0) 70%),
    radial-gradient(120% 70% at 50% 120%, rgba(0,10,40,.6), rgba(0,40,120,0) 60%),
    var(--bg);
  display:flex;flex-direction:column;
}
.sky{position:absolute;inset:0;z-index:0;pointer-events:none}
.sky i{position:absolute;background:#fff;border-radius:50%;
  box-shadow:0 0 6px 1px rgba(255,255,255,.8);animation:tw 3.2s ease-in-out infinite}
@keyframes tw{0%,100%{opacity:.2;transform:scale(.7)}50%{opacity:1;transform:scale(1)}}
.wrap{position:relative;z-index:2;flex:1;min-height:0;display:flex;flex-direction:column;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:var(--topinset) 20px 16px}

/* =========================================================
   画像ビュー（既存アート）：#002878地に可変フィット・切れない。
   オーバーレイは画像ボックス基準＝座標がズレない。
   ========================================================= */
.imgview{position:relative;z-index:2;flex:1;min-height:0;width:100%;display:flex;align-items:flex-start;justify-content:center;background:transparent;overflow:hidden;padding-top:var(--topinset)}
/* 画像画面：背景をフラット地色にし、画像の四辺(=#002878)と一体化＝境界線を消す */
.imgstage{background:var(--bg)}
/* 焼き込み文言の上書き：地色で隠して正しいテキストを重ねる */
.imgmask{position:absolute;display:flex;align-items:center;justify-content:flex-end;
  background:var(--bg);color:#fff;font-family:'Kosugi Maru',sans-serif;
  font-size:14px;font-weight:700;white-space:nowrap;pointer-events:none;padding-right:1%}
/* クイズ画面：見出し開始位置を全画面と統一（時間表示と被らない）。縦詰めのflex列 */
.qstage{padding-top:var(--topinset);display:flex;flex-direction:column;overflow:hidden}
.imgwrap{position:relative;display:inline-block;max-width:100%;max-height:100%;line-height:0}
.imgwrap > img{display:block;width:auto;height:auto;max-width:100%;max-height:100%}
/* 画像下端のベタ焼きナビを隠す（共通コードナビに置換） */
.navmask{position:absolute;left:0;right:0;bottom:0;height:6.4%;background:var(--bg)}
/* エンド画面の「エリア一覧へ戻る」チップ（画像の上に重ねず、上部に配置） */
/* 戻る導線：スマホの親指操作に合わせ左下に固定（下部ナビの上） */
.topbar{position:fixed;z-index:15;left:12px;
  bottom:calc(var(--navH) + env(safe-area-inset-bottom) + 12px)}
.backhub{display:inline-flex;align-items:center;gap:5px;padding:8px 15px;
  border:1.5px solid rgba(170,200,255,.5);border-radius:999px;
  background:rgba(0,20,70,.6);color:#cfe0ff;font-size:13px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;cursor:pointer}
.backhub:active{transform:translateY(1px)}

/* 焼き込み見出しの差し替え：地色(#002878)で隠し、複数行を中央寄せで書き直す（暫定・CSS上書き） */
.imgcover{position:absolute;left:0;width:100%;z-index:4;
  background:var(--cv,var(--bg));box-shadow:0 0 12px 7px var(--cv,var(--bg));
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.34em;
  color:#fff;font-family:'Kosugi Maru',sans-serif;font-weight:700;white-space:nowrap;line-height:1.25;
  font-size:clamp(14px,4.8vw,21px)}
/* 焼き込みボタンを覆うコードボタン */
.imgbtn{position:absolute;z-index:5;border:0;border-radius:999px;cursor:pointer;color:var(--ink);
  font-family:'Kosugi Maru',sans-serif;font-weight:700;white-space:nowrap;
  font-size:clamp(14px,4.6vw,20px);
  background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 4px 0 #b88600,0 6px 14px rgba(255,200,0,.35)}
.imgbtn:active{transform:translateY(2px);box-shadow:0 2px 0 #b88600}

/* エリアTOPの戻る導線：上部左に固定（暗い空の上＝白枠と被らない・画像も縮めない） */
.backtop{position:fixed;z-index:16;top:calc(env(safe-area-inset-top) + 8px);left:12px;
  display:inline-flex;align-items:center;gap:5px;padding:7px 15px;
  border:1.5px solid rgba(170,200,255,.55);border-radius:999px;
  background:rgba(0,16,52,.74);color:#cfe0ff;font:700 13px 'Kosugi Maru',sans-serif;cursor:pointer;
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.backtop:active{transform:translateY(1px)}
.backtop span{font-size:14px}

.hot{position:absolute;background:transparent;border:0;padding:0;cursor:pointer;border-radius:12px}
.hot:active{background:rgba(255,255,255,.14)}
.hot[disabled]{cursor:default}
.hot[disabled]:active{background:transparent}

/* =========================================================
   ハブ
   ========================================================= */
.title{text-align:center;margin-top:8px}
.title img{width:90%;max-width:390px;height:auto;display:block;margin:0 auto}

.count{margin:10px auto 0;display:flex;align-items:baseline;justify-content:center;gap:6px}
.count .lbl{font-size:15px;color:#cfe0ff;letter-spacing:.08em}
.count .now{font-size:46px;line-height:1;color:var(--yellow);
  text-shadow:0 0 16px rgba(255,210,0,.8),0 2px 0 #b07a00;transform:translateY(2px);transition:transform .2s}
.count .now.pop{transform:translateY(2px) scale(1.3)}
.count .sep{font-size:30px;color:#9db6ee}
.count .max{font-size:24px;color:#cfe0ff}
.count .unit{font-size:15px;color:#cfe0ff;margin-left:2px}

.starwrap{position:relative;margin:6px auto 2px;width:56%;max-width:225px;aspect-ratio:1;
  display:flex;align-items:center;justify-content:center}
.starwrap::before{content:"";position:absolute;width:120%;height:120%;border-radius:50%;
  background:radial-gradient(circle,rgba(255,225,80,.45),rgba(255,210,0,0) 62%);
  animation:halo 3.5s ease-in-out infinite}
@keyframes halo{0%,100%{transform:scale(.92);opacity:.7}50%{transform:scale(1.06);opacity:1}}
.starwrap img{position:relative;width:100%;height:100%;object-fit:contain;
  filter:drop-shadow(0 6px 18px rgba(0,0,0,.4)) drop-shadow(0 0 22px rgba(255,225,60,.55));
  animation:bob 4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

.lead{display:flex;align-items:center;justify-content:center;gap:10px;margin:2px 0 12px;
  font-size:17px;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.lead .chev{color:var(--yellow);font-size:13px;filter:drop-shadow(0 0 4px rgba(255,230,0,.7))}

.grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.areabtn{display:block;padding:0;border:0;background:transparent;cursor:pointer;transition:transform .08s;-webkit-tap-highlight-color:transparent}
.areabtn:active{transform:translateY(2px)}
.areabtn.full{grid-column:1 / -1}
.areabtn img{display:block;width:100%;height:auto}

.send{margin:auto auto 14px;width:100%;max-width:330px}
.send button{width:100%;padding:17px 20px;border:0;border-radius:999px;cursor:pointer;
  font-size:20px;letter-spacing:.04em;position:relative;overflow:hidden;color:var(--ink);
  font-family:'Kosugi Maru',sans-serif;background:linear-gradient(180deg,#fff36b,#ffd400);
  box-shadow:0 6px 0 #b88600, 0 10px 22px rgba(255,200,0,.45), 0 0 26px rgba(255,225,60,.6)}
.send button .shine{position:absolute;top:0;left:-40%;width:40%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.85),transparent);
  transform:skewX(-18deg);animation:shine 2.4s ease-in-out infinite}
@keyframes shine{0%{left:-50%}55%,100%{left:130%}}
.send.locked button{color:#9fb0d6;background:linear-gradient(180deg,#33457a,#26356a);
  box-shadow:0 6px 0 #16224a, inset 0 1px 0 rgba(255,255,255,.1);cursor:default}
.send.locked .shine{display:none}
.send .hint{text-align:center;font-size:12px;color:#9fb6e8;margin-top:8px}

/* 下部ナビ：ビューポート下端に常に固定（fixed）。max-width内に中央寄せ */
.nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);z-index:20;
  width:100%;max-width:var(--maxw);
  height:calc(var(--navH) + env(safe-area-inset-bottom));
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:#0a2a6e;border-top:1.5px solid rgba(160,190,255,.35);
  padding-bottom:env(safe-area-inset-bottom)}
.nav button{background:#001f5e;border:0;color:#cfe0ff;padding:0 2px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-family:'Kosugi Maru',sans-serif}
.nav button:active{background:#00164a}
.nav button span{font-size:13px;font-weight:700;letter-spacing:0;white-space:nowrap}
/* ナビ非表示画面（スタート）：ナビを隠しコンテンツを全高に */
#app.no-nav #appnav{display:none}
#app.no-nav #screen{bottom:0}

/* =========================================================
   スタート（コード全画面・スクロール可）
   ========================================================= */
/* §要求1：ヒーロー画像は原寸（横幅いっぱい）を維持。説明文の行間/段落間のみ詰めて
   「体験スタート」まで1画面に収める（デザインは崩さない） */
.start{position:absolute;inset:0;z-index:2;overflow-y:auto;display:flex;flex-direction:column;
  align-items:center;padding:0 0 calc(env(safe-area-inset-bottom) + 12px)}
.start .hero{width:100%;flex:0 0 auto}
.start .hero img{display:block;width:100%;margin:0 auto}
.start .intro{flex:0 0 auto;padding:8px 22px 0;font-size:12.5px;line-height:1.42;color:#eaf1ff;text-align:center}
.start .intro p{margin:0 0 .42em}
.start .intro p:last-child{margin:0}
.start .intro b{color:var(--yellow);font-weight:700}
/* 説明文の終わりから「体験スタート」まで 64px 空ける（40px ＋ 24px） */
.start .cta{width:100%;max-width:330px;flex:0 0 auto;margin-top:64px;padding:0 22px}
.start .cta button{width:100%;padding:17px;border:0;border-radius:999px;font-size:21px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;color:var(--ink);cursor:pointer;position:relative;overflow:hidden;
  background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 6px 0 #b88600,0 0 26px rgba(255,225,60,.6)}
.start .cta button:active{transform:translateY(2px);box-shadow:0 4px 0 #b88600}
.start .cta .shine{position:absolute;top:0;left:-40%;width:40%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.85),transparent);
  transform:skewX(-18deg);animation:shine 2.6s ease-in-out infinite}

/* =========================================================
   星のあつめ方（コード全画面・スクロール可）
   ========================================================= */
.howto{position:absolute;inset:0;z-index:2;overflow-y:auto;display:flex;flex-direction:column;
  align-items:center;gap:14px;padding:calc(env(safe-area-inset-top) + 14px) 18px 24px}
.howto .h-title{width:78%;max-width:320px}
.howto .h-title img{width:100%;display:block}
.howto .h-panel{width:100%}
.howto .h-panel img{width:100%;display:block;border-radius:14px}
.howto .cta{width:100%;max-width:320px;margin-top:4px}
.howto .cta button{width:100%;padding:15px;border:0;border-radius:999px;font-size:18px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;color:var(--ink);cursor:pointer;
  background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 5px 0 #b88600}
.howto .cta button:active{transform:translateY(2px);box-shadow:0 3px 0 #b88600}

/* =========================================================
   各種案内（メニュー＋各ドキュメント）コード全画面・スクロール可
   黄色ボタンは start/howto/send と同じデザイントークンを踏襲
   ========================================================= */
.guide{position:absolute;inset:0;z-index:2;overflow-y:auto;display:flex;flex-direction:column;
  align-items:center;gap:18px;padding:calc(env(safe-area-inset-top) + 24px) 22px calc(env(safe-area-inset-bottom) + 24px)}
.g-title{font-size:24px;font-weight:800;color:var(--yellow);letter-spacing:.06em;text-align:center;
  text-shadow:0 0 14px rgba(255,210,0,.6),0 2px 0 #b07a00;margin-top:2px}
.g-menu{width:100%;max-width:330px;display:flex;flex-direction:column;gap:18px;margin-top:8px}
/* 下部：たべっ子どうぶつ星座イラスト（一枚絵・装飾。タップは透過させる） */
.g-seiza{position:relative;flex:1;width:100%;display:flex;align-items:center;justify-content:center;
  margin-top:8px;min-height:0;pointer-events:none}
.g-seiza .sz-all{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;
  filter:drop-shadow(0 0 8px rgba(150,195,255,.4));animation:sztw 3.8s ease-in-out infinite}
@keyframes sztw{0%,100%{opacity:.85}50%{opacity:1}}
.menu-btn{width:100%;padding:18px;border:0;border-radius:999px;font-size:19px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;color:var(--ink);cursor:pointer;
  background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 5px 0 #b88600,0 0 22px rgba(255,225,60,.5)}
.menu-btn:active{transform:translateY(2px);box-shadow:0 3px 0 #b88600}
/* ドキュメント本文（利用規約 / プライバシーポリシー） */
.g-doc{width:100%;max-width:390px;font-size:14px;line-height:1.8;color:#eaf1ff;
  background:rgba(0,15,52,.5);border:1px solid rgba(160,190,255,.3);border-radius:14px;padding:16px 18px}
.g-doc p{margin:0 0 .8em}
.g-doc p:last-child{margin:0}
/* 戻る導線（クイズ等と同じゴーストボタン） */
.g-back{margin-top:2px;display:inline-flex;align-items:center;gap:5px;padding:11px 26px;
  border:1.5px solid rgba(170,200,255,.5);border-radius:999px;background:rgba(0,20,70,.6);
  color:#cfe0ff;font:700 14px 'Kosugi Maru',sans-serif;cursor:pointer}
.g-back:active{transform:translateY(1px)}

/* 最後の画面：画像を小さく上寄せ、ボタンは少し上に */
.imgstage.has-bottombtn .imgview{align-items:flex-start}
.imgstage.has-bottombtn .imgwrap img{max-height:70vh}        /* 画像サイズ（縮めすぎ調整） */
.end-cta{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(env(safe-area-inset-bottom) + 72px);
  z-index:16;width:100%;max-width:var(--maxw);display:flex;justify-content:center;padding:0 22px}
.end-cta-btn{width:100%;max-width:330px;padding:16px;border:0;border-radius:999px;
  font-size:20px;font-weight:700;font-family:'Kosugi Maru',sans-serif;color:var(--ink);cursor:pointer;
  background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 5px 0 #b88600,0 0 22px rgba(255,225,60,.5)}
.end-cta-btn:active{transform:translateY(2px);box-shadow:0 3px 0 #b88600}
/* 送信フィードバック（毎回・連打可） */
.send-toast{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom) + 150px);transform:translateX(-50%);
  z-index:30;color:var(--yellow);font:800 22px 'Kosugi Maru',sans-serif;
  text-shadow:0 0 14px rgba(255,210,0,.8),0 2px 0 #b07a00;pointer-events:none;
  animation:sendtoast .9s ease-out forwards}
@keyframes sendtoast{0%{opacity:0;transform:translateX(-50%) translateY(10px) scale(.8)}
  25%{opacity:1;transform:translateX(-50%) translateY(0) scale(1.1)}
  100%{opacity:0;transform:translateX(-50%) translateY(-30px) scale(1)}}

/* 会場MAP：スクロール可能＋拡大トグル */
.mapwrap{position:relative;z-index:2;flex:1;min-height:0;width:100%;overflow:auto;
  -webkit-overflow-scrolling:touch;padding-top:var(--topinset)}
.mapwrap .map-img{display:block;width:100%;height:auto}
.mapwrap.zoom .map-img{width:200%;max-width:none}     /* 拡大時は2倍にして縦横スクロールで閲覧 */
.map-zoom{position:fixed;z-index:18;right:14px;
  bottom:calc(var(--navH) + env(safe-area-inset-bottom) + 14px);
  padding:11px 18px;border:0;border-radius:999px;background:var(--yellow);color:var(--ink);
  font:700 15px 'Kosugi Maru',sans-serif;box-shadow:0 3px 0 #b89b00;cursor:pointer}
.map-zoom:active{transform:translateY(1px);box-shadow:0 1px 0 #b89b00}

/* 星のあつめ方（新アート1枚絵）：スクロール可能な縦並び */
.howto-scroll{position:relative;z-index:2;flex:1;min-height:0;width:100%;overflow-y:auto;
  -webkit-overflow-scrolling:touch;display:flex;flex-direction:column;align-items:center;
  padding-top:var(--topinset)}
.howto-img{display:block;width:100%;max-width:600px}
/* スタート：画像＋ボタンのタップ領域をスクロール内に重ねる */
.start-wrap{position:relative;width:100%;max-width:600px;margin:0 auto}
.start-wrap .howto-img{width:100%}
/* 撮影写真プレビュー（保存／撮り直す／完了） */
.photo-preview{position:absolute;inset:0;z-index:42;background:rgba(0,8,32,.92);
  display:flex;align-items:center;justify-content:center;padding:20px}
.pp-card{width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:12px}
.pp-img{display:block;width:100%;max-height:56vh;object-fit:contain;border-radius:14px;
  border:2px solid rgba(160,190,255,.5);background:#000}
.pp-hint{font-size:12.5px;color:#cfe0ff;text-align:center;line-height:1.6}
.pp-actions{width:100%;display:flex;flex-direction:column;gap:10px}
.pp-actions button{width:100%;padding:14px;border:0;border-radius:999px;font-size:17px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;cursor:pointer}
.pp-save{color:var(--ink);background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 4px 0 #b88600}
.pp-done{color:#fff;background:linear-gradient(180deg,#1d57c8,#0e2f86);box-shadow:0 4px 0 #0a204f}
.pp-retake{color:#cfe0ff;background:rgba(10,40,110,.7);border:1.5px solid rgba(170,200,255,.5)!important}
.pp-actions button:active{transform:translateY(2px)}

/* エリアTOP：画像の下に置く指示テキスト（画像から約40px離す） */
.area-note-below{margin:40px auto 0;text-align:center;color:#fff;font-weight:800;
  font-family:'Kosugi Maru',sans-serif;font-size:clamp(18px,5.6vw,26px);line-height:1.5;
  text-shadow:0 2px 6px rgba(0,0,0,.6);padding:0 18px calc(env(safe-area-inset-bottom) + 16px)}

/* スタート：全画像をfit表示＋どこでもタップ＋ボタン位置に脈動 */
.start-fit{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer}
.start-fit .swrap{position:relative;display:inline-block;max-width:100%;max-height:100%;line-height:0}
.start-fit .swrap img{display:block;width:auto;height:auto;max-width:100%;max-height:100%}
.start-fit .startpulse{position:absolute;left:22%;top:88.6%;width:57%;height:8.2%;border-radius:999px;
  pointer-events:none;animation:startpulse 1.7s ease-in-out infinite}
@keyframes startpulse{0%,100%{box-shadow:0 0 0 0 rgba(255,225,80,0)}
  50%{box-shadow:0 0 22px 7px rgba(255,225,80,.6)}}
/* 星のあつめ方（新アート1枚絵）下部のCTAボタン */
.howto-cta{position:relative;z-index:2;flex:0 0 auto;width:100%;max-width:330px;margin:10px auto 0;
  padding:0 20px calc(env(safe-area-inset-bottom) + 14px)}
.howto-cta button{width:100%;padding:15px;border:0;border-radius:999px;font-size:18px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;color:var(--ink);cursor:pointer;
  background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 5px 0 #b88600}
.howto-cta button:active{transform:translateY(2px);box-shadow:0 3px 0 #b88600}

/* =========================================================
   送信中（コードアニメ）
   ========================================================= */
.sending{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.sending .star{width:46%;max-width:200px;aspect-ratio:1;
  filter:drop-shadow(0 0 26px rgba(255,225,60,.7));animation:sendfly 2.4s ease-in forwards}
.sending .star img{width:100%;height:100%;object-fit:contain}
@keyframes sendfly{0%{transform:translateY(-40px) scale(1);opacity:1}
  70%{transform:translateY(10px) scale(.9);opacity:1}
  100%{transform:translateY(60px) scale(.18);opacity:.2}}
.sending .waves{width:120px;height:60px;margin-top:6px;position:relative}
.sending .waves span{position:absolute;left:50%;bottom:0;border:3px solid rgba(120,190,255,.7);
  border-radius:50%;transform:translateX(-50%);animation:wv 1.6s ease-out infinite}
.sending .waves span:nth-child(2){animation-delay:.5s}
.sending .waves span:nth-child(3){animation-delay:1s}
@keyframes wv{0%{width:10px;height:6px;opacity:.9}100%{width:140px;height:74px;opacity:0}}
.sending .txt{font-size:18px;font-weight:700;color:var(--yellow);letter-spacing:.1em;
  text-shadow:0 0 12px rgba(255,210,0,.6);margin-top:14px}

/* =========================================================
   エリアTOP（撮影/スキャン）コード全画面：バナー＋本文＋ボタン
   ========================================================= */
.at-banner{position:relative;z-index:2;flex:0 0 auto;width:100%}
.at-banner img{width:100%;display:block}
.at-body{position:relative;z-index:2;flex:1;min-height:0;overflow-y:auto;
  padding:18px 20px;display:flex;flex-direction:column;gap:14px;justify-content:center}
.at-lead{font-size:17px;font-weight:700;color:var(--yellow);text-align:center;line-height:1.65;
  text-shadow:0 1px 4px rgba(0,0,0,.4)}
.at-desc{font-size:14.5px;line-height:1.8;color:#eaf1ff;background:rgba(0,15,52,.5);
  border:1px solid rgba(160,190,255,.3);border-radius:14px;padding:14px 16px}
.at-actions{position:relative;z-index:2;padding:0 20px 18px}
.at-btn{width:100%;padding:16px;border:0;border-radius:999px;font-size:19px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;color:var(--ink);cursor:pointer;
  background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 5px 0 #b88600,0 0 22px rgba(255,225,60,.5)}
.at-btn:active{transform:translateY(2px);box-shadow:0 3px 0 #b88600}

/* =========================================================
   クイズ（実ボタン）
   ========================================================= */
/* §要求2：縦に詰めて iPhone SE でも四択＋回答ボタンが1画面に収まる構成。
   下部共通ナビは非表示(no-nav)・戻る導線は上部チップに置換。 */
/* 戻る導線：回答ボタンの下に配置（中央寄せの丸ボタン）。選択肢とは被らない */
.q-back{display:block;margin:10px auto 0;padding:9px 24px;
  border:1.5px solid rgba(170,200,255,.5);border-radius:999px;background:rgba(0,20,70,.6);
  color:#cfe0ff;font:700 14px/1 'Kosugi Maru',sans-serif;cursor:pointer}
.q-back:active{transform:translateY(1px)}
.q-back span{margin-right:4px}
/* タイトル見出し画像：以前の大きい見せ方に復帰（短い端末のみ高さで保護） */
.q-head{width:100%;flex:0 0 auto;margin-top:2px}
.q-head img{display:block;width:auto;max-width:100%;max-height:30vh;margin:0 auto}
.q-body{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;gap:8px;padding:6px 16px 0}
/* お題：★付き＋枠付きパネル */
.q-prompt{flex:0 0 auto;display:flex;align-items:center;justify-content:center;gap:6px;
  font-size:clamp(13px,3.8vw,16px);color:#eaf1ff;font-weight:700;text-align:center;
  border:1px solid rgba(160,190,255,.45);border-radius:999px;background:rgba(0,15,52,.45);padding:7px 12px}
.q-star{color:#ff5fa2;font-size:16px;text-shadow:0 0 6px rgba(255,95,162,.6)}
/* 問題文：余白が足りない時はここだけ内部スクロール（四択は常に表示） */
.q-question{flex:1 1 auto;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;
  font-size:clamp(12px,3.4vw,14px);line-height:1.55;color:#eaf1ff;background:rgba(0,15,52,.55);
  border:1px solid rgba(160,190,255,.3);border-radius:14px;padding:10px 13px}
.q-label{flex:0 0 auto;text-align:center;color:#cfe0ff;font-weight:700;font-size:13px;letter-spacing:.03em}
.q-opts{flex:0 0 auto;display:grid;grid-template-columns:1fr 1fr;gap:9px}
.q-opt{padding:clamp(10px,2.3vh,15px) 8px;border-radius:14px;border:2px solid rgba(170,200,255,.5);
  background:linear-gradient(180deg, rgba(28,66,150,.92), rgba(12,38,104,.95));
  color:#fff;font-size:clamp(17px,5vw,20px);font-weight:700;font-family:'Kosugi Maru',sans-serif;cursor:pointer;
  box-shadow:0 5px 0 rgba(0,10,40,.5);transition:transform .08s}
.q-opt:active{transform:translateY(2px);box-shadow:0 3px 0 rgba(0,10,40,.5)}
.q-opt.sel{border-color:var(--yellow);background:linear-gradient(180deg,#1d57c8,#0e2f86);
  box-shadow:0 5px 0 #0a204f, 0 0 18px rgba(255,225,60,.5)}
.q-opt.wrong{animation:shake .4s;border-color:#ff6b8a;box-shadow:0 5px 0 #0a204f,0 0 18px rgba(255,80,120,.6)}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-7px)}40%,80%{transform:translateX(7px)}}
/* 回答ボタンは最下部に固定（位置を下げる） */
.q-actions{flex:0 0 auto;padding:10px 16px calc(env(safe-area-inset-bottom) + 12px)}
.q-judge{width:100%;padding:15px;border:0;border-radius:999px;font-size:18px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;color:var(--ink);cursor:pointer;
  background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 5px 0 #b88600}
.q-judge:active{transform:translateY(2px);box-shadow:0 3px 0 #b88600}
.q-judge:disabled{color:#9fb0d6;background:linear-gradient(180deg,#33457a,#26356a);box-shadow:0 5px 0 #16224a;cursor:default;transform:none}

/* =========================================================
   カメラ / スキャン
   ========================================================= */
.cam-layer{position:absolute;inset:0;z-index:30;background:#000}
.cam-label{position:absolute;top:max(14px, env(safe-area-inset-top));left:0;right:0;text-align:center;font-size:15px;color:#fff;z-index:3;text-shadow:0 1px 3px #000}
.cam-video,.cam-preview{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.cam-controls{position:absolute;left:0;right:0;bottom:calc(34px + env(safe-area-inset-bottom));z-index:4;display:flex;flex-direction:column;align-items:center;gap:10px}
.cam-btn{min-width:200px;padding:15px 28px;border:0;border-radius:999px;
  background:linear-gradient(180deg,#fff,#e9eefc);color:#11235a;font-size:18px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;cursor:pointer;box-shadow:0 5px 14px rgba(0,0,0,.5)}
.cam-btn:active{transform:translateY(2px)}
.cam-ghost{padding:9px 22px;border:2px solid rgba(255,255,255,.6);border-radius:999px;background:transparent;color:#fff;font-weight:700;cursor:pointer}
.cam-close{position:absolute;top:max(10px, env(safe-area-inset-top));right:14px;z-index:5;width:40px;height:40px;border-radius:50%;border:0;background:rgba(0,0,0,.55);color:#fff;font-size:23px;cursor:pointer}
.scan-frame{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);width:64%;max-width:280px;aspect-ratio:1;z-index:3}
.scan-frame span{position:absolute;width:40px;height:40px;border:4px solid #ff3b3b}
.scan-frame span:nth-child(1){top:0;left:0;border-right:0;border-bottom:0}
.scan-frame span:nth-child(2){top:0;right:0;border-left:0;border-bottom:0}
.scan-frame span:nth-child(3){bottom:0;left:0;border-right:0;border-top:0}
.scan-frame span:nth-child(4){bottom:0;right:0;border-left:0;border-top:0}
.scan-hint{position:absolute;left:0;right:0;bottom:calc(110px + env(safe-area-inset-bottom));text-align:center;z-index:3;font-size:17px;font-weight:700;color:#fff;text-shadow:0 1px 4px #000;line-height:1.7;padding:0 16px}
.scan-hint.mismatch{color:#ff6b6b;font-weight:700;animation:shake .4s}
/* カメラ起動失敗の案内（黒画面で固まらせない） */
.cam-error{position:absolute;inset:0;z-index:4;display:flex;align-items:center;justify-content:center;
  padding:28px;background:rgba(0,6,26,.94)}
.cam-error-card{max-width:340px;text-align:center}
.cam-error-msg{font-size:15px;line-height:1.8;white-space:pre-line;color:#eaf1ff;margin-bottom:22px}
.cam-error-btn{padding:14px 30px;border:0;border-radius:999px;font-size:17px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;color:var(--ink);cursor:pointer;
  background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 5px 0 #b88600}
.cam-error-btn:active{transform:translateY(2px);box-shadow:0 3px 0 #b88600}
/* スキャン診断HUD（?debug=1 のときだけ表示） */
.cam-hud{display:none}
#app.debug .cam-hud{display:block;position:absolute;left:8px;right:8px;
  top:calc(env(safe-area-inset-top) + 40px);z-index:7;
  font:600 11px/1.5 ui-monospace,Menlo,monospace;color:#9dff9d;
  background:rgba(0,0,0,.6);padding:4px 8px;border-radius:8px;word-break:break-all}

/* =========================================================
   モーダル / トースト
   ========================================================= */
.modal-root{position:absolute;inset:0;z-index:40;background:rgba(0,8,32,.78);display:flex;align-items:center;justify-content:center;padding:28px}
.modal-card{width:100%;max-width:340px;background:linear-gradient(180deg,#0b3aa0,#002878);
  border:2px solid rgba(160,190,255,.55);color:#fff;border-radius:20px;padding:26px 22px;text-align:center;box-shadow:0 14px 40px rgba(0,0,0,.55)}
.modal-text{font-size:17px;font-weight:700;line-height:1.7;margin:4px 0 20px;white-space:pre-line}
.modal-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.modal-btn{min-width:120px;padding:12px 20px;border:1.5px solid rgba(170,200,255,.5);border-radius:999px;
  background:rgba(10,40,110,.7);color:#dfe9ff;font-size:15px;font-weight:700;font-family:'Kosugi Maru',sans-serif;
  cursor:pointer;box-shadow:0 3px 0 rgba(0,12,48,.6)}
.modal-btn:active{transform:translateY(2px);box-shadow:0 1px 0 rgba(0,12,48,.6)}
.modal-btn.primary{border:0;background:var(--yellow);color:#1a1a1a;box-shadow:0 3px 0 #b89b00}
.modal-btn.primary:active{box-shadow:0 1px 0 #b89b00}

.toast{position:absolute;inset:0;z-index:35;display:none;align-items:center;justify-content:center;background:rgba(0,8,32,.6)}
.toast.on{display:flex}
.toast .card{background:linear-gradient(180deg,#0b3aa0,#002878);border:2px solid rgba(255,225,80,.6);
  border-radius:20px;padding:24px 28px;text-align:center;box-shadow:0 14px 40px rgba(0,0,0,.5)}
.toast .card b{font-size:20px;color:var(--yellow);display:block;margin-bottom:6px}
.toast .card span{font-size:14px;color:#cfe0ff}

/* =========================================================
   モーダル：確認/不正解バリアント（§要求1：正誤を明確に）
   ========================================================= */
.modal-icon{width:64px;height:64px;margin:0 auto 10px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:34px;font-weight:900;line-height:1}
.modal-card.confirm{border-color:rgba(255,225,80,.7)}
.modal-card.wrong{border-color:#ff5f86;background:linear-gradient(180deg,#7a1030,#3a0a1e);
  box-shadow:0 14px 40px rgba(120,0,30,.55);animation:wrongpop .42s}
.modal-card.wrong .modal-icon{background:radial-gradient(circle,#ff6b8a,#c11042);color:#fff;
  box-shadow:0 0 24px rgba(255,70,110,.8)}
.modal-card.wrong .modal-text{color:#ffe3ea}
@keyframes wrongpop{0%{transform:scale(.7) rotate(-3deg);opacity:0}
  35%{transform:scale(1.06) rotate(2deg)}60%{transform:scale(.97) rotate(-1.5deg)}100%{transform:scale(1) rotate(0);opacity:1}}
.modal-btn.primary{background:linear-gradient(180deg,#fff36b,#ffd400);color:#1a1a1a;box-shadow:0 3px 0 #b88600}
.modal-card.wrong .modal-btn.primary{background:linear-gradient(180deg,#fff,#ffd9e2);color:#a01038;box-shadow:0 3px 0 #7a0a26}

/* =========================================================
   クリア/正解 キラキラ演出（§要求1）
   ========================================================= */
.celebrate{position:absolute;inset:0;z-index:45;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 42%,rgba(20,60,160,.78),rgba(0,8,32,.92));
  animation:celin .26s ease-out}
.celebrate.out{animation:celout .24s ease-in forwards}
@keyframes celin{0%{opacity:0}100%{opacity:1}}
@keyframes celout{0%{opacity:1}100%{opacity:0}}
.cel-burst{position:absolute;top:42%;left:50%;width:0;height:0;pointer-events:none}
.cel-burst i{position:absolute;left:0;top:0;color:#ffe24a;font-style:normal;
  text-shadow:0 0 8px rgba(255,220,60,.9);opacity:0;
  animation:spark 1s ease-out forwards}
@keyframes spark{0%{transform:translate(0,0) scale(.2) rotate(0);opacity:0}
  18%{opacity:1}
  100%{transform:translate(var(--tx),var(--ty)) scale(1.1) rotate(160deg);opacity:0}}
.cel-card{position:relative;z-index:2;text-align:center;padding:8px 24px;
  animation:celcard .5s cubic-bezier(.18,1.3,.4,1)}
@keyframes celcard{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
.cel-star{width:38vw;max-width:170px;margin:0 auto;
  filter:drop-shadow(0 0 26px rgba(255,225,60,.8));animation:celstar 2.4s ease-in-out infinite}
.cel-star img{width:100%;display:block}
@keyframes celstar{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-8px) rotate(4deg)}}
/* 「クリア！」は丸文字でなくスタイリッシュに（子供っぽく見えないよう斜体ゴシック） */
.cel-title{font-size:32px;font-weight:900;color:var(--yellow);letter-spacing:.06em;margin-top:6px;
  font-family:"Hiragino Sans","Helvetica Neue",Arial,sans-serif;font-style:italic;
  text-shadow:0 0 16px rgba(255,210,0,.7),0 2px 0 #b07a00}
.cel-sub{font-size:16px;color:#eaf1ff;margin-top:6px;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.cel-btn{margin-top:20px;padding:14px 30px;border:0;border-radius:999px;font-size:18px;font-weight:700;
  font-family:'Kosugi Maru',sans-serif;color:var(--ink);cursor:pointer;
  background:linear-gradient(180deg,#fff36b,#ffd400);box-shadow:0 5px 0 #b88600,0 0 22px rgba(255,225,60,.5)}
.cel-btn:active{transform:translateY(2px);box-shadow:0 3px 0 #b88600}
.celebrate.big{background:radial-gradient(circle at 50% 42%,rgba(60,30,160,.82),rgba(0,8,32,.95))}
.celebrate.big .cel-star{max-width:210px}
.celebrate.big .cel-title{font-size:34px}

/* =========================================================
   エンド画面の動き（送信後：Congrats→記念切符→発券済）
   静止JPGの瞬間差し替え＝「コマ送り」感を解消する
   ========================================================= */
/* 入場トランジション：ふわっと立ち上げる */
.imgview.enter{animation:imgenter .5s cubic-bezier(.2,.9,.3,1)}
@keyframes imgenter{0%{opacity:0;transform:translateY(16px) scale(.985)}100%{opacity:1;transform:none}}

/* キラキラ舞い（常時）/ 登場バースト（一発）：画像ボックス基準で重ねる */
/* エフェクトは最前面（見出しz4・ボタンz5より上）。pointer-events:none でタップは貫通 */
.fx-shower,.fx-burst,.fx-shine{position:absolute;inset:0;pointer-events:none;z-index:6;overflow:hidden}
.fx-shower i{position:absolute;top:-6%;color:#ffe24a;font-style:normal;opacity:.9;
  text-shadow:0 0 6px rgba(255,220,60,.85);animation:fxfall linear infinite;will-change:transform}
@keyframes fxfall{0%{transform:translateY(0) rotate(0);opacity:0}
  8%{opacity:1}88%{opacity:1}100%{transform:translateY(108vh) rotate(220deg);opacity:0}}
.fx-burst i{position:absolute;left:50%;top:40%;color:#ffe24a;font-style:normal;font-size:18px;opacity:0;
  text-shadow:0 0 8px rgba(255,220,60,.9);animation:spark 1s ease-out forwards}
/* シャイン：斜めの光が画面を横切る（記念切符のプレミア感） */
.fx-shine::before{content:"";position:absolute;top:-30%;left:-60%;width:38%;height:160%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.42),transparent);
  transform:skewX(-18deg);animation:fxshine 3.4s ease-in-out infinite}
@keyframes fxshine{0%{left:-60%}55%,100%{left:165%}}

/* タップ先（ボタン/QR）を発光でアピール */
.hot.glow{border-radius:16px;animation:hotglow 1.6s ease-in-out infinite}
@keyframes hotglow{0%,100%{box-shadow:0 0 0 0 rgba(255,225,80,0)}
  50%{box-shadow:0 0 0 5px rgba(255,225,80,.45),0 0 22px 7px rgba(255,210,0,.5)}}

/* 送信中（end_sending）：大きな星のグロー＋ドームへ昇る星＋送信の電波（§要求4の動き） */
.fx-sendstar{position:absolute;left:50%;top:62%;width:0;height:0;z-index:2;pointer-events:none}
.fx-sendstar::before{content:"";position:absolute;left:0;top:0;
  width:60vw;max-width:240px;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(255,225,80,.55),rgba(255,210,0,0) 62%);
  animation:sendhalo 1.6s ease-in-out infinite}
@keyframes sendhalo{0%,100%{transform:translate(-50%,-50%) scale(.88);opacity:.5}
  50%{transform:translate(-50%,-50%) scale(1.1);opacity:1}}
.fx-send{position:absolute;left:50%;top:78%;width:0;height:0;z-index:3;pointer-events:none}
.fx-send::before,.fx-send::after{content:"";position:absolute;left:0;top:0;
  width:30px;height:30px;border:3px solid rgba(120,190,255,.8);border-radius:50%;
  transform:translate(-50%,-50%);animation:sendpulse 1.7s ease-out infinite}
.fx-send::after{animation-delay:.85s}
@keyframes sendpulse{0%{width:24px;height:24px;opacity:.9}100%{width:170px;height:170px;opacity:0}}

/* デバッグ：ホットスポット可視化（?debug=1） */
.debug .hot{background:rgba(255,0,0,.22);outline:1px solid rgba(255,0,0,.7)}
