/* ConcreteQC Dashboard styles — extracted from ConcreteQC_Dashboard.html */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#f5f5f7;--card:#fff;--card-hover:#fbfbfd;
  --text:#1d1d1f;--text-sec:#5a5a62;--text-tert:#7c7c84;
  --border:rgba(0,0,0,.06);--border-strong:rgba(0,0,0,.1);
  --green:#34c759;--green-bg:rgba(52,199,89,.08);--green-text:#248a3d;
  --amber:#ff9f0a;--amber-bg:rgba(255,159,10,.08);--amber-text:#c77c00;
  --red:#ff3b30;--red-bg:rgba(255,59,48,.06);--red-text:#d70015;
  --blue:#007aff;--blue-bg:rgba(0,122,255,.06);--blue-text:#0055d4;
  --purple:#af52de;
  --radius:16px;--radius-sm:12px;
  --shadow:0 1px 3px rgba(0,0,0,.04),0 4px 12px rgba(0,0,0,.04);
  --shadow-hover:0 2px 8px rgba(0,0,0,.06),0 8px 24px rgba(0,0,0,.06);
  --font:-apple-system,BlinkMacSystemFont,"SF Pro Text","SF Pro Display","Helvetica Neue",sans-serif;
  --mono:"SF Mono",SFMono-Regular,Menlo,Consolas,monospace;
  --ease:cubic-bezier(.25,.1,.25,1);
}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}

/* === HEADER === */
.header{padding:32px 40px 0;max-width:1400px;margin:0 auto}
.header-top{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:12px}
.header h1{font-size:34px;font-weight:700;letter-spacing:-.5px;color:var(--text)}
.header h1 small{font-size:15px;font-weight:400;color:var(--text-sec);margin-left:6px;letter-spacing:0}
.meta-row{display:flex;gap:20px;flex-wrap:wrap;margin-top:4px}
.meta-pill{font-size:12px;color:var(--text-sec);display:flex;align-items:center;gap:5px;letter-spacing:.2px}
.meta-pill b{color:var(--text);font-weight:600}
.meta-dot{width:6px;height:6px;border-radius:50%;display:inline-block}
.dot-g{background:var(--green)}.dot-a{background:var(--amber)}.dot-r{background:var(--red)}

/* === SEGMENTED CONTROL === */
.seg-wrap{display:flex;justify-content:center;margin:24px auto 0;padding:0 40px}
.seg-ctrl{display:inline-flex;background:rgba(0,0,0,.06);border-radius:10px;padding:2px;gap:0}
.seg-btn{padding:8px 24px;font-size:13px;font-weight:600;color:var(--text-sec);cursor:pointer;border:none;background:none;border-radius:8px;transition:all .25s var(--ease);letter-spacing:-.1px;white-space:nowrap;font-family:var(--font)}
.seg-btn:hover{color:var(--text)}
.seg-btn.active{background:var(--card);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.08),0 0.5px 1px rgba(0,0,0,.06)}

/* === PAGE CONTAINERS === */
.page{display:none;padding:24px 40px 48px;max-width:1400px;margin:0 auto;animation:fadeUp .35s var(--ease)}
.page.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* === LOGIN SCREEN (Apple-style) === */
.login-screen{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#e8ecf3 0%,#f5f5f7 40%,#eaf1fb 100%)}
.login-screen.hiding{animation:loginHide .7s cubic-bezier(.4,0,.2,1) forwards}
@keyframes loginHide{
  0%{opacity:1;transform:scale(1);filter:blur(0)}
  60%{opacity:.4;transform:scale(1.04);filter:blur(6px)}
  100%{opacity:0;transform:scale(1.08);filter:blur(16px);pointer-events:none;visibility:hidden}
}
/* animated mesh orbs */
.login-orb{position:absolute;border-radius:50%;filter:blur(70px);opacity:.55;pointer-events:none;animation:orbFloat 14s ease-in-out infinite}
.login-orb.o1{width:460px;height:460px;background:radial-gradient(circle,#a8c5ff,transparent 70%);top:-120px;left:-120px}
.login-orb.o2{width:520px;height:520px;background:radial-gradient(circle,#c4b5fd,transparent 70%);bottom:-160px;right:-140px;animation-delay:-5s}
.login-orb.o3{width:360px;height:360px;background:radial-gradient(circle,#bbf7d0,transparent 70%);top:40%;left:50%;transform:translate(-50%,-50%);animation-delay:-9s;opacity:.35}
@keyframes orbFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(30px,-40px) scale(1.08)}
  66%{transform:translate(-25px,35px) scale(.95)}
}
.login-orb.o3{animation-name:orbFloatCenter}
@keyframes orbFloatCenter{
  0%,100%{transform:translate(-50%,-50%) scale(1)}
  50%{transform:translate(-50%,-50%) scale(1.15)}
}

.login-card{position:relative;z-index:2;width:380px;max-width:calc(100vw - 32px);background:rgba(255,255,255,.72);backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);border:0.5px solid rgba(255,255,255,.8);border-radius:22px;padding:36px 32px 28px;box-shadow:0 30px 80px rgba(30,50,100,.18),0 8px 24px rgba(30,50,100,.08),inset 0 0 0 0.5px rgba(255,255,255,.4);text-align:center;animation:cardIn .85s cubic-bezier(.2,.8,.2,1) both}
@keyframes cardIn{
  0%{opacity:0;transform:translateY(28px) scale(.94);filter:blur(8px)}
  60%{filter:blur(0)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}

.login-logo{width:72px;height:72px;margin:0 auto 18px;border-radius:20px;background:linear-gradient(135deg,#5b8def 0%,#3c6bd9 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(60,107,217,.35),inset 0 1px 0 rgba(255,255,255,.3);animation:logoIn 1s cubic-bezier(.2,1.3,.4,1) .15s both}
@keyframes logoIn{
  0%{opacity:0;transform:scale(.3) rotate(-12deg)}
  60%{transform:scale(1.08) rotate(3deg)}
  100%{opacity:1;transform:scale(1) rotate(0)}
}
.login-logo svg{width:38px;height:38px;stroke:#fff;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}

.login-title{font-size:22px;font-weight:700;letter-spacing:-.4px;color:#1d1d1f;margin-bottom:3px;animation:fadeSlide .7s ease-out .35s both}
.login-subtitle{font-size:13px;color:#5a5a62;font-weight:500;margin-bottom:24px;animation:fadeSlide .7s ease-out .45s both}
.login-credit{font-size:10px;color:#9e9ea8;letter-spacing:.3px;margin-top:18px;font-weight:400;animation:fadeSlide .7s ease-out 1s both}
@keyframes fadeSlide{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

.login-input-wrap{position:relative;margin-bottom:10px;animation:fadeSlide .7s ease-out .55s both}
.login-input{width:100%;padding:12px 14px;font-size:14px;font-family:var(--font);border:1px solid rgba(0,0,0,.1);border-radius:10px;background:rgba(255,255,255,.85);outline:none;transition:all .2s var(--ease);color:#1d1d1f;text-align:center;letter-spacing:1px}
.login-input::placeholder{letter-spacing:0;color:#9e9ea8}
.login-input:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px rgba(0,122,255,.12)}
.login-input.shake{animation:shake .4s cubic-bezier(.36,.07,.19,.97)}
@keyframes shake{
  10%,90%{transform:translateX(-1px)}
  20%,80%{transform:translateX(2px)}
  30%,50%,70%{transform:translateX(-4px)}
  40%,60%{transform:translateX(4px)}
}

.login-error{font-size:11.5px;color:var(--red-text);min-height:16px;margin-bottom:6px;font-weight:500}
.login-btn{width:100%;padding:12px;font-size:14px;font-weight:600;font-family:var(--font);border:none;border-radius:10px;cursor:pointer;transition:all .2s var(--ease);margin-top:4px;animation:fadeSlide .7s ease-out .65s both}
.login-btn-primary{background:linear-gradient(180deg,#4285ee 0%,#3370e0 100%);color:#fff;box-shadow:0 2px 6px rgba(50,110,220,.25),inset 0 1px 0 rgba(255,255,255,.2)}
.login-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(50,110,220,.35),inset 0 1px 0 rgba(255,255,255,.2)}
.login-btn-primary:active{transform:translateY(0) scale(.98)}
.login-divider{display:flex;align-items:center;gap:10px;margin:16px 0 10px;color:#9e9ea8;font-size:11px;font-weight:500;animation:fadeSlide .7s ease-out .75s both}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:rgba(0,0,0,.08)}
.login-btn-guest{background:rgba(0,0,0,.035);color:#1d1d1f;font-weight:500;animation:fadeSlide .7s ease-out .85s both}
.login-btn-guest:hover{background:rgba(0,0,0,.06)}
.login-btn-guest:active{transform:scale(.98)}

/* === ROLE-BLOCK POPUP === */
.role-block-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(10px) saturate(180%);-webkit-backdrop-filter:blur(10px) saturate(180%);z-index:9500;display:none;align-items:center;justify-content:center;animation:overlayIn .22s var(--ease)}
.role-block-overlay.open{display:flex}
@keyframes overlayIn{from{opacity:0}to{opacity:1}}
.role-block-dialog{background:rgba(255,255,255,.96);backdrop-filter:blur(30px);border-radius:14px;width:300px;padding:22px 20px 0;box-shadow:0 20px 60px rgba(0,0,0,.3),0 0 0 0.5px rgba(0,0,0,.1);text-align:center;animation:dialogIn .28s cubic-bezier(.2,.9,.3,1.1);overflow:hidden}
@keyframes dialogIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.role-block-icon{width:52px;height:52px;margin:0 auto 12px;border-radius:50%;background:linear-gradient(135deg,#ff9f0a,#ff6b00);display:flex;align-items:center;justify-content:center;color:#fff;font-size:26px;box-shadow:0 6px 16px rgba(255,107,0,.3)}
.role-block-title{font-size:16px;font-weight:600;color:#1d1d1f;letter-spacing:-.2px;margin-bottom:6px}
.role-block-msg{font-size:13px;color:#5a5a62;line-height:1.45;margin-bottom:18px;padding:0 4px}
.role-block-msg b{color:#1d1d1f}
.role-block-btns{display:flex;margin:0 -20px;border-top:0.5px solid rgba(0,0,0,.12)}
.role-block-btn{flex:1;padding:12px;font-size:14px;font-weight:600;font-family:var(--font);background:none;border:none;cursor:pointer;color:var(--blue);transition:background .15s}
.role-block-btn:hover{background:rgba(0,122,255,.06)}

/* Dim restricted buttons visually for guests */
.seg-btn.restricted{opacity:.55}
.seg-btn.restricted::after{content:'🔒';font-size:9px;margin-left:5px;opacity:.7;vertical-align:top}

/* Role badge in header */
.role-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:10px;font-size:11px;font-weight:600;letter-spacing:.2px;margin-left:10px;cursor:pointer;transition:all .2s var(--ease)}
.role-badge.engineer{background:var(--green-bg);color:var(--green-text)}
.role-badge.guest{background:rgba(0,0,0,.06);color:var(--text-sec)}
.role-badge:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,.08)}

/* === HERO KPI === */
.hero{display:flex;gap:0;justify-content:center;flex-wrap:wrap;padding:28px 0 8px;border-bottom:1px solid var(--border)}
.hero-stat{text-align:center;padding:0 36px;position:relative}
.hero-stat:not(:last-child)::after{content:'';position:absolute;right:0;top:8px;bottom:8px;width:1px;background:var(--border)}
.hero-stat .hl{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-tert);font-weight:600;margin-bottom:2px}
.hero-stat .hv{font-size:36px;font-weight:700;letter-spacing:-1.5px;font-family:var(--font);line-height:1.1}
.hero-stat .hs{font-size:12px;color:var(--text-sec);margin-top:3px}
.hv-green{color:var(--green-text)}.hv-amber{color:var(--amber-text)}.hv-red{color:var(--red-text)}.hv-default{color:var(--text)}

/* === CARDS === */
.card{background:var(--card);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);margin-bottom:20px;transition:box-shadow .3s var(--ease)}
.card:hover{box-shadow:var(--shadow-hover)}
.card-title{font-size:17px;font-weight:600;color:var(--text);margin-bottom:16px;letter-spacing:-.2px}
.card-subtle{font-size:13px;color:var(--text-sec);margin-bottom:16px;line-height:1.6}

/* === GRID === */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid3{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
@media(max-width:900px){.grid2,.grid3{grid-template-columns:1fr}.hero-stat{padding:0 20px}}
@media(max-width:600px){
  .header,.page{padding-left:16px;padding-right:16px}
  .header{padding-top:22px}
  .header h1{font-size:26px}
  .header h1 small{display:block;margin-left:0;margin-top:2px}
  /* Tab bar: scroll horizontally instead of overflowing the page */
  .seg-wrap{padding:0 12px;justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .seg-wrap::-webkit-scrollbar{display:none}
  .seg-ctrl{flex:0 0 auto}
  .seg-btn{padding:11px 16px}
  /* Stack filters; make inputs full-width so they don't overflow */
  .filters{flex-direction:column;align-items:stretch;gap:10px}
  .date-range{margin-left:0;flex-wrap:wrap}
  select,.search-box,.pfb-input{min-width:0;width:100%}
  select{min-width:0}
  .chart-container{height:300px}
  /* Keep tooltips inside the viewport */
  .kpi .tooltip,.apple-tip-host .apple-tip,.apple-tip-inline .apple-tip,.stat-box .stat-tip{max-width:calc(100vw - 32px)}
}

/* === COMPACT KPIs (trend page) === */
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:12px;margin-bottom:20px}
.kpi{background:var(--card);border-radius:var(--radius-sm);padding:16px 18px;box-shadow:var(--shadow);position:relative;transition:all .25s var(--ease);cursor:default;overflow:visible}
.kpi:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}
.kpi.has-tip{cursor:help}
.kpi .label{font-size:10px;color:var(--text-tert);text-transform:uppercase;letter-spacing:.7px;font-weight:600}
.kpi .value{font-size:24px;font-weight:700;margin-top:3px;letter-spacing:-.8px}
.kpi .sub{font-size:11px;color:var(--text-sec);margin-top:2px}
.kpi .tooltip{display:none;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%);background:rgba(29,29,31,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:#fff;padding:12px 16px;border-radius:12px;font-size:12px;line-height:1.6;width:280px;box-shadow:0 8px 32px rgba(0,0,0,.2);z-index:1000;text-align:left;font-weight:400;pointer-events:none}
.kpi .tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:7px solid transparent;border-top-color:rgba(29,29,31,.92)}
.kpi.has-tip:hover .tooltip{display:block}
.kpi-green .value{color:var(--green-text)}.kpi-amber .value{color:var(--amber-text)}.kpi-red .value{color:var(--red-text)}.kpi-neutral .value{color:var(--text)}
.kpi.clickable{cursor:pointer}
/* Generic Apple-style tooltip — usable on any element */
.apple-tip-host{position:relative;display:inline-flex;align-items:center;justify-content:center;cursor:help;color:var(--text-tert);font-size:12px;margin-left:4px;width:14px;height:14px;border-radius:50%;transition:color .2s var(--ease)}
.apple-tip-host:hover{color:var(--text-sec)}
.apple-tip-host .apple-tip,.apple-tip-inline .apple-tip{display:none;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%);background:rgba(29,29,31,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:#fff !important;padding:10px 14px;border-radius:12px;font-size:12px !important;line-height:1.55;width:max-content;max-width:300px;box-shadow:0 8px 32px rgba(0,0,0,.2);z-index:9999;text-align:left;font-weight:400 !important;pointer-events:none;white-space:normal;text-transform:none !important;letter-spacing:normal !important;font-family:var(--font)}
.apple-tip-host .apple-tip *,.apple-tip-inline .apple-tip *{color:#fff !important;text-transform:none !important;letter-spacing:normal !important;font-family:var(--font)}
.apple-tip-host .apple-tip b,.apple-tip-inline .apple-tip b{font-weight:600 !important;color:#fff !important}
.apple-tip-host .apple-tip::after,.apple-tip-inline .apple-tip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:7px solid transparent;border-top-color:rgba(29,29,31,.92)}
.apple-tip-host:hover .apple-tip,.apple-tip-inline:hover .apple-tip{display:block}
.apple-tip-inline{cursor:help;position:relative}
/* Tap-to-open tooltips (touch devices have no hover) — toggled by js/ui.js */
.kpi.has-tip.tip-open .tooltip{display:block}
.apple-tip-host.tip-open .apple-tip,.apple-tip-inline.tip-open .apple-tip{display:block}
.stat-box.tip-open .stat-tip{display:block}

/* === TABLES === */
table{width:100%;border-collapse:collapse;font-size:13px}
th{padding:10px 12px;text-align:center;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-sec);border-bottom:2px solid var(--border-strong);background:transparent}
td{padding:9px 12px;border-bottom:1px solid var(--border);text-align:center;font-size:13px;color:var(--text)}
tr{transition:background .15s}
tr:hover{background:rgba(0,0,0,.02)}
tr.fail-row{background:var(--red-bg)}tr.fail-row:hover{background:rgba(255,59,48,.1)}
.fail-badge{display:inline-block;background:var(--red);color:#fff;padding:4px 14px;border-radius:20px;font-weight:700;font-size:12px;letter-spacing:.2px}
.scroll-table{max-height:600px;overflow-y:auto;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm)}
.green{color:var(--green-text)}.red{color:var(--red-text)}.orange{color:var(--amber-text)}
th.sortable{cursor:pointer;user-select:none}th.sortable:hover{color:var(--blue)}

/* === INPUTS === */
select,input[type=date],input[type=text]{padding:8px 14px;border:1px solid var(--border-strong);border-radius:10px;font-size:13px;background:var(--card);font-family:var(--font);color:var(--text);transition:all .2s var(--ease);appearance:auto}
select:focus,input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,122,255,.12)}
select{min-width:200px}
.filters{display:flex;gap:12px;margin-bottom:18px;flex-wrap:wrap;align-items:center}
.filters label{font-size:12px;color:var(--text-sec);font-weight:600}
.chart-container{position:relative;height:420px;width:100%}
.search-box{padding:8px 14px;border:1px solid var(--border-strong);border-radius:10px;font-size:13px;width:260px;font-family:var(--font);background:var(--card)}
.search-box:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,122,255,.12)}
.search-box::placeholder{color:var(--text-tert)}

/* === TOGGLE ROW === */
.toggle-row{display:flex;gap:16px;margin-top:14px;flex-wrap:wrap;align-items:center;padding:10px 0;border-top:1px solid var(--border)}
.toggle-row label{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-sec);cursor:pointer;user-select:none;transition:color .15s}
.toggle-row label:hover{color:var(--text)}
.toggle-row input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--blue)}
.date-range{display:flex;gap:8px;align-items:center;margin-left:auto}
.btn-reset{padding:7px 16px;border:1px solid var(--border-strong);border-radius:10px;background:var(--card);font-size:12px;cursor:pointer;color:var(--text-sec);font-family:var(--font);transition:all .2s var(--ease);font-weight:500}
.btn-reset:hover{background:var(--bg);border-color:var(--blue);color:var(--blue)}

/* === STAT ROW === */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-top:14px}
.stat-box{background:var(--bg);border-radius:var(--radius-sm);padding:12px 16px;position:relative;cursor:help;transition:background .2s var(--ease);overflow:visible}
.stat-box:hover{background:rgba(0,0,0,.04)}
.stat-box .sl{font-size:10px;color:var(--text-tert);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.stat-box .sv{font-size:18px;font-weight:700;font-family:var(--mono);color:var(--text);margin-top:2px;letter-spacing:-.5px}
.stat-box .si{font-size:10px;margin-top:2px;font-weight:500}
.stat-box .stat-tip{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:rgba(29,29,31,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:#fff;padding:10px 14px;border-radius:12px;font-size:11px;line-height:1.5;width:260px;box-shadow:0 6px 20px rgba(0,0,0,.2);z-index:1000;text-align:left;font-weight:400;pointer-events:none}
.stat-box .stat-tip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:rgba(29,29,31,.92)}
.stat-box:hover .stat-tip{display:block}

/* === INSIGHT TAGS === */
.insight{font-size:11px;padding:3px 10px;border-radius:20px;font-weight:600;white-space:nowrap;cursor:pointer;transition:opacity .15s}
.insight:hover{opacity:.8}
.insight-cure{background:var(--blue-bg);color:var(--blue-text)}
.insight-water{background:var(--amber-bg);color:var(--amber-text)}
.insight-batch{background:var(--red-bg);color:var(--red-text)}
.insight-ok{background:rgba(0,0,0,.04);color:var(--text-sec)}
.insight-critical{background:var(--red);color:#fff}
.insight-cluster{background:var(--purple);color:#fff}

/* === STABILITY BADGES === */
.stab-badge{display:inline-block;padding:3px 12px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.2px}
.stab-stable{background:var(--green-bg);color:var(--green-text)}
.stab-warning{background:var(--amber-bg);color:var(--amber-text)}
.stab-unstable{background:var(--red-bg);color:var(--red-text)}

/* === ACTION CARDS (Apple style) === */
.actions-grid{display:grid;gap:12px;margin-top:20px}
.action-card{background:var(--card);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow);transition:all .25s var(--ease);border-left:4px solid transparent}
.action-card:hover{box-shadow:var(--shadow-hover)}
.action-card.ac-fail{border-left-color:var(--red)}.action-card.ac-drift{border-left-color:var(--amber)}.action-card.ac-var{border-left-color:var(--blue)}.action-card.ac-margin{border-left-color:var(--amber)}
.ac-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.ac-who{font-weight:700;font-size:15px;color:var(--text);letter-spacing:-.2px}
.ac-tag{padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.3px}
.tag-fail{background:var(--red-bg);color:var(--red-text)}.tag-drift{background:var(--amber-bg);color:var(--amber-text)}.tag-var{background:var(--blue-bg);color:var(--blue-text)}.tag-margin{background:var(--amber-bg);color:var(--amber-text)}
.ac-issue{font-size:13px;color:var(--text-sec);margin-top:6px;line-height:1.5}
.ac-toggle{padding:5px 14px;border:1px solid var(--border-strong);border-radius:10px;background:var(--card);font-size:12px;cursor:pointer;color:var(--blue);font-weight:500;font-family:var(--font);transition:all .2s var(--ease);margin-top:10px}
.ac-toggle:hover{background:var(--blue-bg)}
.ac-expand{display:none;margin-top:14px;padding:16px 20px;background:var(--bg);border-radius:var(--radius-sm);font-size:13px;line-height:1.7;color:var(--text)}
.ac-expand.open{display:block;animation:fadeUp .25s var(--ease)}
.ac-expand h4{color:var(--text);margin-bottom:8px;font-size:14px}
.ac-expand ul{margin:8px 0 0 20px;color:var(--text-sec)}
.ac-expand ul li{margin-bottom:3px}
.ac-expand .popup-label{font-size:11px;color:var(--text-tert);text-transform:uppercase;font-weight:600;margin-top:14px;letter-spacing:.5px}

/* === NO ISSUES === */
.no-issues{text-align:center;padding:32px;color:var(--green-text);font-size:15px;font-weight:600}

/* === PREDICTION CARDS === */
.pred-card{background:var(--card);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);transition:all .25s var(--ease)}
.pred-card:hover{box-shadow:var(--shadow-hover)}
.pred-card h4{font-size:15px;color:var(--text);margin-bottom:4px;font-weight:700;letter-spacing:-.2px}
.pred-detail{font-size:13px;color:var(--text-sec);line-height:1.7}
.prob-bar-bg{width:100%;height:6px;background:rgba(0,0,0,.06);border-radius:3px;margin:8px 0;overflow:hidden}
.prob-bar-fill{height:100%;border-radius:3px;transition:width .6s var(--ease)}
.risk-bar{height:28px;border-radius:8px;display:flex;align-items:center;padding:0 12px;font-size:11px;font-weight:700;color:#fff;letter-spacing:.5px}
.risk-low{background:var(--green)}.risk-med{background:var(--amber)}.risk-high{background:var(--red)}.risk-invest{background:var(--blue)}.risk-mon{background:#8e8e93}.risk-dormant{background:#a8a8b3}
.risk-bar[onclick]{transition:opacity .15s,transform .15s}.risk-bar[onclick]:hover{opacity:.85;transform:scale(1.02)}
.stab-badge[onclick]{transition:opacity .15s}.stab-badge[onclick]:hover{opacity:.7}
.rel-bar{width:60px;height:6px;background:rgba(0,0,0,.06);border-radius:3px;display:inline-block;vertical-align:middle;margin-left:6px;overflow:hidden}

/* === PREDICTION PAGE — Filter bar, Quick Index, At-Risk Panel === */
.pred-filter-bar{background:var(--card);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow);margin-bottom:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:rgba(255,255,255,.9)}
.pfb-group{display:flex;align-items:center;gap:6px}
.pfb-label{font-size:11px;color:var(--text-tert);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.pfb-select,.pfb-input{padding:6px 10px;font-size:13px;font-family:var(--font);border:1px solid var(--border-strong);border-radius:8px;background:#fff;color:var(--text);outline:none;transition:border-color .15s}
.pfb-select:focus,.pfb-input:focus{border-color:var(--blue)}
.pfb-input{width:180px}
.pfb-chips{display:flex;gap:5px;flex-wrap:wrap}
.pfb-chip{padding:5px 11px;font-size:11px;font-weight:600;border-radius:14px;cursor:pointer;transition:all .15s var(--ease);border:1px solid transparent;letter-spacing:.2px;user-select:none;background:rgba(0,0,0,.05);color:var(--text-sec)}
.pfb-chip:hover{background:rgba(0,0,0,.08)}
.pfb-chip.active{color:#fff}
.pfb-chip.active.all{background:var(--text)}
.pfb-chip.active.critical{background:var(--red)}
.pfb-chip.active.caution{background:var(--amber)}
.pfb-chip.active.investigate{background:var(--blue)}
.pfb-chip.active.monitor{background:#8e8e93}
.pfb-chip.active.stable{background:var(--green)}
.pfb-chip.active.dormant{background:#a8a8b3}
.pfb-count{display:inline-block;margin-left:4px;padding:1px 6px;background:rgba(0,0,0,.1);border-radius:8px;font-size:10px;font-weight:700}
.pfb-chip.active .pfb-count{background:rgba(255,255,255,.25)}
.pfb-reset{padding:6px 12px;font-size:12px;font-weight:500;color:var(--blue-text);background:none;border:none;cursor:pointer;border-radius:6px;transition:background .15s}
.pfb-reset:hover{background:var(--blue-bg)}

/* Quick index — one-line color-coded mix chips */
.quick-index{background:var(--card);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow);margin-bottom:14px}
.qi-title{font-size:11px;color:var(--text-tert);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:8px}
.qi-chips{display:flex;gap:6px;flex-wrap:wrap}
.qi-chip{padding:4px 10px;font-size:11px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .18s var(--ease);color:#fff;letter-spacing:.2px;border:1px solid transparent;white-space:nowrap}
.qi-chip:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,.15)}
.qi-chip.dimmed{opacity:.3}
.qi-chip.v-critical{background:var(--red)}
.qi-chip.v-caution{background:var(--amber)}
.qi-chip.v-investigate{background:var(--blue)}
.qi-chip.v-monitor{background:#8e8e93}
.qi-chip.v-stable{background:var(--green)}
.qi-chip.v-dormant{background:#a8a8b3}
.pred-card.highlight{animation:cardPulse 1.6s ease-out}
@keyframes cardPulse{
  0%{box-shadow:0 0 0 0 rgba(0,122,255,.4),var(--shadow)}
  40%{box-shadow:0 0 0 8px rgba(0,122,255,.15),var(--shadow-hover)}
  100%{box-shadow:var(--shadow)}
}

/* === At-Risk Samples Panel === */
.at-risk-panel{background:var(--card);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow);margin-bottom:20px;border-left:4px solid var(--red)}
.at-risk-panel.clean{border-left-color:var(--green)}
.arp-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:12px}
.arp-title{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.2px;display:flex;align-items:center;gap:8px}
.arp-title .arp-dot{width:10px;height:10px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px rgba(255,59,48,.15);animation:pulseDot 2s ease-in-out infinite}
.at-risk-panel.clean .arp-dot{background:var(--green);box-shadow:0 0 0 4px rgba(52,199,89,.15)}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 4px rgba(255,59,48,.15)}50%{box-shadow:0 0 0 8px rgba(255,59,48,.08)}}
.arp-meta{font-size:11px;color:var(--text-sec);background:var(--bg);padding:5px 10px;border-radius:6px;font-weight:500;border:1px solid var(--border)}
.arp-meta b{color:var(--text);font-weight:700}
.arp-sub{font-size:12px;color:var(--text-sec);line-height:1.5;margin-bottom:14px}
.arp-sub b{color:var(--text)}
.arp-table{width:100%;border-collapse:collapse;font-size:12px}
.arp-table thead th{text-align:left;padding:8px 10px;font-size:10.5px;font-weight:700;color:var(--text-tert);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:0}
.arp-table thead th.arp-sort{user-select:none;transition:background .15s,color .15s}
.arp-table thead th.arp-sort:hover{background:var(--border);color:var(--text-sec)}
.arp-sort-ind{display:inline-block;min-width:10px;color:var(--blue-text);font-weight:700;margin-left:2px}
#arpSearch:focus{border-color:var(--blue-text)}
.arp-table tbody td{padding:9px 10px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:top}
.arp-table tbody tr{transition:background .15s}
.arp-table tbody tr:hover{background:var(--bg)}
.arp-table tbody tr.rk-high{background:rgba(255,59,48,.03)}
.arp-table tbody tr.rk-high:hover{background:rgba(255,59,48,.07)}
.arp-table tbody tr.rk-med{background:rgba(255,159,10,.025)}
.arp-table tbody tr.rk-med:hover{background:rgba(255,159,10,.06)}
.arp-pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:.3px;color:#fff}
.arp-pill.high{background:var(--red)}
.arp-pill.med{background:var(--amber)}
.arp-pill.low{background:var(--green)}
.arp-mono{font-family:var(--mono);font-size:11.5px}
.arp-empty{padding:28px 16px;text-align:center;color:var(--text-sec);font-size:13px;background:var(--green-bg);border-radius:10px}
.arp-empty b{color:var(--green-text)}
.arp-scroll{max-height:600px;overflow-y:auto;border-radius:8px;border:1px solid var(--border)}
.arp-models{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;padding:10px 12px;background:var(--bg);border-radius:8px;border:1px solid var(--border);font-size:11px;color:var(--text-sec)}
.arp-models b{color:var(--text)}
.arp-mdl-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:6px;background:#fff;border:1px solid var(--border);font-weight:500}
.arp-mdl-tag.best{background:var(--blue-bg);color:var(--blue-text);border-color:var(--blue-text);font-weight:700}
.arp-warn{margin-top:10px;padding:8px 12px;background:var(--amber-bg);border-radius:8px;font-size:11.5px;color:var(--amber-text);border:1px solid rgba(255,159,10,.2)}
.rel-fill{height:100%;border-radius:3px}
.cube-val{font-size:13px;color:var(--text);font-family:var(--mono);font-weight:500}

/* === POPUP === */
.popup-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.3);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:5000;justify-content:center;align-items:center}
.popup-overlay.open{display:flex}
.popup-box{background:var(--card);border-radius:20px;padding:28px 32px;max-width:540px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2);position:relative;animation:fadeUp .3s var(--ease)}
.popup-box .popup-close{position:absolute;top:14px;right:18px;background:rgba(0,0,0,.06);border:none;width:28px;height:28px;border-radius:50%;font-size:16px;cursor:pointer;color:var(--text-sec);display:flex;align-items:center;justify-content:center;transition:all .15s}
.popup-box .popup-close:hover{background:rgba(0,0,0,.1);color:var(--text)}
.popup-box p{font-size:13px;color:var(--text);line-height:1.7;margin-bottom:8px}
.popup-box .popup-label{font-size:11px;color:var(--text-tert);text-transform:uppercase;font-weight:600;margin-top:14px;letter-spacing:.5px}
.details-title{font-size:17px;font-weight:600;color:var(--text);margin-bottom:4px;letter-spacing:-.2px}
.details-sub{font-size:12px;color:var(--text-sec);margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.details-grid{display:grid;grid-template-columns:110px 1fr;gap:12px 18px}
.details-grid .dk{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-tert);font-weight:600;padding-top:3px}
.details-grid .dv{font-size:14px;color:var(--text);line-height:1.5;word-break:break-word}
.details-grid .dv.empty{color:var(--text-tert);font-style:italic}
.details-empty{text-align:center;color:var(--text-sec);font-size:13px;padding:20px 0;line-height:1.6}
.details-link{color:var(--blue);cursor:pointer;font-weight:500;font-size:12px;user-select:none}
.details-link:hover{text-decoration:underline}
#detailsModal .popup-box{animation:modalPop .22s var(--ease)}
@keyframes modalPop{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}

/* === APPLE-STYLE ALERT === */
.apple-alert{background:var(--card);border-radius:14px;width:280px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.25);animation:modalPop .22s var(--ease)}
.apple-alert-head{padding:20px 16px 16px;text-align:center}
.apple-alert-title{font-size:17px;font-weight:600;color:var(--text);letter-spacing:-.2px;margin-bottom:6px}
.apple-alert-msg{font-size:13px;color:var(--text-sec);line-height:1.5}
.apple-alert-actions{display:flex;border-top:.5px solid var(--border-strong)}
.apple-alert-btn{flex:1;background:none;border:none;padding:11px 0;font-size:17px;cursor:pointer;transition:background .12s;font-family:var(--font);letter-spacing:-.2px}
.apple-alert-btn:hover{background:rgba(0,0,0,.03)}
.apple-alert-btn:active{background:rgba(0,0,0,.06)}
.apple-alert-cancel{color:var(--blue);border-right:.5px solid var(--border-strong);font-weight:400}
.apple-alert-confirm{color:var(--blue);font-weight:600}

/* === ASSESSMENT BADGES === */
.assess-badge{padding:3px 10px;border-radius:10px;font-size:11px;font-weight:600;white-space:nowrap;display:inline-block;letter-spacing:.1px}
.assess-excellent{background:rgba(52,199,89,.18);color:var(--green-text)}
.assess-good{background:rgba(52,199,89,.1);color:var(--green-text)}
.assess-monitor{background:rgba(0,122,255,.1);color:var(--blue-text)}
.assess-warning{background:rgba(255,159,10,.15);color:var(--amber-text)}
.assess-critical{background:rgba(255,59,48,.15);color:var(--red-text)}
.assess-na{background:rgba(0,0,0,.06);color:var(--text-tert)}
.assess-has-action{outline:1.5px solid var(--red);outline-offset:1px}

/* === REPORT BUTTON === */
.report-btn{background:rgba(0,122,255,.08);border:none;color:var(--blue);width:30px;height:30px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.report-btn:hover{background:rgba(0,122,255,.16);transform:scale(1.05)}
.report-btn:active{transform:scale(.95)}

/* === EXPLAIN PANEL === */
.explain-panel{background:rgba(0,0,0,.03);border-radius:var(--radius-sm);padding:14px 18px;margin-bottom:20px;font-size:13px;color:var(--text-sec);line-height:1.7}
.explain-panel b{color:var(--text)}
.explain-clickable{cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;transition:background .15s,box-shadow .15s}
.explain-clickable:hover{background:rgba(0,0,0,.05);box-shadow:0 1px 3px rgba(0,0,0,.05)}
.explain-clickable .ec-arrow{color:var(--text-tert);font-size:20px;font-weight:300;line-height:1}
.explain-clickable .ec-hint{color:var(--text-tert);margin-left:10px;font-size:12px;font-weight:400}

/* === PREDICTION SUB-TABS === */
.pred-subnav{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding:0}
.pred-subbtn{padding:11px 20px;font-size:13px;font-weight:600;color:var(--text-sec);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s,border-color .2s;font-family:var(--font);display:inline-flex;align-items:center;gap:9px;letter-spacing:-.1px}
.pred-subbtn:hover{color:var(--text)}
.pred-subbtn.active{color:var(--text);border-bottom-color:var(--blue)}
.pred-subbadge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:20px;padding:0 8px;background:var(--bg);color:var(--text-sec);border-radius:10px;font-size:11px;font-weight:700;border:1px solid var(--border)}
.pred-subbadge.warn{background:var(--red-bg);color:var(--red-text);border-color:rgba(255,59,48,.2)}
.pred-subbtn.active .pred-subbadge{background:var(--blue);color:#fff;border-color:var(--blue)}
.pred-subbtn.active .pred-subbadge.warn{background:var(--red);color:#fff;border-color:var(--red)}
.pred-subpage{display:none}
.pred-subpage.active{display:block}

/* === MINI TABLE === */
.mini-table{font-size:13px}.mini-table td,.mini-table th{padding:8px 10px}
.mini-table .worst{background:var(--red-bg);font-weight:700}

/* === TREND ARROWS === */
.trend-arrow{font-weight:700;font-size:14px}
.trend-up{color:var(--green-text)}.trend-down{color:var(--red-text)}.trend-flat{color:var(--text-tert)}

/* === ANIMATIONS === */
@keyframes countUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.kpi .value,.stat-box .sv,.hero-stat .hv{animation:countUp .4s var(--ease)}

/* === PLANT SUMMARY CARDS === */
.plant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-top:4px}
.plant-card{background:var(--card);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow);transition:all .25s var(--ease);position:relative;overflow:hidden;border:1px solid var(--border)}
.plant-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}
.plant-card.pc-worst{border-color:rgba(255,59,48,.25)}
.plant-card .pc-accent{position:absolute;left:0;top:0;bottom:0;width:3px}
.pc-accent.ac-green{background:var(--green)}
.pc-accent.ac-amber{background:var(--amber)}
.pc-accent.ac-red{background:var(--red)}
.pc-accent.ac-neutral{background:var(--text-tert)}
.pc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:14px}
.pc-head .pc-name{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.2px;line-height:1.25}
.pc-head .pc-sub{font-size:11px;color:var(--text-tert);text-transform:uppercase;letter-spacing:.6px;font-weight:600;margin-top:3px}
.pc-ring{position:relative;width:42px;height:42px;flex-shrink:0}
.pc-ring svg{transform:rotate(-90deg);width:100%;height:100%}
.pc-ring-bg{fill:none;stroke:rgba(0,0,0,.06);stroke-width:6}
.pc-ring-fg{fill:none;stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .6s var(--ease)}
.pc-ring-fg.rg-green{stroke:var(--green)}
.pc-ring-fg.rg-amber{stroke:var(--amber)}
.pc-ring-fg.rg-red{stroke:var(--red)}
.pc-ring-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--font);font-weight:700;color:var(--text);font-size:16px;letter-spacing:-.4px;line-height:1}
.pc-ring-label small{display:none}
.pc-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.pc-stat{text-align:center;padding:0 2px;position:relative}
.pc-stat:not(:last-child)::after{content:'';position:absolute;right:0;top:8px;bottom:8px;width:1px;background:var(--border)}
.pc-stat .pv{font-size:17px;font-weight:700;letter-spacing:-.3px;font-family:var(--font);line-height:1.1}
.pc-stat .pv.pv-pass{color:var(--green-text)}
.pc-stat .pv.pv-fail{color:var(--red-text)}
.pc-stat .pv.pv-amber{color:var(--amber-text)}
.pc-stat .pv.pv-neutral{color:var(--text)}
.pc-stat .pl{font-size:9px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-tert);font-weight:600;margin-top:3px}
.pc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:12px;gap:8px;flex-wrap:wrap}
.pc-share{font-size:11px;color:var(--text-sec);display:flex;align-items:center;gap:6px}
.pc-share-bar{width:60px;height:5px;background:rgba(0,0,0,.05);border-radius:3px;overflow:hidden}
.pc-share-bar > span{display:block;height:100%;background:var(--blue);border-radius:3px}
.pc-trend{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:10px;color:var(--text-sec);background:rgba(0,0,0,.04)}
.pc-trend.tr-up{color:var(--green-text);background:var(--green-bg)}
.pc-trend.tr-down{color:var(--red-text);background:var(--red-bg)}
.pc-fck-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.pc-chip{font-size:10px;font-weight:600;color:var(--text-sec);background:rgba(0,0,0,.04);padding:3px 8px;border-radius:10px;letter-spacing:.1px;white-space:nowrap}
.pc-chip b{color:var(--text);font-weight:700}

/* === DATA MANAGEMENT === */
.upload-zone{border:2px dashed var(--border-strong);border-radius:var(--radius);padding:48px 32px;text-align:center;transition:all .3s var(--ease);cursor:pointer;background:var(--card)}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--blue);background:var(--blue-bg)}
.upload-zone .uz-icon{font-size:48px;margin-bottom:12px;opacity:.5}
.upload-zone .uz-title{font-size:17px;font-weight:600;color:var(--text);margin-bottom:6px}
.upload-zone .uz-sub{font-size:13px;color:var(--text-sec)}
.data-status{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:20px}
.ds-card{background:var(--card);border-radius:var(--radius-sm);padding:16px 20px;box-shadow:var(--shadow);flex:1;min-width:180px}
.ds-card .ds-label{font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:var(--text-tert);font-weight:600}
.ds-card .ds-val{font-size:20px;font-weight:700;margin-top:4px;letter-spacing:-.5px}
.ds-card .ds-sub{font-size:11px;color:var(--text-sec);margin-top:2px}
.upload-log{background:var(--bg);border-radius:var(--radius-sm);padding:16px 20px;font-size:12px;font-family:var(--mono);color:var(--text-sec);max-height:200px;overflow-y:auto;line-height:1.8;margin-top:16px}
.upload-log .log-ok{color:var(--green-text)}.upload-log .log-warn{color:var(--amber-text)}.upload-log .log-err{color:var(--red-text)}
.btn-primary{padding:10px 24px;border:none;border-radius:10px;background:var(--blue);color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .2s var(--ease)}
.btn-primary:hover{background:#0055d4;transform:translateY(-1px)}
.btn-danger{padding:8px 18px;border:1px solid var(--red);border-radius:10px;background:transparent;color:var(--red-text);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .2s var(--ease)}
.btn-danger:hover{background:var(--red-bg)}
.dm-actions{display:flex;gap:12px;margin-top:16px;align-items:center;flex-wrap:wrap}
