
/* ── CUSTOM PROPERTIES ── */
:root{
  --green:#58CC02;--green-dk:#58A700;--green-lt:#D7FFB8;
  --red:#FF4B4B;--red-dk:#CB3A3A;--red-lt:#FFD7D7;
  --yellow:#FFC800;--yellow-dk:#E6A700;--yellow-lt:#FFF9E0;
  --blue:#1CB0F6;--blue-dk:#0099D6;--blue-dkr:#007BB0;--blue-lt:#DFF4FF;
  --orange:#FF9600;--orange-dk:#CC6600;--orange-lt:#FFF3E0;--purple:#9C27B0;
  --bg:#F0F8FD;--card:#FFFFFF;--border:#E5E5E5;--border-dk:#C9C9C9;
  --txt:#3C3C3C;--txt-md:#777777;--txt-lt:#AFAFAF;
  --font:'Nunito',sans-serif;--font-h:'Baloo 2',sans-serif;
  --shadow:0 2px 8px rgba(0,0,0,.08);
  --z-header:20;--z-pause:50;--z-end-confirm:60;
  --z-rapid-modal:500;--z-drawer-bd:590;--z-drawer:600;
  --z-modal:700;--z-name-modal:710;--z-inpage:800;--z-toast:9999;
  --daily-text:#c03a00;

  /* ── EXTENDED PALETTE & MEDAL TOKENS ── */
  --purple-lt:#CE82FF;--green-icon:#4CAF50;--green-deep:#128807;
  --nmc-card-bg:var(--card);
  --lb-gold-bg:#fffbeb;--lb-gold-border:#f59e0b;
  --lb-silver-bg:#f8fafc;--lb-silver-border:#94a3b8;
  --lb-bronze-bg:#fff7ed;--lb-bronze-border:#d97706;
}
[data-theme="dark"]{
  --bg:#111827;--card:#1F2937;--border:#374151;--border-dk:#4B5563;
  --txt:#F9FAFB;--txt-md:#9CA3AF;--txt-lt:#6B7280;
  --green-lt:#052e16;--blue-lt:#0c4a6e;--red-lt:#450a0a;--yellow-lt:#422006;
  /* ── EXTENDED DARK TOKENS ── */
  --nmc-card-bg:#162840;
  --lb-gold-bg:#2d2508;--lb-gold-border:#b45309;
  --lb-silver-bg:#1e2532;--lb-silver-border:#475569;
  --lb-bronze-bg:#2d1a08;--lb-bronze-border:#c2410c;
  /* Semantic accent tokens */
  --green-dk-lt:#7ed44a;--orange-text-dk:#FFAA33;--orange-tag-dk:#ffb74d;
  --wrong-kw-dk:#ff8080;--shadow-deep:#0f172a;
  --mistakes-hover:#2a1800;--mistakes-active:#3a2000;--mistakes-border:#CC7000;
  --infobox-blue-txt:#7fd4f8;--infobox-green-txt:#a4e96e;--infobox-yellow-txt:#ffd97a;
  --chakra-clr:#7EB8FF;--hero-start:#0c2a32;--hero-end:#0a2310;
  --daily-bar-dk:linear-gradient(140deg,#c0430a 0%,#97300e 52%,#7a2610 100%);
  /* Mode-card dark borders (centralized here so no hex in element selectors) */
  --nmc-relaxed-border-dk:#1f4a24;--nmc-relaxed-bottom-dk:#1a7a10;
  --nmc-rapid-border-dk:#3c1a50;--nmc-rapid-bottom-dk:#7a1a9c;
}
/* ── @KEYFRAMES (hoisted) ──────────────────────────────── */
@keyframes screenFadeIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
@keyframes drawLine{to{stroke-dashoffset:0;}}
@keyframes sparkleAnim{0%,100%{transform:scale(1) rotate(0deg);opacity:.4;}50%{transform:scale(1.4) rotate(90deg);opacity:1;}}
@keyframes floatBob{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
@keyframes lbLivePulse{0%,100%{transform:scale(1);opacity:.6;}55%{transform:scale(2.7);opacity:0;}}
@keyframes flameRingPulse{0%,100%{transform:scale(1);opacity:.3;}50%{transform:scale(1.4);opacity:0;}}
@keyframes flamePop{0%,100%{transform:scale(1);}50%{transform:scale(1.15);}}
@keyframes infernoToday{0%,100%{transform:scale(1) rotate(0deg);filter:drop-shadow(0 0 2px rgba(255,80,0,.6));}45%{transform:scale(1.18) rotate(-3deg);filter:drop-shadow(0 0 4px rgba(255,50,0,.7));}72%{transform:scale(1.10) rotate(2deg);filter:drop-shadow(0 0 3px rgba(255,100,0,.6));}}
@keyframes fireBlazeOnce{0%{transform:scale(1);filter:none;}15%{transform:scale(1.4);filter:drop-shadow(0 0 6px rgba(255,70,0,.8));}35%{transform:scale(1.7);filter:drop-shadow(0 0 10px rgba(255,80,0,.7));}55%{transform:scale(1.35);filter:drop-shadow(0 0 6px rgba(255,120,0,.6));}75%{transform:scale(1.12);filter:drop-shadow(0 0 4px rgba(255,160,0,.5));}100%{transform:scale(1);filter:drop-shadow(0 0 2px rgba(255,80,0,.6));}}
@keyframes todayPendingPulse{0%,100%{box-shadow:0 0 0 1.5px rgba(255,90,0,.20);}50%{box-shadow:0 0 0 2.5px rgba(255,90,0,.40);}}
@keyframes dayLblPulse{0%,100%{opacity:1;}50%{opacity:.5;}}
@keyframes streakElectricPulse{0%{transform:scale(1.1);box-shadow:0 0 10px rgba(0,207,255,.55),0 0 0 0 rgba(0,200,255,.9);}45%{transform:scale(1.2);box-shadow:0 0 22px rgba(0,180,255,.7),0 0 0 14px rgba(0,200,255,0);}100%{transform:scale(1.1);box-shadow:0 0 10px rgba(0,207,255,.55),0 0 0 0 rgba(0,200,255,0);}}
@keyframes throb{0%,100%{transform:scale(1);}50%{transform:scale(1.05);}}
@keyframes correctPop{0%{transform:scale(1);box-shadow:0 4px 0 var(--green-dk);}20%{transform:scale(1.13);box-shadow:0 0 0 8px rgba(88,204,2,.35),0 8px 24px rgba(88,204,2,.4);}50%{transform:scale(1.08);box-shadow:0 0 0 14px rgba(88,204,2,.18),0 10px 28px rgba(88,204,2,.3);}75%{transform:scale(1.03);}100%{transform:scale(1);}}
@keyframes correctFade{0%{opacity:1;transform:scale(1);}30%{opacity:.9;transform:scale(.97);}100%{opacity:0;transform:scale(.82) translateY(-6px);}}
@keyframes wrongShake{0%,100%{transform:translateX(0);}18%{transform:translateX(-9px);}36%{transform:translateX(9px);}54%{transform:translateX(-6px);}72%{transform:translateX(6px);}}
@keyframes cardIn{from{opacity:0;transform:scale(.9) translateY(12px);}to{opacity:1;transform:scale(1) translateY(0);}}
@keyframes hintPulse{from{box-shadow:0 0 0 3px rgba(255,200,0,.3),0 4px 0 var(--yellow-dk);}to{box-shadow:0 0 0 8px rgba(255,200,0,.6),0 4px 0 var(--yellow-dk);}}
@keyframes xpRise{0%{opacity:1;transform:translateY(0) scale(1);}60%{opacity:1;transform:translateY(-34px) scale(1.2);}100%{opacity:0;transform:translateY(-58px) scale(.8);}}
@keyframes rsCardIn{from{opacity:0;transform:translateY(18px) scale(.88);}to{opacity:1;transform:none;}}
@keyframes rsSlideUp{to{opacity:1;transform:translateY(0);}}
@keyframes lbSpin{to{transform:rotate(360deg);}}
@keyframes demoCorrect{0%{transform:scale(1);}40%{transform:scale(1.1);}70%{transform:scale(1.04);}100%{transform:scale(1);}}
@keyframes demoWrong{0%,100%{transform:translateX(0);}20%{transform:translateX(-8px);}40%{transform:translateX(8px);}60%{transform:translateX(-5px);}80%{transform:translateX(5px);}}
@keyframes breatheGlow{0%,100%{transform:scale(1);opacity:.08;}50%{transform:scale(1.3);opacity:.15;}}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
html{overflow:hidden;scrollbar-width:none;max-width:100vw;overscroll-behavior:none;}
html::-webkit-scrollbar{display:none;}
*:focus,*:focus-visible{outline:none;}
/* ── FLEX-CENTER UTILITY ── */
.gc-btn,.gc-hint,.hint-count-badge,.drawer-head-close,.drawer-name-edit-btn,.timer-pill,.ndb-icon,.ndb-lb-icon,.ndb-btn,.nsb-flame-box,.lb-close,.lb-refresh,.lb-loading,.res-icon-btn,.res-stat-icon,.ip-section-icon,.feedback-send-btn,.sfh-btn,.sfh-info-btn,.info-popup-item-icon,.nmc-icon-wrap,.nmc-stats-row,.rapid-modal-backdrop,.rmt-close,.rmt-step-btn,.rmt-play-btn,.nsb-day-sq,.match-card,.scorecard-backdrop,.sc-btn,.lb-backdrop,.np-backdrop,.ip-back-btn,.ip-feat-dot,.ip-toc-num,.ip-pp-num,.htp-step-num,.htp-demo-card,.htp-mode-icon,.htp-hint-icon,#chakra-spin{display:flex;align-items:center;justify-content:center;}
button,a,[data-action],#chakra-spin{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;user-select:none;}
body{
  font-family:var(--font);background:var(--bg);color:var(--txt);
  height:100dvh;max-height:100dvh;
  display:flex;flex-direction:column;align-items:center;
  overflow:hidden;transition:background .3s,color .3s;
}

/* Hide drawer on game/results screens */
body:has(#game-screen.active,#results-screen.active) #side-drawer,
body:has(#game-screen.active,#results-screen.active) #drawer-backdrop{display:none!important;}

/* ── ICON BACKGROUND COLOR UTILITIES (shared across drawer, sections, features) ── */
.ipi-green,.ip-si-green,.ip-fdt-green{background:var(--green-lt);}
.ipi-blue,.ip-si-blue,.ip-fdt-blue{background:var(--blue-lt);}
.ip-si-orange,.ip-fdt-orange{background:var(--orange-lt);}
.ip-fdt-yellow{background:var(--yellow-lt);}
.ipi-gray{background:var(--bg);}

/* ── DRAWER BACKDROP ── */
.drawer-backdrop{
  position:fixed;inset:0;z-index:var(--z-drawer-bd);
  background:rgba(0,0,0,.38);opacity:0;pointer-events:none;
  transition:opacity .3s;backdrop-filter:blur(2px);
}
.drawer-backdrop.open{opacity:1;pointer-events:auto;}

/* ── SIDE DRAWER ── */
.side-drawer{
  position:fixed;top:0;left:-310px;width:290px;height:100dvh;
  background:var(--card);z-index:var(--z-drawer);
  box-shadow:4px 0 28px rgba(0,0,0,.18);
  transition:left .3s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;display:flex;flex-direction:column;padding-bottom:32px;
}
.side-drawer.open{left:0;}

.drawer-head{
  background:var(--blue);padding:max(16px,env(safe-area-inset-top,16px)) 16px 16px;
  display:flex;align-items:center;justify-content:space-between;
  min-height:54px;box-shadow:0 3px 0 var(--blue-dk);flex-shrink:0;
}
.drawer-head-close{
  background:rgba(255,255,255,.2);border:none;border-radius:8px;
  width:34px;height:34px;cursor:pointer;
  color:white;transition:background .15s;flex-shrink:0;
}
.drawer-head-close:hover{background:rgba(255,255,255,.35);}

/* Drawer player name */
.drawer-name-wrap{display:flex;align-items:center;gap:6px;flex:1;min-width:0;justify-content:center;}
.drawer-name-display{
  font-family:var(--font-h);font-size:1.05rem;font-weight:800;color:white;
  letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  min-width:150px;max-width:190px;cursor:pointer;
  border-bottom:1.5px dashed rgba(255,255,255,.45);padding-bottom:1px;
  line-height:1.3;text-align:center;
}
.drawer-name-display.placeholder{color:rgba(255,255,255,.6);font-weight:600;font-size:.88rem;letter-spacing:.2px;border-bottom-color:rgba(255,255,255,.3);}
.drawer-name-edit-btn{
  background:none;border:none;color:rgba(255,255,255,.75);cursor:pointer;
  padding:3px;border-radius:6px;
  transition:color .15s,background .15s;flex-shrink:0;
}
.drawer-name-edit-btn:hover{color:white;background:rgba(255,255,255,.18);}
.drawer-name-input{
  font-family:var(--font-h);font-size:.95rem;font-weight:800;color:white;
  background:rgba(255,255,255,.18);border:1.5px solid rgba(255,255,255,.6);
  border-radius:8px;padding:4px 8px;outline:none;width:170px;letter-spacing:.3px;
}
.drawer-name-input::placeholder{color:rgba(255,255,255,.5);font-weight:600;}
.drawer-name-input:focus{border-color:white;background:rgba(255,255,255,.25);}
.drawer-name-wrap[data-state="editing"] .drawer-name-display,
.drawer-name-wrap[data-state="editing"] .drawer-name-edit-btn{display:none;}
.drawer-name-wrap[data-state="viewing"] .drawer-name-input{display:none;}

/* Drawer level card */
.drawer-level-card{background:var(--blue-lt);border-radius:12px;padding:14px;margin:14px 14px 4px;flex-shrink:0;}
.dl-label{font-family:var(--font-h);font-size:.72rem;font-weight:700;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.8px;margin-bottom:3px;}
.dl-title{font-family:var(--font-h);font-size:.95rem;font-weight:800;color:var(--blue-dk);}
.dl-xp-bar{height:7px;background:var(--border);border-radius:10px;overflow:hidden;margin-top:6px;}
.dl-xp-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--blue-dk));border-radius:10px;transition:width .6s ease;}
.dl-xp-label{font-size:.7rem;color:var(--txt-lt);margin-top:3px;font-weight:700;}

/* Drawer section */
.drawer-section{padding:14px 14px 6px;flex-shrink:0;}
.drawer-section-label{font-family:var(--font-h);font-size:.76rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--txt-lt);margin-bottom:9px;}
.drawer-diff-row{display:flex;gap:6px;flex-wrap:nowrap;}
.diff-btn{
  padding:7px 6px;border-radius:50px;border:2px solid var(--border);
  background:var(--card);font-family:var(--font-h);font-size:.82rem;font-weight:700;
  color:var(--txt-md);cursor:pointer;text-align:center;white-space:nowrap;flex:1;
  box-shadow:0 3px 0 var(--border-dk);
  transition:border-color .18s,background .18s,color .18s,box-shadow .18s;
}
.diff-btn:hover{border-color:var(--green);}
.diff-btn.selected{border-color:var(--blue);background:var(--blue);color:white;box-shadow:0 3px 0 var(--blue-dk);}
.diff-btn[data-diff="5"].selected{border-color:#E91E63;background:#E91E63;box-shadow:0 3px 0 #880E4F;}

/* Drawer topic chips */
.drawer-topic-grid{display:flex;flex-direction:column;gap:6px;}
.topic-chip{
  padding:8px 14px;border-radius:10px;border:2px solid var(--border);
  background:var(--card);font-family:var(--font-h);font-size:.82rem;font-weight:700;
  color:var(--txt-md);cursor:pointer;text-align:left;
  box-shadow:0 2px 0 var(--border-dk);
  transition:border-color .18s,background .18s,color .18s,box-shadow .18s;
}
.topic-chip:hover{border-color:var(--blue);color:var(--blue-dk);}
.topic-chip.selected{border-color:var(--blue);background:var(--blue);color:white;box-shadow:0 2px 0 var(--blue-dk);}

/* Sub-section chips (indented, green accent) */
.topic-chip.topic-chip-section{
  background:rgba(88,204,2,.07);border-color:rgba(88,204,2,.3);color:#3a7a00;
  padding-left:20px;font-size:.79rem;box-shadow:0 2px 0 rgba(88,204,2,.15);
}
.topic-chip.topic-chip-section:hover{border-color:var(--green);color:var(--green-dk);background:rgba(88,204,2,.13);}
.topic-chip.topic-chip-section.selected{background:var(--green);border-color:var(--green-dk);color:white;box-shadow:0 2px 0 var(--green-dk);}
[data-theme="dark"] .topic-chip.topic-chip-section{background:rgba(88,204,2,.10);border-color:rgba(88,204,2,.25);color:var(--green-dk-lt);}
[data-theme="dark"] .topic-chip.topic-chip-section.selected{background:var(--green);border-color:var(--green-dk);color:white;}

/* Mix-mode toggle */
.topic-filter-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px;}
.topic-filter-header .drawer-section-label{margin-bottom:0;}
.mix-toggle-btn{
  font-family:var(--font-h);font-size:.68rem;font-weight:800;letter-spacing:.04em;
  padding:3px 10px;border-radius:50px;border:2px solid var(--border);
  background:var(--card);color:var(--txt-lt);cursor:pointer;white-space:nowrap;
  box-shadow:0 2px 0 var(--border-dk);
  transition:border-color .18s,background .18s,color .18s,box-shadow .18s;
}
.mix-toggle-btn:hover{border-color:var(--orange);color:var(--orange);}
.mix-toggle-btn.active{border-color:var(--orange);background:var(--orange);color:white;box-shadow:0 2px 0 var(--orange-dk);}
.mix-count-badge{font-family:var(--font-h);font-size:.65rem;font-weight:800;color:var(--orange);letter-spacing:.03em;margin:4px 0 2px;min-height:14px;display:block;}

/* In mix mode, "All Topics" chip is disabled */
#topic-scroll.mix-mode .topic-chip[data-is-all="1"]{opacity:.35;pointer-events:none;filter:grayscale(.5);}

/* Mix-mode selected chips use orange accent */
.mix-mode .topic-chip.mix-selected{border-color:var(--orange);background:var(--orange);color:white;box-shadow:0 2px 0 var(--orange-dk);}
.mix-mode .topic-chip.topic-chip-section.mix-selected{border-color:var(--orange-dk);background:var(--orange);color:white;box-shadow:0 2px 0 var(--orange-dk);}

.topic-chip-part-expandable::after{content:'▾';float:right;font-size:.85rem;line-height:1.2;opacity:.45;transition:transform .2s;}
.topic-chip-part-expandable.open::after{transform:rotate(-180deg);opacity:.8;}

/* ── SCREENS ── */

/* ── START SCREEN ── */
#start-screen{
  display:none;flex-direction:column;align-items:center;
  position:fixed;inset:0;height:100dvh;max-height:100dvh;overflow:hidden;padding:0;width:100%;
  background:radial-gradient(circle at 60% 30%,rgba(28,176,246,.08) 0%,transparent 65%),#EBF7FD;
  contain:layout style;touch-action:none;overscroll-behavior:none;
}
#start-screen.active{display:flex;animation:screenFadeIn .38s ease both;}
[data-theme="dark"] #start-screen{
  background:
    radial-gradient(circle at 5% 5%,rgba(255,153,51,.06) 0%,transparent 40%),
    radial-gradient(circle at 95% 95%,rgba(18,136,7,.06) 0%,transparent 40%),
    radial-gradient(circle at 50% 50%,rgba(28,176,246,.05) 0%,transparent 70%),
    var(--bg);
}

/* Header bar */
.sfh{width:100%;display:flex;align-items:center;justify-content:space-between;padding:max(8px,env(safe-area-inset-top,8px)) 14px 0;flex-shrink:0;max-width:480px;align-self:center;position:relative;z-index:var(--z-header);}
.sfh-right{display:flex;gap:4px;position:relative;}
.sfh-btn{
  background:var(--card);border:2px solid var(--border);border-radius:14px;
  width:42px;height:42px;cursor:pointer;
  font-size:1.05rem;box-shadow:var(--shadow);color:var(--txt-md);font-family:var(--font);
  transition:border-color .18s,transform .18s,box-shadow .18s;
}
.sfh-btn:hover{border-color:var(--blue);transform:translateY(-1px);}
.sfh-btn:active{transform:translateY(1px);}
.sfh-right .sfh-btn{width:30px;height:30px;border-radius:10px;}
.sfh-right .sfh-btn svg{width:13px;height:13px;display:block;}

/* Info button + popup */
.sfh-left{display:flex;align-items:center;gap:8px;position:relative;}
.sfh-info-btn{
  background:transparent;border:none;padding:0;
  width:24px;height:24px;cursor:pointer;border-radius:50%;
  color:var(--txt-lt);flex-shrink:0;transition:background .15s;
}
.sfh-info-btn:hover{background:rgba(28,176,246,.12);color:var(--blue);}
.sfh-info-btn svg{display:block;}
.info-popup{
  position:absolute;top:calc(100% + 10px);right:0;
  background:var(--card);border:2px solid var(--border);border-radius:16px;padding:6px;
  box-shadow:0 8px 28px rgba(0,0,0,.13);z-index:var(--z-modal);width:200px;
  opacity:0;pointer-events:none;transform:translateY(-6px) scale(.97);
  transition:opacity .18s ease,transform .18s ease;transform-origin:top right;
}
.info-popup.open{opacity:1;pointer-events:auto;transform:translateY(0) scale(1);}
.info-popup-item{
  display:flex;align-items:center;gap:10px;width:100%;
  background:none;border:none;cursor:pointer;padding:10px 12px;border-radius:11px;
  font-family:var(--font-h);font-size:.82rem;font-weight:700;color:var(--txt-md);
  text-align:left;transition:background .13s,color .13s;
}
.info-popup-item:hover{background:var(--blue-lt);color:var(--blue);}
.info-popup-item-icon{width:28px;height:28px;border-radius:8px;flex-shrink:0;font-size:.9rem;}
.info-popup-divider{height:1px;background:var(--border);margin:4px 6px;}

/* Scrollable start main */
.start-main{
  flex:1;width:100%;max-width:480px;min-height:0;overflow:hidden;
  padding:2px 14px 12px;
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  gap:6px;position:relative;z-index:2;
}

/* ── LOGO ── */
.new-logo-block{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:1;width:100%;animation:screenFadeIn .45s .1s ease both;}
.logo-wrap{display:inline-block;position:relative;}
.new-logo-text{
  font-family:var(--font-h);font-size:clamp(2.2rem,10vw,4.4rem);font-weight:800;
  letter-spacing:-1px;line-height:1.1;position:relative;display:inline-block;color:var(--blue);
}
.res-header .new-logo-text{font-size:clamp(1.3rem,6vw,1.8rem);margin-bottom:4px;}
.logo-sup{font-size:.38em;font-weight:800;vertical-align:super;letter-spacing:0;color:var(--blue);}
.logo-underline-svg{position:absolute;bottom:-5px;left:0;width:100%;height:11px;color:#2D9CDB;opacity:.8;overflow:visible;}
.logo-underline-svg path{stroke-dasharray:320;stroke-dashoffset:320;animation:drawLine 1.2s 1s ease-out forwards;}

.new-tagline{display:flex;align-items:center;gap:8px;justify-content:center;width:100%;font-family:var(--font-h);font-size:clamp(.8rem,2.8vw,1rem);font-weight:700;color:var(--txt-md);letter-spacing:.3px;margin-top:2px;}
.tag-sparkle{font-size:.8rem;display:inline-block;animation:sparkleAnim 2.5s infinite;}
.tag-sparkle.saffron{color:#FF9933;}
.tag-sparkle.green{color:var(--green-deep);animation-delay:1.25s;}

/* ── MODE DIVIDER ── */
.mode-section-divider{display:flex;align-items:center;gap:8px;width:100%;flex-shrink:0;}
.msd-line{flex:1;height:1px;}
.msd-line:first-child{background:linear-gradient(90deg,transparent,rgba(45,156,219,.2));}
.msd-line:last-child{background:linear-gradient(270deg,transparent,rgba(45,156,219,.2));}
.msd-label{font-family:var(--font-h);font-size:.6rem;font-weight:800;color:rgba(0,0,128,.4);text-transform:uppercase;letter-spacing:.2em;white-space:nowrap;display:flex;align-items:center;gap:6px;}
[data-theme="dark"] .msd-label{color:rgba(150,160,200,.45);}
.msd-sparkle{color:var(--blue);font-size:.55rem;}

/* ── 2-COL MODE GRID ── */
.new-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;flex-shrink:1;animation:screenFadeIn .45s .22s ease both;}
.new-mode-card{
  position:relative;display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:14px 12px 11px;border-radius:28px;
  border-width:1.5px;border-style:solid;border-bottom-width:5px;
  background:var(--card);cursor:pointer;min-height:108px;overflow:hidden;min-width:0;
  transition:transform .2s,box-shadow .2s;
}
.new-mode-card:active{transform:translateY(2px);border-bottom-width:2px;}
.new-mode-relaxed{
  --nmc-border:#E8F5E9;--nmc-border-bottom:var(--green-deep);--nmc-hover-shadow:rgba(76,175,80,.12);
  border-color:var(--nmc-border);border-bottom-color:var(--nmc-border-bottom);
}
.new-mode-rapid{
  --nmc-border:#F3E5F5;--nmc-border-bottom:var(--purple);--nmc-hover-shadow:rgba(156,39,176,.12);
  border-color:var(--nmc-border);border-bottom-color:var(--nmc-border-bottom);
}
.new-mode-relaxed:hover,.new-mode-rapid:hover{box-shadow:0 20px 45px var(--nmc-hover-shadow);}
[data-theme="dark"] .new-mode-card{background:var(--nmc-card-bg);}
[data-theme="dark"] .new-mode-relaxed{--nmc-border:var(--nmc-relaxed-border-dk);--nmc-border-bottom:var(--nmc-relaxed-bottom-dk);}
[data-theme="dark"] .new-mode-rapid{--nmc-border:var(--nmc-rapid-border-dk);--nmc-border-bottom:var(--nmc-rapid-bottom-dk);}

.nmc-icon-wrap{padding:10px;border-radius:16px;margin-bottom:7px;transition:transform .2s;}
.new-mode-card:hover .nmc-icon-wrap{transform:scale(1.1);}
.new-mode-card:active .nmc-icon-wrap{transform:scale(.95);}
.nmc-green-icon{background:#E8F5E9;color:var(--green-icon);}
.nmc-purple-icon{background:#F3E5F5;color:var(--purple);}
[data-theme="dark"] .nmc-green-icon{background:rgba(76,175,80,.18);}
[data-theme="dark"] .nmc-purple-icon{background:rgba(156,39,176,.18);}

.nmc-title{font-family:var(--font-h);font-size:1rem;font-weight:900;letter-spacing:.3px;margin-bottom:3px;}
.nmc-green-title{color:var(--green-deep);}
.nmc-purple-title{color:var(--purple);}
[data-theme="dark"] .nmc-green-title{color:var(--green-icon);}
[data-theme="dark"] .nmc-purple-title{color:var(--purple-lt);}

.nmc-desc{font-size:.6rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.1em;text-align:center;}
.nmc-topic-badge{display:none;margin-bottom:5px;font-family:var(--font-h);font-size:.7rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis;text-align:center;}
.nmc-topic-badge.visible{display:block;}
.new-mode-relaxed .nmc-topic-badge{color:var(--green-deep);}
.new-mode-rapid .nmc-topic-badge{color:var(--purple);}
[data-theme="dark"] .new-mode-relaxed .nmc-topic-badge{color:var(--green-icon);}
[data-theme="dark"] .new-mode-rapid .nmc-topic-badge{color:var(--purple-lt);}

/* Mode card streak label + stats row */
.nmc-streak-label{display:none;align-items:center;justify-content:center;gap:3px;font-size:.72rem;font-weight:800;color:var(--orange);text-align:center;}
.nmc-streak-label.visible{display:flex;}
.nmc-stats-row{gap:6px;flex-wrap:nowrap;margin-top:1px;}
.nmc-stats-row .nmc-desc,.nmc-stats-row .nmc-streak-label{margin:0;}

/* ── RAPID TIMER MODAL ── */
.rapid-modal-backdrop{
  position:fixed;inset:0;z-index:var(--z-rapid-modal);
  background:rgba(15,23,42,.6);backdrop-filter:blur(6px);
  padding:16px;
  opacity:0;pointer-events:none;transition:opacity .22s;
}
.rapid-modal-backdrop.open{opacity:1;pointer-events:auto;}
.rapid-modal{
  background:var(--card);border-radius:24px;padding:24px;width:100%;max-width:360px;
  border:2px solid var(--border);box-shadow:0 24px 64px rgba(0,0,0,.25);
  transform:scale(.92);transition:transform .22s cubic-bezier(.34,1.56,.64,1);
}
.rapid-modal-backdrop.open .rapid-modal{transform:scale(1);}


.rmt-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.rmt-title{display:flex;align-items:center;gap:8px;font-family:var(--font-h);font-size:1.2rem;font-weight:800;color:var(--txt);}
.rmt-title-icon{font-size:1.3rem;}
.rmt-close{
  width:34px;height:34px;border-radius:50%;border:none;background:transparent;
  cursor:pointer;
  color:var(--txt-lt);font-size:1.1rem;transition:background .15s;
}
.rmt-close:hover{background:var(--border);}
.rmt-presets{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px;}
.rmt-preset{
  padding:11px 6px;border-radius:14px;border:2px solid var(--border);
  background:var(--card);font-family:var(--font-h);font-size:.9rem;font-weight:800;
  color:var(--txt-md);cursor:pointer;text-align:center;
  transition:border-color .15s,background .15s,color .15s,box-shadow .15s;
}
[data-theme="dark"] .rmt-preset{background:rgba(255,255,255,.04);}
.rmt-preset:hover{border-color:rgba(156,39,176,.4);}
.rmt-preset.selected{background:var(--purple);color:white;border-color:var(--purple);box-shadow:0 4px 18px rgba(156,39,176,.25);}

.rmt-divider{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.rmt-div-line{flex:1;height:1px;background:var(--border);}
.rmt-div-label{font-family:var(--font-h);font-size:.65rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.15em;white-space:nowrap;}

.rmt-stepper{display:flex;align-items:center;gap:10px;}
.rmt-step-side{flex:1;display:flex;justify-content:flex-end;}
.rmt-step-side:last-child{justify-content:flex-start;gap:8px;}
.rmt-step-btn{
  width:44px;height:44px;border-radius:12px;border:2px solid var(--border);
  background:var(--card);
  cursor:pointer;font-size:1.2rem;font-weight:900;color:var(--txt-md);
  transition:background .15s,transform .15s;
}
[data-theme="dark"] .rmt-step-btn{background:var(--border);border-color:var(--border-dk);}
.rmt-step-btn:hover{background:var(--border);}
.rmt-step-btn:active{transform:translateY(1px);}
.rmt-val-wrap{display:flex;flex-direction:column;align-items:center;min-width:64px;}
.rmt-val{font-family:var(--font-h);font-size:2.8rem;font-weight:900;color:var(--txt);line-height:1;}
.rmt-val-unit{font-family:var(--font-h);font-size:.62rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.12em;margin-top:3px;}
.rmt-play-btn{
  width:52px;height:52px;border-radius:50%;border:none;
  background:var(--purple);color:white;
  cursor:pointer;flex-shrink:0;
  box-shadow:0 4px 16px rgba(156,39,176,.45),0 3px 0 #6a1278;
  transition:filter .15s,transform .15s,box-shadow .15s;
}
.rmt-play-btn svg{display:block;margin-left:3px;}
.rmt-play-btn:hover{filter:brightness(1.1);transform:scale(1.07);box-shadow:0 7px 22px rgba(156,39,176,.55),0 3px 0 #6a1278;}
.rmt-play-btn:active{transform:scale(.95);box-shadow:0 2px 8px rgba(156,39,176,.3);}
.rxm-modal{border-top:3px solid var(--green);}
.rxm-modal .rmt-title{color:var(--green-deep);}
[data-theme="dark"] .rxm-modal .rmt-title{color:var(--green-icon);}
.rxm-opts-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;}
.rxm-opt{width:100%;padding:20px 12px;border-radius:16px;border:2px solid var(--green-dk);background:var(--card);cursor:pointer;text-align:center;transition:border-color .15s,background .15s,box-shadow .15s,transform .12s;}
.rxm-opt:hover{background:var(--green);box-shadow:0 6px 20px rgba(88,204,2,.35);transform:translateY(-2px);}
.rxm-opt:hover .rxm-opt-label,.rxm-opt:hover .rxm-opt-sub{color:white;}
.rxm-opt:active{transform:translateY(0);}
[data-theme="dark"] .rxm-opt{background:var(--card);}
.rxm-opt-label{font-family:var(--font-h);font-size:1.1rem;font-weight:900;color:var(--green-deep);margin-bottom:5px;transition:color .15s;}
[data-theme="dark"] .rxm-opt-label{color:var(--green-icon);}
.rxm-opt-sub{font-size:.68rem;font-weight:700;color:var(--txt-md);transition:color .15s;}
.rxm-hint{font-size:.75rem;font-weight:700;color:var(--txt-md);text-align:center;display:flex;align-items:center;justify-content:center;gap:5px;padding-top:6px;white-space:nowrap;}

/* ── DAILY CHALLENGE CARD ── */
.new-daily-bar{
  width:100%;display:flex;flex-direction:column;gap:8px;flex-shrink:0;min-height:0;
  padding:11px 11px 10px;border-radius:18px;border:none;cursor:pointer;
  background:linear-gradient(140deg,#ff8f0e 0%,#f05200 52%,#c73e00 100%);
  box-shadow:0 6px 22px rgba(195,62,0,.4),0 3px 0 rgba(130,28,0,.38);
  position:relative;overflow:hidden;
  animation:screenFadeIn .45s .32s ease both;
  transition:box-shadow .2s,transform .15s;
}
.new-daily-bar::before{content:'';position:absolute;top:-32px;right:-32px;width:140px;height:140px;background:radial-gradient(circle,rgba(255,255,255,.22) 0%,transparent 65%);pointer-events:none;z-index:0;}
.new-daily-bar::after{content:'';position:absolute;inset:0;background:linear-gradient(112deg,rgba(255,255,255,.11) 0%,transparent 46%);pointer-events:none;z-index:0;}
.new-daily-bar:hover{box-shadow:0 12px 34px rgba(195,62,0,.52),0 3px 0 rgba(130,28,0,.38);transform:translateY(-2px);}
.new-daily-bar:active{transform:translateY(1px);box-shadow:0 3px 8px rgba(195,62,0,.32),0 2px 0 rgba(130,28,0,.32);}
[data-theme="dark"] .new-daily-bar{background:var(--daily-bar-dk);box-shadow:0 6px 20px rgba(95,26,0,.6),0 3px 0 rgba(55,8,0,.5);}

/* Daily card top row: icon · text · leaderboard btn */
.ndb-top{display:flex;align-items:center;gap:8px;position:relative;z-index:1;min-width:0;}
.ndb-icon{width:47px;height:47px;flex-shrink:0;background:rgba(255,255,255,.18);border:1.5px solid rgba(255,255,255,.32);border-radius:8px;box-shadow:inset 0 1px 0 rgba(255,255,255,.28);}
[data-theme="dark"] .ndb-icon{background:rgba(0,0,0,.2);border-color:rgba(255,255,255,.16);}
.ndb-text{flex:1;min-width:0;overflow:hidden;display:flex;flex-direction:column;gap:2px;}
.ndb-topic-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:50px;border:1.5px solid rgba(255,255,255,.30);background:rgba(255,255,255,.17);color:rgba(255,255,255,.92);font-family:var(--font-h);font-size:.57rem;font-weight:800;letter-spacing:.18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0;text-transform:uppercase;}
[data-theme="dark"] .ndb-topic-badge{border-color:rgba(255,255,255,.20);background:rgba(0,0,0,.18);color:rgba(255,255,255,.84);}
.ndb-daily-heading{font-family:var(--font-h);font-size:.78rem;font-weight:800;color:rgba(255,255,255,.72);text-transform:uppercase;letter-spacing:.22em;line-height:1;margin-bottom:3px;}
.ndb-topic-main-row{display:flex;align-items:center;}
.ndb-topic-main{font-family:var(--font-h);font-size:clamp(.85rem,3.2vw,1.05rem);font-weight:900;color:white;letter-spacing:.01em;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:100%;}

/* Leaderboard button */
.ndb-lb-btn{
  flex-shrink:0;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.35);border-radius:12px;
  display:flex;align-items:center;gap:5px;padding:8px 10px 8px 9px;cursor:pointer;
  position:relative;overflow:hidden;
  transition:background .2s,border-color .2s,transform .2s,box-shadow .2s;
}
.ndb-lb-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.18) 0%,transparent 60%);pointer-events:none;}
.ndb-lb-btn:hover{background:rgba(255,255,255,.28);border-color:rgba(255,255,255,.60);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.18);}
.ndb-lb-btn:active{transform:scale(.93);box-shadow:none;}
[data-theme="dark"] .ndb-lb-btn{background:rgba(0,0,0,.22);border-color:rgba(255,255,255,.18);}
[data-theme="dark"] .ndb-lb-btn:hover{background:rgba(0,0,0,.36);border-color:rgba(255,255,255,.32);}

/* Live pulse dot */
.ndb-lb-live-dot{width:6px;height:6px;border-radius:50%;background:#7fff4f;flex-shrink:0;position:relative;}
.ndb-lb-live-dot::before{content:'';position:absolute;inset:0;border-radius:50%;background:#7fff4f;animation:lbLivePulse 1.8s ease-in-out infinite;}

.ndb-lb-icon{color:rgba(255,255,255,.9);}
.ndb-lb-inner{display:flex;flex-direction:column;align-items:center;gap:2px;}
.ndb-lb-label{display:block;font-family:var(--font-h);font-size:.58rem;font-weight:800;color:rgba(255,255,255,.80);letter-spacing:.12em;white-space:nowrap;}
.ndb-lb-arrow{font-size:.85rem;font-weight:900;color:rgba(255,255,255,.65);line-height:1;margin-top:1px;}

/* Daily play row: play + share */
.ndb-btn-row{display:flex;align-items:stretch;gap:8px;position:relative;z-index:1;}
.ndb-btn-row .ndb-btn{flex:1;width:auto;}
.ndb-btn{
  position:relative;z-index:1;width:100%;border:none;
  background:rgba(255,255,255,.97);color:var(--daily-text);
  padding:10px 14px;border-radius:13px;
  font-family:var(--font-h);font-size:.98rem;font-weight:900;cursor:pointer;
  gap:6px;
  box-shadow:0 2px 0 rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,1);
  transition:background .15s,box-shadow .15s,transform .15s;white-space:nowrap;letter-spacing:.06px;
}
.ndb-btn:hover{background:#fff;box-shadow:0 5px 16px rgba(0,0,0,.2);}
.ndb-btn:active{transform:translateY(1px);box-shadow:0 1px 0 rgba(0,0,0,.1);}
.ndb-btn:disabled{opacity:.55;cursor:not-allowed;pointer-events:none;}
[data-theme="dark"] .ndb-btn,
[data-theme="dark"] .ndb-share-btn{background:rgba(255,190,80,.24);color:rgba(255,255,255,.98);border:1.5px solid rgba(255,215,105,.32);box-shadow:0 0 0 1px rgba(255,255,255,.28);}
[data-theme="dark"] .ndb-btn:hover,
[data-theme="dark"] .ndb-share-btn:hover{background:rgba(255,190,80,.36);}
.ndb-share-btn{
  flex-shrink:0;display:none;align-items:center;justify-content:center;
  border:none;border-radius:13px;background:rgba(255,255,255,.97);color:var(--daily-text);
  width:44px;height:auto;min-height:42px;padding:0;cursor:pointer;
  box-shadow:0 2px 0 rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,1);
  transition:background .15s,box-shadow .15s,transform .15s;
}
.ndb-share-btn.visible{display:flex;}
.ndb-share-btn:hover{background:#fff;box-shadow:0 5px 16px rgba(0,0,0,.2);transform:translateY(-1px);}
.ndb-share-btn:active{transform:translateY(1px);box-shadow:0 1px 0 rgba(0,0,0,.1);}

/* Attempt counter badge */
.daily-badge{display:inline-flex;align-items:center;font-size:.64rem;border-radius:50px;padding:3px 8px;font-weight:800;margin-left:2px;letter-spacing:.3px;line-height:1.3;vertical-align:middle;}
.daily-badge:empty{display:none;}
.daily-badge.db-zero,.daily-badge.db-progress,.daily-badge.db-done{color:var(--daily-text);}
.daily-badge.db-zero{background:rgba(192,58,0,.16);}
.daily-badge.db-progress{background:rgba(192,58,0,.22);}
.daily-badge.db-done{background:rgba(192,58,0,.30);}
[data-theme="dark"] .daily-badge.db-zero{background:rgba(255,255,255,.18);color:rgba(255,255,255,.85);}
[data-theme="dark"] .daily-badge.db-progress{background:rgba(255,200,0,.32);color:white;}
[data-theme="dark"] .daily-badge.db-done{background:rgba(255,255,255,.4);color:rgba(255,255,255,.95);}

/* ── STREAK BAR ── */
.new-streak-bar{
  width:100%;display:flex;flex-direction:row;align-items:center;gap:12px;flex-shrink:0;min-height:62px;
  padding:10px 16px 10px 12px;border-radius:32px;
  background:rgba(255,255,255,.82);backdrop-filter:blur(14px);
  border:1.5px solid rgba(255,255,255,.75);box-shadow:0 8px 28px rgba(0,0,0,.08);
  animation:screenFadeIn .45s .42s ease both;margin-top:4px;
}
[data-theme="dark"] .new-streak-bar{background:rgba(22,40,64,.95);border-color:rgba(255,255,255,.09);}

.nsb-flame-wrap{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.nsb-flame-box{position:relative;width:40px;height:40px;background:rgba(255,150,0,.10);border-radius:12px;flex-shrink:0;}
.nsb-flame-ring{position:absolute;inset:0;border-radius:12px;border:2px solid rgba(255,150,0,.30);animation:flameRingPulse 2s ease-in-out infinite;}

.nsb-flame-icon{font-size:1.35rem;position:relative;z-index:1;animation:flamePop 1.5s ease-in-out infinite;}

.nsb-days-info{display:flex;flex-direction:column;line-height:1;}
.nsb-days-num{font-family:var(--font-h);font-size:1.5rem;font-weight:900;background:linear-gradient(135deg,var(--orange),#FFB366);background-clip:text;-webkit-background-clip:text;color:transparent;line-height:1;letter-spacing:-.5px;}
.nsb-days-unit{font-size:.56rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.12em;margin-top:1px;}

.nsb-divider{width:1px;height:40px;background:rgba(0,0,0,.08);flex-shrink:0;}
[data-theme="dark"] .nsb-divider{background:rgba(255,255,255,.08);}

/* Day squares */
.nsb-week{flex:1;display:flex;justify-content:space-between;align-items:center;gap:2px;}
.nsb-day{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;max-width:38px;}
.nsb-day-sq{width:100%;aspect-ratio:1;border-radius:10px;border:1.5px solid #d1d5db;font-size:1.15rem;background:#e9ebee;}
[data-theme="dark"] .nsb-day-sq{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.12);}

/* Day square states */
.nsb-day-sq.today{background:rgba(255,90,0,.08);box-shadow:0 0 8px rgba(255,90,0,.10);}
.nsb-day-sq.today .flame-icon{animation:infernoToday 1.6s ease-in-out infinite;}

.nsb-day-sq.today.blaze-once .flame-icon{animation:fireBlazeOnce 1.8s cubic-bezier(.34,1.56,.64,1) forwards,infernoToday 1.6s 1.8s ease-in-out infinite;}
.nsb-day-sq.played{background:rgba(255,110,0,.05);}
.nsb-day-sq.played .flame-icon{filter:drop-shadow(0 0 1px rgba(255,90,0,.4));}
.nsb-day-sq.missed{background:rgba(0,0,0,.03);}
.nsb-day-sq.missed .flame-icon{filter:grayscale(1) opacity(.38);}
[data-theme="dark"] .nsb-day-sq.missed .flame-icon{filter:grayscale(1) opacity(.22);}
[data-theme="dark"] .nsb-day-sq.missed{background:rgba(255,255,255,.03);}
.nsb-day-sq.future{opacity:.8;}
.nsb-day-sq.today-pending{background:rgba(255,90,0,.04);box-shadow:0 0 0 1.5px rgba(255,90,0,.25);animation:todayPendingPulse 2.2s ease-in-out infinite;}

.nsb-day-lbl{font-size:.52rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.05em;}
.nsb-day.is-today .nsb-day-lbl{color:var(--orange);animation:dayLblPulse 2s infinite;}

/* ── GAME SCREEN ── */
#game-screen{display:none;flex-direction:column;align-items:center;padding:0;height:100dvh;max-height:100dvh;overflow:hidden;position:relative;z-index:1;width:100%;contain:layout style;}
#game-screen.active{display:flex;animation:screenFadeIn .3s ease both;}

.game-header{width:100%;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-bottom:14px;gap:6px;padding:max(18px,env(safe-area-inset-top,18px)) 12px 0;flex-shrink:0;}
.gc-top-left,.gc-top-right{display:flex;gap:7px;align-items:center;}
.gc-top-right{justify-content:flex-end;}
.gc-btn{width:36px;height:36px;border-radius:12px;border:none;cursor:pointer;background:transparent;transition:transform .15s,opacity .15s,background .15s;}
.gc-btn svg{width:20px;height:20px;flex-shrink:0;}
.gc-btn:hover{opacity:.75;}
.gc-btn:active{transform:scale(.9);}
.gc-home{color:#2A5FD0;}
.gc-pause{color:var(--orange-dk);}
.gc-end{color:var(--red);border:1.5px solid rgba(255,75,75,.35);}

/* Stat pills */
.stat-pill{display:flex;align-items:center;gap:5px;border-radius:50px;padding:5px 11px;white-space:nowrap;}
.streak-pill{background:var(--yellow-lt);border:2px solid var(--yellow);transition:background .3s,border-color .3s,transform .3s,box-shadow .3s;}
.pill-val{font-family:var(--font-h);font-size:.95rem;font-weight:800;color:var(--green-dk);}
.streak-pill .pill-val{color:var(--yellow-dk);}

/* Electric streak state */
.streak-pill.electric{background:linear-gradient(135deg,#00cfff,#0070ff);border-color:#00cfff;transform:scale(1.1);box-shadow:0 0 10px rgba(0,207,255,.55),0 0 22px rgba(0,120,255,.35);}
.streak-pill.electric .pill-val{color:#ffffff;text-shadow:0 0 8px rgba(0,210,255,.9);}
.streak-pill.electric svg{color:#ffffff!important;filter:drop-shadow(0 0 4px rgba(0,220,255,.9));}
.streak-pill.electric-pulse{animation:streakElectricPulse .55s cubic-bezier(.34,1.56,.64,1);}

/* Timer pill */
.timer-pill{background:var(--orange);border-radius:50px;padding:5px 14px;box-shadow:0 3px 0 #cc7800;min-width:72px;}
.timer-pill.warning{background:var(--red);box-shadow:0 3px 0 var(--red-dk);animation:throb .7s infinite;}

.timer-val{font-family:var(--font-h);font-size:1.2rem;font-weight:800;color:white;min-width:44px;text-align:center;}

/* Progress / spacer bar */
.progress-wrap{width:calc(100% - 24px);height:10px;background:rgba(0,0,0,.22);border-radius:10px;margin:0 12px 8px;overflow:hidden;flex-shrink:0;border:1px solid rgba(0,0,0,.10);}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--green),#8AE700);border-radius:10px;transition:width .5s ease;width:0%;}
[data-theme="dark"] .progress-wrap{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.10);}
.relaxed-spacer{width:calc(100% - 24px);height:8px;border-radius:10px;margin:0 12px 7px;background:var(--green-lt);opacity:.4;flex-shrink:0;}

/* Column headers */
.col-headers{width:calc(100% - 24px);margin:0 12px 7px;display:grid;grid-template-columns:1fr 1fr;gap:8px;flex-shrink:0;}
.col-hdr{text-align:center;font-family:var(--font-h);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--txt-lt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;}

/* Board */
#board-wrap{position:relative;width:calc(100% - 24px);margin:0 12px;flex:1;min-height:0;padding-bottom:10px;}
#board-grid{width:100%;height:100%;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:repeat(5,1fr);gap:18px;}

/* Match cards */
.match-card{
  background:var(--card);border:2.5px solid var(--border);box-shadow:0 4px 0 var(--border-dk);
  border-radius:14px;padding:14px 16px;cursor:pointer;
  text-align:center;font-family:inherit;-webkit-appearance:none;appearance:none;
  min-height:0;height:100%;user-select:none;overflow:hidden;
  will-change:transform;contain:layout style;touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  transition:border-color .15s,box-shadow .15s,transform .15s,background .15s;
}
.match-card.ghost{visibility:hidden;pointer-events:none;}
.match-card.selected{border-color:var(--blue);box-shadow:0 5px 0 var(--blue-dk);background:var(--blue-lt);color:var(--blue-dk);transform:translateY(-2px);}
#board-wrap .match-card.deselecting,#board-wrap .match-card.deselecting:hover{border-color:var(--border);box-shadow:0 4px 0 var(--border-dk);background:var(--card);transform:none;color:var(--txt);transition:none;}

#board-wrap .match-card.correct{border-color:var(--green);box-shadow:0 0 0 0 rgba(88,204,2,.5);background:var(--green-lt);color:var(--green-dk);pointer-events:none;animation:correctPop .5s cubic-bezier(.34,1.56,.64,1) forwards,correctFade .32s ease .62s forwards;}

#board-wrap .match-card.wrong{border-color:var(--red);box-shadow:0 4px 0 var(--red-dk);background:var(--red-lt);color:var(--red-dk);animation:wrongShake .5s cubic-bezier(.36,.07,.19,.97);}

.card-in{animation:cardIn .32s cubic-bezier(.34,1.56,.64,1);}

.card-art-num{display:block;font-family:var(--font-h);font-size:1.12rem;font-weight:800;color:var(--green-dk);line-height:1.25;}
.match-card.selected .card-art-num{color:var(--blue-dk);}
.match-card.wrong .card-art-num{color:var(--red-dk);}
.card-kw{font-size:.88rem;font-weight:700;color:var(--txt);line-height:1.35;}

/* Hint glow */
#board-wrap .hint-glow{border-color:var(--yellow);background:var(--yellow-lt);animation:hintPulse .6s ease infinite alternate;}

/* Pause overlay */
.pause-overlay{position:absolute;inset:0;z-index:var(--z-pause);border-radius:14px;background:rgba(0,0,0,.08);pointer-events:none;display:none;flex-direction:column;align-items:center;justify-content:center;gap:18px;backdrop-filter:blur(3px);}
.pause-overlay.show{display:flex;pointer-events:auto;}
.pause-badge{background:var(--green);color:white;border-radius:50px;padding:12px 32px;font-family:var(--font-h);font-size:1.3rem;font-weight:800;box-shadow:0 5px 0 var(--green-dk);}

/* Keyboard shortcuts panel */
.kb-shortcuts{display:none;background:rgba(255,255,255,.92);border-radius:16px;padding:14px 20px;border:1.5px solid rgba(0,0,0,.07);box-shadow:0 4px 18px rgba(0,0,0,.12);max-width:260px;width:90%;}
@media(hover:hover) and (pointer:fine){
  .match-card:hover:not(.selected):not(.correct):not(.wrong):not(.ghost){border-color:var(--blue);box-shadow:0 4px 0 var(--blue-dk);background:var(--blue-lt);transform:translateY(-2px);}
  .kb-shortcuts{display:block;}
}
[data-theme="dark"] .kb-shortcuts{background:rgba(31,41,55,.96);border-color:rgba(255,255,255,.1);}
.kb-title{font-family:var(--font-h);font-size:.72rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.14em;margin-bottom:10px;text-align:center;}
.kb-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 12px;align-items:center;}
/* Shared keyboard key styles (game pause panel + HTP screen) */
.kb-key,.htp-key{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-h);font-weight:800;background:var(--bg);border:1.5px solid var(--border-dk);border-bottom-width:3px;white-space:nowrap;color:var(--txt);letter-spacing:.04em;}
.kb-key{font-size:.72rem;border-radius:7px;padding:3px 8px;}
.kb-desc{font-size:.73rem;font-weight:700;color:var(--txt-md);}

/* End-game confirm */
.end-confirm-overlay{position:absolute;inset:0;z-index:var(--z-end-confirm);border-radius:14px;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:20px;}
.end-confirm-overlay.show{display:flex;}
.end-confirm-box{background:var(--card);border-radius:20px;padding:24px 22px 20px;text-align:center;width:100%;max-width:280px;box-shadow:0 8px 32px rgba(0,0,0,.28);border:1.5px solid var(--border);animation:rsCardIn .25s cubic-bezier(.34,1.56,.64,1);}
.end-confirm-icon{font-size:1.6rem;margin-bottom:8px;color:var(--red);}
.end-confirm-title{font-family:var(--font-h);font-size:1.1rem;font-weight:900;color:var(--txt);margin-bottom:6px;}
.end-confirm-sub{font-size:.78rem;color:var(--txt-md);line-height:1.5;margin-bottom:18px;}
.end-confirm-btns{display:flex;gap:10px;}
.end-confirm-cancel,.end-confirm-yes{flex:1;padding:11px;border-radius:12px;font-family:var(--font-h);font-size:.88rem;font-weight:800;cursor:pointer;}
.end-confirm-cancel{border:2px solid var(--border);border-bottom-width:4px;background:var(--card);color:var(--txt-md);transition:background .15s,transform .1s;}
.end-confirm-cancel:hover{background:var(--bg);}
.end-confirm-yes{border:2px solid var(--red-dk);border-bottom-width:4px;background:var(--red);color:white;box-shadow:0 4px 0 var(--red-dk);transition:filter .15s,transform .1s;}
.end-confirm-yes:hover{filter:brightness(1.08);}
.end-confirm-cancel:active,.end-confirm-yes:active{transform:translateY(2px);border-bottom-width:2px;}
.end-confirm-yes:active{box-shadow:none;}

/* Hint button */
.gc-hint{position:relative;width:42px;height:42px;flex-shrink:0;border-radius:50%;border:none;background:linear-gradient(145deg,#FFE566,#FFC107);box-shadow:0 3px 0 rgba(160,100,0,.38),0 0 14px rgba(255,210,0,.22);cursor:pointer;color:#7a4f00;transition:transform .18s,box-shadow .18s;}
.gc-hint:hover{transform:translateY(-2px);box-shadow:0 5px 0 rgba(160,100,0,.38),0 0 24px rgba(255,210,0,.45);}
.gc-hint:active{transform:translateY(2px);box-shadow:0 1px 0 rgba(160,100,0,.38),0 0 6px rgba(255,210,0,.2);}
.gc-hint:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none;}
[data-theme="dark"] .gc-hint{box-shadow:0 3px 0 rgba(160,100,0,.5),0 0 18px rgba(255,210,0,.3);}
.hint-count-badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 3px;border-radius:50px;background:#7a4f00;color:#fff;font-size:.6rem;font-weight:900;font-family:var(--font-h);box-shadow:0 1px 4px rgba(0,0,0,.22);line-height:1;}

/* ── TOAST ── */
.toast{position:fixed;top:14px;left:50%;transform:translateX(-50%) translateY(-80px);padding:10px 24px;border-radius:50px;font-family:var(--font-h);font-size:.92rem;font-weight:700;color:white;z-index:var(--z-toast);pointer-events:none;transition:transform .28s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;box-shadow:0 4px 20px rgba(0,0,0,.18);background:var(--red);}
.toast.show{transform:translateX(-50%) translateY(0);}
.toast.green{background:var(--green);}

/* ── ADD TO HOME SCREEN BANNER ── */
.a2hs-banner{
  position:fixed;left:14px;right:14px;bottom:max(16px,env(safe-area-inset-bottom,16px));max-width:420px;margin:0 auto;
  z-index:var(--z-toast);display:flex;align-items:center;gap:10px;
  padding:13px 38px 13px 13px;border-radius:20px;
  background:var(--card);box-shadow:0 10px 35px rgba(0,0,0,.2);
  border:1.5px solid var(--border);
  transform:translateY(150%);opacity:0;pointer-events:none;
  transition:transform .32s cubic-bezier(.34,1.56,.64,1),opacity .32s;
}
.a2hs-banner.show{transform:translateY(0);opacity:1;pointer-events:auto;}
[data-theme="dark"] .a2hs-banner{background:var(--nmc-card-bg);border-color:var(--border-dk);}
.a2hs-close{position:absolute;top:9px;right:9px;width:20px;height:20px;border:none;background:none;color:var(--txt-lt);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;}
.a2hs-close:hover{color:var(--txt-md);}
.a2hs-icon{flex-shrink:0;width:42px;height:42px;border-radius:12px;background:var(--blue-lt);color:var(--blue-dk);display:flex;align-items:center;justify-content:center;}
[data-theme="dark"] .a2hs-icon{background:rgba(28,176,246,.18);}
.a2hs-body{flex:1;min-width:0;}
.a2hs-title{font-family:var(--font-h);font-size:.86rem;font-weight:800;color:var(--txt);margin-bottom:2px;}
.a2hs-sub{font-size:.74rem;font-weight:600;color:var(--txt-md);line-height:1.3;}
.a2hs-sub .a2hs-share-ico{display:inline-flex;vertical-align:-3px;margin:0 1px;color:var(--blue-dk);}
.a2hs-install-btn{flex-shrink:0;font-family:var(--font-h);font-size:.78rem;font-weight:800;color:white;background:var(--blue);border:none;border-radius:50px;padding:8px 14px;cursor:pointer;box-shadow:0 2px 0 var(--blue-dk);white-space:nowrap;}
.a2hs-install-btn:active{transform:translateY(1px);box-shadow:none;}

/* Drawer manual install row (hidden unless installable) */
.a2hs-drawer-row{display:none;padding:0 14px 14px;flex-shrink:0;}
.a2hs-drawer-row.visible{display:block;}
.a2hs-drawer-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:7px;font-family:var(--font-h);font-size:.78rem;font-weight:800;color:var(--blue-dk);background:var(--blue-lt);border:1.5px solid var(--blue);border-radius:12px;padding:10px;cursor:pointer;}
[data-theme="dark"] .a2hs-drawer-btn{background:rgba(28,176,246,.14);color:var(--blue);}

/* ── XP FLOATER ── */
.xp-pop{position:fixed;pointer-events:none;font-size:1.1rem;font-weight:900;font-family:var(--font-h);color:var(--yellow);text-shadow:0 2px 6px rgba(0,0,0,.25);z-index:var(--z-drawer);animation:xpRise .9s ease forwards;}

/* ── RESULTS SCREEN ── */
#results-screen{display:none;flex-direction:column;align-items:center;position:relative;z-index:1;width:100%;max-width:100%;padding:0;background:var(--bg);height:100dvh;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;overscroll-behavior:contain;contain:layout style;}
#results-screen::-webkit-scrollbar{display:none;}
#results-screen.active{display:flex;animation:screenFadeIn .32s ease both;}

.res-app{width:100%;max-width:448px;min-height:100%;display:flex;flex-direction:column;border-left:1px solid var(--border);border-right:1px solid var(--border);position:relative;background:var(--bg);}

/* Results topbar */
.res-topbar{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:10px 16px;}
.res-icon-btn{background:var(--card);border:2px solid var(--border);border-radius:14px;width:42px;height:42px;cursor:pointer;font-size:1.05rem;box-shadow:var(--shadow);color:var(--txt-md);font-family:var(--font);transition:border-color .18s,transform .18s,box-shadow .18s;}
.res-icon-btn:hover{border-color:var(--blue);transform:translateY(-1px);}
.res-icon-btn:active{transform:translateY(1px);}
.res-icon-btn svg{width:17px;height:17px;display:block;}

/* Results main */
.res-main{display:flex;flex-direction:column;padding:24px 24px 48px;gap:28px;position:relative;z-index:1;}

/* Entrance stagger */
.res-stagger{opacity:0;transform:translateY(20px);}
.res-stagger.show{animation:rsSlideUp .5s cubic-bezier(.34,1.56,.64,1) forwards;}
.res-stagger:nth-child(1){animation-delay:.10s;}
.res-stagger:nth-child(2){animation-delay:.20s;}
.res-stagger:nth-child(3){animation-delay:.30s;}
.res-stagger:nth-child(4){animation-delay:.40s;}
.res-stagger:nth-child(5){animation-delay:.50s;}

/* Results header */
.res-header{text-align:center;margin:-8px 0;display:flex;flex-direction:column;align-items:center;gap:2px;}
.res-mode-subtitle{color:var(--txt-md);font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:.1em;}

/* Score card */
.res-score-card{background:var(--card);border-radius:24px;border:2px solid var(--border);padding:24px;box-shadow:0 4px 0 0 var(--border);transition:background .3s,border-color .3s;}
.res-score-inner{display:flex;flex-direction:column;align-items:center;text-align:center;}
.res-score-label-top{font-size:11px;font-weight:700;color:var(--txt-md);text-transform:uppercase;letter-spacing:.2em;margin-bottom:4px;}
.rs-final-num{font-size:60px;font-weight:900;color:var(--blue);margin-bottom:24px;font-family:var(--font-h);line-height:1;}

/* Score bars */
.res-bars{width:100%;display:flex;flex-direction:column;gap:20px;}
.res-bar-row{display:flex;flex-direction:column;gap:6px;}
.res-bar-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2px;}
.res-bar-lbl{font-size:13px;font-weight:700;color:var(--txt);display:flex;align-items:center;gap:8px;}
.res-bar-lbl svg{width:16px;height:16px;display:block;flex-shrink:0;}
.res-bar-value{font-size:13px;font-weight:900;}
.res-bar-value.orange{color:var(--orange);}
.res-bar-value.blue{color:var(--blue);}
.res-bar-track{height:16px;background:var(--border);border-radius:999px;overflow:hidden;padding:3px;}
.res-bar-fill{height:100%;border-radius:999px;position:relative;width:0;transition:width 1s ease;}
.res-bar-fill::after{content:'';position:absolute;top:0;left:0;width:100%;height:30%;background:rgba(255,255,255,.2);border-radius:999px;}
.res-bar-fill.orange{background:var(--orange);}
.res-bar-fill.blue{background:linear-gradient(90deg,#B00000 0%,#DD2200 22%,#FF6000 40%,#FFB300 56%,#C8E000 70%,var(--green) 100%);}

/* Mini stat cards */
.res-mini-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.res-stat-card{background:var(--card);border-radius:16px;border:2px solid var(--border);padding:12px 6px;box-shadow:0 4px 0 0 var(--border);display:flex;flex-direction:column;align-items:center;gap:3px;transition:background .3s,border-color .3s;}
.res-stat-icon{padding:8px;border-radius:12px;margin-bottom:3px;}
.res-stat-icon svg{width:20px;height:20px;display:block;}
.res-stat-icon.green{color:var(--green);background:rgba(88,204,2,.1);}
.res-stat-icon.red{color:var(--red);background:rgba(255,75,75,.1);}
.res-stat-icon.orange{color:var(--orange);background:rgba(255,150,0,.1);}
.res-stat-icon.blue{color:var(--blue);background:rgba(28,176,246,.1);}
.res-stat-val{font-size:18px;font-weight:900;color:var(--txt);line-height:1;font-family:var(--font-h);}
.res-stat-lbl{font-size:9px;font-weight:700;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.1em;}

/* Dark mode: results cards get a deeper drop shadow */
[data-theme="dark"] .res-score-card,
[data-theme="dark"] .res-stat-card,
[data-theme="dark"] .res-breakdown-toggle,
[data-theme="dark"] .res-breakdown-inner{box-shadow:0 4px 0 0 var(--shadow-deep);}

/* Breakdown accordion */
.res-breakdown-section{display:flex;flex-direction:column;gap:8px;}
.res-breakdown-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--card);border:2px solid var(--border);border-radius:16px;box-shadow:0 4px 0 0 var(--border);cursor:pointer;font-family:inherit;transition:background .15s,border-color .3s,box-shadow .3s;}
.res-breakdown-toggle:hover{background:var(--bg);}
.res-breakdown-toggle:active{transform:translateY(1px);box-shadow:none;}
.res-bd-toggle-left{display:flex;align-items:center;gap:12px;}
.res-bd-toggle-left svg{width:20px;height:20px;color:var(--txt-md);display:block;}
.res-bd-toggle-label{font-size:12px;font-weight:900;color:var(--txt);text-transform:uppercase;letter-spacing:.1em;}
.res-chevron{width:20px;height:20px;color:var(--txt-lt);transition:transform .25s ease;display:block;flex-shrink:0;}
.res-chevron.open{transform:rotate(180deg);}

.score-breakdown-card{overflow:hidden;max-height:0;opacity:0;transition:max-height .42s cubic-bezier(.4,0,.2,1),opacity .28s ease;}
.score-breakdown-card.open{opacity:1;}
.res-breakdown-inner{background:var(--bg);border:2px solid var(--border);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:14px;box-shadow:0 4px 0 0 var(--border);margin-top:8px;transition:background .3s,border-color .3s;}

.res-bd-row{display:flex;align-items:center;justify-content:space-between;}
.res-bd-row-left{display:flex;align-items:center;gap:12px;}
.res-bd-icon{background:var(--card);padding:8px;border-radius:8px;border:1px solid var(--border);box-shadow:0 1px 3px rgba(0,0,0,.05);display:flex;transition:background .3s,border-color .3s;}
.res-bd-icon svg{width:16px;height:16px;display:block;}
.res-bd-icon-orange{color:var(--orange);}
.res-bd-row-label{font-size:11px;font-weight:700;color:var(--txt-md);text-transform:uppercase;letter-spacing:.08em;}
.res-bd-row-val{font-size:15px;font-weight:900;color:var(--txt);}
.res-bd-row-val.pos{color:var(--green-dk);}
.res-bd-row-val.neg{color:var(--red-dk);}
.res-bd-row-val.bonus{color:var(--purple);}
.res-bd-row-val.time-color{color:var(--blue-dk);}
.res-bd-total{padding-top:12px;margin-top:4px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.res-bd-total-label{font-size:14px;font-weight:900;color:var(--txt);text-transform:uppercase;letter-spacing:.1em;}
.res-bd-total-val{font-size:20px;font-weight:900;color:var(--green-dk);font-family:var(--font-h);}
.res-bd-total-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px;}

/* ── SCORECARD MODAL ── */
.scorecard-backdrop{position:fixed;inset:0;z-index:var(--z-modal);background:rgba(0,0,0,.82);backdrop-filter:blur(14px);padding:16px;opacity:0;pointer-events:none;transition:opacity .25s,background .3s;}
.scorecard-backdrop.open{opacity:1;pointer-events:auto;}
.scorecard-backdrop:has(.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid)){background:rgba(8,12,24,.92);backdrop-filter:blur(22px) saturate(1.2);}
.scorecard-shell{width:100%;max-width:360px;transform:scale(.88) translateY(12px);transition:transform .3s cubic-bezier(.34,1.56,.64,1);}
.scorecard-backdrop.open .scorecard-shell{transform:scale(1) translateY(0);}

/* Scorecard card */
.sc-card{border-radius:24px;overflow:hidden;box-shadow:0 28px 72px rgba(0,0,0,.45);position:relative;}

/* ══ SCORECARD MODE VARIABLES ═══════════════════════════════════════
   Each mode declares its palette once; consolidated child rules below
   inherit via var(). Adding a new mode only needs a new variable block.
   ═══════════════════════════════════════════════════════════ */
.sc-card.sc-daily{
  --sc-tag-color:rgba(255,200,80,.8);--sc-tag-border:rgba(255,200,80,.3);
  --sc-bt-bg:rgba(255,200,0,.06);--sc-bt-border:rgba(255,200,0,.12);
  --sc-link-color:rgba(255,200,100,.4);--sc-name-color:rgba(255,200,80,.85);
  --sc-logo-color:white;--sc-day-bg:var(--yellow);
  --sc-daynum-color:#111118;--sc-daylbl-color:rgba(17,17,24,.55);
  --sc-bar-color:var(--yellow);
  --sc-sp-bg:rgba(28,176,246,.1);--sc-sp-border:rgba(28,176,246,.22);
  --sc-sp-num:var(--blue);--sc-sp-unit:rgba(28,176,246,.6);
  --sc-ch-bg:rgba(255,200,0,.09);--sc-ch-border:rgba(255,200,0,.2);--sc-chal-main:var(--yellow);
  --sc-str-bg:rgba(255,150,0,.1);--sc-str-border:rgba(255,150,0,.2);
  --sc-str-num:var(--orange);--sc-str-lbl:rgba(255,150,0,.6);
  --sc-inf-color:var(--orange);
  border:1.5px solid rgba(255,200,0,.55);
  box-shadow:0 0 0 1px rgba(255,200,0,.12),0 0 28px rgba(255,200,0,.18),0 28px 72px rgba(0,0,0,.55);
  background:#111118;
}
.sc-card.sc-relaxed{
  --sc-tag-color:rgba(88,204,2,.85);--sc-tag-border:rgba(88,204,2,.3);
  --sc-bt-bg:rgba(88,204,2,.06);--sc-bt-border:rgba(88,204,2,.12);
  --sc-link-color:rgba(100,200,80,.4);--sc-name-color:rgba(88,204,2,.9);
  --sc-logo-color:var(--green);--sc-day-bg:var(--green-deep);
  --sc-daynum-color:#fff;--sc-daylbl-color:rgba(255,255,255,.6);
  --sc-bar-color:var(--green);
  --sc-sp-bg:rgba(88,204,2,.1);--sc-sp-border:rgba(88,204,2,.25);
  --sc-sp-num:var(--green);--sc-sp-unit:rgba(88,204,2,.6);
  --sc-ch-bg:rgba(88,204,2,.09);--sc-ch-border:rgba(88,204,2,.2);--sc-chal-main:var(--green);
  --sc-str-bg:rgba(88,204,2,.1);--sc-str-border:rgba(88,204,2,.2);
  --sc-str-num:var(--green);--sc-str-lbl:rgba(88,204,2,.6);
  --sc-inf-color:var(--green);
  border:1.5px solid rgba(88,204,2,.55);
  box-shadow:0 0 0 1px rgba(88,204,2,.12),0 0 28px rgba(88,204,2,.18),0 28px 72px rgba(0,0,0,.55);
  background:#061508;
}
.sc-card.sc-rapid{
  --sc-tag-color:rgba(206,130,255,.85);--sc-tag-border:rgba(206,130,255,.3);
  --sc-bt-bg:rgba(156,39,176,.06);--sc-bt-border:rgba(156,39,176,.12);
  --sc-link-color:rgba(180,120,255,.4);--sc-name-color:rgba(206,130,255,.9);
  --sc-logo-color:var(--purple-lt);--sc-day-bg:var(--purple);
  --sc-daynum-color:#fff;--sc-daylbl-color:rgba(255,255,255,.6);
  --sc-bar-color:var(--purple-lt);
  --sc-sp-bg:rgba(156,39,176,.12);--sc-sp-border:rgba(206,130,255,.28);
  --sc-sp-num:var(--purple-lt);--sc-sp-unit:rgba(206,130,255,.6);
  --sc-ch-bg:rgba(156,39,176,.1);--sc-ch-border:rgba(206,130,255,.2);--sc-chal-main:var(--purple-lt);
  --sc-str-bg:rgba(156,39,176,.12);--sc-str-border:rgba(206,130,255,.2);
  --sc-str-num:var(--purple-lt);--sc-str-lbl:rgba(206,130,255,.6);
  --sc-inf-color:var(--purple-lt);
  border:1.5px solid rgba(206,130,255,.6);
  box-shadow:0 0 0 1px rgba(206,130,255,.15),0 0 28px rgba(206,130,255,.22),0 28px 72px rgba(0,0,0,.55);
  background:#0E0520;
}

/* Scanline overlay — shared structural rules (unchanged) */
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid)::before{content:'';position:absolute;top:0;left:0;right:0;height:200px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.025) 0px,rgba(255,255,255,.025) 1px,transparent 1px,transparent 28px);pointer-events:none;z-index:0;}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-top{position:relative;z-index:1;}

/* Scorecard player name (base rule unchanged) */
.sc-player-name{font-family:var(--font-h);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;text-align:right;margin:0;}
.sc-player-name:empty{display:none;}

/* ── Consolidated child styles (all inherit mode vars above) ── */
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-brand-tag{color:var(--sc-tag-color);border-color:var(--sc-tag-border);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-bottom{background:var(--sc-bt-bg);border-top:1px solid var(--sc-bt-border);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) :is(.sc-url,.sc-tag){color:var(--sc-link-color);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-player-name{color:var(--sc-name-color);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-brand-logo{color:var(--sc-logo-color);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-day{background:var(--sc-day-bg);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-daynum{color:var(--sc-daynum-color);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-daylbl{color:var(--sc-daylbl-color);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-scorelbl{color:rgba(255,255,255,.38);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-bar-fill{background:var(--sc-bar-color);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-speed{background:var(--sc-sp-bg);border-color:var(--sc-sp-border);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-speed-num{color:var(--sc-sp-num);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-speed-unit{color:var(--sc-sp-unit);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-challenge{background:var(--sc-ch-bg);border-color:var(--sc-ch-border);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-chal-main{color:var(--sc-chal-main);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-chal-sub{color:rgba(255,255,255,.35);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-streak-half{background:var(--sc-str-bg);border:1px solid var(--sc-str-border);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-streak-half-num{color:var(--sc-str-num);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-streak-half-lbl{color:var(--sc-str-lbl);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-streak-bolt{color:var(--sc-str-num);}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-inferno-num{color:var(--sc-inf-color);}
.sc-da-inferno-badge{display:none;align-items:center;gap:4px;}
.sc-card:is(.sc-daily,.sc-relaxed,.sc-rapid) .sc-da-inferno-badge{display:flex;}
.sc-da-inferno-icon{font-size:15px;line-height:1;}
.sc-da-inferno-num{font-family:var(--font-h);font-size:15px;font-weight:800;color:rgba(255,255,255,.75);line-height:1;}

/* MPS bar fill */
#sc-da-mps-fill{background:linear-gradient(90deg,var(--orange),#FFB800);}

/* Dark Arena structural elements */
.sc-da-block{display:flex;align-items:flex-end;gap:14px;margin-bottom:16px;}
.sc-da-day{border-radius:12px;padding:7px 16px;text-align:center;flex-shrink:0;}
.sc-da-daynum{font-family:var(--font-h);font-size:26px;font-weight:800;line-height:1;}
.sc-da-daylbl{font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-top:1px;}
.sc-da-score-area{flex:1;}
.sc-da-scorenum{font-family:var(--font-h);font-size:44px;font-weight:800;color:#fff;line-height:1;}
.sc-da-scorelbl{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-top:1px;}
.sc-da-bar{margin-bottom:14px;}
.sc-da-bar-hd{display:flex;justify-content:space-between;margin-bottom:5px;}
.sc-da-bar-key{font-size:10px;font-weight:700;color:rgba(255,255,255,.45);}
.sc-da-bar-val{font-size:10px;font-weight:800;color:rgba(255,255,255,.8);}
.sc-da-bar-track{height:7px;background:rgba(255,255,255,.07);border-radius:4px;overflow:hidden;}
.sc-da-bar-fill{height:100%;border-radius:4px;width:0%;transition:width 1.3s cubic-bezier(.22,1,.36,1);}
.sc-da-speed{display:flex;gap:8px;margin-bottom:14px;}
.sc-da-speed-half{flex:1;border-radius:11px;padding:8px 11px;}
.sc-da-streak-half{flex:1;border-radius:11px;padding:8px 11px;}
.sc-da-speed-num{font-family:var(--font-h);font-size:20px;font-weight:800;line-height:1;}
.sc-da-speed-unit{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-top:2px;}
.sc-da-streak-half-top{display:flex;align-items:center;gap:3px;line-height:1;}
.sc-da-streak-half-num{font-family:var(--font-h);font-size:20px;font-weight:800;line-height:1;}
.sc-da-streak-half-lbl{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-top:2px;}
.sc-da-challenge{text-align:center;border-radius:13px;padding:12px 14px;}
.sc-da-chal-main{font-size:13px;font-weight:800;letter-spacing:.3px;}
.sc-da-chal-sub{font-size:10px;margin-top:3px;font-weight:600;}

/* Scorecard structure */
.sc-top{padding:22px 22px 16px;position:relative;}
.sc-brand{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:14px;}
.sc-brand-left{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.sc-brand-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:0;}
.sc-brand-logo{font-family:var(--font-h);font-size:1.5rem;font-weight:800;color:white;letter-spacing:-.5px;}
.sc-brand-tag{font-size:.62rem;font-weight:800;letter-spacing:.15em;color:rgba(255,255,255,.55);text-transform:uppercase;padding:2px 8px;border:1px solid rgba(255,255,255,.2);border-radius:20px;}
.sc-bottom{background:rgba(0,0,0,.28);padding:11px 22px;display:flex;align-items:center;justify-content:space-between;}
.sc-url,.sc-tag{font-size:.65rem;font-weight:700;color:rgba(255,255,255,.5);}
.sc-url{letter-spacing:.05em;}
.sc-actions{display:flex;gap:10px;margin-top:14px;}
.sc-btn{flex:1;padding:13px;border-radius:14px;border:none;cursor:pointer;font-family:var(--font-h);font-size:.9rem;font-weight:800;gap:6px;transition:background .18s,transform .18s,box-shadow .18s;}
.sc-btn-share{background:#25D366;color:white;box-shadow:0 4px 0 #128C7E;}
.sc-btn-share:active{transform:translateY(2px);box-shadow:0 2px 0 #128C7E;}
.sc-btn-copy{background:rgba(255,255,255,.12);color:white;border:1.5px solid rgba(255,255,255,.22);transition:background .15s,border-color .15s;}
.sc-btn-copy:hover{background:rgba(255,255,255,.20);}
.sc-btn-copy.copied{background:rgba(88,204,2,.28);border-color:rgba(88,204,2,.5);}

/* ── RESULTS ACTION BUTTONS ── */
.res-actions{display:flex;flex-direction:column;gap:14px;margin-top:4px;}
.res-secondary-row{display:flex;gap:12px;}
.res-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 16px;font-weight:900;font-family:inherit;border-radius:12px;cursor:pointer;
  width:100%;text-transform:uppercase;letter-spacing:.08em;
  border-style:solid;border-width:2px 2px 4px;
  transition:filter .1s,transform .1s,box-shadow .1s,background .15s;
}
.res-btn:active{transform:translateY(2px);border-bottom-width:2px;}

/* Leaderboard button */
.res-lb-btn{
  width:100%;display:inline-flex;align-items:center;justify-content:center;
  padding:14px 24px;font-weight:900;font-family:inherit;border-radius:12px;cursor:pointer;
  background:linear-gradient(135deg,#1a6b00,#0065aa);color:white;
  border:2px solid transparent;border-bottom:4px solid rgba(0,0,0,.2);
  box-shadow:0 4px 0 rgba(0,0,0,.15);
  transition:filter .1s,transform .1s,box-shadow .1s;
  text-transform:uppercase;letter-spacing:.08em;font-size:14px;
}
.res-lb-btn:hover{filter:brightness(1.1);}
.res-lb-btn:active{transform:translateY(2px);box-shadow:none;}

/* Scorecard button (blue) */
.res-btn-scorecard{background:var(--blue);color:white;border-color:var(--blue-dk);box-shadow:0 4px 0 0 var(--blue-dk);padding:16px;font-size:14px;flex:1;}
.res-btn-scorecard:active{box-shadow:none;}
.res-btn-scorecard:disabled{opacity:.35;cursor:not-allowed;transform:none;border-bottom-width:4px;}

/* Mistakes button (orange outline) */
.res-btn-mistakes{background:var(--card);color:var(--orange);border-color:var(--border);border-bottom-color:var(--border-dk);padding:14px 16px;font-size:12px;flex:1;}
.res-btn-mistakes:hover{background:#fff8f0;}
.res-btn-mistakes.active{background:var(--orange-lt);color:#C85000;border-color:var(--orange);border-bottom-color:#C85000;}
[data-theme="dark"] .res-btn-mistakes{background:var(--card);border-color:var(--border-dk);color:var(--orange-text-dk);}
[data-theme="dark"] .res-btn-mistakes:hover{background:var(--mistakes-hover);}
[data-theme="dark"] .res-btn-mistakes.active{background:var(--mistakes-active);color:var(--orange-text-dk);border-color:var(--mistakes-border);}

/* Practice button (blue outline) */
.res-btn-practice{background:var(--card);color:var(--blue);border-color:var(--border);border-bottom-color:var(--border-dk);padding:14px 16px;font-size:12px;flex:1;}
.res-btn-practice:hover{background:var(--bg);}
.res-btn-practice:disabled{opacity:.35;cursor:not-allowed;transform:none;border-bottom-width:4px;}
.res-btn-practice.no-mistakes{color:var(--green-dk);border-color:var(--green);border-bottom-color:var(--green-dk);}
[data-theme="dark"] .res-btn-practice{background:var(--card);border-color:var(--border-dk);}

/* Play Again button (purple) */
.res-btn-play-again{background:#a560f8;color:white;border-color:#8b44e0;box-shadow:0 4px 0 0 #8b44e0;padding:16px;font-size:14px;flex:1;}
.res-btn-play-again:active{box-shadow:none;}

/* Shared: solid coloured buttons brighten on hover; svg size inside all res-btns */
.res-btn-scorecard:hover,.res-btn-play-again:hover{filter:brightness(1.08);}
.res-btn svg{width:18px;height:18px;display:block;flex-shrink:0;margin-right:8px;}
.res-btn-mistakes svg,.res-btn-practice svg{margin-right:6px;}

/* Mistakes list — JS-measured slide-down */
#mistakes-list{
  max-height:0;overflow:hidden;border-radius:14px;
  border:0px solid var(--border);background:var(--card);box-shadow:none;opacity:0;margin-top:0;
  transition:max-height .42s cubic-bezier(.4,0,.2,1),opacity .3s ease,border-width .25s ease,box-shadow .3s ease,margin-top .3s ease;
}
#mistakes-list.open{opacity:1;border-width:2px;box-shadow:0 2px 8px rgba(0,0,0,.07);margin-top:4px;}
#mistakes-scroll-inner{max-height:min(45dvh,380px);overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--border-dk) transparent;}
#mistakes-scroll-inner::-webkit-scrollbar{width:4px;}
#mistakes-scroll-inner::-webkit-scrollbar-track{background:transparent;}
#mistakes-scroll-inner::-webkit-scrollbar-thumb{background:var(--border-dk);border-radius:4px;}
.mistake-row{padding:11px 14px;border-bottom:1.5px solid var(--border);background:var(--card);}
.mistake-row:last-child{border-bottom:none;}
.m-art{font-family:var(--font-h);font-size:.88rem;font-weight:800;color:var(--txt);margin-bottom:3px;}
.m-correct{font-size:.78rem;color:var(--green-dk);font-weight:700;}
.m-wrong-attempts{font-size:.72rem;color:var(--red-dk);font-weight:700;margin-top:4px;display:flex;flex-wrap:wrap;gap:4px;align-items:center;}
.m-wrong-kw{background:var(--red-lt);color:var(--red-dk);border-radius:5px;padding:1px 6px;font-size:.7rem;font-weight:700;white-space:nowrap;}
[data-theme="dark"] .m-wrong-kw{background:rgba(255,75,75,.18);color:var(--wrong-kw-dk);}
.m-wrong-count{font-size:.67rem;font-weight:800;color:var(--txt-lt);margin-left:1px;white-space:nowrap;}
.no-mistakes{padding:14px;text-align:center;font-weight:700;color:var(--green-dk);background:var(--green-lt);}

.res-feedback-spacer{flex:1;min-height:32px;}
.res-ad-placeholder{min-height:100px;margin-top:8px;}
.res-cta-row{display:flex;gap:12px;}
#xpg-sub-lbl{font-size:.65rem;font-weight:700;color:var(--txt-lt);letter-spacing:.02em;}
#sbc-clamp-note{display:none;font-size:.65rem;font-weight:700;color:var(--txt-lt);letter-spacing:.02em;}
#sbc-row-time{display:none;}
#fb-sent-msg{display:none;}
#xpg-level{font-size:.8rem;letter-spacing:.02em;}
.res-topbar-right{display:flex;gap:8px;}
.xpg-sub-row{display:flex;justify-content:flex-end;margin-top:3px;}

/* ── FEEDBACK FORM ── */
.feedback-card{background:transparent;border-radius:12px;padding:12px 4px 8px;box-shadow:none;border:none;animation:screenFadeIn .4s .4s both;}
.feedback-title{font-family:var(--font-h);font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--txt-lt);display:flex;align-items:center;gap:5px;margin-bottom:8px;opacity:.7;}
.feedback-textarea{width:100%;border:1.5px solid var(--border);border-radius:10px;background:var(--bg);color:var(--txt);font-family:var(--font);font-size:.82rem;padding:9px 11px;resize:vertical;min-height:72px;transition:border-color .18s;outline:none;}
.feedback-textarea:focus{border-color:var(--blue);}
.feedback-send-btn{margin-top:8px;width:100%;padding:10px;border-radius:10px;border:none;background:var(--blue);color:white;font-family:var(--font-h);font-size:.85rem;font-weight:800;cursor:pointer;box-shadow:0 3px 0 var(--blue-dk);transition:filter .15s,transform .15s,box-shadow .15s;gap:6px;}
.feedback-send-btn:hover{filter:brightness(1.08);}
.feedback-send-btn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--blue-dk);}
.feedback-send-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none;filter:none;}
.feedback-sent-msg{text-align:center;font-family:var(--font-h);font-size:.82rem;font-weight:700;color:var(--green-dk);padding:6px 0 2px;}

/* ── INLINE PAGE FOOTER ── */
.page-footer-line{width:100%;text-align:center;font-size:.62rem;color:var(--txt-lt);flex-shrink:0;padding:2px 0 0;line-height:1.6;}
.page-footer-line > div:first-child{font-size:.68rem;color:var(--txt-md);}
.page-footer-line a{color:var(--txt-lt);text-decoration:underline;}
.page-footer-line a:hover{color:var(--green);}
.page-footer-line .footer-page-btn,
.ip-page-footer .footer-page-btn{background:none;border:none;padding:0;cursor:pointer;font-family:var(--font);font-size:inherit;color:var(--txt-lt);text-decoration:underline;transition:color .15s;}
.page-footer-line .footer-page-btn:hover,
.ip-page-footer .footer-page-btn:hover{color:var(--green);}

/* ── LEADERBOARD MODAL ── */
.lb-backdrop{position:fixed;inset:0;z-index:var(--z-modal);background:rgba(15,23,42,.65);backdrop-filter:blur(6px);padding:16px;opacity:0;pointer-events:none;transition:opacity .25s;}
.lb-backdrop.open{opacity:1;pointer-events:auto;}
.lb-modal{background:var(--card);border-radius:24px;padding:0;width:100%;max-width:400px;max-height:88dvh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.3);transform:translateY(18px) scale(.95);transition:transform .3s cubic-bezier(.34,1.56,.64,1);}
.lb-backdrop.open .lb-modal{transform:none;}
.lb-head{background:linear-gradient(135deg,#1a6b00 0%,#0065aa 100%);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.lb-title,.st-title{font-family:var(--font-h);font-size:1.08rem;font-weight:800;color:white;display:flex;align-items:center;gap:8px;}
.lb-head-actions{display:flex;align-items:center;gap:8px;}

/* Shared lb-close + lb-refresh + st-close styles */
.lb-close,.lb-refresh,.st-close{width:32px;height:32px;border-radius:50%;border:none;background:rgba(255,255,255,.2);color:white;cursor:pointer;transition:background .15s;font-size:.95rem;}
.lb-close:hover,.lb-refresh:hover,.st-close:hover{background:rgba(255,255,255,.36);}
.lb-refresh.spinning svg{animation:lbSpin .7s linear infinite;}
.st-close{display:flex;align-items:center;justify-content:center;flex-shrink:0;}

.lb-sub{padding:9px 20px 0;font-family:var(--font-h);font-size:.7rem;font-weight:700;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.8px;flex-shrink:0;}
.lb-list{flex:1;overflow-y:auto;padding:10px 14px 18px;}
.lb-row{display:grid;grid-template-columns:38px 1fr auto;align-items:center;gap:10px;padding:10px 12px;border-radius:13px;margin-bottom:6px;background:var(--bg);border:1.5px solid var(--border);font-family:var(--font-h);}
.lb-row.gold{background:var(--lb-gold-bg);border-color:var(--lb-gold-border);}
.lb-row.silver{background:var(--lb-silver-bg);border-color:var(--lb-silver-border);}
.lb-row.bronze{background:var(--lb-bronze-bg);border-color:var(--lb-bronze-border);}
.lb-row.you{background:var(--blue-lt);border-color:var(--blue);box-shadow:0 0 0 2.5px rgba(28,176,246,.22);}
.lb-row.separator{height:0;padding:0;margin:4px 0 10px;background:transparent;border:none;border-top:2px dashed var(--border);pointer-events:none;}
.lb-rank{font-size:.82rem;font-weight:900;color:var(--txt-lt);text-align:center;line-height:1;}
.lb-row.gold .lb-rank,.lb-row.silver .lb-rank,.lb-row.bronze .lb-rank{font-size:1.05rem;}
.lb-medal{width:18px;height:18px;vertical-align:middle;}
.lb-row.gold .lb-medal{color:var(--lb-gold-border);}
.lb-row.silver .lb-medal{color:var(--lb-silver-border);}
.lb-row.bronze .lb-medal{color:var(--lb-bronze-border);}
.lb-name{font-size:.88rem;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;}
.lb-you-tag{font-size:.62rem;font-weight:700;color:var(--blue-dk);background:rgba(28,176,246,.14);border-radius:50px;padding:1px 6px;margin-left:4px;vertical-align:middle;}
.lb-score-cell{font-size:.88rem;font-weight:900;color:var(--green-dk);white-space:nowrap;}
.lb-row.you .lb-score-cell{color:var(--blue-dk);}
.lb-empty{text-align:center;padding:30px 16px;color:var(--txt-lt);font-family:var(--font-h);font-size:.85rem;line-height:1.6;}
.lb-loading{padding:36px;gap:10px;color:var(--txt-lt);font-family:var(--font-h);font-size:.85rem;}
.lb-spinner{width:18px;height:18px;border:2.5px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:lbSpin .7s linear infinite;flex-shrink:0;}
.lb-error{text-align:center;padding:24px;color:var(--red);font-family:var(--font-h);font-size:.82rem;}

/* ── NAME PROMPT MODAL ── */
.np-backdrop{position:fixed;inset:0;z-index:var(--z-name-modal);background:rgba(15,23,42,.65);backdrop-filter:blur(6px);padding:16px;opacity:0;pointer-events:none;transition:opacity .22s;}
.np-backdrop.open{opacity:1;pointer-events:auto;}
.np-modal{background:var(--card);border-radius:22px;padding:24px;width:100%;max-width:340px;box-shadow:0 20px 60px rgba(0,0,0,.28);transform:scale(.92) translateY(8px);transition:transform .25s cubic-bezier(.34,1.56,.64,1);}
.np-backdrop.open .np-modal{transform:none;}
.np-emoji{display:flex;align-items:center;justify-content:center;color:var(--yellow-dk);margin-bottom:10px;}
.np-title{font-family:var(--font-h);font-size:1rem;font-weight:800;color:var(--txt);margin-bottom:4px;text-align:center;}
.np-sub{font-size:.78rem;color:var(--txt-md);margin-bottom:16px;text-align:center;line-height:1.5;}
.np-input{width:100%;padding:12px 14px;border-radius:13px;border:2px solid var(--border);background:var(--bg);font-family:var(--font-h);font-size:.95rem;font-weight:700;color:var(--txt);outline:none;transition:border-color .15s;display:block;}
.np-input:focus{border-color:var(--blue);}
.np-chars{font-size:.68rem;color:var(--txt-lt);text-align:right;margin-top:4px;font-family:var(--font-h);font-weight:700;}
.np-btns{display:flex;gap:10px;margin-top:14px;}
.np-skip{flex:1;padding:12px;border-radius:13px;border:2px solid var(--border);background:var(--bg);font-family:var(--font-h);font-size:.84rem;font-weight:700;color:var(--txt-md);cursor:pointer;transition:border-color .15s,background .15s,color .15s;}
.np-skip:hover{border-color:var(--border-dk);}
.np-submit{flex:2;padding:12px;border-radius:13px;border:none;background:var(--green);font-family:var(--font-h);font-size:.88rem;font-weight:800;color:white;cursor:pointer;box-shadow:0 3px 0 var(--green-dk);transition:filter .15s,transform .15s,box-shadow .15s;}
.np-submit:hover{filter:brightness(1.06);}
.np-submit:active{transform:translateY(2px);box-shadow:0 1px 0 var(--green-dk);}
.np-submit:disabled{opacity:.55;cursor:not-allowed;}

/* ══════════════════════════════════════════════════
   IN-APP PAGE SCREENS  (About, Privacy, HTP)
   Full-screen overlays — z-index 800
══════════════════════════════════════════════════ */
.inpage-screen{position:fixed;inset:0;z-index:var(--z-inpage);background:var(--bg);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .36s cubic-bezier(.4,0,.2,1);overflow:hidden;}
.inpage-screen.open{transform:translateX(0);}

/* Nav bar */
.ip-nav{width:100%;background:var(--card);border-bottom:2px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:max(0px,env(safe-area-inset-top,0px)) 14px 0;min-height:54px;flex-shrink:0;box-shadow:0 2px 10px rgba(0,0,0,.06);gap:12px;}
.ip-nav-logo{display:flex;align-items:center;}
.ip-nav-name{font-family:var(--font-h);font-size:1.15rem;font-weight:800;color:var(--blue);letter-spacing:-.5px;white-space:nowrap;}
.ip-nav-right{display:flex;gap:4px;align-items:center;flex-shrink:0;}
.ip-nav-link{font-family:var(--font-h);font-size:.74rem;font-weight:700;color:var(--txt-md);padding:5px 8px;border-radius:9px;background:none;border:none;cursor:pointer;transition:background .14s,color .14s;letter-spacing:.05px;white-space:nowrap;}
.ip-nav-link:hover{background:var(--blue-lt);color:var(--blue);}
.ip-nav-link.ip-active{background:var(--blue-lt);color:var(--blue-dk);}
.ip-back-btn{background:var(--bg);border:2px solid var(--border);border-radius:50%;width:34px;height:34px;padding:0;flex-shrink:0;color:var(--txt-lt);cursor:pointer;font-size:1.15rem;line-height:1;font-family:inherit;font-weight:400;transition:border-color .14s,color .14s,background .14s;}
.ip-back-btn:hover{border-color:var(--red);color:var(--red);background:var(--red-lt);}

/* Scrollable content area */
.ip-body{flex:1;overflow-y:auto;padding:32px 16px 64px;display:flex;flex-direction:column;align-items:center;scrollbar-width:thin;scrollbar-color:var(--border) transparent;}
.ip-body::-webkit-scrollbar{width:5px;}
.ip-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px;}
.ip-inner{width:100%;max-width:700px;}

/* Hero banner */
.ip-hero{text-align:center;padding:36px 20px 28px;background:linear-gradient(135deg,#e0f7fa 0%,var(--bg) 55%,#e8f5e9 100%);border-radius:20px;border:2px solid var(--border);margin-bottom:32px;position:relative;overflow:hidden;}
[data-theme="dark"] .ip-hero{background:linear-gradient(135deg,var(--hero-start) 0%,var(--card) 55%,var(--hero-end) 100%);}
.ip-hero-htp{background:linear-gradient(135deg,#e8f5e9 0%,var(--bg) 50%,var(--blue-lt) 100%);}
.ip-hero::before{content:'';position:absolute;top:-50px;right:-50px;width:170px;height:170px;background:radial-gradient(circle,rgba(28,176,246,.13) 0%,transparent 65%);pointer-events:none;}
.ip-hero-title{font-family:var(--font-h);font-size:clamp(1.8rem,8vw,3rem);font-weight:800;color:var(--blue);line-height:1.1;margin-bottom:10px;letter-spacing:-1px;}
.ip-hero-title--privacy{font-size:clamp(1.6rem,6vw,2.4rem);color:var(--txt);}
.ip-hero-title--htp{color:var(--green);}
.ip-hero-sub{font-size:.9rem;font-weight:600;color:var(--txt-md);max-width:440px;margin:0 auto 20px;line-height:1.65;}
.ip-hero-sub--flush{margin-bottom:0;}
.ip-flag-strip{display:flex;height:5px;border-radius:50px;overflow:hidden;width:100px;margin:0 auto;}
.ip-flag-strip .fs-s{flex:1;background:#FF9933;}
.ip-flag-strip .fs-w{flex:1;background:#FFF;border-top:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0;}
.ip-flag-strip .fs-g{flex:1;background:var(--green-deep);}

/* Section blocks */
.ip-section{margin-bottom:24px;}
.ip-section-head{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.ip-section-icon{width:38px;height:38px;border-radius:11px;flex-shrink:0;font-size:1.1rem;box-shadow:0 3px 0 rgba(0,0,0,.08);}
.ip-section-title{font-family:var(--font-h);font-size:1.1rem;font-weight:800;color:var(--txt);letter-spacing:-.1px;}

/* Content card */
.ip-card{background:var(--card);border:2px solid var(--border);border-radius:16px;padding:20px;box-shadow:var(--shadow);font-size:.88rem;line-height:1.78;color:var(--txt-md);font-weight:600;}
.ip-card p+p{margin-top:10px;}
.ip-card ul{margin:8px 0 8px 14px;}
.ip-card li{margin-bottom:5px;padding-left:4px;}
.ip-card li::marker{color:var(--blue);}
.ip-card strong{color:var(--txt);font-weight:800;}
.ip-card a{color:var(--blue);}
.ip-card a:hover{color:var(--blue-dk);}

/* Company card */
.ip-company{background:var(--card);border:2px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);}
.ip-company-banner{background:linear-gradient(110deg,var(--blue) 0%,var(--blue-dk) 100%);padding:20px;position:relative;overflow:hidden;}
.ip-company-banner::after{content:'';position:absolute;top:-35px;right:-35px;width:130px;height:130px;background:radial-gradient(circle,rgba(255,255,255,.2) 0%,transparent 65%);pointer-events:none;}
.ip-company-name{font-family:var(--font-h);font-size:1.6rem;font-weight:800;color:white;letter-spacing:-.5px;margin-bottom:3px;}
.ip-company-tag{font-family:var(--font-h);font-size:.75rem;font-weight:700;color:rgba(255,255,255,.78);letter-spacing:.1em;text-transform:uppercase;}
.ip-company-body{padding:20px;font-size:.88rem;line-height:1.78;color:var(--txt-md);font-weight:600;}
.ip-company-body p+p{margin-top:10px;}
.ip-company-body strong{color:var(--txt);font-weight:800;}

/* Pillar grid */
.ip-pillars{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;}
.ip-pillar{background:var(--card);border:2px solid var(--border);border-radius:14px;padding:16px 12px;text-align:center;box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s;}
.ip-pillar:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.09);}
.ip-pillar-icon{font-size:1.6rem;margin-bottom:6px;}
.ip-pillar-title{font-family:var(--font-h);font-size:.85rem;font-weight:800;color:var(--txt);margin-bottom:4px;}
.ip-pillar-desc{font-size:.72rem;font-weight:600;color:var(--txt-lt);line-height:1.5;}

/* Feature list */
.ip-features{display:flex;flex-direction:column;gap:9px;}
.ip-feat{display:flex;align-items:flex-start;gap:12px;background:var(--card);border:2px solid var(--border);border-radius:13px;padding:13px 15px;box-shadow:var(--shadow);}
.ip-feat-dot{width:30px;height:30px;border-radius:9px;flex-shrink:0;font-size:.95rem;margin-top:1px;}
.ip-feat-title{font-family:var(--font-h);font-size:.84rem;font-weight:800;color:var(--txt);margin-bottom:2px;}
.ip-feat-desc{font-size:.78rem;font-weight:600;color:var(--txt-md);line-height:1.5;}

/* Contact CTA */
.ip-contact{background:linear-gradient(135deg,var(--blue-lt) 0%,var(--card) 100%);border:2px solid rgba(28,176,246,.25);border-radius:16px;padding:24px 20px;text-align:center;box-shadow:var(--shadow);}
[data-theme="dark"] .ip-contact{background:linear-gradient(135deg,rgba(28,176,246,.12) 0%,var(--card) 100%);}
.ip-contact-title{font-family:var(--font-h);font-size:1rem;font-weight:800;color:var(--txt);margin-bottom:6px;}
.ip-contact-desc{font-size:.82rem;font-weight:600;color:var(--txt-md);margin-bottom:16px;line-height:1.6;}
.ip-email-btn{display:inline-flex;align-items:center;gap:7px;background:var(--blue);color:white;border-radius:50px;padding:9px 20px;font-family:var(--font-h);font-size:.84rem;font-weight:800;text-decoration:none;letter-spacing:.02em;box-shadow:0 3px 0 var(--blue-dk);transition:background .18s,transform .18s,box-shadow .18s;border:none;cursor:pointer;}
.ip-email-btn:hover{background:var(--blue-dk);transform:translateY(-2px);box-shadow:0 5px 0 var(--blue-dkr);text-decoration:none;color:white;}

/* Privacy: TOC */
.ip-toc{background:var(--card);border:2px solid var(--border);border-radius:14px;padding:18px 20px;margin-bottom:24px;box-shadow:var(--shadow);}
.ip-toc-title{font-family:var(--font-h);font-size:.88rem;font-weight:800;color:var(--txt);margin-bottom:10px;display:flex;align-items:center;gap:7px;}
.ip-toc-list{display:flex;flex-direction:column;gap:2px;}
.ip-toc-item{display:flex;align-items:center;gap:9px;padding:5px 7px;border-radius:8px;font-size:.78rem;font-weight:700;color:var(--txt-md);background:none;border:none;cursor:pointer;text-align:left;width:100%;transition:background .12s,color .12s;}
.ip-toc-item:hover{background:var(--blue-lt);color:var(--blue);}
.ip-toc-num{width:20px;height:20px;border-radius:6px;background:var(--blue-lt);font-family:var(--font-h);font-size:.6rem;font-weight:800;color:var(--blue);flex-shrink:0;}

/* Privacy: section head */
.ip-pp-head{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--border);}
.ip-pp-num{width:32px;height:32px;border-radius:9px;background:var(--blue);color:white;font-family:var(--font-h);font-size:.82rem;font-weight:800;flex-shrink:0;box-shadow:0 3px 0 var(--blue-dk);}
.ip-pp-title{font-family:var(--font-h);font-size:1rem;font-weight:800;color:var(--txt);}

/* Privacy: info boxes */
.ip-infobox{border-radius:11px;padding:12px 14px;margin:12px 0;display:flex;align-items:flex-start;gap:10px;font-size:.8rem;font-weight:700;line-height:1.6;}
.ip-infobox-icon{font-size:1rem;flex-shrink:0;margin-top:1px;}
.ip-ib-blue{background:var(--blue-lt);border:1.5px solid rgba(28,176,246,.3);color:#005f8a;}
.ip-ib-green{background:var(--green-lt);border:1.5px solid rgba(88,204,2,.3);color:#2a6200;}
.ip-ib-yellow{background:var(--yellow-lt);border:1.5px solid rgba(255,200,0,.4);color:#7a5c00;}
[data-theme="dark"] .ip-ib-blue{background:rgba(28,176,246,.12);border-color:rgba(28,176,246,.25);color:var(--infobox-blue-txt);}
[data-theme="dark"] .ip-ib-green{background:rgba(88,204,2,.12);border-color:rgba(88,204,2,.25);color:var(--infobox-green-txt);}
[data-theme="dark"] .ip-ib-yellow{background:rgba(255,200,0,.1);border-color:rgba(255,200,0,.25);color:var(--infobox-yellow-txt);}

/* Privacy: data table */
.ip-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:.78rem;font-weight:600;}
.ip-table th{font-family:var(--font-h);font-size:.68rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.08em;padding:7px 10px;text-align:left;border-bottom:2px solid var(--border);}
.ip-table td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--txt-md);line-height:1.5;vertical-align:top;}
.ip-table tr:last-child td{border-bottom:none;}
.ip-table tr:hover td{background:var(--bg);}

/* Page footer inside inpage screens */
.ip-page-footer{width:100%;text-align:center;padding:16px 16px 0;font-size:.72rem;font-weight:600;color:var(--txt-lt);flex-shrink:0;}

/* ══════════════════════════════════════════════════
   HOW TO PLAY — additional components
══════════════════════════════════════════════════ */

/* Step number pills */
.htp-steps{display:flex;flex-direction:column;gap:14px;}
.htp-step{display:flex;gap:14px;align-items:flex-start;background:var(--card);border:2px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--shadow);}
.htp-step-num{width:36px;height:36px;border-radius:50%;flex-shrink:0;font-family:var(--font-h);font-size:1rem;font-weight:900;color:white;}
.htp-sn-blue{background:var(--blue);box-shadow:0 3px 0 var(--blue-dk);}
.htp-sn-green{background:var(--green);box-shadow:0 3px 0 var(--green-dk);}
.htp-sn-orange{background:var(--orange);box-shadow:0 3px 0 var(--orange-dk);}
.htp-sn-red{background:#E91E63;box-shadow:0 3px 0 #880E4F;}
.htp-step-body{flex:1;min-width:0;}
.htp-step-title{font-family:var(--font-h);font-size:.95rem;font-weight:800;color:var(--txt);margin-bottom:4px;}
.htp-step-desc{font-size:.82rem;font-weight:600;color:var(--txt-md);line-height:1.65;}
.htp-step-desc strong{color:var(--txt);font-weight:800;}

/* Mini demo board */
.htp-demo-wrap{background:var(--card);border:2px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow);}
.htp-demo-label{font-family:var(--font-h);font-size:.68rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.14em;margin-bottom:12px;text-align:center;}
.htp-demo-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:stretch;}
.htp-demo-cols>div{display:flex;flex-direction:column;}
.htp-demo-col-hdr{font-family:var(--font-h);font-size:.65rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.1em;text-align:center;margin-bottom:8px;flex-shrink:0;}
.htp-demo-cards{display:flex;flex-direction:column;gap:8px;flex:1;}
.htp-demo-card{
  background:var(--card);border:2.5px solid var(--border);border-bottom:4px solid var(--border-dk);
  border-radius:12px;padding:10px 12px;text-align:center;cursor:pointer;
  font-size:.78rem;font-weight:700;color:var(--txt);line-height:1.35;
  flex:1;min-height:52px;
  user-select:none;transition:border-color .15s,background .15s,transform .15s,box-shadow .15s;
}
.htp-demo-card .demo-art{display:block;font-family:var(--font-h);font-size:.88rem;font-weight:800;color:var(--green-dk);margin-bottom:2px;}
.htp-demo-card:hover:not(.demo-correct):not(.demo-wrong){border-color:var(--blue);border-bottom-color:var(--blue-dk);background:var(--blue-lt);transform:translateY(-2px);}
.htp-demo-card.demo-selected{border-color:var(--blue);border-bottom-color:var(--blue-dk);background:var(--blue-lt);color:var(--blue-dk);transform:translateY(-2px);box-shadow:0 0 0 3px rgba(28,176,246,.18);}
.htp-demo-card.demo-selected .demo-art{color:var(--blue-dk);}
.htp-demo-card.demo-correct{border-color:var(--green)!important;border-bottom-color:var(--green-dk)!important;background:var(--green-lt)!important;color:var(--green-dk)!important;pointer-events:none;cursor:default;animation:demoCorrect .45s cubic-bezier(.34,1.56,.64,1);}
.htp-demo-card.demo-correct .demo-art{color:var(--green-dk);}

.htp-demo-card.demo-wrong{border-color:var(--red)!important;border-bottom-color:var(--red-dk)!important;background:var(--red-lt)!important;color:var(--red-dk)!important;animation:demoWrong .4s ease;}
.htp-demo-card.demo-wrong .demo-art{color:var(--red-dk);}

.htp-demo-feedback{text-align:center;margin-top:12px;min-height:24px;font-family:var(--font-h);font-size:.78rem;font-weight:800;color:var(--txt-lt);letter-spacing:.04em;transition:color .2s;}
.htp-demo-feedback.fb-correct{color:var(--green-dk);}
.htp-demo-feedback.fb-wrong{color:var(--red);}
.htp-demo-reset{display:block;margin:12px auto 0;background:var(--bg);border:2px solid var(--border);border-bottom:3px solid var(--border-dk);border-radius:50px;padding:6px 18px;font-family:var(--font-h);font-size:.72rem;font-weight:800;color:var(--txt-md);cursor:pointer;letter-spacing:.04em;transition:border-color .15s,color .15s,background .15s;}
.htp-demo-reset:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-lt);}

/* Scoring grid */
.htp-score-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.htp-score-card{background:var(--card);border:2px solid var(--border);border-radius:14px;padding:14px 12px;text-align:center;box-shadow:var(--shadow);}
.htp-score-val{font-family:var(--font-h);font-size:1.5rem;font-weight:900;line-height:1;margin-bottom:4px;}
.htp-score-label{font-size:.7rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.08em;}
.htp-score-desc{font-size:.72rem;font-weight:600;color:var(--txt-md);margin-top:5px;line-height:1.5;}
/* Score value color utilities */
.hsv-green{color:var(--green-dk);}
.hsv-blue{color:var(--blue-dk);}
.hsv-orange{color:var(--orange);}
.hsv-yellow{color:#CC9A00;}
.hsv-red{color:var(--red-dk);}

/* Mode badges row */
.htp-modes{display:flex;flex-direction:column;gap:10px;}
.htp-mode-row{display:flex;align-items:flex-start;gap:12px;background:var(--card);border:2px solid var(--border);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow);}
.htp-mode-icon{width:44px;height:44px;border-radius:13px;flex-shrink:0;font-size:1.4rem;}
/* Mode icon backgrounds */
.htp-mi-green{background:var(--green-lt);}
.htp-mi-orange{background:var(--orange-lt);}
.htp-mi-purple{background:#F3E5F5;}
[data-theme="dark"] .htp-mi-green{background:rgba(88,204,2,.15);}
[data-theme="dark"] .htp-mi-orange{background:rgba(255,150,0,.15);}
[data-theme="dark"] .htp-mi-purple{background:rgba(156,39,176,.15);}
.htp-mode-title{font-family:var(--font-h);font-size:.9rem;font-weight:800;color:var(--txt);margin-bottom:3px;}
.htp-mode-desc{font-size:.8rem;font-weight:600;color:var(--txt-md);line-height:1.6;}
.htp-mode-tag{display:inline-block;font-family:var(--font-h);font-size:.58rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;border-radius:50px;padding:2px 9px;margin-bottom:4px;}
/* Mode tag colors */
.hmt-green{background:var(--green-lt);color:var(--green-dk);}
.hmt-orange{background:var(--orange-lt);color:#A35F00;}
.hmt-purple{background:#F3E5F5;color:#7B1FA2;}
[data-theme="dark"] .hmt-green{background:rgba(88,204,2,.15);color:var(--green-dk-lt);}
[data-theme="dark"] .hmt-orange{background:rgba(255,150,0,.15);color:var(--orange-tag-dk);}
[data-theme="dark"] .hmt-purple{background:rgba(156,39,176,.15);color:var(--purple-lt);}

/* Tip pills */
.htp-tips{display:flex;flex-direction:column;gap:9px;}
.htp-tip{display:flex;gap:10px;align-items:flex-start;background:var(--card);border:2px solid var(--border);border-left:4px solid var(--green);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow);font-size:.82rem;font-weight:600;color:var(--txt-md);line-height:1.6;}
.htp-tip-icon{font-size:1rem;flex-shrink:0;margin-top:1px;}

/* Hint explainer */
.htp-hint-row{display:flex;align-items:center;gap:14px;background:var(--card);border:2px solid var(--border);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow);}
.htp-hint-icon{width:48px;height:48px;border-radius:50%;flex-shrink:0;background:linear-gradient(145deg,#FFE566,#FFC107);font-size:1.4rem;box-shadow:0 3px 0 rgba(160,100,0,.3);}
.htp-hint-title{font-family:var(--font-h);font-size:.9rem;font-weight:800;color:var(--txt);margin-bottom:3px;}
.htp-hint-desc{font-size:.8rem;font-weight:600;color:var(--txt-md);line-height:1.6;}

/* Keyboard shortcuts in HTP */
.htp-keys{display:grid;grid-template-columns:auto 1fr;gap:7px 14px;align-items:center;background:var(--card);border:2px solid var(--border);border-radius:14px;padding:16px;box-shadow:var(--shadow);}
.htp-key{font-size:.75rem;border-radius:8px;padding:4px 10px;}
.htp-key-desc{font-size:.78rem;font-weight:700;color:var(--txt-md);}

/* Play CTA */
.htp-play-cta{background:linear-gradient(135deg,var(--green-lt) 0%,var(--card) 100%);border:2px solid rgba(88,204,2,.28);border-radius:18px;padding:28px 22px;text-align:center;box-shadow:var(--shadow);}
[data-theme="dark"] .htp-play-cta{background:linear-gradient(135deg,rgba(88,204,2,.12) 0%,var(--card) 100%);}
.htp-cta-title{font-family:var(--font-h);font-size:1.15rem;font-weight:800;color:var(--txt);margin-bottom:7px;}
.htp-cta-desc{font-size:.85rem;font-weight:600;color:var(--txt-md);margin-bottom:18px;line-height:1.6;}
.htp-cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--green);color:white;border-radius:50px;padding:12px 28px;font-family:var(--font-h);font-size:.95rem;font-weight:800;border:none;cursor:pointer;letter-spacing:.02em;box-shadow:0 4px 0 var(--green-dk);transition:background .18s,transform .18s,box-shadow .18s;}
.htp-cta-btn:hover{background:var(--green-dk);transform:translateY(-2px);box-shadow:0 6px 0 #3d8000;}
.htp-cta-btn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--green-dk);}

/* ── ASHOKA CHAKRA ── */
.new-chakra-wrap{position:relative;display:flex;justify-content:center;align-items:center;flex-shrink:0;animation:screenFadeIn .45s .16s ease both;}
.chakra-glow-orb{position:absolute;width:266px;height:266px;background:radial-gradient(circle,rgba(45,156,219,.14) 0%,transparent 68%);pointer-events:none;z-index:0;will-change:transform,opacity;animation:breatheGlow 4s ease-in-out infinite;}

#chakra-float{position:relative;z-index:2;animation:floatBob 4s ease-in-out infinite;will-change:transform;backface-visibility:hidden;}
.chakra-paused #chakra-float,.chakra-paused .chakra-glow-orb{animation-play-state:paused;}
#chakra-spin{position:relative;cursor:pointer;-webkit-touch-callout:none;outline:none;user-select:none;will-change:transform;}
#chakra-spin:active{filter:brightness(.88);}
.ashoka-sticker-bg{position:absolute;inset:0;background:white;border-radius:50%;box-shadow:0 12px 40px rgba(45,156,219,.25),0 0 0 2px rgba(255,255,255,1);}
[data-theme="dark"] .ashoka-sticker-bg{background:var(--card);box-shadow:0 12px 40px rgba(126,184,255,.2),0 0 0 2px rgba(255,255,255,.1);}
.ashoka-chakra-svg{position:relative;z-index:1;color:#000080;width:clamp(110px,30.4vw,142px);height:clamp(110px,30.4vw,142px);filter:drop-shadow(0 3px 12px rgba(26,35,184,.28));}
[data-theme="dark"] .ashoka-chakra-svg{color:var(--chakra-clr);filter:drop-shadow(0 3px 14px rgba(126,184,255,.35));}

/* ── RESPONSIVE: MOBILE (≤ 480px) ── */
@media(max-width:480px){
  .stat-pill{padding:4px 8px;}
  .pill-val{font-size:.82rem;}
  .timer-pill{padding:5px 10px;min-width:58px;}
  .timer-val{font-size:1rem;}
  #board-grid{gap:12px;}
  .match-card{padding:10px;}
  .card-art-num{font-size:.94rem;}
  .card-kw{font-size:.8rem;}
  .gc-btn{width:32px;height:32px;}
  .gc-btn svg{width:16px;height:16px;}
  .game-header{margin-bottom:10px;}
  .col-headers{margin-bottom:5px;}
  .gc-hint{width:38px;height:38px;}
  .new-tagline{font-size:.78rem;}
  .new-mode-card{min-height:106px;padding:14px 10px 12px;}
  .new-daily-bar{border-radius:18px;}
  .new-streak-bar{border-radius:18px;padding:8px 14px 8px 10px;}
  .start-main{padding:4px 16px 8px;gap:8px;}
  .res-main{padding:16px 16px 36px;gap:20px;}
  .res-score-card{padding:18px;}
  .res-mini-stats{gap:8px;}
  .res-stat-val{font-size:16px;}
  .res-stat-lbl{font-size:8px;}
  .res-stat-icon{padding:6px;}
  .res-stat-icon svg{width:16px;height:16px;}
  .res-secondary-row{gap:8px;}
  .res-btn{padding:11px 12px;font-size:.82rem;}
  .res-breakdown-inner{padding:14px;}
  .res-bd-total-val{font-size:17px;}
  .scorecard-backdrop{padding:12px;}
  .sc-top{padding:18px 18px 14px;}
  .sc-da-scorenum{font-size:40px;}
  .ip-pillars{grid-template-columns:1fr;}
  .ip-nav{padding:max(0px,env(safe-area-inset-top,0px)) 12px 0;}
  .ip-body{padding:20px 12px 56px;}
}

/* ── RESPONSIVE: SMALL MOBILE (≤ 390px) ── */
@media(max-width:390px){
  .game-header{padding:max(14px,env(safe-area-inset-top,14px)) 10px 0;margin-bottom:10px;gap:4px;}
  .stat-pill{padding:3px 7px;gap:3px;}
  .pill-val{font-size:.78rem;}
  .timer-val{font-size:.95rem;}
  .timer-pill{padding:4px 8px;min-width:54px;}
  .gc-btn{width:30px;height:30px;}
  .gc-btn svg{width:15px;height:15px;}
  .gc-hint{width:34px;height:34px;}
  .col-hdr{font-size:.6rem;letter-spacing:.4px;}
  .card-art-num{font-size:.9rem;}
  .card-kw{font-size:.78rem;}
  .progress-wrap,.relaxed-spacer{width:calc(100% - 20px);margin-left:10px;margin-right:10px;}
  .col-headers{width:calc(100% - 20px);margin:0 10px;}
  #board-wrap{width:calc(100% - 20px);margin:0 10px;}
  .res-mini-stats{grid-template-columns:repeat(2,1fr);gap:8px;}
  .res-stat-icon{padding:6px;margin-bottom:2px;}
  .new-logo-text{font-size:clamp(1.9rem,9vw,2.6rem);}
  .new-tagline{font-size:.72rem;gap:5px;}
  .tag-sparkle{font-size:.65rem;}
  .new-chakra-wrap{margin:0;}
  .ashoka-chakra-svg{width:114px!important;height:114px!important;}
  .chakra-glow-orb{width:228px;height:228px;}
  .new-mode-card{min-height:106px;padding:14px 10px 12px;border-radius:20px;}
  .nmc-icon-wrap{padding:9px;}
  .nmc-icon-wrap svg{width:28px;height:28px;}
  .nmc-title{font-size:.95rem;}
  .nmc-desc{font-size:.56rem;}
  .new-daily-bar{padding:10px 11px;gap:8px;}
  .ndb-icon{width:42px;height:42px;border-radius:8px;}
  .ndb-lb-btn{padding:7px 9px 7px 8px;}
  .ndb-lb-arrow{display:none;}
  .ndb-btn{padding:9px 12px;font-size:.9rem;}
  .start-main{padding:2px 12px 8px;gap:6px;}
  .sfh{padding:max(6px,env(safe-area-inset-top,6px)) 12px 0;}
  .sfh-btn{width:38px;height:38px;}
  .sfh-right .sfh-btn{width:26px;height:26px;}
  .sfh-right .sfh-btn svg{width:11px;height:11px;}
  .new-streak-bar{padding:8px 12px 8px 10px;gap:10px;min-height:58px;border-radius:20px;}
  .scorecard-backdrop{padding:10px;}
  .scorecard-shell{max-width:100%;}
  .sc-top{padding:16px 16px 12px;}
  .sc-brand-logo{font-size:1.2rem;}
  .sc-brand-tag{font-size:.55rem;padding:2px 6px;}
  .sc-player-name{font-size:.62rem;letter-spacing:.08em;}
  .sc-da-inferno-num,.sc-da-inferno-icon{font-size:13px;}
  .sc-da-scorenum{font-size:36px;}
  .sc-da-daynum{font-size:20px;}
  .sc-da-speed-num,.sc-da-streak-half-num{font-size:16px;}
  .sc-da-chal-main{font-size:11px;}
  .sc-da-chal-sub{font-size:9px;}
  .sc-bottom{padding:9px 16px;}
  .sc-btn{padding:10px;font-size:.8rem;}
  .sc-actions{gap:8px;margin-top:10px;}
}

@media(max-width:400px){
  .htp-score-grid{grid-template-columns:1fr;}
}

/* ── RESPONSIVE: TABLET (481–768px) ── */
@media(min-width:481px) and (max-width:768px){
  .start-main{max-width:460px;gap:11px;}
  .sfh{max-width:460px;}
  .new-mode-card{min-height:118px;}
  .new-logo-text{font-size:clamp(2.6rem,9vw,3.6rem);}
}

/* ── RESPONSIVE: DESKTOP (≥ 769px) ── */
@media(min-width:769px){
  #game-screen{max-width:860px;}
  .start-main{max-width:520px;gap:14px;padding:12px 22px 28px;overflow-y:auto;}
  .sfh{max-width:520px;padding:max(16px,env(safe-area-inset-top,16px)) 22px 0;}
  .new-logo-text{font-size:3.8rem;}
  .new-tagline{font-size:1rem;}
  .new-mode-card{min-height:128px;padding:18px 14px 14px;border-radius:28px;}
  .new-mode-grid{gap:12px;}
  .nmc-title{font-size:1.02rem;}
  .nmc-icon-wrap svg{width:32px;height:32px;}
  .ashoka-chakra-svg{width:133px!important;height:133px!important;}
  .chakra-glow-orb{width:285px;height:285px;}
  .new-daily-bar{flex-shrink:0;padding:13px 16px 12px;gap:10px;}
  .new-streak-bar{flex-shrink:0;min-height:68px;padding:11px 18px 11px 14px;}
  .nsb-flame-box{width:42px;height:42px;}
  .nsb-week{gap:5px;}
  .nsb-day{max-width:42px;}
  #results-screen{max-width:580px;}
  .res-mini-stats{gap:12px;}
  .res-stat-val{font-size:1.8rem;}
  .res-app{border-radius:0;}
  .res-main{padding:28px 28px 56px;gap:24px;}
  .res-score-card{padding:28px;}
  .rs-final-num{font-size:68px;}
  .sc-actions{gap:12px;}
  .sc-btn{padding:14px;font-size:.95rem;}
  .scorecard-shell{max-width:380px;}
}

/* ── RESPONSIVE: LARGE DESKTOP (≥ 1024px) ── */
@media(min-width:1024px){
  .start-main{max-width:540px;}
  .sfh{max-width:540px;}
  #game-screen{max-width:860px;}
  .new-mode-card{min-height:130px;}
}


/* ── STATS MODAL ─────────────────────────────────────────────── */
.st-backdrop{position:fixed;inset:0;z-index:var(--z-modal);padding:16px;visibility:hidden;pointer-events:none;display:flex;align-items:center;justify-content:center;transition:visibility 0s .3s;}
.st-backdrop::before{content:'';position:absolute;inset:0;background:rgba(15,23,42,.65);backdrop-filter:blur(6px);opacity:0;transition:opacity .25s;}
.st-backdrop.open{visibility:visible;pointer-events:auto;transition:none;}
.st-backdrop.open::before{opacity:1;}
.st-modal{position:relative;background:var(--card);border-radius:24px;width:100%;max-width:420px;max-height:90dvh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.32);opacity:0;transform:translateY(18px) scale(.95);transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .25s;}
.st-backdrop.open .st-modal{opacity:1;transform:none;transition:transform .3s cubic-bezier(.34,1.56,.64,1);}
.st-head{background:linear-gradient(135deg,#0a3a6e 0%,#1a6b3a 100%);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.st-body{flex:1;overflow-y:auto;padding:16px 16px 20px;display:flex;flex-direction:column;gap:14px;}
.st-xp-row{background:var(--blue-lt);border:1.5px solid var(--blue);border-radius:14px;padding:8px 12px;display:flex;align-items:center;gap:10px;}
.st-xp-icon{font-size:1.25rem;flex-shrink:0;}
.st-xp-info{flex:1;min-width:0;}
.st-xp-level{font-family:var(--font-h);font-size:.68rem;font-weight:900;color:var(--blue-dk);text-transform:uppercase;letter-spacing:.04em;}
.st-xp-title{font-family:var(--font-h);font-size:.88rem;font-weight:800;color:var(--txt);line-height:1.2;}
.st-xp-bar-wrap{height:5px;background:var(--border);border-radius:6px;margin-top:5px;overflow:hidden;}
.st-xp-bar{height:100%;background:var(--blue);border-radius:6px;transition:width .6s ease;}
.st-xp-pts{font-family:var(--font-h);font-size:.63rem;font-weight:700;color:var(--txt-lt);margin-top:2px;}
.st-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.st-cell{background:var(--bg);border:1.5px solid var(--border);border-radius:14px;padding:12px 10px;text-align:center;}
.st-cell-val{font-family:var(--font-h);font-size:1.4rem;font-weight:900;color:var(--txt);line-height:1;}
.st-cell-val.green{color:var(--green-dk);}
.st-cell-val.blue{color:var(--blue-dk);}
.st-cell-val.orange{color:var(--orange-dk);}
.st-cell-val.red{color:var(--red-dk);}
.st-cell-val.purple{color:var(--purple);}
.st-cell-label{font-family:var(--font-h);font-size:.62rem;font-weight:700;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;}
.st-bests{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.st-best-pill{background:var(--bg);border:1.5px solid var(--border);border-radius:14px;padding:10px 8px;text-align:center;}
.st-best-pill-mode{font-family:var(--font-h);font-size:.58rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;}
.st-best-pill-mode.relaxed{color:var(--green-dk);}
.st-best-pill-mode.rapid{color:var(--purple);}
.st-best-pill-mode.daily{color:var(--orange-dk);}
.st-best-pill-val{font-family:var(--font-h);font-size:1.1rem;font-weight:900;color:var(--txt);}
.st-best-pill-sub{font-family:var(--font-h);font-size:.58rem;color:var(--txt-lt);margin-top:2px;}
.st-section-label{font-family:var(--font-h);font-size:.68rem;font-weight:800;color:var(--txt-lt);text-transform:uppercase;letter-spacing:.08em;padding:0 2px;}
.st-chart-wrap{background:var(--bg);border:1.5px solid var(--border);border-radius:16px;padding:12px 10px 10px;}
.st-chart-svg-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.st-chart-svg{display:block;overflow:visible;}
.st-bar-col{cursor:default;}
/* ── Chart tooltip ── */
.st-tip{position:fixed;background:var(--card);border:1.5px solid var(--border);border-radius:10px;padding:8px 12px;pointer-events:none;z-index:calc(var(--z-modal) + 10);font-family:var(--font-h);font-size:.72rem;line-height:1.75;color:var(--txt);box-shadow:0 6px 22px rgba(0,0,0,.14);display:none;white-space:nowrap;}
.st-tip-name{font-weight:800;margin-bottom:3px;color:var(--txt);}
.st-tip-row{display:flex;justify-content:space-between;gap:18px;}
.st-tip-key{color:var(--txt-lt);font-weight:700;}
.st-tip-val{font-weight:800;color:var(--txt);}
.st-tip-val.err{color:var(--red);}
.st-weak{background:var(--red-lt);border:1.5px solid var(--red);border-radius:14px;padding:10px 14px;display:flex;align-items:center;gap:10px;}
.st-weak-icon{font-size:1.3rem;flex-shrink:0;}
.st-weak-text{font-family:var(--font-h);font-size:.8rem;font-weight:700;color:var(--txt);}
.st-weak-text strong{color:var(--red-dk);}
[data-theme="dark"] .st-weak-text strong{color:#ff8080;}
.st-empty{text-align:center;padding:32px 16px;color:var(--txt-lt);font-family:var(--font-h);font-size:.85rem;line-height:1.7;}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important;}
}
