/* ============================================================
   FreedomOS — 9five portal · DARK "Operations Intelligence" theme
   Neutral charcoal ground, teal/terracotta/bronze accents.
   League Spartan + Inter. Brand colors from 9five logo SVG.
   ============================================================ */
:root{
  --dark:#131618; --dark-2:#0e1012; --dark-card:#1b1e21; --dark-surface:#22262a; --dark-border:#2c3237;
  --cream:#f6f3ec; --white:#fff;
  --teal:#3a5c5a; --teal-light:#4a8c88; --teal-bg:rgba(58,92,90,.22);
  --terracotta:#954230; --terracotta-bg:rgba(149,66,48,.2);
  --bronze:#be7c2f; --bronze-bg:rgba(190,124,47,.15);
  --green:#4a8c6f; --green-bg:rgba(74,140,111,.18);
  --orange:#be7c2f; --orange-bg:rgba(190,124,47,.15);
  --red:#954230; --red-bg:rgba(149,66,48,.15);
  --text:#ddd8d0; --muted:#7e8e96;
  --radius:12px; --sidebar-w:260px;
  --shadow:0 8px 28px rgba(0,0,0,.38);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;background:var(--dark);color:var(--text);font-size:15px;line-height:1.55;overflow-x:hidden}
h1,h2,h3,.brand{font-family:'League Spartan','Inter',sans-serif;letter-spacing:-.01em}
a{color:var(--bronze);text-decoration:none}
a:hover{text-decoration:underline}

/* layout */
.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#0e1012 0%,#131618 100%);border-right:1px solid var(--dark-border);padding:0 0 18px;position:sticky;top:0;height:100vh;overflow:auto;display:flex;flex-direction:column}
.sidebar .brand{padding:20px 20px 0;margin:0}
.logo-chip{display:flex;justify-content:center;background:var(--cream);border-radius:10px;padding:14px 16px}
.logo-chip img{width:100%;max-width:160px;height:auto;display:block}
.brand-sub{color:var(--muted);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:8px 4px 16px;text-align:center;border-bottom:1px solid var(--dark-border);margin:0 20px 0}
.nav-group{margin:16px 20px 4px;color:var(--muted);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase}
.nav-group-hdr{display:flex;align-items:center;gap:6px;padding:6px 12px;margin:4px 8px 0;border-radius:7px;cursor:pointer;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);transition:background .12s,color .12s;user-select:none}
.nav-group-hdr:hover{background:rgba(255,255,255,.04);color:var(--text)}
.nav-group-hdr.ng-open{color:var(--teal-light)}
.nav-group-hdr .ng-ico{font-size:13px;opacity:.7;flex-shrink:0}
.nav-group-hdr .ng-arr{margin-left:auto;font-size:11px;opacity:.6;transition:transform .2s}
.nav{padding:0 12px}
.nav a{display:flex;align-items:center;gap:11px;color:var(--text);padding:10px 12px;border-radius:9px;font-size:14px;margin:1px 0}
.nav a:hover{background:var(--teal-bg);text-decoration:none;color:#fff}
.nav a.active{background:var(--teal-bg);color:var(--teal-light);font-weight:600;box-shadow:inset 2px 0 0 var(--teal-light)}
.nav a .ico{width:22px;text-align:center;opacity:.92;font-size:16px}
.sidebar .who{margin:auto 16px 0;border-top:1px solid var(--dark-border);padding:16px 4px 0;color:var(--muted);font-size:12.5px}
.sidebar .who b{color:#fff;display:block;font-size:13.5px}
.sidebar .who a{color:var(--bronze);font-size:12px}

/* main + glass topbar (the page title sits in a sticky bar like the mockup) */
.main{min-height:100vh}
.topline{position:sticky;top:0;z-index:50;background:rgba(19,22,24,.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--dark-border);
  display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 32px;flex-wrap:wrap}
.topline h1{font-size:22px;margin:0;color:#fff;font-weight:600}
.ai-status{display:inline-flex;align-items:center;gap:8px;background:var(--green-bg);border:1px solid rgba(74,140,111,.35);padding:6px 14px;border-radius:20px;font-size:12px;font-weight:500;color:var(--green)}
.ai-status .dot{width:8px;height:8px;background:var(--green);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.refresh-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);background:var(--dark-surface);border:1px solid var(--dark-border);padding:3px 10px;border-radius:12px}
.refresh-badge .rb-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2s infinite}
.sub{color:var(--muted);margin:0;font-size:14px;padding:20px 32px 0}
#content{padding:24px 32px}

/* kpi cards */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;margin-bottom:26px}
.kpi{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);padding:20px;transition:.25s}
.kpi:hover{border-color:var(--teal);transform:translateY(-2px)}
.kpi .kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.kpi .kpi-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--teal-bg)}
.kpi .label{color:var(--muted);font-size:13px;margin-top:4px}
.kpi .value{font-family:'League Spartan',sans-serif;font-size:28px;font-weight:700;color:#fff;line-height:1}
.kpi .value.clay{color:#d2755e} .kpi .value.copper{color:var(--bronze)} .kpi .value.green{color:#6fc79f}
.kpi .foot{color:var(--muted);font-size:12px;margin-top:5px}
.kpi .foot a{color:var(--bronze)}

/* panels + tables */
.panel{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);margin-bottom:24px;overflow:hidden;box-shadow:var(--shadow)}
.panel .head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 20px;border-bottom:1px solid var(--dark-border);flex-wrap:wrap}
.panel .head h2{font-size:16px;margin:0;color:#fff;font-weight:600}
.panel .head .actions{display:flex;gap:8px;align-items:center}
.panel .body{padding:0}
.tablewrap{max-height:560px;overflow:auto}
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead th{position:sticky;top:0;z-index:2;background:var(--dark-surface)}
th{text-align:left;color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:11px 18px;border-bottom:1px solid var(--dark-border)}
td{padding:12px 18px;border-bottom:1px solid rgba(44,50,55,.4);text-align:left;color:var(--text)}
th:first-child,td:first-child{position:sticky;left:0;background:var(--dark-card);z-index:1}
thead th:first-child{z-index:3;background:var(--dark-surface)}
tr:last-child td{border-bottom:none}
tbody tr:hover td,tr.row-click:hover td{background:var(--dark-surface)}
tr.row-click{cursor:pointer}
tr.row-click:hover td:first-child{background:var(--dark-surface)}
td.act{text-align:right}
.lnk{color:var(--teal-light);cursor:pointer;font-weight:600;font-size:12.5px}
.lnk:hover{text-decoration:underline;color:var(--bronze)}
.empty{padding:36px 18px;text-align:center;color:var(--muted)}

/* pills */
.pill{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.pill.green{background:var(--green-bg);color:#6fc79f} .pill.clay{background:var(--terracotta-bg);color:#d2755e}
.pill.copper{background:var(--bronze-bg);color:var(--bronze)} .pill.gray{background:rgba(138,158,156,.18);color:var(--muted)}
.pill.voice{background:var(--teal-bg);color:var(--teal-light)}

/* buttons + forms */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--teal);color:var(--cream);border:1px solid var(--teal);border-radius:8px;padding:9px 16px;font-size:13.5px;font-weight:600;cursor:pointer;font-family:inherit}
.btn:hover{background:var(--teal-light);border-color:var(--teal-light)}
.btn.ghost{background:var(--dark-surface);color:var(--text);border:1px solid var(--dark-border)}
.btn.ghost:hover{border-color:var(--teal);color:var(--teal-light)}
.btn.clay{background:var(--terracotta);border-color:var(--terracotta);color:#fff} .btn.clay:hover{filter:brightness(1.1)}
.btn:disabled{opacity:.5;cursor:not-allowed}
label{display:block;font-size:12.5px;color:var(--muted);margin:12px 0 5px;font-weight:600}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--dark-border);border-radius:9px;font-family:inherit;font-size:14px;background:var(--dark-surface);color:var(--text)}
input::placeholder,textarea::placeholder{color:#5f726f}
input:focus,select:focus,textarea:focus{outline:2px solid var(--teal-light);outline-offset:0;border-color:transparent}
select option{background:var(--dark-surface);color:var(--text)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.note{font-size:12.5px;color:var(--muted)}

/* login */
.login-wrap{display:grid;place-items:center;min-height:100vh;background:linear-gradient(160deg,#0e1012,#131618 60%,#22262a)}
.login-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:16px;padding:34px;width:min(400px,92vw);box-shadow:0 24px 70px rgba(0,0,0,.5)}
.login-card .brand{font-size:38px;color:#fff;text-align:center;margin-bottom:2px;font-family:'League Spartan'}
.login-card .tm{color:var(--bronze);font-size:15px}
.login-card .tag{text-align:center;color:var(--muted);font-size:13px;margin-bottom:22px}
.err{background:var(--terracotta-bg);color:#d2755e;padding:10px 12px;border-radius:9px;font-size:13.5px;margin-top:12px;display:none}

/* ai output + banners */
.ai-out{white-space:pre-wrap;font-size:14px;line-height:1.6;padding:18px;background:var(--dark-surface);border:1px solid var(--dark-border);border-radius:10px;color:var(--text)}
.banner{background:var(--bronze-bg);border:1px solid rgba(190,124,47,.35);color:#e0b878;padding:11px 16px;border-radius:10px;font-size:13.5px;margin-bottom:18px}
.spinner{display:inline-block;width:15px;height:15px;border:2px solid rgba(246,243,236,.35);border-top-color:var(--cream);border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}
.mobile-only{display:none}
@media(max-width:860px){
  .shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-280px;transition:left .2s;z-index:60;width:var(--sidebar-w)}
  .sidebar.open{left:0}
  .mobile-only{display:inline-flex}
  #content,.topline,.sub{padding-left:18px;padding-right:18px}
}
@media(max-width:480px){
  .topline{padding:10px 14px;gap:8px}
  .topline h1{font-size:16px}
  .ai-status{padding:5px 8px;font-size:11px}
  .ai-status .ai-txt{display:none}
  .kpis{grid-template-columns:1fr 1fr;gap:10px}
  .kpi{padding:14px 12px}
  .kpi .value{font-size:22px}
  .kpi .kpi-icon{width:32px;height:32px;font-size:15px}
  #content{padding:14px 14px}
  .sub{padding:12px 14px 0}
  .panel .head{padding:12px 14px}
  .panel .body{overflow-x:auto}
  .btn{padding:8px 12px;font-size:13px}
  th,td{padding:9px 12px;font-size:12.5px}
  .modal-head h2{font-size:16px}
  .modal-body,.modal-foot{padding:14px 16px}
}

/* modal */
#fh-modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center}
.modal-back{position:absolute;inset:0;background:rgba(10,18,17,.6)}
.modal-card{position:relative;background:var(--dark-card);border:1px solid var(--dark-border);border-radius:14px;width:min(560px,94vw);max-height:90vh;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.modal-card.wide{width:min(900px,96vw)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--dark-border)}
.modal-head h2{margin:0;font-size:18px;color:#fff}
.modal-x{background:none;border:none;font-size:24px;color:var(--muted);cursor:pointer;line-height:1}
.modal-body{padding:18px 22px;overflow:auto}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--dark-border)}
.fld-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}
.fld-grid .fld-full{grid-column:1 / -1}
@media(max-width:560px){.fld-grid{grid-template-columns:1fr}}

/* dashboard richness — matches the promised mockup */
.kpi-trend{font-size:12px;font-weight:600;padding:3px 8px;border-radius:6px}
.kpi-trend.up{color:#6fc79f;background:var(--green-bg)} .kpi-trend.warn{color:var(--bronze);background:var(--bronze-bg)} .kpi-trend.down{color:#d2755e;background:var(--terracotta-bg)}
.card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--radius);overflow:hidden;margin-bottom:24px;box-shadow:var(--shadow)}
.card-header{padding:16px 20px;border-bottom:1px solid var(--dark-border);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-header h3{font-family:'League Spartan',sans-serif;font-size:16px;font-weight:600;color:#fff;margin:0}
.card-body{padding:20px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:900px){.two-col{grid-template-columns:1fr}}
.tag{font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.3px}
.tag.orange{background:var(--bronze-bg);color:var(--bronze)} .tag.green{background:var(--green-bg);color:#6fc79f}
.ecocert-badge{font-size:12px;font-weight:600;color:#6fc79f;background:var(--green-bg);border:1px solid rgba(74,140,111,.35);padding:5px 12px;border-radius:14px}

/* production flow strip */
.flow-container{display:flex;align-items:center;gap:6px;overflow-x:auto;padding:4px 0}
.flow-node{flex:1;min-width:120px;background:var(--dark-surface);border:1px solid var(--dark-border);border-radius:11px;padding:16px 12px;text-align:center;cursor:pointer;transition:.25s}
.flow-node:hover{border-color:var(--teal);transform:translateY(-2px)}
.flow-icon{font-size:26px;margin-bottom:8px}
.flow-label{font-weight:600;color:#fff;font-size:13.5px}
.flow-sub{color:var(--muted);font-size:11.5px;margin-top:3px}
.flow-arrow{color:var(--teal-light);font-size:22px;flex-shrink:0}

/* alert items */
.alert-item{display:flex;gap:12px;align-items:flex-start;padding:14px;border:1px solid var(--dark-border);border-radius:10px;margin-bottom:10px;background:var(--dark-surface)}
.alert-item:last-child{margin-bottom:0}
.alert-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.alert-content{flex:1;min-width:0}
.alert-content h4{margin:0 0 3px;font-size:14px;color:#fff;font-weight:600}
.alert-content p{margin:0;font-size:12.5px;color:var(--muted);line-height:1.45}
.alert-time{font-size:11px;color:var(--muted);white-space:nowrap}

/* progress bars */
.prog-row{margin-bottom:16px}
.prog-row:last-child{margin-bottom:0}
.prog-top{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px}
.prog-top .pl{color:var(--muted)} .prog-top .pv{font-weight:600;color:#fff}
.progress-bar{height:8px;background:var(--dark-surface);border-radius:6px;overflow:hidden}
.progress-fill{height:100%;border-radius:6px}
.progress-fill.green{background:var(--green)} .progress-fill.gold{background:var(--bronze)} .progress-fill.blue{background:var(--teal-light)} .progress-fill.orange{background:#d2755e}

/* detail (drill-down) */
.detail-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:18px}
.detail-meta>div{background:var(--dark-surface);border:1px solid var(--dark-border);border-radius:9px;padding:9px 12px}
.dm-l{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.dm-v{display:block;font-size:15px;font-weight:600;color:#fff;margin-top:2px}
.detail-chart{margin:0 0 20px}
.dc-title,.dp-title{font-family:'League Spartan',sans-serif;font-size:14px;font-weight:700;color:var(--teal-light);margin:0 0 8px;text-transform:uppercase;letter-spacing:.03em}
.dc-canvas{height:240px;background:var(--dark-surface);border:1px solid var(--dark-border);border-radius:10px;padding:10px}
.detail-panel{margin:0 0 20px}
.detail-panel .tablewrap{border:1px solid var(--dark-border);border-radius:10px;max-height:300px}
.detail-panel table{font-size:13px}
