*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-surface: #ffffff;--border: #e2e8f0;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--accent: #0f172a;--accent-hover: #1e293b;--accent-fg: #ffffff;--success: #16a34a;--error: #dc2626;--warn: #ca8a04;--diff-easy: #16a34a;--diff-medium: #ca8a04;--diff-hard: #dc2626;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:var(--text-primary);background:var(--bg-primary)}[data-theme=dark]{--bg-primary: #18181b;--bg-secondary: #27272a;--bg-tertiary: #3f3f46;--bg-surface: #27272a;--border: #3f3f46;--text-primary: #f8fafc;--text-secondary: #a1a1aa;--text-muted: #71717a;--accent: #f8fafc;--accent-hover: #e2e8f0;--accent-fg: #18181b;--success: #22c55e;--error: #ef4444;--warn: #eab308;--diff-easy: #22c55e;--diff-medium: #eab308;--diff-hard: #ef4444}body{min-height:100dvh;line-height:1.5;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b880}.oj-loading{display:flex;align-items:center;justify-content:center;height:100dvh;color:var(--text-secondary);font-size:14px}.oj-landing-page{min-height:100dvh;display:flex;flex-direction:column}.oj-landing-header{display:flex;justify-content:space-between;align-items:center;padding:24px 48px}.oj-landing-brand{font-size:18px;font-weight:600;letter-spacing:-.02em}.oj-landing-actions{display:flex;align-items:center;gap:24px}.oj-landing-link{color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s cubic-bezier(.4,0,.2,1)}.oj-landing-link:hover{color:var(--text-primary)}.oj-landing-btn{display:inline-flex;align-items:center;justify-content:center;height:40px;padding:0 20px;border-radius:8px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000000d}.oj-landing-btn.primary{background:var(--accent);color:var(--accent-fg)}.oj-landing-btn.primary:hover{background:var(--accent-hover);transform:scale(.98)}.oj-landing-main{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.oj-landing-hero{text-align:center;max-width:640px;animation:fadeUp .8s cubic-bezier(.16,1,.3,1)}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.oj-landing-hero h1{font-size:clamp(40px,6vw,64px);font-weight:500;letter-spacing:-.04em;line-height:1.1;margin-bottom:24px;color:var(--text-primary)}.oj-landing-hero p{font-size:18px;color:var(--text-secondary);margin-bottom:40px;line-height:1.6}.oj-landing-cta{display:flex;justify-content:center}.oj-auth-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:20px;background:var(--bg-primary)}.oj-auth-card{width:100%;max-width:380px;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;padding:40px 32px;box-shadow:0 10px 40px -10px #0000001a,0 1px 3px #0000000d}.oj-auth-brand{text-align:center;margin-bottom:32px}.oj-auth-brand h1{font-size:24px;font-weight:500;letter-spacing:-.02em}.oj-auth-tabs{display:flex;gap:0;margin-bottom:24px;background:var(--bg-secondary);border-radius:10px;padding:4px}.oj-auth-tab{flex:1;padding:8px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.oj-auth-tab.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:0 1px 4px #0000001a}.oj-auth-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#dc26261a;border-radius:8px;color:var(--error);font-size:13px;margin-bottom:16px}.oj-auth-form{display:flex;flex-direction:column;gap:12px}.oj-auth-field{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;color:var(--text-muted);transition:border-color .2s cubic-bezier(.4,0,.2,1)}.oj-auth-field:focus-within{border-color:var(--text-secondary)}.oj-auth-field input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:14px}.oj-auth-field input::placeholder{color:var(--text-muted)}.oj-auth-submit{padding:12px;background:var(--accent);color:var(--accent-fg);border:none;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s cubic-bezier(.4,0,.2,1);margin-top:8px;box-shadow:0 2px 4px #0f172a1a}.oj-auth-submit:hover:not(:disabled){background:var(--accent-hover)}.oj-auth-submit:disabled{opacity:.6;cursor:not-allowed}.oj-auth-footer{text-align:center;margin-top:20px;color:var(--text-muted);font-size:13px}.oj-auth-link{background:none;border:none;color:var(--text-primary);cursor:pointer;margin-left:4px;font-size:13px;font-weight:500}.oj-auth-link:hover{text-decoration:underline}.oj-auth-note{margin-top:14px;color:var(--text-muted);font-size:12px;line-height:1.6;text-align:center}.oj-layout{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.oj-header{display:flex;align-items:center;height:48px;padding:0 16px;background:var(--bg-primary);border-bottom:1px solid var(--border);flex-shrink:0;gap:12px}.oj-icon-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:8px;display:flex;align-items:center}.oj-icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.oj-header-brand{flex:1;display:flex;align-items:center;gap:12px}.oj-logo{font-size:15px;font-weight:500;letter-spacing:-.01em;color:var(--text-primary)}.oj-logo-subtitle{display:none}.oj-header-right{display:flex;align-items:center;gap:8px}.oj-user-dropdown{position:relative}.oj-user-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:500}.oj-user-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}.oj-user-mode{display:inline-flex;align-items:center;padding:2px 6px;border-radius:999px;background:#ca8a0424;color:var(--warn);font-size:11px;font-weight:600}.oj-dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;min-width:180px;z-index:100;box-shadow:0 4px 20px #0006}.oj-dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;color:var(--text-secondary);width:100%;background:none;border:none;cursor:pointer;text-align:left}.oj-dropdown-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.oj-dropdown-divider{height:1px;background:var(--border);margin:4px 0}.oj-body{display:flex;flex:1;overflow:hidden;background-color:var(--border);padding:4px;gap:4px}.oj-resize-handle{flex:0 0 4px;background-color:transparent;cursor:col-resize;transition:background-color .2s cubic-bezier(.4,0,.2,1);position:relative;border-radius:4px;margin:0 2px}.oj-resize-handle:after{content:"";position:absolute;top:0;bottom:0;left:-8px;right:-8px;z-index:10;cursor:col-resize}.oj-resize-handle:hover,.oj-resize-handle[data-resize-handle-state=drag]{background-color:var(--text-muted);opacity:.15}.oj-resize-handle-horizontal{flex:0 0 4px;background-color:transparent;cursor:row-resize;transition:background-color .2s cubic-bezier(.4,0,.2,1);position:relative;border-radius:4px;margin:2px 0}.oj-resize-handle-horizontal:after{content:"";position:absolute;top:-8px;bottom:-8px;left:0;right:0;z-index:10;cursor:row-resize}.oj-resize-handle-horizontal:hover,.oj-resize-handle-horizontal[data-resize-handle-state=drag]{background-color:var(--text-muted);opacity:.15}.oj-sidebar{display:flex;flex-direction:column;background:var(--bg-primary);height:100%;border-radius:12px;overflow:hidden;border:1px solid var(--border);box-shadow:0 1px 3px #00000005}.oj-sidebar.collapsed{display:none}.oj-search-box{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text-muted)}.oj-search-box input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:13px}.oj-search-box input::placeholder{color:var(--text-muted)}.oj-problem-list{flex:1;overflow-y:auto}.oj-problem-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:12px 16px;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text-secondary);cursor:pointer;font-size:13px;text-align:left;transition:all .2s cubic-bezier(.4,0,.2,1)}.oj-problem-item:hover{background:var(--bg-secondary)}.oj-problem-item.active{background:var(--bg-secondary);color:var(--text-primary);font-weight:500;border-left:3px solid var(--accent);padding-left:13px}.oj-problem-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.oj-problem-meta{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;margin-left:8px}.oj-problem-status-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px}.oj-problem-solved{color:var(--success)}.oj-problem-attempted{color:var(--warning, #f59e0b);opacity:.9}.oj-problem-diff{font-size:11px;flex-shrink:0;opacity:.8}.diff-easy{color:var(--diff-easy)}.diff-medium{color:var(--diff-medium)}.diff-hard{color:var(--diff-hard)}.diff-bg-easy{background-color:var(--diff-easy)}.diff-bg-medium{background-color:var(--diff-medium)}.diff-bg-hard{background-color:var(--diff-hard)}.oj-problem-empty{padding:24px;text-align:center;color:var(--text-muted);font-size:13px}.oj-main-panel{display:flex;flex:1;min-width:0;height:100%}.oj-statement{display:flex;flex-direction:column;padding:24px;overflow-y:auto;background:var(--bg-primary);height:100%;border-radius:12px;border:1px solid var(--border);box-shadow:0 1px 3px #00000005}.oj-problem-header{font-size:24px;font-weight:500;letter-spacing:-.02em;display:flex;align-items:center;gap:12px;margin-bottom:16px}.oj-guest-banner{margin-bottom:16px;padding:12px 14px;border:1px solid rgba(202,138,4,.28);border-radius:10px;background:#ca8a0414;color:var(--text-secondary)}.oj-guest-banner strong{display:block;color:var(--text-primary);margin-bottom:4px}.oj-guest-banner p{font-size:13px;line-height:1.6}.oj-diff-badge{font-size:11px;font-weight:500;padding:2px 8px;border-radius:999px;background:var(--bg-secondary)}.oj-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:32px;font-size:12px;color:var(--text-muted)}.oj-tag{padding:2px 8px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:999px;font-size:11px}.oj-desc{margin-bottom:24px;font-size:14px;line-height:1.7;color:var(--text-secondary)}.oj-desc strong{display:block;color:var(--text-primary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.oj-samples{margin-top:32px}.oj-sample{margin-bottom:24px}.oj-sample-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary);margin-bottom:12px}.oj-sample-grid{display:grid;grid-template-columns:1fr;gap:12px}.oj-sample-label{font-size:11px;color:var(--text-muted);margin-bottom:4px}.oj-sample-grid pre{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:12px;font-size:13px;font-family:JetBrains Mono,Fira Code,monospace;overflow-x:auto;color:var(--text-primary);line-height:1.5}.oj-editor-area{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);border-radius:12px;overflow:hidden;border:1px solid var(--border);box-shadow:0 1px 3px #00000005}.oj-editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.oj-editor-controls{display:flex;align-items:center;gap:12px;min-width:0;flex-wrap:wrap}.oj-editor-tabs{display:flex;gap:4px}.oj-lang-tab{padding:6px 12px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.oj-lang-tab:hover{color:var(--text-primary)}.oj-lang-tab.active{background:var(--bg-secondary);color:var(--text-primary)}.oj-editor-actions{display:flex;gap:8px}.oj-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000000d}.oj-btn:disabled{opacity:.5;cursor:not-allowed}.oj-btn:hover:not(:disabled){background:var(--bg-secondary)}.oj-btn-submit{background:var(--accent);color:var(--accent-fg);border-color:transparent;box-shadow:0 2px 4px #0f172a1a}.oj-btn-submit:hover:not(:disabled){background:var(--accent-hover)}.oj-editor-container{flex:1;overflow:hidden}.oj-editor-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:13px}.oj-editor-container .cm-editor{height:100%}.oj-console-panel{display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary);border-top:1px solid var(--border)}.oj-console{display:flex;flex-direction:column;flex:1;min-height:0}.oj-console-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border)}.oj-status-badge{font-size:11px;letter-spacing:0;text-transform:none}.oj-console-text{padding:16px;font-size:13px;font-family:JetBrains Mono,Fira Code,monospace;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto;line-height:1.6}.oj-hint-panel{margin:12px 16px 0;padding:14px 14px 12px;border:1px solid var(--border);border-radius:12px}.oj-hint-panel-placeholder{background:#fef3c7;border-color:#f3d38a;color:#78350f}.oj-hint-panel-generated{background:color-mix(in srgb,var(--bg-secondary) 82%,#dbeafe);border-color:color-mix(in srgb,var(--border) 74%,#93c5fd)}.oj-hint-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.oj-hint-panel-title{display:inline-flex;align-items:center;gap:8px;color:inherit}.oj-hint-panel-badge{display:inline-flex;align-items:center;height:24px;padding:0 8px;border-radius:999px;font-size:11px;font-weight:600;background:#ffffff8c;color:inherit}.oj-hint-panel-summary{margin-top:10px;font-size:13px;line-height:1.6;color:inherit}.oj-hint-panel-list{margin:10px 0 0;padding-left:18px;font-size:12px;line-height:1.7;color:inherit}.oj-hint-panel-list li+li{margin-top:4px}.oj-hint-panel-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.oj-hint-panel-tag{display:inline-flex;align-items:center;height:24px;padding:0 8px;border-radius:999px;font-size:11px;border:1px solid rgba(120,53,15,.16);background:#ffffff73;color:inherit}.oj-history{flex-shrink:0;border-top:1px solid var(--border);min-height:180px;max-height:280px;overflow-y:auto}.oj-history-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 16px;font-size:11px;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-primary);position:sticky;top:0}.oj-history-title-group,.oj-history-scope{display:flex;align-items:center;gap:8px}.oj-scope-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:var(--bg-secondary);color:var(--text-secondary);font-size:12px;cursor:pointer}.oj-scope-chip.active{background:var(--bg-tertiary);color:var(--text-primary)}.oj-history-count{font-size:11px;text-transform:none;letter-spacing:0}.oj-history-filters{display:flex;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg-primary)}.oj-filter-input,.oj-filter-select{height:34px;padding:0 10px;border:1px solid var(--border);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary)}.oj-filter-input{min-width:220px}.oj-hint-callout{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.oj-hint-callout p{margin-top:4px;font-size:12px;color:var(--text-secondary)}.oj-btn-hint{display:inline-flex;align-items:center;gap:8px}.oj-history-list{background:var(--bg-primary)}.oj-history-item{display:flex;align-items:center;gap:12px;padding:8px 16px;font-size:13px;border-bottom:1px solid var(--border);color:var(--text-secondary)}.oj-history-mode{font-size:11px;padding:2px 6px;border-radius:4px;background:var(--bg-secondary);color:var(--text-muted)}.oj-history-status{font-weight:500;min-width:60px}.oj-history-problem{color:var(--text-primary);min-width:160px}.oj-history-student{color:var(--text-secondary);min-width:140px;font-family:JetBrains Mono,monospace;font-size:12px}.oj-history-cases{color:var(--text-muted);min-width:50px}.oj-history-time{color:var(--text-muted);min-width:60px}.oj-history-date{color:var(--text-muted);margin-left:auto;font-size:12px}.oj-history-empty{padding:16px;color:var(--text-muted);font-size:13px}.oj-admin-page{flex:1;overflow-y:auto;padding:24px;background:var(--bg-secondary)}.oj-admin-hero{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:20px}.oj-admin-eyebrow{color:var(--text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.oj-admin-hero h1{font-size:28px;margin-bottom:8px}.oj-admin-hero p{color:var(--text-secondary);max-width:640px}.oj-admin-summary{min-width:240px;padding:16px;border-radius:12px;border:1px solid var(--border);background:var(--bg-primary);display:flex;flex-direction:column;gap:4px;box-shadow:0 1px 3px #00000005}.oj-admin-summary-label{color:var(--text-muted);font-size:12px}.oj-admin-error,.oj-admin-empty{padding:16px;border-radius:12px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-secondary);box-shadow:0 1px 3px #00000005}.oj-admin-error{color:var(--error);margin-bottom:16px;box-shadow:0 1px 3px #00000005}.oj-admin-list{display:grid;gap:12px}.oj-admin-card{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:18px;border-radius:12px;border:1px solid var(--border);background:var(--bg-primary);box-shadow:0 1px 3px #00000005}.oj-admin-card-main{display:flex;flex-direction:column;gap:6px}.oj-admin-card-title{display:flex;align-items:center;gap:8px;color:var(--text-primary)}.oj-admin-card-main p{color:var(--text-secondary)}.oj-admin-pill{display:inline-flex;width:fit-content;padding:4px 10px;border-radius:999px;background:#3b82f614;color:#3b82f6;font-size:12px;font-weight:600}.oj-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-muted);height:100%}.oj-empty-state h2{font-size:16px;font-weight:500;color:var(--text-secondary)}@media(max-width:960px){.oj-landing-header{padding:20px 24px}.oj-landing-hero h1{font-size:40px}.oj-sidebar{position:absolute;left:0;top:48px;bottom:0;z-index:50;width:280px;box-shadow:0 1px 3px #00000005}.oj-main{flex-direction:column}.oj-statement{width:100%;min-width:0;max-width:none;border-right:none;border-bottom:1px solid var(--border);max-height:40vh;box-shadow:0 1px 3px #00000005}.oj-editor-toolbar{align-items:flex-start;flex-direction:column;gap:10px}.oj-editor-actions{width:100%;justify-content:flex-end}}@media(max-width:768px){.oj-admin-hero,.oj-admin-card{flex-direction:column;align-items:stretch;box-shadow:0 1px 3px #00000005}}.oj-statement::-webkit-scrollbar,.oj-problem-list::-webkit-scrollbar{display:none}.oj-statement,.oj-problem-list{-ms-overflow-style:none;scrollbar-width:none}
