:root {
    --primary-red: #E71D36;
    --dark-red: #D6142E;
    --primary-blue: #123F9E;
    --dark-navy: #0E2F75;
    --bg-main: #F8F9FB;
    --bg-card: #FFFFFF;
    --bg-sidebar: #FAFAFA;
    --border-color: #E5E7EB;
    --text-primary: #111827;
    --text-secondary: #6B7280;
    --text-muted: #9CA3AF;
    --success: #10B981;
    --warning: #F59E0B;
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --shadow-md: 0 4px 6px rgba(0,0,0,0.07);
    --shadow-lg: 0 10px 15px rgba(0,0,0,0.08);
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --sidebar-w: 256px;
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }

html,body,#root { height:100%; width:100%; }

body {
    font-family:'Inter','Segoe UI','Roboto',sans-serif;
    background-color:var(--bg-main);
    color:var(--text-primary);
    line-height:1.6;
    font-size:14px;
    -webkit-font-smoothing:antialiased;
}

a { text-decoration:none; color:inherit; }

button { font-family:inherit; cursor:pointer; }

input,textarea,select { font-family:inherit; }

.app-layout {
    display:flex;
    height:100vh;
    overflow:hidden;
}

.sidebar {
    width:var(--sidebar-w);
    min-width:var(--sidebar-w);
    background:var(--bg-sidebar);
    border-right:1px solid var(--border-color);
    display:flex;
    flex-direction:column;
    overflow-y:auto;
    overflow-x:hidden;
    z-index:100;
    flex-shrink:0;
}

.sidebar-brand {
    padding:20px var(--spacing-lg);
    border-bottom:1px solid var(--border-color);
    display:flex;
    align-items:center;
    gap:var(--spacing-md);
    min-height:64px;
    flex-shrink:0;
}

.sidebar-logo-img {
    width:140px;
    height:auto;
    object-fit:contain;
    display:block;
}

.brand-icon-fallback {
    width:36px;
    height:36px;
    background:var(--primary-red);
    border-radius:var(--radius-md);
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    font-weight:800;
    font-size:16px;
    flex-shrink:0;
}

.nav-section {
    padding:var(--spacing-md) var(--spacing-sm);
}

.nav-section-label {
    font-size:10px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:1px;
    color:var(--text-muted);
    padding:0 var(--spacing-sm) var(--spacing-sm) var(--spacing-sm);
}

.nav-item {
    list-style:none;
    margin-bottom:2px;
}

.nav-link {
    display:flex;
    align-items:center;
    gap:10px;
    padding:9px var(--spacing-md);
    border-radius:var(--radius-md);
    color:var(--text-secondary);
    font-size:13.5px;
    font-weight:500;
    transition:all 0.15s ease;
    position:relative;
}

.nav-link:hover {
    background:rgba(231,29,54,0.06);
    color:var(--primary-red);
}

.nav-link.active {
    background:rgba(231,29,54,0.1);
    color:var(--primary-red);
    font-weight:600;
}

.nav-icon {
    width:18px;
    height:18px;
    flex-shrink:0;
    display:flex;
    align-items:center;
    justify-content:center;
    font-style:normal;
}

.nav-badge {
    margin-left:auto;
    min-width:18px;
    height:18px;
    background:var(--primary-red);
    color:#fff;
    border-radius:9px;
    font-size:10px;
    font-weight:700;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:0 5px;
}

.sidebar-footer {
    margin-top:auto;
    padding:var(--spacing-md) var(--spacing-lg);
    border-top:1px solid var(--border-color);
}

.sync-row {
    display:flex;
    align-items:center;
    gap:6px;
    font-size:11px;
    color:var(--text-muted);
}

.sync-dot {
    width:7px;
    height:7px;
    border-radius:50%;
    background:var(--success);
    flex-shrink:0;
    transition:background 0.3s;
}

.sync-dot.syncing {
    background:var(--warning);
    animation:pulseDot 1s ease-in-out infinite;
}

.main-content {
    flex:1;
    display:flex;
    flex-direction:column;
    overflow:hidden;
    min-width:0;
}

.topbar {
    background:var(--bg-card);
    border-bottom:2px solid var(--primary-red);
    padding:0 var(--spacing-xl);
    display:flex;
    align-items:center;
    justify-content:space-between;
    height:64px;
    flex-shrink:0;
    box-shadow:var(--shadow-sm);
    gap:var(--spacing-md);
}

.topbar-left {
    display:flex;
    align-items:center;
    gap:var(--spacing-md);
}

.topbar-title {
    font-size:18px;
    font-weight:700;
    color:var(--text-primary);
    white-space:nowrap;
}

.topbar-right {
    display:flex;
    align-items:center;
    gap:var(--spacing-md);
    margin-left:auto;
}

.gmail-status {
    display:flex;
    align-items:center;
    gap:6px;
    font-size:12px;
    color:var(--text-muted);
}

.gmail-dot {
    width:8px;
    height:8px;
    border-radius:50%;
    background:#D1D5DB;
    transition:background 0.3s;
}

.gmail-dot.connected { background:var(--success); box-shadow:0 0 0 3px rgba(16,185,129,0.15); }
.gmail-dot.disconnected { background:var(--warning); animation:pulseDot 2s ease-in-out infinite; }

.notif-btn {
    position:relative;
    width:36px;
    height:36px;
    border:1px solid var(--border-color);
    border-radius:var(--radius-md);
    background:transparent;
    display:flex;
    align-items:center;
    justify-content:center;
    color:var(--text-secondary);
    transition:all 0.15s;
    font-size:16px;
}

.notif-btn:hover { background:var(--bg-main); color:var(--primary-red); border-color:var(--primary-red); }

.notif-badge {
    position:absolute;
    top:-4px;
    right:-4px;
    min-width:16px;
    height:16px;
    background:var(--primary-red);
    color:#fff;
    border-radius:8px;
    font-size:9px;
    font-weight:700;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:0 3px;
    border:2px solid var(--bg-card);
}

.user-pill {
    display:flex;
    align-items:center;
    gap:var(--spacing-sm);
    padding:6px 10px 6px 6px;
    border:1px solid var(--border-color);
    border-radius:var(--radius-xl);
    background:var(--bg-card);
    cursor:pointer;
    transition:all 0.15s;
}

.user-pill:hover { border-color:var(--primary-red); background:var(--bg-main); }

.user-avatar {
    width:28px;
    height:28px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:700;
    font-size:11px;
    color:#fff;
    flex-shrink:0;
    overflow:hidden;
}

.user-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }

.avatar-blue { background:#3B82F6; }
.avatar-purple { background:#8B5CF6; }
.avatar-teal { background:#0D9488; }
.avatar-brown { background:#92400E; }
.avatar-red { background:var(--primary-red); }
.avatar-navy { background:var(--dark-navy); }

.user-pill-info { line-height:1.2; }
.user-pill-name { font-size:12px; font-weight:600; color:var(--text-primary); }
.user-pill-role { font-size:10px; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.4px; }

.role-badge {
    padding:2px 8px;
    border-radius:20px;
    font-size:10px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:0.3px;
}

.role-badge.admin { background:rgba(18,63,158,0.1); color:var(--primary-blue); border:1px solid rgba(18,63,158,0.2); }
.role-badge.user { background:var(--bg-main); color:var(--text-muted); border:1px solid var(--border-color); }

.logout-btn {
    padding:7px var(--spacing-md);
    background:transparent;
    border:1px solid var(--border-color);
    border-radius:var(--radius-md);
    color:var(--text-secondary);
    font-size:13px;
    font-weight:500;
    transition:all 0.15s;
}

.logout-btn:hover { background:rgba(231,29,54,0.05); color:var(--primary-red); border-color:var(--primary-red); }

.content-area {
    flex:1;
    overflow-y:auto;
    padding:var(--spacing-xl);
}

.page-header {
    margin-bottom:var(--spacing-xl);
}

.page-title {
    font-size:26px;
    font-weight:700;
    color:var(--text-primary);
    margin-bottom:4px;
    letter-spacing:-0.3px;
}

.page-subtitle {
    font-size:14px;
    color:var(--text-secondary);
}

.btn {
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:9px var(--spacing-md);
    border:none;
    border-radius:var(--radius-md);
    font-size:13.5px;
    font-weight:600;
    cursor:pointer;
    transition:all 0.15s ease;
    white-space:nowrap;
}

.btn:disabled { opacity:0.6; cursor:not-allowed; }

.btn-primary { background:var(--primary-red); color:#fff; }
.btn-primary:hover:not(:disabled) { background:var(--dark-red); box-shadow:var(--shadow-md); }

.btn-secondary { background:var(--bg-card); color:var(--text-primary); border:1px solid var(--border-color); }
.btn-secondary:hover:not(:disabled) { background:var(--bg-main); }

.btn-blue { background:var(--primary-blue); color:#fff; }
.btn-blue:hover:not(:disabled) { background:var(--dark-navy); }

.btn-success { background:#10B981; color:#fff; }
.btn-success:hover:not(:disabled) { background:#059669; }

.btn-warning { background:#F59E0B; color:#fff; }
.btn-warning:hover:not(:disabled) { background:#D97706; }

.btn-danger-outline {
    background:transparent;
    color:var(--primary-red);
    border:1px solid rgba(231,29,54,0.3);
    padding:5px 10px;
    border-radius:var(--radius-sm);
    font-size:12px;
    font-weight:600;
}

.btn-danger-outline:hover { background:var(--primary-red); color:#fff; border-color:var(--primary-red); }

.btn-sm { padding:6px 10px; font-size:12px; }

.btn-hold {
    background:rgba(245,158,11,0.1);
    color:#D97706;
    border:1px solid rgba(245,158,11,0.35);
}

.btn-hold:hover { background:rgba(245,158,11,0.2); }

.btn-hold.active {
    background:#F59E0B;
    color:#fff;
    border-color:#F59E0B;
}

.stats-grid {
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
    gap:var(--spacing-md);
    margin-bottom:var(--spacing-xl);
}

.stat-card {
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--radius-lg);
    padding:var(--spacing-lg);
    box-shadow:var(--shadow-sm);
    display:flex;
    align-items:center;
    gap:var(--spacing-md);
    border-left:4px solid var(--border-color);
    transition:box-shadow 0.15s;
}

.stat-card:hover { box-shadow:var(--shadow-md); }

.stat-icon-wrap {
    width:44px;
    height:44px;
    border-radius:var(--radius-md);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:20px;
    flex-shrink:0;
}

.stat-body { flex:1; min-width:0; }

.stat-label {
    font-size:11px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:0.5px;
    color:var(--text-muted);
    margin-bottom:4px;
}

.stat-value {
    font-size:28px;
    font-weight:700;
    color:var(--text-primary);
    line-height:1;
}

.stat-sub { font-size:12px; color:var(--text-muted); margin-top:4px; }

.stat-blue  { border-left-color:#3B82F6; }
.stat-blue  .stat-icon-wrap { background:rgba(59,130,246,0.1); }
.stat-purple { border-left-color:#8B5CF6; }
.stat-purple .stat-icon-wrap { background:rgba(139,92,246,0.1); }
.stat-amber { border-left-color:#F59E0B; }
.stat-amber .stat-icon-wrap { background:rgba(245,158,11,0.1); }
.stat-red   { border-left-color:var(--primary-red); }
.stat-red   .stat-icon-wrap { background:rgba(231,29,54,0.1); }
.stat-green { border-left-color:var(--success); }
.stat-green .stat-icon-wrap { background:rgba(16,185,129,0.1); }

.toolbar {
    display:flex;
    align-items:center;
    gap:var(--spacing-md);
    margin-bottom:var(--spacing-md);
    flex-wrap:wrap;
}

.search-bar {
    display:flex;
    align-items:center;
    flex:1;
    min-width:200px;
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--radius-lg);
    padding:0 var(--spacing-md);
    gap:var(--spacing-sm);
    transition:border-color 0.15s;
}

.search-bar:focus-within { border-color:var(--primary-red); }

.search-bar input {
    flex:1;
    background:transparent;
    border:none;
    outline:none;
    padding:10px 0;
    font-size:13.5px;
    color:var(--text-primary);
}

.search-bar input::placeholder { color:var(--text-muted); }

.search-icon { color:var(--text-muted); font-size:14px; font-style:normal; }

.filter-row {
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:var(--spacing-md);
    margin-bottom:var(--spacing-md);
    flex-wrap:wrap;
}

.pill-group {
    display:flex;
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--radius-lg);
    padding:3px;
    gap:2px;
}

.pill-btn {
    padding:5px 14px;
    border:none;
    background:transparent;
    border-radius:calc(var(--radius-lg) - 3px);
    font-size:12.5px;
    font-weight:500;
    color:var(--text-secondary);
    cursor:pointer;
    transition:all 0.15s;
    white-space:nowrap;
}

.pill-btn:hover { background:var(--bg-main); color:var(--text-primary); }
.pill-btn.active { background:var(--primary-blue); color:#fff; font-weight:600; }

.tab-group {
    display:flex;
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--radius-lg);
    padding:3px;
    gap:2px;
}

.tab-btn {
    display:flex;
    align-items:center;
    gap:6px;
    padding:6px 16px;
    border:none;
    background:transparent;
    border-radius:calc(var(--radius-lg) - 3px);
    font-size:13px;
    font-weight:500;
    color:var(--text-secondary);
    cursor:pointer;
    transition:all 0.15s;
    white-space:nowrap;
}

.tab-btn:hover { background:var(--bg-main); color:var(--text-primary); }

.tab-btn.active[data-tab="pending"] { background:rgba(245,158,11,0.1); color:#B45309; font-weight:700; }
.tab-btn.active[data-tab="completed"] { background:rgba(16,185,129,0.1); color:#059669; font-weight:700; }

.tab-count {
    min-width:18px;
    height:18px;
    background:var(--bg-main);
    color:var(--text-muted);
    border-radius:9px;
    font-size:10px;
    font-weight:700;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:0 5px;
}

.tab-btn.active[data-tab="pending"] .tab-count { background:rgba(245,158,11,0.2); color:#B45309; }
.tab-btn.active[data-tab="completed"] .tab-count { background:rgba(16,185,129,0.2); color:#059669; }

.table-card {
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
}

.table {
    width:100%;
    border-collapse:collapse;
}

.table thead {
    background:var(--bg-main);
    border-bottom:1px solid var(--border-color);
}

.table th {
    padding:11px var(--spacing-md);
    text-align:left;
    font-size:11px;
    font-weight:700;
    color:var(--text-secondary);
    text-transform:uppercase;
    letter-spacing:0.5px;
    white-space:nowrap;
}

.table td {
    padding:12px var(--spacing-md);
    border-bottom:1px solid var(--border-color);
    font-size:13.5px;
    color:var(--text-primary);
    vertical-align:middle;
}

.table tbody tr:last-child td { border-bottom:none; }
.table tbody tr:hover td { background:rgba(18,63,158,0.025); }

.table tbody tr.row-removing {
    opacity:0;
    transform:translateX(20px);
    transition:opacity 0.3s,transform 0.3s;
}

.record-row { cursor:pointer; }

.caller-name { font-weight:600; color:var(--text-primary); line-height:1.2; }
.caller-num { font-size:11.5px; color:var(--text-muted); margin-top:2px; }

.transcript-preview {
    font-size:12.5px;
    color:var(--text-secondary);
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    max-width:320px;
    display:block;
}

.time-col { white-space:nowrap; font-size:12px; color:var(--text-muted); font-variant-numeric:tabular-nums; }

.status-pill {
    display:inline-flex;
    align-items:center;
    gap:4px;
    padding:3px 10px;
    border-radius:20px;
    font-size:11.5px;
    font-weight:600;
}

.status-pill.pending { background:rgba(245,158,11,0.1); color:#D97706; }
.status-pill.solved { background:rgba(16,185,129,0.1); color:#059669; }
.status-pill.held { background:rgba(245,158,11,0.12); color:#B45309; border:1px solid rgba(245,158,11,0.3); }

.hold-indicator {
    display:inline-flex;
    align-items:center;
    gap:4px;
    padding:2px 8px;
    background:rgba(245,158,11,0.1);
    border:1px solid rgba(245,158,11,0.3);
    border-radius:20px;
    font-size:11px;
    color:#B45309;
    font-weight:600;
    margin-top:3px;
}

.action-btns { display:flex; gap:6px; align-items:center; }

.badge-incomplete {
    display:inline-flex;
    align-items:center;
    gap:4px;
    padding:2px 10px;
    background:rgba(245,158,11,0.08);
    color:#B45309;
    border-radius:20px;
    font-size:11.5px;
    font-weight:500;
    border:1px solid rgba(245,158,11,0.3);
    white-space:nowrap;
}

.badge-failed {
    display:inline-flex;
    align-items:center;
    gap:4px;
    padding:2px 8px;
    background:rgba(231,29,54,0.08);
    color:var(--primary-red);
    border-radius:20px;
    font-size:11.5px;
    font-weight:500;
    border:1px solid rgba(231,29,54,0.2);
}

.processing-text { font-size:12px; color:var(--text-muted); font-style:italic; }

.date-group-row td {
    padding:0 !important;
    border-bottom:none !important;
    background:transparent !important;
}

.date-group-header {
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:12px var(--spacing-md) 4px;
}

.date-group-label {
    font-size:11px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:0.6px;
    color:var(--text-muted);
}

.date-group-count {
    font-size:10px;
    font-weight:600;
    color:var(--text-muted);
    background:var(--bg-main);
    border:1px solid var(--border-color);
    border-radius:10px;
    padding:1px 7px;
}

.empty-state {
    text-align:center;
    padding:60px var(--spacing-lg);
    color:var(--text-muted);
}

.empty-state-icon { font-size:40px; margin-bottom:var(--spacing-md); }
.empty-state-title { font-size:15px; font-weight:600; color:var(--text-secondary); margin-bottom:6px; }
.empty-state-sub { font-size:13px; }

.loading-state {
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    padding:60px;
    color:var(--text-muted);
    gap:var(--spacing-md);
}

.modal-overlay {
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.45);
    display:flex;
    align-items:center;
    justify-content:center;
    z-index:1000;
    padding:var(--spacing-lg);
    backdrop-filter:blur(2px);
}

.modal {
    background:var(--bg-card);
    border-radius:var(--radius-xl);
    width:100%;
    max-width:620px;
    max-height:90vh;
    overflow-y:auto;
    box-shadow:0 20px 40px rgba(0,0,0,0.15);
    animation:modalIn 0.2s ease;
}

@keyframes modalIn { from { opacity:0; transform:translateY(16px) scale(0.98); } to { opacity:1; transform:none; } }

.modal-lg { max-width:760px; }

.modal-header {
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);
    border-bottom:1px solid var(--border-color);
    gap:var(--spacing-md);
}

.modal-title { font-size:17px; font-weight:700; color:var(--text-primary); }
.modal-subtitle { font-size:12px; color:var(--text-muted); margin-top:2px; }

.modal-close {
    width:30px;
    height:30px;
    border:none;
    background:var(--bg-main);
    border-radius:var(--radius-md);
    display:flex;
    align-items:center;
    justify-content:center;
    color:var(--text-muted);
    font-size:16px;
    flex-shrink:0;
    transition:all 0.15s;
}

.modal-close:hover { background:rgba(231,29,54,0.08); color:var(--primary-red); }

.modal-body { padding:var(--spacing-xl); }

.modal-footer {
    padding:var(--spacing-md) var(--spacing-xl) var(--spacing-xl);
    display:flex;
    gap:var(--spacing-sm);
    justify-content:flex-end;
}

.detail-grid { margin-bottom:var(--spacing-lg); }

.detail-row {
    display:flex;
    gap:var(--spacing-md);
    padding:10px 0;
    border-bottom:1px solid var(--border-color);
    align-items:flex-start;
}

.detail-row:last-child { border-bottom:none; }

.detail-label {
    min-width:90px;
    font-size:11px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:0.3px;
    color:var(--text-muted);
    padding-top:2px;
}

.detail-val { font-size:14px; color:var(--text-primary); flex:1; }

.transcript-section { margin-top:var(--spacing-md); }

.transcript-section-header {
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:var(--spacing-sm);
}

.transcript-section-label {
    font-size:11px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:0.5px;
    color:var(--text-muted);
}

.transcript-block {
    padding:var(--spacing-lg);
    background:var(--bg-main);
    border-radius:var(--radius-md);
    border:1px solid var(--border-color);
    max-height:280px;
    overflow-y:auto;
    line-height:1.85;
    font-size:14px;
    color:var(--text-primary);
    white-space:pre-wrap;
    word-break:break-word;
}

.transcript-empty { text-align:center; padding:var(--spacing-lg); }

.copy-btn {
    display:inline-flex;
    align-items:center;
    gap:4px;
    padding:4px 10px;
    background:transparent;
    border:1px solid var(--border-color);
    border-radius:var(--radius-sm);
    font-size:11.5px;
    font-weight:600;
    color:var(--text-secondary);
    cursor:pointer;
    transition:all 0.15s;
}

.copy-btn:hover { background:var(--primary-blue); color:#fff; border-color:var(--primary-blue); }

.copy-btn.copied { background:var(--success); color:#fff; border-color:var(--success); }

.comment-list { display:flex; flex-direction:column; gap:var(--spacing-md); margin-bottom:var(--spacing-md); }

.comment-item {
    display:flex;
    gap:var(--spacing-sm);
}

.comment-avatar {
    width:28px;
    height:28px;
    border-radius:50%;
    flex-shrink:0;
    font-size:10px;
}

.comment-body {
    flex:1;
    min-width:0;
}

.comment-meta {
    font-size:11px;
    color:var(--text-muted);
    margin-bottom:3px;
}

.comment-meta strong { color:var(--text-primary); }

.comment-text {
    background:var(--bg-main);
    border:1px solid var(--border-color);
    border-radius:var(--radius-md);
    padding:8px 12px;
    font-size:13px;
    line-height:1.5;
    color:var(--text-primary);
}

.comment-input-row { display:flex; gap:var(--spacing-sm); align-items:flex-end; }
.comment-input-row textarea {
    flex:1;
    padding:9px 12px;
    border:1px solid var(--border-color);
    border-radius:var(--radius-md);
    font-size:13px;
    resize:none;
    min-height:72px;
    background:var(--bg-main);
    color:var(--text-primary);
    transition:border-color 0.15s;
}
.comment-input-row textarea:focus { outline:none; border-color:var(--primary-red); background:#fff; }

.phone-link { color:var(--primary-blue); font-weight:600; }
.phone-link:hover { text-decoration:underline; }

.form-group { margin-bottom:var(--spacing-lg); }

.form-label {
    display:block;
    font-size:12px;
    font-weight:600;
    color:var(--text-primary);
    margin-bottom:6px;
    text-transform:uppercase;
    letter-spacing:0.3px;
}

.form-input,.form-select,.form-textarea {
    width:100%;
    padding:10px var(--spacing-md);
    border:1px solid var(--border-color);
    border-radius:var(--radius-md);
    font-size:14px;
    background:var(--bg-card);
    color:var(--text-primary);
    transition:border-color 0.15s;
}

.form-input:focus,.form-select:focus,.form-textarea:focus {
    outline:none;
    border-color:var(--primary-red);
    box-shadow:0 0 0 3px rgba(231,29,54,0.08);
}

.form-textarea { resize:vertical; min-height:80px; }

.spinner {
    display:inline-block;
    width:14px;
    height:14px;
    border:2px solid rgba(255,255,255,0.3);
    border-top-color:currentColor;
    border-radius:50%;
    animation:spin 0.6s linear infinite;
    flex-shrink:0;
}

.spinner-dark {
    border:2px solid var(--border-color);
    border-top-color:var(--primary-red);
}

@keyframes spin { to { transform:rotate(360deg); } }

@keyframes pulseDot {
    0%,100% { opacity:1; }
    50% { opacity:0.4; }
}

@keyframes slideDown {
    from { opacity:0; transform:translateY(-8px); }
    to { opacity:1; transform:none; }
}

@keyframes fadeIn {
    from { opacity:0; }
    to { opacity:1; }
}

.notif-panel {
    position:fixed;
    top:68px;
    right:var(--spacing-xl);
    width:360px;
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow-lg);
    z-index:500;
    animation:slideDown 0.15s ease;
    max-height:480px;
    display:flex;
    flex-direction:column;
    overflow:hidden;
}

.notif-panel-header {
    padding:var(--spacing-md) var(--spacing-lg);
    border-bottom:1px solid var(--border-color);
    display:flex;
    align-items:center;
    justify-content:space-between;
    flex-shrink:0;
}

.notif-panel-title { font-size:14px; font-weight:700; color:var(--text-primary); }

.notif-list { overflow-y:auto; flex:1; }

.notif-item {
    padding:12px var(--spacing-lg);
    border-bottom:1px solid var(--border-color);
    cursor:pointer;
    transition:background 0.1s;
    display:flex;
    gap:var(--spacing-sm);
    align-items:flex-start;
}

.notif-item:last-child { border-bottom:none; }
.notif-item:hover { background:var(--bg-main); }
.notif-item.unread { background:rgba(18,63,158,0.03); }

.notif-dot {
    width:8px;
    height:8px;
    border-radius:50%;
    flex-shrink:0;
    margin-top:5px;
}

.notif-dot.info { background:var(--primary-blue); }
.notif-dot.success { background:var(--success); }
.notif-dot.warning { background:var(--warning); }
.notif-dot.assignment { background:#8B5CF6; }
.notif-dot.read { background:var(--border-color); }

.notif-msg { font-size:12.5px; color:var(--text-primary); line-height:1.4; flex:1; }
.notif-time { font-size:10.5px; color:var(--text-muted); margin-top:2px; }

.notif-empty { padding:40px; text-align:center; color:var(--text-muted); font-size:13px; }

.toast-container {
    position:fixed;
    top:var(--spacing-lg);
    right:var(--spacing-lg);
    z-index:2000;
    display:flex;
    flex-direction:column;
    gap:var(--spacing-sm);
    pointer-events:none;
}

.toast {
    padding:12px var(--spacing-lg);
    border-radius:var(--radius-lg);
    border-left:4px solid;
    font-size:13.5px;
    font-weight:500;
    box-shadow:var(--shadow-lg);
    animation:slideDown 0.2s ease;
    pointer-events:all;
    max-width:360px;
    display:flex;
    align-items:center;
    gap:var(--spacing-sm);
}

.toast-success { background:#F0FDF4; border-left-color:var(--success); color:#065F46; }
.toast-error { background:#FEF2F2; border-left-color:var(--primary-red); color:#7F1D1D; }
.toast-info { background:#EFF6FF; border-left-color:var(--primary-blue); color:#1E3A8A; }
.toast-warning { background:#FFFBEB; border-left-color:var(--warning); color:#78350F; }

.ranking-table { width:100%; }

.ranking-row {
    display:flex;
    align-items:center;
    gap:var(--spacing-md);
    padding:12px var(--spacing-lg);
    border-bottom:1px solid var(--border-color);
    transition:background 0.1s;
}

.ranking-row:last-child { border-bottom:none; }
.ranking-row:hover { background:var(--bg-main); }

.rank-num {
    width:28px;
    height:28px;
    border-radius:50%;
    background:var(--bg-main);
    border:1px solid var(--border-color);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:12px;
    font-weight:700;
    color:var(--text-muted);
    flex-shrink:0;
}

.rank-num.gold { background:#FEF3C7; border-color:#F59E0B; color:#D97706; }
.rank-num.silver { background:#F3F4F6; border-color:#9CA3AF; color:#6B7280; }
.rank-num.bronze { background:#FEF2F2; border-color:#EF9F8C; color:#C2410C; }

.rank-info { flex:1; min-width:0; }
.rank-name { font-size:14px; font-weight:600; color:var(--text-primary); }
.rank-email { font-size:11.5px; color:var(--text-muted); }

.rank-bar-wrap { flex:2; min-width:100px; }
.rank-bar-bg { height:6px; background:var(--bg-main); border-radius:3px; overflow:hidden; }
.rank-bar-fill { height:100%; border-radius:3px; background:linear-gradient(90deg,var(--primary-blue),var(--primary-red)); transition:width 0.6s ease; }

.rank-count { font-size:18px; font-weight:700; color:var(--text-primary); min-width:40px; text-align:right; }
.rank-label { font-size:11px; color:var(--text-muted); text-align:right; }

.chart-container {
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--radius-lg);
    padding:var(--spacing-xl);
    box-shadow:var(--shadow-sm);
}

.chart-title { font-size:14px; font-weight:700; color:var(--text-primary); margin-bottom:var(--spacing-lg); }

.bar-chart {
    display:flex;
    align-items:flex-end;
    gap:var(--spacing-md);
    height:160px;
}

.bar-col {
    flex:1;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:4px;
    height:100%;
    justify-content:flex-end;
}

.bar-fill {
    width:100%;
    max-width:48px;
    border-radius:var(--radius-sm) var(--radius-sm) 0 0;
    background:linear-gradient(180deg,var(--primary-red),var(--dark-red));
    min-height:4px;
    transition:height 0.4s ease;
}

.bar-val { font-size:11px; font-weight:700; color:var(--text-primary); }
.bar-label { font-size:10px; color:var(--text-muted); }

.admin-grid {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:var(--spacing-lg);
    margin-bottom:var(--spacing-lg);
}

.section-card {
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
}

.section-card-header {
    padding:var(--spacing-md) var(--spacing-lg);
    border-bottom:1px solid var(--border-color);
    display:flex;
    align-items:center;
    justify-content:space-between;
}

.section-card-title { font-size:14px; font-weight:700; color:var(--text-primary); }

.perf-row {
    display:flex;
    align-items:center;
    gap:var(--spacing-md);
    padding:10px var(--spacing-lg);
    border-bottom:1px solid var(--border-color);
    transition:background 0.1s;
}

.perf-row:last-child { border-bottom:none; }
.perf-row:hover { background:var(--bg-main); }

.perf-info { flex:1; min-width:0; }
.perf-name { font-size:13px; font-weight:600; color:var(--text-primary); }
.perf-email { font-size:11px; color:var(--text-muted); }

.perf-stats { text-align:right; }
.perf-today { font-size:18px; font-weight:700; color:var(--primary-blue); line-height:1; }
.perf-total { font-size:11px; color:var(--text-muted); }

.user-select-grid {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:var(--spacing-sm);
    max-height:220px;
    overflow-y:auto;
    margin-bottom:var(--spacing-md);
}

.user-select-item {
    display:flex;
    align-items:center;
    gap:var(--spacing-sm);
    padding:8px var(--spacing-md);
    border:2px solid var(--border-color);
    border-radius:var(--radius-md);
    cursor:pointer;
    transition:all 0.15s;
    background:var(--bg-card);
}

.user-select-item:hover { border-color:var(--primary-blue); background:rgba(18,63,158,0.03); }
.user-select-item.selected { border-color:var(--primary-blue); background:rgba(18,63,158,0.06); }

.user-select-name { font-size:13px; font-weight:600; color:var(--text-primary); }
.user-select-email { font-size:11px; color:var(--text-muted); }

.login-page {
    min-height:100vh;
    background:linear-gradient(135deg,#0E2F75 0%,#123F9E 55%,#1a1a2e 100%);
    display:flex;
    align-items:center;
    justify-content:center;
    position:relative;
    overflow:hidden;
}

.login-shapes {
    position:absolute;
    inset:0;
    pointer-events:none;
}

.login-shape {
    position:absolute;
    border-radius:50%;
    opacity:0.07;
    background:#fff;
}

.ls1 { width:500px; height:500px; top:-200px; right:-100px; animation:floatShape 8s ease-in-out infinite; }
.ls2 { width:300px; height:300px; bottom:-100px; left:-80px; animation:floatShape 6s ease-in-out infinite reverse; }
.ls3 { width:200px; height:200px; top:40%; left:15%; animation:floatShape 10s ease-in-out infinite 2s; }

@keyframes floatShape {
    0%,100% { transform:translateY(0) scale(1); }
    50% { transform:translateY(-20px) scale(1.04); }
}

.login-card {
    background:#fff;
    border-radius:20px;
    padding:48px 44px;
    width:100%;
    max-width:440px;
    box-shadow:0 32px 64px rgba(0,0,0,0.25),0 0 0 1px rgba(255,255,255,0.05);
    text-align:center;
    position:relative;
    z-index:1;
    animation:cardIn 0.4s cubic-bezier(0.34,1.56,0.64,1);
}

@keyframes cardIn {
    from { opacity:0; transform:translateY(24px) scale(0.97); }
    to { opacity:1; transform:none; }
}

.login-logo-wrap {
    margin-bottom:28px;
    display:flex;
    align-items:center;
    justify-content:center;
}

.login-logo-img {
    max-width:200px;
    max-height:80px;
    object-fit:contain;
}

.login-title { font-size:24px; font-weight:700; color:var(--text-primary); margin-bottom:6px; letter-spacing:-0.3px; }
.login-subtitle { font-size:14px; color:var(--text-muted); margin-bottom:var(--spacing-xl); line-height:1.5; }

.google-signin-btn {
    width:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    padding:14px var(--spacing-lg);
    border:2px solid var(--border-color);
    border-radius:var(--radius-lg);
    background:#fff;
    color:var(--text-primary);
    font-size:15px;
    font-weight:600;
    cursor:pointer;
    transition:all 0.2s ease;
    font-family:inherit;
    text-decoration:none;
}

.google-signin-btn:hover {
    border-color:var(--primary-blue);
    box-shadow:0 4px 12px rgba(18,63,158,0.15);
    transform:translateY(-1px);
}

.google-icon {
    width:20px;
    height:20px;
    flex-shrink:0;
}

.login-divider {
    display:flex;
    align-items:center;
    gap:var(--spacing-md);
    margin:var(--spacing-lg) 0;
    color:var(--text-muted);
    font-size:12px;
}

.login-divider::before,.login-divider::after {
    content:'';
    flex:1;
    height:1px;
    background:var(--border-color);
}

.login-footer {
    margin-top:var(--spacing-xl);
    font-size:12px;
    color:var(--text-muted);
    display:flex;
    align-items:center;
    justify-content:center;
    gap:6px;
}

.login-error {
    margin-top:var(--spacing-md);
    padding:12px var(--spacing-md);
    background:rgba(231,29,54,0.07);
    border:1px solid rgba(231,29,54,0.2);
    border-radius:var(--radius-md);
    color:var(--primary-red);
    font-size:13px;
    font-weight:500;
}

.settings-section { margin-bottom:var(--spacing-xl); }
.settings-section-title {
    font-size:14px;
    font-weight:700;
    color:var(--text-primary);
    margin-bottom:var(--spacing-md);
    padding-bottom:var(--spacing-sm);
    border-bottom:1px solid var(--border-color);
}

.users-table-wrap {
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
}

@media (max-width:1024px) {
    .admin-grid { grid-template-columns:1fr; }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:768px) {
    :root { --sidebar-w:0px; }
    .sidebar { display:none; }
    .content-area { padding:var(--spacing-md); }
    .stats-grid { grid-template-columns:1fr; }
    .topbar { padding:0 var(--spacing-md); }
    .topbar-title { font-size:15px; }
    .user-pill-info { display:none; }
    .bar-chart { height:100px; }
    .filter-row { flex-direction:column; align-items:stretch; }
    .user-select-grid { grid-template-columns:1fr; }
}

@media (max-width:480px) {
    .modal { border-radius:0; max-height:100vh; }
    .login-card { padding:36px 24px; border-radius:16px; }
    .notif-panel { right:var(--spacing-md); left:var(--spacing-md); width:auto; }
}

.text-center { text-align:center; }
.fw-600 { font-weight:600; }
.fw-700 { font-weight:700; }
.mt-sm { margin-top:var(--spacing-sm); }
.mt-md { margin-top:var(--spacing-md); }
.mt-lg { margin-top:var(--spacing-lg); }
.mb-md { margin-bottom:var(--spacing-md); }
.mb-lg { margin-bottom:var(--spacing-lg); }
.gap-sm { gap:var(--spacing-sm); }
.gap-md { gap:var(--spacing-md); }
.flex { display:flex; }
.flex-col { flex-direction:column; }
.items-center { align-items:center; }
.justify-between { justify-content:space-between; }
.hidden { display:none !important; }
.truncate { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }