﻿@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Space+Grotesk:wght@600;700;800&display=swap');

/* ===== TOPBAR / HEADER OVERRIDES ===== */

:root {
    --bg-body: #070d1a;
    --bg-sidebar: #0b1120;
    --bg-panel: rgba(13,20,38,0.85);
    --bg-topbar: rgba(7,13,26,0.92);
    --text-primary: #e8edf5;
    --text-secondary: #8896b3;
    --text-muted: #4f617a;
    --border-color: rgba(255,255,255,0.06);
    --primary: #2d8cff;
    --primary-dark: #1a6cd8;
    --primary-glow: rgba(45,140,255,0.25);
    --accent: #00e5c3;
    --accent-glow: rgba(0,229,195,0.2);
    --glass-bg: rgba(255,255,255,0.03);
    --glass-border: rgba(255,255,255,0.08);
    --panel-shadow: 0 4px 24px rgba(0,0,0,0.6);
    --sidebar-width: 255px;
    --topbar-height: 64px;
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 18px;
    --transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
    --card: #0f1929;
    --error: #ff5c6c;
}

body.light {
    --bg-body: #f0f4fa;
    --bg-sidebar: #ffffff;
    --bg-panel: rgba(255,255,255,0.9);
    --bg-topbar: rgba(255,255,255,0.95);
    --text-primary: #0d1526;
    --text-secondary: #445577;
    --text-muted: #7788aa;
    --border-color: rgba(0,0,0,0.07);
    --primary: #1a6cd8;
    --primary-glow: rgba(26,108,216,0.15);
    --glass-bg: rgba(0,0,0,0.02);
    --glass-border: rgba(0,0,0,0.06);
    --panel-shadow: 0 4px 24px rgba(0,40,100,0.08);
    --card: #fff;
}

*{box-sizing:border-box;margin:0;padding:0;}

body{
    font-family:'Inter',sans-serif;
    background:var(--bg-body);
    color:var(--text-primary);
    transition:background .5s,color .5s;
    overflow-x:hidden;
    height:100vh;
    font-size:14px;
    line-height:1.6;
}

h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;letter-spacing:-0.03em;line-height:1.2;}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:10px;}

/* LOGIN */
body.login-page{
    display:flex;align-items:center;justify-content:center;
    background:radial-gradient(ellipse at 30% 40%, #061535 0%, #020c1b 60%, #000 100%);
    min-height:100vh;
}

.login-container{width:100%;max-width:400px;padding:20px;}

.login-box{
    background:var(--card);
    padding:40px 36px;
    border-radius:20px;
    border:1px solid rgba(45,140,255,0.12);
    box-shadow:0 24px 64px rgba(0,0,0,0.7),0 0 0 1px rgba(45,140,255,0.06);
    animation:fadeUp .5s ease;
}

@keyframes fadeUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}

.login-box .brand{text-align:center;margin-bottom:28px;}
.login-box .brand h1{font-size:20px;color:var(--text-primary);margin:0;}
.login-box .brand p{font-size:12px;color:var(--text-muted);margin-top:4px;}

.login-box .input-group{margin-top:16px;}
.login-box .input-group label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);display:block;margin-bottom:7px;}
.login-box .input-group input{
    width:100%;padding:11px 14px;border-radius:var(--radius-sm);
    border:1px solid rgba(255,255,255,0.08);
    background:rgba(255,255,255,0.04);
    color:var(--text-primary);outline:none;font-size:14px;font-family:inherit;
    transition:var(--transition);
}
.login-box .input-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);}
.login-box .password-wrapper{position:relative;}
.login-box .password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);cursor:pointer;color:var(--text-muted);font-size:17px;user-select:none;}

.login-box button{
    width:100%;padding:12px;margin-top:20px;border:none;border-radius:var(--radius-sm);
    background:linear-gradient(135deg,var(--primary),var(--primary-dark));
    color:#fff;font-weight:600;cursor:pointer;font-size:14px;font-family:inherit;
    transition:var(--transition);letter-spacing:.3px;
}
.login-box button:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--primary-glow);}
.login-box .error-message{color:var(--error);font-size:12px;margin-top:10px;text-align:center;display:none;padding:8px;background:rgba(255,92,108,0.08);border-radius:6px;border:1px solid rgba(255,92,108,0.15);}
.login-box .footer{text-align:center;margin-top:16px;font-size:11px;color:var(--text-muted);}

/* LAYOUT */
.admin-layout{display:flex;min-height:100vh;}

/* SIDEBAR */
.sidebar{
    width:var(--sidebar-width);
    background:var(--bg-sidebar);
    border-right:1px solid var(--border-color);
    position:fixed;height:100vh;z-index:1000;
    transition:var(--transition);
    display:flex;flex-direction:column;
    overflow:hidden;
}

.sidebar .brand{
    padding:0 22px;
    border-bottom:1px solid var(--border-color);
    display:flex;justify-content:center;align-items:center;
}

.brand-logo{max-width:250px;width:100%;height:auto;object-fit:contain;transition:var(--transition);transform:scale(1.3);margin:-60px 0;}
.topbar-logo{display:none;}
.topbar-logo img{height:38px;}
body.sidebar-collapsed .brand-logo{width:0;opacity:0;height:0;transform:scale(0);}

#userRole { display: none !important; }

.sidebar nav{padding:16px 12px;flex:1;overflow-y:auto;position:relative;z-index:10;}

.sidebar-section{
    font-size:9px;font-weight:700;text-transform:uppercase;
    color:var(--text-muted);margin:20px 10px 8px;letter-spacing:2px;
}

.menu-item{
    display:flex;align-items:center;justify-content:space-between;
    padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:2px;
    font-size:13px;font-weight:500;color:var(--text-secondary);
    transition:var(--transition);cursor:pointer;text-decoration:none;
}

.menu-item:hover{background:var(--glass-bg);color:var(--primary);padding-left:18px;}
.menu-item.active{background:linear-gradient(135deg,rgba(45,140,255,0.18),rgba(45,140,255,0.06));color:var(--primary);border-left:2px solid var(--primary);padding-left:12px;font-weight:600;}

.arrow{width:16px;height:16px;opacity:.5;transition:transform .3s;flex-shrink:0;}
.has-dropdown.open .arrow{transform:rotate(90deg);opacity:1;color:var(--primary);}

.submenu{max-height:0;overflow:hidden;transition:max-height .35s ease;padding-left:12px;}
.has-dropdown.open .submenu{max-height:600px;margin:4px 0 8px;}

.submenu a{
    display:block;padding:8px 14px;font-size:12px;
    color:var(--text-muted);border-radius:6px;
    transition:var(--transition);text-decoration:none;
    border-left:2px solid transparent;
}
.submenu a:hover,.submenu a.active{color:var(--primary);background:var(--glass-bg);border-left-color:var(--primary);padding-left:18px;}

/* MAIN */
.main{flex:1;margin-left:var(--sidebar-width);transition:var(--transition);}

/* TOPBAR */
.topbar{
    height:var(--topbar-height);
    padding:0 32px;
    background:var(--bg-topbar);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    display:flex;
    align-items:center;
    justify-content:space-between;
    position:sticky;
    top:0;
    z-index:900;
    /* Gradient accent line at bottom */
    border-bottom:none;
    box-shadow:0 1px 0 0 rgba(45,140,255,0.18), 0 2px 24px rgba(0,0,0,0.45);
}
/* Animated gradient underline */
.topbar::after{
    content:'';
    position:absolute;
    bottom:0;left:0;right:0;
    height:1px;
    background:linear-gradient(90deg,transparent 0%,var(--primary) 30%,var(--accent) 70%,transparent 100%);
    opacity:0.5;
}

.topbar-left{display:flex;align-items:center;gap:18px;flex:1;}

/* PILL SEARCH */
.search-box{
    position:relative;
    width:300px;
    display:flex;
    align-items:center;
}
.search-icon{position:absolute;left:14px;color:var(--text-muted);pointer-events:none;transition:var(--transition);}
.search-box input{
    width:100%;
    padding:9px 44px 9px 42px;
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.09);
    border-radius:50px;
    color:var(--text-primary);
    font-family:inherit;
    font-size:13px;
    transition:var(--transition);
    outline:none;
    letter-spacing:.1px;
}
.search-box input::placeholder{color:var(--text-muted);}
.search-box input:focus{
    border-color:var(--primary);
    background:rgba(45,140,255,0.06);
    box-shadow:0 0 0 3px var(--primary-glow);
    width:360px;
}
.search-box input:focus ~ .search-icon,
.search-box:focus-within .search-icon{color:var(--primary);}
.search-key{
    position:absolute;right:14px;
    padding:2px 8px;
    background:rgba(255,255,255,0.07);
    border:1px solid rgba(255,255,255,0.1);
    border-radius:50px;
    font-size:10px;
    color:var(--text-muted);
    font-weight:700;
    letter-spacing:.5px;
    pointer-events:none;
}

.topbar-right{display:flex;align-items:center;gap:14px;}

/* Light mode topbar */
body.light .topbar{box-shadow:0 1px 0 0 rgba(26,108,216,0.15),0 2px 16px rgba(0,40,100,0.07);}
body.light .topbar::after{background:linear-gradient(90deg,transparent,var(--primary) 30%,#00b8a0 70%,transparent);opacity:0.4;}
body.light .search-box input{background:rgba(0,0,0,0.04);border-color:rgba(0,0,0,0.09);}
body.light .search-box input:focus{background:rgba(26,108,216,0.05);}

/* THEME TOGGLE */
.theme-toggle{
    width:52px;height:26px;
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.1);
    border-radius:50px;
    display:flex;align-items:center;justify-content:space-between;
    padding:0 6px;cursor:pointer;position:relative;
    transition:var(--transition);
}
.theme-toggle:hover{border-color:var(--primary);background:rgba(45,140,255,0.08);}
.toggle-ball{
    position:absolute;width:18px;height:18px;
    background:linear-gradient(135deg,var(--primary),var(--accent));
    border-radius:50%;left:4px;transition:var(--transition);
    transform:translateX(24px);
    box-shadow:0 2px 8px var(--primary-glow);
}
body.light .toggle-ball{transform:translateX(0);}
.sun,.moon{font-size:11px;z-index:1;pointer-events:none;line-height:1;}

/* CONTENT */
.content{padding:32px;}

.page-title{margin-bottom:28px;}
.page-title h1{font-size:26px;font-weight:700;color:var(--text-primary);}
.page-title p{font-size:13px;color:var(--text-muted);margin-top:4px;}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:24px;}

.card{
    background:var(--bg-panel);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid var(--glass-border);
    padding:24px;border-radius:var(--radius-lg);
    transition:var(--transition);box-shadow:var(--panel-shadow);
    position:relative;overflow:hidden;
}
.card::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(45,140,255,0.04),transparent 60%);
    pointer-events:none;
}
.card:hover{transform:translateY(-4px);border-color:rgba(45,140,255,0.3);box-shadow:0 12px 32px rgba(0,0,0,0.5),0 0 0 1px rgba(45,140,255,0.12);}

.card p{font-size:32px;font-weight:700;font-family:'Space Grotesk';}
.card-horizontal{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.card-info{flex:1;}
.card-info h3{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:8px;}

.card-icon{
    width:48px;height:48px;display:flex;align-items:center;justify-content:center;
    background:rgba(45,140,255,0.1);border:1px solid rgba(45,140,255,0.2);
    border-radius:var(--radius-md);color:var(--primary);flex-shrink:0;
    transition:var(--transition);
}
.card:hover .card-icon{background:var(--primary);color:#fff;transform:scale(1.08);box-shadow:0 6px 18px var(--primary-glow);}
.card-icon svg{width:22px;height:22px;}

/* PANEL */
.panel{
    background:var(--bg-panel);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid var(--glass-border);padding:28px;border-radius:var(--radius-lg);
    box-shadow:var(--panel-shadow);margin-top:24px;
}

/* ANALYTICS GRID */
.analytics-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:20px;margin-top:24px;}
.chart-box{min-height:300px;}

/* TABLE */
.premium-table-container{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
th{text-align:left;padding:16px 20px;color:var(--text-muted);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;border-bottom:1px solid var(--border-color);}
td{padding:16px 20px;border-bottom:1px solid var(--border-color);font-size:13px;color:var(--text-secondary);}
tbody tr:hover{background:var(--glass-bg);}

/* ADMIN TABLE */
.admin-table{width:100%;border-spacing:0 6px;border-collapse:separate;}
.admin-table th{padding:12px 18px;text-align:left;color:var(--text-muted);font-size:10px;text-transform:uppercase;letter-spacing:1.2px;font-weight:700;}
.admin-table tbody tr{background:var(--glass-bg);border-radius:var(--radius-sm);transition:var(--transition);}
.admin-table tbody tr:hover{background:rgba(45,140,255,0.05);transform:translateX(2px);}
.admin-table td{padding:14px 18px;border:none;font-size:13px;}
.admin-table td:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm);}
.admin-table td:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0;}

/* BUTTONS */
.btn{
    padding:10px 22px;border-radius:var(--radius-sm);font-weight:600;font-size:13px;
    cursor:pointer;border:none;transition:var(--transition);
    display:inline-flex;align-items:center;gap:7px;text-decoration:none;letter-spacing:.2px;
}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:0 4px 14px var(--primary-glow);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 22px var(--primary-glow);}
.btn-outline{background:transparent;border:1px solid var(--glass-border);color:var(--text-primary);}
.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:rgba(45,140,255,0.05);}

/* BADGES */
.badge{padding:5px 12px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;}
.badge-success{background:rgba(0,229,195,0.1);color:#00e5c3;border:1px solid rgba(0,229,195,0.2);}
.badge-warning{background:rgba(255,180,0,0.1);color:#ffb400;border:1px solid rgba(255,180,0,0.2);}
.badge-danger{background:rgba(255,92,108,0.1);color:#ff5c6c;border:1px solid rgba(255,92,108,0.2);}

/* STATUS BADGES */
.status-badge{padding:4px 11px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;display:inline-flex;align-items:center;gap:5px;}
.status-active{background:rgba(0,229,195,0.1);color:#00e5c3;border:1px solid rgba(0,229,195,0.18);}
.status-warning{background:rgba(255,180,0,0.1);color:#ffb400;border:1px solid rgba(255,180,0,0.18);}
.status-expired,.status-inactive{background:rgba(255,92,108,0.1);color:#ff5c6c;border:1px solid rgba(255,92,108,0.18);}

/* ACTION BUTTONS */
.action-buttons{display:flex;gap:6px;align-items:center;}
.btn-icon{
    width:33px;height:33px;display:flex;align-items:center;justify-content:center;
    border-radius:7px;background:var(--glass-bg);border:1px solid var(--glass-border);
    color:var(--text-secondary);cursor:pointer;transition:var(--transition);
}
.btn-icon:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px);box-shadow:0 4px 12px var(--primary-glow);}

/* FORMS */
.form-group{margin-bottom:20px;}
.form-group label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:8px;}
.form-control{
    width:100%;padding:11px 16px;
    background:var(--glass-bg);border:1px solid var(--glass-border);
    border-radius:var(--radius-sm);color:var(--text-primary);
    font-family:inherit;font-size:13px;transition:var(--transition);outline:none;
}
.form-control:focus{border-color:var(--primary);background:rgba(45,140,255,0.04);box-shadow:0 0 0 3px var(--primary-glow);}
select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%234f617a' 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 12px center;background-size:16px;padding-right:40px;}
body.light .form-control{background:#fff;}

/* FILTER ROW */
.filter-row{display:flex;gap:12px;align-items:center;flex-wrap:nowrap;overflow-x:auto;background:var(--glass-bg);padding:16px;border-radius:var(--radius-md);border:1px solid var(--glass-border);margin-bottom:24px;}
.filter-group{display:flex;align-items:center;gap:8px;background:var(--bg-panel);border:1px solid var(--glass-border);padding:7px 12px;border-radius:var(--radius-sm);flex:1;min-width:180px;}
.filter-group svg{color:var(--primary);opacity:.7;flex-shrink:0;}
.filter-group select,.filter-group input{background:transparent;border:none;color:var(--text-primary);width:100%;outline:none;font-size:13px;font-family:inherit;}

/* MODALS */
.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:2000;padding:20px;}
.modal.active{display:flex;animation:modalIn .25s ease;}
@keyframes modalIn{from{opacity:0;transform:scale(.97);}to{opacity:1;transform:scale(1);}}
.modal-content.glass{background:var(--bg-panel);border:1px solid var(--glass-border);border-radius:20px;padding:36px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:var(--panel-shadow);}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;}
.modal-header h2{font-size:20px;font-weight:700;}
.close-modal{background:none;border:none;color:var(--text-secondary);font-size:28px;cursor:pointer;line-height:1;transition:var(--transition);}
.close-modal:hover{color:#ff5c6c;}

/* PROFILE */
.profile{position:relative;}
.profile-trigger{
    display:flex;align-items:center;gap:10px;
    cursor:pointer;
    padding:5px 10px 5px 6px;
    border-radius:50px;
    border:1px solid transparent;
    transition:var(--transition);
    background:rgba(255,255,255,0.04);
}
.profile-trigger:hover{
    border-color:rgba(45,140,255,0.3);
    background:rgba(45,140,255,0.06);
}
/* Glowing avatar ring */
.profile img{
    width:36px;height:36px;
    border-radius:50%;
    border:2px solid transparent;
    background:linear-gradient(var(--bg-panel),var(--bg-panel)) padding-box,
                linear-gradient(135deg,var(--primary),var(--accent)) border-box;
    transition:var(--transition);
}
.profile-trigger:hover img{
    box-shadow:0 0 0 3px var(--primary-glow);
}
/* Dropdown */
.profile-menu{
    position:absolute;top:calc(100% + 10px);right:0;
    width:220px;
    background:var(--bg-panel);
    backdrop-filter:blur(20px);
    border:1px solid rgba(45,140,255,0.15);
    border-radius:var(--radius-lg);
    box-shadow:0 16px 40px rgba(0,0,0,0.5),0 0 0 1px rgba(45,140,255,0.08);
    display:none;overflow:hidden;z-index:1001;
}
.profile.active .profile-menu{
    display:block;
    animation:popup .25s cubic-bezier(.18,.89,.32,1.28);
}
@keyframes popup{from{opacity:0;transform:translateY(8px) scale(.97);}}
.profile-info{
    padding:16px 18px;
    border-bottom:1px solid var(--border-color);
    background:linear-gradient(135deg,rgba(45,140,255,0.06),rgba(0,229,195,0.04));
}
.profile-info strong{font-size:13px;font-weight:700;}
.profile-info p{font-size:11px;color:var(--text-muted);margin-top:2px;}
.profile-menu-item{padding:11px 18px;display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:var(--text-secondary);transition:var(--transition);text-decoration:none;background:none;border:none;width:100%;text-align:left;cursor:pointer;}
.profile-menu-item:hover{background:var(--glass-bg);color:var(--primary);padding-left:22px;}
.profile-menu-item.danger:hover{color:#ff5c6c;background:rgba(255,92,108,0.06);padding-left:22px;}
.profile-divider{height:1px;background:var(--border-color);}

/* SIDEBAR COLLAPSED */
body.sidebar-collapsed .sidebar{width:0;padding:0;margin-left:-255px;}
body.sidebar-collapsed .main{margin-left:0;}

/* MISC UTILITY ICONS */
svg.arrow,.sidebar-toggle svg,.search-icon,.input-icon,.btn svg,.action-buttons svg{width:18px;height:18px;flex-shrink:0;}

.page-loader{display:none;}
.error-message{display:none;}
.preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;}
.preview-item span{display:block;font-size:11px;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;}
.mock-asset-box{background:var(--glass-bg);border:2px dashed var(--glass-border);border-radius:10px;height:110px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px;margin-top:8px;}
.input-with-icon{position:relative;}
.input-with-icon .input-icon{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;}
.page-header-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;}

/* SIDEBAR TOGGLE */
.sidebar-toggle{cursor:pointer;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);background:var(--glass-bg);border:1px solid var(--glass-border);transition:var(--transition);}
.sidebar-toggle:hover{background:var(--primary);color:#fff;border-color:var(--primary);}

/* RESPONSIVE */
@media screen and (max-width:1024px){
    :root{--sidebar-width:230px;}
    .topbar{padding:0 20px;}
    .content{padding:22px;}
    .search-box{width:260px;}
}

@media screen and (max-width:768px){
    :root{--sidebar-width:270px;--topbar-height:58px;}
    .sidebar{left:calc(-1 * var(--sidebar-width));transition:transform .4s cubic-bezier(.4,0,.2,1);}
    body.sidebar-collapsed .sidebar{transform:translateX(0);margin-left:0;width:var(--sidebar-width);}
    body.sidebar-collapsed .brand-logo{width:auto!important;opacity:1!important;}
    body.sidebar-collapsed .main{margin-left:0;}
    .main{margin-left:0!important;}
    .premium-table-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;}
    table{min-width:580px;}
    .panel{padding:18px;margin-top:16px;}
    .topbar{padding:0 14px;}
    .topbar-right{gap:12px;}
    .search-box{display:none;}
    .sidebar-toggle{display:flex!important;}
    .topbar-logo{display:flex!important;align-items:center;height:32px;order:-1;margin-right:12px;}
    .topbar-logo img{height:100%;object-fit:contain;}
    .page-title h1{font-size:22px;}
    .cards{grid-template-columns:1fr!important;gap:12px!important;}
    .card{padding:18px;}
    .analytics-grid{grid-template-columns:1fr;}
    .profile-trigger span,.profile-trigger div{display:none;}
    .modal-content.glass{padding:20px;width:95%;border-radius:16px;max-height:85vh;}
    .filter-row{flex-direction:column;align-items:stretch;}
    .filter-group{min-width:100%;}
    body.sidebar-mobile-active::after{content:'';position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);z-index:999;}
    body.sidebar-mobile-active .sidebar{transform:translateX(var(--sidebar-width));}
}


@media screen and (max-width:480px){
    .page-header-actions{flex-direction:column;gap:12px;}
    .btn{width:100%;justify-content:center;}
}

/* ===== COMPACT MODULE HERO ===== */
.module-hero {
    background: linear-gradient(135deg, rgba(45,140,255,0.08) 0%, rgba(0,229,195,0.04) 100%);
    border: 1px solid rgba(45,140,255,0.15);
    border-radius: 14px;
    padding: 14px 20px;
    margin-bottom: 18px;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    gap: 16px;
}
.module-hero::before {
    content: '';
    position: absolute;
    top: -30px; right: -30px;
    width: 130px; height: 130px;
    background: radial-gradient(circle, rgba(45,140,255,0.10), transparent 70%);
    pointer-events: none;
}
.module-hero h1 {
    font-size: 1.05rem;
    margin-bottom: 3px;
    color: var(--text-primary);
}
.module-hero p {
    font-size: 12px;
    color: var(--text-muted);
    margin: 0;
    max-width: 600px;
    line-height: 1.5;
}
.module-hero-icon {
    width: 44px; height: 44px;
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(45,140,255,0.12);
    color: var(--primary);
    flex-shrink: 0;
}

/* ===== ATS PAGE VERTICAL DOT NAV ===== */
.ats-sidenav {
    position: fixed;
    right: 24px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    z-index: 500;
}
.ats-sidenav-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    border: 2px solid rgba(255,255,255,0.2);
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
}
.ats-sidenav-dot::before {
    content: attr(data-label);
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    background: var(--bg-panel);
    border: 1px solid var(--glass-border);
    color: var(--text-primary);
    font-size: 11px;
    font-weight: 600;
    white-space: nowrap;
    padding: 4px 10px;
    border-radius: 6px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
    box-shadow: 0 4px 12px rgba(0,0,0,0.4);
}
.ats-sidenav-dot:hover::before { opacity: 1; }
.ats-sidenav-dot:hover {
    background: rgba(45,140,255,0.5);
    border-color: var(--primary);
    transform: scale(1.5);
}
.ats-sidenav-dot.active {
    background: var(--primary);
    border-color: var(--primary);
    width: 10px;
    height: 26px;
    border-radius: 6px;
    box-shadow: 0 0 0 3px var(--primary-glow);
    transform: none;
}

/* ===== ATS OVERVIEW MODULE CARDS ===== */
.ats-section-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--text-muted);
    margin: 28px 0 12px;
    padding-left: 2px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.ats-section-label::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--glass-border);
}
.ats-module-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
    gap: 14px;
    margin-bottom: 4px;
}
.ats-module-card {
    background: var(--bg-panel);
    border: 1px solid var(--glass-border);
    border-radius: 14px;
    padding: 18px 20px;
    cursor: pointer;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 14px;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.ats-module-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(45,140,255,0.04), transparent 60%);
    opacity: 0;
    transition: opacity 0.3s;
}
.ats-module-card:hover::before { opacity: 1; }
.ats-module-card:hover {
    border-color: var(--primary);
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.4), 0 0 0 1px rgba(45,140,255,0.15);
}
.ats-module-card-icon {
    width: 42px; height: 42px;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: var(--transition);
}
.ats-module-card:hover .ats-module-card-icon { transform: scale(1.1); }
.ats-module-card-body h3 {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 3px;
    font-family: 'Inter', sans-serif;
    letter-spacing: 0;
}
.ats-module-card-body p {
    font-size: 11px;
    color: var(--text-muted);
    line-height: 1.4;
    margin: 0;
}
.ats-module-card-arrow {
    margin-left: auto;
    color: var(--text-muted);
    opacity: 0;
    transition: all 0.25s ease;
    flex-shrink: 0;
}
.ats-module-card:hover .ats-module-card-arrow {
    opacity: 1;
    color: var(--primary);
    transform: translateX(3px);
}
