*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#000;--bg-2:#0d0d0d;--bg-3:#161616;--bg-4:#1e1e1e;--border:#2a2a2a;--border-2:#383838;--text:#e8e8e8;--text-2:#a0a0a0;--text-3:#606060;--accent:#4a90d9;--accent-dim:#4a90d926;--accent-hover:#5a9fe8;--green:#22c55e;--green-dim:#22c55e26;--red:#ef4444;--red-dim:#ef444426;--orange:#f97316;--orange-dim:#f9731626;--yellow:#eab308;--yellow-dim:#eab30826;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.5}[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}[data-theme=light] body{background:var(--bg)}[data-theme=light] .rep-color-label[data-color=white]{color:var(--text-2);border:1px solid var(--border);background:#0000000f}[data-theme=light] .rep-color-label[data-color=black]{color:var(--text);border:1px solid var(--border-2);background:#0000001a}[data-site-theme=midnight]{--bg:#000;--bg-2:#0d0d0d;--bg-3:#161616;--bg-4:#1e1e1e;--border:#2a2a2a;--border-2:#383838;--text:#e8e8e8;--text-2:#a0a0a0;--text-3:#606060;--accent:#4a90d9;--accent-dim:#4a90d926;--accent-hover:#5a9fe8}[data-site-theme=graphite]{--bg:#1c1c1c;--bg-2:#242424;--bg-3:#2c2c2c;--bg-4:#363636;--border:#444;--border-2:#545454;--text:#e0e0e0;--text-2:#9a9a9a;--text-3:#5a5a5a;--accent:#4a90d9;--accent-dim:#4a90d926;--accent-hover:#5a9fe8}[data-site-theme=navy]{--bg:#08111e;--bg-2:#0e1828;--bg-3:#152032;--bg-4:#1d2a40;--border:#283a58;--border-2:#364e70;--text:#d8e8f8;--text-2:#8099b8;--text-3:#4d6280;--accent:#60a5fa;--accent-dim:#60a5fa26;--accent-hover:#7bb8fc}[data-site-theme=forest]{--bg:#080e08;--bg-2:#0d160d;--bg-3:#131e13;--bg-4:#192619;--border:#223622;--border-2:#2c482c;--text:#d8f0d8;--text-2:#7aaa7a;--text-3:#4a6e4a;--accent:#4ade80;--accent-dim:#4ade8026;--accent-hover:#6aee9a}[data-site-theme=parchment]{--bg:#f5f0e8;--bg-2:#f5f0e8;--bg-3:#f6f1de;--bg-4:#ddd8ce;--border:#c8c1b8;--border-2:#b8b0a6;--text:#1e1b16;--text-2:#5a5248;--text-3:#8a8078;--accent:#4a90d9;--accent-dim:#4a90d926;--accent-hover:#5a9fe8}[data-site-theme=ocean]{--bg:#eef6ff;--bg-2:#e4f0ff;--bg-3:#d2e8ff;--bg-4:#b8d8ff;--border:#90bce0;--border-2:#6ea0cc;--text:#0d2440;--text-2:#3a5878;--text-3:#6685a8;--accent:#07c;--accent-dim:#0077cc26;--accent-hover:#08e}[data-site-theme=rose]{--bg:#fff5f7;--bg-2:#ffecf0;--bg-3:#ffdde4;--bg-4:#f8c0cc;--border:#e8a0b0;--border-2:#d47888;--text:#3d0f1a;--text-2:#7a3a48;--text-3:#a86070;--accent:#e0305a;--accent-dim:#e0305a26;--accent-hover:#f04575}[data-site-theme=mint]{--bg:#f0fdf6;--bg-2:#e6faf0;--bg-3:#d0f5e4;--bg-4:#b0ebcc;--border:#80d0a8;--border-2:#5ab88a;--text:#0a2c1e;--text-2:#286040;--text-3:#508e68;--accent:#16a34a;--accent-dim:#16a34a26;--accent-hover:#22c458}[data-site-theme=lavender]{--bg:#faf5ff;--bg-2:#f3e8ff;--bg-3:#e8d4ff;--bg-4:#d4b0fe;--border:#a880e0;--border-2:#8858c8;--text:#2a1548;--text-2:#5a3898;--text-3:#8460c0;--accent:#7c3aed;--accent-dim:#7c3aed26;--accent-hover:#9050ff}html{scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:#78787899 transparent;overflow-y:scroll}::-webkit-scrollbar-thumb{background-color:#78787899;border-radius:8px}::-webkit-scrollbar-thumb:hover{background-color:#787878e6}body{background:var(--bg);min-height:100vh}#root{min-height:100vh}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-4);color:var(--text);border:1px solid var(--border-2);cursor:pointer;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:background .15s}.btn-secondary:hover:not(:disabled){background:var(--bg-3)}.btn-ghost{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 12px;font-size:14px;transition:color .15s,background .15s}.btn-ghost:hover{color:var(--text);background:var(--bg-4)}.btn-danger-sm{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:18px;transition:color .15s,background .15s;display:flex}.btn-danger-sm:hover{color:var(--red);background:var(--red-dim)}.btn-danger{background:var(--red);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:9px 18px;font-size:14px;font-weight:600;transition:opacity .15s}.btn-danger:hover{opacity:.85}.loading-full{min-height:100vh;color:var(--text-2);justify-content:center;align-items:center;display:flex}.loading-state{text-align:center;color:var(--text-2);padding:60px}.auth-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--bg-3);border:1px solid var(--border);border-radius:16px;width:100%;max-width:400px;padding:40px}.auth-logo{text-align:center;margin-bottom:8px;font-size:48px}.auth-title{text-align:center;color:var(--text);font-size:26px;font-weight:700}.auth-subtitle{color:var(--text-2);text-align:center;margin-bottom:28px;font-size:14px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-error{background:var(--red-dim);border:1px solid var(--red);color:var(--red);border-radius:8px;padding:10px 14px;font-size:13px}.auth-banned{background:var(--red-dim);border:1px solid var(--red);color:var(--red);border-radius:8px;align-items:flex-start;gap:10px;padding:12px 14px;font-size:13px;font-weight:600;display:flex}.auth-banned svg{flex-shrink:0;margin-top:1px}.auth-banned-reason{margin-top:4px;font-weight:400}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-2);font-size:13px;font-weight:500}.form-group input,.form-group textarea,.form-group select{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text);resize:vertical;border-radius:8px;outline:none;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-3)}.auth-form .btn-primary{width:100%;margin-top:4px;padding:12px}.auth-switch{text-align:center;color:var(--text-2);margin-top:20px;font-size:13px}.auth-switch a{color:var(--accent);font-weight:500;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.dashboard{flex-direction:column;min-height:100vh;padding-left:240px;display:flex}.dash-header{background:var(--bg-2);border-right:1px solid var(--border);z-index:200;flex-direction:column;justify-content:flex-start;align-items:stretch;width:240px;height:100vh;padding:20px 8px;transition:width .22s,box-shadow .22s;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.dash-header--collapsed{width:48px}.dash-header--floating{box-shadow:4px 0 24px #00000038}.dash-header--collapsed .nav-link{justify-content:center;padding:8px}.dash-header--collapsed .nav-link-label,.dash-header--collapsed .nav-dropdown-chevron,.dash-header--collapsed .sidebar-bottom-content{display:none}.dash-header--collapsed .sidebar-collapse-btn{justify-content:center;padding:8px}.sidebar-collapse-btn{color:var(--text-3);cursor:pointer;white-space:nowrap;text-align:left;background:0 0;border:none;border-radius:6px;flex-shrink:0;align-items:center;gap:9px;width:100%;margin-top:4px;padding:6px 12px;font-size:13px;font-weight:500;transition:color .15s,background .15s;display:flex}.sidebar-collapse-btn:hover{color:var(--text);background:var(--bg-3)}body.sidebar-collapsed .dashboard,body.sidebar-collapsed .editor-layout,body.sidebar-collapsed .study-page,body.sidebar-collapsed .profile-page,body.sidebar-collapsed .training-page{padding-left:48px}body.sidebar-collapsed .site-footer{padding-left:80px}body.sidebar-collapsed .board-wrapper{width:min(calc(100vw - 48px - var(--right-panel-width,440px) - 48px), calc(100vh - 48px))}body.sidebar-collapsed .study-board-wrapper{width:min(100vw - 546px,100vh - 48px)!important}.dash-brand{color:var(--text);letter-spacing:-.3px;cursor:pointer;white-space:nowrap;border-bottom:1px solid var(--border);margin-bottom:4px;padding:4px 8px 16px;font-size:20px;font-weight:700}.main-nav{flex-direction:column;flex:1;justify-content:flex-start;align-items:stretch;gap:2px;padding:4px 0;display:flex}.nav-link{color:var(--text-2);cursor:pointer;white-space:nowrap;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:9px;width:100%;padding:7px 12px;font-size:14px;font-weight:500;transition:color .15s,background .15s;display:flex;overflow:hidden}.nav-link:hover{color:var(--text);background:var(--bg-3)}.nav-link.active{color:var(--text);background:var(--bg-4)}.nav-link svg,.nav-submenu-item svg{flex-shrink:0}.nav-dropdown-wrap{position:relative}.nav-link--dropdown{justify-content:space-between;align-items:center;gap:4px;display:flex}.nav-dropdown-chevron{flex-shrink:0;transition:transform .15s}.nav-link--dropdown.open .nav-dropdown-chevron{transform:rotate(180deg)}.nav-submenu{box-shadow:none;background:0 0;border:none;border-radius:0;flex-direction:column;gap:1px;margin-top:2px;padding:2px 0 2px 10px;display:flex;position:static}.nav-submenu-item{text-align:left;width:100%;color:var(--text-2);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:5px;align-items:center;gap:8px;padding:6px 12px;font-size:13px;font-weight:500;transition:color .12s,background .12s;display:flex}.nav-submenu-item:hover,.nav-submenu-item.active{color:var(--text);background:var(--bg-3)}.nav-link--soon{color:var(--text-3);opacity:.5;cursor:default;-webkit-user-select:none;user-select:none;background:0 0;border:none;border-radius:6px;align-items:center;gap:5px;padding:6px 12px;font-size:14px;font-weight:500;display:flex;position:relative}.nav-soon-badge{text-transform:uppercase;letter-spacing:.06em;background:var(--accent);color:#fff;border-radius:4px;padding:1px 5px;font-size:9px;font-weight:700;line-height:1.5}.mobile-header-right{align-items:center;gap:4px;display:none}.hamburger-btn{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;transition:background .15s;display:flex}.hamburger-btn:hover{background:var(--bg-3)}.hamburger-bar{background:var(--text);transform-origin:50%;border-radius:2px;width:100%;height:2px;transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .28s cubic-bezier(.4,0,.2,1);display:block}.hamburger-btn.open .hamburger-bar:first-child{transform:translateY(7px)rotate(45deg)}.hamburger-btn.open .hamburger-bar:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger-btn.open .hamburger-bar:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;opacity:0;background:#0000008c;transition:opacity .32s cubic-bezier(.4,0,.2,1);display:none;position:fixed;inset:0}.mobile-overlay.open{opacity:1}.mobile-nav{background:var(--bg-2);border-left:1px solid var(--border);z-index:201;flex-direction:column;width:280px;transition:transform .32s cubic-bezier(.4,0,.2,1);display:none;position:fixed;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-8px 0 32px #0003}.mobile-nav.open{transform:translate(0)}.mobile-nav-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.mobile-nav-brand{color:var(--text);letter-spacing:-.3px;font-size:18px;font-weight:700}.mobile-nav-close{width:32px;height:32px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.mobile-nav-close:hover{background:var(--bg-3);color:var(--text)}.mobile-nav-links{flex-direction:column;gap:2px;padding:12px 12px 4px;display:flex}.mobile-nav-link{color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:11px 14px;font-size:15px;font-weight:500;transition:background .15s,color .15s;display:flex}.mobile-nav-link:hover{background:var(--bg-3);color:var(--text)}.mobile-nav-link.active{background:var(--bg-4);color:var(--text)}.mobile-nav-link--parent{align-items:center;display:flex}.mobile-nav-link--child{color:var(--text-2);padding-left:28px;font-size:14px}.mobile-nav-link--soon{color:var(--text-3);opacity:.5;cursor:default;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:8px;padding:11px 14px;font-size:15px;font-weight:500;display:flex}.mobile-nav-divider{background:var(--border);flex-shrink:0;height:1px;margin:8px 12px}.mobile-nav-user{flex-direction:column;gap:2px;padding:4px 12px 20px;display:flex}.mobile-nav-user-info{align-items:center;gap:10px;margin-bottom:4px;padding:10px 14px;display:flex}.mobile-nav-avatar{object-fit:cover;background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.mobile-nav-avatar.initials{justify-content:center;align-items:center;display:flex}.mobile-nav-username{color:var(--text);font-size:14px;font-weight:600}.mobile-nav-item{color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px 14px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.mobile-nav-item:hover{background:var(--bg-3);color:var(--text)}.mobile-nav-item.danger{color:#ef4444}.mobile-nav-item.danger:hover{background:#ef444414}.mobile-nav-auth{flex-direction:column;gap:8px;padding:16px 20px;display:flex}.mobile-icon{display:flex!important}.nav-search-wrap{flex-shrink:0;width:100%;height:32px;position:relative}.nav-search-input{background:var(--bg-3);border:1px solid var(--border);color:var(--text);z-index:10;border-radius:8px;outline:none;width:100%;height:32px;padding:0 32px 0 12px;font-size:13px;transition:border-color .15s;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.nav-search-input::placeholder{color:var(--text-3)}.nav-search-input:focus{border-color:var(--accent);width:100%}.nav-search-icon{color:var(--text-3);pointer-events:none;z-index:11;position:absolute;top:50%;right:9px;transform:translateY(-50%)}.nav-search-dropdown{top:0;left:var(--sidebar-w,240px);background:var(--bg-3);border-right:1px solid var(--border);z-index:300;border-radius:0;flex-direction:column;width:360px;height:100vh;display:flex;position:fixed;overflow-y:auto;box-shadow:6px 0 20px #00000059}.nav-search-loading,.nav-search-empty{color:var(--text-3);text-align:center;padding:20px 16px;font-size:13px}.nav-search-section{border-bottom:1px solid var(--border)}.nav-search-section:last-of-type{border-bottom:none}.nav-search-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);align-items:center;gap:5px;padding:8px 14px 4px;font-size:10px;font-weight:700;display:flex}.nav-search-item{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:7px 14px;transition:background .12s;display:flex}.nav-search-item:hover{background:var(--bg-4)}.nav-search-item-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.nav-search-item-sub{color:var(--text-3);flex-shrink:0;font-size:11px}.nav-search-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:22px;height:22px}.nav-search-avatar-init{background:var(--accent);color:#fff;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex}.nav-search-see-all{border:none;border-top:1px solid var(--border);width:100%;color:var(--accent);cursor:pointer;text-align:center;background:0 0;padding:10px 14px;font-size:12px;font-weight:600;transition:background .12s;display:block}.nav-search-see-all:hover{background:var(--bg-4)}.search-page-form{margin-bottom:28px}.search-page-input-wrap{max-width:600px;position:relative}.search-page-icon{color:var(--text-3);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-page-input{background:var(--bg-3);border:1px solid var(--border);width:100%;color:var(--text);border-radius:10px;outline:none;padding:12px 16px 12px 44px;font-size:15px;transition:border-color .15s}.search-page-input:focus{border-color:var(--accent)}.search-page-title{color:var(--text-2);margin-bottom:20px;font-size:16px;font-weight:600}.search-page-title strong{color:var(--text)}.search-hint{color:var(--text-3);margin-top:12px;font-size:14px}.search-results-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.search-section{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;overflow:hidden}.search-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);border-bottom:1px solid var(--border);align-items:center;gap:6px;padding:12px 16px;font-size:11px;font-weight:700;display:flex}.search-result-item{border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:10px;width:100%;padding:10px 16px;transition:background .12s;display:flex}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-3)}.search-result-dot{background:var(--text-3);border-radius:50%;flex-shrink:0;width:8px;height:8px}.search-result-dot.color-white{background:#e8e8e8}.search-result-dot.color-black{background:#333}.search-result-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:28px;height:28px}.search-result-avatar-init{background:var(--accent);color:#fff;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.search-result-thumb{object-fit:cover;border-radius:4px;flex-shrink:0;width:36px;height:28px}.search-result-body{flex:1;min-width:0}.search-result-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;display:block;overflow:hidden}.search-result-sub{color:var(--text-3);margin-top:1px;font-size:11px;display:block}.nav-icon-wrap{position:relative}.nav-icon-btn{width:34px;height:34px;color:var(--text-2);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;transition:color .15s,background .15s,border-color .15s;display:flex}.nav-icon-btn:hover,.nav-icon-btn.open{color:var(--text);background:var(--bg-3);border-color:var(--border)}.nav-dropdown{background:var(--bg-3);border:1px solid var(--border);z-index:200;border-radius:10px;width:300px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 24px #00000080}.nav-dropdown-header{color:var(--text);border-bottom:1px solid var(--border);padding:12px 16px;font-size:13px;font-weight:600}.nav-dropdown-empty{text-align:center;color:var(--text-3);padding:24px 16px;font-size:13px}.nav-dropdown-footer{border-top:1px solid var(--border)}.nav-dropdown-see-all{width:100%;color:var(--accent);text-align:center;cursor:pointer;background:0 0;border:none;padding:11px 16px;font-size:13px;font-weight:500;transition:background .15s;display:block}.nav-dropdown-see-all:hover{background:var(--bg-4)}.sidebar-panel-backdrop{inset:0;left:var(--sidebar-w,240px);z-index:299;position:fixed}.sidebar-panel{left:var(--sidebar-w,240px);background:var(--bg-3);border-right:1px solid var(--border);z-index:300;flex-direction:column;width:320px;height:100vh;display:flex;position:fixed;top:0;box-shadow:6px 0 20px #00000059}.sidebar-panel-header{color:var(--text);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;font-size:14px;font-weight:600;display:flex}.sidebar-panel-close{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.sidebar-panel-close:hover{color:var(--text);background:var(--bg-4)}.sidebar-panel-list{flex:1;overflow-y:auto}.sidebar-panel-footer{border-top:1px solid var(--border);flex-shrink:0;padding:10px 12px}.sidebar-panel-see-all{width:100%;color:var(--accent);cursor:pointer;text-align:center;background:0 0;border:none;border-radius:6px;padding:8px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s}.sidebar-panel-see-all:hover{background:var(--accent-dim)}.page-placeholder-title{color:var(--text);padding:48px 0 0;font-size:28px;font-weight:700}.sidebar-bottom{border-top:1px solid var(--border);flex-direction:column;gap:2px;margin-top:4px;padding-top:8px;display:flex}.sidebar-divider{background:var(--border);flex-shrink:0;height:1px;margin:4px 0}.sidebar-action-btn{color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;flex-shrink:0;align-items:center;gap:8px;width:100%;padding:7px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:color .15s,background .15s;display:flex;position:relative}.sidebar-action-btn:hover{color:var(--text);background:var(--bg-3)}.sidebar-action-btn.active-panel{color:var(--text);background:var(--bg-4)}.sidebar-action-btn.danger{color:var(--red)}.sidebar-action-btn.danger:hover{color:var(--red);background:var(--red-dim)}.sidebar-badge{color:#fff;text-align:center;background:#e53e3e;border-radius:99px;min-width:18px;height:18px;margin-left:auto;padding:0 4px;font-size:10px;font-weight:700;line-height:18px}.sidebar-profile-btn{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text);cursor:pointer;text-align:left;border-radius:8px;flex-shrink:0;align-items:center;gap:8px;width:100%;padding:6px 10px;font-family:inherit;font-size:13px;transition:background .15s;display:flex}.sidebar-profile-btn:hover{background:var(--bg-3)}.sidebar-profile-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.sidebar-auth{flex-direction:column;gap:6px;padding:4px 0;display:flex}.user-menu{position:relative}.user-menu-trigger{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;font-family:inherit;font-size:14px;transition:background .15s,border-color .15s;display:flex}.user-menu-trigger:hover{background:var(--bg-3);border-color:var(--border-2)}.user-menu-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.user-menu-avatar-img{object-fit:cover;border-radius:50%;flex-shrink:0;width:28px;height:28px}.user-menu-name{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.user-menu-caret{color:var(--text-3);font-size:9px}.user-menu-dropdown{background:var(--bg-3);border:1px solid var(--border-2);z-index:200;border-radius:10px;flex-direction:column;gap:2px;min-width:180px;padding:6px;display:flex;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #00000080}.user-menu-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:9px 12px;font-family:inherit;font-size:14px;transition:background .12s;display:flex}.user-menu-item:hover:not(:disabled){background:var(--bg-4)}.user-menu-item:disabled{opacity:.45;cursor:default}.user-menu-item.danger{color:var(--red)}.user-menu-item.danger:hover{background:var(--red-dim)}.user-menu-item{gap:8px}.user-menu-item svg{flex-shrink:0}.btn-icon-label{align-items:center;gap:6px;display:inline-flex}.context-menu-item svg{flex-shrink:0}.soon-badge{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text-3);border-radius:8px;margin-left:auto;padding:1px 6px;font-size:10px}.user-menu-divider{background:var(--border);height:1px;margin:4px 0}.theme-toggle-row{justify-content:space-between;align-items:center;gap:8px;padding:7px 12px;display:flex}.theme-toggle-label{color:var(--text);align-items:center;gap:6px;font-size:14px;display:flex}.theme-toggle-switch{flex-shrink:0;width:44px;height:24px;position:relative}.theme-toggle-switch input{opacity:0;width:0;height:0;position:absolute}.theme-toggle-track{background:var(--bg-4);border:1px solid var(--border-2);cursor:pointer;border-radius:12px;transition:background .2s,border-color .2s;position:absolute;inset:0}.theme-toggle-switch input:checked+.theme-toggle-track{background:var(--accent-dim);border-color:var(--accent)}.theme-toggle-track:after{content:"";background:var(--text-2);border-radius:50%;width:18px;height:18px;transition:transform .2s,background .2s;position:absolute;top:2px;left:3px}.theme-toggle-switch input:checked+.theme-toggle-track:after{background:var(--accent);transform:translate(20px)}.profile-avatar-card{align-items:center;flex-direction:row!important;gap:24px!important}.avatar-preview{background:var(--accent);border:2px solid var(--border-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;display:flex;overflow:hidden}.avatar-img{object-fit:cover;width:100%;height:100%}.avatar-placeholder{color:#fff;font-size:32px;font-weight:700}.avatar-actions{flex-direction:column;gap:6px;display:flex}.avatar-hint{color:var(--text-3);font-size:12px}.avatar-upload-btn{cursor:pointer;text-align:center;display:inline-block}.avatar-upload-btn.disabled{opacity:.5;pointer-events:none}.study-progress-bar-row{background:var(--bg-2);border-bottom:1px solid var(--border);color:var(--text-2);justify-content:space-between;align-items:center;gap:12px;padding:8px 24px;font-size:13px;display:flex}.study-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.study-reviewed{color:var(--text-3);flex-shrink:0;font-size:12px}.editor-subheader{background:var(--bg-2);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 24px;display:flex}.dash-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:40px 32px}.dash-title-row{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.dash-title-row h2{font-size:24px;font-weight:700}.modal-overlay{z-index:100;background:#000000bf;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-3);border:1px solid var(--border-2);border-radius:16px;flex-direction:column;gap:16px;width:100%;max-width:440px;padding:32px;display:flex}.modal h3{font-size:18px;font-weight:600}.modal.modal-sm{max-width:360px;padding:24px}.modal-body-text{color:var(--text-2);font-size:14px;line-height:1.5}.modal-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.color-toggle{gap:8px;display:flex}.color-toggle button{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text-2);cursor:pointer;border-radius:8px;flex:1;padding:10px;font-size:14px;transition:all .15s}.color-toggle button.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.empty-state{text-align:center;color:var(--text-2);padding:80px 0}.empty-icon{margin-bottom:16px;font-size:64px}.repertoire-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.load-more-wrap{justify-content:center;margin-top:32px;display:flex}.load-more-btn{min-width:160px}.repertoire-card{background:var(--bg-3);border:1px solid var(--border);border-radius:14px;flex-direction:row;min-height:140px;transition:border-color .15s;display:flex;position:relative;overflow:hidden}.repertoire-card:hover{border-color:var(--border-2)}.card-delete-btn{z-index:2;width:24px;height:24px;color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:color .15s,background .15s;display:flex;position:absolute;top:8px;right:8px}.card-delete-btn:hover{color:var(--red);background:var(--red-dim)}.rep-color-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.board-preview-mini{aspect-ratio:1;pointer-events:none;-webkit-user-select:none;user-select:none;flex-shrink:0;align-self:stretch;width:38%;overflow:hidden}.board-preview-mini>*{width:100%!important;height:100%!important}.rep-card-body{flex-direction:column;flex:1;gap:8px;min-width:0;padding:14px 16px;display:flex}.rep-progress{margin-top:auto}.rep-progress-label{color:var(--text-3);justify-content:space-between;margin-bottom:4px;font-size:11px;display:flex}.rep-progress-bar{background:var(--bg-4);border-radius:2px;height:4px;overflow:hidden}.rep-progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .3s}.rep-card-header{justify-content:space-between;align-items:center;display:flex}.rep-color-badge{font-size:22px}.rep-color-badge[data-color=white]{color:#f5f5f5}.rep-color-badge[data-color=black]{color:var(--text-2)}.rep-visibility-badge{opacity:.6;margin-left:6px;font-size:14px}.rep-visibility-badge.public{opacity:1}.rep-author-badge{color:var(--text-3);background:var(--bg-3);border-radius:10px;margin-left:auto;padding:2px 8px;font-size:12px}.dash-section-divider{border:none;border-top:1px solid var(--border);margin:8px 0 4px}.empty-state.small{padding:16px 0}.empty-state.small .empty-icon{display:none}.rep-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:17px;font-weight:700;overflow:hidden}.rep-desc{color:var(--text-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;font-size:12px;display:-webkit-box;overflow:hidden}.rep-stats{color:var(--text-3);flex-wrap:wrap;gap:8px;margin-top:auto;font-size:11px;display:flex}.rep-stat{align-items:center;gap:3px;display:flex}.rep-stat-count{color:var(--text-3)}.rep-stat-author{color:var(--text-3);margin-left:auto;font-style:italic}.rep-stat-author-link{cursor:pointer;transition:color .15s}.rep-stat-author-link:hover{color:var(--accent)}.rep-actions{gap:6px;margin-top:auto;display:flex}.rep-actions button{flex:1;padding:6px 8px;font-size:12px}.editor-layout{flex-direction:column;height:100vh;padding-left:240px;display:flex;overflow:hidden}.editor-header{background:var(--bg-2);border-bottom:1px solid var(--border);align-items:center;gap:20px;padding:16px 32px;display:flex}.editor-header h2{flex:1;font-size:18px;font-weight:600}.editor-title-display{align-items:center;gap:6px;display:flex}.editor-title-edit-btn{cursor:pointer;color:var(--text-muted);opacity:0;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px 4px;transition:opacity .15s;display:flex}.editor-title-display:hover .editor-title-edit-btn{opacity:1}.editor-title-input{background:var(--bg-card);border:1px solid var(--accent);color:var(--text);border-radius:6px;outline:none;flex:1;padding:2px 8px;font-size:18px;font-weight:600}.color-chip{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text-2);border-radius:20px;padding:4px 10px;font-size:13px}.color-chip[data-color=white]{color:#e0e0e0}.color-chip[data-color=black]{color:var(--text-2)}.visibility-chip{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text-3);cursor:pointer;border-radius:20px;padding:4px 10px;font-family:inherit;font-size:12px;transition:background .15s,color .15s,border-color .15s}.visibility-chip.public{color:#4ade80;background:#22c55e1f;border-color:#22c55e66}.visibility-chip.shared{color:#63b3ed;background:#63b3ed1f;border-color:#63b3ed66}.visibility-chip.inactive{opacity:.45}.visibility-chip-group{align-items:center;gap:6px;display:flex}.visibility-selector{gap:6px;display:flex}.visibility-option{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text-3);cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:5px;padding:6px 10px;font-family:inherit;font-size:12px;transition:background .15s,color .15s,border-color .15s;display:flex}.visibility-option.active{background:rgba(var(--accent-rgb,99, 179, 237), .15);border-color:var(--accent,#63b3ed);color:var(--accent,#63b3ed)}.share-link-row{align-items:center;gap:6px;display:flex}.share-link-input{border:1px solid var(--border-2);background:var(--bg-3);color:var(--text-3);border-radius:6px;width:220px;padding:4px 8px;font-family:monospace;font-size:12px}.share-link-copy{padding:4px 10px;font-size:12px}.visibility-toggle{align-items:center;gap:12px;display:flex}.visibility-label{color:var(--text);flex:1;font-size:14px}.visibility-hint{color:var(--text-3);margin:0;font-size:12px}.toggle-switch{background:var(--bg-4);border:1px solid var(--border-2);cursor:pointer;border-radius:12px;flex-shrink:0;width:44px;height:24px;padding:0;transition:background .2s,border-color .2s;position:relative}.toggle-switch:after{content:"";background:var(--text-3);border-radius:50%;width:16px;height:16px;transition:transform .2s,background .2s;position:absolute;top:3px;left:3px}.toggle-switch.on{background:#22c55e33;border-color:#22c55e80}.toggle-switch.on:after{background:#4ade80;transform:translate(20px)}.rep-author{color:var(--text-3);margin-left:auto;font-size:12px}.editor-body{flex:1;min-height:0;display:flex;overflow:hidden}.board-panel{background:var(--bg);flex-direction:column;flex:1;align-items:center;gap:12px;min-width:0;padding:24px;display:flex;position:relative}.board-wrapper{width:min(calc(100vw - 240px - var(--right-panel-width,440px) - 48px), calc(100vh - 48px));aspect-ratio:1;flex-shrink:0}.board-controls{align-items:center;gap:10px;width:100%;display:flex}.board-loading{aspect-ratio:1;background:var(--bg-3);width:100%;color:var(--text-3);border-radius:4px;justify-content:center;align-items:center;font-size:14px;display:flex}.status-saving{color:var(--text-3);font-size:13px}.status-ok{color:var(--green);font-size:13px}.move-history{flex-wrap:wrap;gap:6px;width:100%;display:flex}.move-chip{background:var(--bg-4);border:1px solid var(--border);color:var(--text-2);border-radius:6px;padding:3px 8px;font-family:Courier New,monospace;font-size:13px}.analysis-side-panel{flex-direction:column;flex-shrink:0;width:440px;min-height:0;display:flex;overflow:hidden}.side-panel-resize{cursor:col-resize;background:var(--border);flex-shrink:0;width:5px;transition:background .15s}.side-panel-resize:hover{background:color-mix(in srgb, var(--accent) 60%, var(--border) 40%)}.analysis-panel-header{border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:4px;padding:8px 10px;display:flex}.analysis-panel-header-actions{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.analysis-action-btn{background:var(--bg-3);border:1px solid var(--border);min-width:32px;height:32px;color:var(--text-2);cursor:pointer;white-space:nowrap;border-radius:8px;flex-shrink:0;align-items:center;transition:background .14s,color .14s;display:inline-flex;overflow:hidden}.analysis-action-btn:hover:not(:disabled){background:var(--bg-2);color:var(--text)}.analysis-action-btn.active{background:var(--accent-subtle,#6366f11f);color:var(--accent)}.analysis-action-btn:disabled{opacity:.4;cursor:not-allowed}.analysis-action-btn .aab-icon{flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.analysis-action-btn .aab-label{opacity:0;max-width:0;padding-right:0;font-size:12px;font-weight:500;transition:max-width .26s cubic-bezier(.4,0,.2,1),opacity .18s,padding-right .26s cubic-bezier(.4,0,.2,1);overflow:hidden}.analysis-action-btn:not(:disabled):hover .aab-label{opacity:1;max-width:110px;padding-right:10px}.analysis-action-btn--save{background:var(--accent);color:#fff;border-color:#0000}.analysis-action-btn--save:hover:not(:disabled){background:var(--accent-hover);color:#fff}@media (width<=900px){.analysis-side-panel{width:100%;height:800px}.editor-layout{height:100vh}}.tree-panel{background:var(--bg-2);flex-direction:column;flex-shrink:0;width:440px;display:flex;overflow:hidden}.tree-panel-header{border-bottom:1px solid var(--border);background:var(--bg-3);flex-direction:column;flex-shrink:0;gap:6px;padding:10px 12px 8px;display:flex}.tree-panel-header-top{align-items:center;gap:6px;min-width:0;display:flex}.tree-panel-header-bottom{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.chapters-header{border-bottom:1px solid var(--border);background:var(--bg-3);flex-shrink:0;padding:8px 12px 0}.chapter-tabs{flex-wrap:wrap;gap:4px;display:flex}.chapter-tab{border:1px solid var(--border);color:var(--text-2);cursor:pointer;background:0 0;border-bottom:none;border-radius:6px 6px 0 0;padding:6px 14px;font-family:inherit;font-size:13px;transition:background .15s,color .15s}.chapter-tab:hover{background:var(--bg-4);color:var(--text)}.chapter-tab.active{background:var(--bg-2);color:var(--text);border-color:var(--border-2)}.chapter-tab.add-chapter{color:var(--text-3);padding:4px 12px;font-size:18px}.chapter-tab.add-chapter:hover{color:var(--accent)}.board-edit-row{justify-content:center;align-items:flex-start;gap:14px;width:100%;display:flex}.board-edit-row .board-wrapper{flex-shrink:0;width:min(44vw,78vh)}.board-edit-sidebar{flex-direction:column;flex-shrink:0;gap:10px;width:170px;padding-top:2px;display:flex}.board-edit-palette{grid-template-columns:repeat(3,1fr);gap:4px;display:grid}.board-edit-piece-btn{background:var(--bg-3);cursor:pointer;aspect-ratio:1;border:2px solid #0000;border-radius:5px;justify-content:center;align-items:center;padding:4px;transition:background .1s,border-color .1s;display:flex}.board-edit-piece-btn:hover{background:var(--bg-4)}.board-edit-piece-btn.selected{border-color:var(--accent);background:var(--bg-4)}.board-edit-piece-btn img{pointer-events:none;width:100%;height:auto;display:block}.board-edit-eraser-btn{background:var(--bg-3);color:var(--text-2);cursor:pointer;border:2px solid #0000;border-radius:5px;grid-column:span 3;justify-content:center;align-items:center;gap:5px;padding:5px;font-size:12px;transition:background .1s,border-color .1s;display:flex}.board-edit-eraser-btn:hover{background:var(--bg-4)}.board-edit-eraser-btn.selected{border-color:var(--accent);background:var(--bg-4);color:var(--accent)}.board-edit-divider{background:var(--border);height:1px}.board-edit-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);font-size:10px;font-weight:600}.board-edit-side-row,.board-edit-fen-row{flex-direction:column;gap:5px;display:flex}.board-edit-side-toggle{width:100%}.board-edit-side-toggle button{flex:1;padding:4px 6px;font-size:11px}.board-edit-fen-input{background:var(--bg-2);border:1px solid var(--border);color:var(--text);box-sizing:border-box;resize:none;border-radius:5px;width:100%;padding:5px 7px;font-family:monospace;font-size:10px}.board-edit-fen-input:focus{border-color:var(--accent);outline:none}.board-edit-clear{width:100%;padding:5px 8px;font-size:11px}.board-edit-actions{gap:6px;display:flex}.board-edit-actions .btn-ghost,.board-edit-actions .btn-primary{flex:1;justify-content:center;padding:6px 4px;font-size:12px}.board-overlay-btn.active{background:var(--accent-subtle,#6366f126);color:var(--accent)}.line-tabs-bar{border-bottom:1px solid var(--border);background:var(--bg-3)}.line-tabs{flex-wrap:wrap;gap:2px;padding:6px 8px 0;display:flex}.line-tab{color:var(--text-3);cursor:pointer;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:5px 5px 0 0;padding:4px 10px;font-family:inherit;font-size:12px;transition:background .15s,color .15s}.line-tab:hover{background:var(--bg-4);color:var(--text-2)}.line-tab.active{background:var(--bg-2);color:var(--text);border-color:var(--border)}.line-tab.add-line{color:var(--text-3);align-items:center;padding:4px 8px;display:flex}.line-tab.add-line:hover{color:var(--accent)}.line-fen-bar{align-items:center;gap:8px;padding:6px 10px;display:flex}.line-fen-label{color:var(--text-3);white-space:nowrap;font-size:11px}.line-fen-input{background:var(--bg-4);border:1px solid var(--border);color:var(--text);border-radius:4px;flex:1;min-width:0;padding:3px 6px;font-family:monospace;font-size:11px}.line-fen-input:focus{border-color:var(--accent);outline:none}.tree-empty{color:var(--text-3);padding:20px 16px;font-size:14px;line-height:1.7}.move-tree{padding:16px}.move-tree-wrap{flex-direction:column;height:100%;min-height:0;display:flex}.tree-tabs{border-bottom:1px solid var(--border);flex-shrink:0;gap:2px;margin-bottom:8px;padding:6px 8px 0;display:flex}.tree-tab{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:4px 10px 6px;font-size:12px;font-weight:500;transition:color .15s,border-color .15s}.tree-tab:hover{color:var(--text-2)}.tree-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.puzzle-defining-banner{background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent);border-radius:6px;flex-shrink:0;align-items:center;gap:6px;margin:0 8px 8px;padding:6px 10px;font-size:12px;display:flex}.puzzle-defining-banner span{flex:1}.puzzle-cancel-btn{color:var(--accent);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0 4px;font-size:12px}.puzzle-cancel-btn:hover{opacity:1}.puzzle-flash{background:var(--green-dim);border:1px solid var(--green);color:var(--green);border-radius:6px;flex-shrink:0;margin:0 8px 6px;padding:5px 10px;font-size:12px}.pgn-move.pgn-puzzle-start{background:var(--accent-dim);outline:1px solid var(--accent);border-radius:3px}.puzzle-tab-empty{text-align:center;color:var(--text-3);padding:24px 12px;font-size:13px}.puzzle-list{flex-direction:column;gap:4px;padding:4px 8px;display:flex;overflow-y:auto}.puzzle-item{background:var(--bg-4);border:1px solid var(--border);border-radius:6px;align-items:center;gap:6px;padding:6px 8px;display:flex}.puzzle-item-body{cursor:pointer;color:var(--text-2);text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:6px;padding:0;font-family:Courier New,monospace;font-size:13px;display:flex}.puzzle-item-body:hover{color:var(--text)}.puzzle-item-num{color:var(--text-3);min-width:20px;font-size:11px}.puzzle-item-arrow{color:var(--text-3);margin:0 2px}.puzzle-item-confirm{align-items:center;gap:4px;display:flex}.pgn-tree{color:var(--text-3);word-wrap:break-word;flex:1;min-height:0;padding:10px;font-family:Courier New,monospace;font-size:14px;line-height:2;overflow-y:auto}.pgn-num{color:var(--text-3);-webkit-user-select:none;user-select:none;margin-right:3px}.pgn-move{color:var(--green);cursor:pointer;border-radius:4px;margin:0 1px;padding:1px 4px;transition:background .12s,color .12s;display:inline-block}.pgn-move:hover{background:var(--bg-4)}.pgn-active{outline:1px solid var(--border-2);background:var(--bg-4)!important;color:var(--green)!important}.pgn-alt-block{border-left:2px solid var(--border-2);align-items:flex-start;margin:1px 0;padding-left:6px;display:flex}.pgn-alt-icon{color:var(--text-3);-webkit-user-select:none;user-select:none;flex-shrink:0;margin-right:5px;font-size:13px;line-height:2}.pgn-alt-body{word-wrap:break-word;flex:1;min-width:0}.pgn-comment{color:var(--text-3);margin:0 4px;font-size:13px;font-style:italic;display:inline}.pgn-comment-dot{background:var(--accent);vertical-align:super;border-radius:50%;flex-shrink:0;width:5px;height:5px;margin-left:2px;display:inline-block}.pgn-has-comment{position:relative}.pgn-comment-balloon{z-index:1200;background:var(--bg-3);border:1px solid var(--border-2);color:var(--text-2);pointer-events:all;border-radius:8px;max-width:300px;padding:8px 12px;font-size:13px;line-height:1.5;box-shadow:0 4px 16px #0000004d}.pgn-comment-move-token{background:var(--accent-dim);color:var(--accent);cursor:pointer;white-space:nowrap;border:none;border-radius:3px;padding:1px 4px;font-family:Courier New,monospace;font-size:13px;transition:background .1s,color .1s}.pgn-comment-move-token:hover{background:var(--accent);color:#fff}.board-preview-badge{color:#000;z-index:20;background:#f59e0b;border-radius:10px;align-items:center;gap:6px;padding:2px 10px;font-size:11px;font-weight:700;display:flex;position:absolute;top:6px;left:50%;transform:translate(-50%)}.board-preview-badge button{cursor:pointer;color:#000;background:0 0;border:none;padding:0;font-size:14px;font-weight:700;line-height:1}.board-wrapper.preview-mode{outline-offset:3px;border-radius:4px;outline:2px solid #f59e0b}.pgn-variation-title{color:var(--accent);letter-spacing:.2px;margin:0 4px 0 2px;font-size:12px;font-weight:600;display:inline}.pgn-variation-title-label{opacity:.7;margin-right:3px;font-weight:400}.lang-switcher{background:var(--bg-4);border:1px solid var(--border);border-radius:6px;gap:2px;padding:2px;display:flex}.lang-btn{color:var(--text-3);cursor:pointer;letter-spacing:.04em;background:0 0;border:none;border-radius:4px;padding:3px 7px;font-family:inherit;font-size:11px;font-weight:600;transition:background .12s,color .12s}.lang-btn:hover{color:var(--text)}.lang-btn.active{background:var(--accent);color:#fff}.editor-header-right{align-items:center;gap:10px;display:flex}.engine-panel{background:var(--bg-3);border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:6px;width:100%;padding:12px 16px;display:flex}.engine-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.engine-title{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:600}.engine-status{border-radius:20px;padding:2px 8px;font-size:11px}.engine-status.analyzing{color:var(--accent);background:var(--accent-dim);animation:1.4s ease-in-out infinite pulse}.engine-status.done{color:var(--text-3)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.engine-empty,.engine-loading{color:var(--text-3);align-items:center;gap:8px;padding:4px 0;font-size:13px;display:flex}.engine-spinner{border:2px solid var(--border-2);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:12px;height:12px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.engine-line{border-bottom:1px solid var(--border);align-items:baseline;gap:10px;padding:4px 0;display:flex}.engine-line:last-child{border-bottom:none}.engine-eval{flex-shrink:0;min-width:52px;font-family:Courier New,monospace;font-size:13px;font-weight:700}.eval-white{color:#e8e8e8}.eval-black{color:#ef4444}.eval-equal{color:var(--text-3)}.eval-mate-white{color:var(--green)}.eval-mate-black{color:var(--red)}.engine-moves{color:var(--text-2);word-break:break-word;font-family:Courier New,monospace;font-size:13px;line-height:1.4}.engine-move-token{cursor:pointer;border-radius:3px;padding:1px 2px;transition:background .1s,color .1s}.engine-move-token:hover{background:var(--accent);color:#fff}.explorer-panel{border-top:1px solid var(--border);flex-direction:column;flex:1;gap:8px;min-height:0;padding:12px 16px;display:flex;overflow-y:auto}.explorer-header{align-items:center;gap:8px;display:flex}.explorer-title{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;flex:1;font-size:12px;font-weight:600}.explorer-total{color:var(--text-3);font-size:11px}.explorer-opening{align-items:baseline;gap:6px;display:flex}.explorer-eco{color:var(--accent);background:var(--accent-dim);border-radius:4px;flex-shrink:0;padding:1px 6px;font-size:11px;font-weight:700}.explorer-opening-name{color:var(--text-2);font-size:12px;font-style:italic}.explorer-position-wdl{align-items:center;gap:6px;display:flex}.wdl-label{min-width:30px;font-size:11px;font-weight:600}.wdl-label-w{color:#e8e8e8;text-align:left}.wdl-label-b{color:var(--text-3);text-align:right}.wdl-bar{background:var(--bg-4);border-radius:3px;flex:1;height:6px;display:flex;overflow:hidden}.wdl-bar-wide{height:8px}.wdl-w{background:#e8e8e8}.wdl-d{background:#606060}.wdl-b{background:#1a1a1a;border-left:1px solid #2a2a2a}.explorer-empty{color:var(--text-3);padding:4px 0;font-size:13px}.explorer-table{border-collapse:collapse;width:100%;font-size:13px}.explorer-table th{color:var(--text-3);text-align:left;border-bottom:1px solid var(--border);padding:4px 6px 6px;font-size:11px;font-weight:500}.th-bar{min-width:120px}.explorer-row{cursor:pointer;transition:background .12s}.explorer-row:hover{background:var(--bg-4)}.explorer-row td{border-bottom:1px solid var(--border);vertical-align:middle;padding:6px}.explorer-row:last-child td{border-bottom:none}.td-san{color:var(--green);white-space:nowrap;font-family:Courier New,monospace;font-weight:700}.td-games{color:var(--text-2);white-space:nowrap;text-align:right;padding-right:10px}.td-bar{min-width:120px}.wdl-pct-line{justify-content:space-between;margin-top:2px;font-size:10px;display:flex}.wdl-pct-w{color:#e8e8e8}.wdl-pct-d,.wdl-pct-b{color:var(--text-3)}.td-rating{color:var(--text-3);white-space:nowrap;text-align:right;font-size:12px}.comment-panel{border-top:1px solid var(--border);background:var(--bg-3);flex-direction:column;flex-shrink:0;gap:8px;padding:16px;display:flex}.comment-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-size:12px}.comment-textarea{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text);resize:none;border-radius:8px;width:100%;padding:7px 12px;font-family:inherit;font-size:14px;line-height:1.5;transition:border-color .15s}.comment-textarea:focus{border-color:var(--accent);outline:none}.comment-textarea::placeholder{color:var(--text-3)}.comment-save{align-self:flex-end}.comment-label-row{align-items:center;gap:8px;display:flex}.comment-actions{justify-content:flex-end;gap:6px;display:flex}.annotation-badge{color:var(--accent);background:var(--accent-dim);text-transform:uppercase;letter-spacing:.05em;border-radius:4px;padding:2px 7px;font-size:11px;font-weight:600}.comment-panel.annotation-active{border-top-color:var(--accent)}.board-wrapper.annotation-mode{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}.context-menu{z-index:1000;background:var(--bg-3);border:1px solid var(--border-2);border-radius:8px;min-width:160px;padding:4px;position:fixed;box-shadow:0 8px 24px #00000080}.context-menu-item{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:7px;padding:8px 12px;font-family:inherit;font-size:14px;transition:background .12s;display:flex}.context-menu-item:hover{background:var(--bg-4)}.context-menu-item.danger{color:var(--red)}.context-menu-item.danger:hover{background:var(--red-dim)}.context-menu-divider{background:var(--border);height:1px;margin:4px 0}.study-page{flex-direction:column;height:100vh;padding-left:240px;display:flex;overflow:hidden}.study-header{background:var(--bg-2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.study-progress{color:var(--text-2);font-size:14px}.study-body{flex:1;min-height:0;display:flex}.pawn-mascot{border-bottom:1px solid var(--border);flex-shrink:0;align-items:flex-start;gap:12px;padding:14px 16px 12px;display:flex}.pawn-avatar{background:var(--accent-dim);border:1.5px solid var(--accent);-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:20px;line-height:1;display:flex}.pawn-bubble{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text);border-radius:10px;flex:1;min-width:0;padding:9px 13px;font-size:13px;font-weight:500;line-height:1.45;position:relative}.pawn-bubble:before{content:"";border-top:7px solid #0000;border-bottom:7px solid #0000;border-right:8px solid var(--border-2);position:absolute;top:11px;left:-8px}.pawn-bubble:after{content:"";border-top:7px solid #0000;border-bottom:7px solid #0000;border-right:8px solid var(--bg-4);position:absolute;top:11px;left:-6px}.pawn-bubble--comment{border-color:var(--accent);flex-direction:column;gap:10px;display:flex}.pawn-comment-body{color:var(--text);white-space:pre-wrap;font-size:13px;font-weight:400;line-height:1.6}.comment-bubble-actions{align-items:center;gap:6px;display:flex}.comment-continue-btn{font-size:12px}.study-feedback{text-align:center;border-radius:14px;flex-direction:column;align-items:center;gap:12px;width:100%;padding:24px;display:flex}.study-feedback.correct{background:var(--green-dim);border:1px solid var(--green)}.study-feedback.wrong{background:var(--red-dim);border:1px solid var(--red)}.feedback-icon{font-size:36px}.study-feedback.correct .feedback-icon{color:var(--green)}.study-feedback.wrong .feedback-icon{color:var(--red)}.feedback-icon-ok{color:#22c55e;stroke:#22c55e;filter:drop-shadow(0 1px 4px #22c55e80)}.feedback-icon-err{stroke:#ef4444;filter:drop-shadow(0 1px 4px #ef444480)}.feedback-sub{color:var(--text-2);font-size:13px}.rating-buttons{gap:8px;width:100%;margin-top:4px;display:flex}.btn-rating{border:1px solid var(--border-2);background:var(--bg-4);cursor:pointer;border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:2px;padding:10px 8px;font-family:inherit;transition:all .15s;display:flex}.btn-rating span{color:var(--text);font-size:13px;font-weight:500}.btn-rating small{color:var(--text-3);font-size:11px}.btn-rating.again:hover{background:var(--red-dim);border-color:var(--red)}.btn-rating.hard:hover{background:var(--orange-dim);border-color:var(--orange)}.btn-rating.good:hover{background:var(--green-dim);border-color:var(--green)}.btn-rating.easy:hover{background:var(--yellow-dim);border-color:var(--yellow)}.study-info{border-left:1px solid var(--border);background:var(--bg-2);flex-direction:column;flex-shrink:0;width:450px;display:flex;overflow:hidden}.study-info h3{color:var(--text-2);margin-bottom:20px;font-size:16px;font-weight:600}.variant-accordion{flex-direction:column;padding:0 0 8px;display:flex;overflow-y:auto}.study-panel-actions{background:var(--bg-2);flex-shrink:0;gap:8px;padding:10px 12px;display:flex}.btn-study-mode{border:1px solid var(--border-2);background:var(--bg-3);color:var(--text-2);cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:9px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:flex}.btn-study-mode:hover{background:var(--bg-4);color:var(--text);border-color:var(--accent)}.btn-study-mode.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.variant-chapter{border-bottom:1px solid var(--border)}.variant-chapter-btn{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:12px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .12s;display:flex}.variant-chapter-btn:hover{background:var(--bg-3)}.variant-chapter-btn.open{color:var(--accent)}.variant-chevron{color:var(--text-3);flex-shrink:0;transition:transform .2s}.variant-chevron.rotated{transform:rotate(90deg)}.variant-chapter-btn.open .variant-chevron{color:var(--accent)}.variant-list{flex-direction:column;padding:4px 0 8px;display:flex}.variant-item{color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:none;align-items:baseline;gap:6px;padding:7px 16px 7px 32px;font-family:inherit;font-size:12px;transition:background .12s,color .12s;display:flex}.variant-item:hover{background:var(--bg-3);color:var(--text)}.variant-num{color:var(--text-3);flex-shrink:0;min-width:16px;font-size:11px}.variant-name{font-family:Courier New,monospace;font-size:12px}.variant-empty{color:var(--text-3);padding:6px 16px 6px 32px;font-size:12px}.variant-item.active{background:var(--accent-dim);color:var(--accent)}.variant-item.active .variant-num,.variant-item.active .variant-name{color:var(--accent)}.variant-active-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-left:auto}.puzzle-study-main{flex:1;justify-content:center;align-items:flex-start;gap:40px;padding:32px 40px;display:flex}.puzzle-study-board-col{flex-direction:column;align-items:center;display:flex}.puzzle-study-board-wrap{width:min(48vw,100vh - 105px);max-width:none}.puzzle-study-info-col{flex-direction:column;gap:20px;min-width:240px;max-width:320px;padding-top:8px;display:flex}.puzzle-study-info-inner{flex-direction:column;flex:1;gap:16px;padding:16px;display:flex;overflow-y:auto}.puzzle-study-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.puzzle-study-title{color:var(--text);font-size:18px;font-weight:700}.puzzle-status{background:var(--bg-3);border:1px solid var(--border);color:var(--text-2);border-radius:10px;align-items:center;gap:8px;min-height:48px;padding:12px 16px;font-size:14px;display:flex}.puzzle-status.solved{background:var(--green-dim);border-color:var(--green);color:var(--green);font-weight:600}.puzzle-status.wrong{background:var(--red-dim);border-color:var(--red);color:var(--red)}.puzzle-moves-played{flex-wrap:wrap;gap:6px;display:flex}.puzzle-move-chip{background:var(--bg-4);border:1px solid var(--border);color:var(--text-2);border-radius:6px;padding:3px 8px;font-family:Courier New,monospace;font-size:13px}.puzzle-study-actions{flex-direction:column;gap:10px;display:flex}.puzzle-study-actions .btn-primary{justify-content:center;align-items:center;gap:6px;display:flex}.study-board-wrapper{max-width:none;width:min(100vw - 738px,100vh - 48px)!important}@media (width<=768px){.study-board-wrapper{max-width:none;width:min(100vw - 32px,58vh)!important}}.study-help-bar{justify-content:center;gap:8px;display:flex}.btn-hint{border:1px solid var(--border-2);background:var(--bg-4);color:var(--text-2);cursor:pointer;border-radius:7px;align-items:center;gap:5px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;display:flex}.btn-hint:hover:not(:disabled){background:var(--yellow-dim);border-color:var(--yellow);color:var(--text)}.btn-hint:disabled{opacity:.45;cursor:default}.btn-solution{border:1px solid var(--accent);background:var(--accent-dim);color:var(--accent);cursor:pointer;border-radius:7px;align-items:center;gap:5px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;display:flex}.btn-solution:hover{background:var(--accent);color:#fff}.btn-undo{color:#ef4444;cursor:pointer;background:#ef44441a;border:1px solid #ef444459;border-radius:7px;align-items:center;gap:5px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;display:flex}.btn-undo:hover{background:#ef444438;border-color:#ef4444}.variant-done-bar{width:100%;max-width:var(--board-max,600px);background:var(--green-dim);border:1px solid var(--green);border-radius:10px;justify-content:space-between;align-items:center;gap:12px;margin-top:4px;padding:12px 16px;display:flex}.variant-done-label{color:var(--green);align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.variant-done-actions{flex-shrink:0;gap:8px;display:flex}.position-meta{flex-direction:column;gap:12px;display:flex}.meta-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.meta-label{color:var(--text-3);font-size:13px}.meta-value{color:var(--text);font-family:Courier New,monospace;font-size:14px;font-weight:500}.state-badge[data-state=new]{color:var(--accent)}.state-badge[data-state=learning]{color:var(--orange)}.state-badge[data-state=review]{color:var(--green)}.state-badge[data-state=relearning]{color:var(--red)}.new-card-badge{color:var(--accent);background:var(--accent-dim);border-radius:20px;padding:4px 12px;font-size:13px;display:inline-block}.study-done{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.done-icon{color:var(--green);font-size:64px}.study-done h2{font-size:28px;font-weight:700}.study-done p{color:var(--text-2);font-size:16px}.done-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:8px;display:flex}.profile-page{background:var(--bg);flex-direction:column;min-height:100vh;padding-left:240px;display:flex}.profile-header{background:var(--bg-2);border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:16px 32px;display:flex}.profile-header h2{flex:1;font-size:18px;font-weight:600}.profile-body{flex-direction:column;gap:24px;width:100%;max-width:560px;margin:0 auto;padding:32px;display:flex}.profile-card{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:16px;padding:24px;display:flex}.profile-card-title{color:var(--text-2);border-bottom:1px solid var(--border);padding-bottom:12px;font-size:15px;font-weight:600}.profile-card-footer{justify-content:flex-end;align-items:center;gap:12px;margin-top:4px;display:flex}.profile-msg{font-size:13px}.profile-msg.ok{color:var(--green)}.profile-msg.err{color:var(--red)}.settings-fide-link{color:var(--accent);font-weight:500;text-decoration:none}.settings-fide-link:hover{text-decoration:underline}.settings-social-input-wrap{border:1px solid var(--border);background:var(--bg-1);border-radius:8px;align-items:center;transition:border-color .15s;display:flex;overflow:hidden}.settings-social-input-wrap:focus-within{border-color:var(--accent)}.settings-social-prefix{color:var(--text-3);background:var(--bg-3);border-right:1px solid var(--border);white-space:nowrap;align-items:center;height:38px;padding:0 10px;font-size:12px;line-height:38px;display:flex}.settings-social-input-wrap input{height:38px;color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:0 12px;font-size:14px}.theme-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.theme-option{border:1px solid var(--border);color:var(--text);cursor:pointer;text-align:left;background:0 0;border-radius:8px;align-items:center;gap:12px;width:100%;padding:10px 14px;font-family:inherit;font-size:14px;transition:background .12s,border-color .12s;display:flex}.theme-option:hover{background:var(--bg-3)}.theme-option.selected{border-color:var(--accent);background:var(--accent-dim)}.theme-swatches{flex-shrink:0;gap:3px;display:flex}.swatch{border:1px solid #ffffff1a;border-radius:4px;width:22px;height:22px;display:block}.piece-preview-img{object-fit:contain;flex-shrink:0;width:36px;height:36px}.theme-name{flex:1}.theme-check{color:var(--accent);font-size:15px;font-weight:700}.site-theme-group-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;font-size:11px;font-weight:700}.site-theme-grid{flex-wrap:wrap;gap:10px;margin-bottom:4px;display:flex}.site-theme-option{border:2px solid var(--border);background:var(--bg-3);cursor:pointer;border-radius:10px;flex-direction:column;align-items:center;gap:6px;min-width:76px;padding:8px;transition:border-color .15s,transform .1s;display:flex}.site-theme-option:hover{border-color:var(--border-2);transform:translateY(-1px)}.site-theme-option.selected{border-color:var(--accent)}.site-theme-swatch{border:1px solid #80808033;border-radius:6px;justify-content:flex-end;align-items:flex-end;width:58px;height:38px;padding:5px;display:flex}.site-theme-accent{border:1.5px solid #fff6;border-radius:50%;flex-shrink:0;width:12px;height:12px}.site-theme-name{color:var(--text-2);font-size:11px;font-weight:500}.board-preview{aspect-ratio:1;border:1px solid var(--border);border-radius:6px;grid-template-columns:repeat(8,1fr);width:180px;margin:0 auto;display:grid;overflow:hidden}.preview-square{aspect-ratio:1}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}@media (width<=1024px){.board-preview-mini{display:none}}@media (width<=768px){.theme-option{gap:4px}.editor-body,.study-body{flex-direction:column}.board-panel{flex:none;width:100%;padding:8px 16px 0}.tree-panel,.study-info{flex:none;width:100%;max-width:100%;height:800px}.dash-main{padding:24px 16px}.editor-header,.study-header{padding:12px 16px}.chapters-header{display:none}.user-card-friend-btn.friends{flex:0;font-size:0}.puzzle-history-card{padding:0!important}.training-panel-body{order:1}.board-overlay-bar{justify-content:flex-end;width:100%;padding:4px 0;flex-direction:row!important;position:static!important}}.chapter-drawer-overlay{z-index:300;background:#000000b8;align-items:flex-end;display:flex;position:fixed;inset:0}.chapter-drawer{background:var(--bg-2);border-radius:16px 16px 0 0;flex-direction:column;width:100%;max-height:65vh;display:flex;overflow-y:auto}.chapter-drawer-header{border-bottom:1px solid var(--border);color:var(--text);background:var(--bg-2);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;font-size:15px;font-weight:600;display:flex;position:sticky;top:0}.chapter-drawer-close{cursor:pointer;color:var(--text-3);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.chapter-drawer-close:hover{background:var(--bg-3);color:var(--text)}.chapter-drawer-item{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text-2);text-align:left;cursor:pointer;background:0 0;align-items:center;gap:8px;padding:14px 16px;font-family:inherit;font-size:14px;transition:background .12s;display:flex}.chapter-drawer-item:hover{background:var(--bg-3);color:var(--text)}.chapter-drawer-item.active{color:var(--accent);font-weight:600}.chapter-drawer-add{color:var(--text-3)}.chapter-drawer-add:hover{color:var(--accent);background:var(--bg-3)}.chapter-drawer-chapter{flex-direction:column;display:flex}.chapter-drawer-chapter-btn{font-weight:600}.chapter-drawer-variant{padding-left:36px;font-size:13px}.chapter-drawer-variant.active{color:var(--accent);font-weight:600}@media (width<=600px){.repertoire-grid{grid-template-columns:1fr}.up-hero{padding:20px 0 14px}.up-hero-inner{flex-direction:column;align-items:flex-start;gap:16px}.up-hero-right{flex-flow:wrap;justify-content:flex-start;align-items:center;gap:10px;width:100%;height:auto!important}.up-hero-actions{flex-wrap:wrap;gap:6px}.up-name{white-space:normal;font-size:20px}.site-footer-inner{justify-content:center;gap:10px}.site-footer-left,.site-footer-links{justify-content:center;width:100%}.site-footer-lang{align-self:center}}@media (width<=900px){#root{min-height:unset}.dashboard{min-height:unset;flex-direction:column;padding-left:0}.training-page{padding-left:0;overflow:visible}.editor-layout{padding-left:0}.study-page{height:auto;padding-left:0;overflow:visible}.profile-page{padding-left:0}.site-footer{padding:16px 20px!important}.up-hero-inner{align-items:flex-start}.up-hero-right{height:auto!important}.up-socials{margin-top:0!important}.dash-header{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;justify-content:space-between;align-items:center;width:100%;height:56px;padding:0 16px;position:relative;overflow:visible}.dash-brand{border-bottom:none;margin-bottom:0;padding:0}.main-nav,.sidebar-bottom{display:none}.mobile-header-right{display:flex}.mobile-overlay{pointer-events:none;display:block}.mobile-overlay.open{pointer-events:all}.mobile-nav{display:flex}.sidebar-panel,.sidebar-panel-backdrop{display:none}}.rep-color-label{text-transform:uppercase;letter-spacing:.06em;border-radius:4px;align-self:flex-start;padding:2px 7px;font-size:11px;font-weight:600}.rep-color-label[data-color=white]{color:#d0d0d0;background:#ffffff12}.rep-color-label[data-color=black]{color:var(--text-3);border:1px solid var(--border);background:#0006}.rep-visibility-text{color:var(--text-3);align-items:center;gap:4px;font-size:11px;display:flex}.rep-visibility-text.public{color:var(--accent)}.rep-visibility-text.shared{color:#63b3ed}.pub-card{cursor:pointer}.pub-card:hover{border-color:var(--border-2);background:var(--bg-3)}.explore-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.explore-search{background:var(--bg-2);border:1px solid var(--border);min-width:180px;color:var(--text);border-radius:8px;outline:none;flex:1;padding:8px 12px;font-size:13px;transition:border-color .15s}.explore-search:focus{border-color:var(--accent)}.explore-search::placeholder{color:var(--text-3)}.explore-color-filter{gap:4px;display:flex}.color-filter-btn{background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:12px;transition:all .15s}.color-filter-btn:hover{border-color:var(--border-2);color:var(--text)}.color-filter-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.library-tabs{gap:6px;margin-bottom:20px;display:flex}.library-tab{border:1px solid var(--border);background:var(--bg-2);color:var(--text-2);cursor:pointer;border-radius:20px;padding:6px 16px;font-size:13px;transition:all .15s}.library-tab:hover{border-color:var(--border-2);color:var(--text)}.library-tab.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);font-weight:600}.explore-sort{background:var(--bg-2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;outline:none;padding:8px 12px;font-size:12px}.explore-sort:focus{border-color:var(--accent)}.star-rating{gap:2px;display:flex}.star-btn{cursor:pointer;color:var(--text-3);background:0 0;border:none;padding:0;line-height:1;transition:color .1s}.star-btn:disabled{cursor:default}.star-icon{stroke:currentColor;fill:none;transition:fill .1s,color .1s}.star-icon.filled{fill:var(--yellow);color:var(--yellow)}.star-rating:not(.readonly) .star-btn:hover .star-icon{color:var(--yellow);fill:var(--yellow-dim)}.explore-social{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:12px;margin-top:16px;padding:14px 16px;display:flex}.social-rating-avg{align-items:center;gap:8px;display:flex}.avg-value{color:var(--text);font-size:18px;font-weight:700}.ratings-count{color:var(--text-3);font-size:12px}.social-my-rating{align-items:center;gap:8px;display:flex}.social-label{color:var(--text-2);font-size:12px}.social-follow{border-top:1px solid var(--border);align-items:center;gap:10px;padding-top:10px;display:flex}.follow-count{color:var(--text-2);align-items:center;gap:5px;font-size:13px;display:flex}.btn-follow{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text-2);cursor:pointer;border-radius:8px;align-items:center;gap:6px;margin-left:auto;padding:6px 14px;font-size:13px;transition:all .15s;display:flex}.btn-follow:hover{border-color:var(--accent);color:var(--accent)}.btn-follow.following{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.btn-follow-card{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text-2);cursor:pointer;border-radius:7px;align-items:center;gap:5px;padding:5px 11px;font-family:inherit;font-size:12px;transition:all .15s;display:inline-flex}.btn-follow-card:hover{border-color:var(--accent);color:var(--accent)}.btn-follow-card.following{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.explore-reviews{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:12px;margin-top:16px;padding:14px 16px;display:flex}.reviews-header{justify-content:space-between;align-items:center;display:flex}.reviews-header h3{color:var(--text);font-size:14px;font-weight:600}.review-form{flex-direction:column;gap:8px;display:flex}.review-form textarea{background:var(--bg-3);border:1px solid var(--border);color:var(--text);resize:vertical;border-radius:8px;outline:none;padding:10px 12px;font-family:inherit;font-size:13px}.review-form textarea:focus{border-color:var(--accent)}.review-form-actions{justify-content:flex-end;align-items:center;gap:8px;display:flex}.reviews-empty{color:var(--text-3);font-size:13px}.reviews-list{flex-direction:column;gap:12px;display:flex}.review-item{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:10px 12px}.review-item.mine{border-color:var(--accent);background:var(--accent-dim)}.review-author{align-items:center;gap:8px;margin-bottom:6px;display:flex}.review-avatar{object-fit:cover;border-radius:50%;width:26px;height:26px}.review-avatar-placeholder{background:var(--bg-4);border:1px solid var(--border-2);width:26px;height:26px;color:var(--text-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:inline-flex}.review-name{color:var(--text);font-size:13px;font-weight:600}.review-date{color:var(--text-3);margin-left:auto;font-size:11px}.review-body{color:var(--text-2);white-space:pre-wrap;font-size:13px;line-height:1.5}.panels-column{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.panel-block{border-bottom:1px solid var(--border);flex-direction:column;min-height:0;display:flex;overflow:hidden}.panel-block.panel-collapsed{overflow:visible}.panel-header{background:var(--bg-3);border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;box-sizing:border-box;flex-shrink:0;justify-content:space-between;align-items:center;height:34px;padding:0 8px 0 12px;display:flex}.panel-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);font-size:10px;font-weight:700}.panel-actions{align-items:center;gap:1px;display:flex}.line-select-group{flex:1;align-items:center;gap:1px;min-width:0;margin-left:8px;display:flex}.line-select{background:var(--bg-2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;flex:1;min-width:0;height:22px;padding:2px 4px;font-family:inherit;font-size:11px}.panel-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px 6px;line-height:1;transition:background .12s,color .12s;display:flex}.panel-btn:hover{background:var(--accent-dim);color:var(--accent-hover)}.panel-btn-label{border:1px solid var(--border);border-radius:4px;gap:4px;padding:4px 8px;font-family:inherit;font-size:12px}.panel-content{flex:1;min-height:0;overflow-y:auto}.panel-resize-handle{background:var(--bg-3);cursor:ns-resize;border-bottom:1px solid var(--border);flex-shrink:0;height:5px;transition:background .15s;position:relative}.panel-resize-handle:hover{background:var(--accent);opacity:.45}.panel-resize-handle:after{content:"";border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-2);width:28px;height:3px;position:absolute;top:1px;left:50%;transform:translate(-50%)}.pgn-modal{z-index:900;background:var(--bg-2);border:1px solid var(--border-2);border-radius:10px;flex-direction:column;min-width:320px;min-height:260px;display:flex;position:fixed;overflow:hidden;box-shadow:0 12px 48px #00000080}.pgn-modal-header{background:var(--bg-3);border-bottom:1px solid var(--border-2);cursor:grab;color:var(--text);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;font-weight:600;display:flex}.pgn-modal-header:active{cursor:grabbing}.pgn-modal-close{width:22px;height:22px;color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;display:flex}.pgn-modal-close:hover{background:var(--bg-4);color:var(--text)}.pgn-modal-body{flex-direction:column;flex:1;gap:10px;padding:14px;display:flex;overflow-y:auto}.pgn-modal-label{color:var(--text-3);font-size:12px;font-weight:500}.pgn-textarea{background:var(--bg-3);border:1px solid var(--border-2);width:100%;color:var(--text);resize:none;box-sizing:border-box;border-radius:6px;flex:1;min-height:80px;padding:8px;font-family:monospace;font-size:11px}.pgn-textarea:focus{border-color:var(--accent,#63b3ed);outline:none}.pgn-modal-file-row{align-items:center;gap:8px;display:flex}.pgn-file-btn{cursor:pointer;align-items:center;gap:6px;padding:5px 10px;font-size:12px;display:inline-flex}.pgn-error{color:#f87171;margin:0;font-size:12px}.pgn-import-btn{align-self:flex-end;font-size:13px}.pgn-game-picker{flex-direction:column;gap:6px;display:flex}.pgn-game-picker-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.pgn-select-all-btn{flex-shrink:0;padding:2px 8px;font-size:11px}.pgn-game-list{flex-direction:column;gap:3px;max-height:180px;display:flex;overflow-y:auto}.pgn-game-item{border:1px solid var(--border);background:var(--surface);cursor:pointer;text-align:left;border-radius:5px;grid-template-rows:auto auto;grid-template-columns:18px 1fr;gap:2px 8px;padding:7px 10px;transition:background .1s,border-color .1s;display:grid}.pgn-game-check{color:var(--accent);grid-row:1/3;justify-content:center;align-items:center;min-width:18px;font-size:13px;font-weight:700;display:flex}.pgn-game-item:hover{background:var(--bg-3)}.pgn-game-item.selected{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent)}.pgn-game-players{color:var(--text);font-size:13px;font-weight:500}.pgn-game-meta{color:var(--text-muted);font-size:11px}.pgn-import-progress{flex-direction:column;gap:8px;padding:8px 0;display:flex}.pgn-import-progress-game{color:var(--text);font-size:14px;font-weight:600}.pgn-import-progress-name{color:var(--text-2);font-size:13px}.pgn-import-bar-wrap{background:var(--bg-3);border-radius:4px;height:7px;overflow:hidden}.pgn-import-bar-wrap--sm{height:4px}.pgn-import-bar-fill{background:var(--accent);border-radius:4px;height:100%;transition:width .2s}.pgn-import-bar-fill--dim{background:var(--accent-dim,color-mix(in srgb, var(--accent) 60%, transparent))}.pgn-import-progress-moves{color:var(--text-3);font-size:12px}.pgn-modal-resize{cursor:nwse-resize;background:linear-gradient(135deg, transparent 50%, var(--border-2) 50%);border-radius:0 0 10px;width:16px;height:16px;position:absolute;bottom:0;right:0}.panel-float{z-index:800;background:var(--bg-2);border:1px solid var(--border-2);border-radius:10px;flex-direction:column;display:flex;position:fixed;overflow:hidden;box-shadow:0 10px 48px #00000073}.panel-float .panel-header{cursor:grab;border-bottom:1px solid var(--border-2);border-radius:10px 10px 0 0}.panel-float .panel-header:active{cursor:grabbing}.panel-float .panel-content{flex:1;min-height:0;overflow-y:auto}.panel-float-resize{cursor:nwse-resize;width:18px;height:18px;position:absolute;bottom:0;right:0}.panel-float-resize:before{content:"";border-right:2px solid var(--border-2);border-bottom:2px solid var(--border-2);border-radius:0 0 2px;width:8px;height:8px;position:absolute;bottom:3px;right:3px}.study-comments-btn{border:1px solid var(--border);color:var(--text-2);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:5px;padding:5px 10px;font-size:13px;transition:background .15s,color .15s;display:flex}.study-comments-btn:hover{background:var(--bg-3);color:var(--text)}.study-bar-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.study-votes{align-items:center;gap:4px;display:flex}.study-vote-btn{border:1px solid var(--border);width:28px;height:28px;color:var(--text-2);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex}.study-vote-btn:hover{background:var(--bg-3);color:var(--text)}.study-vote-btn:disabled{opacity:.5;cursor:default}.study-vote-btn.up.active{color:var(--green);border-color:var(--green);background:var(--green-dim)}.study-vote-btn.down.active{color:var(--red);border-color:var(--red);background:var(--red-dim)}.study-vote-count{text-align:center;min-width:20px;font-size:12px;font-weight:600}.study-vote-count.up{color:var(--green)}.study-vote-count.down{color:var(--red)}.study-more-btn{border:1px solid var(--border);width:32px;height:32px;color:var(--text-2);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.study-more-btn:hover,.study-more-btn.active{background:var(--bg-3);color:var(--text)}.study-dropdown-wrap{position:relative}.study-dropdown{background:var(--bg-2);border:1px solid var(--border);z-index:200;border-radius:10px;min-width:160px;padding:4px;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #0006}.study-dropdown-item{width:100%;color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;transition:background .15s,color .15s;display:flex}.study-dropdown-item:hover{background:var(--bg-3);color:var(--text)}.study-dropdown-item.danger{color:var(--red)}.study-dropdown-item.danger:hover{background:var(--red-dim);color:var(--red)}.comment-modal-overlay{z-index:1000;background:#000000e0;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.comment-modal{background:var(--bg-2);border:1px solid var(--border);border-radius:14px;flex-direction:column;width:min(820px,95vw);height:90vh;display:flex;overflow:hidden}.comment-modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.comment-modal-title{color:var(--text);align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.comment-modal-count{color:var(--text-3);font-weight:400}.comment-modal-close{border:1px solid var(--border);width:32px;height:32px;color:var(--text-2);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;display:flex}.comment-modal-close:hover{background:var(--bg-3);color:var(--text)}.comment-modal-body,.comment-section{flex-direction:column;flex:1;min-height:0;display:flex}.comment-list{flex-direction:column;flex:1;gap:2px;padding:12px 20px;display:flex;overflow-y:auto}.comment-empty{color:var(--text-3);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:48px 20px;font-size:14px;display:flex}.comment-sentinel{height:1px}.comment-loading-more{text-align:center;color:var(--text-3);padding:10px;font-size:13px}.comment-input-area{border-top:1px solid var(--border);background:var(--bg-2);flex-shrink:0;padding:12px 20px 16px}.comment-login-prompt{text-align:center;color:var(--text-3);padding:12px 0;font-size:14px}.comment-login-link{color:var(--accent);text-underline-offset:2px;text-decoration:underline}.comment-login-link:hover{opacity:.8}.comment-item{border-bottom:1px solid var(--border);gap:10px;padding:12px 0;display:flex}.comment-item:last-child{border-bottom:none}.comment-highlighted{background:var(--accent-subtle,#63b3ed14);border-left:3px solid var(--accent,#63b3ed);border-radius:0 4px 4px 0;margin-left:-10px;padding-left:10px}.comment-back-btn{color:var(--accent,#63b3ed);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:6px 0 10px;font-size:13px;font-weight:500;display:flex}.comment-back-btn:hover{text-decoration:underline}.comment-reply{border-bottom:1px solid var(--border-0,#ffffff0a);padding:8px 0}.comment-reply:last-child{border-bottom:none}.comment-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:34px;height:34px}.comment-avatar-initials{background:var(--accent-dim,#6366f133);color:var(--accent);justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.comment-content{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.comment-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.comment-author-badge{color:#f59e0b;cursor:default;align-items:center;display:inline-flex;position:relative}.comment-author-badge:after{content:attr(data-tooltip);background:var(--bg);color:var(--text);border:1px solid var(--border);white-space:nowrap;pointer-events:none;opacity:0;z-index:10;border-radius:6px;padding:3px 8px;font-size:11px;transition:opacity .15s;position:absolute;bottom:calc(100% + 5px);left:50%;transform:translate(-50%)}.comment-author-badge:hover:after{opacity:1}.comment-author{color:var(--text);font-size:13px;font-weight:600}.comment-time{color:var(--text-3);font-size:12px}.comment-edited{color:var(--text-3);font-size:11px;font-style:italic}.comment-body{color:var(--text-2);word-break:break-word;font-size:14px;line-height:1.55}.comment-body strong,.comment-body b{color:var(--text);font-weight:600}.comment-body em,.comment-body i{font-style:italic}.comment-body u{text-decoration:underline}.comment-body p{margin:0 0 4px}.comment-body p:last-child{margin:0}.comment-actions{flex-wrap:wrap;align-items:center;gap:4px;margin-top:2px;display:flex}.comment-action-btn{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-size:12px;transition:background .12s,color .12s;display:flex}.comment-action-btn:hover{background:var(--bg-3);color:var(--text-2)}.comment-action-btn.liked,.comment-action-btn.danger:hover{color:#e11d48}.comment-action-btn.muted{opacity:.45}.comment-action-btn.muted:hover{opacity:.9}.comment-delete-confirm{color:var(--text-2);align-items:center;gap:4px;font-size:12px;display:flex}.comment-replies{border-left:2px solid var(--border);flex-direction:column;margin-top:8px;padding-left:12px;display:flex}.comment-load-replies-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:5px;margin-top:4px;padding:6px 8px;font-size:12px;display:flex}.comment-load-replies-btn:hover{background:var(--bg-3)}.comment-reply-editor{margin-top:8px}.comment-editor{border:1px solid var(--border);background:var(--bg-3);border-radius:10px;flex-direction:column;gap:6px;display:flex;overflow:hidden}.comment-editor.compact{border-radius:8px}.comment-editor-toolbar{gap:2px;padding:6px 8px 0;display:flex}.editor-tool-btn{width:26px;height:26px;color:var(--text-2);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:5px;justify-content:center;align-items:center;font-family:inherit;display:flex}.editor-tool-btn:hover{background:var(--bg-2);color:var(--text);border-color:var(--border)}.comment-editor-input{min-height:72px;max-height:200px;color:var(--text);word-break:break-word;outline:none;padding:8px 12px;font-size:14px;line-height:1.55;position:relative;overflow-y:auto}.comment-editor.compact .comment-editor-input{min-height:52px}.comment-editor-input.is-empty:before{content:attr(data-placeholder);color:var(--text-3);pointer-events:none;position:absolute}.comment-editor-input:focus{background:0 0}.comment-editor-footer{border-top:1px solid var(--border);background:var(--bg-2);justify-content:flex-end;align-items:center;gap:8px;padding:6px 8px;display:flex}.btn-sm{border-radius:7px;padding:5px 12px;font-size:12px}.nav-icon-btn{position:relative}.nav-badge{color:#fff;text-align:center;pointer-events:none;background:#e53e3e;border-radius:99px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:16px;position:absolute;top:-4px;right:-6px}.notifications-dropdown{width:320px}.notif-list{flex-direction:column;display:flex}.notif-item{border-bottom:1px solid var(--border);color:var(--text-2);cursor:default;align-items:center;gap:10px;padding:10px 14px;font-size:13px;display:flex}.notif-item.clickable,.notif-page-item.clickable{cursor:pointer}.notif-item.clickable:hover{background:var(--bg-2)}.notif-page-item.clickable:hover{background:color-mix(in srgb, var(--accent) 8%, var(--bg-1))}.notif-item.unread{background:var(--bg-2);color:var(--text-1);font-weight:500}.notif-avatar-wrap{flex-shrink:0;width:32px;height:32px;position:relative}.notif-avatar-wrap .online-dot{position:absolute;bottom:-2px;right:-2px}.notif-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:32px;height:32px}.notif-avatar-initial{background:var(--accent);color:#fff;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.notif-text{line-height:1.35}.user-card-overlay{z-index:1100;background:#000000e0;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.user-card-modal{border:1px solid var(--border);background:#000000d9;border-radius:16px;flex-direction:column;gap:16px;width:min(440px,92vw);padding:28px 24px 20px;display:flex;position:relative;box-shadow:0 16px 48px #0000004d}.user-card-inline{background:var(--bg-3);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:14px;padding:20px;transition:border-color .15s;display:flex}.user-card-inline:hover{border-color:var(--accent)}.user-card-close{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;transition:color .15s;display:flex;position:absolute;top:12px;right:12px}.user-card-close:hover{color:var(--text-1)}.user-card-loading{color:var(--text-3);padding:32px;font-size:13px}.uc-top{flex-direction:row;align-items:flex-start;gap:16px;display:flex}.uc-identity{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.uc-elos{flex-wrap:wrap;gap:4px;display:flex}.uc-elo-chip{background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);border-radius:6px;padding:2px 8px;font-size:11px}.uc-meta{color:var(--text-3);flex-direction:column;gap:2px;font-size:12px;display:flex}.user-card-avatar-wrap{cursor:pointer;border-radius:10px;flex-shrink:0;width:80px;height:80px;position:relative;overflow:visible}.user-card-avatar-img{object-fit:cover;border-radius:10px;width:100%;height:100%}.user-card-avatar-wrap .online-dot{position:absolute;bottom:-3px;right:-3px}.user-card-avatar-initials{background:var(--accent);color:#fff;justify-content:center;align-items:center;width:100%;height:100%;font-size:24px;font-weight:700;display:flex}.user-card-name{color:var(--text-1);cursor:pointer;font-size:17px;font-weight:700}.user-card-name:hover{color:var(--accent)}.user-card-actions{flex-direction:row;gap:8px;width:100%;margin-top:4px;display:flex}.user-card-friend-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:9px;flex:1;justify-content:center;align-items:center;gap:7px;padding:9px 16px;font-size:13px;font-weight:600;transition:opacity .15s;display:flex}.user-card-friend-btn:disabled{cursor:default}.user-card-friend-btn.add{background:var(--accent);color:#fff}.user-card-friend-btn.add:hover:not(:disabled){opacity:.88}.user-card-friend-btn.friends{background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);opacity:1}.user-card-friend-btn.pending{background:var(--bg-2);border:1px solid var(--border);color:var(--text-3)}.user-card-friend-btn.accept{color:#fff;background:#38a169}.user-card-friend-btn.accept:hover:not(:disabled){opacity:.88}.user-card-visit-btn{cursor:pointer;background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);border-radius:9px;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:flex}.user-card-visit-btn:hover{background:var(--bg-3);color:var(--text)}.user-card-msg-btn{color:#fff;cursor:pointer;background:#2d7a4f;border:none;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:opacity .15s;display:flex}.user-card-msg-btn:hover:not(:disabled){opacity:.85}.user-card-msg-btn:disabled{cursor:default;opacity:.6}.up-loading{text-align:center;color:var(--text-3);padding:60px 0;font-size:14px}.up-hero{background:var(--bg-1);border-bottom:1px solid var(--border);padding:36px 0 28px}.up-hero-inner{justify-content:space-between;align-items:center;gap:24px;max-width:1200px;margin:0 auto;padding:0 32px;display:flex}.up-hero-left{align-items:center;gap:24px;min-width:0;display:flex}.up-avatar{object-fit:cover;border:3px solid var(--border);border-radius:12px;flex-shrink:0;width:88px;height:88px}.up-avatar-initials{background:var(--accent);color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:88px;height:88px;font-size:30px;font-weight:700;display:flex}.up-hero-identity{flex-direction:column;gap:6px;min-width:0;display:flex}.up-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:24px;font-weight:700;overflow:hidden}.up-elos{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.up-elo-chip{background:var(--bg-2);border:1px solid var(--border);color:var(--text-3);border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;display:flex}.up-elo-chip strong{color:var(--text);font-weight:700}.up-meta{color:var(--text-3);flex-wrap:wrap;gap:16px;font-size:13px;display:flex}.up-socials{flex-direction:row;align-items:center;gap:8px;margin-top:auto;display:flex}.up-social-link{opacity:.85;border-radius:6px;justify-content:center;align-items:center;transition:opacity .15s,transform .15s;display:flex}.up-social-link:hover{opacity:1;transform:translateY(-1px)}.up-hero-right{flex-direction:column;flex-shrink:0;justify-content:space-between;align-items:flex-end;height:120px;display:flex}.up-hero-actions{align-items:center;gap:8px;display:flex}.up-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:9px;align-items:center;gap:7px;padding:8px 18px;font-size:13px;font-weight:600;transition:opacity .15s,background .15s;display:inline-flex}.up-btn:disabled{cursor:default;opacity:.7}.up-btn-primary{background:var(--accent);color:#fff}.up-btn-primary:hover:not(:disabled){opacity:.88}.up-btn-secondary{background:var(--bg-2);border:1px solid var(--border);color:var(--text-2)}.up-btn-secondary:hover:not(:disabled){background:var(--bg-3);color:var(--text)}.up-btn-icon{background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);padding:8px 10px}.up-btn-icon:hover,.up-btn-icon.active{background:var(--bg-3);color:var(--text)}.up-dropdown-wrap{position:relative}.up-dropdown{background:var(--bg-2);border:1px solid var(--border);z-index:200;border-radius:10px;min-width:180px;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 8px 24px #00000040}.up-dropdown-item{width:100%;color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:9px;padding:10px 14px;font-size:13px;transition:background .12s;display:flex}.up-dropdown-item:hover{background:var(--bg-3);color:var(--text)}.up-dropdown-item.danger{color:#e53e3e}.up-dropdown-item.danger:hover{background:#e53e3e14}.up-tabs-bar{border-bottom:1px solid var(--border);background:var(--bg-0,var(--bg))}.up-tabs-inner{max-width:1200px;margin:0 auto;padding:0 32px;display:flex}.up-tab{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:13px 20px;font-size:14px;font-weight:500;transition:color .15s,border-color .15s}.up-tab:hover{color:var(--text)}.up-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-badge{color:#fff;vertical-align:middle;background:#e53e3e;border-radius:9999px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:6px;padding:0 5px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.friends-discover-bar{justify-content:flex-end;margin-bottom:20px;display:flex}.friends-discover-panel{background:var(--bg-2);border:1px solid var(--border);border-radius:14px;margin-bottom:28px;padding:20px}.friends-discover-header{align-items:center;margin-bottom:16px;display:flex}.friends-discover-search{margin-bottom:20px;position:relative}.friends-discover-search-icon{color:var(--text-3);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.friends-discover-input{box-sizing:border-box;background:var(--bg-3);border:1px solid var(--border);width:100%;color:var(--text);border-radius:10px;outline:none;padding:10px 14px 10px 36px;font-size:14px;transition:border-color .15s}.friends-discover-input:focus{border-color:var(--accent)}.friends-discover-input::placeholder{color:var(--text-3)}.friends-section{margin-bottom:32px}.friends-section-title{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;margin:0 0 16px;font-size:14px;font-weight:600}.up-content{box-sizing:border-box;width:100%;max-width:1200px;margin:0 auto;padding:32px}.up-placeholder{min-height:120px}.friends-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=900px){.friends-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.friends-grid{grid-template-columns:1fr}}.up-modal-overlay{z-index:500;background:#000000e0;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.up-modal{border:1px solid var(--border);background:#000000e0;border-radius:14px;flex-direction:column;gap:16px;width:100%;max-width:440px;padding:24px;display:flex}.up-modal-header{color:var(--text);justify-content:space-between;align-items:center;font-size:16px;font-weight:700;display:flex}.up-modal-close{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px;display:flex}.up-modal-close:hover{background:var(--bg-3);color:var(--text)}.up-report-reasons{flex-direction:column;gap:2px;display:flex}.up-report-reason{color:var(--text-2);cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:9px 12px;font-size:14px;transition:background .12s;display:flex}.up-report-reason:hover{background:var(--bg-2)}.up-report-reason input[type=radio]{accent-color:var(--accent);width:15px;height:15px}.up-report-textarea{background:var(--bg-2);border:1px solid var(--border);width:100%;color:var(--text);resize:vertical;box-sizing:border-box;border-radius:8px;padding:14px 16px;font-family:inherit;font-size:13px}.up-report-textarea:focus{border-color:var(--accent);outline:none}.up-report-sent{color:#38a169;text-align:center;margin:0;padding:16px 0;font-size:14px}.up-banned-label{color:#e53e3e;align-items:center;gap:6px;margin-top:8px;font-size:.9rem;font-weight:600;display:flex}.up-ban-form{flex-direction:column;gap:14px;padding:16px;display:flex}.up-ban-field-label{color:var(--muted);letter-spacing:.02em;text-transform:uppercase;font-size:.82rem;font-weight:500}.up-ban-checkboxes{flex-direction:column;gap:10px;padding:4px 0;display:flex}.up-ban-check{cursor:pointer;color:var(--text);align-items:center;gap:9px;font-size:.9rem;display:flex}.up-ban-check--all{border-bottom:1px solid var(--border);padding-bottom:8px}.up-ban-check input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.up-btn-ban{color:#fff;cursor:pointer;background:#e53e3e;border:none;border-radius:7px;width:100%;padding:9px 18px;font-size:.9rem;font-weight:600;transition:opacity .15s}.up-btn-ban:hover:not(:disabled){opacity:.88}.up-btn-ban:disabled{opacity:.45;cursor:not-allowed}.up-btn-danger{color:#fff;cursor:pointer;background:#e53e3e;border:none;border-radius:7px;padding:9px 18px;font-size:.9rem;font-weight:600;transition:opacity .15s}.up-btn-danger:hover:not(:disabled){opacity:.88}.up-btn-danger:disabled{opacity:.45;cursor:not-allowed}.admin-delete-reason-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin:0 0 8px;font-size:.8rem;font-weight:600}.admin-delete-presets{flex-direction:column;gap:6px;display:flex}.admin-delete-preset{border:1.5px solid var(--border);cursor:pointer;color:var(--text);border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:.88rem;transition:border-color .15s,background .15s;display:flex}.admin-delete-preset input[type=radio]{accent-color:#e53e3e}.admin-delete-preset:hover{background:#e53e3e0d;border-color:#e53e3e}.admin-delete-preset.selected{background:#e53e3e14;border-color:#e53e3e}.comment-author.clickable{cursor:pointer}.comment-author.clickable:hover{color:var(--accent);text-decoration:underline}.notif-page-list{flex-direction:column;gap:2px;display:flex}.notif-page-item{border:1px solid var(--border);background:var(--bg-1);border-radius:10px;align-items:center;gap:12px;padding:14px 16px;transition:background .15s;display:flex;position:relative}.notif-page-item.unread{background:var(--bg-2)}.notif-page-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:40px;height:40px}.notif-page-content{flex:1;min-width:0}.notif-page-text{color:var(--text-1);margin:0;font-size:13.5px;line-height:1.35}.notif-page-time{color:var(--text-3);margin-top:2px;font-size:11.5px;display:block}.notif-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:8px;height:8px}.settings-layout{align-items:stretch;gap:0;min-height:calc(100vh - 56px);padding:40px 48px;display:flex}.settings-nav{flex-direction:column;flex-shrink:0;align-self:flex-start;gap:2px;width:220px;display:flex;position:sticky;top:24px}.settings-nav-item{text-align:left;width:100%;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:9px 14px;font-size:13.5px;transition:background .15s,color .15s;display:block}.settings-nav-item:hover{background:var(--bg-4);color:var(--text)}.settings-nav-item.active{background:var(--accent-dim);color:var(--accent);font-weight:500}.profile-card-desc{color:var(--text-2);margin-bottom:16px;font-size:13px}.lang-tab-switcher{gap:8px;display:flex}.lang-tab-btn{border:1px solid var(--border);background:var(--bg-2);color:var(--text-2);cursor:pointer;border-radius:6px;padding:6px 18px;font-size:13px;transition:background .15s,color .15s}.lang-tab-btn:hover{color:var(--text)}.lang-tab-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.blog-lang-options{flex-direction:column;gap:12px;display:flex}.blog-lang-option{cursor:pointer;align-items:center;gap:8px;font-size:14px;display:flex}.blog-lang-option input[type=radio]{accent-color:var(--accent)}.blog-lang-hint{color:var(--text-3);font-size:12px}.blog-lang-checkboxes{flex-direction:column;gap:8px;padding-left:24px;display:flex}.blog-lang-checkbox{cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.blog-lang-checkbox input[type=checkbox]{accent-color:var(--accent)}.settings-content{border-left:1px solid var(--border);flex-direction:column;flex:1;gap:20px;min-width:0;margin-left:40px;padding-left:40px;display:flex}@media (width<=768px){.settings-layout{flex-direction:column;gap:0;padding:0 16px 60px}.settings-content{border-left:none;margin-left:0;padding-left:0}}.settings-mobile-bar{display:none}@media (width<=768px){.settings-mobile-bar{background:var(--bg-2);border:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;border-radius:10px;justify-content:space-between;align-items:center;margin:16px 0 20px;padding:14px 16px;font-size:14px;font-weight:600;display:flex}.settings-mobile-bar:hover{background:var(--bg-3)}}.settings-drawer-overlay{z-index:300;background:#000000b8;align-items:flex-end;display:flex;position:fixed;inset:0}.settings-drawer{background:var(--bg-2);border-radius:16px 16px 0 0;flex-direction:column;width:100%;max-height:80vh;display:flex;overflow-y:auto}.settings-drawer-header{border-bottom:1px solid var(--border);color:var(--text);background:var(--bg-2);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;font-size:15px;font-weight:600;display:flex;position:sticky;top:0}.settings-drawer-close{cursor:pointer;color:var(--text-3);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.settings-drawer-close:hover{background:var(--bg-3);color:var(--text)}.settings-drawer-item{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text-2);text-align:left;cursor:pointer;background:0 0;justify-content:space-between;align-items:center;padding:15px 18px;font-family:inherit;font-size:14px;transition:background .12s;display:flex}.settings-drawer-item:hover{background:var(--bg-3);color:var(--text)}.settings-drawer-item.active{color:var(--accent);font-weight:600}.notif-toggle-list{flex-direction:column;gap:0;display:flex}.notif-toggle-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 0;display:flex}.notif-toggle-row:last-child{border-bottom:none}.notif-toggle-label{color:var(--text);align-items:center;gap:8px;font-size:13.5px;display:flex}.notif-disabled .notif-toggle-label{color:var(--text-3)}.notif-disabled .toggle-switch{opacity:.4;cursor:not-allowed}.invite-code-row{align-items:center;gap:8px;display:flex}.invite-code-input{letter-spacing:.08em;background:var(--bg-3);border:1px solid var(--border);color:var(--text-2);border-radius:8px;flex:1;padding:8px 12px;font-family:JetBrains Mono,monospace;font-size:14px}.invite-copy-btn{flex-shrink:0;align-items:center;gap:6px;display:flex}.form-row{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;display:grid}.uc-full-name{color:var(--text-3);margin-top:1px;font-size:12px}.up-full-name{color:var(--text-2);margin-top:2px;font-size:14px}.blog-page-inner{box-sizing:border-box;width:100%;max-width:1200px;margin:0 auto;padding:32px 24px 64px}.blog-filters{flex-wrap:wrap;gap:10px;margin-bottom:24px;display:flex}.blog-search{border:1px solid var(--border);background:var(--bg-2);min-width:180px;color:var(--text);border-radius:8px;flex:1;padding:8px 12px;font-size:14px}.blog-search::placeholder{color:var(--text-3)}.blog-search:focus{border-color:var(--accent);outline:none}.blog-list{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}@media (width<=1200px){.blog-list{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.blog-list{grid-template-columns:1fr}}.blog-card{border:1px solid var(--border);background:var(--bg-2);cursor:pointer;border-radius:12px;flex-direction:column;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.blog-card:hover{border-color:var(--accent);box-shadow:0 2px 16px #0000002e}.blog-card-cover{width:100%;height:160px;overflow:hidden}.blog-card-cover img{object-fit:cover;width:100%;height:100%}.blog-card-body{flex-direction:column;flex:1;gap:8px;padding:18px 20px;display:flex}.blog-card-meta{color:var(--text-3);align-items:center;gap:10px;font-size:12px;display:flex}.blog-card-category{text-transform:uppercase;letter-spacing:.05em;color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.blog-card-date{color:var(--text-3);font-size:12px}.blog-card-title{color:var(--text);margin:0;font-size:17px;font-weight:700;line-height:1.35}.blog-card-excerpt{color:var(--text-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.55;display:-webkit-box;overflow:hidden}.blog-card-footer{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.blog-card-author{color:var(--text-2);align-items:center;gap:8px;font-size:13px;display:flex}.blog-card-avatar{object-fit:cover;border-radius:50%;width:26px;height:26px}.blog-card-avatar.initials{background:var(--accent);color:#fff;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.blog-card-stats{align-items:center;gap:10px;display:flex}.blog-stat{color:var(--text-3);align-items:center;gap:4px;font-size:12px;display:flex}.blog-stat.green{color:var(--green)}.blog-stat.red{color:var(--red)}.blog-post-page{max-width:1200px;margin:0 auto;padding:0 24px 80px}.blog-post-cover{border-radius:0 0 16px 16px;width:100%;max-height:380px;margin-bottom:32px;overflow:hidden}.blog-post-cover img{object-fit:cover;width:100%;height:100%}.blog-post-header{margin-bottom:32px}.blog-post-meta{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:10px;display:flex}.blog-post-date{color:var(--text-3);font-size:13px}.blog-post-title{color:var(--text);margin:0 0 16px;font-size:28px;font-weight:800;line-height:1.25}.blog-post-author-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.blog-post-actions{align-items:center;gap:10px;display:flex}@media (width<=600px){.blog-post-page{width:100vw;padding:0 14px 60px}.blog-post-title{font-size:20px}.blog-post-author-row{flex-direction:column;align-items:flex-start}.blog-post-actions{flex-wrap:wrap}}.blog-post-content{color:var(--text-2);font-size:15px;line-height:1.75}.blog-post-content h1,.blog-post-content h2,.blog-post-content h3{color:var(--text);margin:1.5em 0 .5em;line-height:1.3}.blog-post-content h1{font-size:22px}.blog-post-content h2{font-size:19px}.blog-post-content h3{font-size:16px}.blog-post-content p{margin:0 0 1em}.blog-post-content a{color:var(--accent);text-decoration:underline}.blog-post-content ul,.blog-post-content ol{margin:0 0 1em;padding-left:1.5em}.blog-post-content li{margin:.35em 0}.blog-post-content blockquote{border-left:3px solid var(--accent);color:var(--text-3);margin:1em 0;padding:.5em 1em;font-style:italic}.blog-post-content code{background:var(--bg-3);border-radius:4px;padding:2px 5px;font-family:monospace;font-size:.9em}.blog-post-content pre{background:var(--bg-3);border-radius:8px;margin:1em 0;padding:14px 16px;font-family:monospace;font-size:13px;overflow-x:auto}.blog-post-content img{border-radius:8px;max-width:100%;margin:1em 0}.blog-post-content hr{border:none;border-top:1px solid var(--border);margin:2em 0}.blog-fen-board{width:360px;max-width:100%;margin:20px auto;font-size:0;line-height:0}.blog-author-posts{border-top:1px solid var(--border);margin-top:48px;padding-top:32px}.blog-author-posts-title{color:var(--text);margin:0 0 16px;font-size:15px;font-weight:700}.blog-author-posts-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.blog-author-post-card{border:1px solid var(--border);cursor:pointer;background:var(--bg-2);border-radius:10px;transition:border-color .15s;overflow:hidden}.blog-author-post-card:hover{border-color:var(--accent)}.blog-author-post-card img{object-fit:cover;width:100%;height:100px}.blog-author-post-card span{color:var(--text);padding:10px 12px;font-size:13px;font-weight:600;line-height:1.35;display:block}.blog-create-page{box-sizing:border-box;flex-direction:column;gap:12px;width:100%;max-width:1200px;margin:0 auto;padding:32px 24px 80px;display:flex}.blog-create-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.blog-create-actions{align-items:center;gap:10px;display:flex}.blog-save-msg-inline{color:var(--accent);font-size:13px}.blog-meta-bar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.blog-cover-btn{margin-left:auto}.blog-cover-preview-bar{border-radius:12px;width:100%;max-height:260px;overflow:hidden}.blog-cover-preview-bar img{object-fit:cover;width:100%;height:100%}.blog-cover-upload{border:2px dashed var(--border);cursor:pointer;background:var(--bg-2);border-radius:12px;justify-content:center;align-items:center;width:100%;height:200px;transition:border-color .15s;display:flex;overflow:hidden}.blog-cover-upload:hover{border-color:var(--accent)}.blog-cover-preview{object-fit:cover;width:100%;height:100%}.blog-cover-placeholder{color:var(--text-3);font-size:13px}.blog-title-input{border:none;border-bottom:2px solid var(--border);width:100%;color:var(--text);background:0 0;outline:none;padding:10px 0;font-size:22px;font-weight:700;transition:border-color .15s}.blog-title-input:focus{border-bottom-color:var(--accent)}.blog-title-input::placeholder{color:var(--text-3)}.blog-excerpt-input{border:1px solid var(--border);background:var(--bg-2);width:100%;color:var(--text);resize:vertical;border-radius:8px;outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.blog-excerpt-input:focus{border-color:var(--accent)}.blog-excerpt-input::placeholder{color:var(--text-3)}.blog-toolbar{border:1px solid var(--border);background:var(--bg-2);border-radius:8px;flex-wrap:wrap;align-items:center;gap:2px;padding:6px 8px;display:flex}.blog-tb-btn{width:30px;height:30px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.blog-tb-btn:hover{background:var(--bg-3);color:var(--text)}.blog-tb-btn.active{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent)}.blog-tb-sep{background:var(--border);width:1px;height:20px;margin:0 4px}.blog-tb-fen{letter-spacing:.02em;white-space:nowrap;padding:0 2px;font-size:11px;font-weight:700}.blog-tb-btn:has(.blog-tb-fen){width:auto;padding:0 8px}.blog-editor-content{border:1px solid var(--border);background:var(--bg-2);cursor:text;border-radius:8px;min-height:400px;padding:16px}.blog-editor-content .tiptap{min-height:360px;color:var(--text-2);outline:none;font-size:15px;line-height:1.7}.blog-editor-content .tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--text-3);float:left;pointer-events:none;height:0}.blog-editor-content .tiptap h1,.blog-editor-content .tiptap h2,.blog-editor-content .tiptap h3{color:var(--text);margin:1.2em 0 .4em}.blog-editor-content .tiptap h1{font-size:22px}.blog-editor-content .tiptap h2{font-size:18px}.blog-editor-content .tiptap h3{font-size:15px}.blog-editor-content .tiptap a{color:var(--accent)}.blog-editor-content .tiptap blockquote{border-left:3px solid var(--accent);color:var(--text-3);margin:.8em 0;padding:.4em 1em;font-style:italic}.blog-editor-content .tiptap code{background:var(--bg-3);border-radius:4px;padding:1px 4px;font-family:monospace;font-size:.9em}.blog-editor-content .tiptap pre{background:var(--bg-3);border-radius:8px;padding:12px 14px;font-family:monospace;font-size:13px;overflow-x:auto}.blog-editor-content .tiptap ul,.blog-editor-content .tiptap ol{padding-left:1.4em}.blog-editor-content .tiptap img{border-radius:8px;max-width:100%}.blog-editor-content .tiptap hr{border:none;border-top:1px solid var(--border);margin:1.5em 0}.blog-pgn-viewer{max-width:360px;margin:24px auto}.pgn-viewer{border:1px solid var(--border);background:var(--bg-2);border-radius:12px;overflow:hidden}.pgn-viewer-info{color:var(--text-2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:600;display:flex}.pgn-vs{color:var(--text-3);margin:0 4px;font-weight:400}.pgn-result{color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent);white-space:nowrap;border-radius:20px;padding:2px 8px;font-size:12px;font-weight:700}.pgn-viewer-board{width:100%;font-size:0;line-height:0}.pgn-viewer-board>*{width:100%!important}.pgn-viewer-controls{border-top:1px solid var(--border);border-bottom:1px solid var(--border);justify-content:center;align-items:center;gap:8px;padding:10px 14px;display:flex}.pgn-btn{border:1px solid var(--border);background:var(--bg-3);width:32px;height:32px;color:var(--text-2);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.pgn-btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent)}.pgn-btn:disabled{opacity:.35;cursor:default}.pgn-counter{color:var(--text-3);text-align:center;min-width:50px;font-size:13px}.pgn-move-list{flex-wrap:wrap;gap:2px 4px;max-height:140px;padding:10px 14px;font-size:13px;line-height:1.6;display:flex;overflow-y:auto}.pgn-move-group{align-items:baseline;gap:2px;display:inline-flex}.pgn-move-num{color:var(--text-3);-webkit-user-select:none;user-select:none;font-size:12px}.pgn-move{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:1px 5px;font-family:inherit;font-size:13px;transition:background .1s,color .1s}.pgn-move:hover{background:var(--bg-3);color:var(--text)}.pgn-move.active{background:var(--accent);color:#fff}.pgn-viewer-error{color:var(--red);text-align:center;padding:12px;font-size:13px}.blog-related-section{border-top:1px solid var(--border);margin-top:48px;padding-top:32px}.blog-related-title{color:var(--text);margin:0 0 20px;font-size:17px;font-weight:600}.blog-related-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=900px){.blog-related-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=540px){.blog-related-grid{grid-template-columns:1fr}}.blog-comments-section{border-top:1px solid var(--border);margin-top:48px;padding-top:32px}.blog-comments-title{color:var(--text);align-items:center;gap:8px;margin:0 0 20px;font-size:15px;font-weight:700;display:flex}.tiptap-pgn-block{border:2px dashed var(--border);background:var(--bg-3);color:var(--text-3);-webkit-user-select:none;user-select:none;cursor:default;border-radius:8px;align-items:center;gap:8px;margin:8px 0;padding:12px 16px;font-size:13px;font-style:italic;display:flex}.forum-page-inner{box-sizing:border-box;width:100%;max-width:1200px;margin:0 auto;padding:32px 24px 64px}.forum-list{flex-direction:column;gap:12px;display:flex}.forum-card{border:1px solid var(--border);background:var(--bg-2);cursor:pointer;border-radius:12px;gap:0;height:auto;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.forum-card--pinned{border-color:var(--accent)}.forum-pin-badge{text-transform:uppercase;letter-spacing:.04em;color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent);border-radius:4px;align-items:center;gap:4px;padding:2px 7px;font-size:.7rem;font-weight:600;display:inline-flex}.forum-pin-btn{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:.75rem;transition:color .15s,background .15s;display:inline-flex}.forum-pin-btn:hover{color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent)}.forum-pin-btn.active{color:var(--accent)}.forum-pin-btn:disabled{opacity:.5;cursor:default}.forum-card:hover{border-color:var(--accent);box-shadow:0 2px 12px #00000026}.forum-card-board{background:var(--bg-3);flex-shrink:0;justify-content:center;align-items:center;width:110px;padding:12px;display:flex}.forum-card-body{flex-direction:column;flex:1;gap:8px;padding:22px 24px;display:flex}.forum-card-tags{flex-wrap:wrap;gap:6px;display:flex}.forum-tag{color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent);cursor:pointer;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600;transition:background .15s}.forum-tag:hover,.forum-tag.active{background:color-mix(in srgb, var(--accent) 25%, transparent)}.forum-tag-remove{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:none;padding:0 0 0 4px;font-size:10px}.forum-tag-remove:hover{opacity:1}.forum-card-title{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:16px;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.forum-card-excerpt{color:var(--text-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.forum-card-footer{justify-content:space-between;align-items:center;margin-top:auto;padding-top:6px;display:flex}.forum-author-elo{color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent);border-radius:10px;padding:1px 6px;font-size:11px;font-weight:600}.forum-tag-input-wrap{border:1px solid var(--border);background:var(--bg-2);border-radius:8px;flex-wrap:wrap;align-items:center;gap:6px;min-height:40px;padding:8px 12px;display:flex}.forum-tag-input{min-width:120px;color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:13px}.forum-tag-input::placeholder{color:var(--text-3)}.forum-post-page{box-sizing:border-box;width:100%;max-width:1200px;margin:0 auto;padding:32px 24px 80px}.forum-create-page{box-sizing:border-box;flex-direction:column;gap:12px;width:100%;max-width:1200px;margin:0 auto;padding:32px 24px 80px;display:flex}.forum-post-inner{background:var(--bg-2);border:1px solid var(--border);border-radius:16px;padding:32px 36px}.forum-post-title{color:var(--text);margin:0 0 16px;font-size:26px;font-weight:800;line-height:1.3}.forum-post-body{border-top:1px solid var(--border);margin:24px 0;padding-top:24px}.forum-post-actions{border-top:1px solid var(--border);border-bottom:1px solid var(--border);align-items:center;gap:12px;margin-bottom:24px;padding:16px 0;display:flex}.forum-vote-btn{border:1px solid var(--border);background:var(--bg-3);color:var(--text-2);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .15s;display:flex}.forum-vote-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.forum-vote-btn.voted{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent)}.forum-vote-btn:disabled{opacity:.5;cursor:default}.btn-xs{align-items:center;gap:4px;padding:4px 8px;font-size:12px;display:flex}.btn-xs.red{color:var(--red)}.btn-xs.red:hover{background:color-mix(in srgb, var(--red) 10%, transparent)}@keyframes skel-pulse{0%,to{opacity:1}50%{opacity:.45}}.skel{background:var(--bg-3);border-radius:6px;animation:1.5s ease-in-out infinite skel-pulse}.forum-card-skeleton{cursor:default;pointer-events:none}.forum-card-skeleton:hover{border-color:var(--border);box-shadow:none}.skel-tags{background:0 0;gap:8px;height:20px;animation:none;display:flex}.skel-tag{background:var(--bg-3);border-radius:20px;width:56px;height:20px;animation:1.5s ease-in-out infinite skel-pulse}.skel-tag:nth-child(2){width:72px;animation-delay:.2s}.skel-title{border-radius:6px;width:65%;height:22px;animation-delay:.1s}.skel-line{border-radius:4px;width:90%;height:14px;animation-delay:.15s}.skel-line-short{width:70%;animation-delay:.2s}.skel-author{border-radius:20px;width:140px;height:26px;animation-delay:.25s}.skel-stats{border-radius:4px;width:100px;height:14px;animation-delay:.3s}.blog-card-skeleton{cursor:default;pointer-events:none}.blog-card-skeleton:hover{border-color:var(--border);box-shadow:none}.blog-card-skel-cover{border-radius:0;flex-shrink:0;width:100%;height:160px}.skel-category{border-radius:20px;width:70px;height:18px;animation-delay:50ms}.repertoire-card-skeleton{cursor:default;pointer-events:none;min-height:140px}.repertoire-card-skeleton:hover{border-color:var(--border)}.rep-card-skel-board{border-radius:0;flex-shrink:0;align-self:stretch;width:38%}.friend-card-skeleton{cursor:default;pointer-events:none}.friend-card-skeleton:hover{border-color:var(--border)}.skel-avatar-lg{border-radius:10px;flex-shrink:0;width:80px;height:80px;animation-delay:50ms}.skel-btn{border-radius:8px;height:34px;animation-delay:.3s}.notif-page-item-skeleton{cursor:default;pointer-events:none}.skel-avatar-sm{border-radius:50%;flex-shrink:0;width:40px;height:40px;animation-delay:50ms}.skel-notif-text{border-radius:4px;width:70%;height:14px;animation-delay:.1s}.skel-notif-time{border-radius:4px;width:48px;height:11px;margin-top:6px;animation-delay:.15s}.site-footer{background:var(--bg-1);border-top:1px solid var(--border);padding:20px 32px 20px 272px}.site-footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;max-width:1200px;margin:0 auto;display:flex}.site-footer-left{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.site-footer-brand{color:var(--text);align-items:center;gap:6px;font-size:13px;font-weight:700;display:flex}.site-footer-beta{background:var(--accent);color:#fff;letter-spacing:.04em;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:700}.site-footer-version{color:var(--text-3);font-size:11px;font-weight:400}.site-footer-copy{color:var(--text-3);font-size:12px}.site-footer-links{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.site-footer-link{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:12px;transition:color .15s,background .15s}.site-footer-link:hover{color:var(--text);background:var(--bg-2)}.site-footer-lang{background:var(--bg-2);border:1px solid var(--border);color:var(--text-3);cursor:pointer;border-radius:6px;outline:none;margin-left:4px;padding:3px 8px;font-size:12px;transition:border-color .15s,color .15s}.site-footer-lang:hover,.site-footer-lang:focus{border-color:var(--accent);color:var(--text)}.messages-page-root{height:100dvh;overflow:hidden}.messages-layout{flex:1;min-height:0;display:flex;overflow:hidden}.messages-sidebar{border-right:1px solid var(--border);background:var(--bg-1);flex-direction:column;flex-shrink:0;width:300px;display:flex;overflow:hidden}.messages-sidebar-header{border-bottom:1px solid var(--border);flex-shrink:0;padding:16px 20px 12px}.messages-sidebar-title{color:var(--text);font-size:15px;font-weight:700}.messages-sidebar-list{flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.msg-conv-item{text-align:left;border:none;border-bottom:1px solid var(--border);cursor:pointer;background:0 0;align-items:center;gap:12px;width:100%;padding:12px 16px;transition:background .12s;display:flex}.msg-conv-item:hover{background:var(--bg-2)}.msg-conv-item.active{background:var(--bg-3)}.msg-conv-skeleton{cursor:default;pointer-events:none}.msg-conv-avatar-wrap{flex-shrink:0;position:relative}.msg-conv-avatar-img{object-fit:cover;border-radius:50%;width:42px;height:42px}.msg-conv-avatar-initials{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-size:14px;font-weight:700;display:flex}.msg-conv-unread{color:#fff;background:#e53e3e;border-radius:9999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-3px;right:-3px}.msg-conv-info{flex:1;min-width:0}.msg-conv-name-row{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.msg-conv-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.msg-conv-time{color:var(--text-3);flex-shrink:0;font-size:11px}.msg-conv-preview{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.msg-conv-skel-avatar{border-radius:50%;flex-shrink:0;width:42px;height:42px}.msg-load-more{margin:12px auto;font-size:13px}.msg-empty-sidebar{text-align:center;color:var(--text-3);padding:32px 20px;font-size:13px}.messages-chat{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.messages-no-selection{color:var(--text-3);flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.messages-chat-header{border-bottom:1px solid var(--border);background:var(--bg-1);flex-shrink:0;align-items:center;gap:12px;padding:12px 20px;display:flex}.msg-chat-avatar{border-radius:50%;flex-shrink:0;width:36px;height:36px;overflow:hidden}.msg-chat-avatar img{object-fit:cover;width:100%;height:100%}.messages-chat-name{color:var(--text);cursor:pointer;background:0 0;border:none;padding:0;font-size:15px;font-weight:600;transition:color .15s}.messages-chat-name:hover{color:var(--accent)}.messages-list{flex-direction:column;flex:1;gap:6px;min-height:0;padding:20px 24px;display:flex;overflow-y:auto}.msg-top-sentinel{flex-shrink:0;height:1px}.msg-loading-more{justify-content:center;padding:8px 0;display:flex}.msg-skeletons{flex-direction:column;gap:10px;padding-top:8px;display:flex}.msg-skel-row{display:flex}.msg-skel-row.right{justify-content:flex-end}.msg-skel-bubble{border-radius:16px;height:36px}.msg-bubble-wrap{justify-content:flex-start;display:flex}.msg-bubble-wrap.mine{justify-content:flex-end}.msg-bubble{background:var(--bg-3);border:1px solid var(--border);border-radius:18px 18px 18px 4px;flex-direction:column;gap:3px;max-width:68%;padding:9px 14px;display:flex}.msg-bubble.mine{background:var(--accent);color:#fff;border-color:#0000;border-radius:18px 18px 4px}.msg-bubble-text{word-break:break-word;white-space:pre-wrap;font-size:14px;line-height:1.5}.msg-bubble-time{opacity:.6;align-self:flex-end;font-size:10px}.messages-input-area{border-top:1px solid var(--border);background:var(--bg-1);flex-shrink:0;align-items:flex-end;gap:10px;padding:14px 20px;display:flex}.messages-textarea{resize:none;background:var(--bg-2);border:1px solid var(--border);color:var(--text);border-radius:12px;outline:none;flex:1;max-height:140px;padding:10px 14px;font-family:inherit;font-size:14px;line-height:1.5;transition:border-color .15s;overflow-y:auto}.messages-textarea:focus{border-color:var(--accent)}.messages-send-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:opacity .15s;display:flex}.messages-send-btn:hover:not(:disabled){opacity:.85}.messages-send-btn:disabled{opacity:.4;cursor:default}.messages-blocked-notice{border-top:1px solid var(--border);background:var(--surface);color:var(--text-muted);text-align:center;flex-shrink:0;padding:14px 20px;font-size:.85rem}.plan-badge-row{margin-bottom:1rem}.plan-badge{letter-spacing:.05em;text-transform:uppercase;border-radius:999px;padding:.25rem .75rem;font-size:.8rem;font-weight:700;display:inline-block}.plan-badge--free{background:var(--border);color:var(--text-muted)}.plan-badge--basic{color:#3b82f6;background:#2563eb22;border:1px solid #3b82f655}.plan-badge--pro{color:#a78bfa;background:#7c3aed22;border:1px solid #7c3aed55}.plan-badge--premium{color:#f59e0b;background:#d9770622;border:1px solid #d9770655}.plan-features-table{border-collapse:collapse;width:100%;margin-top:.5rem;font-size:.9rem}.plan-features-table td{border-bottom:1px solid var(--border);color:var(--text);padding:.45rem .25rem}.plan-features-table td:last-child{text-align:right;font-weight:600}.plan-usage-bar{background:var(--border);border-radius:3px;height:5px;margin-top:2px;overflow:hidden}.plan-usage-bar__fill{background:var(--accent);border-radius:3px;height:100%;transition:width .4s}.plan-limit-modal{text-align:center;max-width:400px}.plan-limit-modal__title{margin-bottom:.75rem;font-size:1.1rem}.plan-limit-modal__body{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem;line-height:1.5}.plan-limit-modal__actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.plan-gate-page{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:12px;max-width:460px;margin:6rem auto;padding:2.5rem}.plan-gate-page h2{margin-bottom:.75rem;font-size:1.25rem}.plan-gate-page p{color:var(--text-muted);margin-bottom:1.75rem;font-size:.95rem;line-height:1.6}.plan-gate-page__actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.plan-billing-toggle{gap:.5rem;margin-bottom:1.5rem;display:flex}.plan-billing-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:.4rem;padding:.4rem 1rem;font-size:.85rem;transition:all .15s;display:flex}.plan-billing-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.plan-billing-save{color:#16a34a;background:#16a34a22;border-radius:4px;padding:1px 5px;font-size:.7rem}.plan-table-grid{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}@media (width<=900px){.plan-table-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.plan-table-grid{grid-template-columns:1fr}}.plan-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.6rem;padding:1.25rem 1rem 1rem;display:flex;position:relative}.plan-card--current{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.plan-card__current-badge{background:var(--accent);color:#fff;white-space:nowrap;letter-spacing:.04em;border-radius:999px;padding:2px 10px;font-size:.7rem;font-weight:700;position:absolute;top:-11px;left:50%;transform:translate(-50%)}.plan-card__name{align-self:flex-start}.plan-card__price{align-items:baseline;gap:.25rem;margin:.25rem 0 .5rem;display:flex}.plan-card__price-main{font-size:1.6rem;font-weight:800}.plan-card__price-period{color:var(--text-muted);font-size:.8rem}.plan-card__price-soon{color:var(--text-3);letter-spacing:.05em;text-transform:uppercase;opacity:.7;font-size:1rem;font-weight:600}.plan-card__features{flex-direction:column;flex:1;gap:0;margin:0;padding:0;list-style:none;display:flex}.plan-card__features li{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.35rem 0;font-size:.82rem;display:flex}.plan-card__features li:last-child{border-bottom:none}.plan-feat-bar-row{padding:.15rem 0 .4rem!important;display:block!important}.plan-feat-label{color:var(--text-muted)}.plan-feat-val{font-weight:600}.plan-feat-val.ok{color:#16a34a}.plan-feat-val.no{color:var(--text-muted);opacity:.5}.plan-card__footer{margin-top:.75rem}.plan-card__footer button{justify-content:center;width:100%}.gift-code-card{margin-top:1.5rem}.puzzle-history-card{padding:20px 24px}.puzzle-history-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:18px;display:flex}.puzzle-history-total{color:var(--text-3);font-size:13px}.puzzle-history-empty{color:var(--text-3);margin:24px 0;font-size:14px}.puzzle-history-table-wrap{border:1px solid var(--border);border-radius:8px;overflow-x:auto}.puzzle-history-table{border-collapse:collapse;width:100%;font-size:13px}.puzzle-history-table thead th{background:var(--bg-2);text-align:left;color:var(--text-2);white-space:nowrap;border-bottom:1px solid var(--border);padding:9px 12px;font-size:12px;font-weight:600}.puzzle-history-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.puzzle-history-table tbody tr:last-child{border-bottom:none}.puzzle-history-table tbody tr:hover{background:var(--bg-2)}.ph-row--ok{border-left:3px solid #22c55e80}.ph-row--fail{border-left:3px solid #dc262666}.puzzle-history-table td{vertical-align:middle;padding:9px 12px}.ph-date{white-space:nowrap;color:var(--text-2)}.ph-time-of-day{color:var(--text-3);font-size:11px;display:block}.ph-puzzle-link{cursor:pointer;color:var(--accent);background:0 0;border:none;padding:0;font-family:monospace;font-size:12px;text-decoration:none}.ph-puzzle-link:hover{text-decoration:underline}.ph-rating{color:var(--text);white-space:nowrap;font-weight:600}.ph-themes{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:12px;overflow:hidden}.ph-duration{white-space:nowrap;font-variant-numeric:tabular-nums}.ph-rchange{white-space:nowrap;font-weight:600}.ph-rchange.up{color:#16a34a}.ph-rchange.down{color:#dc2626}.ph-result{text-align:center}.ph-badge{border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;font-weight:700;display:inline-flex}.ph-badge--ok{color:#16a34a;background:#22c55e26}.ph-badge--fail{color:#dc2626;background:#dc26261f}.puzzle-history-more{width:100%;margin-top:16px}.gift-code-row{align-items:stretch;gap:.75rem;margin-top:.75rem;display:flex}.gift-code-input-wrap{background:var(--bg-3,var(--surface));border:1px solid var(--border);border-radius:10px;flex:1;align-items:center;gap:.6rem;padding:0 1rem;transition:border-color .15s,box-shadow .15s;display:flex}.gift-code-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent)}.gift-code-icon{flex-shrink:0;font-size:1.1rem}.gift-code-input{letter-spacing:.1em;color:var(--text);text-transform:uppercase;background:0 0;border:none;outline:none;flex:1;padding:.7rem 0;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.95rem}.gift-code-input::placeholder{color:var(--text-muted);letter-spacing:.04em;text-transform:none;font-size:.85rem}.gift-code-btn{flex-shrink:0;padding:.7rem 1.25rem}.gift-code-msg{border-radius:7px;margin-top:.6rem;padding:.5rem .75rem;font-size:.85rem}.gift-code-msg.ok{color:#16a34a;background:#16a34a18;border:1px solid #16a34a33}.gift-code-msg.err{color:#ef4444;background:#dc262618;border:1px solid #dc262633}.chess-title-badge{color:#fff;letter-spacing:.04em;vertical-align:middle;background:#dc2626;border-radius:4px;flex-shrink:0;margin-right:4px;padding:1px 5px;font-size:10px;font-weight:700;line-height:1.5;display:inline-block}.plan-icon{vertical-align:middle;cursor:default;flex-shrink:0;align-items:center;margin-left:5px;display:inline-flex;position:relative}.plan-icon:after{content:attr(data-tooltip);background:var(--bg);color:var(--text);border:1px solid var(--border);white-space:nowrap;pointer-events:none;opacity:0;z-index:10;border-radius:6px;padding:3px 8px;font-size:11px;transition:opacity .15s;position:absolute;bottom:calc(100% + 5px);left:50%;transform:translate(-50%)}.plan-icon:hover:after{opacity:1}.plan-icon--basic{color:#3b82f6}.plan-icon--pro{color:#a78bfa}.plan-icon--premium{color:#f59e0b}.legal-page{max-width:760px;margin:0 auto;padding:2rem 1.5rem 4rem}.legal-back{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;gap:6px;margin-bottom:2rem;padding:0;font-size:.875rem;transition:color .15s;display:inline-flex}.legal-back:hover{color:var(--text)}.legal-content h1{color:var(--text);margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.legal-updated{color:var(--text-muted);margin-bottom:2rem;font-size:.8125rem}.legal-content h2{color:var(--text);margin:2rem 0 .5rem;font-size:1.05rem;font-weight:600}.legal-content h3{color:var(--text);margin:1.25rem 0 .4rem;font-size:.9375rem;font-weight:600}.legal-content p,.legal-content li{color:var(--text-muted);font-size:.9375rem;line-height:1.7}.legal-content ul{margin:.5rem 0;padding-left:1.4rem}.legal-content li{margin-bottom:.35rem}.legal-content strong{color:var(--text)}.legal-content code{background:var(--bg-secondary,#1e1e2e);color:var(--accent);border-radius:4px;padding:1px 5px;font-size:.84em}.feedback-modal{width:100%;max-width:480px}.feedback-modal__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.feedback-modal__header h3{color:var(--text);margin:0;font-size:1rem;font-weight:600}.feedback-modal__body{flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.feedback-modal__footer{justify-content:flex-end;gap:.75rem;margin-top:.25rem;display:flex}.feedback-modal__sent{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:1.25rem;padding:2rem 1.25rem;font-size:.9375rem;display:flex}.feedback-field{flex-direction:column;gap:.35rem;display:flex}.feedback-field label{color:var(--text-muted);font-size:.8125rem;font-weight:500}.feedback-input,.feedback-textarea{background:var(--bg-secondary,#1e1e2e);border:1px solid var(--border);width:100%;color:var(--text);resize:none;box-sizing:border-box;border-radius:6px;outline:none;padding:.55rem .75rem;font-family:inherit;font-size:.9375rem;transition:border-color .15s}.feedback-input:focus,.feedback-textarea:focus{border-color:var(--accent)}.feedback-error{color:#f87171;margin:0;font-size:.8125rem}.home-section{margin-bottom:3rem}.home-section-header{justify-content:space-between;align-items:baseline;margin-bottom:1.25rem;display:flex}.home-section-title{color:var(--text);margin:0;font-size:1.15rem;font-weight:700}.home-section-link{cursor:pointer;color:var(--accent);background:0 0;border:none;align-items:center;gap:4px;padding:0;font-size:.8125rem;font-weight:500;transition:opacity .15s;display:inline-flex}.home-section-link:hover{opacity:.75}.home-course-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (width<=700px){.home-course-grid{grid-template-columns:1fr}}.home-blog-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}@media (width<=960px){.home-blog-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=500px){.home-blog-grid{grid-template-columns:1fr}}.home-hero-row{grid-template-columns:3fr 1fr;gap:20px;margin-bottom:28px;display:grid}@media (width<=768px){.home-hero-row{grid-template-columns:1fr}}.home-hero-card{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:16px;min-height:200px;padding:32px 36px;display:flex}.home-hero-greeting{color:var(--text-2);margin:0;font-size:1.05rem}.home-hero-greeting strong{color:var(--text);font-weight:700}.home-hero-logo{font-size:3rem;line-height:1}.home-hero-title{color:var(--text);margin:0;font-size:1.6rem;font-weight:800}.home-hero-sub{color:var(--text-2);margin:0;font-size:.95rem;line-height:1.6}.home-hero-last-label{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin:0;font-size:.8rem;font-weight:600}.home-hero-last-title{color:var(--text);margin:4px 0 8px;font-size:1.1rem;font-weight:700}.home-hero-last-sub{color:var(--text-2);margin:4px 0 8px;font-size:.9rem}.home-hero-last{flex-direction:column;gap:4px;display:flex}.home-hero-course-skel{flex-direction:column;gap:8px;margin-top:8px;display:flex}.home-hero-btn{align-self:flex-start;align-items:center;gap:6px;margin-top:4px;display:inline-flex}.home-hero-guest-actions{flex-wrap:wrap;gap:10px;display:flex}.home-puzzle-card{background:linear-gradient(135deg, var(--accent) 0%, #7c3aed 100%);color:#fff;border-radius:14px;flex-direction:column;align-items:flex-start;gap:10px;padding:28px 24px;display:flex}.home-puzzle-icon{font-size:2.5rem;line-height:1}.home-puzzle-title{color:#fff;margin:0;font-size:1.05rem;font-weight:700}.home-puzzle-sub{color:#ffffffbf;margin:0;font-size:.85rem}.home-puzzle-card .btn-primary{color:#fff;background:#ffffff2e;border:1px solid #ffffff4d;justify-content:center;align-self:stretch;margin-top:auto}.home-puzzle-card .btn-primary:hover{background:#ffffff47}.home-action-row{grid-template-columns:1fr 1fr 2fr;gap:16px;margin-bottom:28px;display:grid}@media (width<=900px){.home-action-row{grid-template-columns:1fr 1fr}.home-action-card--game{grid-column:1/-1}}@media (width<=600px){.home-action-row{grid-template-columns:1fr}}.home-action-card{border-radius:14px;flex-direction:column;gap:10px;min-height:180px;padding:24px;display:flex}.home-action-card--studio{background:linear-gradient(135deg, var(--accent) 0%, #7c3aed 100%);color:#fff}.home-action-card--errors{color:#fff;background:linear-gradient(135deg,#0f766e 0%,#0891b2 100%)}.home-action-card--game{background:var(--bg-1);border:1px solid var(--border);color:var(--text)}.home-action-icon{opacity:.9;font-size:2rem;line-height:1}.home-action-title{margin:0;font-size:1rem;font-weight:700}.home-action-card--studio .home-action-title,.home-action-card--errors .home-action-title{color:#fff}.home-action-sub{opacity:.8;flex:1;margin:0;font-size:.82rem;line-height:1.5}.home-action-btn{justify-content:center;align-self:stretch;margin-top:auto}.home-action-card--studio .btn-primary,.home-action-card--errors .btn-primary{color:#fff;background:#ffffff2e;border:1px solid #ffffff4d}.home-action-card--studio .btn-primary:hover,.home-action-card--errors .btn-primary:hover{background:#ffffff47}.home-action-connections{flex-direction:column;flex:1;gap:4px;display:flex}.home-action-badge{color:#ffffffd9;background:#ffffff26;border:1px solid #ffffff40;border-radius:20px;align-items:center;gap:4px;width:fit-content;padding:3px 10px;font-size:.78rem;display:inline-flex}.home-action-badge--connected{color:#fff;background:#ffffff38;border-color:#fff6;font-weight:600}.home-action-day-label{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-size:.78rem;font-weight:700}.home-daily-game-skel{flex-direction:column;flex:1;gap:0;display:flex}.home-daily-game-players{flex-wrap:wrap;align-items:center;gap:10px;margin:4px 0;display:flex}.home-daily-game-white,.home-daily-game-black{color:var(--text);font-size:.95rem;font-weight:700}.home-daily-game-result{color:var(--accent);background:var(--bg-2);border:1px solid var(--border);border-radius:6px;padding:2px 8px;font-size:.85rem;font-weight:700}.home-daily-game-meta{color:var(--text-3);flex-wrap:wrap;flex:1;gap:6px;font-size:.78rem;display:flex}.home-daily-game-meta span{background:var(--bg-2);border:1px solid var(--border);border-radius:4px;padding:2px 7px}.home-daily-game-actions{gap:8px;margin-top:auto;display:flex}.home-daily-game-btn{flex:1;justify-content:center}.home-quick-section{margin-bottom:40px}.home-quick-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=768px){.home-quick-grid{grid-template-columns:repeat(2,1fr)}}.home-quick-card{background:var(--bg-1);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:14px;flex-direction:column;align-items:flex-start;gap:8px;padding:24px 20px;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex}.home-quick-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 20px #0000001f}.home-quick-icon{background:var(--bg-2);width:48px;height:48px;color:var(--accent);border-radius:12px;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.home-quick-label{color:var(--text);font-size:1rem;font-weight:700}.home-quick-desc{color:var(--text-2);font-size:.8rem;line-height:1.4}.home-plan-banner{grid-template-columns:minmax(0,1fr) 3fr;gap:20px;margin-bottom:40px;display:grid}@media (width<=768px){.home-plan-banner{grid-template-columns:1fr}}.home-plan-left-col{flex-direction:column;gap:20px;min-width:0;display:flex}.home-plan-left{border:1px solid var(--border);background:var(--bg-1);border-radius:16px;flex-direction:column;flex:1;justify-content:center;align-items:flex-start;gap:10px;padding:24px;display:flex}.home-plan-left--free{background:var(--bg-1);border-color:var(--border)}.home-plan-left--basic{background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border-color:#a5d6a7}.home-plan-left--pro{background:linear-gradient(135deg,#e3f2fd,#ede7f6);border-color:#90caf9}.home-plan-left--premium{background:linear-gradient(135deg,#fffde7,#fff3e0);border-color:#ffe082}[data-theme=dark] .home-plan-left--basic{background:linear-gradient(135deg,#1b5e2018,#33691e18);border-color:#388e3c55}[data-theme=dark] .home-plan-left--pro{background:linear-gradient(135deg,#0d47a118,#4a148c18);border-color:#1565c055}[data-theme=dark] .home-plan-left--premium{background:linear-gradient(135deg,#f57f1718,#e6510018);border-color:#f9a82555}.home-plan-demo{background:var(--bg-1);border:1px solid var(--border);border-radius:16px;flex-direction:column;flex:1;justify-content:center;align-items:flex-start;gap:8px;padding:24px;display:flex}.home-invite-icon{background:var(--bg-2);width:36px;height:36px;color:var(--accent);border-radius:10px;justify-content:center;align-items:center;margin-bottom:2px;display:flex}.home-invite-title{color:var(--text);margin:0;font-size:.95rem;font-weight:700}.home-invite-sub{color:var(--text-2);margin:0;font-size:.78rem;line-height:1.4}.home-invite-row{flex-wrap:wrap;align-items:center;gap:8px;width:100%;margin-top:4px;display:flex}.home-invite-code{color:var(--text-2);background:var(--bg-2);border:1px solid var(--border);text-overflow:ellipsis;white-space:nowrap;border-radius:6px;flex:1;min-width:0;padding:5px 10px;font-family:monospace;font-size:.72rem;overflow:hidden}.home-invite-copy-btn{border:1px solid var(--border);background:var(--bg-2);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:8px;flex-shrink:0;align-items:center;gap:5px;padding:6px 12px;font-size:.78rem;font-weight:600;transition:background .15s,color .15s;display:inline-flex}.home-invite-copy-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.home-invite-login-hint{color:var(--text-2);margin:0;font-size:.78rem;font-style:italic}.home-plan-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-2);font-size:.75rem;font-weight:600}.home-plan-badge{border-radius:8px;align-items:center;gap:6px;padding:4px 14px;font-size:1.1rem;font-weight:800;display:inline-flex}.home-plan-badge--free{background:var(--bg-2);color:var(--text-2)}.home-plan-badge--basic{color:#2e7d32;background:#e8f5e9}.home-plan-badge--pro{color:#1565c0;background:#e3f2fd}.home-plan-badge--premium{color:#f57f17;background:linear-gradient(135deg,#fffde7,#fff8e1);border:1px solid #ffe082}[data-theme=dark] .home-plan-badge--basic{color:#81c784;background:#1b5e2022}[data-theme=dark] .home-plan-badge--pro{color:#64b5f6;background:#0d47a122}[data-theme=dark] .home-plan-badge--premium{color:#ffd54f;background:#f57f1722;border-color:#f57f1744}.home-plan-cta{border-radius:8px;margin-top:4px;padding:7px 16px;font-size:.82rem}.home-plan-right{background-image:url(/images/grow-up.png);background-position:50%;background-size:cover;border-radius:16px;align-items:flex-start;min-height:400px;padding:32px;display:flex}@media (width<=768px){.home-plan-right{min-height:220px}}.home-plan-right-text{color:#fff;text-shadow:0 2px 16px #00000073;letter-spacing:-.02em;margin:0 0 0 75px;font-size:2.4rem;font-weight:900;line-height:1.1}@media (width<=768px){.home-plan-right-text{margin-left:0}}.home-social-row{grid-template-columns:minmax(0,2fr) minmax(0,1fr) minmax(0,1fr);gap:20px;margin-bottom:40px;display:grid}@media (width<=1024px){.home-social-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}@media (width<=768px){.home-social-row{grid-template-columns:minmax(0,1fr)}}.home-forum-card{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;min-width:0;padding:24px;overflow:hidden}@media (width>=769px) and (width<=1024px){.home-forum-card{grid-column:1/-1}}.home-thread-list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.home-thread-item{cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;transition:background .12s;display:flex}.home-thread-item:hover{background:var(--bg-2)}.home-thread-avatar{background:var(--bg-3);width:34px;height:34px;color:var(--text-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:flex;overflow:hidden}.home-thread-avatar img{object-fit:cover;width:100%;height:100%}.home-thread-body{flex:1;min-width:0}.home-thread-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;overflow:hidden}.home-thread-meta{color:var(--text-2);align-items:center;gap:4px;margin-top:2px;font-size:.75rem;display:flex}.home-thread-arrow{color:var(--text-3);flex-shrink:0}.home-thread-skel{align-items:center;gap:12px;padding:10px 0;display:flex}.home-fact-card{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:8px;min-width:0;padding:24px;display:flex;overflow:hidden}.home-fact-header{justify-content:space-between;align-items:center;display:flex}.home-fact-label{text-transform:uppercase;letter-spacing:.07em;color:var(--accent);margin:0;font-size:.75rem;font-weight:700}.home-fact-refresh{cursor:pointer;color:var(--accent);opacity:.6;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:opacity .15s,transform .3s;display:flex}.home-fact-refresh:hover{opacity:1}.home-fact-refresh:active{transform:rotate(180deg)}.home-fact-text{color:var(--text-2);margin:0;font-size:.88rem;font-style:italic;line-height:1.6}.home-fact-text:before{content:"\"";vertical-align:-.55rem;color:var(--accent);opacity:.5;margin-right:4px;font-family:Georgia,serif;font-size:2rem;font-style:normal;line-height:0}.home-fact-text:after{content:"\"";vertical-align:-.55rem;color:var(--accent);opacity:.5;margin-left:4px;font-family:Georgia,serif;font-size:2rem;font-style:normal;line-height:0}.home-news-card{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;min-width:0;padding:24px;overflow:hidden}.home-news-title{color:var(--text);margin:0 0 12px;font-size:.95rem;font-weight:700}.home-news-list{flex-direction:column;gap:14px;margin:0;padding:0;list-style:none;display:flex}.home-news-item{flex-direction:column;gap:2px;display:flex}.home-news-item-title{color:var(--text);font-size:.85rem;font-weight:600}.home-news-item-content{color:var(--text-2);margin:2px 0 0;font-size:.8rem;line-height:1.5}.home-news-item-date{color:var(--text-3);font-size:.72rem}.home-news-empty{color:var(--text-3);margin:12px 0 0;font-size:.85rem}.chess-fact{background:var(--bg-1);border-radius:12px;align-items:center;gap:12px;margin:0 0 40px;padding:28px 40px 28px 52px;display:flex;position:relative}.chess-fact-mark{color:var(--accent);opacity:.25;-webkit-user-select:none;user-select:none;flex-shrink:0;margin-top:-8px;font-family:Georgia,serif;font-size:5rem;line-height:1}.chess-fact-mark--close{align-self:flex-end;margin-top:0;margin-bottom:-8px}.chess-fact-text{color:var(--text-1);flex:1;margin:0;font-size:1rem;font-style:italic;line-height:1.65}@media (width<=600px){.chess-fact{padding:20px 20px 20px 24px}.chess-fact-mark{font-size:3.5rem}}.announcement-list{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.announcement-bar{border-left:4px solid #0000;align-items:flex-start;gap:10px;padding:12px 16px;font-size:.875rem;line-height:1.5;display:flex}.announcement-icon{flex-shrink:0;margin-top:1px}.announcement-body{flex-direction:column;gap:2px;display:flex}.announcement-title{font-weight:600}.announcement-content{opacity:.9}.announcement-bar--danger{border-color:#ef4444}.announcement-bar--warning{border-color:#f59e0b}.announcement-bar--info{border-color:#3b82f6}.announcement-bar--success{border-color:#22c55e}.announcement-bar--base{border-color:var(--border)}.ad-banner{background:var(--bg-1);border:1px dashed var(--border);border-radius:8px;justify-content:center;align-items:center;width:100%;min-height:90px;margin-bottom:1.5rem;display:flex;position:relative;overflow:hidden}.ad-banner__label{color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;font-size:.65rem;position:absolute;top:4px;left:8px}.ad-banner__slot{width:100%;height:90px}.training-page{flex-direction:column;height:100vh;padding-left:240px;display:flex;overflow:hidden}@media (width<=768px){.training-page{height:auto}.board-wrapper{width:98vw!important}}.training-body{flex:1;min-height:0;display:flex;overflow:hidden}.training-board-panel{justify-content:flex-start;padding-top:24px;padding-bottom:24px;position:relative}.training-board-wrapper{aspect-ratio:1;flex-shrink:0;width:min(100%,100vh - 48px)}@keyframes board-icon-pop{0%{opacity:0;transform:translate(-50%,-50%)scale(.4)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.board-move-icon{border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;animation:.18s ease-out forwards board-icon-pop;display:flex}.board-move-icon--wrong{color:#fff;background:#dc2626e6;box-shadow:0 1px 6px #0006}.board-move-icon--correct{color:#fff;background:#22c55ee6;box-shadow:0 1px 6px #0006}.board-overlay-bar{z-index:10;flex-direction:column;align-items:center;gap:5px;display:flex;position:absolute;top:10px;right:10px}.board-nav-bar{z-index:10;align-items:center;gap:5px;display:flex;position:absolute;bottom:10px;right:10px}.board-overlay-timer{font-variant-numeric:tabular-nums;color:var(--text-2);background:var(--bg-3);border:1px solid var(--border);pointer-events:none;border-radius:8px;align-items:center;gap:5px;margin-right:2px;padding:5px 10px;font-size:14px;font-weight:700;display:flex}.board-overlay-btn{background:var(--bg-3);border:1px solid var(--border);width:32px;height:32px;color:var(--text-2);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.board-overlay-btn:hover{background:var(--bg-2);color:var(--text)}.chapter-mobile-btn{display:none}@media (width<=768px){.chapter-mobile-btn{display:flex}}.bsm-overlay{z-index:300;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.bsm-panel{background:var(--bg);border:1px solid var(--border);border-radius:14px;flex-direction:column;width:480px;max-width:calc(100vw - 32px);max-height:85vh;display:flex;overflow:hidden;box-shadow:0 8px 40px #00000059}.bsm-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.bsm-title{font-size:16px;font-weight:700}.bsm-close{cursor:pointer;color:var(--text-3);background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;display:flex}.bsm-close:hover{color:var(--text);background:var(--bg-3)}.bsm-body{flex-direction:column;gap:12px;padding:20px;display:flex;overflow-y:auto}.bsm-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-top:4px;margin-bottom:8px;font-size:11px;font-weight:700}.training-status-bar{justify-content:space-between;align-items:center;gap:12px;width:min(48vw,76vh);max-width:560px;display:flex}@keyframes rdiff-pop{0%{opacity:0;transform:translateY(4px)scale(.85)}60%{transform:translateY(-1px)scale(1.08)}to{opacity:1;transform:translateY(0)scale(1)}}.training-rating-value-row{align-items:baseline;gap:8px;display:flex}.training-rdiff-anim{font-size:16px;font-weight:700;animation:.3s ease-out forwards rdiff-pop}.training-rdiff-anim.up{color:var(--green)}.training-rdiff-anim.down{color:var(--red)}.training-bar-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.training-lichess-link{color:var(--text-3);font-size:11px;text-decoration:none;transition:color .15s}.training-lichess-link:hover{color:var(--accent)}.training-skip-btn,.training-next-btn{white-space:nowrap;font-size:13px}.training-nav{flex-shrink:0;gap:3px;display:flex}.training-nav-btn{border:1px solid var(--border-2);background:var(--bg-3);width:34px;height:34px;color:var(--text-2);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;font-family:inherit;transition:all .15s;display:flex}.training-nav-btn:hover:not(:disabled){background:var(--bg-4);border-color:var(--accent);color:var(--text)}.training-nav-btn:disabled{opacity:.3;cursor:default}.training-hint-btn,.training-solve-btn{cursor:pointer;white-space:nowrap;border-radius:6px;flex-shrink:0;align-items:center;gap:5px;height:34px;padding:0 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;display:flex}.training-hint-btn{background:var(--yellow-dim);border:1px solid var(--yellow);color:var(--yellow)}.training-hint-btn:hover{background:#eab30840}.training-solve-btn{background:var(--orange-dim);border:1px solid var(--orange);color:var(--orange)}.training-solve-btn:hover{background:#f9731640}.training-info{border-left:1px solid var(--border);background:var(--bg-2);flex-direction:column;flex-shrink:0;width:340px;display:flex;overflow:hidden}.training-panel-header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;padding:10px 12px;display:flex}.training-panel-back{border:1px solid var(--border);width:32px;height:32px;color:var(--text-2);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:border-color .15s,color .15s;display:flex}.training-panel-back:hover{border-color:var(--text-2);color:var(--text)}.training-panel-body{flex:1;min-height:0;overflow:hidden auto}.training-panel-footer{border-top:1px solid var(--border);flex-shrink:0}.training-footer-top{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 12px;display:flex}.training-footer-top .btn-secondary{border-radius:6px;height:30px;padding:0 10px;font-size:12px}.training-footer-score{flex:1;min-width:0}.training-footer-score-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px;font-size:10px}.training-footer-score-value{flex-wrap:wrap;align-items:baseline;gap:6px;display:flex}.training-footer-timer{font-variant-numeric:tabular-nums;color:var(--text-2);flex-shrink:0;align-items:center;gap:5px;font-size:14px;font-weight:700;display:flex}.training-footer-bottom{flex-direction:column;gap:8px;padding:10px 12px;display:flex}.training-footer-btns{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.training-footer-btns .btn-primary,.training-footer-btns .btn-secondary,.training-footer-btns .btn-ghost{border-radius:6px;align-items:center;gap:5px;height:34px;padding:0 12px;font-size:13px;display:flex}.training-footer-btns--grid{grid-template-columns:1fr 1fr;display:grid}.training-footer-btns--grid>*{justify-content:center;width:100%;height:34px}.btn-outline-danger{color:var(--error,#dc2626);border:1px solid var(--error,#dc2626);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;align-items:center;gap:5px;height:34px;padding:0 12px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s;display:flex}.btn-outline-danger:hover{background:#dc26261a}.training-footer-nav{gap:4px;display:flex}.training-rating-card{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;padding:16px 18px;display:flex}.training-rating-icon{background:var(--accent-dim);border:1.5px solid var(--accent);width:36px;height:36px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.training-rating-body{flex-direction:column;flex:1;display:flex}.training-rating-label{color:var(--text-3);font-size:11px}.training-rating-value{color:var(--text);font-size:22px;font-weight:700;line-height:1.2}.training-rd-badge{color:var(--text-3);background:var(--bg-4);border:1px solid var(--border-2);cursor:default;border-radius:6px;padding:3px 7px;font-size:11px}.training-puzzle-meta{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:6px;padding:10px 18px;display:flex}.training-puzzle-rating{color:var(--yellow);align-items:center;gap:4px;font-size:12px;font-weight:600;display:flex}.training-tag{background:var(--bg-4);border:1px solid var(--border-2);color:var(--text-3);border-radius:10px;padding:2px 7px;font-size:10px}.training-section-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;align-items:center;gap:6px;margin-bottom:10px;font-size:11px;font-weight:500;display:flex}.training-session{border-bottom:1px solid var(--border);padding:14px 18px}.training-dots{flex-wrap:wrap;gap:5px;display:flex}.training-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.training-dot.ok{background:var(--green)}.training-dot.fail{background:var(--red)}.training-dot.pending{background:#9ca3af}.training-themes{flex-direction:column;flex:1;display:flex;overflow-y:auto}.theme-accordion{flex-direction:column;display:flex}.theme-accordion-header{border:none;border-bottom:1px solid var(--border);cursor:pointer;width:100%;color:var(--text-2);text-align:left;-webkit-user-select:none;user-select:none;background:0 0;align-items:center;gap:8px;padding:10px 18px;font-family:inherit;font-size:13px;font-weight:600;transition:background .12s,color .12s;display:flex}.theme-accordion-header:hover,.theme-accordion-header.open{background:var(--bg-3);color:var(--text)}.theme-accordion-header.has-selected{color:var(--accent)}.theme-accordion-label{flex:1}.theme-accordion-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}.theme-accordion-chevron{color:var(--text-3);flex-shrink:0;transition:transform .2s}.theme-accordion-chevron.rotated{transform:rotate(180deg)}.theme-accordion-items{background:var(--bg);border-bottom:1px solid var(--border);flex-direction:column;max-height:214px;display:flex;overflow-y:auto}.theme-accordion-item{border:none;border-bottom:1px solid var(--border);cursor:pointer;color:var(--text-2);text-align:left;-webkit-user-select:none;user-select:none;background:0 0;padding:8px 18px 8px 28px;font-family:inherit;font-size:12px;transition:background .1s,color .1s}.theme-accordion-item:last-child{border-bottom:none}.theme-accordion-item:hover{background:var(--bg-3);color:var(--text)}.theme-accordion-item.active{color:var(--accent);background:var(--accent-dim);font-weight:600}.menu-sidebar-sub .theme-accordion{margin:0 -14px}@media (width<=900px){.training-page{height:auto;padding-left:0!important;overflow:visible!important}.training-body{flex-direction:column}.training-board-panel{padding:16px}.training-board-wrapper{width:min(90vw,60vh)!important}.training-status-bar{width:min(90vw,60vh);max-width:420px}.training-info{border-left:none;border-top:1px solid var(--border);width:100%;overflow:visible}.training-panel-body{flex:none;order:1;overflow-y:visible}.board-overlay-bar{justify-content:flex-end;width:100%;padding:4px 0;flex-direction:row!important;position:static!important}}.menu-sidebar-btn{border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:14px;padding:18px;transition:background .12s;display:flex}.menu-sidebar-btn:hover{background:var(--bg-3)}.menu-sidebar-btn-icon{background:var(--accent-dim);border:1.5px solid var(--accent);width:44px;height:44px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.menu-sidebar-btn-text{flex:1;min-width:0}.menu-sidebar-btn-title{color:var(--text);font-size:15px;font-weight:700}.menu-sidebar-btn-desc{color:var(--text-3);margin-top:2px;font-size:12px}.menu-sidebar-btn-rating{color:var(--accent);font-weight:700}.menu-sidebar-btn--hard:hover{background:#ea580c0f}.menu-sidebar-btn-icon--hard{color:#ea580c;background:#ea580c1f;border-color:#ea580c}.menu-sidebar-btn--daily{border-color:#14b8a64d}.menu-sidebar-btn--daily:hover{background:#14b8a60f}.menu-sidebar-btn-icon--daily{color:#14b8a6;background:#14b8a61f;border-color:#14b8a6}.menu-sidebar-btn--retry{border-color:#6366f14d}.menu-sidebar-btn--retry:hover{background:#6366f10f}.menu-sidebar-btn-icon--retry{color:#6366f1;background:#6366f11f;border-color:#6366f1}.menu-retry-badge{color:#fff;vertical-align:middle;background:#6366f1;border-radius:10px;justify-content:center;align-items:center;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:700;line-height:1.4;display:inline-flex}.retry-counter-card{color:#6366f1;background:#6366f114;border:1px solid #6366f133;border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:12px;display:flex}.retry-complete-card{color:#16a34a;text-align:center;background:#22c55e14;border:1px solid #22c55e40;border-radius:10px;flex-direction:column;align-items:center;gap:8px;padding:20px 16px;display:flex}.retry-complete-title{font-size:14px;font-weight:600}.retry-complete-desc{color:var(--text-3);font-size:12px}.menu-hard-rush-note{color:var(--text-3);margin:0;padding:0 2px 4px;font-size:12px;font-style:italic}.menu-sidebar-sub{flex-direction:column;gap:12px;padding:14px;display:flex}.puzzle-menu-back{align-self:flex-start;font-size:13px}.menu-sidebar-themes-grid{justify-content:flex-start}.menu-rush-time-options{flex-direction:column;gap:8px;display:flex}.menu-rush-time-btn{background:var(--bg-3);border:1.5px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-2);border-radius:12px;align-items:center;gap:14px;padding:14px 16px;transition:border-color .15s,box-shadow .15s;display:flex}.menu-rush-time-btn:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);color:var(--text)}.rush-time-label{color:var(--text);font-size:15px;font-weight:700}.rush-time-record{color:var(--text-3);font-size:12px}.training-menu-back{justify-content:center;width:calc(100% - 36px);margin:auto 18px 14px;font-size:12px}.puzzle-comment-btn{background:var(--bg-3);border:1px solid var(--border);height:34px;color:var(--text-2);cursor:pointer;white-space:nowrap;border-radius:6px;flex-shrink:0;align-items:center;gap:5px;padding:0 10px;font-family:inherit;font-size:12px;transition:background .15s,color .15s;display:flex}.puzzle-comment-btn:hover{background:var(--surface-hover);color:var(--text)}.puzzle-comment-count{background:var(--accent);color:#fff;text-align:center;border-radius:99px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:600}.rush-info-panel{border-left:1px solid var(--border);background:var(--bg-2);flex-direction:column;flex-shrink:0;width:340px;display:flex;overflow:hidden}.rush-timer-card{background:var(--bg-3);border:1px solid var(--border);color:var(--text-3);text-align:center;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:16px 12px 12px;display:flex}.rush-timer-label{text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:700}.rush-timer-value{font-variant-numeric:tabular-nums;color:var(--text);font-size:72px;font-weight:800;line-height:1}.rush-score-card{background:var(--bg-3);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;margin-top:8px;padding:14px 16px;display:flex}.rush-score-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-size:12px}.rush-score-value{color:var(--accent);font-size:30px;font-weight:800}.rush-lives-card{background:var(--bg-3);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;margin-top:8px;padding:12px 16px;display:flex}.rush-lives-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-size:12px}.rush-hearts{gap:6px;font-size:20px;display:flex}.rush-heart.active{color:var(--red)}.rush-heart.lost{color:var(--border-2)}.rush-puzzle-info{color:var(--text-3);text-align:center;margin-top:4px;padding:6px 4px;font-size:12px}.rush-sidebar-records{background:var(--bg-3);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:6px;margin-top:8px;padding:12px 16px;display:flex}.rush-rec-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:2px;font-size:11px}.rush-rec-row{color:var(--text-2);justify-content:space-between;font-size:13px;display:flex}.rush-rec-row.current{color:var(--accent);font-weight:600}.rush-rec-val{color:var(--text);font-weight:700}.rush-back-btn{justify-content:center;margin-top:auto;font-size:13px}.rush-ended{flex:1;justify-content:center;align-items:center;padding:40px 24px;display:flex}.rush-ended-card{background:var(--bg-2);border:1.5px solid var(--border);text-align:center;border-radius:20px;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:400px;padding:48px 40px 40px;display:flex}.rush-ended-trophy{color:var(--accent)}.rush-ended-title{color:var(--text);margin:0;font-size:22px;font-weight:700}.rush-ended-score{flex-direction:column;align-items:center;gap:2px;display:flex}.rush-ended-num{color:var(--accent);font-size:52px;font-weight:800;line-height:1}.rush-ended-label{color:var(--text-3);font-size:14px}.rush-new-record{color:var(--green);background:var(--green-dim);border:1px solid var(--green);border-radius:8px;padding:6px 16px;font-size:16px;font-weight:700}.rush-records-list{background:var(--bg-3);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:6px;width:100%;padding:12px 16px;display:flex}.rush-ended-actions{gap:12px;margin-top:4px;display:flex}@media (width<=768px){.rush-info-panel{border-left:none;border-top:1px solid var(--border);width:100%}.rush-timer-value{font-size:40px}.rush-sidebar-records{display:none}}.daily-sidebar-header{color:#14b8a6;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:8px;padding:14px 16px;font-size:13px;font-weight:700;display:flex}.daily-complete-card{text-align:center;background:var(--bg-3);border:1px solid var(--border);border-radius:12px;flex-direction:column;align-items:center;gap:8px;margin:8px 0;padding:24px 16px;display:flex}.daily-trophy-icon{color:var(--accent)}.daily-complete-title{color:var(--text);font-size:15px;font-weight:700}.daily-complete-sub{color:var(--text-3);font-size:12px}.training-daily-done{color:#14b8a6;white-space:nowrap;background:#14b8a61a;border:1px solid #14b8a64d;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:700}.analysis-import-drop{position:relative}.analysis-import-menu{background:var(--bg-3);border:1px solid var(--border);z-index:200;border-radius:8px;min-width:130px;position:absolute;top:calc(100% + 4px);left:0;overflow:hidden;box-shadow:0 6px 18px #0006}.analysis-import-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;align-items:center;gap:7px;padding:9px 14px;font-size:13px;transition:background .12s;display:flex}.analysis-import-item:hover{background:var(--bg-4)}.analysis-fen-bar{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:8px 16px;display:flex}.analysis-movelist{flex-direction:column;height:100%;padding:6px 8px;display:flex;overflow-y:auto}.amove-row{align-items:center;gap:0;padding:1px 0;display:flex}.amove-num{color:var(--text-muted);flex-shrink:0;min-width:28px;padding-left:4px;font-size:12px}.amove-ellipsis{min-width:64px;color:var(--text-muted);padding:2px 8px;font-size:13px;display:inline-block}.amove-token{cursor:pointer;color:var(--text);text-align:left;background:0 0;border:none;border-radius:4px;min-width:64px;padding:3px 8px;font-size:13px;transition:background .12s}.amove-token:hover{background:var(--hover)}.amove-token.active{background:var(--accent);color:#fff;font-weight:500}.analysis-game-list{flex-direction:column;gap:6px;max-height:360px;margin:12px 0;display:flex;overflow-y:auto}.analysis-game-item{background:var(--surface);border:1px solid var(--border);border-radius:6px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.analysis-game-info{flex-direction:column;gap:3px;min-width:0;display:flex}.analysis-game-title{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.analysis-game-meta{color:var(--text-muted);align-items:center;gap:4px;font-size:12px;display:flex}.analysis-game-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.analysis-pgn-header-grid{grid-template-columns:1fr 1fr;gap:0 12px;display:grid}.analysis-game-result{color:var(--accent);margin-left:8px;font-size:12px;font-weight:600}.analysis-comment-editor{border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:6px;padding:10px 10px 8px;display:flex}.analysis-comment-editor textarea{resize:vertical;border:1px solid var(--border);background:var(--surface);min-height:56px;color:var(--text);box-sizing:border-box;border-radius:5px;width:100%;padding:6px 8px;font-size:13px}.analysis-comment-actions{justify-content:flex-end;align-items:center;gap:6px;display:flex}.master-games-body{flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.master-games-sidebar{border-right:1px solid var(--border);background:var(--bg-2);flex-direction:column;flex-shrink:0;width:380px;transition:transform .22s;display:flex;overflow:hidden}.master-games-sidebar--hidden{z-index:20;pointer-events:none;width:380px;position:absolute;top:0;bottom:0;left:0;transform:translate(-100%)}.master-games-sidebar--overlay{z-index:20;pointer-events:auto;width:380px;position:absolute;top:0;bottom:0;left:0;transform:translate(0);box-shadow:4px 0 28px #00000047}.master-sidebar-tab{background:var(--bg-2);border:1px solid var(--border);cursor:pointer;z-index:10;width:22px;height:56px;color:var(--text-2);border-left:none;border-top-right-radius:6px;border-bottom-right-radius:6px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:absolute;top:14px;left:0}.master-sidebar-tab:hover{background:var(--bg-3);color:var(--text)}.master-sidebar-overlay-backdrop{z-index:19;background:#00000059;position:absolute;inset:0}.master-games-filters{border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:8px;padding:10px;display:flex}.master-search-wrap{align-items:center;display:flex;position:relative}.master-search-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:9px}.master-search-input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:6px;padding:7px 28px 7px 30px;font-size:13px}.master-search-input:focus{border-color:var(--accent);outline:none}.master-vs-sep{color:var(--text-3);pointer-events:none;font-size:11px;font-weight:700;line-height:1;position:absolute;left:9px}.master-search-clear{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:2px;display:flex;position:absolute;right:7px}.master-suggestions{background:var(--bg-4);border:1px solid var(--border);z-index:50;border-radius:6px;max-height:200px;margin-top:3px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 16px #0000004d}.master-suggestion-item{text-align:left;cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;padding:8px 12px;font-size:13px;display:block}.master-suggestion-item:hover{background:var(--hover)}.master-filter-row{gap:6px;display:flex}.master-filter-input{border:1px solid var(--border);background:var(--surface);color:var(--text);text-transform:uppercase;border-radius:5px;flex:1;padding:6px 8px;font-size:12px}.master-filter-input:focus{border-color:var(--accent);outline:none}.master-filter-select{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:5px;flex:1;padding:6px;font-size:12px}.master-games-list{flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.master-game-info{border-top:1px solid var(--border);flex-shrink:0;padding:10px 12px}.master-sidebar-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:5px;padding:7px 10px;display:flex}.master-game-row{border-bottom:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-top:none;border-left:none;border-right:none;flex-direction:column;gap:3px;padding:9px 12px;transition:background .1s;display:flex}.master-game-row:hover{background:var(--hover)}.master-game-row.active{background:color-mix(in srgb, var(--accent) 12%, transparent);border-left:2px solid var(--accent);padding-left:10px}.master-game-players{color:var(--text);flex-wrap:wrap;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.master-game-result{color:var(--accent);background:color-mix(in srgb, var(--accent) 15%, transparent);border-radius:3px;padding:1px 5px;font-size:11px;font-weight:700}.master-game-meta{color:var(--text-muted);flex-wrap:wrap;gap:6px;font-size:11px;display:flex}.master-eco{color:var(--text-2);font-weight:600}.master-pagination{border-top:1px solid var(--border);color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;gap:10px;padding:8px;font-size:13px;display:flex}.master-loading,.master-empty{text-align:center;color:var(--text-muted);padding:24px;font-size:13px}.master-viewer{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.master-viewer-header{border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:3px;padding:10px 16px;display:flex}.master-viewer-title{font-size:14px;font-weight:500}.master-viewer-meta{color:var(--text-muted);flex-wrap:wrap;gap:10px;font-size:12px;display:flex}.master-viewer-body{flex:1;min-height:0;display:flex;overflow:hidden}.master-right-panel{border-left:1px solid var(--border);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.master-moves-panel{background:var(--bg-2);flex:1;min-height:0;overflow-y:auto}.master-empty-viewer{color:var(--text-muted);flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.guess-setup{flex:1;justify-content:center;align-items:center;padding:32px;display:flex;overflow:auto}.guess-setup-card{flex-direction:column;gap:28px;width:100%;max-width:460px;display:flex}.guess-setup-game-title{color:var(--text-1);font-size:1rem;font-weight:600;line-height:1.5}.guess-setup-eco{color:var(--text-2);margin-top:4px;font-size:.8rem}.guess-play-as-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:10px;font-size:.72rem;font-weight:700}.guess-player-btns{gap:12px;display:flex}.guess-player-btn{cursor:pointer;border:2px solid #0000;border-radius:10px;flex-direction:column;flex:1;gap:4px;padding:14px 16px;font-family:inherit;transition:border-color .15s,box-shadow .15s,transform .1s;display:flex}.guess-player-btn:hover{transform:translateY(-1px)}.guess-player-btn--white{color:#111;background:#f2f2f2}.guess-player-btn--black{color:#f0f0f0;background:#1e1e1e}.guess-player-btn.selected{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent)}.guess-player-color-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px;display:inline-block}.guess-player-name{font-size:.88rem;font-weight:600;line-height:1.3}.guess-player-elo{opacity:.6;font-size:.75rem}.guess-mode-btns{flex-direction:column;gap:10px;display:flex}.guess-mode-btn{border:1.5px solid var(--border);background:var(--bg-2);width:100%;color:var(--text-1);cursor:pointer;text-align:left;border-radius:8px;padding:13px 18px;font-family:inherit;font-size:.9rem;transition:background .15s,border-color .15s}.guess-mode-btn:hover:not(:disabled){background:var(--bg-3);border-color:var(--accent)}.guess-mode-btn:disabled{opacity:.38;cursor:not-allowed}.guess-status-bar{color:var(--text-3);border:1px solid var(--border);border-radius:6px;align-items:center;gap:6px;min-height:34px;margin-top:8px;padding:7px 12px;font-size:.8rem;transition:color .2s,border-color .2s;display:flex}.guess-status-bar.your-turn{color:var(--accent);border-color:var(--accent);font-weight:600}.board-btn-row{justify-content:space-between;align-items:center;gap:5px;display:flex}.board-btn-group{align-items:center;gap:5px;display:flex}.guess-hint-btn{gap:5px;padding:0 10px;font-family:inherit;font-size:.78rem;width:auto!important}.guess-hint-btn span{font-size:.78rem}.guess-result-overlay{z-index:50;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0000009e;justify-content:center;align-items:center;animation:.25s fadeIn;display:flex;position:absolute;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.guess-result-card{background:var(--bg-2);border:1px solid var(--border);text-align:center;border-radius:18px;flex-direction:column;align-items:center;gap:14px;width:90%;max-width:320px;padding:36px 44px;animation:.28s slideUp;display:flex;box-shadow:0 24px 64px #00000073}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}.guess-result-emoji{font-size:3rem;line-height:1}.guess-result-title{color:var(--text-1);font-size:1.15rem;font-weight:700}.guess-result-score{color:var(--accent);letter-spacing:.04em;font-size:1.8rem;font-weight:800}.guess-result-label{color:var(--text-2);font-size:.88rem}.guess-result-card .btn-primary{width:100%;margin-top:8px}.guess-result-close{cursor:pointer;color:var(--text-3);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex;position:absolute;top:12px;right:12px}.guess-result-close:hover{color:var(--text-1);background:var(--bg-3)}.guess-result-card{position:relative}.guess-status-bar--result{color:var(--text-2);border-color:var(--border);gap:8px}.master-sidebar-mobile-header{display:none}.master-sidebar-close-btn{border:1px solid var(--border);background:var(--bg-4);width:32px;height:32px;color:var(--text-2);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.master-sidebar-close-btn:hover{background:var(--bg-3);color:var(--text)}.master-sidebar-open-btn,.master-sidebar-backdrop{display:none}@media (width<=768px){.master-games-sidebar{z-index:50;width:100%;max-width:none;box-shadow:none;transition:transform .26s;position:absolute;inset:0;transform:translate(-100%)}.master-games-sidebar.mobile-open{transform:translate(0)}.master-sidebar-backdrop{z-index:49;background:#00000073;display:block;position:absolute;inset:0}.master-sidebar-mobile-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:flex-end;align-items:center;padding:8px 12px;display:flex}.master-sidebar-open-btn{border:1px solid var(--border);background:var(--bg-3);width:30px;height:30px;color:var(--text-2);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.master-sidebar-open-btn:hover{background:var(--bg-4);color:var(--text)}.master-viewer-header{flex-direction:row;align-items:flex-start;gap:8px}.master-viewer-body{flex-direction:column;overflow-y:auto}.master-right-panel{border-left:none;border-top:1px solid var(--border);flex-shrink:0;min-height:0;max-height:400px}.master-sidebar-footer{flex-shrink:0;order:-1}.board-panel{align-items:center;padding:10px!important}.master-empty-viewer{text-align:center;padding:24px 16px}.guess-setup{padding:16px 12px}.guess-setup-card{gap:20px}}.ot-diff-legend{color:var(--text-3);margin:8px 0 4px;font-size:12px}.ot-opening-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:4px;display:grid}.ot-opening-card{background:var(--bg-2);border:2px solid var(--border);text-align:left;cursor:pointer;border-radius:12px;flex-direction:column;gap:6px;padding:14px 16px;transition:border-color .15s,background .15s;display:flex}.ot-opening-card:hover{border-color:var(--accent);background:var(--bg-3)}.ot-opening-card.selected{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, var(--bg-2))}.ot-opening-card-header{align-items:center;gap:6px;display:flex}.ot-opening-eco{color:var(--text-3);background:var(--bg-4);border-radius:4px;padding:1px 5px;font-size:11px;font-weight:700}.ot-opening-color{margin-left:auto;font-size:14px}.ot-opening-diff{color:var(--accent);letter-spacing:1px;font-size:11px}.ot-opening-name{color:var(--text);font-size:14px;font-weight:600}.ot-opening-desc{color:var(--text-3);font-size:12px;line-height:1.4}.ot-selected-view{flex-direction:column;gap:16px;max-width:640px;display:flex}.ot-selected-card{background:var(--bg-2);border:2px solid var(--accent);border-radius:14px;flex-direction:column;gap:6px;padding:18px 22px;display:flex}.ot-change-btn{align-self:flex-start;margin-top:8px;font-size:13px}.ot-config-panel{background:var(--bg-2);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:14px;margin-top:0;padding:20px 24px;display:flex}.ot-config-panel h3{margin:0;font-size:17px}.ot-config-row{flex-wrap:wrap;gap:24px;display:flex}.ot-config-group{flex-direction:column;gap:6px;display:flex}.ot-config-group label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.ot-config-hint{color:var(--text-3);margin:0;font-size:13px}.ot-deviation-banner{background:color-mix(in srgb, var(--warning,#f59e0b) 15%, var(--bg-2));border:1px solid var(--warning,#f59e0b);width:100%;color:var(--text);border-radius:8px;align-items:center;gap:8px;margin-bottom:6px;padding:8px 12px;font-size:13px;display:flex}.ot-deviation-banner svg{color:var(--warning,#f59e0b);flex-shrink:0}.ot-deviation-banner span{flex:1}.ot-eval-warning-banner{background:color-mix(in srgb, var(--red,#ef4444) 15%, var(--bg-2));border-color:var(--red,#ef4444)}.ot-eval-warning-banner svg{color:var(--red,#ef4444)}.ot-dev-btn{border:1px solid var(--border);background:var(--bg-3);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:6px;padding:3px 10px;font-size:12px;transition:background .12s}.ot-dev-btn:hover{background:var(--bg-4)}.ot-dev-close{color:var(--text-3);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:16px;line-height:1}.ot-board-column{flex-direction:column;display:flex}.ot-board-row{align-items:stretch;gap:6px;display:flex}.ot-eval-bar{background:var(--bg-4);border-radius:4px;flex-direction:column;flex-shrink:0;align-self:stretch;width:14px;display:flex;position:relative;overflow:hidden}.ot-eval-bar-black{background:#1a1a1a;flex-shrink:0;transition:height .4s}.ot-eval-bar-white{background:#f0ede8;flex-shrink:0;transition:height .4s}.ot-eval-label{color:var(--text-3);white-space:nowrap;writing-mode:vertical-rl;text-orientation:mixed;pointer-events:none;font-size:9px;font-weight:700;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.ot-phase-badge{background:var(--bg-3);border:1px solid var(--border);color:var(--text-2);border-radius:6px;padding:3px 8px;font-size:12px}.ot-move-counter{color:var(--text-3);font-variant-numeric:tabular-nums;font-size:12px}.promo-overlay{z-index:20;background:#00000073;border-radius:4px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.promo-picker{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;gap:8px;padding:12px 16px;display:flex;box-shadow:0 8px 32px #0006}.promo-piece{border:1px solid var(--border);background:var(--bg-3);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:56px;height:56px;font-size:36px;line-height:1;transition:background .15s,transform .1s;display:flex}.promo-piece:hover{background:var(--accent);transform:scale(1.1)}.ot-thinking-bar{background:linear-gradient(90deg, transparent 0%, var(--accent) 40%, transparent 100%);pointer-events:none;background-size:60% 100%;border-radius:0 0 2px 2px;height:3px;animation:1.4s ease-in-out infinite ot-slide;position:absolute;bottom:0;left:0;right:0}@keyframes ot-slide{0%{background-position:-60% 0}to{background-position:160% 0}}.ot-thinking-label{color:var(--text-3);align-items:center;gap:5px;font-size:12px;font-style:italic;display:flex}.ot-thinking-pulse{background:var(--accent);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:1.2s ease-in-out infinite ot-pulse}@keyframes ot-pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.ot-controls-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;width:100%;margin-top:6px;display:flex}.ot-controls-left{align-items:center;gap:5px;display:flex}.ot-controls-right{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.ot-info-header{border-bottom:1px solid var(--border);padding:12px 14px}.ot-info-opening-name{font-size:14px;font-weight:700;line-height:1.3}.ot-info-eco{color:var(--text-3);margin-top:2px;font-size:12px}.ot-move-list{flex-direction:column;flex:1;gap:2px;min-height:0;padding-right:4px;font-size:13px;display:flex;overflow-y:auto}.ot-move-row{align-items:center;gap:4px;display:flex}.ot-move-num{color:var(--text-3);font-variant-numeric:tabular-nums;min-width:22px}.ot-move-san{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-family:inherit;font-size:13px}.ot-move-san:hover{background:var(--bg-3)}.ot-move-san.active{background:var(--accent);color:#fff}.ot-end-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.ot-end-card{background:var(--bg-2);border:1px solid var(--border);text-align:center;border-radius:20px;flex-direction:column;align-items:center;gap:18px;min-width:320px;max-width:420px;padding:40px 48px;display:flex;position:relative}.ot-end-close{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:20px;line-height:1;transition:color .12s,background .12s;position:absolute;top:12px;right:14px}.ot-end-close:hover{color:var(--text);background:var(--bg-3)}.ot-end-verdict{margin:0;font-size:22px}.ot-end-stats{flex-direction:column;gap:10px;width:100%;display:flex}.ot-end-stat{background:var(--bg-3);border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.ot-end-stat-label{color:var(--text-3);font-size:13px}.ot-end-stat-value{color:var(--text);font-size:15px;font-weight:700}.ot-end-stat-value small{color:var(--text-3);margin-left:4px;font-size:11px;font-weight:400}.ot-end-actions{flex-wrap:wrap;justify-content:center;gap:10px;width:100%;display:flex}@media (width<=900px){.ot-opening-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.ot-config-row{flex-direction:column;gap:12px}.ot-end-card{width:90vw;min-width:0;padding:28px 20px}}@media (width<=600px){.ot-opening-grid{grid-template-columns:1fr}}.et-category-badge{text-transform:uppercase;letter-spacing:.04em;background:var(--bg-3);color:var(--text-2);border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.et-objective-badge{border-radius:4px;padding:2px 7px;font-size:11px;font-weight:600}.et-obj-win{background:color-mix(in srgb, var(--green,#22c55e) 15%, transparent);color:var(--green,#22c55e)}.et-obj-draw{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent)}.et-config-info{flex-direction:column;gap:10px;display:flex}.et-info-row{align-items:center;gap:10px;display:flex}.et-info-label{color:var(--text-3);min-width:90px;font-size:13px}.et-tb-bar{writing-mode:vertical-rl;text-orientation:mixed;justify-content:center;align-items:center;width:36px;display:flex;transform:rotate(180deg)}.et-tb-label{letter-spacing:.03em;white-space:nowrap;font-size:11px;font-weight:700}.et-menu-intro{color:var(--text-3);margin:0 0 20px;font-size:14px;line-height:1.6}.et-theme-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.et-theme-card{background:var(--bg-2);border:2px solid var(--border);text-align:center;cursor:pointer;border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:24px 18px 20px;transition:border-color .15s,background .15s,transform .12s;display:flex}.et-theme-card:hover{border-color:var(--accent);background:var(--bg-3);transform:translateY(-2px)}.et-theme-icon{color:var(--text);margin-bottom:4px;font-size:42px;line-height:1;display:block}.et-theme-name{color:var(--text);font-size:14px;font-weight:700}.et-theme-diff{color:var(--accent);letter-spacing:2px;font-size:13px}.et-theme-desc{color:var(--text-3);margin-top:2px;font-size:12px;line-height:1.5}.et-diff-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:20px;margin-top:2px;padding:2px 7px;font-size:10px;font-weight:700;display:inline-block}.et-diff-badge.easy{color:#22c55e;background:#22c55e26}.et-diff-badge.medium{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent)}.et-diff-badge.hard{color:#ef4444;background:#ef444426}.et-loading-state{color:var(--text-3);justify-content:center;align-items:center;gap:10px;padding:60px 0;font-size:14px;display:flex}.et-loading-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@media (width<=700px){.et-theme-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=440px){.et-theme-grid{grid-template-columns:1fr}.et-theme-card{text-align:left;flex-direction:row;padding:16px}.et-theme-icon{margin-bottom:0;font-size:30px}}.stats-kpi-row{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px;display:grid}.stats-kpi-card{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:16px 14px 14px;display:flex}.stats-kpi-icon{color:var(--accent);margin-bottom:2px}.stats-kpi-value{color:var(--text);font-size:26px;font-weight:700;line-height:1}.stats-kpi-label{color:var(--text-3);text-align:center;font-size:11px}.stats-kpi-sub{color:var(--text-3);font-size:10px}.stats-section{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:18px 20px}.stats-section-title{color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;margin:0 0 14px;font-size:13px;font-weight:600}.stats-empty{color:var(--text-3);text-align:center;padding:24px 0;font-size:13px}.stats-rating-svg{width:100%;height:auto;display:block;overflow:visible}.stats-empty-chart{height:100px;color:var(--text-3);justify-content:center;align-items:center;font-size:20px;display:flex}.stats-two-col{grid-template-columns:1fr 1fr;gap:12px;margin-top:12px;display:grid}.stats-theme-list{flex-direction:column;gap:8px;display:flex}.stats-theme-row{align-items:center;gap:8px;display:flex}.stats-theme-name{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:130px;font-size:12px;overflow:hidden}.stats-theme-bar-wrap{background:var(--bg-3);border-radius:4px;flex:1;height:7px;overflow:hidden}.stats-theme-bar{border-radius:4px;height:100%;transition:width .6s}.stats-theme-pct{text-align:right;flex-shrink:0;width:34px;font-size:11px;font-weight:700}.stats-theme-count{color:var(--text-3);text-align:right;flex-shrink:0;width:28px;font-size:10px}.stats-heatmap{flex-wrap:wrap;gap:3px;display:flex}.stats-heatmap-col{flex-direction:column;gap:3px;display:flex}.stats-heatmap-cell{background:var(--bg-3);cursor:default;border-radius:2px;width:11px;height:11px}.stats-heatmap-legend{color:var(--text-3);align-items:center;gap:6px;margin-top:10px;font-size:10px;display:flex}.stats-heatmap-legend-cells{gap:3px;display:flex}.stats-opening-row{flex-wrap:wrap;align-items:center;gap:24px;display:flex}.stats-opening-total,.stats-opening-due{flex-direction:column;align-items:center;gap:2px;display:flex}.stats-opening-num{color:var(--text);font-size:28px;font-weight:700;line-height:1}.stats-opening-lbl{color:var(--text-3);font-size:11px}.stats-opening-states{flex-wrap:wrap;gap:8px;margin-left:auto;display:flex}.stats-state-pill{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.stats-state-new{background:color-mix(in srgb, var(--text-3) 15%, transparent);color:var(--text-3)}.stats-state-learning{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent)}.stats-state-review{background:color-mix(in srgb, var(--green,#22c55e) 15%, transparent);color:var(--green,#22c55e)}.stats-endgame-bar-wrap{background:var(--bg-4);border-radius:3px;width:140px;height:6px;overflow:hidden}.stats-endgame-bar{background:var(--green);border-radius:3px;height:100%;transition:width .4s}@media (width<=900px){.stats-kpi-row{grid-template-columns:repeat(3,1fr)}.stats-two-col{grid-template-columns:1fr}}@media (width<=560px){.stats-kpi-row{grid-template-columns:repeat(2,1fr)}.stats-opening-row{gap:12px}.stats-opening-states{margin-left:0}}.gr-overlay{z-index:900;background:#000000d1;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.gr-panel{background:var(--bg-2);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:100%;max-width:1260px;max-height:92vh;display:flex;overflow:hidden}.gr-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.gr-header-info{flex-wrap:wrap;align-items:baseline;gap:8px;min-width:0;display:flex}.gr-header-title{white-space:nowrap;font-size:17px;font-weight:700}.gr-header-sep{color:var(--text-3)}.gr-header-sub{color:var(--text-2);font-size:12px}.gr-close-btn{border:1px solid var(--border);width:32px;height:32px;color:var(--text-2);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:border-color .15s,color .15s;display:flex}.gr-close-btn:hover{border-color:var(--text-2);color:var(--text)}.gr-body{flex:1;grid-template-columns:1fr 1.15fr .85fr;display:grid;overflow:hidden}.gr-col{border-right:1px solid var(--border);flex-direction:column;gap:10px;padding:16px;display:flex;overflow-y:auto}.gr-col:last-child{border-right:none}.gr-col-title{color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;flex-shrink:0;font-size:11px;font-weight:600}.gr-board-row{flex-shrink:0;align-items:stretch;gap:6px;display:flex}.gr-board-wrap{flex:1;min-width:0}.gr-nav-row{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;display:flex}.gr-nav-counter{color:var(--text-3);margin-left:auto;font-size:11px}.gr-move-list{border-radius:8px;flex:1;min-height:80px;overflow-y:auto}.gr-move-row{align-items:stretch;display:flex}.gr-move-num{width:32px;color:var(--text-3);background:var(--bg-4);border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:flex-end;align-items:center;padding:0 8px;font-size:11px;display:flex}.gr-move-btn{background:var(--bg-4);border:none;border-bottom:1px solid var(--border);color:var(--text);cursor:pointer;text-align:left;border-left:1px solid var(--border);flex:1;justify-content:space-between;align-items:center;gap:4px;padding:5px 8px;font-size:13px;transition:background .12s;display:flex}.gr-move-btn:hover{background:var(--bg-3)}.gr-move-btn.active{background:var(--accent-dim);color:var(--accent)}.gr-move-btn-empty{pointer-events:none}.gr-move-san{text-align:left;flex:1}.gr-class-badge{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:8px;font-weight:800;line-height:1;display:flex}.gr-progress-wrap{background:var(--bg-3);border-radius:6px;flex-shrink:0;height:22px;position:relative;overflow:hidden}.gr-progress-bar{background:var(--accent);height:100%;transition:width .3s}.gr-progress-text{color:var(--text);justify-content:center;align-items:center;font-size:11px;display:flex;position:absolute;inset:0}.gr-chart-wrap{background:var(--bg-3);border-radius:8px;flex-shrink:0;padding:4px 0;overflow:hidden}.gr-tooltip{background:var(--bg-4);border:1px solid var(--border-2);pointer-events:none;border-radius:6px;padding:6px 10px;font-size:12px}.gr-tooltip-move{color:var(--text);font-weight:600}.gr-tooltip-eval{color:var(--text-2)}.gr-critical{flex-direction:column;flex:1;gap:6px;display:flex}.gr-critical-title{color:var(--text);font-size:14px;font-weight:600}.gr-critical-sub{color:var(--text-2);font-size:12px}.gr-no-errors{color:var(--green);padding:8px 4px;font-size:13px}.gr-critical-list{flex-direction:column;gap:4px;max-height:180px;display:flex;overflow-y:auto}.gr-critical-item{text-align:left;background:var(--bg-3);border:1px solid var(--border);cursor:pointer;width:100%;color:var(--text);border-radius:6px;align-items:center;gap:8px;padding:7px 10px;transition:border-color .15s,background .15s;display:flex}.gr-critical-item:hover{border-color:var(--accent)}.gr-critical-item.active{border-color:var(--accent);background:var(--accent-dim)}.gr-critical-item.expanded{background:var(--bg-3);border-bottom-color:#0000;border-radius:4px 4px 0 0}.gr-critical-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.gr-critical-move{flex:1;font-size:13px}.gr-critical-class{color:var(--text-2);white-space:nowrap;font-size:11px}.gr-critical-cpl{color:var(--text-3);white-space:nowrap;font-size:11px}.gr-critical-item-wrap{flex-direction:column;display:flex}.gr-variation{background:var(--bg-3);border:1px solid var(--border);border-top:none;border-left:2px solid var(--green);border-radius:0 0 4px 4px;flex-wrap:wrap;align-items:center;gap:1px 0;margin-bottom:2px;padding:4px 8px 6px 12px;display:flex}.gr-var-num{color:var(--text-3);-webkit-user-select:none;user-select:none;padding:0 2px;font-size:10px}.gr-var-move{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:1px 5px;font-family:inherit;font-size:11px}.gr-var-move.gr-var-best{color:var(--green);font-weight:600}.gr-var-move.active{background:var(--accent);color:#fff}.gr-var-move:hover:not(.active){background:var(--bg-2)}.gr-rating-wrap{text-align:center;border-bottom:1px solid var(--border);flex-shrink:0;padding:12px 0 8px}.gr-est-label{color:var(--text-2);margin-bottom:6px;font-size:12px}.gr-rating-both{justify-content:space-around;gap:8px;display:flex}.gr-rating-side{flex-direction:column;flex:1;align-items:center;display:flex}.gr-rating-side-label{margin-bottom:2px;font-size:20px}.gr-rating-number{margin-bottom:4px;font-size:46px;font-weight:800;line-height:1}.gr-rating-placeholder{color:var(--text-3)}.gr-avg-cpl{color:var(--text-2);font-size:12px}.gr-breakdown{flex-direction:column;flex-shrink:0;gap:7px;padding:4px 0;display:flex}.gr-breakdown-row{align-items:center;gap:8px;display:flex}.gr-breakdown-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.gr-breakdown-label{flex:1;font-size:13px}.gr-breakdown-symbol{color:var(--text-2);font-size:12px}.gr-breakdown-count{text-align:right;min-width:20px;font-size:14px;font-weight:700}.gr-rating-explanation{color:var(--text-3);padding-top:4px;font-size:11px;line-height:1.65}.gr-color-toggle{border:1px solid var(--border);background:var(--bg-2);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:4px;flex-shrink:0;margin-left:10px;padding:2px 8px;font-size:12px}.gr-color-toggle:hover{background:var(--bg-3)}.gr-tabs{gap:4px;margin:6px 0 8px;display:flex}.gr-tab{border:1px solid var(--border);background:var(--bg-2);color:var(--text-2);cursor:pointer;white-space:nowrap;text-align:center;border-radius:4px;flex:1;padding:4px 6px;font-size:11px}.gr-tab:hover{background:var(--bg-3)}.gr-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.gr-save-wrap{flex-direction:column;align-items:center;gap:6px;margin-top:16px;display:flex}.gr-save-btn{width:60%}.gr-save-dialog{flex-direction:column;align-items:center;gap:6px;width:100%;display:flex;position:relative}.gr-save-dialog-title{color:var(--text-2);margin-bottom:2px;font-size:12px}.gr-save-dialog-btns{flex-direction:column;gap:5px;width:70%;display:flex}.gr-save-dialog-btns button{font-size:12px}.gr-save-cancel{color:var(--text-3);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:14px;position:absolute;top:0;right:0}.gr-save-cancel:hover{color:var(--text)}.gr-save-msg{text-align:center;padding:6px 0;font-size:13px;display:block}.gr-save-ok{color:var(--green,#16a34a);font-weight:600}.gr-save-err{color:var(--red,#dc2626)}@media (width<=960px){.gr-body{grid-template-columns:1fr 1fr}.gr-col-right{border-right:none;border-top:1px solid var(--border);grid-column:1/-1}}@media (width<=620px){.gr-body{grid-template-columns:1fr}.gr-col{border-right:none;border-bottom:1px solid var(--border)}.gr-col:last-child{border-bottom:none}.gr-panel{max-height:95vh}.gr-rating-number{font-size:36px}}.online-dot{box-shadow:0 0 0 2px var(--bg-0);background:#22c55e;border-radius:50%;flex-shrink:0;display:inline-block}.online-dot--md{width:10px;height:10px}.online-dot--sm{width:8px;height:8px}.umc-avatar-wrap{display:inline-block;position:relative}.umc-avatar-wrap .online-dot{position:absolute;bottom:-2px;right:-2px}
