@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5faf7;--card: #ffffff;--card2: #f0f7f2;--border: #dde8e0;--border2: #ccd8cf;--accent: hsl(152, 45%, 35%);--accent-hover: hsl(152, 50%, 28%);--accent-muted: rgba(45, 140, 90, .1);--accent-light: hsl(152, 40%, 94%);--text: #1a2e23;--text-muted: #6b8075;--text-dim: #4a6556;--green: #16a34a;--red: #dc2626;--yellow: #ca8a04;--blue: #2563eb;--orange: #ea580c;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.06);--shadow-lg: 0 12px 32px rgba(0,0,0,.08)}[data-theme=dark]{--bg: #0c1210;--card: #131c18;--card2: #1a2620;--border: #1e2e26;--border2: #283d32;--accent: hsl(152, 45%, 42%);--accent-hover: hsl(152, 50%, 50%);--accent-muted: rgba(45, 180, 100, .15);--accent-light: rgba(45, 180, 100, .08);--text: #e8f0ec;--text-muted: #7a9a89;--text-dim: #a3bfaf;--green: #22c55e;--red: #ef4444;--yellow: #eab308;--blue: #3b82f6;--orange: #f97316;--shadow-sm: 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 12px rgba(0,0,0,.3);--shadow-lg: 0 12px 32px rgba(0,0,0,.4)}html,body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .2s,color .2s}#root{min-height:100vh}.app-layout{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;width:230px;height:100vh;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;overflow-y:auto;box-shadow:var(--shadow-sm)}.main-content{margin-left:230px;flex:1;padding:28px;min-height:100vh;overflow-x:hidden}.sidebar-logo{padding:20px 16px 16px;border-bottom:1px solid var(--border)}.sidebar-logo-text{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.3px}.sidebar-logo-sub{font-size:11px;color:var(--text-muted);margin-top:2px}.sidebar-nav{flex:1;padding:8px;display:flex;flex-direction:column;gap:2px}.sidebar-section-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;padding:8px 8px 4px;margin-top:8px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;color:var(--text-dim);font-size:13.5px;font-weight:450;transition:all .15s;border:none;background:none;width:100%;text-align:left;-webkit-user-select:none;user-select:none}.nav-item:hover{background:var(--card2);color:var(--text)}.nav-item.active{background:var(--accent-muted);color:var(--accent);font-weight:550}.nav-item svg{flex-shrink:0;opacity:.75}.nav-item.active svg{opacity:1}.sidebar-footer{padding:8px;border-top:1px solid var(--border)}.theme-toggle{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;color:var(--text-dim);font-size:13.5px;font-weight:450;transition:all .15s;border:none;background:none;width:100%;text-align:left;-webkit-user-select:none;user-select:none;margin-bottom:4px}.theme-toggle:hover{background:var(--card2);color:var(--text)}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:15px;font-weight:600;color:var(--text)}.card-subtitle{font-size:12px;color:var(--text-muted);margin-top:2px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;align-items:flex-start;gap:14px;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.green{background:#16a34a1a;color:var(--green)}.stat-icon.blue{background:#2563eb1a;color:var(--blue)}.stat-icon.orange{background:#ea580c1a;color:var(--orange)}.stat-icon.red{background:#dc26261a;color:var(--red)}.stat-icon.accent{background:var(--accent-muted);color:var(--accent)}[data-theme=dark] .stat-icon.green{background:#22c55e1f}[data-theme=dark] .stat-icon.blue{background:#3b82f61f}[data-theme=dark] .stat-icon.orange{background:#f973161f}[data-theme=dark] .stat-icon.red{background:#ef44441f}.stat-body{flex:1;min-width:0}.stat-label{font-size:12px;color:var(--text-muted);margin-bottom:4px;font-weight:500}.stat-value{font-size:26px;font-weight:700;color:var(--text);line-height:1;letter-spacing:-.5px}.stat-sub{font-size:11px;color:var(--text-muted);margin-top:4px}.table-wrapper{overflow-x:auto;border-radius:10px}table{width:100%;border-collapse:collapse;font-size:13.5px}thead tr{border-bottom:1px solid var(--border)}th{text-align:left;padding:10px 14px;font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}td{padding:11px 14px;color:var(--text-dim);border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr{transition:background .1s}tbody tr:hover{background:var(--accent-light)}[data-theme=dark] tbody tr:hover{background:#ffffff05}tbody tr.clickable{cursor:pointer}.td-primary{color:var(--text)!important;font-weight:500}.td-mono{font-family:Menlo,Monaco,Courier New,monospace;font-size:12px;color:var(--text-dim)}.td-truncate{max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge-green{background:#16a34a1a;color:#16a34a}.badge-red{background:#dc26261a;color:#dc2626}.badge-yellow{background:#ca8a041a;color:#a16207}.badge-blue{background:#2563eb1a;color:#2563eb}.badge-accent{background:var(--accent-muted);color:var(--accent)}.badge-gray{background:#6b80751a;color:var(--text-muted)}.badge-orange{background:#ea580c1a;color:#ea580c}[data-theme=dark] .badge-green{background:#22c55e1f;color:#4ade80}[data-theme=dark] .badge-red{background:#ef44441f;color:#f87171}[data-theme=dark] .badge-yellow{background:#eab3081f;color:#facc15}[data-theme=dark] .badge-blue{background:#3b82f61f;color:#60a5fa}[data-theme=dark] .badge-gray{background:#71717a26;color:#a1a1aa}[data-theme=dark] .badge-orange{background:#f973161f;color:#fb923c}.badge-purple{background:var(--accent-muted);color:var(--accent)}.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:13.5px;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s,box-shadow .15s;font-family:inherit;white-space:nowrap;box-shadow:0 1px 2px #00000014}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 2px 6px #0000001a}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#dc262614;color:var(--red);border:1px solid rgba(220,38,38,.18);border-radius:8px;font-size:12.5px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.btn-danger:hover{background:#dc262624}[data-theme=dark] .btn-danger{background:#ef44441f;border-color:#ef444433}.btn-success{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#16a34a14;color:var(--green);border:1px solid rgba(22,163,74,.18);border-radius:8px;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.btn-success:hover{background:#16a34a24}[data-theme=dark] .btn-success{background:#22c55e1f;border-color:#22c55e33}.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:transparent;color:var(--text-dim);border:1px solid var(--border2);border-radius:8px;font-size:13.5px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.btn-ghost:hover{background:var(--card2);color:var(--text)}.btn-sm{padding:5px 10px!important;font-size:12px!important}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-label{font-size:12.5px;font-weight:600;color:var(--text-dim)}.form-input,.form-select,.form-textarea{background:var(--bg);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-size:13.5px;font-family:inherit;padding:9px 12px;width:100%;transition:border-color .15s,box-shadow .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.form-input::placeholder{color:var(--text-muted)}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b8075' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.form-select option{background:var(--card);color:var(--text)}.form-textarea{resize:vertical;min-height:80px}.form-error{font-size:12px;color:var(--red)}.form-hint{font-size:11.5px;color:var(--text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.search-bar{position:relative;display:flex;align-items:center}.search-bar svg{position:absolute;left:10px;color:var(--text-muted);pointer-events:none;flex-shrink:0}.search-input{background:var(--bg);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-size:13.5px;font-family:inherit;padding:8px 12px 8px 34px;width:260px;transition:border-color .15s,width .2s,box-shadow .15s;outline:none}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted);width:300px}.search-input::placeholder{color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}[data-theme=dark] .modal-overlay{background:#0009}.modal{background:var(--card);border:1px solid var(--border2);border-radius:14px;width:100%;max-width:600px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-lg{max-width:780px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card);z-index:1}.modal-title{font-size:16px;font-weight:700;color:var(--text)}.modal-close{width:28px;height:28px;border-radius:7px;border:none;background:var(--card2);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:var(--border);color:var(--text)}.modal-body{padding:20px 24px}.modal-footer{padding:16px 24px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-title{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.4px}.page-sub{font-size:13px;color:var(--text-muted);margin-top:2px}.page-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.file-upload-area{border:2px dashed var(--border2);border-radius:10px;padding:24px;text-align:center;cursor:pointer;transition:all .15s;background:var(--bg)}.file-upload-area:hover{border-color:var(--accent);background:var(--accent-light)}.file-upload-area.has-file{border-color:var(--accent);border-style:solid;background:var(--accent-light)}.file-upload-area svg{color:var(--text-muted);margin-bottom:8px}.file-upload-area p{font-size:13px;color:var(--text-muted)}.file-upload-area .filename{font-size:13px;color:var(--accent);font-weight:600;margin-top:4px}.file-preview{margin-top:12px;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.file-preview img{max-width:100%;max-height:200px;display:block;margin:0 auto}.divider{height:1px;background:var(--border);margin:16px 0}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-dim)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-accent{color:var(--accent)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.font-mono{font-family:Menlo,Monaco,Courier New,monospace}.font-sm{font-size:12px}.font-bold{font-weight:700}.w-full{width:100%}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state svg{margin:0 auto 12px;opacity:.3}.empty-state p{font-size:14px}.spinner{width:18px;height:18px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;padding:60px;gap:10px;color:var(--text-muted);font-size:13px}.info-row{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.info-row:last-child{border-bottom:none}.info-row .label{color:var(--text-muted);font-weight:500;flex-shrink:0;margin-right:12px}.info-row .value{color:var(--text);text-align:right;word-break:break-all}.alert{padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:16px;border:1px solid}.alert-info{background:#2563eb0f;border-color:#2563eb26;color:var(--blue)}.alert-warning{background:#ca8a040f;border-color:#ca8a0426;color:var(--yellow)}.alert-success{background:#16a34a0f;border-color:#16a34a26;color:var(--green)}.alert-error{background:#dc26260f;border-color:#dc262626;color:var(--red)}[data-theme=dark] .alert-info{background:#3b82f614;border-color:#3b82f633;color:#93c5fd}[data-theme=dark] .alert-warning{background:#eab30814;border-color:#eab30833;color:#fde047}[data-theme=dark] .alert-success{background:#22c55e14;border-color:#22c55e33;color:#86efac}[data-theme=dark] .alert-error{background:#ef444414;border-color:#ef444433;color:#fca5a5}.section-title{font-size:13px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px}.tag{display:inline-flex;align-items:center;padding:2px 7px;border-radius:5px;font-size:11px;font-weight:600;background:var(--card2);color:var(--text-muted);border:1px solid var(--border)}.role-admin{background:var(--accent-muted);color:var(--accent);border:1px solid rgba(45,140,90,.2)}.role-support{background:#2563eb14;color:var(--blue);border:1px solid rgba(37,99,235,.15)}.role-user{background:var(--card2);color:var(--text-muted);border:1px solid var(--border)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
