/* ===== CSS CUSTOM PROPERTIES ===== */
:root{
  --bg-primary:#0a0b0e;
  --bg-secondary:#111318;
  --bg-hover:#1a1d24;
  --text-primary:#f1f5f9;
  --text-secondary:#94a3b8;
  --text-muted:#64748b;
  --border:#1e2028;
  --accent:#f97316;
  --accent-hover:#fb923c;
  --success:#34d399;
  --warning:#fcd34d;
  --error:#ef4444;
  --sidebar-width:240px;
}

/* ===== RESET & BASE ===== */
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg-primary);color:var(--text-primary);font-family:'Inter',sans-serif;font-size:14px;line-height:1.5}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:'Space Grotesk',sans-serif;font-weight:700}
.hidden{display:none!important}
code,.mono{font-family:'JetBrains Mono',monospace}

/* ===== SIDEBAR LAYOUT ===== */
.app-layout{display:flex;min-height:100vh}

.sidebar{
  width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);
  position:fixed;top:0;left:0;bottom:0;z-index:10;
  display:flex;flex-direction:column;padding:24px 0;
  transition:width .2s ease;
}
.sidebar-logo{padding:0 24px;margin-bottom:28px;text-align:center}
.sidebar-logo svg{width:48px;height:48px;margin-bottom:8px}
.sidebar-logo h1{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:2px}
.sidebar-logo .sidebar-subtitle{font-size:11px;color:var(--text-secondary);display:block;margin-top:2px;font-family:'Inter',sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:0.5px}
.sidebar-divider{height:1px;background:var(--border);margin:8px 16px}

.sidebar-nav{list-style:none;flex:1;overflow-y:auto;padding:0 8px}
.sidebar-nav li a{
  display:flex;align-items:center;gap:12px;
  padding:9px 16px;color:var(--text-secondary);
  font-size:13px;font-weight:500;border-radius:8px;
  transition:all .15s;cursor:pointer;text-decoration:none;
  margin-bottom:2px;
}
.sidebar-nav li a:hover{background:var(--bg-hover);color:var(--text-primary);text-decoration:none}
.sidebar-nav li a.active{background:var(--bg-hover);color:var(--accent);text-decoration:none}
.sidebar-nav li a.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent);border-radius:0 3px 3px 0}
.sidebar-nav li{position:relative}
.sidebar-nav li a svg{width:18px;height:18px;flex-shrink:0;stroke-width:1.75}
.sidebar-nav .nav-section-label{font-size:10px;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-muted);padding:16px 16px 6px;font-family:'Inter',sans-serif;font-weight:600}

.sidebar-footer{
  padding:16px 16px 0;border-top:1px solid var(--border);margin-top:auto;
  display:flex;align-items:center;justify-content:space-between;
}
.sidebar-user{display:flex;flex-direction:column;min-width:0}
.sidebar-user-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:11px;color:var(--text-muted);text-transform:capitalize}
.sidebar-logout{background:none;border:none;color:var(--text-muted);padding:6px;border-radius:6px;cursor:pointer;transition:all .15s;display:flex;align-items:center}
.sidebar-logout:hover{color:var(--error);background:rgba(239,68,68,.1)}
.sidebar-logout svg{width:18px;height:18px}

.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}

/* ===== MOBILE SIDEBAR ===== */
@media(max-width:768px){
  :root{--sidebar-width:60px}
  .sidebar-logo h1,.sidebar-logo .sidebar-subtitle{display:none}
  .sidebar-logo svg{width:32px;height:32px;margin-bottom:0}
  .sidebar-logo{margin-bottom:16px}
  .sidebar-nav li a span{display:none}
  .sidebar-nav li a{justify-content:center;padding:12px}
  .sidebar-nav .nav-section-label{display:none}
  .sidebar-footer{padding:12px 8px 0;flex-direction:column;gap:8px}
  .sidebar-user{display:none}
  .sidebar-divider{margin:8px 8px}
}

/* ===== CONTENT ===== */
.tab-content{padding:24px;max-width:1400px;margin:0 auto}
#tab-customers,#tab-visits,#tab-sales,#tab-analytics{max-width:none;padding:12px}

/* ===== ANALYTICS TAB ===== */
.analytics-filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:20px;padding:12px 16px;background:#111318;border:1px solid #1e2028;border-radius:10px}
.analytics-filter-bar .btn.preset-active{background:#f97316;color:#fff;border-color:#f97316}
.analytics-filter-bar input[type="month"]{width:140px;padding:6px 10px;font-size:12px}
.analytics-section{margin-bottom:24px}
.analytics-section-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#111318;border:1px solid #1e2028;border-radius:10px;cursor:pointer;user-select:none;margin-bottom:12px}
.analytics-section-header h2{font-size:16px;margin:0}
.analytics-section-header .toggle-icon{color:#94a3b8;font-size:16px;transition:transform .2s}
.analytics-section-header.collapsed .toggle-icon{transform:rotate(-90deg)}
.analytics-section-body{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.analytics-section-body.collapsed{display:none}
.chart-card{background:#111318;border:1px solid #1e2028;border-radius:10px;padding:16px;position:relative}
.chart-card h3{font-size:13px;color:#94a3b8;margin-bottom:12px;font-family:'Space Grotesk',sans-serif;font-weight:600;text-transform:none;letter-spacing:0}
.chart-card .chart-container{position:relative;height:300px}
.chart-card.wide{grid-column:span 2}
.chart-card.tall .chart-container{height:400px}
.spenders-table{width:100%;border-collapse:collapse;font-size:12px}
.spenders-table th{text-align:left;padding:6px 10px;color:#94a3b8;border-bottom:1px solid #1e2028;font-size:11px}
.spenders-table td{padding:6px 10px;border-bottom:1px solid #0d0e12}
.spenders-table tr:hover td{background:#0d0e12}
.cohort-table{width:100%;border-collapse:collapse;font-size:11px}
.cohort-table th,.cohort-table td{padding:5px 8px;text-align:center;border:1px solid #1e2028}
.cohort-table th{background:#0d0e12;color:#94a3b8;font-size:10px;white-space:nowrap}
.cohort-cell{border-radius:4px;color:#fff;font-weight:600}
@media(max-width:1024px){.analytics-section-body{grid-template-columns:1fr}.chart-card.wide{grid-column:span 1}}

/* ===== DATE SLICER (shared) ===== */
.date-slicer{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:12px;padding:10px 16px;background:#111318;border:1px solid #1e2028;border-radius:10px}
.date-slicer .ds-label{font-size:11px;color:#64748b;font-family:'Inter',sans-serif;font-weight:500;text-transform:none;letter-spacing:0;margin-right:4px}
.date-slicer .ds-btn{padding:4px 10px;border:1px solid #1e2028;border-radius:5px;background:none;color:#94a3b8;cursor:pointer;font-size:11px;font-family:'Inter',sans-serif;font-weight:500;transition:all .15s;white-space:nowrap}
.date-slicer .ds-btn:hover{border-color:#f97316;color:#f97316}
.date-slicer .ds-btn.ds-active{background:#f97316;color:#fff;border-color:#f97316}
.date-slicer .ds-sep{color:#1e2028;font-size:14px}
.date-slicer input[type="date"]{width:130px;padding:4px 8px;font-size:11px;font-family:'Inter',sans-serif;background:#0a0b0e;border:1px solid #1e2028;border-radius:5px;color:#f1f5f9}
.date-slicer input[type="date"]:focus{border-color:#f97316;outline:none}
.date-slicer .ds-range-label{font-size:11px;color:#64748b;margin-left:auto}
.clickable-name{color:#f97316;cursor:pointer;text-decoration:none}
.clickable-name:hover{text-decoration:underline}

/* ===== PANELS ===== */
.panel{background:#111318;border:1px solid #1e2028;border-radius:10px;overflow:hidden;margin-bottom:20px}
.panel-header{padding:16px 20px;border-bottom:1px solid #1e2028;display:flex;align-items:center;justify-content:space-between}
.panel-header h2{font-size:16px;color:#f1f5f9}
.panel-body{padding:20px}

/* ===== STAT CARDS ===== */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.stat-card{background:#111318;border:1px solid #1e2028;border-radius:10px;padding:20px}
.stat-label{font-size:12px;color:#94a3b8;text-transform:none;letter-spacing:0;margin-bottom:8px;font-weight:500}
.stat-value{font-family:'Space Grotesk',sans-serif;font-size:32px;font-weight:700;color:#f97316}
.stat-sub{font-size:12px;color:#64748b;margin-top:4px}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;border:1px solid #475569;font-weight:500;font-family:'Inter',sans-serif;font-size:13px;cursor:pointer;transition:all .2s;color:#f1f5f9;background:none}
.btn:hover{border-color:#f97316;color:#f97316}
.btn-primary{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border-color:#f97316}
.btn-primary:hover{opacity:.9;color:#fff}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-danger{border-color:#ef4444;color:#ef4444}
.btn-danger:hover{background:#ef4444;color:#fff}

/* ===== FORMS ===== */
input,select,textarea{background:#0a0b0e;border:1px solid #1e2028;border-radius:6px;padding:10px 14px;color:#f1f5f9;font-family:'Inter',sans-serif;font-size:14px;width:100%}
input:focus,select:focus,textarea:focus{outline:none;border-color:#f97316}
label{font-size:13px;color:#94a3b8;display:block;margin-bottom:6px}
.form-row{display:flex;gap:16px;margin-bottom:16px}
.form-row>*{flex:1}

/* ===== TABLES ===== */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:10px 14px;color:#94a3b8;font-size:12px;text-transform:none;letter-spacing:0;border-bottom:1px solid #1e2028;font-family:'Inter',sans-serif;font-weight:600}
td{padding:10px 14px;border-bottom:1px solid #0d0e12;font-size:13px}
tr:hover td{background:#0d0e12}
tr.clickable{cursor:pointer}

/* ===== BADGES ===== */
.badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;font-family:'Inter',sans-serif}
.badge-green{background:#0a2e1a;color:#34d399}
.badge-red{background:#2e0a0a;color:#f87171}
.badge-yellow{background:#2e1f0a;color:#fcd34d}
.badge-blue{background:#0a1a2e;color:#60a5fa}
tr.visit-future{background:rgba(96,165,250,0.06);border-left:2px solid #60a5fa}
tr.visit-future:hover{background:rgba(96,165,250,0.12)}
.badge-purple{background:#1a0a2e;color:#c4b5fd}

/* ===== UPLOAD ===== */
.upload-zone{border:2px dashed #1e2028;border-radius:10px;padding:40px;text-align:center;cursor:pointer;transition:all .2s}
.upload-zone:hover,.upload-zone.dragover{border-color:#f97316;background:#111318}
.upload-zone p{color:#94a3b8;margin-top:8px}

/* ===== PROGRESS BAR ===== */
.progress-bar{height:8px;background:#1e2028;border-radius:4px;overflow:hidden;margin:12px 0}
.progress-fill{height:100%;background:linear-gradient(90deg,#f97316,#ea580c);transition:width .3s;border-radius:4px}

/* ===== PROFILE CARD ===== */
.profile-header{display:flex;align-items:center;gap:20px;padding:20px;border-bottom:1px solid #1e2028}
.profile-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#f97316,#ea580c);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff}
.profile-name{font-size:20px;font-weight:700}
.profile-meta{color:#94a3b8;font-size:13px;margin-top:4px}
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:20px}
@media(max-width:768px){.profile-grid{grid-template-columns:1fr}}

/* ===== PAGINATION ===== */
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px}
.page-btn{padding:6px 12px;border:1px solid #1e2028;border-radius:6px;background:none;color:#94a3b8;cursor:pointer;font-size:13px}
.page-btn.active{border-color:#f97316;color:#f97316}
.page-btn:disabled{opacity:.3;cursor:default}

/* ===== DATA GRID ===== */
.grid-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:12px 20px;border-bottom:1px solid #1e2028;background:#0d0e12}
.grid-toolbar input[type="text"]{width:240px;padding:7px 12px;font-size:13px}
.grid-toolbar .btn{padding:6px 14px;font-size:12px}
.grid-wrap{overflow:auto;max-height:calc(100vh - 200px);position:relative}
.grid-wrap table{min-width:100%}
.grid-wrap th{position:sticky;top:0;z-index:2;background:#111318;cursor:pointer;user-select:none;white-space:nowrap;padding:8px 12px;font-size:11px}
.grid-wrap th:hover{color:#f97316}
.grid-wrap th .sort-arrow{margin-left:4px;font-size:10px;color:#f97316}
.grid-wrap td{padding:7px 12px;white-space:nowrap;max-width:250px;overflow:hidden;text-overflow:ellipsis;font-size:12px}
.grid-wrap tr.clickable:hover td{background:#161820}
.col-filter{display:block;width:100%;padding:4px 6px;font-size:11px;margin-top:4px;background:#0a0b0e;border:1px solid #1e2028;border-radius:4px;color:#f1f5f9}
.col-filter:focus{border-color:#f97316;outline:none}

/* Column picker */
.col-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:100;display:flex;align-items:center;justify-content:center}
.col-picker{background:#111318;border:1px solid #1e2028;border-radius:12px;width:520px;max-width:90vw;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}
.col-picker-header{padding:16px 20px;border-bottom:1px solid #1e2028;display:flex;align-items:center;justify-content:space-between}
.col-picker-header h2{font-size:16px;margin:0}
.col-picker-body{padding:12px 20px;overflow-y:auto;flex:1}
.col-picker-body label{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:13px;cursor:pointer;color:#94a3b8}
.col-picker-body label:hover{color:#f1f5f9}
.col-picker-body input[type="checkbox"]{accent-color:#f97316;width:16px;height:16px}
.col-picker-footer{padding:12px 20px;border-top:1px solid #1e2028;display:flex;gap:10px;justify-content:flex-end}
.col-picker-search{width:100%;padding:8px 12px;margin-bottom:8px}
.col-group{margin-bottom:12px}
.col-group-label{font-size:11px;text-transform:uppercase;letter-spacing:0.5px;color:#64748b;margin-bottom:6px;font-family:'Inter',sans-serif;font-weight:600}

/* ===== LOGIN ===== */
.login-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:1000}
.login-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:40px;width:380px;max-width:90vw}
.login-logo{text-align:center;margin-bottom:8px}
.login-logo svg{width:56px;height:56px}
.login-box h1{text-align:center;margin-bottom:4px;color:var(--text-primary);font-size:28px;letter-spacing:2px}
.login-box .login-subtitle{text-align:center;font-size:13px;color:var(--text-secondary);margin-bottom:8px}
.login-box .login-accent-bar{width:40px;height:3px;background:var(--accent);margin:0 auto 28px;border-radius:2px}
.login-box .error{color:#f87171;font-size:13px;margin-top:12px;text-align:center}
.login-box .success{color:var(--success);font-size:13px;margin-top:12px;text-align:center}
.login-box input{margin-bottom:16px}
.login-box .btn-primary{width:100%;justify-content:center}
.login-links{text-align:center;margin-top:16px;font-size:13px;color:var(--text-secondary)}
.login-links a{color:var(--accent);cursor:pointer}
.pwd-wrap{position:relative;display:flex;align-items:center}
.pwd-wrap input{padding-right:42px;flex:1}
.pwd-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;padding:6px;line-height:1;z-index:2;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:4px}
.pwd-toggle:hover{color:var(--accent);background:rgba(255,255,255,.06)}

/* ===== USER MANAGEMENT ===== */
.users-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:900px){.users-grid{grid-template-columns:1fr}}
.pending-panel{border-color:#f97316}
.pending-panel .panel-header{background:rgba(249,115,22,.08)}
.user-table th{font-size:11px;padding:8px 12px}
.user-table td{padding:8px 12px;font-size:13px}
.user-table select{width:auto;padding:4px 8px;font-size:12px}

/* ===== TOAST ===== */
.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;border-radius:8px;font-size:13px;color:#fff;animation:slideIn .3s ease;max-width:400px}
.toast-success{background:#166534}
.toast-error{background:#991b1b}
.toast-info{background:#1e3a5f}
@keyframes slideIn{from{opacity:0;transform:translateX(100px)}to{opacity:1;transform:translateX(0)}}

/* ===== MODERN POLISH ===== */
.stat-card{transition:box-shadow .2s ease,border-color .2s ease}
.stat-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.3);border-color:#2a2d38}
.chart-card{transition:box-shadow .2s ease,border-color .2s ease}
.chart-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.3);border-color:#2a2d38}
.panel{transition:box-shadow .2s ease}
.btn:active{transform:scale(0.98)}

/* ===== CALENDAR ===== */
.cal-day{transition:background .15s;position:relative;min-height:100px;padding:4px 6px;background:#0a0b0e;cursor:pointer;border:1px solid transparent}
.cal-day:hover{background:#14161b!important}
.cal-today{outline:2px solid #f97316;outline-offset:-2px;border-radius:2px}
.cal-other-month{opacity:.35}
.cal-item{font-size:10px;padding:2px 5px;margin-bottom:2px;border-left:3px solid #f97316;background:rgba(249,115,22,0.08);border-radius:2px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;transition:opacity .15s;line-height:1.4}
.cal-item:hover{opacity:.75}
.cal-type-btn{border:1px solid #333;border-radius:6px;padding:4px 10px;font-size:11px;cursor:pointer;transition:all .15s;background:transparent}
.cal-type-active{font-weight:600}
.cal-day-header{font-size:11px;font-weight:600;color:#64748b;text-align:center;padding:8px 4px;background:#111318}
/* Calendar detail panel */
.cal-detail-tabs{display:flex;gap:0;border-bottom:1px solid #1e2028;margin-bottom:16px}
.cal-detail-tab-btn{padding:10px 18px;font-size:13px;color:#94a3b8;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .15s;font-weight:500}
.cal-detail-tab-btn:hover{color:#f1f5f9;background:rgba(255,255,255,.03)}
.cal-detail-tab-btn.active{color:#f97316;border-bottom-color:#f97316;font-weight:600}
.cal-detail-section{margin-bottom:16px}
.cal-task-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid #1e2028;font-size:13px;transition:background .15s}
.cal-task-item:hover{background:rgba(255,255,255,.04)}
.cal-task-status-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;flex-shrink:0;transition:transform .1s,box-shadow .15s;user-select:none}
.cal-task-status-btn:hover{transform:scale(1.15);box-shadow:0 0 0 3px rgba(249,115,22,.25)}
.cal-task-status-btn:active{transform:scale(0.95)}
.cal-task-title{flex:1;cursor:pointer;border-radius:4px;padding:2px 4px;transition:background .15s}
.cal-task-title:hover{background:rgba(255,255,255,.06)}
.cal-task-edit-modal input,.cal-task-edit-modal textarea{width:100%;background:#0a0b0e;border:1px solid #334155;border-radius:6px;color:#e2e8f0;padding:8px 10px;font-size:13px;font-family:inherit}
.cal-task-edit-modal input:focus,.cal-task-edit-modal textarea:focus{outline:none;border-color:#f97316}
.cal-task-edit-modal label{font-size:11px;color:#94a3b8;margin-bottom:4px;display:block}
.cal-task-done .cal-task-title{text-decoration:line-through;opacity:.5}
.cal-task-phase{font-size:10px;padding:2px 8px;border-radius:4px;background:#1e2028;color:#94a3b8;min-width:24px;text-align:center}
.media-card{cursor:pointer;background:#111318;border:1px solid #1e2028;border-radius:8px;overflow:hidden;transition:border-color .15s}
.media-card:hover{border-color:#f97316}
.media-drop-active{border-color:#f97316!important;background:rgba(249,115,22,.05)!important}
/* Events tab */
.evt-card{background:#111318;border:1px solid #1e2028;border-left:4px solid #f97316;border-radius:8px;padding:16px 20px;margin-bottom:12px;cursor:pointer;transition:all .15s}
.evt-card:hover{border-color:#f9731644;background:#13151a}
.evt-card-title{font-size:16px;font-weight:700;color:#f1f5f9;margin-bottom:6px}
.evt-card-meta{display:flex;flex-wrap:wrap;gap:8px 16px;font-size:12px;color:#94a3b8;margin-bottom:8px}
.evt-card-meta span{display:flex;align-items:center;gap:4px}
.evt-card-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.evt-card-actions{display:flex;gap:6px;margin-left:auto;flex-shrink:0}
.evt-time-btn{background:transparent;color:#64748b}
.evt-time-btn.active{background:#f9731622;color:#f97316;font-weight:600}
.evt-link-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;background:#1e293b;color:#38bdf8;font-size:11px;text-decoration:none;transition:background .15s}
.evt-link-icon:hover{background:#334155}

/* GHL tab sub-navigation */
.ghl-sub-active{background:#f9731622!important;color:#f97316!important;border-color:#f97316!important;font-weight:600!important}
.ghl-section{animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ===== R1SE TV TAB ===== */
.tv-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}
.tv-stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:16px 20px;text-align:center}
.tv-stat-card .stat-label{font-size:11px;color:var(--text-muted);font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.5px}
.tv-stat-card .stat-value{font-size:28px;font-family:'Space Grotesk',sans-serif;font-weight:700;margin:4px 0}
.tv-upcoming-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.tv-event-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;padding:16px;transition:border-color .2s}
.tv-event-card:hover{border-color:var(--accent)}
.tv-event-card .ev-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.tv-event-card .ev-name{font-size:15px;font-weight:600;color:var(--text-primary)}
.tv-event-card .ev-time{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--accent);white-space:nowrap}
.tv-event-card .ev-meta{font-size:12px;color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:6px 14px;margin-bottom:8px}
.tv-event-card .ev-badges{display:flex;gap:6px;flex-wrap:wrap}
.tv-badge{font-size:10px;font-family:'JetBrains Mono',monospace;padding:2px 8px;border-radius:4px;font-weight:600}
.tv-badge-obs{background:#166534;color:#86efac}
.tv-badge-zoom{background:#1e3a5f;color:#93c5fd}
.tv-badge-music{background:#713f12;color:#fcd34d}
.tv-badge-off{background:var(--border);color:var(--text-muted)}
.tv-catalogue-tabs{display:flex;gap:0;overflow-x:auto;margin-bottom:16px;border-bottom:1px solid var(--border)}
.tv-cat-tab{padding:8px 16px;border:none;background:none;color:var(--text-secondary);cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;border-bottom:2px solid transparent;white-space:nowrap;transition:all .2s}
.tv-cat-tab:hover{color:var(--text-primary)}
.tv-cat-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.tv-video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.tv-video-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .2s,transform .15s}
.tv-video-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.tv-video-card .tv-thumb{width:100%;aspect-ratio:16/9;background:var(--bg-primary);object-fit:cover}
.tv-video-card .tv-vid-info{padding:12px}
.tv-video-card .tv-vid-title{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tv-video-card .tv-vid-meta{font-size:11px;color:var(--text-muted);font-family:'JetBrains Mono',monospace;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.tv-thumb-wrap{position:relative;width:100%}
.tv-thumb-empty{aspect-ratio:16/9;background:var(--bg-primary)}
.tv-dur-badge{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.8);color:#fff;font-size:11px;padding:2px 6px;border-radius:4px;font-family:'JetBrains Mono',monospace}
.tv-vid-instructor{background:var(--accent);color:#fff;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:600;letter-spacing:.3px}
.tv-vid-seq{background:var(--bg-primary);color:var(--text-muted);padding:1px 6px;border-radius:3px;font-size:10px;border:1px solid var(--border)}
.tv-vid-featured{position:absolute;top:6px;left:6px;background:rgba(245,158,11,.9);color:#fff;font-size:10px;padding:2px 8px;border-radius:4px;font-weight:600}
.tv-featured{border-color:rgba(245,158,11,.5)!important}
.tv-curation-btns{position:absolute;top:6px;right:6px;display:flex;gap:4px;opacity:0;transition:opacity .2s}
.tv-video-card:hover .tv-curation-btns{opacity:1}
.tv-cur-btn{width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:rgba(0,0,0,.7);color:#fff;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.tv-cur-btn:hover{background:rgba(245,158,11,.9);border-color:transparent}
.tv-cur-btn.active{background:rgba(245,158,11,.9);border-color:transparent}
.tv-cur-hide:hover{background:rgba(239,68,68,.9)}
.tv-video-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9998;display:flex;align-items:center;justify-content:center}
.tv-video-modal-inner{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;width:min(900px,95vw);max-height:90vh;overflow:auto;position:relative}
.tv-modal-close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;z-index:1}
.tv-modal-close:hover{color:var(--accent)}
.tv-embed-wrap{position:relative;padding-top:56.25%;background:#000}
.tv-embed-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.tv-modal-info{padding:16px 20px}
.tv-modal-info h3{font-size:16px;margin-bottom:6px}
.tv-modal-info p{font-size:13px;color:var(--text-secondary)}
.tv-load-more{display:block;margin:20px auto;padding:10px 28px}
.tv-empty{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}
.tv-history-table{width:100%;border-collapse:collapse}
.tv-history-table th{text-align:left;padding:8px 12px;color:var(--text-secondary);font-size:11px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--bg-primary);position:sticky;top:0}
.tv-history-table td{padding:8px 12px;border-bottom:1px solid #0d0e12;font-size:13px}
.tv-history-table tr:hover td{background:var(--bg-hover)}
.tv-result-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}
.tv-result-green{background:var(--success)}
.tv-result-amber{background:var(--warning)}
.tv-result-red{background:var(--error)}
/* Mode & view toggles */
.tv-mode-btn{padding:8px 16px;border:none;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;transition:all .2s;border-right:1px solid var(--border)}
.tv-mode-btn:last-child{border-right:none}
.tv-mode-btn:hover{color:var(--text-primary);background:var(--bg-hover)}
.tv-mode-btn.active{color:var(--accent);background:rgba(249,115,22,.1)}
.tv-view-btn{padding:6px 10px;border:none;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;transition:all .2s;border-right:1px solid var(--border)}
.tv-view-btn:last-child{border-right:none}
.tv-view-btn:hover{color:var(--text-primary)}
.tv-view-btn.active{color:var(--accent);background:rgba(249,115,22,.1)}
/* List view */
.tv-video-list{display:flex;flex-direction:column;gap:2px}
.tv-list-row{display:grid;grid-template-columns:60px 1fr 120px 80px 80px 60px 100px;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:border-color .2s}
.tv-list-row:hover{border-color:var(--accent)}
.tv-list-row .tv-list-thumb{width:60px;height:34px;border-radius:4px;object-fit:cover;background:var(--bg-primary)}
.tv-list-row .tv-list-title{font-size:13px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tv-list-row .tv-list-meta{font-size:11px;color:var(--text-muted);font-family:'JetBrains Mono',monospace}
/* Star button */
.tv-star-btn{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text-muted);transition:all .15s;padding:2px}
.tv-star-btn:hover{color:#f59e0b;transform:scale(1.2)}
.tv-star-btn.starred{color:#f59e0b}
.tv-star-counts{font-size:9px;color:var(--text-muted);font-family:'JetBrains Mono',monospace}
/* Edit/remove action bar on cards */
.tv-card-actions{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.9));padding:8px;display:flex;gap:4px;justify-content:flex-end;opacity:0;transition:opacity .2s}
.tv-video-card:hover .tv-card-actions{opacity:1}
.tv-action-btn{padding:4px 8px;border-radius:4px;border:1px solid rgba(255,255,255,.2);background:rgba(0,0,0,.6);color:#fff;font-size:10px;cursor:pointer;font-weight:600;transition:all .15s}
.tv-action-btn:hover{background:rgba(249,115,22,.8);border-color:transparent}
.tv-action-btn.tv-action-remove:hover{background:rgba(239,68,68,.8)}
/* Hidden/removed styling */
.tv-video-card.tv-removed{opacity:.5;border-style:dashed}

/* TV Rating Badges */
.tv-rating-row{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}
.tv-rating-badge{font-size:10px;padding:2px 6px;border-radius:4px;font-weight:600;display:inline-flex;align-items:center;gap:2px}
.tv-rating-badge small{font-weight:400;opacity:.7}
.tv-rating-r1se{background:rgba(245,158,11,.15);color:#f59e0b}
.tv-rating-instr{background:rgba(59,130,246,.15);color:#60a5fa}
.tv-rating-member{background:rgba(148,163,184,.12);color:#94a3b8}

/* ===== SOCIAL ANALYTICS REDESIGN ===== */
#igDailySection .chart-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:16px}
#igDailyPills>div{min-width:90px;transition:transform .15s}
#igDailyPills>div:hover{transform:translateY(-2px)}
#socialPlatformCards>div{transition:transform .15s,box-shadow .15s}
#socialPlatformCards>div:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.3)}

/* ===== MODAL OVERLAY (conversations & tasks) ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-box{background:var(--bg-secondary,#111318);border:1px solid var(--border,#1e293b);border-radius:12px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-overlay.hidden{display:none}
.task-filter{background:var(--bg-secondary,#1e293b);color:#94a3b8;border:1px solid transparent;border-radius:6px;padding:4px 12px;font-size:12px;cursor:pointer;transition:all .15s}
.task-filter:hover{color:#e2e8f0;border-color:#334155}
.task-filter.active{background:#d31a67;color:#fff;border-color:#d31a67}
