@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-dark:#0c0e14;--bg-panel:#13161f;--bg-surface:#1a1e2e;--bg-surface-hover:#222840;--bg-surface-active:#2a3250;--text-primary:#e4e6f0;--text-secondary:#8b90a8;--text-muted:#4e5268;--accent-primary:#6c63ff;--accent-hover:#7c74ff;--accent-secondary:#ec4899;--accent-success:#22c55e;--accent-warning:#f59e0b;--accent-danger:#ef4444;--accent-info:#3b82f6;--border-color:#1e2236;--border-focus:#6c63ff;--transition-fast:.15s ease-out;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--shadow-sm:0 1px 3px #00000080;--shadow-md:0 4px 12px #0009;--shadow-lg:0 12px 32px #000000b3;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background-color:var(--bg-dark);color:var(--text-primary);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;font-weight:700;line-height:1.2}a{color:var(--accent-primary);text-decoration:none}a:hover{color:var(--accent-hover)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-surface-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.admin-layout{min-height:100vh;display:flex}.admin-main{margin-left:var(--sidebar-width);min-width:0;transition:margin-left var(--transition-normal);flex:1}.admin-content{min-height:calc(100vh - var(--header-height));padding:28px 32px}.sidebar{width:var(--sidebar-width);background:var(--bg-panel);border-right:1px solid var(--border-color);z-index:50;transition:width var(--transition-normal);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed)}.sidebar--collapsed~.admin-main{margin-left:var(--sidebar-collapsed)}.sidebar-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;min-height:68px;padding:20px 16px;display:flex}.sidebar-logo{color:var(--accent-primary);white-space:nowrap;letter-spacing:-.03em;align-items:center;gap:10px;font-size:18px;font-weight:800;display:flex}.sidebar-toggle{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;width:28px;height:28px;transition:all var(--transition-fast);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-toggle:hover{color:var(--text-primary);border-color:var(--accent-primary)}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex;overflow-y:auto}.sidebar-link{color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;width:100%;font-size:14px;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;padding:10px 12px;text-decoration:none;display:flex}.sidebar-link:hover{color:var(--text-primary);background:var(--bg-surface)}.sidebar-link--active{background:#6c63ff1a;color:var(--accent-primary)!important}.sidebar-link--active:before{content:"";background:var(--accent-primary);border-radius:0 3px 3px 0;width:3px;height:24px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-footer{border-top:1px solid var(--border-color);padding:12px 8px}.sidebar-user{align-items:center;gap:10px;margin-bottom:4px;padding:10px 12px;display:flex}.sidebar-avatar{object-fit:cover;border:2px solid var(--border-color);border-radius:50%;width:32px;height:32px}.sidebar-user-info{overflow:hidden}.sidebar-user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-logout{color:var(--accent-danger)!important}.sidebar-logout:hover{background:#ef44441a!important}.admin-header{height:var(--header-height);border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);z-index:40;background:#13161fcc;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.admin-header-title{font-size:20px;font-weight:700}.admin-header-env{color:var(--text-muted);background:var(--bg-surface);border-radius:6px;padding:4px 10px;font-size:12px}.btn{cursor:pointer;transition:all var(--transition-normal);font-size:13px;font-weight:600;font-family:var(--font-sans);color:var(--text-primary);white-space:nowrap;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);color:#fff;box-shadow:0 4px 14px #6c63ff4d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #6c63ff73}.btn-danger{background:linear-gradient(135deg, var(--accent-danger), #dc2626);color:#fff;box-shadow:0 4px 14px #ef44444d}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #ef444466}.btn-ghost{color:var(--text-secondary);background:0 0;padding:8px 14px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-surface)}.btn-lg{padding:14px 28px;font-size:15px}.btn-icon{color:var(--text-muted);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.btn-icon:hover{color:var(--text-primary);background:var(--bg-surface-hover)}.btn-icon--danger:hover{color:var(--accent-danger);background:#ef44441a}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.stats-card{background:var(--bg-panel);border:1px solid var(--border-color);transition:all var(--transition-normal);border-radius:14px;align-items:center;gap:16px;padding:20px;animation:.4s ease-out both fadeInUp;display:flex}.stats-card:hover{box-shadow:var(--shadow-md);border-color:var(--bg-surface-hover);transform:translateY(-2px)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stats-card-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.stats-card--primary .stats-card-icon{color:var(--accent-primary);background:#6c63ff1f}.stats-card--accent .stats-card-icon{color:var(--accent-secondary);background:#ec48991f}.stats-card--success .stats-card-icon{color:var(--accent-success);background:#22c55e1f}.stats-card--warning .stats-card-icon{color:var(--accent-warning);background:#f59e0b1f}.stats-card--info .stats-card-icon{color:var(--accent-info);background:#3b82f61f}.stats-card-value{letter-spacing:-.03em;font-size:26px;font-weight:800;line-height:1}.stats-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:12px;font-weight:500}.data-table-wrapper{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:14px;overflow:hidden}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;background:var(--bg-surface);border-bottom:1px solid var(--border-color);white-space:nowrap;padding:12px 16px;font-size:11px;font-weight:600}.data-table td{color:var(--text-secondary);vertical-align:middle;border-bottom:1px solid #1e223680;padding:12px 16px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#6c63ff08}.data-table-clickable{cursor:pointer}.data-table-clickable:hover td{background:#6c63ff0f!important}.data-table-empty{font-style:italic;text-align:center!important;color:var(--text-muted)!important;padding:40px 16px!important}.user-cell{align-items:center;gap:10px;display:flex}.user-cell-avatar{object-fit:cover;border:1px solid var(--border-color);border-radius:50%;width:32px;height:32px}.user-cell-name{color:var(--text-primary);font-size:13px;font-weight:600}.user-cell-email{color:var(--text-muted);font-size:12px}.table-actions{justify-content:flex-end;gap:4px;display:flex}.badge{text-transform:capitalize;letter-spacing:.02em;border-radius:6px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge--default{background:var(--bg-surface);color:var(--text-secondary)}.badge--primary{color:var(--accent-primary);background:#6c63ff1f}.badge--success{color:var(--accent-success);background:#22c55e1f}.badge--warning{color:var(--accent-warning);background:#f59e0b1f}.badge--danger{color:var(--accent-danger);background:#ef44441f}.badge--info{color:var(--accent-info);background:#3b82f61f}.badge--muted{background:var(--bg-surface);color:var(--text-muted)}.status-dot{align-items:center;gap:6px;font-size:12px;font-weight:500;display:inline-flex}.status-dot:before{content:"";border-radius:50%;width:7px;height:7px}.status-dot--active{color:var(--accent-success)}.status-dot--active:before{background:var(--accent-success);box-shadow:0 0 8px #22c55e66}.status-dot--draft{color:var(--text-muted)}.status-dot--draft:before{background:var(--text-muted)}.star-latest{color:var(--accent-warning);fill:var(--accent-warning)}.mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:12px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:24px;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-panel);border:1px solid var(--border-color);width:100%;box-shadow:var(--shadow-lg);border-radius:16px;max-height:90vh;animation:.25s cubic-bezier(.4,0,.2,1) slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{font-size:17px;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:6px;padding:4px;display:flex}.modal-close:hover{color:var(--text-primary);background:var(--bg-surface)}.modal-body{padding:20px 24px}.modal-actions{border-top:1px solid var(--border-color);justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;display:flex}.confirm-dialog{text-align:center}.confirm-icon{width:56px;height:56px;color:var(--accent-warning);background:#f59e0b1f;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.confirm-icon--danger{color:var(--accent-danger);background:#ef44441f}.confirm-message{color:var(--text-secondary);margin-bottom:20px;font-size:14px;line-height:1.6}.confirm-actions{justify-content:center;gap:10px;display:flex}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--bg-panel);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);border-radius:10px;align-items:center;gap:10px;min-width:280px;max-width:400px;padding:12px 16px;font-size:13px;font-weight:500;animation:.3s cubic-bezier(.4,0,.2,1) toastIn;display:flex}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast--success{border-left:3px solid var(--accent-success)}.toast--success svg{color:var(--accent-success)}.toast--error{border-left:3px solid var(--accent-danger)}.toast--error svg{color:var(--accent-danger)}.toast-close{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;border-radius:4px;margin-left:auto;padding:2px;display:flex}.toast-close:hover{color:var(--text-primary)}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-surface);border:1px solid var(--border-color);width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);transition:border-color var(--transition-fast);border-radius:8px;outline:none;padding:10px 14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c63ff1a}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%238b90a8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.form-textarea{resize:vertical;min-height:60px}.form-checkbox label{cursor:pointer;align-items:center;gap:8px;text-transform:none!important;letter-spacing:0!important;font-size:13px!important;font-weight:500!important;display:flex!important}.form-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-primary);cursor:pointer}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.page-toolbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.search-box{background:var(--bg-surface);border:1px solid var(--border-color);min-width:280px;transition:border-color var(--transition-fast);border-radius:10px;align-items:center;gap:8px;padding:0 14px;display:flex}.search-box:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c63ff1a}.search-box svg{color:var(--text-muted);flex-shrink:0}.search-box input{color:var(--text-primary);width:100%;font-size:13px;font-family:var(--font-sans);background:0 0;border:none;outline:none;padding:10px 0}.filter-group{gap:8px;display:flex}.filter-group select{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-primary);font-size:12px;font-family:var(--font-sans);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%238b90a8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border-radius:8px;outline:none;padding:8px 32px 8px 12px}.pagination{justify-content:center;align-items:center;gap:16px;margin-top:20px;padding:16px 0;display:flex}.pagination-info{color:var(--text-muted);font-size:13px}.file-upload{background:var(--bg-surface);border:2px dashed var(--border-color);cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast);border-radius:10px;align-items:center;gap:10px;padding:14px;font-size:13px;display:flex}.file-upload:hover{border-color:var(--accent-primary);color:var(--text-secondary)}.file-info{color:var(--text-muted);margin-top:6px;font-size:11px}.back-btn{margin-bottom:20px}.user-detail-header{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:24px;padding:24px;display:flex}.user-detail-info{align-items:center;gap:16px;display:flex}.user-detail-avatar{object-fit:cover;border:2px solid var(--border-color);border-radius:50%;width:56px;height:56px}.user-detail-name{font-size:20px;font-weight:700}.user-detail-email{color:var(--text-muted);margin-bottom:6px;font-size:13px}.user-detail-badges{gap:6px;display:flex}.user-detail-meta{gap:24px;display:flex}.meta-item{text-align:center}.meta-item label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;font-size:10px;font-weight:600;display:block}.meta-item span{color:var(--text-secondary);font-size:13px;font-weight:600}.detail-section{margin-bottom:24px}.detail-section-title{color:var(--text-primary);margin-bottom:12px;font-size:15px;font-weight:700}.role-editor{align-items:center;gap:10px;display:flex}.role-editor .form-select{width:160px}.sub-actions{gap:10px;display:flex}.login-page{background:var(--bg-dark);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle,#6c63ff14,#0000 60%);width:60%;height:60%;animation:10s ease-in-out infinite loginFloat;position:absolute;top:-30%;left:-20%}.login-page:after{content:"";background:radial-gradient(circle,#ec48990f,#0000 60%);width:50%;height:50%;animation:12s ease-in-out infinite reverse loginFloat;position:absolute;bottom:-30%;right:-20%}@keyframes loginFloat{0%,to{transform:translate(0)}50%{transform:translate(20px,-15px)}}.login-card{z-index:1;background:var(--bg-panel);border:1px solid var(--border-color);text-align:center;width:100%;max-width:420px;box-shadow:var(--shadow-lg);border-radius:20px;padding:48px 40px;position:relative}.login-logo{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);color:#fff;border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 20px;display:flex;box-shadow:0 8px 24px #6c63ff4d}.login-title{letter-spacing:-.03em;margin-bottom:8px;font-size:24px;font-weight:800}.login-subtitle{color:var(--text-muted);margin-bottom:28px;font-size:14px}.login-error{color:var(--accent-danger);text-align:left;background:#ef44441a;border:1px solid #ef444433;border-radius:10px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.login-btn{width:100%}.login-btn svg{flex-shrink:0}.admin-loading{min-height:100vh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:14px;display:flex}.page-loading{justify-content:center;align-items:center;padding:80px 0;display:flex}.admin-loading-spinner{border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.page-error{text-align:center;color:var(--accent-danger);padding:60px 0;font-size:14px}@media (width<=900px){.sidebar{width:var(--sidebar-collapsed)}.admin-main{margin-left:var(--sidebar-collapsed)}.admin-content{padding:20px 16px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.page-toolbar{flex-direction:column;align-items:stretch}.search-box{min-width:unset}.user-detail-header{flex-direction:column}.user-detail-meta{flex-wrap:wrap}.form-row{grid-template-columns:1fr}}
