/* ===== Shared Peppy Thinkers header/footer ===== */
.container{width:min(1120px,calc(100% - 44px));max-width:none;margin:0 auto;}
.site-header,.site-header *,.site-footer,.site-footer *{box-sizing:border-box;}
.puzzle-site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.86);backdrop-filter:blur(16px);border-bottom:1px solid rgba(223,231,242,.9);padding:0;}
.puzzle-header-inner{min-height:82px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.puzzle-brand,.brand{display:inline-flex;align-items:center;gap:13px;min-width:fit-content;color:inherit;text-decoration:none;}
.brand-badge{width:44px;height:44px;border-radius:15px;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.92rem;font-weight:900;background:linear-gradient(135deg,#4078ff,#6757f5);box-shadow:0 12px 22px rgba(64,120,255,.22);}
.logo{display:block;font-size:1.55rem;font-weight:900;letter-spacing:-.04em;line-height:1.05;color:#172033;}
.tagline{display:block;margin-top:8px;color:#718096;font-size:.68rem;font-weight:800;letter-spacing:.19em;}
.site-nav{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:8px;}
.site-nav a{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:8px 12px;border-radius:999px;color:#435067;font-size:.9rem;font-weight:900;text-decoration:none;transition:transform .18s ease,background .18s ease,color .18s ease,box-shadow .18s ease;}
.site-nav a:hover{transform:translateY(-1px);background:#f2f0ff;color:#4d3fdc;}
.site-nav a.active{color:#fff;background:#6757f5;box-shadow:0 12px 22px rgba(103,87,245,.25);}
.menu-toggle{display:none;width:42px;height:42px;border:1px solid #dfe7f2;border-radius:14px;background:#fff;color:#27344a;font-size:1.2rem;font-weight:900;cursor:pointer;}

/* ===== Mini Games sub navigation ===== */
.mini-game-subnav{
  width:min(1320px,calc(100% - 44px));
  margin:18px auto 18px;
  padding:14px 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:8px;
  border-radius:24px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(223,231,242,.9);
  box-shadow:0 10px 25px rgba(34,50,84,.08);
  backdrop-filter:blur(14px);
}
.mini-game-subnav a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:9px 13px;
  border-radius:999px;
  background:#fff;
  border:1px solid #dfe7f2;
  color:#435067;
  font-size:.9rem;
  font-weight:900;
  text-decoration:none;
  transition:transform .18s ease,background .18s ease,color .18s ease,border-color .18s ease,box-shadow .18s ease;
}
.mini-game-subnav a:hover,
.mini-game-subnav a.active{
  color:#fff;
  background:#6757f5;
  border-color:#6757f5;
  box-shadow:0 10px 22px rgba(103,87,245,.22);
  transform:translateY(-1px);
}

.puzzle-site-footer{padding:32px 0;border-top:1px solid #dfe7f2;background:rgba(255,255,255,.62);}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;}
.site-footer h3{font-size:1rem;font-weight:900;margin:0;letter-spacing:-.02em;}
.site-footer p{color:#5f6b7c;font-size:.9rem;margin:4px 0 0;}
.footer-nav{display:flex;gap:18px;flex-wrap:wrap;}
.footer-nav a{color:#435067;font-size:.9rem;font-weight:800;text-decoration:none;}
.footer-nav a:hover{color:#6757f5;}

:root{
  --bg1:#fff7ed;
  --bg2:#eef2ff;
  --ink:#243041;
  --muted:#64748b;
  --panel:rgba(255,255,255,.84);
  --solid:#fffdf8;
  --pink:#f472b6;
  --blue:#60a5fa;
  --green:#34d399;
  --yellow:#fbbf24;
  --purple:#a78bfa;
  --soil:#7c4a2d;
  --soil-dark:#50311f;
  --danger:#ef4444;
  --shadow:0 22px 60px rgba(48,52,75,.18);
  --soft:0 12px 30px rgba(48,52,75,.12);
  --radius:24px;
}
*{box-sizing:border-box}
html,body{min-height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 12% 8%,rgba(251,191,36,.28),transparent 26%),
    radial-gradient(circle at 84% 14%,rgba(96,165,250,.22),transparent 28%),
    radial-gradient(circle at 50% 94%,rgba(52,211,153,.16),transparent 30%),
    linear-gradient(135deg,var(--bg1),var(--bg2));
  overflow-x:hidden;
}
button,select{font:inherit}
button{border:0;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,opacity .16s ease;}
button:not(:disabled):hover{transform:translateY(-1px)}
button:disabled{opacity:.55;cursor:not-allowed}
select{width:100%;border:1px solid rgba(100,116,139,.18);background:white;border-radius:16px;padding:11px 12px;margin-top:6px;color:var(--ink);font-weight:900;}
label{display:block;color:var(--muted);font-weight:900;font-size:.86rem;margin:14px 0;}
.app-shell{min-height:100%;padding:18px;}
.game-header{
  max-width:1540px;
  margin:0 auto 16px;
  padding:14px 16px;
  display:grid;
  grid-template-columns:minmax(260px,1fr) auto auto;
  gap:14px;
  align-items:center;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.78);
  border-radius:28px;
  box-shadow:var(--soft);
  backdrop-filter:blur(14px);
}
.brand-block{display:flex;align-items:center;gap:12px;min-width:0}
.logo-treat{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;font-size:1.9rem;background:linear-gradient(145deg,#fde68a,#fb7185);box-shadow:inset 0 0 0 3px rgba(255,255,255,.48),var(--soft);}
h1{margin:0;font-size:clamp(1.35rem,2vw,2.25rem);letter-spacing:-.055em;line-height:1.05;}
.brand-block p{margin:2px 0 0;color:var(--muted);font-weight:800;font-size:.88rem;}
.top-stats{display:flex;align-items:center;gap:8px;}
.stat{min-width:82px;padding:9px 11px;background:rgba(255,253,248,.9);border:1px solid rgba(100,116,139,.14);border-radius:18px;text-align:center;}
.stat span{display:block;color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;font-weight:900;}
.stat strong{display:block;margin-top:2px;font-size:1.08rem;}
.header-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end;flex-wrap:wrap;}
.icon-btn{width:42px;height:42px;border-radius:15px;background:rgba(255,253,248,.9);color:var(--ink);font-weight:900;box-shadow:var(--soft);}
.primary-btn,.soft-btn,.gold-btn,.danger-soft-btn{border-radius:16px;padding:11px 14px;font-weight:900;}
.primary-btn{color:#fff;background:linear-gradient(135deg,#fb7185,#ec4899);box-shadow:0 12px 26px rgba(236,72,153,.22);}
.soft-btn{color:var(--ink);background:rgba(255,253,248,.92);border:1px solid rgba(100,116,139,.14);}
.gold-btn{color:#442a05;background:linear-gradient(135deg,#fde68a,#fbbf24);box-shadow:0 12px 26px rgba(251,191,36,.24);}
.danger-soft-btn{color:#8b1a1a;background:#fee2e2;border:1px solid #fecaca;}
.full{width:100%;}
.game-layout{max-width:1540px;margin:0 auto;display:grid;grid-template-columns:minmax(250px,318px) minmax(760px,1fr);gap:18px;align-items:start;}
.side-panel{display:flex;flex-direction:column;gap:14px;}
.panel-card{background:var(--panel);border:1px solid rgba(255,255,255,.78);border-radius:var(--radius);padding:16px;box-shadow:var(--soft);backdrop-filter:blur(14px);}
.panel-card h2{margin:0 0 10px;font-size:1.05rem;letter-spacing:-.02em;}
.status-card p,.coach-card p{margin:0 0 12px;color:var(--muted);font-weight:800;line-height:1.45;}
.mini-meter{height:12px;border-radius:999px;background:rgba(100,116,139,.14);overflow:hidden;}
.mini-meter span{display:block;height:100%;width:100%;background:linear-gradient(90deg,var(--pink),var(--yellow),var(--green));transition:width .25s ease;}
.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;}
.status-grid div{background:rgba(255,253,248,.72);border-radius:16px;padding:10px;}
.status-grid span{display:block;color:var(--muted);font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.05em;}
.status-grid strong{display:block;font-size:1.1rem;margin-top:2px;white-space:nowrap;}
.button-stack{display:grid;gap:9px;}
.table-zone{min-width:0;}
.treat-table{position:relative;min-height:calc(100vh - 130px);border-radius:38px;padding:20px;overflow:hidden;background:radial-gradient(circle at 50% 36%,rgba(255,255,255,.18),transparent 32%),repeating-linear-gradient(35deg,rgba(255,255,255,.045) 0 3px,transparent 3px 13px),linear-gradient(135deg,#60a5fa 0%,#34d399 48%,#22c55e 100%);border:10px solid var(--soil);box-shadow:var(--shadow),inset 0 0 0 8px rgba(255,255,255,.16);}
.table-shine{position:absolute;inset:52px 80px;border:2px dashed rgba(255,255,255,.20);border-radius:50%;pointer-events:none;}
.quick-rules{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;margin-bottom:14px;}
.quick-rules span{color:#fff;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.20);border-radius:999px;padding:7px 10px;font-size:.82rem;font-weight:800;backdrop-filter:blur(8px);}
.message-banner{position:relative;z-index:2;margin:0 auto 18px;width:fit-content;max-width:min(92%,840px);color:white;text-align:center;font-weight:900;line-height:1.35;padding:10px 16px;border-radius:999px;background:rgba(31,77,46,.48);border:1px solid rgba(255,255,255,.20);box-shadow:0 8px 24px rgba(0,0,0,.12);}
.instructions{position:relative;z-index:2;text-align:center;margin:14px 0 0;color:rgba(255,255,255,.88);font-weight:900;line-height:1.45;}
.theme-picker{margin:0 0 12px;}
.difficulty-picker{margin:0;}
.theme-select{border:1px solid #e1d8ca;border-radius:14px;padding:10px 12px;background:#fff;color:#253047;font-weight:900;}
.mini-game{position:relative;z-index:2;height:620px;border-radius:30px;overflow:hidden;border:2px solid rgba(255,255,255,.30);margin:12px auto;box-shadow:inset 0 0 0 5px rgba(255,255,255,.35),0 18px 38px rgba(0,0,0,.14);user-select:none;touch-action:none;isolation:isolate;max-width:980px;}
.mini-game.mini-running{outline:3px solid rgba(255,255,255,.65);outline-offset:-7px;}
.mini-score{position:absolute;left:14px;top:14px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.88);font-weight:900;z-index:30;box-shadow:0 8px 20px rgba(30,40,60,.12);}
.mini-time-bar{position:absolute;left:14px;right:14px;bottom:14px;height:10px;border-radius:999px;background:rgba(255,255,255,.55);overflow:hidden;z-index:32;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5);}
.mini-time-bar span{display:block;height:100%;width:100%;border-radius:999px;background:linear-gradient(90deg,#fb7185,#fbbf24,#34d399);transform-origin:left center;}
.basket{position:absolute;z-index:31;bottom:24px;left:50%;transform:translateX(-50%);font-size:68px;line-height:1;filter:drop-shadow(0 10px 8px rgba(30,40,60,.18));}
.treat{position:absolute;z-index:30;font-size:42px;line-height:1;filter:drop-shadow(0 9px 8px rgba(30,40,60,.15));will-change:top,left,transform;}
.treat.bad-treat{filter:drop-shadow(0 9px 8px rgba(30,40,60,.18));animation:badWobble .7s ease-in-out infinite alternate;}
.theme-badge{position:absolute;right:16px;top:14px;z-index:22;display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:999px;background:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.65);color:#253047;font-size:.78rem;font-weight:900;box-shadow:0 8px 20px rgba(30,40,60,.12);pointer-events:none;}
.theme-decor{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden;}
.theme-decor span{position:absolute;display:grid;place-items:center;font-size:2.35rem;line-height:1;filter:drop-shadow(0 8px 10px rgba(30,40,60,.12));}
.mini-pop{position:absolute;z-index:40;transform:translate(-50%,-50%);color:#253047;background:#fff;border-radius:999px;padding:6px 9px;font-weight:900;animation:popFloat .7s ease forwards;pointer-events:none;box-shadow:0 10px 20px rgba(30,40,60,.12);}
@keyframes popFloat{from{opacity:0;transform:translate(-50%,-20%) scale(.8)}20%{opacity:1}to{opacity:0;transform:translate(-50%,-110%) scale(1.08)}}
@keyframes badWobble{from{scale:1;}to{scale:1.08;}}
.mini-message{position:absolute;inset:0;z-index:60;display:grid;place-items:center;padding:18px;background:rgba(30,41,59,.20);backdrop-filter:blur(4px);}
.mini-message.hidden{display:none;}
.mini-message>div{width:min(360px,100%);text-align:center;background:rgba(255,253,248,.96);border-radius:26px;padding:24px;box-shadow:var(--shadow);}
.mini-message h3{margin:0 0 8px;font-size:1.7rem;letter-spacing:-.03em;}
.mini-message p{margin:0 0 16px;color:var(--muted);font-weight:800;line-height:1.45;}
#miniGame[data-theme="spring"]{border-color:#9ee6bd;background:linear-gradient(180deg,#bde7ff 0%,#e6f7ff 52%,#c8f7d5 53%,#8fe0a3 100%);}
#miniGame[data-theme="summer"]{border-color:#fcd34d;background:linear-gradient(180deg,#93c5fd 0%,#dbeafe 50%,#fde68a 51%,#fbbf24 100%);}
#miniGame[data-theme="autumn"]{border-color:#fdba74;background:linear-gradient(180deg,#fed7aa 0%,#fff7ed 50%,#fbbf24 51%,#d97706 100%);}
#miniGame[data-theme="winter"]{border-color:#bfdbfe;background:linear-gradient(180deg,#dbeafe 0%,#eff6ff 50%,#ffffff 51%,#bfdbfe 100%);}
#miniGame[data-theme="halloween"]{border-color:#c084fc;background:linear-gradient(180deg,#312e81 0%,#581c87 54%,#1f2937 55%,#111827 100%);}
#miniGame[data-theme="christmas"]{border-color:#86efac;background:linear-gradient(180deg,#bfdbfe 0%,#eff6ff 50%,#dcfce7 51%,#16a34a 100%);}
#miniGame[data-theme="halloween"] .theme-badge,#miniGame[data-theme="halloween"] .mini-score{color:#3b0764;}
#miniGame[data-theme="halloween"] .mini-message{background:rgba(0,0,0,.32);}
#miniGame[data-theme="autumn"] .mini-score{color:#78350f;}
#miniGame[data-theme="christmas"] .mini-score{color:#7f1d1d;}
.modal{position:fixed;inset:0;background:rgba(14,41,29,.54);display:grid;place-items:center;z-index:1200;padding:18px;}
.modal.hidden{display:none;}
.modal-card{width:min(720px,96vw);max-height:88vh;overflow:auto;background:var(--solid);border-radius:28px;padding:24px;box-shadow:var(--shadow);position:relative;}
.modal-card h2{margin:0 0 12px;font-size:1.55rem;letter-spacing:-.03em;}
.modal-card p,.modal-card li{color:var(--muted);line-height:1.55;font-weight:800;}
.modal-close{position:absolute;right:14px;top:14px;width:38px;height:38px;border-radius:14px;background:#eef2ff;font-size:1.35rem;font-weight:900;}
@media(max-width:1180px){
  .game-header{grid-template-columns:1fr;}
  .top-stats{justify-content:space-between;flex-wrap:wrap;}
  .header-actions{justify-content:flex-end;}
  .game-layout{grid-template-columns:1fr;}
  .side-panel{order:2;display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));}
  .table-zone{order:1;}
}
@media(max-width:820px){
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center;}
  .site-nav{position:absolute;left:22px;right:22px;top:76px;display:none;flex-direction:column;align-items:stretch;padding:12px;border:1px solid #dfe7f2;border-radius:22px;background:rgba(255,255,255,.98);box-shadow:0 18px 45px rgba(34,50,84,.11);}
  .site-nav.open{display:flex;}
  .site-nav a{text-align:center;}
}
@media(max-width:760px){
  .app-shell{padding:10px;}
  .game-header{border-radius:22px;}
  .brand-block{align-items:flex-start;}
  .logo-treat{width:44px;height:44px;border-radius:15px;font-size:1.5rem;}
  .top-stats{gap:6px;}
  .stat{flex:1;min-width:70px;padding:8px 6px;}
  .side-panel{grid-template-columns:1fr;}
  .treat-table{min-height:740px;border-radius:26px;border-width:7px;padding:12px;}
  .quick-rules{display:none;}
  .mini-game{height:530px;border-radius:22px;}
}
@media(max-width:680px){
  .mini-game-subnav{width:min(100% - 28px,1120px);justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;}
  .mini-game-subnav::-webkit-scrollbar{display:none;}
  .mini-game-subnav a{flex:0 0 auto;}

  .container{width:min(100% - 28px,1120px);}
  .puzzle-header-inner{min-height:82px;}
  .brand-badge{width:40px;height:40px;}
  .logo{font-size:1.28rem;}
  .tagline{font-size:.58rem;}
  .footer-inner{align-items:flex-start;flex-direction:column;}
}
@media(max-width:560px){
  .header-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%;justify-content:stretch;}
  .header-actions .icon-btn{width:100%;}
  .primary-btn,.soft-btn{padding:10px 11px;}
  .top-stats{display:grid;grid-template-columns:repeat(2,1fr);}
  .stat{min-width:0;}
  .mini-game{height:480px;}
  .basket{font-size:58px;}
  .treat{font-size:36px;}
  .message-banner{border-radius:18px;}
}
