:root{--bg:#f0f1f5;--bg-deep:#e4e6ed;--panel:#ffffff;--panel-raised:#f8f9fc;--border:#d6d9e3;--border-glow:rgba(0, 188, 255, 0.25);--text:#1a1d2e;--text-muted:#6b7180;--text-dim:#9ba3b5;--accent:#00bcff;--accent-dim:rgba(0, 188, 255, 0.18);--accent-glow:rgba(0, 188, 255, 0.35);--accent-dark:#0095cc;--correct:#00bcff;--incorrect:#ff3b5c;--incorrect-bg:rgba(255, 59, 92, 0.12);--shadow-sm:0 1px 3px rgba(0,0,0,0.06),0 1px 2px rgba(0,0,0,0.04);--shadow-md:0 4px 12px rgba(0,0,0,0.08),0 2px 4px rgba(0,0,0,0.04);--shadow-lg:0 12px 32px rgba(0,0,0,0.10),0 4px 8px rgba(0,0,0,0.05);--font-ui:'DM Sans',system-ui,-apple-system,sans-serif;--font-mono:'JetBrains Mono','Fira Code','Consolas',monospace;--transition:0.2s cubic-bezier(0.4, 0, 0.2, 1);--primary:var(--accent);--box-bg:var(--panel);--bg-color:var(--bg);--text-color:var(--text);--text-gray:var(--text-muted);--border-color:var(--border);--highlight-blue:var(--correct);--highlight-red:var(--incorrect);--shadow:var(--shadow-sm);--dot-color:rgba(155, 163, 181, 0.45)}body.dark{--bg:#0d0d10;--bg-deep:#070708;--panel:#161720;--panel-raised:#1e1f2e;--border:#252636;--border-glow:rgba(0, 188, 255, 0.20);--text:#e8eaf0;--text-muted:#6e7491;--text-dim:#3d4060;--accent:#00d4ff;--accent-dim:rgba(0, 212, 255, 0.14);--accent-glow:rgba(0, 212, 255, 0.30);--accent-dark:#00aacc;--correct:#00d4ff;--incorrect:#ff3b5c;--incorrect-bg:rgba(255, 59, 92, 0.12);--shadow-sm:0 1px 3px rgba(0,0,0,0.35),0 1px 2px rgba(0,0,0,0.25);--shadow-md:0 4px 16px rgba(0,0,0,0.45),0 2px 6px rgba(0,0,0,0.30);--shadow-lg:0 16px 48px rgba(0,0,0,0.55),0 6px 16px rgba(0,0,0,0.35);--primary:var(--accent);--box-bg:var(--panel);--bg-color:var(--bg);--text-color:var(--text);--text-gray:var(--text-muted);--border-color:var(--border);--highlight-blue:var(--correct);--highlight-red:var(--incorrect);--shadow:var(--shadow-sm);--dot-color:rgba(61, 64, 96, 0.8)}*,::after,::before{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth;overflow-x:hidden}body{font-family:var(--font-ui);background-color:var(--bg);color:var(--text);display:flex;flex-direction:column;align-items:center;min-height:100vh;transition:background-color .35s ease,color .35s ease,border-color .35s ease;padding:20px 16px;background-image:radial-gradient(circle,var(--dot-color) 1px,transparent 1px);background-size:28px 28px;position:relative;overflow-x:hidden}body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 50% 0,transparent 50%,var(--bg-deep) 100%);pointer-events:none;z-index:0}body>*{position:relative;z-index:1}h1{font-family:var(--font-ui);font-size:1.35rem;font-weight:700;letter-spacing:-.02em}header{width:100%;max-width:860px;display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:14px 20px;background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-md);transition:background-color .35s ease,border-color .35s ease,box-shadow .35s ease}.header-title{display:flex;align-items:center;gap:10px;font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.header-title .app-icon-rect{fill:var(--panel)}.header-title .app-icon-t{fill:var(--accent)}.app-icon{width:34px;height:34px;flex-shrink:0;filter:drop-shadow(0 0 6px var(--accent-glow))}.header-btns{display:flex;gap:8px;align-items:center}.theme-toggle{background:var(--panel-raised);border:1px solid var(--border);cursor:pointer;color:var(--text-muted);padding:0;border-radius:10px;transition:background-color var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition),transform .1s ease;line-height:1;display:flex;align-items:center;justify-content:center;width:42px;height:42px;min-width:42px;min-height:42px}@media (hover:hover){.theme-toggle:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}}.theme-toggle:active{transform:scale(.92);opacity:.8}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.theme-toggle svg{width:18px;height:18px;stroke:currentColor;flex-shrink:0}.moon-icon,.sun-icon{animation:theme-icon-in .3s cubic-bezier(.34,1.2,.64,1) both}@keyframes theme-icon-in{from{opacity:0;transform:rotate(-20deg) scale(.65)}to{opacity:1;transform:rotate(0) scale(1)}}.header-left{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}#player-name-tag{font-size:.75rem;font-weight:700;color:var(--text-muted);letter-spacing:.01em;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:44px}.config-bar{width:100%;max-width:860px;display:flex;justify-content:center;align-items:center;margin-bottom:16px;gap:10px;flex-wrap:wrap}.mode-toggle{display:flex;background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);padding:3px;gap:2px;transition:background-color .35s ease,border-color .35s ease}.mode-btn{padding:10px 18px;border:none;background:0 0;color:var(--text-muted);cursor:pointer;font-family:var(--font-ui);font-size:.875rem;font-weight:700;border-radius:9px;transition:background-color var(--transition),color var(--transition),box-shadow var(--transition),transform .1s ease;min-height:44px;letter-spacing:.01em}.mode-btn.active{background:var(--accent);color:#000;box-shadow:0 0 16px var(--accent-glow),0 2px 6px rgba(0,0,0,.2);animation:mode-activate .35s cubic-bezier(.34,1.2,.64,1) both}@keyframes mode-activate{0%{transform:scale(1.04)}100%{transform:scale(1)}}.mode-btn:hover:not(.active){background:rgba(128,128,128,.12);color:var(--text)}.mode-btn:active{transform:scale(.96)}.mode-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.difficulty-toggle{display:flex;background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);padding:3px;gap:2px;transition:background-color .35s ease,border-color .35s ease}.difficulty-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;background:0 0;color:var(--text-muted);cursor:pointer;font-family:var(--font-ui);font-size:.825rem;font-weight:700;border-radius:9px;transition:background-color var(--transition),color var(--transition),box-shadow var(--transition),transform .1s ease;min-height:44px;letter-spacing:.01em;white-space:nowrap}.difficulty-btn svg{width:15px;height:15px;flex-shrink:0}.difficulty-btn.active{background:var(--accent);color:#000;box-shadow:0 0 16px var(--accent-glow),0 2px 6px rgba(0,0,0,.2);animation:mode-activate .35s cubic-bezier(.34,1.2,.64,1) both}.difficulty-btn:hover:not(.active){background:rgba(128,128,128,.12);color:var(--text)}.difficulty-btn:active{transform:scale(.96)}.difficulty-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.stats-container{display:flex;justify-content:space-between;width:100%;max-width:860px;margin-bottom:16px;background:var(--panel);padding:0;border-radius:16px;box-shadow:var(--shadow-md);border:1px solid var(--border);overflow:hidden;transition:background-color .35s ease,border-color .35s ease}.stat-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 12px;flex:1;position:relative;border-left:1px solid var(--border);transition:background-color var(--transition),border-color .35s ease}.stat-item:first-child{border-left:none}.stat-item::after{content:'';position:absolute;bottom:0;left:15%;right:15%;height:2px;background:var(--accent);border-radius:2px 2px 0 0;opacity:0;transition:opacity var(--transition),left var(--transition),right var(--transition)}.stat-item:hover::after{opacity:.7;left:5%;right:5%}.stat-label{font-family:var(--font-ui);font-size:.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:5px}.stat-value{font-family:var(--font-mono);font-size:1.6rem;font-weight:700;color:var(--text);letter-spacing:-.04em;line-height:1;transition:color .15s ease}.stat-item.stat-flash{animation:stat-flash .3s ease-out}@keyframes stat-flash{0%{background:rgba(76,175,80,.25)}100%{background:0 0}}.typing-area{position:relative;width:100%;max-width:860px;background:var(--panel);border-radius:16px;padding:30px 28px;box-shadow:var(--shadow-md);border:1px solid var(--border);min-height:180px;cursor:text;transition:border-color .25s ease,box-shadow .25s ease,background-color .35s ease}.typing-area:focus-within{border-color:var(--border-glow);box-shadow:var(--shadow-md),0 0 0 1px var(--accent-dim),inset 0 0 40px rgba(0,188,255,.03)}.typing-area.empty .text-display::before{content:'Start typing to begin...';position:absolute;top:30px;left:28px;right:28px;font-family:var(--font-mono);font-size:1.15rem;color:var(--text-dim);pointer-events:none;opacity:1;letter-spacing:.02em}.text-display{font-family:var(--font-mono);font-size:1.2rem;line-height:1.8;color:var(--text-muted);user-select:none;white-space:pre-wrap;word-break:break-word;position:relative;letter-spacing:.02em}.text-display span{transition:color 80ms ease}.text-display span.correct{color:var(--correct)}.text-display span.incorrect{color:var(--incorrect);background-color:var(--incorrect-bg);border-radius:3px}.text-display span.current{border-bottom:2px solid var(--accent);color:var(--text);animation:caret-blink 1s step-end infinite}@keyframes caret-blink{0%,100%{opacity:1}50%{opacity:.4}}.lives-display{position:absolute;top:10px;right:12px;display:flex;align-items:center;gap:8px;z-index:10;pointer-events:none}.lives-hearts{display:flex;gap:4px;align-items:center}.heart{width:18px;height:18px;color:#ef4444;transition:opacity .3s ease,transform .3s ease}.heart svg{width:100%;height:100%;fill:currentColor}.heart.lost{opacity:.2;transform:scale(.8)}.heart.breaking{animation:heart-break .4s ease-out forwards}@keyframes heart-break{0%{transform:scale(1);opacity:1}30%{transform:scale(1.3);opacity:.8}100%{transform:scale(.6);opacity:.2}}.idle-ring-container{width:36px;height:36px;position:relative}.idle-ring{width:100%;height:100%}.idle-ring-bg{stroke:var(--border)}.idle-ring-progress{stroke:var(--accent);transition:stroke .3s ease;stroke-linecap:round}.idle-ring-container.danger .idle-ring-progress{stroke:#ef4444}.encouragement-toast{position:absolute;top:10px;left:50%;transform:translateX(-50%) translateY(-10px);background:var(--panel-raised);border:1px solid var(--border-glow);border-radius:10px;padding:8px 16px;font-family:var(--font-ui);font-size:.82rem;font-weight:700;color:var(--text);z-index:15;pointer-events:none;opacity:0;transition:opacity .3s ease,transform .3s cubic-bezier(.34, 1.08, .64, 1);white-space:nowrap;box-shadow:var(--shadow-md);will-change:transform,opacity}.encouragement-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.encouragement-toast.warning{border-color:#ef4444;color:#ef4444}.encouragement-toast.success{border-color:#22c55e;color:#22c55e}.encouragement-toast.record{border-color:gold;color:gold;font-size:.9rem}.encouragement-toast.fire{border-color:#ff9800;color:#ff9800}.typing-area.streak-warm{box-shadow:var(--shadow-md),0 0 15px rgba(255,152,0,.15)}.typing-area.streak-hot{box-shadow:var(--shadow-md),0 0 20px rgba(255,87,34,.25)}.typing-area.streak-fire{animation:streak-pulse 1.5s ease-in-out infinite}.typing-area.streak-inferno{animation:streak-pulse-intense .8s ease-in-out infinite}@keyframes streak-pulse{0%,100%{box-shadow:var(--shadow-md),0 0 20px rgba(255,61,0,.3)}50%{box-shadow:var(--shadow-md),0 0 35px rgba(255,61,0,.45)}}@keyframes streak-pulse-intense{0%,100%{box-shadow:var(--shadow-md),0 0 30px rgba(244,67,54,.5)}50%{box-shadow:var(--shadow-md),0 0 50px rgba(244,67,54,.7)}}.typing-area.word-pop{animation:word-pop .3s cubic-bezier(.34,1.56,.64,1)}@keyframes word-pop{0%{transform:scale(1)}40%{transform:scale(1.008)}100%{transform:scale(1)}}.bonus-word:not(.correct):not(.incorrect){color:gold;text-shadow:0 0 8px rgba(255,215,0,.3)}.typing-area.song-mode{min-height:400px;padding:0;overflow:hidden;cursor:default}.typing-area.song-mode #input-field{pointer-events:none;z-index:-1}#song-game{width:100%;height:400px;position:relative;background:linear-gradient(180deg,var(--bg-deep) 0,var(--panel) 100%);transition:transform .1s;contain:layout style paint}#song-game.shake{animation:shake .3s;will-change:transform}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.lane{width:70px;height:70px;border:2px solid var(--border);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;color:var(--text-muted);transition:background-color var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition),transform .1s ease;position:relative;cursor:pointer;user-select:none;padding:0;background:var(--panel-raised)}.lane:hover{border-color:var(--accent);transform:scale(1.04);box-shadow:0 0 16px var(--accent-glow)}.lane svg{width:30px;height:30px;stroke:currentColor;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;fill:none}#lane-left.active{border-color:#e91e63;background:#e91e63;color:#fff;transform:scale(1.08);box-shadow:0 0 28px rgba(233,30,99,.7),0 0 50px rgba(233,30,99,.35);animation:lane-punch .25s cubic-bezier(.34,1.2,.64,1) both}#lane-up.active{border-color:#2196f3;background:#2196f3;color:#fff;transform:scale(1.08);box-shadow:0 0 28px rgba(33,150,243,.7),0 0 50px rgba(33,150,243,.35);animation:lane-punch .25s cubic-bezier(.34,1.2,.64,1) both}#lane-down.active{border-color:#ff9800;background:#ff9800;color:#fff;transform:scale(1.08);box-shadow:0 0 28px rgba(255,152,0,.7),0 0 50px rgba(255,152,0,.35);animation:lane-punch .25s cubic-bezier(.34,1.2,.64,1) both}#lane-right.active{border-color:#4caf50;background:#4caf50;color:#fff;transform:scale(1.08);box-shadow:0 0 28px rgba(76,175,80,.7),0 0 50px rgba(76,175,80,.35);animation:lane-punch .25s cubic-bezier(.34,1.2,.64,1) both}@keyframes lane-punch{0%{transform:scale(1.15)}60%{transform:scale(.95)}100%{transform:scale(1.08)}}.lane.active{border-color:var(--accent);background:var(--accent);color:#000;transform:scale(1.08);box-shadow:0 0 24px var(--accent-glow);animation:lane-punch .25s cubic-bezier(.34,1.2,.64,1) both}.lane:active:not(.active){transform:scale(.94)}.note{position:absolute;width:60px;height:60px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:#fff;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));z-index:10;border:3px solid rgba(255,255,255,.8);contain:layout style paint;animation:note-spawn .1s cubic-bezier(.34,1.2,.64,1) both}@keyframes note-spawn{from{opacity:0}to{opacity:1}}.note.trail{position:absolute;width:60px;height:60px;border-radius:10px;opacity:.2;z-index:5;pointer-events:none;animation:none}.note.left{background:linear-gradient(135deg,#ff4081,#e91e63,#c2185b);filter:drop-shadow(0 0 12px rgba(233, 30, 99, .5))}.note.up{background:linear-gradient(135deg,#64b5f6,#2196f3,#1976d2);filter:drop-shadow(0 0 12px rgba(33, 150, 243, .5))}.note.down{background:linear-gradient(135deg,#ffb74d,#ff9800,#f57c00);filter:drop-shadow(0 0 12px rgba(255, 152, 0, .5))}.note.right{background:linear-gradient(135deg,#81c784,#4caf50,#388e3c);filter:drop-shadow(0 0 12px rgba(76, 175, 80, .5))}.note.double{border:4px solid gold;box-shadow:0 0 40px gold,0 6px 20px rgba(0,0,0,.5)}.note.speed-burst{border:4px solid #ff6b6b;animation:speedPulse .4s cubic-bezier(.45,0,.55,1) infinite}@keyframes speedPulse{0%,100%{opacity:1}50%{opacity:.7}}.note svg{width:36px;height:36px;stroke:white;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;fill:none;filter:drop-shadow(0 0 10px rgba(255,255,255,.8))}.hit-zone{position:absolute;bottom:10px;width:100%;height:80px;display:flex;justify-content:center;gap:20px;align-items:center;z-index:20}.start-btn{position:absolute;top:45%;left:50%;transform:translate(-50%,-50%);padding:18px 40px;font-family:var(--font-mono);font-size:1.25rem;font-weight:700;letter-spacing:.08em;background:var(--accent);color:#000;border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 20px var(--accent-glow),0 2px 8px rgba(0,0,0,.3);transition:box-shadow .2s ease,transform .15s ease;z-index:100}.start-btn:hover{transform:translate(-50%,-50%) scale(1.06);box-shadow:0 6px 28px var(--accent-glow),0 4px 12px rgba(0,0,0,.35)}.start-btn:active{transform:translate(-50%,-50%) scale(.96)}.start-btn.hidden{display:none}.multiplier-display{position:absolute;top:20px;right:20px;font-family:var(--font-mono);font-size:2.25rem;font-weight:700;color:var(--accent);text-shadow:0 0 20px var(--accent-glow);animation:pulse .5s ease-in-out infinite;will-change:transform}.multiplier-display.legendary{color:gold;text-shadow:0 0 20px gold,0 0 40px orange;border:3px solid gold;border-radius:12px;padding:5px 15px}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}.phase-indicator{position:absolute;top:10px;left:10px;font-family:var(--font-mono);font-size:.8rem;font-weight:700;letter-spacing:.06em;color:var(--text);background:var(--panel);padding:6px 12px;border-radius:8px;border:1px solid var(--border);box-shadow:var(--shadow-sm);z-index:15;transition:all .3s}.phase-indicator.phase-1{border-color:#4caf50;color:#4caf50}.phase-indicator.phase-2{border-color:#ff9800;color:#ff9800}.phase-indicator.phase-3{border-color:#f44336;color:#f44336;background:#1a0a0a}.progress-bar{position:absolute;top:10px;right:80px;width:120px;height:5px;background:var(--border);border-radius:3px;overflow:hidden;z-index:15}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#ff9800,#f44336);border-radius:3px;transition:width .3s;width:0%}.progress-milestone{position:absolute;top:0;width:1px;height:100%;background:rgba(255,255,255,.3);z-index:16}.speed-indicator{position:absolute;top:10px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:.75rem;font-weight:700;letter-spacing:.06em;color:var(--text);background:var(--panel);padding:5px 12px;border-radius:8px;border:1px solid var(--border);z-index:15}.speed-indicator.speed-1{color:#4caf50;border-color:#4caf50}.speed-indicator.speed-2{color:#ff9800;border-color:#ff9800}.speed-indicator.speed-3{color:#f44336;border-color:#f44336}.particle{position:absolute;width:6px;height:6px;border-radius:50%;pointer-events:none;animation:particle-burst .2s ease-out forwards;will-change:transform,opacity;contain:layout style paint}@keyframes particle-burst{0%{transform:translate(0,0) scale(1);opacity:1}100%{transform:translate(var(--tx),var(--ty)) scale(0);opacity:0}}.combo-text{position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:3rem;font-weight:700;color:var(--accent);text-shadow:0 0 20px var(--accent-glow);animation:combo-pop .55s cubic-bezier(.34,1.2,.64,1) forwards;pointer-events:none;z-index:50;will-change:transform,opacity;contain:layout style paint}@keyframes combo-pop{0%{transform:translate(-50%,-50%) scale(.2);opacity:0}45%{transform:translate(-50%,-50%) scale(1.18);opacity:1}70%{transform:translate(-50%,-50%) scale(.95);opacity:1}100%{transform:translate(-50%,-50%) scale(1);opacity:0}}.rating-text{position:absolute;font-family:var(--font-mono);font-size:1.8rem;font-weight:700;pointer-events:none;animation:rating-float .85s cubic-bezier(.25,.46,.45,.94) forwards;z-index:60;background:rgba(0,0,0,.7);padding:6px 14px;border-radius:8px;will-change:transform,opacity;contain:layout style paint;letter-spacing:.04em}.rating-text.perfect{color:gold;text-shadow:0 3px 10px rgba(0,0,0,.9),0 0 25px gold,0 0 40px gold}.rating-text.good{color:#66bb6a;text-shadow:0 3px 10px rgba(0,0,0,.9),0 0 20px #4caf50,0 0 35px #4caf50}.rating-text.miss{color:#ef5350;text-shadow:0 3px 10px rgba(0,0,0,.9),0 0 20px #f44336,0 0 35px #f44336}.rating-text.amazing{color:#00e5ff;text-shadow:0 3px 10px rgba(0,0,0,.9),0 0 30px #00e5ff,0 0 50px #00e5ff}@keyframes rating-float{0%{transform:translateY(0) scale(.6);opacity:1}30%{transform:translateY(-20px) scale(1.05);opacity:1}100%{transform:translateY(-70px) scale(1);opacity:0}}.milestone-message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:2.8rem;font-weight:700;color:#fff;text-shadow:0 0 20px currentColor,0 0 40px currentColor;z-index:100;animation:milestonePop 1.5s ease-out forwards;pointer-events:none;text-align:center;will-change:transform,opacity;contain:layout style paint}@keyframes milestonePop{0%{transform:translate(-50%,-50%) scale(0);opacity:0}20%{transform:translate(-50%,-50%) scale(1.2);opacity:1}40%{transform:translate(-50%,-50%) scale(1);opacity:1}80%{transform:translate(-50%,-50%) scale(1.1);opacity:1}100%{transform:translate(-50%,-50%) scale(1.5);opacity:0}}.milestone-message.speed-up{color:#ff6b6b;text-shadow:0 0 30px #ff6b6b,0 0 60px #ff6b6b}.milestone-message.milestone{color:gold}.confetti{position:absolute;width:8px;height:8px;z-index:90;pointer-events:none;will-change:transform,opacity;contain:layout style paint;animation:confetti-fall .4s ease-out forwards}@keyframes confetti-fall{0%{transform:translate(0,0) rotate(0);opacity:1}100%{transform:translate(var(--tx),var(--ty)) rotate(var(--rotation));opacity:0}}#input-field{position:absolute;opacity:0;top:0;left:0;height:100%;width:100%;z-index:5;cursor:text;font-size:16px;font-family:var(--font-mono);pointer-events:auto}.controls{margin-top:20px;display:flex;gap:12px;margin-bottom:20px;width:100%;max-width:860px}button.reset-btn{flex:1;background:var(--accent);color:#000;border:none;padding:14px 24px;border-radius:12px;font-family:var(--font-ui);font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .18s cubic-bezier(.34, 1.2, .64, 1),box-shadow var(--transition);letter-spacing:.01em;box-shadow:0 4px 16px var(--accent-glow),var(--shadow-sm)}button.reset-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--accent-glow),var(--shadow-md)}button.reset-btn:active{transform:translateY(1px) scale(.97);box-shadow:0 2px 10px var(--accent-glow)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);display:flex;justify-content:center;align-items:center;z-index:100;opacity:0;pointer-events:none;contain:layout style paint;transition:opacity .3s ease}.modal-overlay.active{opacity:1;pointer-events:auto}.modal{background:var(--panel);padding:32px;border-radius:20px;width:90%;max-width:420px;text-align:center;box-shadow:var(--shadow-lg),0 0 60px rgba(0,0,0,.3);border:1px solid var(--border);animation:modal-in .25s cubic-bezier(.34,1.08,.64,1)}@keyframes modal-in{from{transform:scale(.92) translateY(12px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.modal h2{margin-bottom:24px;font-family:var(--font-ui);font-size:1.4rem;font-weight:700;letter-spacing:-.3px}.result-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.result-item{background:var(--panel-raised);border:1px solid var(--border);border-radius:12px;padding:14px 10px;position:relative;overflow:hidden}.result-item::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent);opacity:.5}.result-item h3{font-family:var(--font-ui);font-size:.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:6px}.result-item p{font-family:var(--font-mono);font-size:1.6rem;font-weight:700;color:var(--text);letter-spacing:-.04em;line-height:1}.show-more-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;margin:4px 0 0;background:0 0;border:1px solid var(--border);border-radius:10px;color:var(--text-muted);font-family:var(--font-ui);font-size:.8rem;font-weight:700;cursor:pointer;transition:color var(--transition),background-color var(--transition)}.show-more-btn svg{width:14px;height:14px;transition:transform .3s ease}.show-more-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.show-more-btn:active{transform:scale(.97)}.show-more-btn.expanded svg{transform:rotate(180deg)}.more-stats{max-height:0;overflow:hidden;opacity:0;transition:max-height .35s cubic-bezier(.4, 0, .2, 1),opacity .3s ease,margin .3s ease;margin-top:0}.more-stats.expanded{max-height:400px;opacity:1;margin-top:12px}.rank-display{text-align:center;margin:-4px 0 12px}.rank-badge{display:inline-block;padding:4px 14px;border-radius:20px;font-family:var(--font-ui);font-size:.8rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid;animation:rank-pop .5s cubic-bezier(.34,1.56,.64,1) both;animation-delay:.2s;opacity:0;animation-fill-mode:forwards}@keyframes rank-pop{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:1}}.rank-badge.rank-up{animation:rank-up-shine .7s ease-out both;animation-delay:.2s}@keyframes rank-up-shine{0%{transform:scale(0);opacity:0}60%{transform:scale(1.25)}100%{transform:scale(1);opacity:1}}.next-rank{font-size:.72rem;font-family:var(--font-ui);margin-top:5px;letter-spacing:.02em;animation:fade-in-up .4s ease both;animation-delay:.55s;opacity:0;animation-fill-mode:forwards}@keyframes fade-in-up{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.result-roast{font-size:.78rem;color:var(--text-muted);font-style:italic;margin-top:6px;opacity:.8}.auto-restart{text-align:center;color:var(--text-muted);font-size:.82rem;font-family:var(--font-ui);margin:10px 0 2px;letter-spacing:.02em;min-height:1.2em;animation:pulse-text 1s ease-in-out infinite}@keyframes pulse-text{0%,100%{opacity:.55}50%{opacity:1}}#high-score-display{margin:14px 0;padding:12px 16px;background:var(--accent-dim);border:1px solid var(--border-glow);border-radius:10px;font-size:.875rem;color:var(--text)}.trophy-icon{display:inline-flex;align-items:center;vertical-align:middle;margin-right:4px;color:gold}.trophy-icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.confirm-modal{background:var(--panel);padding:28px;border-radius:18px;width:90%;max-width:360px;text-align:center;box-shadow:var(--shadow-lg);border:1px solid var(--border);animation:modal-in .22s cubic-bezier(.34,1.08,.64,1)}.confirm-modal h2{margin-bottom:12px;font-size:1.15rem;font-weight:700}.confirm-modal p{margin-bottom:22px;color:var(--text-muted);line-height:1.55;font-size:.9rem}.confirm-buttons{display:flex;gap:10px;justify-content:center}.confirm-btn{padding:11px 24px;border-radius:10px;border:none;font-family:var(--font-ui);font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .1s ease}.confirm-btn.primary{background:var(--accent);color:#000}.confirm-btn.secondary{background:var(--panel-raised);color:var(--text-muted);border:1px solid var(--border)}.confirm-btn:hover{opacity:.88}.confirm-btn:active{opacity:.75;transform:scale(.97)}footer{width:100%;max-width:860px;margin-top:24px;padding:20px 0 40px;border-top:1px solid var(--border);text-align:center;content-visibility:auto;contain-intrinsic-size:auto 120px}.footer-links{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;margin-bottom:10px}.footer-links a{color:#5d6272;text-decoration:none;font-size:.8rem;letter-spacing:.01em;position:relative;padding-bottom:2px;transition:color var(--transition)}body.dark .footer-links a{color:var(--text-muted)}.footer-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent);transition:width .25s cubic-bezier(.4, 0, .2, 1)}.footer-links a:hover{color:var(--accent)}.footer-links a:hover::after{width:100%}.footer-copyright{font-size:.75rem;color:#5d6272;margin-top:8px}body.dark .footer-copyright{color:var(--text-muted)}.legal-modal{background:var(--panel);padding:30px;border-radius:18px;width:90%;max-width:700px;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-lg);border:1px solid var(--border);transition:background-color .35s ease,border-color .35s ease}.legal-modal h2{margin-bottom:20px;color:var(--text)}.legal-modal h3{margin-top:20px;margin-bottom:10px;color:var(--text)}.legal-modal p,.legal-modal ul{line-height:1.65;color:var(--text);margin-bottom:15px;font-size:.95rem}.legal-modal ul{margin-left:20px}.legal-modal a{color:var(--accent);text-decoration:none}.legal-modal a:hover{text-decoration:underline}.close-legal-btn{margin-top:20px;padding:10px 24px;background:var(--accent);color:#000;border:none;border-radius:10px;cursor:pointer;font-family:var(--font-ui);font-size:.9rem;font-weight:700;transition:opacity .2s,transform .1s ease}.close-legal-btn:hover{opacity:.88}.close-legal-btn:active{opacity:.8;transform:scale(.97)}.tips-popup{position:fixed;bottom:90px;right:20px;width:260px;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:20px 18px 18px;box-shadow:var(--shadow-lg),0 0 30px rgba(0,0,0,.15);z-index:500;opacity:0;transform:translateY(16px);pointer-events:none;transition:opacity .3s ease,transform .3s cubic-bezier(.34, 1.08, .64, 1)}.tips-popup.show{opacity:1;transform:translateY(0);pointer-events:auto}.tips-popup-close{position:absolute;top:10px;right:10px;background:0 0;border:none;cursor:pointer;color:var(--text-muted);padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background-color var(--transition),transform .1s ease}.tips-popup-close:hover{color:var(--text);background:var(--accent-dim)}.tips-popup-close:active{transform:scale(.9)}.tips-popup-close svg{width:15px;height:15px}.tips-popup-icon{width:36px;height:36px;background:var(--accent-dim);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;color:var(--accent)}.tips-popup-icon svg{width:18px;height:18px}.tips-popup-title{font-size:.9rem;font-weight:700;color:var(--text);margin:0 0 6px;letter-spacing:-.01em}.tips-popup-body{font-size:.8rem;color:var(--text-muted);margin:0 0 14px;line-height:1.45}.tips-popup-btn{display:inline-block;background:var(--accent);color:#000;text-decoration:none;font-size:.8rem;font-weight:700;padding:8px 14px;border-radius:8px;transition:opacity var(--transition),transform .1s ease}.tips-popup-btn:hover{opacity:.85}.tips-popup-btn:active{transform:scale(.96)}.adblock-banner{position:fixed;top:0;left:0;right:0;background:var(--panel);border-bottom:2px solid var(--accent);padding:12px 20px;z-index:201;transform:translateY(-100%);transition:transform .3s cubic-bezier(.4, 0, .2, 1);box-shadow:var(--shadow-md)}.adblock-banner.show{transform:translateY(0)}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--panel);border-top:1px solid var(--border);padding:16px 20px;z-index:200;transform:translateY(100%);transition:transform .3s cubic-bezier(.4, 0, .2, 1);box-shadow:0 -4px 20px rgba(0,0,0,.12)}.cookie-banner.show{transform:translateY(0)}.cookie-content{max-width:860px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.cookie-text{flex:1;font-size:.82rem;line-height:1.5;color:var(--text-muted)}.cookie-text a{color:#006da8;text-decoration:underline}.dark .cookie-text a{color:var(--accent)}.cookie-btn{padding:9px 18px;background:var(--accent);color:#000;border:none;border-radius:8px;cursor:pointer;font-family:var(--font-ui);font-weight:700;font-size:.82rem;white-space:nowrap;transition:opacity var(--transition),transform .1s ease}.cookie-btn:hover{opacity:.88}.cookie-btn:active{opacity:.8;transform:scale(.97)}.profile-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:28px 24px;text-align:center;margin-bottom:24px;box-shadow:var(--shadow-md)}.profile-stats-row{display:flex;justify-content:center;gap:32px;flex-wrap:wrap}.profile-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.profile-stat-val{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--text)}.profile-stat-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.profile-section{margin-bottom:32px}.profile-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-top:0;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border)}.vibe-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px}.vibe-list li{background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:10px;padding:12px 16px;font-size:.92rem;color:var(--text);line-height:1.4}.vibe-list li.vibe-hook{border-left-color:#ff9800;font-weight:700}.mode-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:14px}.mode-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.mode-card-header{padding:14px 18px;font-weight:700;font-size:.95rem;font-family:var(--font-ui);color:var(--text);border-bottom:1px solid var(--border);background:var(--panel-raised)}.mode-table{width:100%;min-width:460px;border-collapse:collapse;font-size:.85rem}.mode-table th{padding:10px 14px;text-align:left;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700;border-bottom:1px solid var(--border);background:var(--panel-raised);white-space:nowrap}.mode-table td{padding:11px 14px;color:var(--text);border-bottom:1px solid var(--border);font-family:var(--font-mono);white-space:nowrap}.mode-table tr:last-child td{border-bottom:none}.mode-table td:first-child{font-family:var(--font-ui);font-weight:700;position:sticky;left:0;z-index:1;background:var(--panel);box-shadow:2px 0 4px rgba(0,0,0,.06)}.mode-table th:first-child{position:sticky;left:0;z-index:1;background:var(--panel-raised);box-shadow:2px 0 4px rgba(0,0,0,.06)}.mode-table tr.diff-baby td:first-child{color:#4caf50}.mode-table tr.diff-standard td:first-child{color:var(--accent)}.mode-table tr.diff-hard td:first-child{color:#ef5350}.dna-bar-group{margin-bottom:14px}.dna-label{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-muted);margin-bottom:6px}.dna-track{height:8px;background:var(--panel-raised);border-radius:4px;overflow:hidden;border:1px solid var(--border)}.dna-fill{height:100%;border-radius:4px;transition:width .8s cubic-bezier(.4, 0, .2, 1)}.dna-baby{background:#4caf50}.dna-standard{background:var(--accent)}.dna-hard{background:#ef5350}.badges-grid{display:flex;flex-wrap:wrap;gap:10px}.badge-chip{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:8px 14px;font-size:.82rem;font-weight:700;color:var(--text);font-family:var(--font-ui)}.badge-chip svg{width:14px;height:14px;color:var(--accent);flex-shrink:0}.profile-username-section{text-align:center;margin-bottom:24px;padding:20px 24px;background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-md)}.profile-username-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);margin-bottom:8px}.profile-username-row{display:flex;align-items:center;justify-content:center;gap:12px}.profile-username-display{font-size:1.6rem;font-weight:700;color:var(--text);font-family:var(--font-ui);letter-spacing:-.02em}.profile-edit-btn{padding:6px 14px;background:var(--accent-dim);border:1px solid var(--border-glow);border-radius:20px;color:var(--accent);font-size:.75rem;font-weight:700;cursor:pointer;transition:background-color var(--transition),border-color var(--transition),transform .1s ease;font-family:var(--font-ui);letter-spacing:.02em}.profile-edit-btn:hover{background:var(--accent);color:#000;border-color:var(--accent)}.profile-edit-btn:active{transform:scale(.94)}.username-modal-desc{color:var(--text-muted);font-size:.85rem;margin-bottom:16px!important}.username-modal-input{width:100%;padding:10px;border:1px solid var(--border);border-radius:8px;background:var(--panel-raised);color:var(--text);font-family:var(--font-ui);font-size:.95rem;box-sizing:border-box;margin-bottom:12px;outline:0;transition:border-color var(--transition)}.username-modal-input:focus{border-color:var(--accent)}.confirm-modal .username-modal-error{color:#ef5350!important;font-size:.8rem;margin-bottom:12px;min-height:16px}.username-modal-buttons{display:flex;gap:10px;justify-content:center}.table-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:20px 0;border-radius:12px;border:1px solid var(--border)}.blog-table,article table{width:100%;min-width:400px;border-collapse:collapse;font-size:.88rem;font-family:var(--font-ui)}.blog-table th,article table th{background:var(--panel-raised);color:var(--text-muted);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.blog-table td,article table td{padding:10px 14px;color:var(--text);border-bottom:1px solid var(--border);vertical-align:top;line-height:1.45}.blog-table tr:last-child td,article table tr:last-child td{border-bottom:none}.blog-table tr:nth-child(2n) td,article table tr:nth-child(2n) td{background:var(--panel-raised)}@media (max-width:768px){.config-bar{justify-content:center}.lane{width:70px;height:70px}.hit-zone{gap:10px}.stats-container{border-radius:14px}.stat-value{font-size:1.3rem}.stats-container{overflow-x:auto}.stat-item{min-width:0;padding:14px 8px}.controls{margin-bottom:32px}}@media (max-width:360px){.lane{width:60px;height:60px}.hit-zone{gap:5px}body{padding:12px 10px}.stat-value{font-size:1.1rem}.text-display{font-size:1rem}.stat-label{font-size:.58rem;letter-spacing:.08em}.lives-display{gap:5px}.heart{width:14px;height:14px}.idle-ring-container{width:28px;height:28px}.difficulty-btn{padding:8px 10px;font-size:.75rem}.difficulty-btn svg{width:13px;height:13px}}@media (min-width:1024px){body{padding:40px 60px;background-size:32px 32px}header{max-width:1080px;margin-bottom:24px;padding:16px 28px}h1{font-size:1.65rem}.header-title{font-size:1.65rem;letter-spacing:-.02em}.app-icon{width:38px;height:38px}.config-bar{max-width:1080px;margin-bottom:18px;gap:12px}.mode-btn{padding:11px 22px;font-size:.9rem}.difficulty-btn{padding:11px 20px;font-size:.85rem}.difficulty-btn svg{width:16px;height:16px}.stats-container{max-width:1080px;margin-bottom:20px}.stat-item{padding:22px 20px}.stat-label{font-size:.68rem;letter-spacing:.12em}.stat-value{font-size:2.2rem}.typing-area{max-width:1080px;padding:40px;min-height:220px}.typing-area.empty .text-display::before{font-size:1.35rem;top:40px;left:40px}.text-display{font-size:1.45rem;line-height:1.85;letter-spacing:.02em}#input-field{font-size:20px}.typing-area.song-mode{min-height:600px}#song-game{height:600px}.lane{width:100px;height:100px;border-radius:16px}.lane svg{width:40px;height:40px}.hit-zone{gap:30px}.note{width:80px;height:80px}.modal{max-width:540px}.confirm-modal{max-width:440px}.legal-modal{max-width:960px}.controls{max-width:1080px;margin-bottom:12px}footer{max-width:1080px;padding-bottom:40px}button.reset-btn{padding:16px 32px;font-size:1rem}.heart{width:22px;height:22px}.idle-ring-container{width:42px;height:42px}.lives-display{top:16px;right:18px;gap:10px}article{max-width:780px;padding:0 32px 80px}article h1{font-size:2.3rem}article h2{font-size:1.45rem;margin-top:44px}article p{font-size:1.05rem;line-height:1.8}article li{font-size:1.05rem}.page-header{max-width:780px;padding:24px 32px}.page-footer{max-width:780px;padding:24px 32px}}@media (min-width:860px){.blog-list{max-width:1020px;display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.blog-list>h1{grid-column:1/-1;margin-bottom:4px}.blog-list>#pagination{grid-column:1/-1;margin-top:4px}.blog-card{margin-bottom:0}}@media (min-width:900px){.profile-page{max-width:1100px;padding:0 36px 80px}body:has(.profile-page) .page-footer,body:has(.profile-page) .page-header{max-width:1100px}#profile-content{display:grid;grid-template-columns:300px minmax(0,1fr);gap:28px;align-items:start}#profile-content>:first-child{grid-column:1;grid-row:1;margin-bottom:0;text-align:left}#profile-content>:nth-child(2){grid-column:1;grid-row:2;margin-bottom:0}#profile-content>:nth-child(3){grid-column:2;grid-row:1;margin-bottom:0;min-width:0}#profile-content>:nth-child(4){grid-column:2;grid-row:2;margin-bottom:0;min-width:0}#profile-content>:nth-child(5){grid-column:2;grid-row:3;margin-bottom:0;min-width:0}.profile-stat-val{font-size:1.8rem}.profile-stats-row{gap:24px;justify-content:flex-start}.profile-card{padding:28px}}@media (min-width:1440px){body{padding:52px 80px}header{max-width:1140px}.config-bar{max-width:1140px}.stats-container{max-width:1140px}.typing-area{max-width:1140px;padding:44px 48px}.controls{max-width:1140px}footer{max-width:1140px}.text-display{font-size:1.6rem;line-height:1.9}.stat-value{font-size:2.6rem}.stat-label{font-size:.72rem}h1{font-size:1.85rem}.header-title{font-size:1.85rem}#song-game{height:700px}.typing-area.song-mode{min-height:700px}.lane{width:110px;height:110px}.note{width:90px;height:90px}.blog-list{max-width:1120px}article{max-width:820px}.page-header{max-width:820px}.page-footer{max-width:820px}.profile-page{max-width:1280px}body:has(.profile-page) .page-footer,body:has(.profile-page) .page-header{max-width:1280px}#profile-content{grid-template-columns:340px minmax(0,1fr)}}.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-family:var(--font-ui);font-size:1.2rem;font-weight:700;letter-spacing:-.2px;transition:color var(--transition)}.logo svg{width:30px;height:30px;flex-shrink:0}.breadcrumb{font-size:.82rem;color:var(--text-muted);margin-bottom:20px;font-family:var(--font-ui)}.breadcrumb a{color:var(--accent);text-decoration:none}@media (hover:hover){.logo:hover{color:var(--accent)}.breadcrumb a:hover{text-decoration:underline}}article{max-width:720px;margin:0 auto;padding:0 20px 60px;font-family:var(--font-ui);width:100%;box-sizing:border-box}article h1{font-size:2rem;line-height:1.3;margin-bottom:12px;letter-spacing:-.5px;font-family:var(--font-ui)}article h2{font-size:1.35rem;margin-top:40px;margin-bottom:16px;letter-spacing:-.3px;font-family:var(--font-ui)}article h3{font-size:1.1rem;margin-top:28px;margin-bottom:12px;font-family:var(--font-ui)}article p{margin-bottom:18px;font-size:1rem;line-height:1.75;color:var(--text)}article ol,article ul{margin-bottom:18px;padding-left:24px}article li{margin-bottom:8px;font-size:1rem;line-height:1.7;color:var(--text)}.meta{color:var(--text-muted);font-size:.85rem;margin-bottom:28px}article table{width:100%;border-collapse:collapse;margin:20px 0 28px;font-size:.92rem}article td,article th{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}article th{background:var(--panel-raised);font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}article td{color:var(--text)}@media (hover:hover){article tr:hover td{background:var(--accent-dim)}}.highlight-row td{font-weight:700;color:var(--accent)}article blockquote{border-left:3px solid var(--accent);padding:14px 18px;margin:20px 0;background:var(--panel-raised);border-radius:0 10px 10px 0;font-style:italic;color:var(--text-muted)}.cta-box{background:var(--panel-raised);border:1px solid var(--border);border-top:2px solid var(--accent);border-radius:14px;padding:24px;text-align:center;margin:36px 0}.cta-box p{margin-bottom:16px;font-weight:700;font-size:1.05rem}.cta-btn{display:inline-block;background:var(--accent);color:#000;padding:12px 28px;border-radius:10px;text-decoration:none;font-weight:700;font-size:.95rem;transition:opacity .2s,transform .1s ease}@media (hover:hover){.cta-btn:hover{opacity:.88}}.cta-btn:active{transform:scale(.97)}.tag{display:inline-block;background:var(--panel-raised);border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:.75rem;color:var(--text-muted);margin:2px;font-family:var(--font-ui)}.tags{margin-top:36px}.blog-list{max-width:720px;margin:0 auto;padding:0 20px 40px}.blog-list h1{font-size:1.8rem;margin-bottom:28px}.blog-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:22px;margin-bottom:16px;transition:box-shadow var(--transition),border-color var(--transition),transform .15s ease}@media (hover:hover){.blog-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-glow);transform:translateY(-2px)}.blog-card h2 a:hover{color:var(--accent)}}.blog-card h2{font-size:1.2rem;margin-bottom:8px}.blog-card h2 a{color:var(--text);text-decoration:none}.blog-card .meta{margin-bottom:8px}.blog-card p{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin:0}.pagination{display:flex;justify-content:center;gap:8px;margin-top:28px}.page-btn{padding:8px 16px;border:1px solid var(--border);border-radius:8px;background:var(--panel);color:var(--text);cursor:pointer;font-family:var(--font-ui);font-size:.875rem;transition:border-color .2s,color .2s,background-color .2s,transform .1s ease}@media (hover:hover){.page-btn:hover{border-color:var(--accent);color:var(--accent)}}.page-btn:active{transform:scale(.95)}.page-btn.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700}.page-footer{max-width:720px;margin:0 auto;padding:20px;border-top:1px solid var(--border);text-align:center;font-size:.8rem;color:var(--text-muted);transition:border-color .35s ease}.page-footer a{color:var(--accent);text-decoration:none}@media (hover:hover){.page-footer a:hover{text-decoration:underline}}.page-header{width:100%;max-width:720px;margin:0 auto;padding:20px;display:flex;justify-content:space-between;align-items:center}@media (max-width:480px){article h1{font-size:1.45rem}article h2{font-size:1.15rem}article table{font-size:.82rem}article td,article th{padding:8px 10px}}@keyframes area-activate{0%{box-shadow:var(--shadow-md),0 0 0 3px var(--accent)}60%{box-shadow:var(--shadow-md),0 0 0 2px var(--accent-dim)}100%{box-shadow:var(--shadow-md)}}.typing-area.active{animation:area-activate .6s cubic-bezier(.4,0,.2,1) both}@keyframes fade-up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}header{animation:fade-up .5s cubic-bezier(.22,1,.36,1) both;animation-delay:0s}.config-bar{animation:fade-up .5s cubic-bezier(.22,1,.36,1) both;animation-delay:80ms}.stats-container{animation:fade-up .5s cubic-bezier(.22,1,.36,1) both;animation-delay:.16s}.typing-area{animation:fade-up .5s cubic-bezier(.22,1,.36,1) both;animation-delay:.24s}.controls{animation:fade-up .5s cubic-bezier(.22,1,.36,1) both;animation-delay:.32s}@media (max-width:480px){.profile-stats-row{gap:16px}.profile-stat-val{font-size:1.2rem}.mode-table{font-size:.72rem}.mode-table th{padding:7px 8px}.mode-table td{padding:8px 8px}.profile-card{padding:20px 16px;margin-bottom:18px}.profile-section{margin-bottom:24px}.mode-card{margin-bottom:12px}.vibe-list{gap:8px}.vibe-list li{padding:10px 12px;font-size:.85rem}.badges-grid{gap:8px}.badge-chip{padding:6px 12px;font-size:.75rem}.dna-label{font-size:.75rem}.profile-section-title{font-size:.65rem}.profile-username-section{padding:16px 18px}.profile-username-display{font-size:1.3rem}}@media (max-width:600px){.mode-table{min-width:420px;font-size:.78rem}.mode-table td,.mode-table th{padding:8px 10px}.mode-table td:last-child,.mode-table th:last-child{display:none}}