.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:48px 40px;width:100%;max-width:400px;text-align:center}.login-logo{font-size:32px;font-weight:900;color:var(--accent);margin-bottom:12px;letter-spacing:4px}.login-card h1{font-size:22px;font-weight:700;margin-bottom:4px}.login-sub{color:var(--muted);margin-bottom:32px;font-size:14px}.login-form{display:flex;flex-direction:column;gap:16px;text-align:left}.login-error{background:#f871711a;border:1px solid #f87171;border-radius:var(--radius);padding:10px 14px;color:#f87171;font-size:13px}.layout{display:flex;min-height:100vh}.sidebar{width:220px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 0;flex-shrink:0;position:sticky;top:0;height:100vh}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 20px 28px;border-bottom:1px solid var(--border)}.logo-icon{font-size:24px;color:var(--accent)}.logo-text{font-weight:700;font-size:18px;letter-spacing:.5px}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:20px 12px;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius);color:var(--muted);transition:.15s;font-size:14px;font-weight:500}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--accent);color:#fff}.nav-icon{font-size:16px}.logout-btn{margin:0 12px;padding:10px 12px;background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);font-size:14px;text-align:left;display:flex;gap:12px;align-items:center;transition:.15s}.logout-btn:hover{border-color:var(--red);color:var(--red)}.main-content{flex:1;padding:32px;overflow-y:auto;max-width:1200px}.page-header{margin-bottom:28px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px 20px}.stat-value{font-size:36px;font-weight:700;line-height:1}.stat-label{color:var(--muted);font-size:13px;margin-top:8px;font-weight:500}.stat-sub{color:var(--muted);font-size:12px;margin-top:4px}.section{margin-bottom:32px}.section-title{font-size:16px;font-weight:600;margin-bottom:14px}.table td{padding:12px 16px;border-bottom:1px solid var(--border)}code{background:var(--surface2);padding:2px 6px;border-radius:4px;font-size:12px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap}.page-title{font-size:26px;font-weight:700}.page-sub{color:var(--muted);font-size:14px;margin-top:4px;display:block}.filters{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.filters select,.filters input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;color:var(--text);font-size:13px;outline:none}.search-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;color:var(--text);font-size:13px;outline:none;min-width:220px}.search-input:focus{border-color:var(--accent)}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{padding:12px 16px;text-align:left;color:var(--muted);font-weight:600;border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--surface2)}.key-badge{background:var(--surface2);padding:2px 8px;border-radius:4px;font-family:monospace;font-size:12px}.steam-id{font-size:12px;background:var(--surface2);padding:2px 8px;border-radius:4px}.muted{color:var(--muted)}.nowrap{white-space:nowrap}.empty{text-align:center;color:var(--muted);padding:32px!important}.tag{background:#6c63ff26;color:var(--accent);padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}.actions{display:flex;gap:6px;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:var(--radius);padding:10px 18px;font-size:14px;font-weight:600;transition:.15s}.btn-primary:hover:not(:disabled){background:#5a52d5}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-sm{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:5px 12px;color:var(--text);font-size:12px;font-weight:600;transition:.15s}.btn-sm:hover{border-color:var(--text)}.btn-warn{border-color:var(--yellow)!important;color:var(--yellow)!important}.btn-danger{border-color:var(--red)!important;color:var(--red)!important}.copy-btn{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:3px 10px;color:var(--text);font-size:12px;font-family:monospace;cursor:pointer;transition:.15s}.add-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;margin-bottom:24px}.add-card h2{font-size:15px;font-weight:600;margin-bottom:16px}.add-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;align-items:end}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.field input,.field select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:9px 12px;color:var(--text);font-size:13px;outline:none;transition:.15s}.field input:focus,.field select:focus{border-color:var(--accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;width:100%;max-width:480px}.modal h2{font-size:18px;font-weight:700;margin-bottom:20px}.modal-form{display:flex;flex-direction:column;gap:16px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.toggle-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);cursor:pointer}.detail-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.editor-page{display:flex;flex-direction:column;height:calc(100vh - 64px)}.editor-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;gap:16px;flex-wrap:wrap}.editor-actions{display:flex;gap:10px;align-items:center;flex-shrink:0}.editor-wrap{flex:1;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;min-height:400px}.editor-toolbar{display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--surface2);border-bottom:1px solid var(--border)}.editor-badge{background:var(--accent);color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700}.editor-info{color:var(--muted);font-size:12px}.code-editor{flex:1;background:var(--bg);color:#e2e8f0;border:none;outline:none;padding:20px;font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:13px;line-height:1.6;resize:none;-moz-tab-size:2;tab-size:2;min-height:500px}.hint-box{margin-top:12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 16px;font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:8px;align-items:center}.hint-box code{background:var(--surface2);padding:2px 8px;border-radius:4px;color:var(--accent)}.portal-wrap{min-height:100vh;background:#0f172a;color:#e2e8f0;font-family:Inter,sans-serif;padding:2rem 1rem}.portal-card{max-width:440px;margin:8vh auto 0;background:#1e293b;border:1px solid #334155;border-radius:16px;padding:2.5rem 2rem;text-align:center}.portal-logo{margin-bottom:2rem}.portal-hex{font-size:2.5rem;color:#6366f1}.portal-logo h1{margin:.5rem 0 .25rem;font-size:1.5rem;font-weight:700}.portal-logo p{color:#94a3b8;font-size:.9rem}.portal-error{background:#450a0a;border:1px solid #f87171;color:#fca5a5;border-radius:8px;padding:.75rem 1rem;margin-bottom:1.5rem;font-size:.875rem}.steam-btn{display:inline-block;margin-top:1rem}.steam-btn img{height:52px;border-radius:6px;transition:opacity .15s}.steam-btn img:hover{opacity:.85}.portal-loading{color:#94a3b8;font-size:1rem}.portal-empty{color:#94a3b8}.portal-empty small{display:block;margin-top:.5rem;font-size:.8rem}.portal-header-bar{display:flex;align-items:center;gap:1rem;max-width:800px;margin:0 auto 2rem;background:#1e293b;border:1px solid #334155;border-radius:12px;padding:.875rem 1.25rem}.portal-title{font-weight:700;font-size:1.05rem}.portal-steamid{color:#64748b;font-size:.8rem;font-family:monospace;flex:1}.portal-logout{background:none;border:1px solid #334155;color:#94a3b8;border-radius:6px;padding:.35rem .75rem;cursor:pointer;font-size:.8rem}.portal-logout:hover{border-color:#f87171;color:#f87171}.portal-licences{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem}.portal-licence-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.5rem}.plc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.plc-script{font-weight:700;font-size:1rem}.plc-status{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.plc-key-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.plc-key{flex:1;background:#0f172a;border:1px solid #334155;border-radius:8px;padding:.6rem 1rem;font-size:.85rem;color:#a5b4fc;word-break:break-all}.plc-copy{background:#4f46e5;color:#fff;border:none;border-radius:8px;padding:.6rem 1rem;cursor:pointer;font-size:.8rem;white-space:nowrap;transition:background .15s}.plc-copy:hover{background:#6366f1}.plc-meta{display:flex;gap:1.5rem;font-size:.8rem;color:#94a3b8;margin-bottom:1rem}.plc-meta strong{color:#e2e8f0}.plc-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.plc-hint{color:#475569;font-size:.75rem}.plc-hint code{color:#6366f1}.plc-regen{background:none;border:1px solid #334155;color:#94a3b8;border-radius:8px;padding:.45rem .9rem;cursor:pointer;font-size:.8rem;transition:all .15s}.plc-regen:hover:not(:disabled){border-color:#f59e0b;color:#f59e0b}.plc-regen:disabled{opacity:.5;cursor:default}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--surface2:#222638;--border:#2a2d3e;--accent:#6c63ff;--accent2:#4ade80;--red:#f87171;--yellow:#fbbf24;--text:#e2e8f0;--muted:#64748b;--radius:8px;font-family:Inter,system-ui,sans-serif}body{background:var(--bg);color:var(--text);min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
