:root{--primary: #a8c5da;--primary-soft: rgba(168, 197, 218, .12);--primary-fg: #0c2d40;--secondary-soft: rgba(45, 212, 191, .15);--secondary-fg: #003d35;--secondary-container: #0d9488;--tertiary: #ffb786;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: .18s ease;--grid-size: 32px;--font-mono: "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;--font-sans: "Noto Sans SC", -apple-system, BlinkMacSystemFont, "PingFang SC", sans-serif;--font-heading: "Sora", -apple-system, BlinkMacSystemFont, sans-serif}:root[data-theme=dark],:root:not([data-theme]){--bg-spotlight: radial-gradient(ellipse 90% 60% at 60% 0%, rgba(77, 142, 255, .1), transparent 70%);--bg: #10131a;--bg-elevated: #1d2027;--panel: rgba(29, 32, 39, .65);--panel-solid: #1d2027;--panel-hover: rgba(39, 42, 49, .85);--border: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .14);--text: #e1e2ec;--text-soft: #c2c6d6;--text-faint: #8c909f;--grid-line: rgba(168, 197, 218, .04);--code-bg: #0b0e15;--code-fg: #c2c6d6;--shadow-card: 0 1px 0 rgba(255, 255, 255, .04) inset, 0 4px 24px rgba(0, 0, 0, .45);--shadow-pop: 0 12px 40px rgba(0, 0, 0, .6), 0 0 60px rgba(45, 212, 191, .1);--primary: #a8c5da;--primary-soft: rgba(168, 197, 218, .12);--primary-fg: #0c2d40;--success: #34d399;--success-soft: rgba(52, 211, 153, .14);--error: #ffb4ab;--error-soft: rgba(255, 180, 171, .14)}:root[data-theme=light]{--bg-spotlight: radial-gradient(ellipse 90% 55% at 65% 0%, rgba(77, 142, 255, .08), transparent 70%);--bg: #f0f4ff;--bg-elevated: #ffffff;--panel: rgba(255, 255, 255, .72);--panel-solid: #ffffff;--panel-hover: rgba(241, 245, 255, .85);--border: rgba(15, 23, 42, .08);--border-strong: rgba(15, 23, 42, .16);--text: #0f172a;--text-soft: #424754;--text-faint: #8c909f;--grid-line: rgba(77, 142, 255, .05);--code-bg: #0f172a;--code-fg: #e2e8f0;--shadow-card: 0 1px 2px rgba(15, 23, 42, .04), 0 8px 24px rgba(77, 142, 255, .06);--shadow-pop: 0 12px 36px rgba(15, 23, 42, .12);--primary: #4d8eff;--primary-soft: rgba(77, 142, 255, .12);--primary-fg: #ffffff;--secondary: #2dd4bf;--secondary-soft: rgba(45, 212, 191, .1);--secondary-fg: #ffffff;--success: #16a34a;--success-soft: rgba(22, 163, 74, .1);--error: #dc2626;--error-soft: rgba(220, 38, 38, .1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;font-family:var(--font-sans);font-size:14px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}a:hover{filter:brightness(1.1)}button{font-family:var(--font-heading);cursor:pointer;border:1px solid transparent;border-radius:var(--radius-sm);padding:8px 18px;background:var(--primary);color:var(--primary-fg);font-weight:600;font-size:13px;letter-spacing:.03em;transition:transform var(--transition),box-shadow var(--transition),background var(--transition)}button:hover{transform:translateY(-1px);box-shadow:0 0 16px var(--primary-soft),0 4px 12px #0003;filter:none}button:active{transform:translateY(0);box-shadow:none}button.secondary{background:transparent;color:var(--text);border-color:var(--border-strong)}button.secondary:hover{background:var(--panel-hover);border-color:var(--primary);color:var(--primary);box-shadow:0 0 12px var(--primary-soft)}button:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}input,textarea,select{font-family:var(--font-sans);font-size:14px;color:var(--text);background:#0b0e1599;border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:9px 12px;width:100%;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}:root[data-theme=light] input,:root[data-theme=light] textarea,:root[data-theme=light] select{background:#fffc}input::placeholder,textarea::placeholder{color:var(--text-faint)}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft),0 0 12px var(--primary-soft)}textarea{font-family:var(--font-mono);font-size:13px;line-height:1.6;resize:vertical;min-height:180px}.layout[data-category=tools]{--category-bg-image: var(--tools-bg-url);--category-overlay: linear-gradient(rgba(6,3,1,.68), rgba(6,3,1,.68))}:root[data-theme=dark] .layout[data-category=tools]{--bg-spotlight: radial-gradient(ellipse 90% 55% at 65% 0%, rgba(192,96,0,.1), transparent 70%)}:root[data-theme=light] .layout[data-category=tools]{--primary: #c2710c;--primary-soft: rgba(194, 113, 12, .12);--primary-fg: #ffffff;--category-bg-image: url(/bg-tools.jpg?v=3);--category-overlay: linear-gradient(rgba(255,250,245,.92), rgba(255,250,245,.92))}.layout[data-category=games]{--primary: #2dd4bf;--primary-soft: rgba(45, 212, 191, .15);--primary-fg: #003d35;--category-bg-image: var(--games-bg-url);--category-overlay: linear-gradient(rgba(2,15,12,.46), rgba(2,15,12,.46))}:root[data-theme=dark] .layout[data-category=games]{--bg-spotlight: radial-gradient(ellipse 100% 60% at 50% 0%, rgba(45, 212, 191, .1), transparent 70%);--grid-line: rgba(45, 212, 191, .04)}:root[data-theme=light] .layout[data-category=games]{--primary: #0d9488;--primary-soft: rgba(13, 148, 136, .12);--primary-fg: #ffffff;--category-overlay: linear-gradient(rgba(220,255,250,.5), rgba(220,255,250,.5))}.layout{display:grid;grid-template-rows:52px 1fr;grid-template-columns:200px 1fr;grid-template-areas:"topnav topnav" "sidebar main";min-height:100vh;background-color:var(--bg);background-image:var(--bg-spotlight),var(--category-overlay, linear-gradient(transparent, transparent)),linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px),var(--category-bg-image, none);background-size:auto,auto,var(--grid-size) var(--grid-size),var(--grid-size) var(--grid-size),cover;background-position:0 0,0 0,-1px -1px,-1px -1px,center;background-repeat:repeat,repeat,repeat,repeat,no-repeat;background-attachment:local,local,local,local,fixed}.topnav{grid-area:topnav;position:sticky;top:0;z-index:200;display:flex;align-items:center;gap:0;padding:0 20px;background:#10131aa6;border-bottom:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 4px 20px #2dd4bf14}:root[data-theme=light] .topnav{background:#ffffffd1}.topnav-brand{display:flex;align-items:center;gap:9px;color:var(--text);text-decoration:none;font-weight:700;font-size:15px;letter-spacing:.01em;white-space:nowrap;margin-right:20px;flex-shrink:0}.topnav-brand:hover{filter:none;color:var(--text)}.topnav-brand .logo{min-width:26px;height:26px;border-radius:7px;padding:0 7px;background:var(--primary);color:var(--primary-fg);display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;font-family:var(--font-mono);white-space:nowrap;box-shadow:0 0 14px var(--primary-soft)}.topnav-brand .logo.logo-mark{padding:0;background:transparent;box-shadow:0 0 14px var(--primary-soft);overflow:hidden}.topnav-brand .logo.logo-mark .brand-mark{width:26px;height:26px;display:block}.topnav-brand .brand-name{color:var(--text)}.category-tabs{display:flex;align-items:stretch;height:100%;gap:2px}.category-tab{display:flex;align-items:center;gap:7px;padding:0 18px;height:100%;font-size:13.5px;font-weight:600;color:var(--text);border-bottom:2px solid transparent;transition:color var(--transition),border-color var(--transition),background var(--transition);white-space:nowrap}.category-tab:hover{color:var(--text);filter:none;background:var(--panel-hover)}.category-tab.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--primary-soft)}.category-tab .nav-icon{display:flex;flex-shrink:0;width:15px;height:15px;opacity:.7}.category-tab .nav-icon svg{width:15px;height:15px}.category-tab.active .nav-icon{opacity:1;filter:drop-shadow(0 0 5px currentColor)}.topnav-end{margin-left:auto;display:flex;align-items:center;gap:10px}.topnav-user{font-size:13px;font-weight:600;color:var(--text);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-wrap{position:relative}.user-menu-trigger{display:inline-flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;background:transparent;border:1px solid var(--border);border-radius:999px;color:var(--text);font-family:var(--font-sans);font-size:13px;font-weight:600;box-shadow:none;transition:background var(--transition),border-color var(--transition);cursor:pointer}.user-menu-trigger:hover{background:var(--panel-hover);border-color:var(--border-strong);transform:none;filter:none}.user-menu-avatar{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary);color:var(--primary-fg);font-family:var(--font-mono);font-size:12px;font-weight:800;flex-shrink:0}.user-menu-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-caret{opacity:.55}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;z-index:400;padding:6px;background:var(--panel-solid);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-pop);display:flex;flex-direction:column;gap:1px;animation:user-menu-in .14s ease-out}@keyframes user-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.user-menu-dropdown{animation:none}}.user-menu-header{padding:8px 10px 10px;border-bottom:1px solid var(--border);margin-bottom:4px}.user-menu-header-name{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--text)}.user-menu-header-email{margin-top:2px;font-size:11px;color:var(--text-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-badge{padding:1px 7px;background:var(--primary-soft);color:var(--primary);border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.04em}.user-menu-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-soft);font-family:var(--font-sans);font-size:13px;font-weight:500;text-align:left;cursor:pointer;box-shadow:none;transition:background var(--transition),color var(--transition)}.user-menu-item:hover{background:var(--panel-hover);color:var(--text);transform:none;filter:none}.user-menu-item.admin-item{color:var(--primary)}.user-menu-item.admin-item:hover{background:var(--primary-soft);color:var(--primary)}.user-menu-item.danger{color:var(--error)}.user-menu-item.danger:hover{background:var(--error-soft);color:var(--error)}.user-menu-item svg{flex-shrink:0;opacity:.7}.user-menu-item.admin-item svg,.user-menu-item.danger svg{opacity:.9}.user-menu-divider{height:1px;background:var(--border);margin:4px}.topnav-login{font-size:13px;font-weight:600;padding:6px 14px;border-radius:var(--radius-sm);background:var(--primary-soft);color:var(--primary)}.topnav-login:hover{filter:none;background:var(--primary);color:var(--primary-fg)}.theme-toggle{padding:6px 12px;display:flex;align-items:center;justify-content:center;gap:6px;border-radius:var(--radius-sm);background:var(--primary-soft);color:var(--primary);border:1px solid var(--primary);cursor:pointer;font-size:13px;font-weight:600;transition:background var(--transition),color var(--transition),border-color var(--transition)}.theme-toggle:hover{background:var(--primary);color:var(--primary-fg);transform:none;filter:none}.theme-toggle .icon{font-family:var(--font-mono);font-size:14px;line-height:1}.sidebar{grid-area:sidebar;position:sticky;top:52px;height:calc(100vh - 52px);padding:16px 10px;flex-shrink:0;background:#191b23ad;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}:root[data-theme=light] .sidebar{background:#ffffffd1}.sidebar-category-label{display:flex;align-items:center;gap:8px;padding:6px 10px 12px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);border-bottom:1px solid var(--border);margin-bottom:8px;opacity:.85}.sidebar-category-label .nav-icon{display:flex;width:14px;height:14px;filter:drop-shadow(0 0 4px currentColor)}.sidebar-category-label .nav-icon svg{width:14px;height:14px}.sidebar nav{flex:1}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text);margin-bottom:2px;font-family:var(--font-heading);font-weight:500;font-size:13px;letter-spacing:.02em;transition:background var(--transition),color var(--transition),box-shadow var(--transition)}.nav-item:hover{background:var(--panel-hover);color:var(--text);filter:none}.nav-item.active{background:var(--primary-soft);color:var(--primary);box-shadow:inset 0 0 12px var(--primary-soft)}:root[data-theme=light] .nav-item.active{background:var(--primary-soft);color:var(--primary);box-shadow:none}.nav-item .nav-icon{display:flex;flex-shrink:0;width:16px;height:16px;opacity:.5}.nav-item .nav-icon svg{width:16px;height:16px}.nav-item.active .nav-icon{opacity:1;filter:drop-shadow(0 0 4px currentColor)}.main{grid-area:main;padding:28px 36px;overflow-x:hidden;min-height:calc(100vh - 52px);display:flex;flex-direction:column;max-width:1400px}.page-header{margin-bottom:22px;padding:24px 26px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--panel);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.page-header h2{margin:0 0 8px;font-family:var(--font-heading);font-size:24px;font-weight:700;letter-spacing:-.01em}.page-header p{margin:0;color:var(--text-soft);font-size:14px}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);padding:22px;margin-bottom:16px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-card);transition:border-color var(--transition),box-shadow var(--transition)}.card:hover{border-color:#a8c5da26;box-shadow:0 0 30px #2dd4bf1a,0 4px 24px #00000059}.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.row>*{flex:0 0 auto}.row .grow{flex:1 1 auto}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.label{display:block;font-weight:600;margin-bottom:7px;color:var(--text);font-size:13px;letter-spacing:.01em}.tag{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:500;background:var(--panel-hover);color:var(--text-soft);border:1px solid var(--border)}.tag.ok{background:var(--success-soft);color:var(--success);border-color:transparent}.tag.err{background:var(--error-soft);color:var(--error);border-color:transparent}.code-block{background:var(--code-bg);color:var(--code-fg);padding:16px;border-radius:var(--radius-md);border:1px solid var(--border);font-family:var(--font-mono);font-size:13px;line-height:1.6;white-space:pre-wrap;word-break:break-all;max-height:420px;overflow:auto}.kv-grid{display:grid;grid-template-columns:110px 1fr;gap:10px 16px}.kv-grid .key{color:var(--text-soft);font-size:13px}.kv-grid .val{font-family:var(--font-mono);word-break:break-all;color:var(--text)}.checkbox-row{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.checkbox-row label{display:flex;align-items:center;gap:6px;font-weight:400;color:var(--text-soft)}.checkbox-row input{width:auto}.regex-presets{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:10px}.regex-presets-label{margin-right:4px;color:var(--text-soft);font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.regex-preset-chip{padding:4px 12px;border:1px solid var(--border-strong);border-radius:999px;background:transparent;color:var(--text-soft);font-size:12.5px;font-weight:500;letter-spacing:0;box-shadow:none;transition:border-color var(--transition),color var(--transition),background var(--transition)}.regex-preset-chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft);transform:none;filter:none}.diff-view-card{overflow-x:auto;padding:16px}.diff-view-card table{width:100%}.diff-viewer-shell{overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated)}.diff-viewer-shell pre{margin:0;font-family:var(--font-mono)}.chunk-loading{display:flex;flex-direction:column;gap:14px;align-items:stretch;color:var(--text-soft);font-size:13px}.chunk-loading-bar{position:relative;height:3px;border-radius:2px;overflow:hidden;background:var(--panel-hover)}.chunk-loading-bar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;width:40%;background:linear-gradient(90deg,transparent,var(--primary),transparent);animation:chunk-loading-slide 1.2s infinite ease-in-out}@keyframes chunk-loading-slide{0%{transform:translate(-100%)}to{transform:translate(350%)}}.match-list{display:flex;flex-direction:column;gap:8px}.match-item{border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;background:var(--bg-elevated)}.match-item .head{display:flex;justify-content:space-between;color:var(--text-soft);font-size:12px;margin-bottom:4px}.match-item .text{font-family:var(--font-mono);word-break:break-all;color:var(--text)}.toolbar{display:flex;gap:8px;flex-wrap:wrap}.error-banner{background:var(--error-soft);color:var(--error);border:1px solid transparent;border-radius:var(--radius-sm);padding:11px 14px;margin-top:12px;font-size:13px}.json-error-block{margin-top:12px}.json-error-block .error-banner{margin-top:0}.json-error-block .error-banner strong{display:inline-block;margin-right:10px;font-weight:700}.json-error-pos{display:inline-block;padding:1px 8px;border-radius:999px;background:#f871712e;color:var(--error);font-family:var(--font-mono);font-size:12px;font-weight:600}.json-error-msg{margin-top:6px;color:var(--error);font-family:var(--font-mono);font-size:12.5px;line-height:1.55;word-break:break-all;opacity:.92}.json-error-preview{margin-top:10px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated)}.json-error-preview-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;color:var(--text-soft);font-size:12px;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase}.json-jump-btn{padding:4px 10px;font-size:12px;border-radius:6px}.json-error-context{margin:0;padding:12px;border-radius:var(--radius-sm);background:var(--code-bg);color:var(--code-fg);font-family:var(--font-mono);font-size:13px;line-height:1.6;white-space:pre-wrap;word-break:break-all;max-height:220px;overflow:auto}.json-error-ellipsis{color:var(--text-faint);margin:0 2px}.json-error-mark{display:inline-block;padding:0 2px;margin:0 1px;border-radius:3px;background:var(--error);color:#fff;font-weight:700;text-decoration:underline wavy rgba(255,255,255,.6);text-underline-offset:3px;box-shadow:0 0 0 2px #f8717159}.json-error-mark-eof{padding:1px 6px;font-size:11px;letter-spacing:.06em}.json-error-charinfo{margin-top:10px;color:var(--text-soft);font-size:12px}.json-error-charinfo code{display:inline-block;padding:1px 6px;border-radius:4px;background:var(--panel-hover);color:var(--text);font-family:var(--font-mono);font-size:12px}.success-banner{background:var(--success-soft);color:var(--success);border:1px solid transparent;border-radius:var(--radius-sm);padding:11px 14px;margin-top:12px;font-size:13px}@property --gh1x{syntax: "<percentage>"; inherits: false; initial-value: 4%;}@property --gh1y{syntax: "<percentage>"; inherits: false; initial-value: 30%;}@property --gh2x{syntax: "<percentage>"; inherits: false; initial-value: 88%;}@property --gh2y{syntax: "<percentage>"; inherits: false; initial-value: 60%;}.home-hero{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:22px;padding:28px 30px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--panel);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-card)}.home-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse 75% 220% at var(--gh1x) var(--gh1y),rgba(168,197,218,.38),transparent 65%),radial-gradient(ellipse 70% 180% at var(--gh2x) var(--gh2y),rgba(45,212,191,.22),transparent 68%);animation:hero-drift-a 14s ease-in-out infinite alternate,hero-drift-b 19s ease-in-out infinite alternate-reverse}:root[data-theme=light] .home-hero:before{background:radial-gradient(ellipse 75% 220% at var(--gh1x) var(--gh1y),rgba(77,142,255,.18),transparent 65%),radial-gradient(ellipse 70% 180% at var(--gh2x) var(--gh2y),rgba(13,148,136,.14),transparent 68%)}@keyframes hero-drift-a{0%{--gh1x: 4%;--gh1y: 30%}40%{--gh1x: 18%;--gh1y: 72%}70%{--gh1x: 8%;--gh1y: 48%}to{--gh1x: 4%;--gh1y: 30%}}@keyframes hero-drift-b{0%{--gh2x: 88%;--gh2y: 60%}45%{--gh2x: 70%;--gh2y: 24%}78%{--gh2x: 85%;--gh2y: 80%}to{--gh2x: 88%;--gh2y: 60%}}@media (prefers-reduced-motion: reduce){.home-hero:before{animation:none}}.home-hero-body{position:relative;flex:1;min-width:0}.home-hero-body h2{margin:0 0 6px;font-size:32px;font-weight:800;letter-spacing:-.025em;color:var(--text);text-wrap:balance}.home-hero-body p{margin:0;color:var(--text-soft);font-size:14px;line-height:1.55}@media (max-width: 720px){.home-hero{flex-direction:column;align-items:flex-start}.home-hero-body h2{font-size:26px}}.home-card--game{--game-accent: #2dd4bf;--game-accent-soft: rgba(45, 212, 191, .12)}:root[data-theme=light] .home-card--game{--game-accent: #0d9488;--game-accent-soft: rgba(13, 148, 136, .1)}.home-card--game .home-card-icon{background:var(--game-accent-soft);color:var(--game-accent)}.home-card--game:hover{border-color:var(--game-accent);box-shadow:0 8px 32px #2dd4bf1f,var(--shadow-card)}.home-card--game:hover .home-card-icon{box-shadow:0 0 14px var(--game-accent-soft)}.home-card--game:before{background:linear-gradient(90deg,transparent,var(--game-accent),transparent)}.home-section{margin-bottom:20px}.home-section-label{font-size:12px;font-weight:600;color:var(--text-faint);margin-bottom:10px;padding:0 2px}.home-section-label--games{color:#2dd4bf}:root[data-theme=light] .home-section-label--games{color:#0d9488}.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.home-card{position:relative;overflow:hidden;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);padding:22px;display:block;color:var(--text);transition:transform var(--transition),border-color var(--transition),background var(--transition)}.home-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--primary),transparent);opacity:0;transition:opacity var(--transition)}.home-card:hover{transform:translateY(-2px);border-color:var(--primary);background:var(--panel-hover);text-decoration:none;filter:none;box-shadow:0 8px 32px #22d3ee1a,var(--shadow-card)}.home-card:hover:before{opacity:1}.home-card-icon{width:38px;height:38px;border-radius:var(--radius-md);background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:14px;flex-shrink:0;transition:box-shadow var(--transition)}.home-card-icon svg{width:18px;height:18px}.home-card:hover .home-card-icon{box-shadow:0 0 14px var(--primary-soft)}.home-card h3{margin:0 0 6px;font-size:15px;font-weight:600;color:var(--text)}.home-card p{margin:0;color:var(--text-soft);font-size:13px;line-height:1.55}.ad-slot{display:block;margin:24px 0 0;padding:12px 16px;border:1px solid var(--primary);background:var(--primary-soft);border-radius:var(--radius-sm);color:var(--text);font-size:13px;transition:background var(--transition)}.ad-slot:hover{background:var(--panel-hover);text-decoration:none;filter:none}.site-footer{margin-top:auto;padding-top:24px;color:var(--text-faint);font-size:12px;text-align:center}.site-footer a{color:var(--text-faint)}.site-footer a:hover{color:var(--primary)}.admin-login-wrap{display:flex;justify-content:center;padding-top:60px}.admin-login-card{width:100%;max-width:400px}.admin-login-title{font-size:18px;font-weight:700;font-family:var(--font-heading);margin-bottom:20px;color:var(--text)}.admin-layout{margin:-28px -36px;flex:1;display:grid;grid-template-columns:220px 1fr;min-height:calc(100vh - 52px)}.admin-nav{border-right:1px solid var(--border);background:var(--panel-solid);padding:20px 12px;display:flex;flex-direction:column;gap:4px}:root[data-theme=light] .admin-nav{background:#f8fafff2}.admin-nav-badge{font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--text-faint);padding:4px 10px 12px;border-bottom:1px solid var(--border);margin-bottom:8px;text-transform:uppercase}.admin-nav-items{flex:1;display:flex;flex-direction:column;gap:2px}.admin-nav-item{width:100%;text-align:left;padding:8px 12px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-soft);font-family:var(--font-sans);font-size:13.5px;font-weight:500;box-shadow:none;cursor:pointer;transition:background var(--transition),color var(--transition)}.admin-nav-item:hover{background:var(--panel-hover);color:var(--text);transform:none;filter:none}.admin-nav-item.active{background:var(--primary-soft);color:var(--primary)}.admin-nav-session{padding-top:14px;border-top:1px solid var(--border);font-size:12px}.admin-session-status{display:flex;align-items:center;gap:6px;font-weight:600;color:var(--success);margin-bottom:3px}.admin-session-dot{width:6px;height:6px;border-radius:50%;background:var(--success);flex-shrink:0;animation:session-pulse 2.5s ease-out infinite}@keyframes session-pulse{0%{box-shadow:0 0 #34d39980}70%{box-shadow:0 0 0 5px #34d39900}to{box-shadow:0 0 #34d39900}}@media (prefers-reduced-motion: reduce){.admin-session-dot{animation:none}}.admin-session-exp{color:var(--text-faint);margin-bottom:2px}.admin-session-time{font-family:var(--font-mono)}.admin-content{padding:28px 36px;overflow-x:hidden}.admin-fieldset{margin:0 0 24px}.admin-fieldset:last-of-type{margin-bottom:0}.admin-legend{font-size:13px;font-weight:600;color:var(--text-soft);margin-bottom:4px}.admin-form-row{display:grid;grid-template-columns:130px 1fr;gap:12px;align-items:start;padding:10px 0;border-bottom:1px solid var(--border)}.admin-form-row:last-child{border-bottom:none}.admin-form-label{font-size:13px;font-weight:500;color:var(--text-soft);padding-top:9px;line-height:1.4}.admin-form-ctrl{min-width:0}.admin-actions{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.admin-loading{padding:24px;color:var(--text-faint);font-size:13px}.admin-empty{padding:40px 24px;color:var(--text-faint);font-size:13px;text-align:center}.admin-table{width:100%;border-collapse:collapse}.admin-table th{padding:9px 16px;font-size:11.5px;font-weight:600;color:var(--text-faint);text-align:left;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.admin-table td{padding:10px 16px;font-size:13px;color:var(--text);border-bottom:1px solid var(--border)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--panel-hover)}.color-row{display:grid;grid-template-columns:48px 1fr;gap:10px}.color-row input[type=color]{padding:2px;min-height:38px;background:var(--bg-elevated)}.image-config-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:start}.upload-button{position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:var(--radius-sm);background:var(--primary);color:var(--primary-fg);cursor:pointer;white-space:nowrap;font-weight:600;font-size:13px;transition:filter var(--transition),opacity var(--transition)}.upload-button:hover{filter:brightness(1.1)}.upload-button.uploading{opacity:.55;cursor:wait}.upload-button input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.image-preview{grid-column:1 / -1;display:flex;align-items:center;gap:12px;min-width:0;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated)}.image-preview img{width:72px;height:48px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border)}.image-preview span{min-width:0;overflow-wrap:anywhere;color:var(--text-soft);font-size:12px}.admin-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600;display:flex;align-items:center;justify-content:center;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:20px}.admin-modal{width:100%;max-width:520px;padding:22px 24px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--panel-solid);box-shadow:var(--shadow-pop)}.admin-modal-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px}.admin-modal-meta{font-size:13px;color:var(--text-soft);margin-bottom:14px}.admin-modal-meta strong{color:var(--primary);font-weight:600}.admin-modal-link{width:100%;min-height:80px;font-family:var(--font-mono);font-size:12px;word-break:break-all;resize:none}@media (max-width: 720px){.admin-layout{grid-template-columns:1fr}.admin-nav{flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid var(--border)}.admin-nav-items{flex-direction:row;flex:none}.admin-nav-session{display:none}.admin-content{padding:20px 16px}.admin-form-row,.image-config-row{grid-template-columns:1fr}}.tool-hero{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:130px;margin-bottom:18px;padding:28px 30px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--panel);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.tool-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 0% 0%,var(--primary-soft),transparent 50%),radial-gradient(circle at 100% 100%,var(--primary-soft),transparent 50%);pointer-events:none;opacity:.6}.tool-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:24px 24px;pointer-events:none;mask-image:radial-gradient(circle at 50% 50%,black,transparent 75%);-webkit-mask-image:radial-gradient(circle at 50% 50%,black,transparent 75%)}.tool-hero>*{position:relative;z-index:1}.tool-kicker{display:inline-flex;align-items:center;margin-bottom:10px;padding:3px 10px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.tool-hero h2{margin:0 0 8px;font-size:26px;font-weight:700;letter-spacing:-.01em;color:var(--text)}.tool-hero p{margin:0;max-width:620px;color:var(--text-soft);font-size:14px;line-height:1.55}.hero-clock,.hero-glyph{flex:0 0 auto;min-width:170px;padding:16px 18px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);text-align:right}.hero-clock span{display:block;margin-bottom:8px;color:var(--text-soft);font-size:11px;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase}.hero-clock strong{font-family:var(--font-mono);font-size:22px;color:var(--primary);font-weight:600;letter-spacing:.01em}.hero-glyph{min-height:96px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:36px;font-weight:700;color:var(--primary);text-align:center}.tool-panel{border-top:2px solid var(--primary)}.tool-panel .label{color:var(--text)}.action-toolbar button:first-child{background:var(--primary);color:var(--primary-fg);box-shadow:0 0 18px var(--primary-soft)}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.metric-card{min-width:0;padding:16px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--panel);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:border-color var(--transition)}.metric-card:hover{border-color:var(--primary)}.metric-card.clickable{cursor:pointer;text-align:left;font-family:inherit;box-shadow:none;position:relative}.metric-card.clickable:hover{transform:translateY(-2px);filter:none;box-shadow:0 8px 24px #0000004d}.metric-card.clickable strong{font-size:22px;line-height:1.2;margin-top:4px}.metric-card-hint{display:block;margin-top:8px;font-size:11px;font-style:normal;color:var(--primary);opacity:.75;font-family:var(--font-sans)}.metric-card.clickable:hover .metric-card-hint{opacity:1}.admin-drilldown-modal{max-width:720px;max-height:78vh;display:flex;flex-direction:column}.admin-drilldown-body{overflow-y:auto;overflow-x:auto;margin:4px -6px 0;padding:0 6px;min-height:60px}.admin-drilldown-modal .admin-table th,.admin-drilldown-modal .admin-table td{padding:8px 12px}.metric-card span{display:block;margin-bottom:8px;color:var(--text-soft);font-size:11px;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase}.metric-card strong{display:block;overflow-wrap:anywhere;font-family:var(--font-mono);font-size:14px;color:var(--text);font-weight:600}.auth-card{max-width:520px}.auth-tabs{display:flex;gap:6px;margin-bottom:20px;padding:4px;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);width:fit-content}.auth-tabs button{padding:7px 18px;font-size:13px;border-radius:5px;box-shadow:none}.auth-tabs button.secondary{background:transparent;border-color:transparent;color:var(--text-soft)}.auth-tabs button.secondary:hover{background:var(--panel-hover);border-color:transparent;color:var(--text)}.text-link{display:inline-flex;align-items:center;min-height:36px;padding:0 4px;color:var(--primary);font-weight:600;font-size:13px}.sms-login-box{display:flex;justify-content:space-between;gap:14px;align-items:center;margin-top:20px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated)}.sms-login-box strong{color:var(--text);font-size:13px}.sms-login-box p{margin:4px 0 0;color:var(--text-soft);font-size:12px}.nav-group{margin-bottom:4px}.nav-group-label{display:flex;align-items:center;gap:6px;padding:5px 10px;margin:0 0 2px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--primary);background:var(--primary-soft);border-radius:var(--radius-sm);opacity:.9}.nav-group-icon{display:flex;width:14px;height:14px}.nav-group-icon svg{width:14px;height:14px}.idiom-hero{--tool-color: var(--primary)}.idiom-dict-count{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.04em;vertical-align:middle}.idiom-level-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}.idiom-level-btn{flex:1;min-width:100px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:12px 16px;border:2px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text);box-shadow:none;transition:border-color var(--transition),background var(--transition)}.idiom-level-btn:hover{border-color:var(--lcolor, var(--primary));background:var(--panel-hover);transform:none;filter:none}.idiom-level-btn.active{border-color:var(--lcolor, var(--primary));background:var(--primary-soft)}.idiom-level-name{font-size:15px;font-weight:700;color:var(--lcolor, var(--primary))}.idiom-level-desc{font-size:12px;color:var(--text-soft);font-weight:400}.idiom-mode-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}.idiom-mode-btn{flex:1;min-width:160px;display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 16px;border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text);box-shadow:none;transition:border-color var(--transition),background var(--transition),transform var(--transition)}.idiom-mode-btn:hover{border-color:var(--primary);background:var(--primary-soft);transform:translateY(-2px);filter:none}.idiom-mode-icon{font-size:28px;line-height:1}.idiom-mode-name{font-size:15px;font-weight:700;color:var(--text)}.idiom-mode-desc{font-size:12px;color:var(--text-soft);font-weight:400;text-align:center}.idiom-status-card{padding:14px 20px;margin-bottom:12px}.idiom-status-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.idiom-status-item{display:flex;flex-direction:column;gap:4px}.idiom-status-item span{color:var(--text-soft);font-size:11px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}.idiom-status-item strong{font-size:16px;font-weight:700;color:var(--text)}.idiom-tail-hint{font-family:var(--font-mono);font-size:18px!important;color:var(--primary)!important}.idiom-tail-hint em{font-style:normal;font-size:13px;color:var(--text-soft);margin-left:4px}.idiom-chain-scroll{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-height:56px;margin-bottom:16px;padding:12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);max-height:200px;overflow-y:auto}.idiom-chain-item{display:inline-flex;flex-direction:column;align-items:center;gap:2px}.idiom-chain-word{font-size:16px;font-weight:600;padding:4px 10px;border-radius:var(--radius-sm);background:var(--panel-hover);color:var(--text);border:1px solid var(--border)}.idiom-chain-item.user .idiom-chain-word{background:var(--primary-soft);color:var(--primary);border-color:var(--primary)}.idiom-chain-item.cpu .idiom-chain-word{background:#f871711f;color:var(--error);border-color:#f8717166}.idiom-chain-item.system .idiom-chain-word{background:var(--panel-hover);color:var(--text-soft)}.idiom-chain-pinyin{font-family:var(--font-mono);font-size:10px;color:var(--text-faint)}.idiom-chain-arrow{color:var(--text-faint);font-size:14px;align-self:center}.idiom-thinking .idiom-chain-word{animation:idiom-blink .9s infinite}@keyframes idiom-blink{0%,to{opacity:1}50%{opacity:.3}}.idiom-input-row{display:flex;gap:10px;align-items:center;margin-bottom:10px}.idiom-input{width:300px;flex:0 0 auto;font-size:15px;font-family:var(--font-mono);letter-spacing:.1em}.idiom-msg{padding:9px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:10px}.idiom-msg-ok{background:var(--success-soft);color:var(--success)}.idiom-msg-err{background:var(--error-soft);color:var(--error)}.idiom-msg-info{background:var(--primary-soft);color:var(--primary)}.idiom-msg-bar{min-height:36px;padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:background .15s,color .15s;color:transparent}.idiom-msg-bar.idiom-msg-ok{color:var(--success);background:var(--success-soft)}.idiom-msg-bar.idiom-msg-err{color:var(--error);background:var(--error-soft)}.idiom-msg-bar.idiom-msg-info{color:var(--text);background:var(--panel-hover)}.idiom-inline-msg{font-size:13px;font-weight:600;white-space:nowrap}.idiom-inline-msg.idiom-msg-ok{color:var(--success)}.idiom-inline-msg.idiom-msg-err{color:var(--error)}.idiom-inline-msg.idiom-msg-info{color:var(--text-soft)}.idiom-action-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.idiom-hints{margin-top:12px}.idiom-hints-label{font-size:12px;color:var(--text-soft);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.idiom-hints-empty{color:var(--text-faint);font-size:13px}.idiom-hint-chip{display:inline-flex;align-items:center;gap:8px;margin:4px 6px 4px 0;padding:6px 12px;border:1px solid var(--border-strong);border-radius:999px;background:transparent;color:var(--text);font-size:13px;box-shadow:none;transition:border-color var(--transition),color var(--transition),background var(--transition)}.idiom-hint-chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft);transform:none;filter:none}.idiom-hint-py{font-family:var(--font-mono);font-size:11px;color:var(--text-faint)}.idiom-hint-chip:hover .idiom-hint-py{color:var(--primary);opacity:.7}.idiom-over-card{text-align:center}.idiom-over-msg{font-size:20px;font-weight:700;color:var(--text);margin-bottom:10px}.idiom-over-score{font-size:15px;color:var(--text-soft);margin-bottom:16px}.idiom-over-score strong{font-size:24px;color:var(--primary)}.idiom-over-hint-count{font-size:13px;margin-left:8px}.idiom-over-chain{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;padding:14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);max-height:180px;overflow-y:auto;margin-bottom:6px}.idiom-over-word{font-size:14px;font-weight:600}.idiom-over-word.user{color:var(--primary)}.idiom-over-word.cpu{color:var(--error)}.idiom-over-word.system{color:var(--text-soft)}.idiom-over-arrow{color:var(--text-faint);margin:0 4px;font-size:12px}.idiom-over-submit-tip{margin-top:12px;color:var(--success);font-size:13px}.idiom-personal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.idiom-personal-card{display:flex;flex-direction:column;gap:4px;padding:14px;border:1px solid var(--border);border-top:2px solid var(--lcolor, var(--primary));border-radius:var(--radius-md);background:var(--bg-elevated)}.idiom-personal-label{font-size:12px;font-weight:700;letter-spacing:.04em}.idiom-personal-best{font-family:var(--font-mono);font-size:28px;font-weight:700;color:var(--text);line-height:1.1}.idiom-personal-sub{font-size:12px;color:var(--text-soft)}.idiom-leader-header{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:14px}.idiom-leader-tabs{display:flex;gap:4px;padding:3px;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border)}.idiom-leader-tab{padding:4px 12px;border-radius:5px;font-size:12.5px;font-weight:500;background:transparent;color:var(--text-soft);border:none;box-shadow:none;transition:background var(--transition),color var(--transition)}.idiom-leader-tab:hover{background:var(--panel-hover);color:var(--text);transform:none;filter:none}.idiom-leader-tab.active{background:var(--primary);color:var(--primary-fg)}.idiom-leader-diff-tabs{display:flex;gap:4px}.idiom-leader-diff-tab{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;background:transparent;color:var(--text-soft);border:1px solid var(--border-strong);box-shadow:none;transition:border-color var(--transition),color var(--transition),background var(--transition)}.idiom-leader-diff-tab:hover{border-color:var(--lcolor, var(--primary));color:var(--lcolor, var(--primary));transform:none;filter:none}.idiom-leader-diff-tab.active{background:var(--lcolor, var(--primary));color:#fff;border-color:transparent}.idiom-leader-list{display:flex;flex-direction:column;gap:0}.idiom-leader-row{display:grid;grid-template-columns:36px 1fr auto auto;align-items:center;gap:8px;padding:9px 8px;border-radius:var(--radius-sm);font-size:13.5px;border-bottom:1px solid var(--border);transition:background var(--transition)}.idiom-leader-row:last-child{border-bottom:none}.idiom-leader-row:hover{background:var(--panel-hover)}.idiom-leader-head{font-size:11px;color:var(--text-soft);font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;padding:6px 8px;background:var(--bg-elevated);border-radius:var(--radius-sm);margin-bottom:4px}.idiom-leader-head:hover{background:var(--bg-elevated)}.idiom-leader-row.self{background:var(--primary-soft)}.idiom-leader-row.top1 .idiom-leader-nick{font-weight:700;color:var(--text)}.idiom-leader-rank{font-family:var(--font-mono);color:var(--text-soft);font-size:13px}.idiom-leader-nick{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.idiom-leader-self-tag{display:inline-block;margin-left:6px;padding:1px 5px;border-radius:999px;font-size:10px;font-style:normal;font-weight:700;background:var(--primary);color:var(--primary-fg)}.idiom-leader-val{font-family:var(--font-mono);font-weight:600;color:var(--primary);text-align:right;min-width:40px}@media (max-width: 720px){.layout{display:block}.sidebar{position:relative;width:auto;height:auto;border-right:0;border-bottom:1px solid var(--border);flex-direction:column}.sidebar nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.sidebar-account{margin-top:12px}.main{padding:20px 16px;max-width:100%}.grid-2,.metric-grid,.image-config-row{grid-template-columns:1fr}.tool-hero{align-items:flex-start;flex-direction:column;padding:22px}.hero-clock,.hero-glyph{width:100%;text-align:left}.sms-login-box{align-items:flex-start;flex-direction:column}}@media (max-width: 640px){.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.idiom-status-row{grid-template-columns:repeat(2,1fr)}.idiom-level-row{flex-direction:column}}.nickname-style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:8px;margin-bottom:10px}.nickname-style-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;font-size:12px;font-weight:600;background:color-mix(in srgb,var(--sc) 10%,var(--panel-hover));color:var(--text-soft);border:1px solid color-mix(in srgb,var(--sc) 25%,var(--border));border-radius:10px;transition:background var(--transition),color var(--transition),border-color var(--transition),box-shadow var(--transition)}.nickname-style-icon{font-size:20px;line-height:1}.nickname-style-btn:hover{background:color-mix(in srgb,var(--sc) 20%,var(--panel-hover));color:var(--text);border-color:var(--sc);transform:none;filter:none}.nickname-style-btn.active{position:relative;background:color-mix(in srgb,var(--sc) 28%,var(--panel-hover));color:var(--sc);border:2px solid var(--sc);box-shadow:0 0 12px color-mix(in srgb,var(--sc) 45%,transparent);transform:translateY(-2px)}.nickname-style-btn.active:after{content:"✓";position:absolute;top:-7px;right:-7px;width:15px;height:15px;background:var(--sc);color:#fff;border-radius:50%;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:15px;text-align:center}.nickname-style-desc{margin:8px 0 0;font-size:13px;color:var(--text-faint)}.nickname-results{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.nickname-chip{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:14px 12px 10px;background:var(--panel-hover);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition),border-color var(--transition),transform var(--transition);text-align:center}.nickname-chip:hover{background:var(--primary-soft);border-color:var(--primary);transform:translateY(-2px)}.nickname-chip.couple-b{border-color:var(--primary)}.couple-pair{display:flex;align-items:center;gap:8px;margin-bottom:8px}.couple-pair .nickname-chip{flex:1;margin-bottom:0}.couple-heart{color:#f43f5e;font-size:16px;flex-shrink:0}.couple-mark{position:absolute;top:-10px;left:50%;transform:translate(-50%);font-size:10px;font-weight:700;font-family:var(--font-mono);background:var(--primary);color:var(--primary-fg);padding:1px 7px;border-radius:999px;letter-spacing:.05em}.nickname-text{font-size:14px;font-weight:600;color:var(--text);word-break:break-all;line-height:1.4}.nickname-copy-hint{font-size:11px;color:var(--text-faint);font-family:var(--font-mono)}.nickname-chip:hover .nickname-copy-hint{color:var(--primary)}.sudoku-hero{margin-bottom:20px}.sudoku-v2-badge{display:inline-block;padding:3px 12px;background:var(--primary-soft);border:1px solid var(--primary);border-radius:999px;font-size:11px;font-family:var(--font-heading);font-weight:600;letter-spacing:.08em;color:var(--primary);margin-bottom:10px}.sudoku-v2-title{font-family:var(--font-heading);font-size:40px;font-weight:800;letter-spacing:-.02em;line-height:1.2;color:var(--primary);text-shadow:0 0 15px var(--primary),0 0 40px var(--primary-soft);margin:0 0 8px}.sudoku-v2-title-sub{font-size:22px;font-weight:300;font-style:italic;color:var(--text-soft);text-shadow:none;margin-left:4px}.sudoku-v2-desc{color:var(--text-soft);font-size:14px;margin:0}.sudoku-v2-grid{display:grid;grid-template-columns:1fr 260px;gap:16px;align-items:start}.sudoku-v2-main,.sudoku-v2-sidebar{display:flex;flex-direction:column;gap:12px}.sudoku-v2-mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.sudoku-v2-mode-icon{font-family:var(--font-heading);font-size:26px;font-weight:800;letter-spacing:-.02em}.sudoku-v2-diff-grid{display:grid;grid-template-columns:1fr;gap:8px}.sudoku-v2-diff-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 14px;background:var(--panel-hover);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:14px;font-weight:700;color:var(--text-soft);box-shadow:none;transition:border-color var(--transition),color var(--transition),background var(--transition)}.sudoku-v2-diff-btn:hover{border-color:var(--primary);color:var(--primary);transform:none;filter:none}.sudoku-v2-diff-btn.active{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.sudoku-v2-diff-btn:disabled{opacity:.35;cursor:not-allowed}.sudoku-v2-diff-btn:disabled:hover{border-color:var(--border);color:var(--text-soft)}.sudoku-v2-diff-desc{font-size:11px;font-weight:400;color:var(--text-faint);font-family:var(--font-sans)}.sudoku-progress-fill{position:relative;height:4px;border-radius:2px;background:var(--panel-hover);overflow:hidden}.sudoku-progress-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;width:var(--pct, 0%);background:linear-gradient(90deg,var(--primary),var(--primary));border-radius:2px;transition:width .3s ease-out}@media (max-width: 768px){.sudoku-v2-grid{grid-template-columns:1fr}.sudoku-v2-title{font-size:28px}}.sudoku-level-grid{display:grid;grid-template-columns:repeat(10,minmax(0,1fr));gap:6px}.sudoku-level{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-soft);font-family:var(--font-mono);font-size:13px;font-weight:600;box-shadow:none;transition:border-color var(--transition),color var(--transition),background var(--transition);gap:1px}.sudoku-level:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft);transform:none;filter:none}.sudoku-level.completed{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.sudoku-level.current{border-color:var(--primary);border-width:2px;color:var(--primary);background:var(--bg-elevated);box-shadow:0 0 0 3px var(--primary-soft)}.sudoku-level.current:after{content:"▶";position:absolute;top:2px;right:4px;font-size:8px;color:var(--primary)}.sudoku-level{position:relative}.sudoku-level.locked{color:var(--text-faint);background:var(--panel-hover);border-color:var(--border);cursor:not-allowed;opacity:.55}.sudoku-level.locked:hover{border-color:var(--border);color:var(--text-faint);background:var(--panel-hover)}.sudoku-level-no{font-size:14px}.sudoku-level-time{font-size:9px;opacity:.75}@media (max-width: 720px){.sudoku-level-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}.sudoku-board{display:grid;border:2px solid var(--primary);border-radius:var(--radius-sm);background:var(--bg-elevated);width:100%;max-width:560px;aspect-ratio:1;overflow:hidden}.sudoku-stat-row{display:flex;gap:10px;align-items:center}.sudoku-stat{display:flex;align-items:baseline;gap:8px;padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated)}.sudoku-stat span{font-size:11px;color:var(--text-faint);font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase}.sudoku-stat strong{font-family:var(--font-mono);font-size:15px;color:var(--text);font-weight:600}.sudoku-reset-btn{margin-left:auto;padding:6px 12px;font-size:12px}.sudoku-tool-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;background:var(--bg-elevated);color:var(--text-soft);border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:12px;font-weight:600;box-shadow:none;transition:border-color var(--transition),color var(--transition),background var(--transition);cursor:pointer}.sudoku-tool-btn:hover{border-color:var(--primary);color:var(--primary);transform:none;filter:none}.sudoku-tool-btn.active{background:#fbbf241a;border-color:#fbbf24;color:#fbbf24}.sudoku-tool-btn.hint-btn:not(:disabled):hover{border-color:#fbbf24;color:#fbbf24}.sudoku-tool-btn:disabled{opacity:.4;cursor:not-allowed}.sudoku-back-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:var(--primary-soft);color:var(--primary);border:2px solid var(--primary);border-radius:var(--radius-md);font-family:var(--font-heading);font-size:14px;font-weight:700;cursor:pointer;transition:background var(--transition),color var(--transition),box-shadow var(--transition),transform var(--transition);flex-shrink:0}.sudoku-game-layout{display:grid;grid-template-columns:1fr 200px;gap:16px;align-items:start}@media (max-width: 800px){.sudoku-game-layout{grid-template-columns:1fr}.sudoku-game-right{order:-1}}.sudoku-game-left{min-width:0}.sudoku-game-card{display:flex;flex-direction:column;gap:16px}.sudoku-board-wrap{display:flex;justify-content:center}.sudoku-board{display:grid;border:2px solid var(--primary);border-radius:var(--radius-sm);background:var(--bg-elevated);width:100%;max-width:540px;aspect-ratio:1;overflow:hidden}.sudoku-board.mark-mode{border-color:#fbbf24}.sudoku-cell{display:flex;align-items:center;justify-content:center;border:0;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-elevated);color:var(--text);font-family:var(--font-mono);font-size:20px;font-weight:500;border-radius:0;padding:0;box-shadow:none;cursor:pointer;transition:background .1s,color .1s}.sudoku-cell:hover{transform:none;filter:none;background:var(--panel-hover);box-shadow:none}.sudoku-cell.given{color:var(--text-soft);font-weight:700;cursor:default}.sudoku-cell.box-r{border-right:2px solid var(--primary)}.sudoku-cell.box-b{border-bottom:2px solid var(--primary)}.sudoku-board.mark-mode .sudoku-cell.box-r{border-right-color:#fbbf24}.sudoku-board.mark-mode .sudoku-cell.box-b{border-bottom-color:#fbbf24}.sudoku-cell.peer{background:var(--panel-hover)}.sudoku-cell.same{background:var(--primary-soft);color:var(--primary)}.sudoku-cell.selected{background:var(--primary);color:var(--primary-fg);font-weight:700}.sudoku-board.mark-mode .sudoku-cell.selected{background:#fbbf2433;color:var(--text);border:2px solid #fbbf24}.sudoku-cell.wrong{color:var(--error)}.sudoku-cell.wrong.selected{background:var(--error);color:#fff}.sudoku-board.v4 .sudoku-cell,.sudoku-board.v6 .sudoku-cell{font-size:24px}.sudoku-marks{display:grid;width:90%;height:90%;pointer-events:none}.sudoku-mark-num{font-size:9px;font-family:var(--font-mono);color:var(--text-faint);display:flex;align-items:center;justify-content:center;line-height:1}.sudoku-mark-num.on{color:var(--primary);font-weight:700}.sudoku-board.v4 .sudoku-mark-num,.sudoku-board.v6 .sudoku-mark-num{font-size:11px}.sudoku-popover-mode-label{text-align:center;font-size:10px;font-weight:700;letter-spacing:.06em;color:#fbbf24;margin-bottom:5px;text-transform:uppercase}:root[data-theme=light] .sudoku-popover-key{background:#ffffffb3;text-shadow:none}.sudoku-popover-key:hover:not(:disabled){background:var(--primary);color:var(--primary-fg);transform:scale(1.08);filter:none;box-shadow:0 0 12px var(--primary)}.sudoku-popover-key.invalid{color:var(--text-faint);border-color:var(--border);opacity:.4;cursor:not-allowed}.sudoku-popover-key.marked{background:var(--primary-soft);border-width:2px}:root[data-theme=light] .sudoku-popover-clear{background:#ffffffb3;text-shadow:none}.sudoku-times-list{display:flex;flex-direction:column;gap:6px}.sudoku-time-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border)}.sudoku-time-row.best{border-color:var(--primary);background:var(--primary-soft)}.sudoku-time-rank{font-size:16px;flex-shrink:0}.sudoku-time-val{font-family:var(--font-mono);font-size:16px;font-weight:700;color:var(--text)}.sudoku-time-row.best .sudoku-time-val{color:var(--primary)}.sudoku-times-empty{font-size:12px;color:var(--text-faint);text-align:center;padding:8px 0}.sudoku-game-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}.sudoku-back-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:var(--primary-soft);color:var(--primary);border:2px solid var(--primary);border-radius:var(--radius-md);font-family:var(--font-heading);font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 0 0 0 var(--primary-soft);transition:background var(--transition),color var(--transition),box-shadow var(--transition),transform var(--transition);flex-shrink:0}.sudoku-back-btn:hover{background:var(--primary);color:var(--primary-fg);box-shadow:0 0 24px var(--primary-soft);transform:translate(-2px);filter:none}.sudoku-back-btn svg{width:14px;height:14px}.sudoku-game-title{flex:1;min-width:0}.sudoku-game-title-main{font-family:var(--font-heading);font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.01em}.sudoku-game-title-sub{font-size:12px;color:var(--text-faint);margin-top:2px}.sudoku-game-clock{min-width:130px;padding:10px 14px}@media (max-width: 720px){.sudoku-game-header{flex-wrap:wrap}.sudoku-game-title{order:3;flex:1 0 100%}}.sudoku-popover{position:fixed;z-index:600;padding:8px;background:transparent;border:1px solid color-mix(in srgb,var(--primary) 60%,transparent);border-radius:var(--radius-md);box-shadow:0 0 0 1px #00000073,0 0 24px var(--primary-soft);animation:sudoku-pop-in .12s ease-out}@keyframes sudoku-pop-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion: reduce){.sudoku-popover{animation:none}}.sudoku-popover-grid{display:grid;gap:4px}.sudoku-popover-key{width:40px;height:40px;padding:0;background:#0f12198c;color:var(--primary);border:1.5px solid var(--primary);border-radius:50%;font-family:var(--font-mono);font-size:17px;font-weight:700;box-shadow:0 0 0 1px #0006;text-shadow:0 1px 2px rgba(0,0,0,.6);transition:background var(--transition),color var(--transition),transform var(--transition)}:root[data-theme=light] .sudoku-popover-key{background:#ffffffb3;color:var(--primary);text-shadow:none}.sudoku-popover-key:hover{background:var(--primary);color:var(--primary-fg);transform:scale(1.08);filter:none;box-shadow:0 0 12px var(--primary)}.sudoku-popover-clear{width:100%;margin-top:6px;padding:6px 0;background:#0f121973;color:var(--text);border:1px solid color-mix(in srgb,var(--text-soft) 35%,transparent);border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.05em;box-shadow:0 0 0 1px #00000059;text-shadow:0 1px 2px rgba(0,0,0,.5)}:root[data-theme=light] .sudoku-popover-clear{background:#ffffffb3;color:var(--text);text-shadow:none}.sudoku-popover-clear:hover{border-color:var(--error);color:var(--error);background:#0f121999;transform:none;filter:none}h1,h2,h3,h4{font-family:var(--font-heading)}.neon-glow{text-shadow:0 0 10px var(--primary),0 0 20px rgba(173,198,255,.4)}.neon-border{box-shadow:0 0 12px var(--primary-soft),inset 0 0 12px var(--primary-soft)}.idiom-v2-hero{margin-bottom:20px}.idiom-v2-badge{display:inline-block;padding:3px 12px;background:#a8c5da1f;border:1px solid rgba(168,197,218,.25);border-radius:999px;font-size:11px;font-family:var(--font-heading);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);margin-bottom:10px}.idiom-v2-title{font-family:var(--font-heading);font-size:40px;font-weight:800;letter-spacing:-.02em;line-height:1.2;color:var(--primary);text-shadow:0 0 15px var(--primary),0 0 40px var(--primary-soft);margin:0 0 8px}.idiom-v2-title-sub{font-size:22px;font-weight:300;font-style:italic;color:var(--text-soft);text-shadow:none}.idiom-v2-desc{color:var(--text-soft);font-size:14px;margin:0}.idiom-v2-grid{display:grid;grid-template-columns:1fr 300px;gap:16px;align-items:start}.idiom-v2-main,.idiom-v2-sidebar{display:flex;flex-direction:column;gap:12px}.idiom-v2-start-row{display:flex;gap:10px}.idiom-v2-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.idiom-v2-mode-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 12px;height:auto;border-radius:10px}.idiom-v2-mode-btn.secondary{background:transparent}.idiom-v2-mode-icon{font-size:28px;line-height:1}.idiom-v2-mode-name{font-size:16px;font-weight:700;font-family:var(--font-heading)}.idiom-v2-mode-desc{font-size:11px;opacity:.7;font-weight:400;font-family:var(--font-sans)}.idiom-v2-mode-start{font-size:11px;color:var(--primary);font-weight:600;margin-top:4px}.idiom-v2-nickname-row{display:flex;align-items:center;gap:10px;padding-top:4px;border-top:1px solid var(--border)}.idiom-v2-chain-card{min-height:380px;display:flex;flex-direction:column;gap:16px}.idiom-v2-chain-header{display:flex;justify-content:space-between;align-items:center}.idiom-v2-chain-label{font-family:var(--font-heading);font-size:12px;font-weight:600;letter-spacing:.05em;color:var(--text-faint);text-transform:uppercase}.idiom-v2-pts{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--tertiary);background:#ffb7861a;padding:3px 10px;border-radius:6px}.idiom-v2-chain-history{flex:1;display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:16px 0;min-height:120px}.idiom-v2-history-item{display:flex;align-items:center;gap:8px}.idiom-v2-history-word{padding:10px 14px;background:var(--panel-hover);border:1px solid var(--border);border-radius:var(--radius-md);font-size:18px;font-weight:700;font-family:var(--font-heading)}.idiom-v2-arrow{color:var(--primary);opacity:.6;font-size:16px}.idiom-v2-current{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 22px;background:#a8c5da14;border:2px solid var(--primary);border-radius:var(--radius-lg);animation:idiom-pulse 2s infinite ease-in-out}@keyframes idiom-pulse{0%,to{box-shadow:0 0 8px var(--primary-soft),inset 0 0 8px var(--primary-soft)}50%{box-shadow:0 0 24px var(--primary-soft),inset 0 0 16px var(--primary-soft)}}.idiom-v2-current-word{font-size:32px;font-weight:800;font-family:var(--font-heading);color:var(--text);letter-spacing:.05em}.idiom-v2-current-py{font-size:11px;font-family:var(--font-mono);color:var(--primary);background:var(--primary-soft);padding:2px 10px;border-radius:999px;text-transform:uppercase;font-weight:600}.idiom-v2-thinking{padding:18px 22px;border:2px dashed var(--border-strong);border-radius:var(--radius-lg);font-size:24px;color:var(--text-faint);letter-spacing:4px}.idiom-v2-input-area{display:flex;gap:8px;align-items:stretch;margin-top:auto}.idiom-v2-input{flex:1;background:var(--panel-hover)!important;border:2px solid var(--border-strong)!important;border-radius:var(--radius-md)!important;padding:12px 16px!important;font-size:18px!important;font-weight:700;font-family:var(--font-heading)!important;min-height:52px}.idiom-v2-input:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px var(--primary-soft),0 0 16px var(--primary-soft)!important}.idiom-v2-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.idiom-v2-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.idiom-v2-stat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 12px;text-align:center}.idiom-v2-stat-label{font-size:11px;color:var(--text-faint);font-family:var(--font-heading);letter-spacing:.05em;text-transform:uppercase}.idiom-v2-stat-val{font-family:var(--font-heading);font-size:22px;font-weight:800}.idiom-v2-over-card{text-align:center}.idiom-v2-over-msg{font-size:18px;font-weight:700;font-family:var(--font-heading);margin-bottom:8px;color:var(--primary)}.idiom-v2-over-score{font-size:15px;color:var(--text-soft);margin-bottom:16px}.idiom-v2-over-score strong{font-size:28px;color:var(--text);font-family:var(--font-heading)}.idiom-v2-card-title{font-family:var(--font-heading);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);margin-bottom:12px;display:flex;align-items:center;gap:6px}.idiom-v2-diff-grid{display:grid;grid-template-columns:1fr;gap:8px}.idiom-v2-diff-btn{padding:10px 8px;background:var(--panel-hover);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:12px;font-weight:700;color:var(--text-soft);display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;transition:all var(--transition)}.idiom-v2-diff-btn:hover{border-color:var(--lc, var(--primary));color:var(--lc, var(--primary));transform:none;box-shadow:none;filter:none}.idiom-v2-diff-btn.active{border-color:var(--lc, var(--primary));color:var(--lc, var(--primary));background:rgba(from var(--lc) r g b / .08);box-shadow:0 0 10px rgba(from var(--lc) r g b / .15)}.idiom-v2-diff-btn.active{border-color:var(--lc, var(--primary));color:var(--lc, var(--primary));background:color-mix(in srgb,var(--lc, var(--primary)) 8%,transparent)}.idiom-v2-diff-desc{font-size:10px;opacity:.65;font-weight:400;font-family:var(--font-sans);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.idiom-v2-leader-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.idiom-v2-leader-tabs{display:flex;gap:4px;align-items:center}.idiom-v2-diff-tabs{display:flex;gap:4px;margin-bottom:12px}@media (max-width: 768px){.idiom-v2-grid{grid-template-columns:1fr}.idiom-v2-title{font-size:28px}}
