*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  /* ── Dailo Brand Colors ── */
  --brand-black:#000000;      /* Trust Black */
  --brand-moss:#223322;       /* Moss Green */
  --brand-lime:#CAFE6E;       /* Neon Lime */
  --brand-grey:#BABABA;       /* Urban Grey */
  --brand-white:#FFFFFF;      /* Pure White */

/* ── Semantic tokens ── */
--ink:#000000;
--ink2:#111;
--ink3:#333;
--mid:#666;
--soft:#BABABA;
--line:#e8e8e8;
--line2:#f3f3f3;
--bg:#f5f5f3;
--card:#FFFFFF;
--r:12px;
--rs:7px;
--accent:#CAFE6E;           /* Neon Lime — primary accent */
--accent-dk:#223322;        /* Moss Green — dark accent */
--accent-up:#2d7a3a;
--accent-dn:#c0392b;
}
body{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);min-height:100vh;padding-bottom:120px;-webkit-font-smoothing:antialiased;}

/* ══ STICKY HEADER BLOCK (topbar + range bar) ══ */
.sticky-head{position:sticky;top:0;z-index:300;}

/* TOPBAR */
.topbar{background:var(--brand-black);height:54px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;}
.topbar-left{display:flex;align-items:center;gap:20px;}
.logo-area{display:flex;align-items:center;gap:12px;}
.logo-svg{height:26px;width:auto;}
.logo-pipe{width:1px;height:16px;background:#2a2a2a;}
.logo-tag{font-size:10px;font-weight:500;color:var(--brand-lime);letter-spacing:0.14em;text-transform:uppercase;}
.view-switcher{display:flex;background:#111;border-radius:8px;padding:3px;gap:2px;}
.view-btn{padding:4px 16px;border-radius:6px;font-size:11px;font-weight:600;color:#666;border:none;background:transparent;cursor:pointer;font-family:inherit;letter-spacing:0.02em;transition:all 0.15s;white-space:nowrap;}
.view-btn.active{background:var(--brand-lime);color:var(--brand-black);font-weight:700;}
.topbar-right{display:flex;align-items:center;gap:10px;}
.topbar-user{font-size:11px;font-weight:500;color:#555;background:#111;padding:5px 12px;border-radius:6px;}
.topbar-date{font-size:11px;font-weight:500;color:#444;font-family:'DM Mono',monospace;}

/* RANGE + FILTER BAR */
.range-bar{background:#fff;border-bottom:1px solid var(--line);padding:0 28px;height:44px;display:flex;align-items:center;gap:6px;}
.range-tabs{display:flex;gap:3px;}
.range-tab{padding:3px 12px;border-radius:6px;font-size:11px;font-weight:600;color:var(--mid);border:1.5px solid transparent;background:transparent;cursor:pointer;font-family:inherit;transition:all 0.12s;}
.range-tab.active{background:var(--brand-black);color:var(--brand-lime);border-color:var(--brand-black);font-weight:700;}
.range-tab:hover:not(.active){background:var(--line2);color:var(--ink3);border-color:var(--line);}
.rsep{width:1px;height:16px;background:var(--line);margin:0 4px;}
.rcustom{display:flex;align-items:center;gap:6px;}
.rcustom label{font-size:9px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--soft);}
.rcustom input{height:26px;border:1.5px solid var(--line);border-radius:var(--rs);padding:0 7px;font-family:inherit;font-size:11px;font-weight:500;background:#fafafa;color:var(--ink);outline:none;transition:border-color 0.15s;cursor:pointer;}
.rcustom input:focus{border-color:var(--brand-black);}
.rright{display:flex;align-items:center;gap:7px;margin-left:auto;}
.rindicator{font-size:10px;font-weight:600;color:var(--soft);font-family:'DM Mono',monospace;white-space:nowrap;}
.fsel{height:26px;border:1.5px solid var(--line);border-radius:var(--rs);padding:0 7px;font-family:inherit;font-size:11px;font-weight:500;background:#fafafa;color:var(--ink);outline:none;cursor:pointer;}
.btn-export{background:var(--brand-lime);color:var(--brand-black);border:none;border-radius:var(--rs);padding:0 14px;height:26px;font-family:inherit;font-size:11px;font-weight:700;cursor:pointer;letter-spacing:0.04em;transition:opacity 0.15s;}
.btn-export:hover{opacity:0.8;}

/* ══ VIEWS ══ */
.view{display:none;}
.view.active{display:block;}
.page{max-width:1380px;margin:0 auto;padding:24px 28px;display:flex;flex-direction:column;gap:20px;}

/* ══ SECTION HEADER ══ */
.sec-hdr{display:flex;align-items:baseline;gap:10px;margin-bottom:14px;}
.sec-hdr h2{font-size:13px;font-weight:900;letter-spacing:-0.2px;color:var(--ink);}
.sec-hdr span{font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--soft);}

/* ══ CARD BASE ══ */
.card{background:var(--card);border-radius:var(--r);padding:20px;border:1px solid var(--line);}
.card-label{font-size:9px;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;color:var(--soft);margin-bottom:8px;}
.card-title{font-size:13px;font-weight:800;color:var(--ink);margin-bottom:14px;letter-spacing:-0.2px;}

/* ══ SIGNAL CARDS (top row) ══ */
.signal-row{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;}
@media(max-width:1200px){.signal-row{grid-template-columns:repeat(3,1fr);}}
.sig-card{background:var(--card);border-radius:var(--r);padding:16px 18px 12px;border:1px solid var(--line);display:flex;flex-direction:column;gap:0;position:relative;overflow:hidden;}
.sig-card.sig-primary{border-color:var(--brand-lime);border-width:2px;}
.sig-eyebrow{font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--soft);margin-bottom:6px;}
.sig-val{font-size:28px;font-weight:700;letter-spacing:-1.2px;line-height:1;color:var(--ink);}
.sig-val-unit{font-size:14px;font-weight:400;color:var(--soft);margin-left:2px;}
.sig-name{font-size:11px;font-weight:600;color:var(--ink3);margin-top:4px;line-height:1.3;}
.sig-sub{font-size:10px;font-weight:400;color:var(--soft);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sig-delta{font-size:10px;font-weight:600;margin-top:6px;}
.sig-delta.up{color:var(--accent-up);}
.sig-delta.dn{color:var(--accent-dn);}
.sig-delta.flat{color:var(--soft);}
/* ranked items inside card */
.sig-rank2{margin-top:8px;padding-top:8px;border-top:1px solid var(--line2);}
.sig-rank2-row{display:flex;align-items:center;justify-content:space-between;margin-top:4px;}
.sig-rank2-name{font-size:10px;font-weight:500;color:var(--mid);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sig-rank2-n{font-size:10px;font-weight:700;font-family:'DM Mono',monospace;color:var(--ink3);flex-shrink:0;margin-left:6px;}
.sig-rank-label{font-size:9px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--line);margin-right:4px;}

/* ══ GRIDS ══ */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;}
.g13{display:grid;grid-template-columns:1fr 3fr;gap:20px;}
.g31{display:grid;grid-template-columns:3fr 1fr;gap:20px;}
@media(max-width:960px){.g2,.g3,.g13,.g31{grid-template-columns:1fr;}}
.chart-box{position:relative;width:100%;}

/* ══ DEMAND HERO ══ */
.demand-hero{background:var(--brand-moss);border-radius:var(--r);padding:24px 24px 20px;}
.demand-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
@media(max-width:960px){.demand-cols{grid-template-columns:1fr;}}
.demand-col{background:rgba(255,255,255,0.05);border-radius:10px;padding:16px;border:1px solid rgba(255,255,255,0.08);}
.demand-col-title{font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:12px;display:flex;align-items:center;gap:7px;}
.dcicon{width:15px;height:15px;border-radius:3px;display:inline-flex;align-items:center;justify-content:center;font-size:9px;}
.dcicon-oos{background:rgba(255,255,255,0.1);}
.dcicon-new{background:var(--brand-lime);color:var(--brand-black);}
.dcicon-hi{background:rgba(255,255,255,0.15);}
.d-item{padding:7px 0;border-bottom:1px solid rgba(255,255,255,0.06);display:flex;flex-direction:column;gap:3px;}
.d-item:last-child{border-bottom:none;padding-bottom:0;}
.d-item-top{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.d-item-name{font-size:11px;font-weight:500;color:rgba(255,255,255,0.75);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.d-item-right{display:flex;align-items:center;gap:6px;flex-shrink:0;}
.d-item-count{font-size:11px;font-weight:700;font-family:'DM Mono',monospace;padding:1px 8px;border-radius:4px;}
.d-count-oos{background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.6);}
.d-count-new{background:var(--brand-lime);color:var(--brand-black);}
.d-count-hi{background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.7);}
.d-delta{font-size:9px;font-weight:700;white-space:nowrap;}
.d-delta.up{color:#7ec89a;}
.d-delta.dn{color:#e07070;}
.d-item-cat{font-size:9px;font-weight:400;color:rgba(255,255,255,0.25);letter-spacing:0.04em;}
.d-bar{height:2px;background:rgba(255,255,255,0.08);border-radius:1px;margin-top:3px;}
.d-bar-fill{height:2px;background:rgba(255,255,255,0.2);border-radius:1px;}
.d-bar-fill.new{background:var(--brand-lime);opacity:0.6;}

/* ══ RANKED TOPICS CARD ══ */
.topic-rank{display:flex;flex-direction:column;gap:0;}
.tr-item{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--line2);}
.tr-item:last-child{border-bottom:none;}
.tr-num{font-size:10px;font-weight:900;font-family:'DM Mono',monospace;color:var(--soft);width:16px;flex-shrink:0;}
.tr-num.n1{font-size:18px;color:var(--ink);width:20px;}
.tr-bar-wrap{flex:1;display:flex;flex-direction:column;gap:3px;}
.tr-name{font-size:12px;font-weight:700;color:var(--ink);}
.tr-name.n1{font-size:16px;font-weight:900;letter-spacing:-0.3px;}
.tr-bars{display:flex;flex-direction:column;gap:2px;}
.tr-bar-row{display:flex;align-items:center;gap:6px;}
.tr-bar-track{flex:1;height:5px;background:var(--line2);border-radius:3px;overflow:hidden;}
.tr-bar-fill{height:100%;border-radius:3px;}
.tr-bar-fill.cur{background:var(--brand-black);}
.tr-bar-fill.prv{background:var(--brand-grey);}
.tr-bar-label{font-size:9px;font-weight:800;color:var(--soft);width:28px;text-align:right;letter-spacing:0.02em;}
.tr-count{font-size:12px;font-weight:900;font-family:'DM Mono',monospace;color:var(--ink);flex-shrink:0;text-align:right;min-width:36px;}
.tr-count.n1{font-size:20px;}
.tr-delta{font-size:10px;font-weight:700;flex-shrink:0;min-width:40px;text-align:right;}
.tr-delta.up{color:var(--accent-dn);}/* more calls = problem escalating */
.tr-delta.dn{color:var(--accent-up);}

/* ══ TABLE ══ */
table{width:100%;border-collapse:collapse;font-size:12px;}
thead tr{border-bottom:2px solid var(--line);}
thead th{padding:8px 10px;text-align:left;font-size:9px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:var(--soft);}
thead th.c{text-align:center;}
tbody tr{border-bottom:1px solid var(--line2);transition:background 0.1s;}
tbody tr:hover{background:#fafafa;}
tbody td{padding:9px 10px;font-weight:600;}
tbody td.c{text-align:center;}
tbody td.mono{font-family:'DM Mono',monospace;font-size:10px;color:var(--soft);}
.sbadge{display:inline-block;padding:2px 9px;border-radius:5px;font-weight:800;font-size:11px;}
.sb-a{background:var(--brand-black);color:var(--brand-lime);}
.sb-b{background:#e8e8e8;color:var(--ink3);border:1px solid #d0d0d0;}
.sb-c{background:var(--line2);color:var(--mid);border:1px solid var(--line);}
a.ln{text-decoration:none;color:inherit;transition:opacity 0.1s;}
a.ln:hover{opacity:0.5;}

/* ══ SKILL BARS ══ */
.skill-rows{display:flex;flex-direction:column;gap:11px;}
.skill-row-item{display:flex;flex-direction:column;gap:4px;}
.skill-row-hdr{display:flex;justify-content:space-between;}
.skill-row-name{font-size:11px;font-weight:700;color:var(--ink);}
.skill-row-pct{font-size:11px;font-weight:900;font-family:'DM Mono',monospace;}
.skill-track{height:5px;background:var(--line2);border-radius:3px;overflow:hidden;}
.skill-fill{height:100%;border-radius:3px;background:var(--brand-black);transition:width 0.5s;}
.skill-fill.mid{background:#888;}
.skill-fill.low{background:#ccc;}

/* ══ FLAGS ══ */
.flag-list{display:flex;flex-direction:column;gap:6px;}
.flag-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#fafafa;border:1px solid var(--line);border-radius:var(--rs);gap:10px;}
.flag-name{font-size:12px;font-weight:700;color:var(--ink);}
.flag-cnt{font-size:10px;font-weight:700;background:var(--brand-black);color:var(--brand-lime);padding:2px 9px;border-radius:99px;font-family:'DM Mono',monospace;white-space:nowrap;}

/* ══ CHIPS ══ */
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.chip{display:flex;align-items:center;gap:5px;padding:4px 10px;background:var(--line2);border:1px solid var(--line);border-radius:7px;}
.chip-name{font-size:11px;font-weight:800;color:var(--ink);}
.chip-pct{font-size:9px;font-weight:700;background:var(--brand-black);color:var(--brand-lime);padding:1px 5px;border-radius:4px;}
.chip-n{font-size:9px;color:var(--soft);font-weight:600;}

/* ══ FAQ ══ */
.faq-list{display:flex;flex-direction:column;gap:5px;}
.faq-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#fafafa;border:1px solid var(--line);border-radius:var(--rs);gap:10px;transition:border-color 0.1s;}
.faq-item:hover{border-color:#ccc;}
.faq-q{font-size:12px;font-weight:700;color:var(--ink);}
.faq-n{font-size:11px;font-weight:900;font-family:'DM Mono',monospace;white-space:nowrap;}

/* ══ PAGINATION ══ */
.pag{display:flex;gap:4px;justify-content:flex-end;margin-top:10px;}
.pag button{padding:3px 10px;border-radius:5px;font-size:11px;font-weight:700;border:1.5px solid var(--line);background:#fff;cursor:pointer;font-family:inherit;transition:all 0.1s;}
.pag button.active{background:var(--brand-black);color:var(--brand-lime);border-color:var(--brand-black);}
.pag button:hover:not(.active){border-color:#bbb;background:var(--line2);}

/* ══ RANGE BADGE ══ */
.rbadge{display:inline-block;padding:2px 8px;border-radius:5px;font-weight:800;font-size:11px;}
.rb-hi{background:#e8e8e8;color:var(--ink3);border:1px solid #d0d0d0;}
.rb-ok{background:var(--line2);color:var(--mid);border:1px solid var(--line);}

.hof-sent{font-weight:900;color:var(--ink);}
hr.div{border:none;border-top:1px solid var(--line);margin:12px 0;}
.sec-div{font-size:9px;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;color:var(--soft);margin-bottom:8px;margin-top:4px;}

/* ══ CHART LEGEND ROW ══ */
.chart-legend{display:flex;gap:14px;margin-bottom:10px;}
.cl-item{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;color:var(--mid);}
.cl-dot{width:10px;height:10px;border-radius:2px;}

/* ══ COLUMN HEADER TOOLTIPS ══ */
.th-tip{position:relative;cursor:help;display:inline-flex;align-items:center;gap:3px;}
.th-tip::after{content:'?';display:inline-flex;align-items:center;justify-content:center;width:12px;height:12px;border-radius:50%;background:var(--line);color:var(--mid);font-size:8px;font-weight:900;font-style:normal;letter-spacing:0;text-transform:none;flex-shrink:0;}
.th-tip .tip-box{display:none;position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:11px;font-weight:500;letter-spacing:0;text-transform:none;padding:9px 13px;border-radius:8px;width:230px;line-height:1.55;z-index:500;pointer-events:none;white-space:normal;box-shadow:0 4px 20px rgba(0,0,0,0.2);}
.th-tip .tip-box::before{content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-bottom-color:var(--ink);}
.th-tip:hover .tip-box{display:block;}

/* ══ LIVE DOT ══ */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.35}}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--brand-lime);display:inline-block;animation:pulse 2s ease-in-out infinite;margin-right:5px;vertical-align:middle;}

/* ══ SPREAD BAR (alignment table) ══ */
.spread-wrap{display:flex;flex-direction:column;gap:3px;min-width:140px;}
.spread-track{position:relative;height:6px;background:var(--line2);border-radius:3px;overflow:visible;}
.spread-fill{position:absolute;height:100%;background:var(--brand-grey);border-radius:3px;transition:width 0.4s;}
.spread-fill.wide{background:#c0392b;}
.spread-fill.mid-spread{background:#e8a838;}
.spread-fill.tight{background:#2d7a3a;}
.spread-labels{display:flex;justify-content:space-between;font-size:9px;font-family:'DM Mono',monospace;color:var(--soft);}

/* ══ CALL MODAL ══ */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:1000;align-items:center;justify-content:center;backdrop-filter:blur(3px);}
.modal-overlay.open{display:flex;}
.modal{background:#fff;border-radius:16px;width:680px;max-width:95vw;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,0.3);}
.modal-head{background:var(--brand-black);padding:18px 22px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.modal-title{font-size:13px;font-weight:700;color:#fff;}
.modal-meta{font-size:11px;color:#555;margin-top:2px;}
.modal-close{background:none;border:none;color:#666;font-size:20px;cursor:pointer;padding:0;line-height:1;transition:color 0.15s;}
.modal-close:hover{color:var(--brand-lime);}
/* Player */
.modal-player{background:#0d0d0d;padding:16px 22px;flex-shrink:0;}
.player-bar{height:4px;background:#2a2a2a;border-radius:2px;margin:10px 0;cursor:pointer;position:relative;}
.player-progress{height:100%;background:var(--brand-lime);border-radius:2px;width:34%;transition:width 0.3s;}
.player-controls{display:flex;align-items:center;gap:12px;}
.player-btn{background:var(--brand-lime);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;flex-shrink:0;}
.player-time{font-size:11px;font-family:'DM Mono',monospace;color:#666;}
.player-meta{display:flex;gap:16px;margin-top:10px;}
.player-stat{font-size:10px;color:#555;display:flex;flex-direction:column;gap:2px;}
.player-stat strong{font-size:12px;color:#fff;font-weight:700;}
/* Transcript */
.modal-transcript{padding:18px 22px;overflow-y:auto;flex:1;}
.transcript-title{font-size:9px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--soft);margin-bottom:12px;}
.t-line{display:flex;gap:10px;margin-bottom:12px;}
.t-speaker{font-size:10px;font-weight:700;min-width:68px;flex-shrink:0;padding-top:2px;}
.t-speaker.op{color:var(--brand-black);}
.t-speaker.cu{color:var(--mid);}
.t-text{font-size:12px;line-height:1.6;color:var(--ink3);}
.t-highlight{background:#CAFE6E33;border-radius:3px;padding:0 2px;}

/* ══ CHART VALUE LABELS (via plugin) ══ */
/* handled in JS via Chart.js datalabels-style inline plugin */
