:root{--bg-top: #fff7eb;--bg-bottom: #fbe6ff;--card: #ffffff;--card-soft: #fffaf2;--ink: #2a2438;--ink-soft: #61586f;--accent: #ff9e54;--mint: #8dd8c4;--warn: #d94f4f;--ok: #2f9b58;--border: #eadfef}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{margin:0;font-family:Trebuchet MS,Comic Sans MS,Segoe UI,sans-serif;color:var(--ink);background:#f7f1ff;overflow:hidden}h1,h2,p{margin-top:0}h1{margin-bottom:4px;font-size:1.45rem}h2{margin-bottom:6px;font-size:1.05rem}.app-shell{height:100vh;padding:10px;overflow:hidden;background:linear-gradient(180deg,var(--bg-top),var(--bg-bottom))}.game-screen{height:100%;display:grid;grid-template-rows:auto auto auto 1fr auto;min-height:0;gap:8px}.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:8px;box-shadow:0 10px 24px #371f461f}.eyebrow{margin:0;color:var(--ink-soft);font-size:.9rem}.start-screen{display:grid;min-height:calc(100vh - 28px);place-items:center}.start-card{width:min(560px,100%)}.intro{color:var(--ink-soft);line-height:1.4}.name-form{display:grid;gap:10px}.auth-toggle-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:8px 0 12px}.name-form label{display:grid;gap:6px}input{border-radius:10px;border:1px solid #cab9d4;padding:10px;font:inherit;line-height:1.2;min-height:38px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#fff}button{font:inherit;line-height:1.1;-webkit-appearance:none;-moz-appearance:none;appearance:none}.primary-button,.secondary-button,.small-button,.danger-button{border:0;border-radius:10px;padding:10px 12px;cursor:pointer;color:#1c1328;background:var(--accent);transition:transform .12s ease,filter .12s ease}.secondary-button{background:var(--mint)}.small-button{background:#ffd89e}.danger-button{background:#f9c6c6;color:#5e1717}button:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.02)}button:disabled{opacity:.55;cursor:not-allowed}.top-bar{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:12px;padding:12px}.top-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:8px;min-width:0}.identity-block{min-width:0}.top-trophy-status{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.theme-picker{display:grid;gap:4px;color:var(--ink-soft);font-size:.82rem;width:100%}.theme-picker select{border-radius:8px;border:1px solid #cab9d4;padding:6px 28px 6px 8px;background:#fff;min-width:185px;color:#2a2438;font:inherit;line-height:1.2;min-height:38px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,#70508a 50%),linear-gradient(135deg,#70508a 50%,transparent 50%);background-position:calc(100% - 16px) calc(50% - 3px),calc(100% - 10px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}.custom-theme-controls{display:grid;gap:8px;justify-items:start;width:230px;padding:6px 8px;border:1px solid #e4d7ef;border-radius:10px;background:#faf6ff}.custom-theme-controls label{display:grid;gap:2px;color:var(--ink-soft);font-size:.78rem}.custom-theme-controls input[type=text]{width:120px;height:30px;border:1px solid #cab9d4;border-radius:8px;padding:4px 8px;background:#fff;color:#2a2438}.custom-theme-controls input[type=text]:focus-visible{outline:2px solid #7ab7ff;outline-offset:2px}.swatch-row{display:flex;flex-wrap:wrap;gap:6px;max-width:214px}.swatch-button{width:20px;height:20px;border-radius:999px;border:1px solid rgba(49,35,66,.2);padding:0}.identity-block h1{margin-bottom:2px}.test-mode-toggle{font-size:.85rem;color:var(--ink-soft);display:flex;gap:6px;align-items:center;background:#f8f2ff;border:1px solid #e2d6ef;border-radius:999px;padding:6px 10px}.save-status{min-height:0;margin:0;color:var(--ok);font-weight:700;font-size:.8rem}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:0}.stat-card{background:var(--card-soft);border:1px solid #f2e7d6;border-radius:12px;text-align:center;padding:8px}.stat-card span{display:block;color:var(--ink-soft);margin-bottom:4px}.quiz-lock-banner{margin:4px 0 8px;background:#fff1f1;border:1px solid #f2c3c3;color:var(--warn);border-radius:12px;padding:8px;font-weight:700}.main-layout{display:grid;grid-template-columns:minmax(250px,.9fr) minmax(0,1.6fr) minmax(320px,1fr);gap:8px;min-height:0;max-height:54vh}.puppy-zone{position:relative;overflow:hidden;text-align:center;background:radial-gradient(circle at 20% 10%,#fff6d5 0 28%,transparent 29%),radial-gradient(circle at 80% 15%,#f5e8ff 0 26%,transparent 27%),var(--card);min-height:0;user-select:none;-webkit-user-select:none;-ms-user-select:none;-webkit-user-drag:none}.puppy-zone.fiery-streak-active{border-color:#ff8a3d;box-shadow:0 0 0 2px #ff8a3d40,0 0 30px #ff6c2266}.flame-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5;background:radial-gradient(circle at 15% 100%,rgba(255,89,0,.25) 0 20%,transparent 40%),radial-gradient(circle at 45% 100%,rgba(255,122,0,.28) 0 22%,transparent 44%),radial-gradient(circle at 75% 100%,rgba(255,175,42,.24) 0 20%,transparent 42%);animation:fireRise .9s ease-in-out infinite alternate}@keyframes fireRise{0%{transform:translateY(4px) scale(1);opacity:.75}to{transform:translateY(-4px) scale(1.02);opacity:1}}.puppy-button{width:min(320px,100%);border:2px solid #d39a67;border-radius:44% 44% 40% 40%;padding:10px 10px 12px;background:linear-gradient(180deg,#f6c38f,#e5a96d);cursor:pointer;position:relative;z-index:3;box-shadow:0 8px 20px #48230b40;user-select:none;-webkit-user-select:none;-ms-user-select:none;-webkit-user-drag:none}.puppy-button:active{transform:scale(.95)}.puppy-button.fire-clicking{animation:fireShake .12s linear;box-shadow:0 0 18px #ff751899}@keyframes fireShake{0%{transform:translate(0) scale(1)}25%{transform:translate(-1px) scale(1.02)}50%{transform:translate(1px) scale(.99)}75%{transform:translate(-1px) scale(1.01)}to{transform:translate(0) scale(1)}}.puppy-photo{display:block;width:clamp(150px,24vw,240px);height:clamp(150px,24vw,240px);margin:0 auto 4px;object-fit:cover;border-radius:42% 42% 38% 38%;border:3px solid rgba(119,73,37,.4);box-shadow:0 10px 22px #21100847;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none}.puppy-label{display:block;margin-top:2px;color:#4f3521;font-size:.95rem;font-weight:700;user-select:none;-webkit-user-select:none;-ms-user-select:none;-webkit-user-drag:none;pointer-events:none}.star-button{margin-top:8px;border:2px solid #ffe566;border-radius:999px;padding:8px 18px;background:linear-gradient(135deg,#fff9c4,#ffe033,#ffb300,#ffe033,#fff9c4);background-size:300% 300%;font-weight:700;animation:starPulse 1s ease-in-out infinite,starShimmer 2s linear infinite;position:relative;z-index:6;display:inline-flex;align-items:center;gap:8px;box-shadow:0 0 18px #ffdc32b3,0 0 36px #ffc80066,inset 0 0 12px #fff6;overflow:visible}.star-button:before,.star-button:after{content:"✦";position:absolute;font-size:10px;color:#fffaaa;animation:sparkleOrbit 1.8s linear infinite;text-shadow:0 0 6px #ffe066,0 0 12px #ffcc00;pointer-events:none}.star-button:before{top:-6px;left:8px;animation-delay:-.9s}.star-button:after{bottom:-6px;right:8px}.ui-star-glyph{color:#f90;font-size:1.3rem;text-shadow:0 0 8px #fff,0 0 18px #ffe066,0 0 30px #ffcc00;animation:starTwinkle .7s ease-in-out infinite alternate;display:inline-block}@keyframes starShimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes sparkleOrbit{0%{transform:rotate(0) translate(18px) rotate(0) scale(1);opacity:1}50%{transform:rotate(180deg) translate(18px) rotate(-180deg) scale(1.4);opacity:.7}to{transform:rotate(360deg) translate(18px) rotate(-360deg) scale(1);opacity:1}}.streak-readout{margin:6px 0 0;font-weight:700;color:#8f5a35;position:relative;z-index:6}.streak-readout.hot{color:#cb3d00;text-shadow:0 0 12px rgba(255,90,23,.45);animation:hotPulse .5s ease-in-out infinite alternate}@keyframes hotPulse{0%{transform:scale(1)}to{transform:scale(1.03)}}.hidden{display:none}@keyframes starPulse{0%,to{transform:scale(1);box-shadow:0 0 #ffcd4a4d}50%{transform:scale(1.06);box-shadow:0 0 18px #ffcd4ab3}}.floating-text-layer{pointer-events:none;position:absolute;top:0;right:0;bottom:0;left:0;z-index:7}.floating-text{position:absolute;bottom:46%;color:#935f00;font-size:1rem;font-weight:700;animation:floatUp .9s ease forwards}@keyframes floatUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-50px)}}.message-text{margin:6px 0 0;color:var(--ink-soft)}.left-stack,.right-stack{display:grid;gap:10px;min-height:0}.left-stack,.right-stack{grid-template-rows:minmax(0,1fr)}.shop-card,.trophy-card,.leaderboard-card{min-height:0;display:flex;flex-direction:column}.section-title-row{display:flex;justify-content:space-between;align-items:center;gap:10px}.pill{display:inline-block;padding:4px 8px;border-radius:999px;background:#f4edf8;color:#6a4d7a;font-size:.8rem}.mini-status{margin:4px 0;color:#6a4d7a;font-weight:700;font-size:.86rem}.meter-track{width:100%;height:10px;border-radius:999px;background:#f0dde0;overflow:hidden;margin:6px 0 8px}.meter-fill{height:100%;background:linear-gradient(90deg,#ff8f45,#ff4d2e);box-shadow:0 0 14px #ff5a1780;transition:width .18s ease-out}.compact-status-card{margin-top:0;padding:6px 10px;max-height:28vh;overflow:auto}.dog-park-card{margin-top:8px}.dog-park-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px}.dog-park-self,.dog-park-lobby-list{border:1px solid #e3d6ed;border-radius:12px;padding:8px;background:#fffafc}.dog-avatar-preview{width:56px;height:56px;border-radius:999px;border:1px solid #d3c0e0;display:grid;place-items:center;font-size:1.8rem;background:#f9f1ff;margin-bottom:6px}.dog-need-row{display:flex;justify-content:space-between;gap:8px;margin-top:4px;font-size:.86rem;color:#5f5470;font-weight:700}.dog-action-row{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.dog-lobby-row{display:grid;grid-template-columns:36px minmax(0,1fr) auto;gap:8px;align-items:center;border:1px solid #e3d6ed;border-radius:10px;padding:6px;margin-bottom:6px;background:#fff}.dog-lobby-avatar{width:30px;height:30px;border-radius:999px;border:1px solid #d3c0e0;display:grid;place-items:center;background:#f8f1ff}.status-strip{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;align-items:center}.credential-box{margin-top:8px;border-top:1px dashed #dccbe8;padding-top:6px;display:grid;gap:6px}.credential-panel{margin-top:6px}.credential-panel summary{cursor:pointer;color:#6a4d7a;font-weight:700;font-size:.95rem;list-style:none}.credential-panel summary::-webkit-details-marker{display:none}.credential-panel summary:before{content:"▸";display:inline-block;margin-right:6px;transition:transform .12s ease}.credential-panel[open] summary{margin-bottom:6px}.credential-panel[open] summary:before{transform:rotate(90deg)}.shop-list{display:grid;gap:6px;max-height:none;flex:1;min-height:0;overflow-y:auto;padding-right:4px;max-height:42vh}.shop-list::-webkit-scrollbar{width:8px}.shop-list::-webkit-scrollbar-thumb{background:#d8bfd8;border-radius:999px}.shop-item{text-align:left;width:100%;border:1px solid #dccbe8;border-radius:12px;background:#fff8ff;color:#2b1d34;padding:8px;display:grid;gap:3px;position:relative;overflow:hidden;line-height:1.25}.shop-item strong,.shop-item span,.shop-item em{position:relative;z-index:2}.shop-item em{color:var(--ink-soft);font-style:normal;font-size:.9rem}.shop-effect-line{color:#5e4b70;font-size:.84rem;font-weight:700}.shop-item:disabled{border-style:dashed;background:#f5f0f8;color:#7d7390;opacity:.95}.shop-item-buyable{border-color:#ffa34e;box-shadow:0 0 0 1px #ffa34e59,0 0 16px #ffa34e4d;animation:shopPulse 1s ease-in-out infinite alternate}.shop-item-buyable:after{content:"";position:absolute;top:-120%;left:-40%;width:35%;height:260%;background:linear-gradient(90deg,transparent,rgba(255,234,182,.55),transparent);transform:rotate(24deg);animation:shopShine 1.8s linear infinite;z-index:1;pointer-events:none}.shop-item-bought{animation:boughtBurst .5s ease;border-color:#67c28c}.shop-section-toggle{width:100%;padding:8px;border-radius:8px;border:1px dashed #b09cc0;background:#b09cc01f;color:var(--ink-soft);font-size:.85rem;font-weight:600;cursor:pointer;text-align:center;transition:background .15s}.shop-section-toggle:hover{background:#b09cc03d}.shop-scroll-hint{text-align:center;font-size:.75rem;color:var(--ink-soft);opacity:.5;padding:4px 0 2px;pointer-events:none}@keyframes shopPulse{0%{transform:scale(1)}to{transform:scale(1.015)}}@keyframes shopShine{0%{left:-45%}to{left:125%}}@keyframes boughtBurst{0%{transform:scale(1);box-shadow:0 0 #67c28c80}50%{transform:scale(1.04);box-shadow:0 0 20px #67c28cbf}to{transform:scale(1);box-shadow:0 0 #67c28c00}}.trophy-list{display:grid;gap:4px}.trophy-list-scroll{overflow-y:auto;flex:1;min-height:0;padding-right:4px;max-height:215px}.next-trophy-box{border:1px solid #ead4b6;background:#fff7e9;border-radius:10px;padding:6px;margin-bottom:6px}.next-trophy-box strong{display:block}.next-trophy-box span{display:block;color:#6f5b44;font-size:.86rem;margin-top:2px}.trophy-meter-fill{background:linear-gradient(90deg,#f4b643,#f4842e)}.leaderboard-card{display:grid;gap:6px}.leaderboard-card-themed{background:linear-gradient(180deg,#2c7ec4,#1d5f9f);border:1px solid #5ea5de;box-shadow:inset 0 0 0 1px #ffffff29,0 10px 24px #122c4f59}.leaderboard-card-themed h2,.leaderboard-card-themed .leaderboard-subline,.leaderboard-card-themed .live-toggle,.leaderboard-card-themed .mini-status{color:#eaf5ff}.leaderboard-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.leaderboard-subline{margin:0;color:#6a4d7a;font-size:.8rem}.leaderboard-actions{display:flex;align-items:center;gap:8px}.live-toggle{display:inline-flex;align-items:center;gap:4px;font-size:.85rem;color:#6a4d7a}.live-dot{width:9px;height:9px;border-radius:50%;display:inline-block}.live-dot.on{background:#2acb6b;box-shadow:0 0 10px #2acb6bcc;animation:livePulse .9s ease-in-out infinite alternate}.live-dot.off{background:#bfb5cc}.leaderboard-list{display:grid;gap:4px;max-height:42vh;flex:1;min-height:0;overflow-y:auto;padding-right:2px}.leaderboard-row{border:1px solid rgba(182,220,255,.55);background:linear-gradient(180deg,#216cb3f2,#18528ef2);border-radius:8px;padding:6px 8px;display:grid;gap:6px;grid-template-columns:28px 34px minmax(0,1fr) auto;align-items:center;color:#ecf7ff}.leaderboard-row-top{display:flex;justify-content:flex-start;align-items:center;gap:8px;min-width:0}.leaderboard-rank-lane{font-weight:800;color:#d9efff;font-size:1rem;text-align:center}.leaderboard-avatar{width:28px;height:28px;border-radius:999px;background:linear-gradient(180deg,#f6fbff,#b8dfff);border:1px solid rgba(255,255,255,.8);color:#1e4f86;display:grid;place-items:center;font-size:.65rem;font-weight:800}.leaderboard-gold{font-weight:700;color:#ffe580;text-shadow:0 0 8px rgba(255,229,128,.4);justify-self:end}.leaderboard-row.current-player{border-color:#ffe999;box-shadow:0 0 0 1px #ffe9998c,0 0 14px #ffe99966}.leaderboard-row span{color:#d9efff;font-size:.83rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trophy-item{border:1px solid #e2d9ec;border-radius:10px;padding:6px;display:grid;gap:3px}.trophy-item.earned{border-color:#efc95b;background:#fff8df}.bottom-layout{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}.number-key{display:grid;gap:2px;font-size:.88rem}.number-key-row{display:grid;grid-template-columns:44px 1fr;gap:8px;border-bottom:1px dashed #e6dbef;padding-bottom:2px}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#2b2438ad;display:flex;align-items:center;justify-content:center;padding:12px}.quiz-only-screen{height:100%;display:grid;gap:10px;align-content:start}.quiz-only-card{border:1px solid #e8d8ee;border-radius:12px;background:#fff8ff;padding:12px}.modal-card{width:min(520px,100%);background:var(--card);border:1px solid var(--border);border-radius:16px;padding:12px}.quiz-answers{display:grid;gap:6px}.quiz-answers button{border:1px solid #dccbe8;border-radius:10px;background:#fff8ff;padding:8px;cursor:pointer;text-align:left}.quiz-answers button:hover{background:#ffeef8}.star-rush-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#150c1e73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:90;pointer-events:auto}.star-rush-banner{position:absolute;top:18px;left:50%;transform:translate(-50%);background:linear-gradient(90deg,#ff9f4d,#ff4d7b,#69d0ff);color:#fff;font-weight:800;padding:10px 14px;border-radius:999px;box-shadow:0 0 22px #ff69378c;animation:rushBannerPop .6s ease-in-out infinite alternate}.rush-star{position:absolute;width:74px;height:74px;transform:translate(-50%,-50%);border-radius:50%;border:0;background:transparent;cursor:pointer;box-shadow:none;animation:rushStarPulse .65s ease-in-out infinite alternate,rushStarDrift var(--drift-seconds, 3.2s) ease-in-out infinite alternate}.rush-star:hover{filter:brightness(1.08)}.rush-star-core{display:grid;place-items:center;width:100%;height:100%;color:#ffbf1f;font-size:3rem;line-height:1;text-shadow:0 0 10px rgba(255,234,140,.95),0 0 24px rgba(255,185,44,.8),0 0 36px rgba(255,146,0,.55);animation:starTwinkle .9s ease-in-out infinite alternate;animation-delay:var(--twinkle-delay, 0s)}.rainbow-trail{position:fixed;left:var(--from-x);top:var(--from-y);width:16px;height:16px;border-radius:50%;background:conic-gradient(#ff4d4d,#ffb84d,#f9ff4d,#5cff7a,#4dd6ff,#af6bff,#ff4db8);box-shadow:0 0 16px #ffffffd9;z-index:95;animation:rainbowToGold .8s ease-out forwards}@keyframes rushBannerPop{0%{transform:translate(-50%) scale(1)}to{transform:translate(-50%) scale(1.04)}}@keyframes rushStarPulse{0%{transform:translate(-50%,-50%) scale(.96)}to{transform:translate(-50%,-50%) scale(1.08)}}@keyframes rushStarDrift{0%{margin-left:0;margin-top:0}to{margin-left:var(--drift-x, 0);margin-top:var(--drift-y, 0)}}@keyframes starTwinkle{0%{opacity:.9;filter:brightness(.96)}to{opacity:1;filter:brightness(1.1)}}@keyframes rainbowToGold{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(-44vw,-42vh) scale(.2)}}@keyframes livePulse{0%{transform:scale(1);opacity:.85}to{transform:scale(1.18);opacity:1}}@media (max-width: 980px){body{overflow:auto}.app-shell{height:auto;overflow:visible}.main-layout,.bottom-layout{grid-template-columns:1fr}.left-stack,.right-stack{grid-template-rows:auto}.shop-list,.trophy-list-scroll,.leaderboard-list{max-height:240px}.status-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.dog-park-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.top-bar{grid-template-columns:1fr}.top-actions{width:100%;justify-content:flex-start;min-width:0}.top-trophy-status{white-space:normal}.theme-picker,.custom-theme-controls{width:100%}}@media (max-width: 560px){.app-shell{padding:10px}.stats-grid,.status-strip{grid-template-columns:1fr}}
