*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{color:#1a1a2e;-webkit-font-smoothing:antialiased;background:#f0f2f5;font-family:Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5}body{min-height:100vh}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;background:0 0;border:none}input,textarea{font:inherit;border:none;outline:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:#c8c6c4;border-radius:3px}.layout{height:100vh;display:flex;overflow:hidden}.sidebar{color:#fff;background:#1a1a2e;flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:12px;padding:20px 20px 24px;display:flex}.brand-icon{letter-spacing:-.5px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex}.brand-text{letter-spacing:-.3px;font-size:17px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:16px 12px;display:flex}.nav-item{color:#ffffffb3;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:13.5px;transition:all .15s;display:flex}.nav-item:hover{color:#fff;background:#ffffff14}.nav-item.active{color:#fff;background:#6366f140}.nav-item svg{opacity:.7;flex-shrink:0}.nav-item.active svg{opacity:1}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 20px}.version{color:#ffffff4d;font-size:11px}.content{background:#f0f2f5;flex:1;overflow-y:auto}.page{max-width:1200px;margin:0 auto;padding:32px}.page-header{margin-bottom:28px}.page-header h1{color:#1a1a2e;margin-bottom:6px;font-size:24px;font-weight:700}.page-sub{color:#6b7280;font-size:14px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px;display:grid}.stat-card{background:#fff;border-radius:12px;padding:20px;position:relative;overflow:hidden;box-shadow:0 1px 3px #0000000f}.stat-dot{border-radius:50%;width:8px;height:8px;margin-bottom:12px}.stat-value{color:#1a1a2e;font-size:28px;font-weight:700;line-height:1}.stat-label{color:#6b7280;margin-top:4px;font-size:13px}.stat-sub{color:#9ca3af;margin-top:2px;font-size:11px}.cards-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=900px){.cards-row{grid-template-columns:1fr}}.card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f}.card h2{color:#1a1a2e;margin-bottom:16px;font-size:16px;font-weight:600}.quick-actions{flex-direction:column;gap:8px;display:flex}.action-btn{color:#374151;background:#f3f4f6;border-radius:8px;align-items:center;gap:10px;padding:12px 16px;font-size:13.5px;font-weight:500;transition:all .15s;display:flex}.action-btn:hover{background:#e5e7eb}.action-btn.primary{color:#fff;background:#6366f1}.action-btn.primary:hover{background:#4f46e5}.token-mini-list{flex-direction:column;gap:6px;display:flex}.token-mini{border-radius:8px;align-items:center;gap:12px;padding:10px 12px;transition:background .12s;display:flex}.token-mini:hover{background:#f3f4f6}.token-mini-avatar{color:#fff;background:#6366f1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.token-mini-info{flex:1;min-width:0}.token-mini-name{white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:500;display:block;overflow:hidden}.token-mini-email{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;font-size:12px;display:block;overflow:hidden}.token-mini-status{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.token-mini-status.active{color:#166534;background:#dcfce7}.token-mini-status.expired{color:#991b1b;background:#fee2e2}.empty-text{color:#9ca3af;font-size:13px}.template-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.tpl-card{background:#fff;border-radius:12px;align-items:flex-start;gap:16px;padding:20px;transition:box-shadow .15s;display:flex;box-shadow:0 1px 3px #0000000f}.tpl-card:hover{box-shadow:0 4px 12px #0000001a}.tpl-icon{color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;font-weight:700;display:flex}.tpl-body{flex-direction:column;flex:1;gap:12px;min-width:0;display:flex}.tpl-info h3{color:#1a1a2e;margin-bottom:2px;font-size:15px;font-weight:600}.tpl-info p{color:#6b7280;font-size:12.5px;line-height:1.4}.tpl-actions{flex-wrap:wrap;gap:6px;display:flex}.tpl-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:6px;margin-top:8px;padding:10px 14px;font-size:12px;line-height:1.5}.tpl-error-link{color:#6366f1;margin-top:4px;font-weight:600;text-decoration:underline;display:inline-block}.token-table{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000f}.token-table-head{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;background:#fafafa;border-bottom:1px solid #f3f4f6;grid-template-columns:1.5fr 1.5fr 1fr .7fr 1.2fr;padding:12px 20px;font-size:12px;font-weight:600;display:grid}.token-row{border-bottom:1px solid #f3f4f6;grid-template-columns:1.5fr 1.5fr 1fr .7fr 1.2fr;align-items:center;padding:14px 20px;font-size:13px;transition:background .1s;display:grid}.token-row:hover{background:#f9fafb}.token-row:last-child{border-bottom:none}.token-user{align-items:center;gap:10px;font-weight:500;display:flex}.token-avatar{color:#fff;background:#6366f1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex}.token-email{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.token-date{color:#6b7280;font-size:12px}.token-actions{flex-wrap:wrap;gap:4px;display:flex}.status-badge{border-radius:10px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.status-badge.active{color:#166534;background:#dcfce7}.status-badge.expired{color:#991b1b;background:#fee2e2}.btn{white-space:nowrap;border-radius:6px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .12s;display:inline-flex}.btn-sm{padding:5px 10px;font-size:12px}.btn-primary{color:#fff;background:#6366f1}.btn-primary:hover{background:#4f46e5}.btn-secondary{color:#374151;background:#f3f4f6}.btn-secondary:hover{background:#e5e7eb}.btn-danger{color:#991b1b;background:#fee2e2}.btn-danger:hover{background:#fecaca}.loading-state,.empty-state{text-align:center;color:#6b7280;padding:48px 24px}.empty-state svg{margin:0 auto 16px;display:block}code{background:#f3f4f6;border-radius:4px;padding:2px 6px;font-family:ui-monospace,Consolas,monospace;font-size:12px}.ol{background:#fff;flex-direction:column;height:100vh;display:flex;overflow:hidden}.ol-err{text-align:center;color:#6b7280;padding:40px}.ol-bar{color:#fff;background:#0078d4;flex-shrink:0;align-items:center;gap:10px;height:48px;padding:0 12px;display:flex}.ol-back{color:#fff;border-radius:4px;align-items:center;gap:6px;padding:4px 10px;font-size:13px;display:flex}.ol-back:hover{background:#ffffff26}.ol-logo{letter-spacing:-.3px;font-size:17px;font-weight:600}.ol-search{background:#ffffff2e;border:1px solid #ffffff40;border-radius:4px;flex:0 320px;align-items:center;gap:6px;height:30px;padding:0 10px;display:flex}.ol-search input{color:#fff;background:0 0;width:100%;font-size:13px}.ol-search input::placeholder{color:#fff9}.ol-user-chip{align-items:center;gap:8px;font-size:13px;display:flex}.ol-user-email{color:#ffffffbf;font-size:11px}.ol-user-av{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:600;display:flex}.ol-toolbar{background:#fff;border-bottom:1px solid #edebe9;flex-shrink:0;align-items:center;gap:2px;padding:4px 8px;display:flex;overflow-x:auto}.ol-tb{color:#323130;white-space:nowrap;border-radius:4px;flex-shrink:0;align-items:center;gap:5px;padding:6px 10px;font-size:12.5px;display:flex}.ol-tb:hover{background:#f3f2f1}.ol-tb:disabled{opacity:.4;pointer-events:none}.ol-tb.primary{color:#fff;background:#0078d4}.ol-tb.primary:hover{background:#106ebe}.ol-tb.primary svg{color:#fff}.ol-sep{background:#edebe9;flex-shrink:0;width:1px;height:24px;margin:0 4px}.ol-fixed-dd{z-index:9999;background:#fff;border:1px solid #edebe9;border-radius:6px;min-width:220px;max-height:360px;padding:4px 0;position:fixed;overflow-y:auto;box-shadow:0 8px 24px #0000002e}.ol-dd-item{color:#323130;cursor:pointer;align-items:center;gap:8px;padding:7px 12px;font-size:13px;transition:background .1s;display:flex}.ol-dd-item:hover{background:#f3f2f1}.ol-body{flex:1;display:flex;overflow:hidden}.ol-loading{color:#605e5c;justify-content:center;align-items:center;gap:12px;width:100%;font-size:14px;display:flex}.ol-folders{background:#faf9f8;border-right:1px solid #edebe9;flex-shrink:0;width:200px;padding:8px 0;overflow-y:auto}.ol-f{cursor:pointer;color:#323130;align-items:center;gap:8px;padding:6px 10px 6px 16px;font-size:13px;transition:background .1s;display:flex}.ol-f:hover{background:#f3f2f1}.ol-f.active{color:#0078d4;background:#deecf9;font-weight:500}.ol-f.active svg{color:#0078d4}.ol-f svg{color:#605e5c;flex-shrink:0}.ol-f-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.ol-f-count{color:#605e5c;white-space:nowrap;font-variant-numeric:tabular-nums;flex-shrink:0;font-size:11px}.ol-f-count.has-unread{color:#0078d4;font-weight:600}.ol-list{border-right:1px solid #edebe9;flex-direction:column;flex-shrink:0;width:320px;display:flex;overflow:hidden}.ol-list-head{border-bottom:1px solid #edebe9;justify-content:space-between;align-items:center;padding:12px 14px 10px;display:flex}.ol-list-title{color:#323130;font-size:16px;font-weight:600}.ol-list-info{color:#605e5c;font-size:12px}.ol-list-scroll{flex:1;overflow-y:auto}.ol-spin-row{color:#605e5c;align-items:center;gap:8px;padding:16px;font-size:13px;display:flex}.ol-empty-msg{text-align:center;color:#605e5c;padding:24px;font-size:13px}.ol-msg{cursor:pointer;border-bottom:1px solid #f3f2f1;gap:10px;padding:10px 14px;transition:background .1s;display:flex;position:relative}.ol-msg:hover{background:#f3f2f1}.ol-msg.sel{background:#deecf9}.ol-msg.unread .ol-msg-from,.ol-msg.unread .ol-msg-subj{font-weight:600}.ol-dot{background:#0078d4;border-radius:50%;width:6px;height:6px;position:absolute;top:50%;left:4px;transform:translateY(-50%)}.ol-msg-av{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:flex}.ol-msg-body{flex:1;min-width:0}.ol-msg-r1{align-items:center;gap:6px;margin-bottom:2px;display:flex}.ol-msg-from{text-overflow:ellipsis;white-space:nowrap;color:#323130;flex:1;font-size:13px;overflow:hidden}.ol-msg-time{color:#605e5c;white-space:nowrap;font-size:11px}.ol-msg-subj{color:#323130;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:12.5px;overflow:hidden}.ol-msg-prev{color:#605e5c;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.ol-msg-att{color:#605e5c;opacity:.6;margin-top:4px;display:inline-flex}.ol-read{flex-direction:column;flex:1;display:flex;overflow:hidden}.ol-read-empty{color:#605e5c;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;font-size:14px;display:flex}.ol-read-content{flex:1;padding:24px 32px;overflow-y:auto}.ol-read-subj{color:#201f1e;margin-bottom:16px;font-size:20px;font-weight:600;line-height:1.3}.ol-read-meta{align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.ol-read-av{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:16px;font-weight:600;display:flex}.ol-read-name{color:#323130;font-size:14px;font-weight:600}.ol-read-name span{color:#605e5c;font-size:12px;font-weight:400}.ol-read-to{color:#605e5c;margin-top:2px;font-size:12px}.ol-read-date{color:#605e5c;white-space:nowrap;margin-left:auto;font-size:12px}.ol-divider{border:none;border-top:1px solid #edebe9;margin:0 0 16px}.ol-read-html{color:#323130;font-size:14px;line-height:1.7}.ol-read-html img{max-width:100%}.ol-compose{z-index:100;background:#fff;border-radius:8px 8px 0 0;flex-direction:column;width:560px;max-height:600px;display:flex;position:fixed;bottom:0;right:24px;box-shadow:0 -4px 24px #00000026}.ol-compose-head{color:#fff;background:#0078d4;border-radius:8px 8px 0 0;justify-content:space-between;align-items:center;padding:10px 14px;font-size:14px;font-weight:500;display:flex}.ol-compose-head button{background:0 0;padding:4px}.ol-compose-field{border-bottom:1px solid #edebe9;align-items:center;padding:8px 14px;display:flex}.ol-compose-field label{color:#605e5c;flex-shrink:0;width:55px;font-size:13px}.ol-compose-field input{color:#323130;flex:1;font-size:13px}.ol-compose-comment{color:#323130;resize:none;border:none;border-bottom:1px solid #edebe9;outline:none;min-height:100px;padding:12px 14px;font-family:inherit;font-size:13.5px}.ol-compose-original{color:#605e5c;background:#faf9f8;border-bottom:1px solid #edebe9;flex:1;max-height:200px;padding:12px 14px;font-size:13px;overflow-y:auto}.ol-compose-original img{max-width:100%}.ol-compose-foot{border-top:1px solid #edebe9;gap:8px;padding:10px 14px;display:flex}.ol-load-more{text-align:center;color:#0078d4;cursor:pointer;background:0 0;border-top:1px solid #f3f2f1;width:100%;padding:12px;font-size:13px;font-weight:500;transition:background .1s;display:block}.ol-load-more:hover{background:#f3f2f1}.ol-search-clear{cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;align-items:center;padding:2px;display:flex}.ol-search-clear:hover{background:#fff3}.ol-toasts{z-index:10000;pointer-events:none;flex-direction:column;gap:8px;max-width:420px;display:flex;position:fixed;top:60px;right:16px}.ol-toast{pointer-events:auto;background:#fff;border-radius:8px;align-items:flex-start;gap:10px;padding:12px 14px;font-size:13px;line-height:1.4;animation:.25s ease-out toastIn;display:flex;box-shadow:0 4px 16px #00000029}.ol-toast-error{border-left:4px solid #d13438}.ol-toast-error svg{color:#d13438;flex-shrink:0;margin-top:1px}.ol-toast-success{border-left:4px solid #107c10}.ol-toast-success svg{color:#107c10;flex-shrink:0;margin-top:1px}.ol-toast-msg{color:#323130;flex:1}.ol-toast-x{cursor:pointer;color:#605e5c;background:0 0;flex-shrink:0;padding:2px}.ol-toast-x:hover{color:#323130}@keyframes toastIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.ol-rules-overlay{z-index:200;background:#00000059;animation:.15s ease-out fadeIn;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.ol-rules-panel{z-index:201;background:#fff;flex-direction:column;width:520px;max-width:90vw;height:100vh;animation:.2s ease-out slideIn;display:flex;position:fixed;top:0;right:0;box-shadow:-8px 0 32px #0003}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.ol-rules-head{background:#faf9f8;border-bottom:1px solid #edebe9;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.ol-rules-head h2{color:#323130;font-size:17px;font-weight:600}.ol-rules-body{flex:1;padding:0;overflow-y:auto}.ol-rules-empty{text-align:center;color:#605e5c;padding:48px 24px;font-size:13px}.ol-rule-item{border-bottom:1px solid #f3f2f1;align-items:flex-start;gap:12px;padding:14px 20px;transition:background .1s;display:flex}.ol-rule-item:hover{background:#faf9f8}.ol-rule-info{flex:1;min-width:0}.ol-rule-name{color:#323130;margin-bottom:3px;font-size:13.5px;font-weight:600}.ol-rule-desc{color:#605e5c;font-size:12px;line-height:1.4}.ol-rule-badge{border-radius:4px;margin-top:4px;padding:2px 6px;font-size:10px;font-weight:600;display:inline-block}.ol-rule-badge.on{color:#166534;background:#dcfce7}.ol-rule-badge.off{color:#991b1b;background:#fee2e2}.ol-rule-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.ol-rule-actions button{color:#605e5c;border-radius:4px;align-items:center;gap:4px;padding:5px 8px;font-size:12px;transition:all .1s;display:flex}.ol-rule-actions button:hover{color:#323130;background:#f3f2f1}.ol-rule-actions button.danger:hover{color:#991b1b;background:#fee2e2}.ol-rules-foot{border-top:1px solid #edebe9;gap:8px;padding:12px 20px;display:flex}.ol-rule-form{padding:20px}.ol-rule-form h3{color:#323130;margin-bottom:16px;font-size:15px;font-weight:600}.ol-rf-field{margin-bottom:14px}.ol-rf-field label{color:#605e5c;margin-bottom:4px;font-size:12px;font-weight:600;display:block}.ol-rf-field input,.ol-rf-field select{color:#323130;background:#fff;border:1px solid #d1d5db;border-radius:5px;width:100%;padding:8px 10px;font-size:13px}.ol-rf-field input:focus,.ol-rf-field select:focus{border-color:#0078d4;outline:none;box-shadow:0 0 0 2px #0078d426}.ol-rf-row{gap:10px;display:flex}.ol-rf-row .ol-rf-field{flex:1}.ol-rf-section{color:#323130;border-top:1px solid #f3f2f1;margin:16px 0 8px;padding-top:12px;font-size:13px;font-weight:600}.ol-rf-toggle{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.ol-rf-toggle span{color:#323130;font-size:13px}.ol-rf-actions{border-top:1px solid #edebe9;gap:8px;margin-top:20px;padding-top:16px;display:flex}.cfg-sections{flex-direction:column;gap:20px;display:flex}.cfg-section{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000f}.cfg-section-head{border-bottom:1px solid #f3f4f6;align-items:center;gap:16px;padding:20px 24px;display:flex}.cfg-section-head h2{color:#1a1a2e;margin-bottom:2px;font-size:16px;font-weight:600}.cfg-section-head p{color:#6b7280;font-size:13px}.cfg-section-icon{color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.cfg-section-icon.tg{background:#08c}.cfg-section-icon.cf{background:#f38020}.cfg-fields{flex-direction:column;gap:16px;padding:20px 24px;display:flex}.cfg-field{flex-direction:column;gap:5px;display:flex}.cfg-field label{color:#374151;font-size:13px;font-weight:600}.cfg-field input{color:#1a1a2e;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:9px 12px;font-size:13px;transition:border-color .15s}.cfg-field input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.cfg-hint{color:#9ca3af;font-size:11px}.cfg-field-actions{gap:8px;display:flex}.cfg-toggle{justify-content:space-between;align-items:center;padding:4px 0;display:flex}.cfg-toggle span:first-child{color:#374151;font-size:13px;font-weight:500}.cfg-toggle input{display:none}.cfg-switch{cursor:pointer;background:#d1d5db;border-radius:11px;flex-shrink:0;width:40px;height:22px;transition:background .2s;position:relative}.cfg-switch:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #00000026}.cfg-toggle input:checked+.cfg-switch{background:#6366f1}.cfg-toggle input:checked+.cfg-switch:after{transform:translate(18px)}.cfg-save-bar{justify-content:flex-end;margin-top:24px;display:flex}.cfg-toast{border-radius:8px;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:13px;animation:.25s ease-out toastIn;display:flex}.cfg-toast-success{color:#166534;background:#dcfce7;border:1px solid #bbf7d0}.cfg-toast-success svg{color:#22c55e}.cfg-toast-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.cfg-toast-error svg{color:#ef4444}.cfg-deploy-result{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;align-items:center;gap:10px;margin-top:12px;padding:12px 14px;font-size:13px;display:flex}.cfg-deploy-url{color:#166534;word-break:break-all;flex:1;font-family:ui-monospace,Consolas,monospace;font-size:12px}.cfg-copy-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#22c55e;border-radius:4px;padding:4px 10px;font-size:11px;font-weight:600;transition:background .15s}.cfg-copy-btn:hover{background:#16a34a}.spinner{border:2.5px solid #edebe9;border-top-color:#0078d4;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}.spinner.small{border-width:2px;width:14px;height:14px}@keyframes spin{to{transform:rotate(360deg)}}.login-page{background:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,#0f172a 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:400px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.login-brand{text-align:center;color:#fff;background:linear-gradient(135deg,#6366f1 0%,#4f46e5 100%);padding:36px 32px 24px}.login-brand .brand-icon.lg{letter-spacing:1px;background:#fff3;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 12px;font-size:22px;font-weight:800;display:flex}.login-brand h1{margin:0 0 4px;font-size:22px;font-weight:700}.login-brand p{opacity:.85;margin:0;font-size:13px}.login-form{padding:28px 32px 32px}.login-field{margin-bottom:16px}.login-field label{color:#475569;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.login-field input,.login-field select{color:#1e293b;box-sizing:border-box;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;width:100%;padding:10px 14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.login-field input:focus,.login-field select:focus{background:#fff;border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f126}.login-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px}.login-btn{border-radius:8px;width:100%;margin-top:4px;padding:12px;font-size:15px;font-weight:600}.cpw-overlay{z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172ab3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.cpw-modal{background:#fff;border-radius:16px;width:100%;max-width:440px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.cpw-header{padding:28px 32px 16px}.cpw-header h2{color:#1e293b;margin:0 0 6px;font-size:18px;font-weight:700}.cpw-sub{color:#64748b;margin:0;font-size:13px}.cpw-form{padding:0 32px 28px}.cpw-actions{gap:10px;margin-top:20px;display:flex}.cpw-actions .btn{flex:1}.cpw-generated-notice{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;margin-top:8px;padding:10px 14px;font-size:12px;font-weight:500}.sidebar-footer{border-top:1px solid #ffffff14;align-items:center;gap:8px;margin-top:auto;padding:12px;display:flex}.sidebar-user{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.sidebar-user-avatar{color:#c7d2fe;background:#6366f14d;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.sidebar-user-info{flex-direction:column;min-width:0;display:flex}.sidebar-user-name{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.sidebar-user-role{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;font-size:10px}.sidebar-logout{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;align-items:center;padding:6px;transition:all .15s;display:flex}.sidebar-logout:hover{color:#f87171;background:#ef444426}.adm-toolbar{justify-content:flex-end;margin-bottom:16px;display:flex}.adm-form-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:20px;padding:24px;box-shadow:0 1px 3px #0000000f}.adm-form-card h3{color:#1e293b;margin:0 0 16px;font-size:16px;font-weight:700}.adm-form-grid{grid-template-columns:1fr 1fr;gap:12px 16px;display:grid}@media (width<=640px){.adm-form-grid{grid-template-columns:1fr}}.adm-form-actions{gap:10px;margin-top:18px;display:flex}.adm-pw-row{gap:8px;display:flex}.adm-pw-row input{flex:1}.status-badge.admin{color:#3b82f6;background:#eff6ff}.cfg-section-icon.sv{color:#22c55e;background:#f0fdf4}.cfg-section-icon.ao{color:#d97706;background:#fef3c7}.cfg-origins-list{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.cfg-origins-empty{color:#94a3b8;padding:12px 0;font-size:13px}.cfg-origin-row{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;display:flex}.cfg-origin-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.cfg-origin-url{color:#1e293b;word-break:break-all;font-family:ui-monospace,Consolas,monospace;font-size:13px}.cfg-origin-label{color:#94a3b8;font-size:11px}.cfg-origin-add{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.cfg-origin-add input{border:1.5px solid #e2e8f0;border-radius:8px;flex:1;min-width:180px;padding:8px 12px;font-size:13px}.cfg-origin-add input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f126}.cfg-origin-label-input{min-width:100px!important;max-width:160px!important}.ol-attachments{margin-bottom:12px;padding:12px 0}.ol-att-label{color:#605e5c;align-items:center;gap:6px;margin-bottom:8px;font-size:12px;font-weight:600;display:flex}.ol-att-list{flex-wrap:wrap;gap:6px;display:flex}.ol-att-chip{color:#323130;cursor:pointer;background:#f3f2f1;border:1px solid #edebe9;border-radius:6px;align-items:center;gap:6px;max-width:260px;padding:6px 12px;font-size:12px;transition:all .12s;display:inline-flex}.ol-att-chip:hover{background:#deecf9;border-color:#0078d4}.ol-att-name{white-space:nowrap;text-overflow:ellipsis;max-width:160px;overflow:hidden}.ol-att-size{color:#605e5c;flex-shrink:0;font-size:11px}.ext-status{white-space:nowrap;border-radius:6px;align-items:center;gap:5px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex}.ext-running{color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe}.ext-done{gap:4px}.ext-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.ext-spinner{border:2px solid #bfdbfe;border-top-color:#2563eb;border-radius:50%;flex-shrink:0;width:12px;height:12px;animation:.7s linear infinite spin}.ext-text{text-overflow:ellipsis;max-width:120px;overflow:hidden}.ext-cancel,.ext-clear{cursor:pointer;color:inherit;opacity:.6;background:0 0;border:none;padding:0 2px;font-size:14px;line-height:1}.ext-cancel:hover,.ext-clear:hover{opacity:1}.ext-download{cursor:pointer;white-space:nowrap;color:#fff!important;background:#107c10!important;border-radius:5px!important;padding:3px 8px!important;font-size:11px!important}.ext-download:hover{background:#0e6b0e!important}
