:root{font-family:-apple-system,BlinkMacSystemFont,Noto Sans SC,Microsoft YaHei,sans-serif;color:#0f172a;background:#e0f2fe;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 16% 14%,rgba(255,237,213,.95),transparent 34%),radial-gradient(circle at 84% 12%,rgba(187,247,208,.8),transparent 30%),linear-gradient(135deg,#e0f2fe,#ecfdf5 54%,#fff7ed)}button,a{font:inherit}button{border:0;cursor:pointer}.app-shell{min-height:100svh;padding:18px}.stage{position:relative;display:flex;min-height:calc(100svh - 36px);flex-direction:column;gap:16px;overflow:hidden;border:1px solid rgba(255,255,255,.82);border-radius:34px;background:#fffbebb8;box-shadow:0 30px 90px #d43f3229;padding:16px}.stage:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#ffffffc2,#ffffff2e),radial-gradient(circle at 76% 74%,rgba(14,165,233,.18),transparent 38%);pointer-events:none}.top-strip,.game-grid,.progress-track{position:relative;z-index:1}.top-strip{display:flex;align-items:center;justify-content:space-between;gap:12px}.brand-pill,.score-pill,.home-link{display:inline-flex;min-height:44px;align-items:center;justify-content:center;gap:8px;border-radius:999px;background:#ffffffe0;box-shadow:0 8px 24px #0f172a14;color:#b91c1c;font-size:.92rem;font-weight:900;padding:0 16px;text-decoration:none}.score-pill{color:#047857}.home-link{color:#475569}.game-grid{display:grid;flex:1;grid-template-columns:minmax(0,1.12fr) minmax(330px,.62fr);gap:16px}.number-panel,.camera-panel{border-radius:30px;background:#ffffffc7;box-shadow:0 18px 52px #0f172a1a;-webkit-backdrop-filter:blur(18px) saturate(150%);backdrop-filter:blur(18px) saturate(150%)}.number-panel{display:grid;min-height:540px;place-items:center;padding:28px}.camera-panel{display:flex;min-height:540px;flex-direction:column;gap:14px;padding:16px}.ready-copy,.question-copy,.finish-copy{width:min(100%,680px);text-align:center}.eyebrow{margin:0 0 10px;color:#dc2626;font-size:1rem;font-weight:950}.ready-copy h1,.finish-copy h1{margin:0;color:#0f172a;font-size:clamp(3rem,7vw,6.5rem);line-height:.98;font-weight:950}.question-copy h1{margin:0;color:#ea580c;font-size:clamp(9rem,28vw,19rem);line-height:.86;font-weight:950;text-shadow:0 14px 0 rgba(251,146,60,.18)}.lead{margin:22px auto 0;max-width:520px;color:#475569;font-size:1.18rem;font-weight:800;line-height:1.8}.challenge-text{margin:20px 0 0;color:#475569;font-size:clamp(1.6rem,4vw,3.4rem);font-weight:950}.challenge-text span{margin-left:12px;color:#dc2626}.mascot-orbit{display:grid;width:120px;height:120px;margin:0 auto 18px;place-items:center;border-radius:36px;background:#fff7ed;box-shadow:0 18px 42px #f9731633}.mascot-orbit img{width:104px;height:104px;object-fit:contain}.mode-tabs{display:inline-grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:26px;border-radius:999px;background:#f1f5f9;padding:8px}.mode-tabs button{min-width:120px;border-radius:999px;background:transparent;color:#475569;font-weight:950;padding:14px 18px}.mode-tabs .selected{background:#fff;color:#dc2626;box-shadow:0 8px 22px #0f172a17}.hero-action,.primary-action,.soft-action{display:inline-flex;min-height:58px;align-items:center;justify-content:center;gap:10px;border-radius:999px;font-size:1.08rem;font-weight:950;transition:transform .15s ease,box-shadow .15s ease}.hero-action,.primary-action{background:#ef4444;color:#fff;box-shadow:0 16px 34px #ef444447;padding:0 30px}.hero-action{margin-top:22px}.soft-action{background:#f1f5f9;color:#334155;padding:0 24px}.hero-action:hover,.primary-action:hover,.soft-action:hover{transform:translateY(-2px)}.hero-action:active,.primary-action:active,.soft-action:active{transform:scale(.98)}.camera-frame{position:relative;flex:1;min-height:320px;overflow:hidden;border-radius:26px;background:#0f172a}.camera-video{display:none}.camera-canvas{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.camera-empty{position:absolute;inset:0;display:grid;place-items:center;align-content:center;gap:12px;background:linear-gradient(135deg,#dbeafe,#ffedd5);color:#0c4a6e;font-weight:950}.camera-status,.result-grid{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;border-radius:24px;background:#ffffffdb;padding:14px}.status-label{margin:0 0 4px;color:#64748b;font-size:.78rem;font-weight:900}.camera-status strong{color:#0f172a;font-size:1.25rem;font-weight:950}.finger-badge{display:inline-flex;min-width:82px;align-items:center;justify-content:center;gap:8px;border-radius:20px;background:#ecfdf5;color:#059669;font-size:2rem;font-weight:950;padding:10px 14px}.feedback-card{display:inline-flex;min-width:250px;align-items:center;justify-content:center;gap:10px;margin-top:28px;border-radius:26px;color:#fff;font-size:1.28rem;font-weight:950;padding:16px 20px}.feedback-card span{font-size:.95rem}.feedback-card.correct{background:#10b981}.feedback-card.wrong{background:#f97316}.helper-error{margin:10px 0 0;border-radius:18px;background:#fee2e2;color:#991b1b;font-weight:900;line-height:1.55;padding:12px 14px}.helper-note{margin:12px 0 0;border-radius:18px;background:#ecfeff;color:#155e75;font-weight:900;line-height:1.55;padding:12px 14px}.privacy-note{margin:0;color:#64748b;font-size:.86rem;font-weight:800;text-align:center}.progress-track{height:12px;overflow:hidden;border-radius:999px;background:#ffffffb3}.progress-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#10b981,#f59e0b,#ef4444);transition:width .26s ease}.stars{display:flex;justify-content:center;gap:10px;margin-top:18px;color:#f59e0b}.result-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:22px;text-align:left}.result-grid span{border-radius:18px;background:#f8fafc;color:#475569;font-weight:900;padding:14px}.result-grid strong{float:right;color:#0f172a}.finish-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}.spin{animation:spin .9s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:860px){.app-shell{padding:10px}.stage{min-height:calc(100svh - 20px);border-radius:28px;padding:12px}.top-strip{flex-wrap:wrap}.brand-pill{order:-1;width:100%}.game-grid{grid-template-columns:1fr}.number-panel,.camera-panel{min-height:auto;border-radius:26px}.number-panel{padding:22px 14px}.camera-frame{min-height:250px}.question-copy h1{font-size:clamp(7rem,42vw,11rem)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
