/* ============================================================
   DLS Operations Hub — Dark Tile Dashboard
   Grid: 6 columns at >=1200, 4 at >=800, 2 below
   Visual tokens defined in tokens.css
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --col-count:6;
}
body{background:var(--bg);color:var(--t1);font-family:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;min-height:100vh;-webkit-font-smoothing:antialiased}

/* Chrome bar */
.chrome-bar{height:3px;background:linear-gradient(90deg,var(--bg),var(--blue-mid),var(--blue-soft),var(--blue-mid),var(--bg))}

/* === NAV === */
.nav{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);flex-wrap:wrap;gap:var(--space-sm)}
.nav-left{display:flex;align-items:center;gap:var(--space-lg)}
.nav-logo{display:flex;align-items:center;gap:var(--space-sm)}
.nav-mark{width:30px;height:30px;flex-shrink:0}
.nav-title{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--t1)}
.nav-title span{color:var(--t1)}
.nav-sep{width:1px;height:22px;background:var(--border)}
.nav-tabs{display:flex;gap:2px}
.nav-tab{font-size:var(--text-lg);font-weight:var(--weight-medium);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);color:var(--t3);background:none;border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}
.nav-tab:hover{color:var(--t2);background:var(--bg-card)}
.nav-tab.active{color:#fff;background:var(--blue);box-shadow:0 0 14px rgba(59,107,255,.4)}
.nav-right{display:flex;align-items:center;gap:var(--space-md)}
.nav-auto-refresh{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-base);color:var(--t4);cursor:pointer}
.nav-auto-refresh input{cursor:pointer}
.nav-refresh-btn{font-size:var(--text-base);font-weight:var(--weight-medium);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);border:1px solid var(--border);background:none;color:var(--t3);cursor:pointer;transition:all var(--transition-fast)}
.nav-refresh-btn:hover{background:var(--bg-card);color:var(--t1);border-color:var(--border-hover)}
.nav-status{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-base);color:var(--t4);font-weight:var(--weight-medium)}
.nav-status.ok{color:var(--green)}
.nav-status.ok::before{content:'';width:6px;height:6px;border-radius:var(--radius-full);background:var(--green);box-shadow:0 0 10px var(--green),0 0 20px rgba(0,255,163,.3);animation:pulse 2s ease-in-out infinite}
.nav-status.err{color:var(--red)}
.nav-clock{font-size:var(--text-base);color:var(--t4);font-variant-numeric:tabular-nums}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* === GRID === */
.grid{display:grid;grid-template-columns:repeat(var(--col-count),1fr);gap:var(--space-md);padding:var(--space-md) var(--space-lg) var(--space-2xl)}
.tab-hidden{display:none!important}

/* Tile spans */
.span-1{grid-column:span 1}.span-2{grid-column:span 2}.span-3{grid-column:span 3}
.span-4{grid-column:span 4}.span-5{grid-column:span 5}.span-6{grid-column:span 6}

/* === TILE === */
.tile{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-lg);position:relative;overflow:hidden;transition:border-color var(--transition-normal),background var(--transition-normal),box-shadow var(--transition-normal)}
.tile:hover{border-color:var(--border-hover);background:var(--bg-card-hover);box-shadow:var(--shadow-sm)}
.tile::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent)}
.tile-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);flex-wrap:wrap;gap:var(--space-sm)}
.tile-title{font-size:var(--text-lg);font-weight:var(--weight-medium);color:var(--t2);letter-spacing:.3px}
.tile-badge{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--t4);background:var(--bg-elevated);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}
.tile-badge.ok{color:var(--green);background:var(--green-dim)}
.tile-badge.warn{color:var(--amber);background:var(--amber-dim)}
.tile-badge.err{color:var(--red);background:var(--red-dim)}
.tile-controls{display:flex;align-items:center;gap:var(--space-sm)}
.tile-pills{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.tile-pill{font-size:var(--text-sm);font-weight:var(--weight-medium);padding:var(--space-xs) var(--space-sm);background:transparent;color:var(--t4);border:none;cursor:pointer;transition:all var(--transition-fast)}
.tile-pill:hover{color:var(--t2)}
.tile-pill.active{background:var(--blue);color:#fff}
.tile-refresh{font-size:var(--text-sm);font-weight:var(--weight-medium);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);border:1px solid var(--border);background:none;color:var(--t4);cursor:pointer;transition:all var(--transition-fast)}
.tile-refresh:hover{background:var(--bg-elevated);color:var(--t2);border-color:var(--border-hover)}

/* === KPI TILE === */
.kpi{text-align:left}
.kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.kpi:nth-child(1)::before{background:linear-gradient(90deg,var(--blue),var(--blue-soft));box-shadow:0 0 8px rgba(59,107,255,.4)}
.kpi:nth-child(2)::before{background:linear-gradient(90deg,var(--blue-mid),var(--blue-soft));box-shadow:0 0 8px rgba(80,128,255,.4)}
.kpi:nth-child(3)::before{background:linear-gradient(90deg,var(--red),#ff8899);box-shadow:0 0 8px rgba(255,68,102,.4)}
.kpi:nth-child(4)::before{background:linear-gradient(90deg,var(--amber),#ffe066);box-shadow:0 0 8px rgba(255,204,0,.4)}
.kpi-label{font-size:var(--text-base);font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:1.2px;color:var(--t4);margin-bottom:var(--space-sm)}
.kpi-row{display:flex;align-items:baseline;gap:var(--space-sm)}
.kpi-val{font-size:var(--text-3xl);font-weight:var(--weight-bold);line-height:1;letter-spacing:-.5px;color:var(--t1)}
.kpi-val--green{color:var(--green);text-shadow:0 0 16px rgba(0,255,163,.3)}.kpi-val--amber{color:var(--amber);text-shadow:0 0 16px rgba(255,204,0,.3)}.kpi-val--red{color:var(--red);text-shadow:0 0 16px rgba(255,68,102,.3)}
.kpi-delta{font-size:var(--text-sm);font-weight:var(--weight-medium);padding:2px var(--space-xs);border-radius:var(--radius-sm)}
.kpi-delta.up{color:var(--green);background:var(--green-dim)}
.kpi-delta.down{color:var(--red);background:var(--red-dim)}
.kpi-sub{font-size:var(--text-base);color:var(--t4);margin-top:var(--space-xs)}

/* === CHART === */
.chart-wrap{position:relative;width:100%;height:220px}
.chart-wrap--tall{height:280px}

/* === DYNAMICS SUMMARY === */
.dynamics-summary{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-xs) var(--space-sm);margin-bottom:var(--space-sm);border-radius:var(--radius-sm);background:var(--bg-elevated);font-size:var(--text-base);flex-wrap:wrap}
.dynamics-stat{color:var(--t3);font-weight:var(--weight-medium)}
.dynamics-stat strong{color:var(--t1);font-weight:var(--weight-bold)}
.dynamics-stat--positive{color:var(--red)}
.dynamics-stat--negative{color:var(--green)}

/* === RING LAYOUT (categories) === */
.ring-layout{display:flex;align-items:center;gap:var(--space-md);height:220px;overflow:hidden}
.ring-chart{width:160px;height:160px;flex-shrink:0;position:relative}
.ring-legend{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;min-width:0;overflow:hidden}
.ring-legend-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-base);color:var(--t2);white-space:nowrap;overflow:hidden}
.ring-legend-dot{width:8px;height:8px;border-radius:var(--radius-sm);flex-shrink:0}
.ring-legend-label{overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.ring-legend-val{font-weight:var(--weight-medium);color:var(--t1);margin-left:var(--space-xs);min-width:32px;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0}

/* === WORKFLOW LIST === */
.wf-list{display:flex;flex-direction:column;gap:var(--space-xs);max-height:360px;overflow-y:auto}
.wf-list::-webkit-scrollbar{width:3px}.wf-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}
.wf-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast)}
.wf-row:hover{background:var(--bg-elevated)}
.wf-dot{width:7px;height:7px;border-radius:var(--radius-full);flex-shrink:0}
.wf-dot.ok{background:var(--green);box-shadow:0 0 6px rgba(0,255,163,.4),0 0 12px rgba(0,255,163,.15)}
.wf-dot.warn{background:var(--amber);box-shadow:0 0 6px rgba(255,204,0,.4),0 0 12px rgba(255,204,0,.15)}
.wf-dot.err{background:var(--red);box-shadow:0 0 6px rgba(255,68,102,.4),0 0 12px rgba(255,68,102,.15)}
.wf-dot.grey{background:var(--t4)}
.wf-info{flex:1;min-width:0}
.wf-name{font-size:var(--text-lg);font-weight:var(--weight-medium);color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wf-meta{font-size:var(--text-base);color:var(--t4);margin-top:1px}
.wf-pct{font-size:var(--text-lg);font-weight:var(--weight-bold);min-width:44px;text-align:right}
.wf-pct.ok{color:var(--green)}.wf-pct.warn{color:var(--amber)}.wf-pct.err{color:var(--red)}

/* === PIPELINE STATS === */
.pipeline-stats{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap}
.pipeline-stat{flex:1;min-width:60px;text-align:center;padding:var(--space-sm);background:var(--bg-elevated);border-radius:var(--radius-sm)}
.pipeline-stat__val{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--t1);line-height:1}
.pipeline-stat__val--danger{color:var(--red)}.pipeline-stat__val--warning{color:var(--amber)}.pipeline-stat__val--success{color:var(--green)}
.pipeline-stat__label{font-size:var(--text-xs);color:var(--t4);text-transform:uppercase;letter-spacing:.5px;margin-top:var(--space-xs)}

/* === TICKET LIST === */
.tkt-list{display:flex;flex-direction:column;gap:0;max-height:260px;overflow-y:auto}
.tkt-list::-webkit-scrollbar{width:3px}.tkt-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}
.tkt-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid rgba(255,255,255,.03);font-size:var(--text-md)}
.tkt-row:last-child{border-bottom:none}
.tkt-id{font-weight:var(--weight-medium);color:var(--blue-soft);min-width:66px;font-variant-numeric:tabular-nums}
.tkt-cat{color:var(--t3);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tkt-badge{font-size:var(--text-sm);font-weight:var(--weight-medium);padding:1px var(--space-xs);border-radius:var(--radius-sm)}
.tkt-badge--open{color:var(--red);background:var(--red-dim)}
.tkt-badge--pending{color:var(--amber);background:var(--amber-dim)}
.tkt-badge--resolved{color:var(--green);background:var(--green-dim)}
.tkt-badge--neutral{color:var(--t4);background:var(--bg-elevated)}
.tkt-time{font-size:var(--text-sm);color:var(--t4);min-width:40px;text-align:right;flex-shrink:0}

/* === SALES === */
.sales-timer{font-size:var(--text-sm);color:var(--t4);font-variant-numeric:tabular-nums}
.sales-sections{max-height:600px;overflow-y:auto}
.sales-sections::-webkit-scrollbar{width:3px}.sales-sections::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}
.sales-section{margin-bottom:var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.sales-section__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);cursor:pointer;user-select:none;transition:background var(--transition-fast)}
.sales-section__header:hover{filter:brightness(1.1)}
.sales-section__header::before{content:'\25BC';font-size:var(--text-xs);margin-right:var(--space-sm);transition:transform var(--transition-fast);color:inherit;opacity:.5}
.sales-section__header--collapsed::before{transform:rotate(-90deg)}
.sales-section__title{font-weight:var(--weight-bold);font-size:var(--text-md)}
.sales-section__count{background:rgba(255,255,255,.1);border-radius:var(--radius-full);padding:1px var(--space-sm);font-size:var(--text-sm);font-weight:var(--weight-medium)}
.sales-section--danger .sales-section__header{background:rgba(255,68,102,.12);color:var(--red)}
.sales-section--warning .sales-section__header{background:var(--amber-dim);color:var(--amber)}
.sales-section--info .sales-section__header{background:rgba(59,107,255,.15);color:var(--blue-soft)}
.sales-section--muted .sales-section__header{background:var(--bg-elevated);color:var(--t3)}
.sales-section__body--collapsed{display:none}

.sales-table{width:100%;border-collapse:collapse;font-size:var(--text-base)}
.sales-table th{padding:var(--space-sm);text-align:left;font-weight:var(--weight-medium);color:var(--t4);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-elevated);border-bottom:1px solid var(--border);position:sticky;top:0}
.sales-table td{padding:var(--space-sm);border-bottom:1px solid rgba(255,255,255,.03);vertical-align:top;color:var(--t2)}
.sales-table tr:hover td{background:rgba(255,255,255,.02)}
.sales-ticket-link{color:var(--blue-soft);text-decoration:none;font-weight:var(--weight-medium)}
.sales-ticket-link:hover{text-decoration:underline}
.sales-ticket-subject{color:var(--t4)}
.sales-td-center{text-align:center}
.sales-td-msg{max-width:250px;color:var(--t3)}
.value-badge{display:inline-block;padding:1px var(--space-xs);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--weight-medium);white-space:nowrap}
.value-badge--high{background:var(--green-dim);color:var(--green)}
.value-badge--medium{background:var(--amber-dim);color:var(--amber)}
.value-badge--low{background:var(--bg-elevated);color:var(--t4)}
.value-badge--unknown{background:var(--bg-elevated);color:var(--t4)}
.urgency-tag{display:inline-block;padding:1px var(--space-xs);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--weight-medium);background:var(--red-dim);color:var(--red);white-space:nowrap}
.sales-footer{padding:var(--space-sm) 0;text-align:right;font-size:var(--text-sm);color:var(--t4)}

/* === FORMS === */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm);margin-bottom:var(--space-md)}
.form-group{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-sm)}
.form-group--full{grid-column:1/-1}
.form-group label{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--t4);text-transform:uppercase;letter-spacing:.5px}
.form-group input,.form-group select,.form-group textarea{padding:var(--space-sm);font-family:inherit;font-size:var(--text-lg);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--t1);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--t4)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 2px rgba(59,107,255,.25),0 0 12px rgba(59,107,255,.1)}
.form-group textarea{resize:vertical}
.form-group select{cursor:pointer}
.form-group select option{background:var(--bg-card);color:var(--t1)}
.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-lg);font-family:inherit;font-size:var(--text-md);font-weight:var(--weight-medium);border:none;border-radius:var(--radius-sm);background:var(--blue);color:#fff;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 0 10px rgba(59,107,255,.25)}
.btn-primary:hover:not(:disabled){background:var(--blue-mid);box-shadow:0 0 18px rgba(59,107,255,.4)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}

/* === PRICING RESULTS === */
.pricing-results{margin-top:var(--space-md)}
.pricing-results table{width:100%;border-collapse:collapse;font-size:var(--text-md)}
.pricing-results th{padding:var(--space-sm);text-align:left;font-weight:var(--weight-medium);color:var(--t4);font-size:var(--text-sm);text-transform:uppercase;background:var(--bg-elevated);border-bottom:1px solid var(--border)}
.pricing-results td{padding:var(--space-sm);border-bottom:1px solid rgba(255,255,255,.03);color:var(--t2)}

/* === RESULT MESSAGE === */
.result-msg{margin-top:var(--space-sm);padding:var(--space-sm);font-size:var(--text-base);border-radius:var(--radius-sm);display:none}
.result-msg.is-visible{display:block}
.result-msg--success{background:var(--green-dim);color:var(--green);border:1px solid rgba(0,255,163,.25)}
.result-msg--error{background:var(--red-dim);color:var(--red);border:1px solid rgba(255,68,102,.25)}

/* === LOADING OVERLAY === */
.tile-loading{position:absolute;inset:0;background:rgba(10,14,26,.85);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);z-index:10}
.tile-loading::after{content:'';width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--blue-soft);border-radius:var(--radius-full);animation:spin .7s linear infinite;box-shadow:var(--shadow-sm)}
@keyframes spin{to{transform:rotate(360deg)}}

/* === EMPTY STATE === */
.empty-state{text-align:center;padding:var(--space-xl);color:var(--t4);font-size:var(--text-lg)}

/* === SECTION HEADER (reused in pricing) === */
.section-header{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin:var(--space-md) 0 var(--space-xs)}

/* === RESPONSIVE === */
@media(max-width:1200px){:root{--col-count:4}
  .span-5,.span-6{grid-column:span 4}
  .span-3{grid-column:span 2}
}
@media(max-width:800px){:root{--col-count:2}
  .span-3,.span-4,.span-5,.span-6{grid-column:span 2}
  .nav-tabs{display:none}
  .ring-layout{flex-direction:column;height:auto}
  .ring-chart{width:100%;height:180px}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:480px){:root{--col-count:1}
  .span-1,.span-2,.span-3,.span-4,.span-5,.span-6{grid-column:span 1}
}

/* === UPTIME BARS === */
.tile-sub{font-size:var(--text-sm);color:var(--t4);font-weight:var(--weight-normal);margin-left:var(--space-sm)}
.uptime-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-bottom:1px solid var(--border)}
.uptime-row:last-child{border-bottom:none}
.uptime-label{width:100px;font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--t2);flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.uptime-bars{flex:1;display:flex;gap:1px;height:24px;align-items:stretch;min-width:0}
.uptime-bar{flex:1;border-radius:var(--radius-sm);min-width:1px;display:block;transition:opacity var(--transition-fast)}
.uptime-bar:hover{filter:brightness(.9)}
.uptime-bar{position:relative}
.uptime-bar::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);background:#0a0e1a;border:1px solid #3a4d6b;color:#f0f6ff;font-size:var(--text-xs);font-weight:var(--weight-medium);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--transition-fast);z-index:20;box-shadow:0 4px 12px rgba(0,0,0,.8)}
.uptime-bar:hover::after{opacity:1}
.uptime-bar.up{background:var(--green)}
.uptime-bar.degraded{background:var(--amber)}
.uptime-bar.down{background:var(--red)}
.uptime-bar.nodata{background:var(--border)}
.uptime-pct{width:52px;text-align:right;font-size:var(--text-base);font-weight:var(--weight-bold);flex-shrink:0}
.uptime-pct.good{color:var(--green)}
.uptime-pct.fair{color:var(--amber)}
.uptime-pct.poor{color:var(--red)}
.uptime-pct.na{color:var(--t4)}
.uptime-range{display:flex;justify-content:space-between;padding:var(--space-xs) 118px 0 118px;font-size:var(--text-xs);color:var(--t4)}

/* === EXPANDABLE REPORT CARDS === */
.report-card{cursor:pointer;transition:background var(--transition-fast);border-radius:var(--radius-sm);padding:var(--space-sm);border-bottom:1px solid rgba(255,255,255,.03)}
.report-card:last-child{border-bottom:none}
.report-card:hover{background:rgba(255,255,255,.03)}
.report-card.selected{background:var(--bg-elevated);border-color:var(--border-hover);box-shadow:var(--shadow-sm)}
.report-card-header{display:flex;align-items:center;gap:var(--space-sm)}

/* Detail panel body */
#report-detail-body{min-height:200px}
#report-detail-body .report-thread{max-height:400px}
#report-detail-body .report-detail-desc{min-height:80px;margin-bottom:var(--space-md)}
#report-detail-body .report-detail-actions{margin-top:var(--space-xs)}

/* Report detail */
textarea.report-detail-desc{width:100%;font-size:var(--text-base);color:var(--t2);margin-bottom:var(--space-md);line-height:1.6;padding:var(--space-sm) var(--space-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;resize:vertical;transition:border-color var(--transition-fast)}
textarea.report-detail-desc:focus{outline:none;border-color:var(--blue-soft);box-shadow:0 0 0 2px rgba(59,107,255,.15)}
.report-detail-actions{display:flex;gap:var(--space-sm);align-items:center;margin-bottom:var(--space-md);flex-wrap:wrap}
.report-detail-actions select{padding:var(--space-xs) var(--space-sm);font-size:var(--text-base);font-family:inherit;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--t1);cursor:pointer;transition:border-color var(--transition-fast)}
.report-detail-actions select:focus{outline:none;border-color:var(--blue-soft)}
.report-detail-actions select option{background:var(--bg-card);color:var(--t1)}

/* Action buttons */
.btn-action{padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;transition:all var(--transition-fast);letter-spacing:.3px}
.btn-action:hover{filter:brightness(1.15)}
.btn-action:disabled{opacity:.5;cursor:not-allowed}
.btn-assess{background:var(--blue);color:#fff;box-shadow:var(--shadow-sm)}
.btn-assess:hover{background:var(--blue-mid)}
.btn-build{background:var(--green);color:#0c1220;box-shadow:0 0 8px rgba(0,255,163,.2)}
.btn-replan{background:var(--amber);color:#0c1220}
.btn-save{background:var(--blue);color:#fff;box-shadow:var(--shadow-sm)}
.btn-save:hover{background:var(--blue-mid)}

/* Chat thread */
.report-thread{max-height:300px;overflow-y:auto;margin-bottom:var(--space-sm)}
.report-thread:empty{display:none}
.report-thread::-webkit-scrollbar{width:3px}.report-thread::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}
.thread-msg{padding:var(--space-sm) var(--space-md);margin:var(--space-xs) 0;border-radius:var(--radius-md);font-size:var(--text-base);line-height:1.5;white-space:pre-wrap;word-break:break-word}
.thread-msg.assistant{background:rgba(0,180,130,.1);border-left:3px solid var(--green)}
.thread-msg.user{background:rgba(255,255,255,.05);border-left:3px solid var(--t3)}
.thread-msg.system{color:var(--t3);font-style:italic;font-size:var(--text-sm);padding:var(--space-xs) var(--space-md)}

/* Thread pulsing indicator (while Allard is thinking) */
.report-thread.pulsing .thread-msg:last-child::after{content:'';display:inline-block;width:6px;height:6px;border-radius:var(--radius-full);background:var(--blue-soft);margin-left:var(--space-sm);vertical-align:middle;animation:pulse 1.2s ease-in-out infinite}

/* Input row */
.report-input-row{display:flex;gap:var(--space-sm);align-items:center}
.report-input-row input{flex:1;padding:var(--space-sm);font-size:var(--text-base);font-family:inherit;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--t1);transition:border-color var(--transition-fast)}
.report-input-row input::placeholder{color:var(--t4)}
.report-input-row input:focus{outline:none;border-color:var(--blue-soft);box-shadow:0 0 0 2px rgba(59,107,255,.15)}
.btn-send{background:var(--blue);color:#fff;padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;transition:all var(--transition-fast)}
.btn-send:hover{background:var(--blue-mid)}

/* Status indicator */
.report-status-text{font-size:var(--text-sm);color:var(--t3);margin-top:var(--space-xs)}
.report-status-text .pulsing-dot{display:inline-block;width:6px;height:6px;border-radius:var(--radius-full);background:var(--blue-soft);margin-right:var(--space-xs);animation:pulse 1.2s ease-in-out infinite}

/* Bridge health dot */
.bridge-dot{display:inline-block;width:8px;height:8px;border-radius:var(--radius-full);margin-left:var(--space-xs);vertical-align:middle}
.bridge-dot.online{background:var(--green);box-shadow:0 0 6px rgba(0,255,163,.4)}
.bridge-dot.offline{background:var(--t4)}

/* Bridge activity tile */
.bridge-job-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-bottom:1px solid rgba(255,255,255,.03)}
.bridge-job-row:last-child{border-bottom:none}
.bridge-job-phase{font-size:var(--text-sm);font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:.5px;padding:2px var(--space-sm);border-radius:var(--radius-sm);min-width:60px;text-align:center}
.bridge-job-phase.assess{background:rgba(59,107,255,.15);color:var(--blue-soft)}
.bridge-job-phase.reply{background:rgba(255,204,0,.12);color:var(--amber)}
.bridge-job-phase.execute{background:rgba(0,255,163,.12);color:var(--green)}
.bridge-job-info{flex:1;min-width:0}
.bridge-job-report{font-size:var(--text-lg);font-weight:var(--weight-medium);color:var(--t1)}
.bridge-job-desc{font-size:var(--text-base);color:var(--t4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}
.bridge-job-status{display:flex;align-items:center;gap:var(--space-xs);min-width:80px;justify-content:flex-end}
.bridge-job-status .pulsing-dot{display:inline-block;width:6px;height:6px;border-radius:var(--radius-full);background:var(--blue-soft);animation:pulse 1.2s ease-in-out infinite}
.bridge-job-elapsed{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--t3);font-variant-numeric:tabular-nums}
.bridge-job-done{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--green)}
.bridge-job-err{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--red)}
.bridge-job-row{cursor:pointer;transition:background var(--transition-fast)}
.bridge-job-row:hover{background:rgba(255,255,255,.03)}
.bridge-job-expanded{background:var(--bg-elevated)!important}
.bridge-job-live{margin-top:var(--space-xs);padding:var(--space-sm);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-base);line-height:1.5;color:var(--t2);white-space:pre-wrap;word-break:break-word;max-height:150px;overflow-y:auto}
.bridge-job-live::-webkit-scrollbar{width:3px}.bridge-job-live::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}

/* === FILE REPORTS (Reports tab) === */
.report-filters{display:flex;gap:var(--space-xs);flex-wrap:wrap}
.report-pill{font-size:var(--text-base);font-weight:var(--weight-medium);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);border:1px solid var(--border);background:transparent;color:var(--t3);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}
.report-pill:hover{color:var(--t1);border-color:var(--border-hover);background:var(--bg-elevated)}
.report-pill.active{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:var(--shadow-sm)}
/* Report list panel */
.rpt-list-panel{overflow:hidden;display:flex;flex-direction:column}
.rpt-card-list{display:flex;flex-direction:column;gap:var(--space-sm);overflow-y:auto;max-height:calc(100vh - 200px);padding-right:var(--space-xs)}
.rpt-card-list .rpt-card{flex-shrink:0}
.rpt-card-list::-webkit-scrollbar{width:3px}.rpt-card-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}
.rpt-card{display:flex;flex-direction:column;background:var(--bg-elevated);border:1px solid var(--border);border-left:4px solid var(--blue);border-radius:var(--radius-md);padding:var(--space-lg);text-decoration:none;color:inherit;transition:all var(--transition-normal);position:relative;cursor:pointer;min-height:0}
.rpt-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover);box-shadow:0 2px 16px rgba(59,107,255,.1)}
.rpt-card.rpt-selected{border-color:var(--blue);background:var(--bg-card-hover);box-shadow:0 0 12px rgba(59,107,255,.2)}
.rpt-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}
.rpt-card-cat{font-size:var(--text-sm);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.8px;padding:2px var(--space-sm);border-radius:var(--radius-sm)}
.rpt-card-date{font-size:var(--text-md);color:var(--t2);font-weight:var(--weight-medium);font-variant-numeric:tabular-nums}
.rpt-card-title{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--t1);line-height:1.3;margin-bottom:var(--space-xs)}
.rpt-card-subtitle{font-size:var(--text-md);color:var(--t3);line-height:1.4;margin-bottom:var(--space-sm)}
.rpt-card-highlights{list-style:none;padding:0;margin:0 0 auto 0;display:flex;flex-direction:column;gap:var(--space-xs)}
.rpt-card-highlights li{font-size:var(--text-base);color:var(--t2);line-height:1.4;padding-left:var(--space-lg);position:relative}
.rpt-card-highlights li::before{content:'\2022';position:absolute;left:0;color:var(--t4);font-size:var(--text-md);line-height:1.4}
.rpt-card-footer{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--blue-soft);opacity:.5;transition:opacity var(--transition-fast);margin-top:var(--space-md);padding-top:var(--space-sm);border-top:1px solid rgba(255,255,255,.04)}
.rpt-card:hover .rpt-card-footer{opacity:1}

/* Report viewer panel */
.rpt-viewer-panel{display:flex;flex-direction:column;overflow:hidden}
.rpt-viewer-body{flex:1;min-height:0}
.rpt-viewer-body iframe{width:100%;height:calc(100vh - 200px);border:none;border-radius:var(--radius-sm);background:#0a0e1a}

/* Feedback panel (expanded on card select) */
.rpt-feedback-panel{display:none;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid rgba(255,255,255,.06)}
.rpt-feedback-panel.open{display:flex}
.rpt-feedback-row{display:flex;align-items:center;gap:var(--space-md)}
.rpt-feedback-label{font-size:var(--text-sm);color:var(--t3);text-transform:uppercase;letter-spacing:.5px;min-width:48px}
.rpt-stars{display:flex;gap:2px}
.rpt-star{font-size:var(--text-lg);cursor:pointer;color:var(--t4);transition:color var(--transition-fast);background:none;border:none;padding:0;line-height:1}
.rpt-star:hover,.rpt-star.active{color:var(--amber)}
.rpt-note-input{display:block;width:100%;padding:var(--space-sm);font-size:var(--text-base);font-family:inherit;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--t1);resize:vertical;min-height:60px;box-sizing:border-box}
.rpt-note-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 2px rgba(59,107,255,.15)}
.rpt-submit-row{display:flex;align-items:center;gap:var(--space-sm);justify-content:flex-end}
.rpt-submitter{padding:var(--space-xs) var(--space-sm);font-size:var(--text-sm);font-family:inherit;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--t1);cursor:pointer;min-width:140px}
.rpt-submitter:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 2px rgba(59,107,255,.15)}
.rpt-submit-btn{padding:var(--space-xs) var(--space-lg);font-size:var(--text-sm);font-weight:var(--weight-bold);color:#fff;background:var(--blue);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.5px}
.rpt-submit-btn:hover{background:var(--blue-soft);box-shadow:0 2px 8px rgba(59,107,255,.3)}
.rpt-submit-btn.saved{background:var(--green)}
.rpt-toast{text-align:center;padding:var(--space-xs) var(--space-sm);font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--green);background:rgba(67,233,123,.08);border:1px solid rgba(67,233,123,.25);border-radius:var(--radius-sm);animation:rpt-toast-in .2s ease-out}

@media(max-width:1200px){.rpt-list-panel{grid-column:span 2}.rpt-viewer-panel{grid-column:span 2}}
@media(max-width:800px){.rpt-list-panel{grid-column:span 2}.rpt-viewer-panel{grid-column:span 2}.rpt-card-list{max-height:400px}}
