/* =========================================================
   Greenflow Design System
   Extracted from reference/index.html and adapted for Blazor
   ========================================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#00235B;--navy-light:#0A3D7C;--delta-red:#C8102E;--red-hover:#A00D24;
  --bg:#F3F5FA;--card:#FFFFFF;--card-hover:#F8F9FF;
  --text:#1A1F36;--text-sec:#5E6687;--text-muted:#9AA0B8;
  --border:#E2E6F0;--border-lt:#EFF1F7;
  --green:#10B981;--green-bg:#D1FAE5;--red-alert:#EF4444;
  --amber:#F59E0B;--amber-bg:#FEF3C7;
  --shadow-sm:0 1px 3px rgba(0,35,91,.06);--shadow-md:0 4px 16px rgba(0,35,91,.08);
  --shadow-lg:0 8px 32px rgba(0,35,91,.12);
  --r:12px;--rs:8px;--rxs:6px;
  --font-d:'Plus Jakarta Sans',sans-serif;--font-b:'DM Sans',sans-serif;
  --tr:0.2s cubic-bezier(.4,0,.2,1);
}
html{font-size:15px}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}

/* ---- LOGIN ---- */
.login-overlay{position:fixed;inset:0;z-index:10000;background:var(--navy);display:flex;align-items:center;justify-content:center}
.login-box{background:var(--card);border-radius:16px;padding:48px 40px;width:400px;box-shadow:0 24px 64px rgba(0,0,0,.3);text-align:center;animation:loginSlide .6s cubic-bezier(.16,1,.3,1)}
@keyframes loginSlide{from{opacity:0;transform:translateY(20px) scale(.97)}}
.login-box .logo-mark{width:52px;height:52px;background:var(--navy);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.login-box .logo-mark svg{width:28px;height:28px}
.login-box h1{font-family:var(--font-d);font-size:1.4rem;font-weight:700;margin-bottom:4px}
.login-box p.login-subtitle{color:var(--text-sec);font-size:.9rem;margin-bottom:28px}
.login-input{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:var(--rs);font-family:var(--font-b);font-size:1rem;outline:none;transition:border-color var(--tr);background:var(--bg);margin-bottom:12px}
.login-input:focus{border-color:var(--navy);background:var(--card)}
.login-btn{width:100%;margin-top:16px;padding:12px;border:none;border-radius:var(--rs);background:var(--delta-red);color:#fff;font-family:var(--font-d);font-weight:600;font-size:1rem;cursor:pointer;transition:all var(--tr)}
.login-btn:hover{background:var(--red-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(200,16,46,.3)}
.login-error{color:var(--delta-red);font-size:.85rem;margin-top:12px;min-height:20px}

/* ---- HEADER ---- */
.app-header{background:var(--card);color:var(--text);height:56px;display:flex;align-items:center;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm);border-bottom:1px solid var(--border)}
.app-header-inner{max-width:1440px;margin:0 auto;padding:0 32px;display:flex;align-items:center;width:100%}
.header-logo{display:flex;align-items:center;gap:10px}
.header-logo svg{width:22px;height:22px;flex-shrink:0}
.header-logo span{font-family:var(--font-d);font-weight:700;font-size:1rem;letter-spacing:-.02em;color:var(--navy)}
.header-nav{display:flex;gap:0;margin-left:40px}
.nav-tab{padding:16px 20px;font-family:var(--font-d);font-weight:600;font-size:.88rem;color:var(--text-sec);cursor:pointer;border:none;background:none;border-bottom:3px solid transparent;transition:all var(--tr);text-decoration:none}
.nav-tab:hover{color:var(--text)}
.nav-tab.active{color:var(--navy);border-bottom-color:var(--delta-red)}
.header-right{margin-left:auto;display:flex;align-items:center;gap:12px}

/* ---- FILTER BAR ---- */
.filter-bar{background:var(--navy);border-bottom:none;position:sticky;top:56px;z-index:90;box-shadow:0 2px 12px rgba(0,35,91,.2)}
.filter-bar-rows{max-width:1440px;margin:0 auto;padding:10px 32px;display:flex;flex-direction:column;gap:6px}
.filter-row{display:flex;align-items:center;gap:10px}
.filter-bar-inner{max-width:1440px;margin:0 auto;padding:14px 32px;display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}
.filter-group{display:flex;flex-direction:column;gap:3px;position:relative}
.filter-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.6);min-width:64px;flex-shrink:0}

/* Multi-select filter trigger */
.ms-trigger{display:flex;align-items:center;gap:6px;padding:7px 12px;border:1.5px solid var(--border);border-radius:var(--rxs);background:var(--bg);cursor:pointer;transition:all var(--tr);min-width:150px;font-size:.85rem;color:var(--text);user-select:none;min-height:36px;flex-wrap:wrap}
.ms-trigger:hover{border-color:var(--navy-light)}
.ms-trigger.open{border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,35,91,.08)}
.ms-trigger .placeholder{color:var(--text-muted)}
.ms-chip{display:inline-flex;align-items:center;gap:4px;background:var(--navy);color:#fff;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:500;line-height:1.4;white-space:nowrap}
.ms-chip .chip-x{cursor:pointer;opacity:.6;font-size:.85rem;margin-left:2px}
.ms-chip .chip-x:hover{opacity:1}

/* Dropdown panel */
.ms-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:var(--card);border:1px solid var(--border);border-radius:var(--rs);box-shadow:var(--shadow-lg);z-index:300;min-width:220px;max-height:320px;overflow-y:auto;display:none;padding:6px}
.ms-dropdown.open{display:block;animation:dropIn .2s ease}
@keyframes dropIn{from{opacity:0;transform:translateY(-6px)}}
.ms-dropdown .ms-search{width:100%;padding:8px 10px;border:1.5px solid var(--border);border-radius:var(--rxs);font-family:var(--font-b);font-size:.85rem;outline:none;margin-bottom:4px}
.ms-dropdown .ms-search:focus{border-color:var(--navy)}
.ms-option{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--rxs);cursor:pointer;font-size:.85rem;transition:background .1s}
.ms-option:hover{background:var(--bg)}
.ms-option .ms-check{width:16px;height:16px;border:2px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.ms-option.selected .ms-check{background:var(--navy);border-color:var(--navy)}
.ms-option.selected .ms-check::after{content:'\2713';color:#fff;font-size:.7rem;font-weight:700}
.ms-option .ms-opt-label{flex:1}
.ms-option .ms-opt-sub{font-size:.72rem;color:var(--text-muted)}

/* Date picker */
.filter-date{padding:7px 12px;border:1.5px solid var(--border);border-radius:var(--rxs);font-family:var(--font-b);font-size:.85rem;background:var(--bg);color:var(--text);outline:none;transition:border-color var(--tr);width:260px;cursor:pointer;min-height:36px}
.filter-date:focus{border-color:var(--navy)}
.filter-bar .flatpickr-input+input.form-control{padding:7px 12px;border:1.5px solid var(--border);border-radius:var(--rxs);font-family:var(--font-b);font-size:.85rem;background:var(--bg);color:var(--text);outline:none;width:260px;cursor:pointer;min-height:36px}
.filter-presets{display:flex;gap:4px;align-items:center}
.preset-btn{padding:7px 12px;border:1.5px solid rgba(255,255,255,.25);border-radius:var(--rxs);background:transparent;font-family:var(--font-b);font-size:.78rem;color:rgba(255,255,255,.7);cursor:pointer;transition:all var(--tr);white-space:nowrap;min-height:36px;display:inline-flex;align-items:center}
.preset-btn:hover{border-color:rgba(255,255,255,.5);color:#fff}
.preset-btn.active{background:rgba(255,255,255,.15);color:#fff;border-color:rgba(255,255,255,.5)}
.dtable .preset-btn{color:var(--navy);border-color:var(--navy);background:transparent;font-size:.75rem;padding:5px 10px;min-height:auto}
.dtable .preset-btn:hover{background:var(--navy);color:#fff}
.filter-reset{padding:7px 14px;border:none;border-radius:var(--rxs);background:rgba(255,255,255,.12);color:rgba(255,255,255,.8);font-family:var(--font-d);font-weight:600;font-size:.8rem;cursor:pointer;transition:all var(--tr);min-height:36px;display:inline-flex;align-items:center}
.filter-reset:hover{background:var(--delta-red);color:#fff}

/* Location toggle buttons */
.location-toggles{display:flex;gap:4px;flex-wrap:wrap}
.toggle-btn{padding:5px 12px;border:1.5px solid rgba(255,255,255,.25);border-radius:var(--rxs);background:transparent;font-family:var(--font-d);font-weight:600;font-size:.78rem;color:rgba(255,255,255,.45);cursor:pointer;transition:all var(--tr);white-space:nowrap;min-height:30px;display:inline-flex;align-items:center}
.toggle-btn:hover{border-color:rgba(255,255,255,.5);color:rgba(255,255,255,.9)}
.toggle-btn.active{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.5)}
.toggle-btn.country-btn.active{background:var(--delta-red);border-color:var(--delta-red);color:#fff}
.toggle-btn.station-btn.active{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.45);color:#fff}
.row-clear-btn{padding:4px 10px;border:none;border-radius:var(--rxs);background:rgba(255,255,255,.08);color:rgba(255,255,255,.5);font-family:var(--font-d);font-weight:600;font-size:.72rem;cursor:pointer;transition:all var(--tr);margin-left:4px;white-space:nowrap}
.row-clear-btn:hover{background:rgba(255,255,255,.15);color:#fff}

/* Flatpickr custom styling */
.flatpickr-calendar{font-family:var(--font-d)!important;border:1px solid var(--border)!important;border-radius:var(--r)!important;box-shadow:var(--shadow-lg)!important;overflow:hidden}
.flatpickr-calendar::before,.flatpickr-calendar::after{display:none!important}
.flatpickr-months{background:var(--navy);padding:8px 4px;border-radius:0;display:flex!important;align-items:center!important}
.flatpickr-months .flatpickr-month{height:auto!important;display:flex!important;align-items:center!important;flex:1}
.flatpickr-current-month{font-family:var(--font-d)!important;font-weight:600;font-size:.85rem;color:#fff;display:flex!important;align-items:center!important;justify-content:center!important;gap:6px!important;padding:0!important;position:relative!important;left:0!important;width:100%!important;height:auto!important;overflow:visible!important}
.flatpickr-current-month .numInputWrapper{display:none!important}
select.flatpickr-monthDropdown-months,
select.flatpickr-yearDropdown{
  font-family:var(--font-d)!important;font-weight:600!important;font-size:.85rem!important;color:#fff!important;
  background:rgba(255,255,255,.1)!important;border:1px solid rgba(255,255,255,.25)!important;
  border-radius:6px!important;padding:5px 26px 5px 10px!important;cursor:pointer!important;
  appearance:none!important;-webkit-appearance:none!important;-moz-appearance:none!important;
  background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")!important;
  background-repeat:no-repeat!important;background-position:right 8px center!important;background-size:10px!important;
  margin:0!important;height:32px!important;line-height:32px!important;padding-top:0!important;padding-bottom:0!important;box-sizing:border-box!important
}
select.flatpickr-monthDropdown-months:hover,
select.flatpickr-yearDropdown:hover{background:rgba(255,255,255,.2)!important;border-color:rgba(255,255,255,.4)!important}
select.flatpickr-monthDropdown-months option,
select.flatpickr-yearDropdown option{background:var(--navy)!important;color:#fff!important;font-family:var(--font-d)!important;padding:6px 10px!important}
.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{fill:#fff!important;color:#fff!important;padding:6px 8px;display:flex!important;align-items:center!important;height:32px!important;position:static!important}
.flatpickr-months .flatpickr-prev-month svg,.flatpickr-months .flatpickr-next-month svg{fill:#fff!important}
.flatpickr-months .flatpickr-prev-month:hover,.flatpickr-months .flatpickr-next-month:hover{background:rgba(255,255,255,.15);border-radius:6px}
.flatpickr-weekdays{background:var(--bg);border-bottom:1px solid var(--border-lt)}
span.flatpickr-weekday{font-family:var(--font-d)!important;font-weight:600;color:var(--text-muted)!important;font-size:.75rem}
.flatpickr-innerContainer{padding:4px}
.flatpickr-day{font-family:var(--font-b);font-size:.85rem;border-radius:var(--rxs);color:var(--text);border:none;height:34px;line-height:34px}
.flatpickr-day:hover{background:var(--bg);border:none}
.flatpickr-day.today{border:2px solid var(--navy)!important;background:transparent}
.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange{background:var(--navy)!important;border-color:var(--navy)!important;color:#fff!important}
.flatpickr-day.inRange{background:rgba(0,35,91,.08)!important;border:none!important;box-shadow:none!important}
.flatpickr-day.startRange{border-radius:var(--rxs) 0 0 var(--rxs)!important}
.flatpickr-day.endRange{border-radius:0 var(--rxs) var(--rxs) 0!important}

/* ---- MAIN CONTENT ---- */
.main-content{padding:24px 32px 48px;max-width:1440px;margin:0 auto}

/* ---- KPI CARDS ---- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:14px;margin-bottom:24px}
.kpi-card{background:var(--card);border-radius:var(--r);padding:18px 20px;border:1px solid var(--border-lt);box-shadow:var(--shadow-sm);transition:all var(--tr);position:relative;overflow:hidden}
.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.kpi-card.blue::before{background:var(--navy)}.kpi-card.red::before{background:var(--delta-red)}.kpi-card.green::before{background:var(--green)}.kpi-card.amber::before{background:var(--amber)}
.kpi-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:4px}
.kpi-value{font-family:var(--font-d);font-size:1.9rem;font-weight:800;color:var(--text);line-height:1.1}
.kpi-sub{font-size:.78rem;color:var(--text-sec);margin-top:3px}

/* ---- SECTION HEADER ---- */
.section-header{font-family:var(--font-d);font-size:1rem;font-weight:700;color:var(--text);margin:28px 0 14px;padding-bottom:8px;border-bottom:2px solid var(--border-lt);display:flex;align-items:center;gap:8px}
.section-header .sh-icon{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(0,35,91,.06);color:var(--navy)}

/* ---- HEATMAP + MAP ROW ---- */
.heatmap-map-row{display:grid;grid-template-columns:1fr 440px;gap:20px;margin-bottom:24px}
@media(max-width:1100px){.heatmap-map-row{grid-template-columns:1fr}}

/* Heatmap */
.heatmap-card{background:var(--card);border-radius:var(--r);padding:20px 24px;border:1px solid var(--border-lt);box-shadow:var(--shadow-sm);overflow-x:auto}
.heatmap-legend{display:flex;gap:16px;margin-bottom:14px;font-size:.78rem;color:var(--text-sec);align-items:center;flex-wrap:wrap}
.heatmap-legend .sw{width:14px;height:14px;border-radius:3px;display:inline-block;margin-right:4px;vertical-align:middle}
.heatmap-legend .sw.g{background:var(--green)}.heatmap-legend .sw.r{background:var(--delta-red)}.heatmap-legend .sw.a{background:var(--amber)}.heatmap-legend .sw.e{background:var(--border-lt);border:1px solid var(--border)}

/* Map card */
.map-card{background:var(--card);border-radius:var(--r);padding:0;border:1px solid var(--border-lt);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden}
.map-card-header{padding:12px 20px;border-bottom:1px solid var(--border-lt)}
.map-card-header h3{font-family:var(--font-d);font-size:.88rem;font-weight:700;margin:0}
.map-info-bar{padding:10px 20px;border-top:1px solid var(--border-lt);background:#fff;font-size:.82rem;line-height:1.4;display:flex;align-items:center;gap:14px;min-height:42px;flex-wrap:wrap}
#leaflet-map{flex:1;min-height:460px;z-index:1}
.leaflet-container{background:#f4f6fb;font-family:var(--font-b)}
.map-legend{padding:6px 12px;background:rgba(255,255,255,.92);border-radius:var(--rs);box-shadow:var(--shadow-md);font-size:.72rem;line-height:1.4;display:flex;align-items:center;gap:8px;flex-wrap:nowrap;white-space:nowrap}
.map-legend h4{font-family:var(--font-d);font-size:.72rem;font-weight:700;margin:0;white-space:nowrap}
.leaflet-control-zoom{border:none!important;box-shadow:var(--shadow-md)!important}
.leaflet-control-zoom a{background:var(--card)!important;color:var(--text)!important;border:1px solid var(--border)!important;font-family:var(--font-d)!important;width:30px!important;height:30px!important;line-height:30px!important}

/* ---- CHARTS ---- */
.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:24px}
.chart-panel{background:var(--card);border-radius:var(--r);border:1px solid var(--border-lt);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column}
.chart-panel>.cp-body,.chart-panel>.cp-body-split{flex:1;min-height:0}
.chart-panel.full{grid-column:1/-1}
.cp-header{padding:12px 18px;border-bottom:1px solid var(--border-lt);display:flex;align-items:center;gap:8px}
.cp-header h3{font-family:var(--font-d);font-size:.88rem;font-weight:700;margin:0}
.cp-source{font-size:.7rem;font-weight:500;color:var(--text-muted);background:var(--bg);padding:2px 8px;border-radius:4px;margin-left:auto;white-space:nowrap}
.cp-body{padding:18px;display:flex;flex-direction:column;box-sizing:border-box}
.chart-wrap{height:280px;position:relative}
.cp-body-split{display:grid;grid-template-columns:1fr 1fr;gap:0;height:100%;box-sizing:border-box}
.cp-body-split>div{padding:18px;display:flex;flex-direction:column}
.cp-body-split .chart-wrap{height:250px;position:relative}
.cp-body-split>div+div{border-left:1px solid var(--border-lt)}
.cp-body-split h4{font-family:var(--font-d);font-size:.8rem;font-weight:600;color:var(--text-sec);margin-bottom:10px}

/* Chart data tables */
.chart-data-table{width:100%;border-collapse:collapse;margin-top:0;font-size:.78rem}
.chart-data-table th{background:var(--bg);padding:6px 10px;text-align:left;font-family:var(--font-d);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border)}
.chart-data-table td{padding:5px 10px;border-bottom:1px solid var(--border-lt);color:var(--text-sec);font-size:.78rem}
.chart-data-table td.num{text-align:right;font-family:var(--font-d);font-weight:600;color:var(--text)}

/* ---- DATA TABLES (Reports) ---- */
.reports-layout{display:grid;grid-template-columns:1fr 440px;gap:20px;transition:all .3s}
.report-tabs{display:flex;gap:0;margin-bottom:0}
.rtab{padding:10px 18px;border:1px solid var(--border);border-bottom:none;background:var(--bg);font-family:var(--font-d);font-weight:600;font-size:.83rem;color:var(--text-sec);cursor:pointer;border-radius:var(--rs) var(--rs) 0 0;transition:all var(--tr);position:relative;top:1px}
.rtab:hover{color:var(--text)}.rtab.active{background:var(--card);color:var(--navy);border-bottom-color:var(--card)}
.rtab .cnt{background:var(--bg);padding:1px 7px;border-radius:10px;font-size:.72rem;margin-left:5px;font-weight:700}
.rtab.active .cnt{background:rgba(0,35,91,.08);color:var(--navy)}
.table-wrap{background:var(--card);border:1px solid var(--border);border-radius:0 var(--rs) var(--rs) var(--rs);box-shadow:var(--shadow-sm);overflow:hidden}
.dtable{width:100%;border-collapse:collapse;font-size:.84rem}
.dtable thead th{background:var(--bg);padding:10px 12px;text-align:left;font-family:var(--font-d);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0}
.dtable tbody tr{border-bottom:1px solid var(--border-lt);transition:background var(--tr);cursor:pointer}
.dtable tbody tr:hover{background:var(--card-hover)}
.dtable tbody tr.selected-row{background:#EEF2FF;border-left:3px solid var(--navy)}
.dtable tbody td{padding:10px 12px;vertical-align:top}
.dtable td.muted{color:var(--text-sec)}
.status-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.73rem;font-weight:600}
.status-badge.clear{background:var(--green-bg);color:#065F46}.status-badge.selectee{background:var(--amber-bg);color:#92400E}
.table-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-sec)}
.page-btns{display:flex;gap:4px}
.pg{padding:5px 10px;border:1px solid var(--border);border-radius:var(--rxs);background:var(--card);font-size:.78rem;cursor:pointer;transition:all var(--tr);font-family:var(--font-b);color:var(--text-sec)}
.pg:hover:not(:disabled){border-color:var(--navy);color:var(--navy)}.pg:disabled{opacity:.4;cursor:default}.pg.active{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ---- DETAIL / SIDE PANELS ---- */
.detail-panel{background:var(--card);border-radius:var(--r);border:1px solid var(--border-lt);box-shadow:var(--shadow-sm);overflow:hidden;display:none;align-self:start;position:sticky;top:140px}
.detail-panel.open{display:block;animation:fadeUp .3s ease}
.dp-header{background:var(--navy);color:#fff;padding:14px 20px;display:flex;align-items:center;justify-content:space-between}
.dp-header h3{font-family:var(--font-d);font-size:.92rem;font-weight:700}
.dp-close{background:none;border:none;color:rgba(255,255,255,.7);font-size:1.3rem;cursor:pointer;padding:0 4px}
.dp-close:hover{color:#fff}
.dp-body{padding:20px}
.dp-field{margin-bottom:14px}
.dp-field label{font-family:var(--font-d);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);display:block;margin-bottom:3px}
.dp-field p{font-size:.88rem;line-height:1.55;color:var(--text)}
.dp-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600;margin-right:4px;margin-bottom:4px}
.dp-badge.local{background:#FEF3C7;color:#92400E}.dp-badge.ops{background:#DBEAFE;color:#1E40AF}.dp-badge.sec{background:#FEE2E2;color:#991B1B}
.dp-divider{border:none;border-top:1px solid var(--border-lt);margin:14px 0}

/* Report side panel */
.rpt-panel{background:var(--card);border-radius:var(--r);border:1px solid var(--border-lt);box-shadow:var(--shadow-sm);overflow:hidden;display:none;align-self:start;position:sticky;top:140px;max-height:calc(100vh - 160px);overflow-y:auto}
.rpt-panel.open{display:block;animation:fadeUp .3s ease}
.rpt-panel-hdr{background:var(--navy);color:#fff;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:1}
.rpt-panel-hdr h3{font-family:var(--font-d);font-size:.9rem;font-weight:700}
.rpt-panel-close{background:none;border:none;color:rgba(255,255,255,.7);font-size:1.3rem;cursor:pointer}
.rpt-panel-close:hover{color:#fff}
.rpt-panel-body{padding:18px}
.rpt-panel-body .rpf{margin-bottom:14px}
.rpt-panel-body .rpf label{font-family:var(--font-d);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);display:block;margin-bottom:3px}
.rpt-panel-body .rpf p{font-size:.87rem;line-height:1.6;color:var(--text)}
.rpt-panel-body .rpf-divider{border:none;border-top:1px solid var(--border-lt);margin:12px 0}

/* ---- EXPORT BUTTON ---- */
.export-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--rxs);border:1.5px solid var(--border);background:transparent;color:var(--text-sec);font-family:var(--font-d);font-weight:600;font-size:.8rem;cursor:pointer;transition:all var(--tr);min-height:36px}
.export-btn:hover{border-color:var(--navy);color:var(--navy);background:var(--bg)}
.export-btn svg{width:15px;height:15px}

/* ---- SETTINGS BUTTON ---- */
.settings-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--rxs);border:none;background:transparent;color:var(--text-sec);font-family:var(--font-d);font-weight:600;font-size:.82rem;cursor:pointer;transition:all var(--tr)}
.settings-btn:hover{color:var(--navy);background:var(--bg)}
.settings-btn svg{width:16px;height:16px}

/* ---- USER ELEMENT ---- */
.user-element{position:relative}
.user-trigger{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 5px;border-radius:var(--rxs);border:none;background:transparent;cursor:pointer;transition:all var(--tr)}
.user-trigger:hover{background:var(--bg)}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700;font-size:.82rem;flex-shrink:0}
.user-name{font-family:var(--font-d);font-weight:600;font-size:.85rem;color:var(--text)}
.user-chevron{width:12px;height:12px;color:var(--text-muted);transition:transform .2s}
.user-trigger.open .user-chevron{transform:rotate(180deg)}

/* User dropdown */
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-lg);z-index:300;width:280px;display:none;overflow:hidden}
.user-dropdown.open{display:block;animation:dropIn .2s ease}
.user-dd-header{padding:16px 18px;border-bottom:1px solid var(--border-lt);display:flex;align-items:center;gap:12px}
.user-dd-header .user-dd-avatar{width:40px;height:40px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700;font-size:1rem;flex-shrink:0}
.user-dd-header .user-dd-name{font-family:var(--font-d);font-weight:700;font-size:.92rem;color:var(--text)}
.user-dd-header .user-dd-email{font-size:.75rem;color:var(--text-muted);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-dd-body{padding:12px 18px}
.user-dd-field{margin-bottom:10px}
.user-dd-field label{font-family:var(--font-d);font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);display:block;margin-bottom:2px}
.user-dd-field p{font-size:.85rem;color:var(--text)}
.user-dd-link{display:flex;align-items:center;gap:8px;padding:10px 18px;font-family:var(--font-d);font-weight:600;font-size:.82rem;color:var(--navy);cursor:pointer;transition:all var(--tr);border:none;background:none;width:100%;text-align:left;border-top:1px solid var(--border-lt);text-decoration:none}
.user-dd-link:hover{background:var(--bg);color:var(--delta-red)}
.user-dd-link svg{width:15px;height:15px;flex-shrink:0}

/* ---- ANIMATIONS ---- */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.anim{animation:fadeUp .35s cubic-bezier(.16,1,.3,1) both}
.d1{animation-delay:.04s}.d2{animation-delay:.08s}.d3{animation-delay:.12s}.d4{animation-delay:.16s}.d5{animation-delay:.2s}.d6{animation-delay:.24s}

/* ---- SCROLLBAR ---- */
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}

/* ---- BLAZOR SPECIFICS ---- */
.blazor-error-boundary{background:#b32121;padding:1rem;color:white;border-radius:var(--rs)}
.blazor-error-boundary::after{content:"An error has occurred."}
#blazor-error-ui{background:var(--delta-red);color:white;padding:.5rem 1rem;text-align:center;font-family:var(--font-d);font-weight:600;font-size:.85rem}

/* ---- BADGES ---- */
.badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.3px}
.bg-green{background:var(--green-bg);color:var(--green)}
.bg-red{background:#FEE2E2;color:var(--red-alert)}
.bg-amber{background:var(--amber-bg);color:var(--amber)}
.bg-blue{background:#DBEAFE;color:var(--navy)}
.bg-purple{background:#EDE9FE;color:#6D28D9}

/* ---- TABLE ROWS ---- */
.dtable tbody tr{cursor:pointer;transition:background var(--tr)}
.dtable tbody tr:hover{background:var(--card-hover)}
.dtable tbody tr.row-selected{background:#EEF2FF;box-shadow:inset 3px 0 0 var(--navy)}

/* ---- FILTER DATE INPUTS ---- */
.filter-bar select,.filter-bar input[type="date"]{
  height:32px;padding:0 10px;border:1px solid var(--border);border-radius:var(--rxs);
  font-family:var(--font-b);font-size:13px;color:var(--text);background:white;
  cursor:pointer;outline:none;transition:border-color var(--tr);
}
.filter-bar select:focus,.filter-bar input[type="date"]:focus{border-color:var(--navy)}

/* ---- UPLOAD ZONES ---- */
.upload-zones{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:24px}
@media(max-width:1100px){.upload-zones{grid-template-columns:1fr}}
.upload-zone{background:var(--card);border-radius:var(--r);border:1px solid var(--border-lt);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,box-shadow .2s}
.upload-zone.drag-over{border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,35,91,.12)}
.upload-zone.drag-over .upload-drop-content svg{opacity:.8}
.upload-zone.drag-over .upload-drop-area{background:rgba(0,35,91,.03)}
.upload-zone-header{padding:14px 18px;border-bottom:1px solid var(--border-lt);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.upload-zone-header h3{font-family:var(--font-d);font-size:.88rem;font-weight:700;margin:0}
.upload-zone-icon{width:28px;height:28px;border-radius:6px;background:rgba(0,35,91,.06);color:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.upload-zone-hint{font-size:.72rem;color:var(--text-muted);width:100%;margin-top:-2px}
.upload-drop-area{position:relative;padding:28px 18px;display:flex;align-items:center;justify-content:center;min-height:140px;border-bottom:1px solid var(--border-lt);cursor:pointer;transition:background .2s}
.upload-file-input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2}
.upload-drop-content{text-align:center;pointer-events:none}
.upload-drop-content p{font-size:.85rem;color:var(--text-sec);margin-top:8px}
.upload-browse{color:var(--navy);font-weight:600;text-decoration:underline}
.upload-drop-sub{font-size:.72rem;color:var(--text-muted);display:block;margin-top:2px}
.upload-file-list{padding:8px 12px;max-height:240px;overflow-y:auto}
.upload-file-item{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-radius:var(--rxs);transition:background .15s}
.upload-file-item:hover{background:var(--bg)}
.upload-file-item.success{background:#F0FDF4}
.upload-file-item.error{background:#FEF2F2}
.upload-file-item.active{background:#FFFBEB}
@keyframes uploadPulse{0%,100%{opacity:1}50%{opacity:.6}}
.upload-file-item.active .badge{animation:uploadPulse 1.5s ease-in-out infinite}
.upload-file-info{flex:1;min-width:0}
.upload-file-name{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.upload-file-name svg{flex-shrink:0;color:var(--text-muted)}
.upload-file-msg{font-size:.72rem;margin-top:2px;padding-left:20px;line-height:1.3}
.upload-file-msg.msg-success{color:var(--green)}
.upload-file-msg.msg-error{color:var(--red-alert)}
.upload-file-status{flex-shrink:0;margin-left:8px}
.upload-zone-actions{padding:12px 18px;border-top:1px solid var(--border-lt);display:flex;align-items:center;gap:8px}
.upload-process-btn{padding:8px 16px;font-size:.82rem;max-width:none;width:auto;margin:0}
.upload-clear-btn{background:var(--bg);color:var(--text-sec);border:1px solid var(--border);padding:8px 14px;font-size:.82rem;margin:0;min-height:auto}
.upload-clear-btn:hover{background:var(--border-lt);color:var(--text)}

/* ---- SETTINGS ---- */
.settings-layout{display:grid;grid-template-columns:220px 1fr;gap:20px;align-items:start}
.settings-sidebar{background:var(--card);border-radius:var(--rm);border:1px solid var(--border);overflow:hidden}
.settings-nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:14px 18px;border:none;background:transparent;font-family:var(--font-b);font-size:.88rem;color:var(--text-sec);cursor:pointer;transition:all var(--tr);text-align:left;border-left:3px solid transparent}
.settings-nav-item:hover{background:var(--bg);color:var(--text)}
.settings-nav-item.active{background:var(--bg);color:var(--navy);border-left-color:var(--navy);font-weight:600}
.settings-nav-item svg{flex-shrink:0}
.settings-nav-group{padding:10px 18px 4px;font-family:var(--font-d);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}
.settings-nav-group:not(:first-child){margin-top:4px;border-top:1px solid var(--border);padding-top:12px}
.settings-content{min-width:0}
.settings-field{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}
.settings-field:last-child{margin-bottom:0}
.settings-label{display:block;font-family:var(--font-d);font-size:.78rem;font-weight:600;color:var(--text-sec);margin-bottom:4px;text-transform:uppercase;letter-spacing:.03em}
.settings-value{padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--rxs);font-family:var(--font-b);font-size:.88rem;color:var(--text);word-break:break-all}
.cp-sub{font-size:.82rem;color:var(--text-muted);margin-left:12px;font-weight:400}
.row-excluded{background:rgba(192,57,43,.04)}
.row-excluded td{color:var(--text-muted)}
.toggle-switch{position:relative;display:inline-block;width:36px;height:20px;cursor:pointer}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:20px;transition:background .2s}
.toggle-slider::before{content:'';position:absolute;width:14px;height:14px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}
.toggle-switch input:checked+.toggle-slider{background:var(--red)}
.toggle-switch input:checked+.toggle-slider::before{transform:translateX(16px)}

/* ---- IMPORT LOG ROWS ---- */
.log-row-toggle{cursor:default}
.log-has-error{cursor:pointer}
.log-has-error:hover{background:var(--bg)}
.log-chevron{transition:transform .2s;vertical-align:middle}
.log-chevron.expanded{transform:rotate(90deg)}
.log-detail-row td{padding:0!important;border-top:none!important}
.log-error-detail{margin:0;padding:14px 18px;background:var(--bg);font-family:var(--font-b);font-size:.8rem;line-height:1.5;color:var(--text-sec);white-space:pre-wrap;word-break:break-all;border-top:1px dashed var(--border);max-height:300px;overflow-y:auto}

/* ---- RESPONSIVE ---- */
@media(max-width:900px){
  .charts-grid{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .filter-bar-rows{padding:8px 16px}
  .filter-bar-inner{padding:12px 16px}
  .filter-row{flex-wrap:wrap}
  .location-toggles{flex-wrap:wrap}
  .main-content{padding:16px}
  .app-header-inner{padding:0 16px}
  .reports-layout{grid-template-columns:1fr}
  .settings-layout{grid-template-columns:1fr}
}
