:root{--bg-main:#050b16;--bg-elevated:#071426;--bg-panel:#0a182bdb;--bg-card:#0c1c30e0;--border-soft:#94a3b824;--border-bright:#a855f757;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--accent-magenta:#ec4899;--accent-purple:#8b5cf6;--accent-cyan:#22d3ee;--accent-teal:#2dd4bf;--accent-amber:#f59e0b;--good:#22c55e;--watch:#f59e0b;--risk:#ef4444;color:var(--text-primary);background:var(--bg-main);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px}*{box-sizing:border-box}html{background:var(--bg-main)}body{background:radial-gradient(circle at 0 0,#8b5cf62e,#0000 32rem),radial-gradient(circle at 100% 0,#22d3ee1a,#0000 28rem),#050b16;min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{cursor:pointer}.app-shell{--sidebar-width:240px;grid-template-columns:var(--sidebar-width) minmax(0, 1fr);will-change:grid-template-columns;grid-template-rows:72px minmax(0,1fr);min-height:100vh;transition:grid-template-columns .42s cubic-bezier(.16,1,.3,1);display:grid}.app-shell.shell-collapsed{--sidebar-width:88px}.topbar{z-index:40;border-bottom:1px solid var(--border-soft);background:linear-gradient(90deg,#040c19fa,#05101df7);grid-area:1/1/auto/-1;align-items:center;min-width:0;padding:0 20px;display:flex;position:sticky;top:0;box-shadow:0 10px 28px #0000002e}.topbar-brand{align-items:center;gap:14px;min-width:0;display:flex}.sidebar{z-index:30;border-right:1px solid var(--border-soft);background:linear-gradient(#040c19f7,#030914fc);flex-direction:column;grid-area:2/1;gap:20px;height:calc(100vh - 72px);padding:18px 14px;transition:padding .42s cubic-bezier(.16,1,.3,1);display:flex;position:sticky;top:72px;overflow:hidden;transform:translateZ(0)}.brand{align-items:center;gap:12px;min-width:0;padding:0;display:flex;overflow:hidden}.brand-mark{background:linear-gradient(135deg,#ec4899,#8b5cf6);border-radius:10px;place-items:center;width:42px;height:42px;font-weight:900;display:grid;box-shadow:0 12px 28px #ec48994d}.brand-name{white-space:nowrap;font-size:22px;font-weight:900;line-height:1}.brand-subtitle{color:var(--accent-magenta);white-space:nowrap;font-weight:600}.nav-item>span:not(.nav-icon),.sidebar-footer{opacity:1;transition:opacity .18s .12s,transform .24s cubic-bezier(.16,1,.3,1) 80ms;transform:translate(0)}.shell-collapsed .nav-item>span:not(.nav-icon),.shell-collapsed .sidebar-footer{opacity:0;pointer-events:none;width:0;min-width:0;transition-delay:0s;overflow:hidden;transform:translate(-10px)}.collapse-btn{width:38px;height:38px;color:var(--text-secondary);background:0 0;border:0;border-radius:50%;place-items:center;display:grid}.collapse-btn:hover{color:#fff;background:#94a3b81f}.nav-list{align-content:start;justify-items:stretch;gap:10px;display:grid}.nav-item{height:50px;color:var(--text-secondary);text-align:left;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:12px;padding:0 14px;transition:width .42s cubic-bezier(.16,1,.3,1),height .42s cubic-bezier(.16,1,.3,1),background .2s,border-color .2s,color .2s,box-shadow .2s,border-radius .2s;display:flex}.nav-icon{flex:0 0 24px;place-items:center;width:24px;height:24px;line-height:0;display:grid}.nav-icon svg{width:19px;height:19px;margin:0;display:block}.shell-collapsed .nav-list{justify-items:center}.shell-collapsed .nav-item{border-radius:14px;justify-content:center;place-items:center;gap:0;width:62px;height:46px;padding:0;line-height:0;display:grid;position:relative;overflow:visible}.shell-collapsed .sidebar{padding-left:0;padding-right:0}.shell-collapsed .nav-icon{flex-basis:auto;place-self:center;width:62px;height:46px}.shell-collapsed .nav-icon svg{place-self:center;width:20px;height:20px}.shell-collapsed .nav-item:after{content:attr(data-tooltip);opacity:0;pointer-events:none;color:#fff;white-space:nowrap;z-index:20;background:#0f172afa;border:1px solid #94a3b838;border-radius:7px;padding:7px 10px;transition:opacity .14s,transform .14s;position:absolute;left:76px;transform:translate(-4px);box-shadow:0 12px 32px #00000059}.shell-collapsed .nav-item:hover:after{opacity:1;transform:translate(0)}.shell-collapsed .nav-active{background:linear-gradient(135deg,#ec4899b8,#8b5cf6d1);border-color:#ec489957;border-radius:16px;justify-self:center;width:62px;box-shadow:0 12px 28px #8b5cf63d}.nav-item:hover{color:#fff;background:#94a3b812}.nav-active{color:#fff;background:linear-gradient(135deg,#ec48998c,#4f46e58c);border:1px solid #ec489966}.sidebar-footer{color:var(--text-muted);margin-top:auto;font-size:12px;display:grid}.data-card{gap:8px;display:grid}.data-card-row{background:linear-gradient(#0f203abd,#071222b3);border:1px solid #94a3b824;border-radius:8px;grid-template-columns:24px minmax(0,1fr);align-items:start;gap:9px;padding:10px;display:grid;box-shadow:inset 0 1px #ffffff08}.data-card-row>span{color:#7dd3fc;background:#22d3ee17;border:1px solid #22d3ee29;border-radius:7px;place-items:center;width:24px;height:24px;display:grid}.data-card-row small{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px;display:block}.data-card-row strong{color:var(--text-secondary);margin-top:2px;font-size:11px;line-height:1.25;display:block}.main{grid-area:2/2;min-width:0;padding:18px 22px 26px;transform:translateZ(0)}.app-footer{color:var(--text-muted);border-top:1px solid #94a3b81f;justify-content:space-between;align-items:center;gap:10px;margin-top:18px;padding:14px 2px 2px;font-size:11px;display:flex}.app-footer span:last-child{color:#cbd5e1b8}.page-header{justify-content:space-between;margin-bottom:12px;display:flex}h1{letter-spacing:0;margin:0;font-size:24px;line-height:1.1}.page-header p{color:var(--text-secondary);margin:7px 0 0}.header-meta,.hint{color:var(--text-muted);margin-top:10px;font-size:13px;display:block}.hint{margin:8px 0 14px}.top-filters{grid-template-columns:repeat(6,minmax(130px,1fr));gap:10px;margin:12px 0 6px;display:grid}.top-filters.executive-filters{grid-template-columns:minmax(260px,1.35fr) minmax(340px,1.75fr) repeat(3,minmax(150px,1fr))}.top-filters.advertiser-filters{grid-template-columns:minmax(145px,1fr) minmax(230px,1.35fr) minmax(300px,1.55fr) minmax(145px,1fr) minmax(130px,.85fr) minmax(130px,.85fr) minmax(145px,1fr);align-items:stretch;gap:8px}.advertiser-filters .filter-control,.advertiser-filters .granularity-control{min-height:48px;padding:7px 9px}.advertiser-filters .filter-control span,.advertiser-filters .granularity-control>span{margin-bottom:5px;font-size:11px}.advertiser-filters .date-control,.advertiser-filters .granularity-control{grid-column:auto}.advertiser-filters .date-input-wrap input{height:27px;padding:2px 24px 2px 8px;font-size:12px}.advertiser-filters .date-input-wrap svg{color:#7dd3fc;opacity:.9;background:0 0;border:0;width:15px;height:15px;padding:2px;display:block;right:6px}.advertiser-filters .granularity-control button,.advertiser-filters select{min-height:27px;font-size:12px}.filter-control,.granularity-control{min-height:54px;color:var(--text-secondary);background:linear-gradient(#0d1d34f2,#071222f2);border:1px solid #94a3b82e;border-radius:8px;padding:8px 11px;box-shadow:inset 0 1px #ffffff08}.filter-control span,.granularity-control>span{color:var(--text-muted);align-items:center;gap:7px;margin-bottom:6px;font-size:12px;display:flex}select,input{color:#fff;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:#03091440;border:0;border-radius:6px;outline:0;width:100%;min-height:25px;padding:2px 8px}input[type=date]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;position:relative}input[type=date]::-webkit-calendar-picker-indicator{opacity:0;cursor:pointer;width:28px;height:100%;position:absolute;top:0;right:4px}select{appearance:none;background-image:linear-gradient(45deg,#0000 50%,#cbd5e1 50%),linear-gradient(135deg,#cbd5e1 50%,#0000 50%);background-position:calc(100% - 13px) 11px,calc(100% - 8px) 11px;background-repeat:no-repeat;background-size:5px 5px;padding-right:24px}option{color:#f8fafc;background:#102036}.date-control{grid-column:span 2}.executive-filters .date-control,.executive-filters .granularity-control{grid-column:auto}.date-control div{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.date-input-wrap{border-radius:6px;min-width:0;display:block;position:relative;overflow:hidden}.date-input-wrap input{background:#03091457;min-width:0;height:30px;padding:2px 30px 2px 10px;font-size:13px;line-height:1;display:block}.date-input-wrap svg{color:#7dd3fc;opacity:.95;pointer-events:none;background:#22d3ee1a;border:1px solid #7dd3fc33;border-radius:5px;width:19px;height:19px;padding:3px;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.granularity-control{grid-column:span 2}.granularity-control div{border:1px solid #94a3b81f;border-radius:7px;grid-template-columns:repeat(5,1fr);display:grid;overflow:hidden}.granularity-control button{min-height:28px;color:var(--text-secondary);background:#0f203ab3;border:0;border-right:1px solid #94a3b81f}.granularity-control button.active,.tabs button.active{color:#fff;background:linear-gradient(135deg,#ec4899a6,#8b5cf6a6)}.granularity-control button:disabled{color:#94a3b86b;cursor:not-allowed;background:#0f203a59}.granularity-control button:disabled:hover{color:#94a3b86b}.dashboard-card{border:1px solid var(--border-soft);background:linear-gradient(#0f203af0,#071222f0);border-radius:8px;box-shadow:0 18px 40px #00000038}.summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:12px;display:grid}.advertiser-summary{grid-template-columns:repeat(5,minmax(0,1fr))}.advertiser-summary-card{grid-template-columns:46px minmax(0,1fr);align-items:center;gap:13px;min-height:104px;padding:14px 16px;display:grid}.advertiser-summary-card .summary-icon{color:#f0abfc;background:linear-gradient(135deg,#8b5cf685,#ec489933);border-radius:8px;place-items:center;width:46px;height:46px;display:grid}.advertiser-summary-card span{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:13px;line-height:1.2;display:block;overflow:hidden}.advertiser-summary-card strong{color:#fff;margin-top:7px;font-size:21px;line-height:1.05;display:block}.advertiser-summary-card .summary-detail{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:5px;font-size:11px;line-height:1.2;display:block;overflow:hidden}.situation-card{grid-template-columns:58px 1fr auto;align-items:center;gap:14px;min-height:116px;padding:16px;display:grid}.card-icon{color:#f0abfc;background:linear-gradient(135deg,#8b5cf666,#ec489926);border-radius:8px;place-items:center;width:58px;height:58px;display:grid}.label,.metric-cell span,.mini-metric span{color:var(--text-muted);font-size:13px}.situation-card strong,.kpi-card strong,.mini-metric strong,.metric-cell strong{color:#fff;margin:6px 0 2px;font-size:23px;display:block}.growth{color:var(--text-muted);font-size:12px;display:block}.mini-metric .growth{text-align:center}.growth.good{color:var(--good)}.growth.risk{color:#fb7185}.status{color:var(--text-secondary);text-transform:capitalize;white-space:nowrap;text-align:center;background:#94a3b814;border:1px solid #94a3b838;border-radius:6px;justify-content:center;align-self:start;align-items:center;min-width:76px;padding:4px 9px;font-size:12px;font-weight:700;display:inline-flex}.mini-metric .status{width:100%}.status-good,.status-strong,.status-healthy{color:#4ade80;background:#22c55e1f;border-color:#22c55e59}.status-watch,.status-opportunity,.status-upside{color:#fbbf24;background:#f59e0b1f;border-color:#f59e0b61}.status-risk{color:#fb7185;background:#ef44441f;border-color:#ef444461}.kpi-strip{grid-template-columns:repeat(10,minmax(145px,1fr));gap:12px;margin:14px 0;padding-bottom:6px;display:grid;overflow-x:auto}.executive-kpi-panel{align-self:stretch;padding:16px}.executive-kpi-panel .panel-header.compact{border-bottom:1px solid #94a3b81f;margin-bottom:14px;padding-bottom:10px}.executive-kpi-groups{gap:14px;display:grid}.kpi-group{padding-top:2px}.kpi-group+.kpi-group{border-top:1px solid #94a3b824;padding-top:14px}.kpi-group h3{color:#f0abfc;text-transform:uppercase;letter-spacing:.08em;margin:0 0 9px;font-size:11px;font-weight:800}.kpi-group-grid{gap:8px;display:grid}.kpi-group-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.kpi-group-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.kpi-card{min-width:0;min-height:98px;box-shadow:none;background:#0c1c30bd;padding:11px}.kpi-card strong{font-size:16px}.kpi-head{align-items:center;gap:7px;min-height:22px;display:flex}.kpi-icon{color:#f0abfc;background:#a855f724;border-radius:6px;place-items:center;width:22px;height:22px;display:grid}.content-grid{grid-template-columns:repeat(12,minmax(0,1fr));align-items:stretch;gap:12px;display:grid}.executive-right-rail{grid-template-rows:minmax(310px,.88fr) minmax(245px,.7fr);align-self:stretch;gap:12px;min-height:0;display:grid}.ads-pulse-panel,.driver-panel{min-width:0;height:100%}.ads-pulse-panel{grid-template-rows:auto minmax(0,1fr);display:grid}.ads-pulse-panel .recharts-responsive-container{min-height:0}.driver-panel{grid-template-rows:auto minmax(0,1fr);display:grid;overflow:hidden}.driver-panel .panel-header{margin-bottom:8px}.driver-panel .driver-table{min-height:0;overflow:auto}.span-3{grid-column:span 3}.span-4{grid-column:span 4}.span-5{grid-column:span 5}.span-6{grid-column:span 6}.span-7{grid-column:span 7}.span-8{grid-column:span 8}.span-12{grid-column:span 12}.panel{min-width:0;padding:14px}.panel h2{letter-spacing:0;margin:0 0 12px;font-size:15px}.panel-header{justify-content:space-between;align-items:start;gap:12px;margin-bottom:8px;display:flex}.panel-header h2{margin:0}.panel-header p{color:var(--text-muted);margin:4px 0 0;font-size:12px}.metric-controls{grid-template-columns:minmax(150px,1fr) minmax(120px,.8fr);gap:8px;min-width:300px;display:grid}.metric-controls select{border:1px solid var(--border-soft);background-color:#0a182be6;border-radius:6px;height:32px;padding:0 28px 0 8px;font-size:12px}.trend-controls{grid-template-columns:repeat(3,minmax(112px,1fr));min-width:420px}.map-controls{min-width:360px}.tabs{border:1px solid var(--border-soft);border-radius:7px;display:flex;overflow:hidden}.tabs button{min-width:78px;height:32px;color:var(--text-secondary);border:0;border-right:1px solid var(--border-soft);background:#0f203ab3;font-size:11px}.driver-table{border:1px solid #94a3b81f;border-radius:8px;gap:0;display:grid;overflow:hidden}.driver-panel .driver-table{display:block}.driver-panel .panel-header{align-items:center}.driver-panel .panel-header p{max-width:310px}.driver-panel .tabs{flex-wrap:nowrap}.driver-panel .tabs button{min-width:auto;padding:0 10px}.driver-row{color:var(--text-secondary);border-bottom:1px solid #94a3b81a;grid-template-columns:24px minmax(94px,1.1fr) 1.45fr 88px 58px 68px;align-items:center;gap:8px;padding:7px 9px;font-size:12px;display:grid}.driver-row:last-child{border-bottom:0}.driver-row div{background:#94a3b824;border-radius:99px;height:8px;overflow:hidden}.driver-head{color:var(--text-muted);background:#03091440;font-weight:700}.driver-head div{background:0 0}.driver-row i{background:linear-gradient(90deg,#8b5cf6,#ec4899);height:100%;display:block}.driver-row em,.driver-row small{color:var(--text-secondary);text-align:right;font-style:normal}.driver-row b{color:var(--text-muted);text-align:right;font-size:12px;font-weight:700}.driver-row b.good{color:var(--good)}.driver-row b.watch{color:#fbbf24}.driver-row b.risk{color:#fb7185}.mini-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.mini-grid.single{grid-template-columns:1fr}.mini-metric{border:1px solid var(--border-soft);background:#0f203a99;border-radius:8px;align-content:start;gap:3px;min-height:96px;padding:10px;display:grid}.mini-metric strong{font-size:17px}.mini-title{align-items:center;gap:6px;display:flex}.mini-title svg{color:#c084fc}.executive-lower-left,.executive-lower-right{align-self:stretch;gap:12px;display:grid}.risk-panel,.growth-panel,.map-panel,.detail-panel{min-width:0}.risk-grid,.growth-panel .mini-grid.single{grid-template-columns:repeat(2,minmax(0,1fr))}.executive-lower-right{grid-template-rows:auto minmax(0,1fr)}.detail-panel{grid-template-rows:auto minmax(0,1fr);display:grid}.detail-panel .table-wrap{height:100%;min-height:0;overflow:auto}.report-grid{grid-template-columns:40% .72fr 1.55fr;grid-template-areas:"metrics trend trend""metrics donut placement""funnel funnel position";gap:12px;display:grid}.metric-groups{grid-area:metrics;gap:10px;display:grid}.trend-panel{grid-area:trend}.donut-panel{grid-area:donut}.placement-panel{grid-area:placement}.funnel-panel{grid-area:funnel}.position-panel{grid-area:position}.metric-row{grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.metric-cell{border-right:1px solid var(--border-soft);min-height:76px;padding:8px 12px}.metric-cell:last-child{border-right:0}.metric-cell strong{font-size:20px}.metric-label{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;display:flex;overflow:hidden}.metric-label svg{color:currentColor;flex:none}.metric-groups .dashboard-card:first-child h2,.metric-groups .dashboard-card:first-child .metric-label{color:#c084fc}.metric-groups .dashboard-card:nth-child(2) h2,.metric-groups .dashboard-card:nth-child(2) .metric-label{color:#ec4899}.metric-groups .dashboard-card:nth-child(3) h2,.metric-groups .dashboard-card:nth-child(3) .metric-label{color:#22d3ee}.metric-groups .dashboard-card:nth-child(4) h2,.metric-groups .dashboard-card:nth-child(4) .metric-label{color:#f59e0b}.metric-groups .dashboard-card:nth-child(3) .metric-cell:nth-child(3) .metric-label,.metric-groups .dashboard-card:nth-child(3) .metric-cell:nth-child(3) strong,.metric-groups .dashboard-card:nth-child(3) .metric-cell:nth-child(4) .metric-label,.metric-groups .dashboard-card:nth-child(3) .metric-cell:nth-child(4) strong{color:#a3e635}.donut-row{grid-template-columns:1fr;gap:4px;display:grid}.donut-metric{text-align:center;color:var(--text-muted);position:relative}.donut-chart{height:124px;position:relative}.donut-center{pointer-events:none;place-content:center;display:grid;position:absolute;inset:0}.donut-center strong{color:#fff;font-size:12px;line-height:1.05;display:block}.donut-center span{color:var(--text-muted);margin-top:1px;font-size:9px}.donut-metric>span{margin-top:2px;display:block}.donut-metric em{color:#4ade80;font-size:12px;font-style:normal;display:block}.placement-panel .table-wrap{overflow-x:hidden}.placement-panel table{table-layout:auto;min-width:0}.placement-panel th,.placement-panel td{padding:8px 7px}.table-wrap{width:100%;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:650px}th,td{text-align:left;color:var(--text-secondary);white-space:nowrap;border-bottom:1px solid #94a3b81f;padding:9px 10px;font-size:12px}th{color:var(--text-muted);font-weight:700}td:first-child{color:#fff;font-weight:700}.table-footer{color:var(--text-muted);padding:9px 10px 0;font-size:12px}.sort-head{width:100%;color:inherit;font:inherit;text-align:left;background:0 0;border:0;align-items:center;gap:5px;padding:0;font-weight:700;display:inline-flex}.sort-head span{color:var(--accent-cyan);min-width:8px;font-size:10px}.table-footer-paged{justify-content:space-between;align-items:center;gap:10px;display:flex}.pager{gap:6px;display:inline-flex}.pager button{border:1px solid var(--border-soft);min-height:24px;color:var(--text-secondary);background:#0f203ab8;border-radius:6px;padding:2px 9px}.pager button:disabled{opacity:.42;cursor:default}.empty,.error,.loading-state{color:var(--text-secondary);border:1px solid var(--border-soft);background:#0f203acc;border-radius:8px;padding:18px}.funnel{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.funnel-step{text-align:center;border:1px solid var(--border-bright);clip-path:polygon(0 0,calc(100% - 26px) 0,100% 50%,calc(100% - 26px) 100%,0 100%,18px 50%);background:linear-gradient(135deg,#8b5cf642,#ec48991c);align-content:center;justify-items:center;min-height:104px;padding:14px;display:grid}.funnel-step:first-child{clip-path:polygon(0 0,calc(100% - 26px) 0,100% 50%,calc(100% - 26px) 100%,0 100%)}.funnel-step span{color:var(--text-muted)}.funnel-step strong{margin-top:7px;font-size:22px}.funnel-rates{color:var(--text-muted);text-align:center;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px;display:grid}.funnel-rates strong{color:#fff;margin-top:4px;font-size:16px;display:block}.funnel-rates span{border-right:1px dashed #94a3b847}.funnel-rates span:last-child{border-right:0}.index-list{gap:8px;display:grid}.index-row{color:var(--text-secondary);grid-template-columns:minmax(138px,1fr) 36px minmax(74px,.75fr) 78px;align-items:center;gap:10px;font-size:12px;display:grid}.index-row strong{color:#a7f3d0;font-size:15px}.index-progress{background:#94a3b82e;border-radius:99px;height:8px;overflow:hidden}.index-progress i{background:linear-gradient(90deg,#22d3ee,#22c55e);height:100%;display:block}.index-risk strong{color:#fb7185}.index-risk .index-progress i{background:linear-gradient(90deg,#fb7185,#ef4444)}.index-watch strong{color:#fbbf24}.index-watch .index-progress i{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.index-healthy strong{color:#38bdf8}.index-healthy .index-progress i{background:linear-gradient(90deg,#22d3ee,#38bdf8)}.index-strong strong{color:#4ade80}.index-strong .index-progress i{background:linear-gradient(90deg,#22d3ee,#22c55e)}.position-panel .status{min-width:72px;padding:3px 8px;font-size:11px}.fine-print{color:var(--text-muted);margin:12px 0 0;font-size:11px;font-style:italic}.campaign-filters{grid-template-columns:1.35fr 1.55fr 1fr 1fr 1fr 1.05fr 1fr}.campaign-filters .date-control,.campaign-filters .granularity-control{grid-column:auto}.campaign-filters .filter-control,.campaign-filters .granularity-control{min-height:48px;padding:7px 9px}.campaign-filters .filter-control span,.campaign-filters .granularity-control>span{margin-bottom:5px;font-size:11px}.campaign-filters .date-input-wrap input{height:27px;padding:2px 24px 2px 8px;font-size:12px}.campaign-filters .date-input-wrap svg{color:#7dd3fc;opacity:.9;background:0 0;border:0;width:15px;height:15px;padding:2px;display:block;right:6px}.campaign-filters .granularity-control button,.campaign-filters select{min-height:27px;font-size:12px}.campaign-summary{grid-template-columns:repeat(4,minmax(0,1fr))}.campaign-grid{grid-template-columns:40% 1fr 1fr;grid-template-areas:"left right right""objective detail detail";gap:12px;display:grid}.campaign-left-rail{grid-area:left;grid-template-rows:auto minmax(0,1fr);gap:12px;min-width:0;display:grid}.campaign-kpi-panel{min-width:0}.campaign-right-rail{grid-area:right;grid-template-rows:minmax(0,1fr) auto;align-self:stretch;gap:12px;min-width:0;display:grid}.campaign-pulse-panel{grid-template-rows:auto minmax(0,1fr);min-height:0;display:grid}.pacing-panel,.action-panel{min-width:0}.objective-panel{grid-area:objective}.campaign-detail-panel{grid-area:detail}.objective-panel,.campaign-detail-panel{grid-template-rows:auto minmax(0,1fr);align-self:stretch;display:grid}.campaign-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.campaign-kpi-grid .kpi-card{min-height:102px}.campaign-kpi-grid .kpi-card .recharts-responsive-container{display:none}.pacing-panel .panel-header{align-items:center}.pacing-panel .panel-header p{max-width:260px}.pacing-table .driver-row{grid-template-columns:24px minmax(110px,1fr) minmax(88px,1fr) 104px 82px 54px;min-width:0}.pacing-table.driver-table{overflow:hidden}.action-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.action-card{border:1px solid var(--border-soft);background:#0f203a9e;border-radius:8px;align-content:start;gap:4px;min-height:96px;padding:9px;display:grid;position:relative}.action-card .mini-title{align-items:flex-start;min-height:26px;line-height:1.1}.action-card strong{color:#fff;margin-top:2px;font-size:19px;line-height:1}.action-card small,.action-card em{color:var(--text-muted);font-size:11px;font-style:normal}.action-card .status{width:100%;margin-top:2px;padding:2px 7px}.objective-panel .table-wrap,.campaign-detail-panel .table-wrap{grid-template-rows:minmax(0,auto) auto;align-content:start;height:100%;display:grid}.objective-panel table,.campaign-detail-panel table{min-width:0}.objective-panel th,.objective-panel td,.campaign-detail-panel th,.campaign-detail-panel td{padding:8px 6px}.objective-panel th,.objective-panel td{font-size:11px}.objective-panel .table-wrap,.campaign-detail-panel .table-wrap{overflow-x:hidden}.campaign-detail-panel th,.campaign-detail-panel td{font-size:11px}.objective-panel tr,.campaign-detail-panel tr{height:41px}.campaign-detail-panel .compact-status{min-width:58px;padding:2px 6px;font-size:10px}.growth-filters{grid-template-columns:1.4fr 1.55fr 1fr 1fr 1fr 1fr}.growth-filters .date-control,.growth-filters .granularity-control{grid-column:auto}.growth-filters .filter-control,.growth-filters .granularity-control{min-height:48px;padding:7px 9px}.growth-filters .filter-control span,.growth-filters .granularity-control>span{margin-bottom:5px;font-size:11px}.growth-filters .date-input-wrap input{height:27px;padding:2px 24px 2px 8px;font-size:12px}.growth-filters .date-input-wrap svg{color:#7dd3fc;opacity:.9;background:0 0;border:0;width:15px;height:15px;padding:2px;display:block;right:6px}.growth-filters .granularity-control button,.growth-filters select{min-height:27px;font-size:12px}.growth-summary{grid-template-columns:repeat(4,minmax(0,1fr))}.growth-grid{grid-template-columns:repeat(10,minmax(0,1fr));grid-template-areas:"kpi kpi kpi kpi pulse pulse pulse pulse pulse pulse""driver driver driver driver driver simulator simulator simulator simulator simulator""map map map map map sankey sankey sankey sankey sankey""detail detail detail detail detail detail detail detail detail detail";gap:12px;display:grid}.growth-kpi-panel{grid-area:kpi;min-width:0}.growth-pulse-panel{grid-area:pulse;grid-template-rows:auto minmax(0,1fr);min-height:0;display:grid}.growth-driver-panel{grid-area:driver;min-width:0}.simulator-panel{grid-area:simulator;min-width:0}.opportunity-map-panel{grid-area:map}.sankey-panel{grid-area:sankey}.growth-detail-panel{grid-area:detail}.growth-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.growth-kpi-grid .kpi-card{min-height:104px}.growth-kpi-grid .kpi-card .recharts-responsive-container{display:none}.commercial-simulator{gap:12px;display:grid}.sim-controls{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.sim-controls label{color:var(--text-muted);gap:5px;font-size:11px;display:grid}.sim-controls select,.stepper{border:1px solid var(--border-soft);background:#03091459;border-radius:7px;height:30px}.stepper{grid-template-columns:28px 1fr 28px;display:grid;overflow:hidden}.stepper button{color:var(--text-secondary);background:#0f203acc;border:0}.stepper input{text-align:center;background:0 0;height:100%;min-height:0;padding:0 4px;font-size:11px}.sim-flow{grid-template-columns:repeat(4,minmax(0,1fr));align-items:center;gap:8px;display:grid}.sim-result{border:1px solid var(--border-soft);background:#0f203a99;border-radius:8px;align-content:center;gap:4px;min-height:82px;padding:9px;display:grid;position:relative}.sim-result:not(:last-child):after{content:">";color:var(--text-muted);z-index:2;font-weight:800;position:absolute;top:50%;right:-11px;transform:translateY(-50%)}.sim-result span{color:#c084fc}.sim-result small{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;line-height:1.15;overflow:hidden}.sim-result strong{color:#fff;font-size:16px}.sankey-layout{grid-template-columns:minmax(0,1fr) 190px;align-items:stretch;gap:10px;display:grid}.sankey-wrap{background:#0309142e;border:1px solid #94a3b81a;border-radius:8px;min-height:300px;position:relative;overflow:hidden}.sankey-wrap svg{width:100%;height:100%;position:absolute;inset:0}.sankey-label{z-index:2;color:var(--text-muted);font-size:11px;position:absolute;top:10px}.sankey-label.left{left:14px}.sankey-label.right{right:14px}.sankey-nodes{pointer-events:none;position:absolute;inset:0}.sankey-nodes span{color:#fff;text-align:center;background:linear-gradient(135deg,#8b5cf6b8,#22d3ee3d);border:1px solid #94a3b838;border-radius:7px;gap:1px;min-width:112px;padding:5px 8px;font-size:11px;display:grid;position:absolute;transform:translateY(-50%)}.sankey-nodes span.active{border-color:#22d3eea6;box-shadow:0 0 0 2px #22d3ee1a}.sankey-nodes small{color:var(--text-secondary);font-size:10px}.sankey-left span{left:12px}.sankey-right span{right:12px}.sankey-flow-list{align-content:start;gap:7px;display:grid}.sankey-select{color:var(--text-muted);gap:5px;font-size:11px;display:grid}.sankey-select select{border:1px solid var(--border-soft);background-color:#03091459;border-radius:7px;height:31px}.sankey-source-total{color:var(--text-secondary);padding:2px 0 3px;font-size:12px}.sankey-flow-list div{border:1px solid var(--border-soft);background:#0f203a8c;border-radius:7px;padding:8px}.sankey-flow-list strong{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:11px;display:block;overflow:hidden}.sankey-flow-list span{color:var(--text-muted);font-size:11px}.growth-detail-panel table{min-width:0}.growth-detail-panel th,.growth-detail-panel td{padding:8px 7px;font-size:11px}.growth-detail-panel .compact-status{min-width:62px;padding:2px 6px;font-size:10px}.quality-filters{grid-template-columns:1.4fr 1.55fr 1fr 1.1fr 1.05fr 1fr}.quality-filters .date-control,.quality-filters .granularity-control{grid-column:auto}.quality-filters .filter-control,.quality-filters .granularity-control{min-height:48px;padding:7px 9px}.quality-filters .filter-control span,.quality-filters .granularity-control>span{margin-bottom:5px;font-size:11px}.quality-filters .date-input-wrap input{height:27px;padding:2px 24px 2px 8px;font-size:12px}.quality-filters .date-input-wrap svg{color:#7dd3fc;opacity:.9;background:0 0;border:0;width:15px;height:15px;padding:2px;display:block;right:6px}.quality-filters .granularity-control button,.quality-filters select{min-height:27px;font-size:12px}.quality-summary{grid-template-columns:repeat(4,minmax(0,1fr))}.quality-grid{grid-template-columns:repeat(10,minmax(0,1fr));grid-template-areas:"kpi kpi kpi kpi pulse pulse pulse pulse pulse pulse""driver driver driver driver driver health health health health health""queue queue queue queue detail detail detail detail detail detail";gap:12px;display:grid}.quality-kpi-panel{grid-area:kpi;min-width:0}.quality-pulse-panel{grid-area:pulse;grid-template-rows:auto minmax(0,1fr);min-height:0;display:grid}.quality-driver-panel{grid-area:driver;min-width:0}.quality-health-panel{grid-area:health;min-width:0}.reconciliation-panel{grid-area:queue;min-width:0}.quality-detail-panel{grid-area:detail;min-width:0}.quality-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.quality-kpi-grid .kpi-card{min-height:104px}.quality-kpi-grid .kpi-card .recharts-responsive-container{display:none}.quality-health-grid{grid-template-columns:.95fr 1.25fr;align-items:stretch;gap:10px;display:grid}.quality-score{border:1px solid var(--border-soft);background:#0f203a9e;border-radius:8px;align-content:start;gap:9px;min-width:0;padding:12px;display:grid}.score-head{color:var(--text-muted);justify-content:space-between;align-items:center;gap:8px;font-size:12px;display:flex}.quality-score>strong{color:#fff;font-size:34px;line-height:1}.score-bar{background:#94a3b82e;border-radius:99px;height:9px;overflow:hidden}.score-bar i{background:linear-gradient(90deg,#22d3ee,#22c55e);height:100%;display:block}.quality-score.score-risk>strong{color:#fb7185}.quality-score.score-risk .score-bar i{background:linear-gradient(90deg,#fb7185,#ef4444)}.quality-score.score-watch>strong{color:#fbbf24}.quality-score.score-watch .score-bar i{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.quality-score.score-good>strong{color:#4ade80}.score-components{gap:6px;margin-top:2px;display:grid}.score-components div{color:var(--text-muted);grid-template-columns:minmax(0,1fr) auto;gap:8px;font-size:11px;display:grid}.score-components b{color:var(--text-secondary);font-size:11px}.quality-signal-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.quality-signal-grid .mini-metric{min-height:92px}.quality-driver-panel .driver-row{grid-template-columns:24px minmax(110px,1fr) 1.45fr 102px 60px 62px}.quality-metric-controls{grid-template-columns:minmax(190px,1fr) minmax(190px,1fr);min-width:410px}.reconciliation-panel,.quality-detail-panel{grid-template-rows:auto minmax(0,1fr);display:grid}.reconciliation-panel .table-wrap,.quality-detail-panel .table-wrap{grid-template-rows:minmax(0,auto) auto;align-content:start;height:100%;display:grid}.reconciliation-panel table,.quality-detail-panel table{min-width:0}.reconciliation-panel th,.reconciliation-panel td,.quality-detail-panel th,.quality-detail-panel td{padding:8px 7px;font-size:11px}.reconciliation-panel tr,.quality-detail-panel tr{height:41px}.reconciliation-panel .table-wrap,.quality-detail-panel .table-wrap{overflow-x:hidden}.placeholder-card{text-align:center;min-height:360px;color:var(--text-secondary);align-content:center;place-items:center;display:grid}.placeholder-card h2{color:#fff;margin:12px 0 0;font-size:28px}.chart-tooltip{border:1px solid var(--border-soft);color:var(--text-secondary);background:#030914f2;border-radius:8px;gap:5px;padding:10px 12px;display:grid;box-shadow:0 16px 40px #00000059}.chart-tooltip strong{color:#fff}@media (width<=1180px){.app-shell,.app-shell.shell-collapsed{--sidebar-width:88px}.sidebar{padding:18px 0}.brand-name,.brand-subtitle,.nav-item>span:not(.nav-icon),.sidebar-footer{display:none}.nav-item{justify-content:center;padding:0}.top-filters,.summary-grid,.advertiser-summary{grid-template-columns:repeat(2,1fr)}.top-filters.executive-filters,.top-filters.advertiser-filters,.top-filters.campaign-filters,.top-filters.growth-filters,.top-filters.quality-filters{grid-template-columns:repeat(2,minmax(0,1fr))}.report-grid{grid-template-columns:1fr;grid-template-areas:"metrics""trend""donut""placement""funnel""position"}.campaign-grid{grid-template-columns:1fr;grid-template-areas:"left""right""objective""detail"}.growth-grid{grid-template-columns:1fr;grid-template-areas:"kpi""pulse""driver""simulator""map""sankey""detail"}.quality-grid{grid-template-columns:1fr;grid-template-areas:"kpi""pulse""driver""health""queue""detail"}.span-3,.span-4,.span-5,.span-6,.span-7,.span-8,.executive-right-rail,.executive-lower-left,.executive-lower-right{grid-column:span 12}.executive-right-rail{grid-template-rows:auto auto}.metric-controls,.map-controls{min-width:0}.driver-row{min-width:620px}}@media (width<=760px){.app-shell{display:block}.topbar{min-height:64px;padding:0 14px}.topbar .brand{display:flex}.topbar .brand-mark{width:38px;height:38px}.topbar .brand-name{font-size:19px;display:block}.topbar .brand-subtitle{display:none}.sidebar{border-right:0;border-bottom:1px solid var(--border-soft);flex-direction:row;align-items:center;width:100%;height:auto;padding:10px 12px;position:static;overflow-x:auto}.sidebar-footer{display:none}.nav-list{display:flex}.nav-item,.shell-collapsed .nav-item{border-radius:12px;flex:0 0 56px;width:56px;height:44px}.shell-collapsed .nav-icon{width:56px;height:44px}.main{padding:16px}.app-footer{flex-direction:column;align-items:flex-start;gap:4px}.top-filters,.summary-grid,.advertiser-summary,.metric-row,.funnel,.funnel-rates,.top-filters.executive-filters,.top-filters.advertiser-filters,.top-filters.campaign-filters,.top-filters.growth-filters,.top-filters.quality-filters{grid-template-columns:1fr}.date-control,.granularity-control{grid-column:auto}.panel-header{display:grid}.metric-controls,.map-controls{grid-template-columns:1fr;width:100%}.date-control div{grid-template-columns:1fr}.kpi-strip{grid-template-columns:repeat(2,minmax(130px,1fr))}.kpi-group-grid.cols-2,.kpi-group-grid.cols-3,.risk-grid,.growth-panel .mini-grid.single,.campaign-kpi-grid,.action-grid,.growth-kpi-grid,.sim-controls,.sim-flow,.quality-kpi-grid,.quality-health-grid,.quality-signal-grid{grid-template-columns:1fr}.sim-result:after{display:none}.sankey-layout{grid-template-columns:1fr}.placement-panel .table-wrap,.objective-panel .table-wrap,.campaign-detail-panel .table-wrap,.reconciliation-panel .table-wrap,.quality-detail-panel .table-wrap{overflow-x:auto}.placement-panel table,.objective-panel table,.campaign-detail-panel table,.reconciliation-panel table,.quality-detail-panel table{min-width:620px}.executive-kpi-panel,.panel{padding:12px}.situation-card{grid-template-columns:44px 1fr}.situation-card .status{grid-column:1/-1;width:100%}}
