/* =========================
   Design Spec – styles
========================= */
:root{
  --bg:#0b0c10;
  --text:#e9e9ef;
  --muted:#a9a9b6;
  --line:rgba(255,255,255,.12);
  --card:rgba(255,255,255,.06);
  --card2:rgba(255,255,255,.08);
  --accent:#6d5efc;
  --accent2:#4f8cff;
  --danger:#ff6b6b;
  --ok:#22c55e;
  --radius:16px;
  --font:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:var(--font);
  background:radial-gradient(1200px 600px at 70% -20%, #2a1f4a, #05070d 60%);
  color:var(--text);
}

/* Topbar */
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));
}

.brand{ display:flex; align-items:center; gap:12px; }
.logo{
  width:34px; height:34px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-weight:900;
  background:linear-gradient(135deg,var(--accent2),var(--accent));
}
.brand-title{ font-weight:900; }
.brand-sub{ font-size:12px; opacity:.7; margin-top:2px; }

.tabs{
  display:flex;
  gap:6px;
  padding:6px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
}
.tab{
  border:none;
  background:transparent;
  color:rgba(255,255,255,.72);
  padding:10px 14px;
  border-radius:999px;
  cursor:pointer;
  font-weight:800;
}
.tab.is-active{
  background:linear-gradient(135deg,var(--accent2),var(--accent));
  color:#fff;
}

.top-actions{ display:flex; align-items:center; gap:10px; }
.userpill{
  display:flex;
  gap:8px;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  font-weight:800;
  font-size:13px;
}
.userpill .role{ opacity:.7; font-weight:800; }

/* Buttons */
.btn, .pill, .icon-btn{
  border:none;
  cursor:pointer;
  font-weight:900;
  color:#fff;
}
.btn{
  border-radius:999px;
  padding:12px 18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}
.btn:hover{ background:rgba(255,255,255,.12); }
.btn-primary{
  background:linear-gradient(135deg,var(--accent2),var(--accent));
  border:none;
}
.btn-primary:hover{ filter:brightness(1.05); }
.btn-secondary{ background:rgba(255,255,255,.08); }

.pill{
  border-radius:999px;
  padding:10px 14px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}
.pill:hover{ background:rgba(255,255,255,.12); }
.pill-accent{
  background:linear-gradient(135deg,#22c55e,#16a34a);
  border:none;
}
.pill-danger{
  background:rgba(255,107,107,.18);
  border:1px solid rgba(255,107,107,.35);
  color:#ffd3d3;
}
.pill:disabled, .btn:disabled{
  opacity:.45;
  cursor:not-allowed;
}

.icon-btn{
  padding:8px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}
.icon-btn:hover{ background:rgba(255,255,255,.12); }

/* Page header row */
.hero{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:22px 24px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:linear-gradient(90deg, rgba(255,255,255,.04), rgba(255,255,255,0));
}
.hero h1{ margin:0; font-size:30px; }
.hero-actions{ display:flex; gap:12px; }

/* Tables */
.table-wrap{ padding:18px 24px 36px; }
.table{
  width:100%;
  border-collapse:collapse;
}
.table thead th{
  text-align:left;
  font-size:13px;
  opacity:.72;
  padding:10px 8px;
}
.table tbody td{
  padding:12px 8px;
  border-top:1px solid rgba(255,255,255,.06);
  vertical-align:top;
}
.table .col-check{ width:40px; }
.table .col-expand{ width:44px; }

.shipping{ white-space:pre-line; }

/* PO-rad när den är expanderad */
tr.is-expanded{
  background:#e6e6e6;
}

tr.is-expanded td{
  color:#111;
}
/* Variant-del när PO är expanderad */
tr.is-expanded + tr .details{
  background:#e6e6e6;
  padding:12px;
  border-radius:0 0 12px 12px;
}
/* Variant-rader – ökad läsbarhet */
tr.is-expanded + tr .variant-row{
  background:#f4f4f4;
  border-radius:8px;
  margin:4px 0;
}

/* Variant-rubrik något mörkare än bakgrunden */
tr.is-expanded + tr .variant-head{
  background:#ededed;
  border-radius:6px;
  margin-bottom:6px;
}
/* ===== Variantdelen: bättre text-kontrast när PO är expanderad ===== */

/* Bas: hela variantytan får mörk text */
tr.is-expanded + tr .details{
  color:#111;
}

/* Rubrikrad: mörkare text + tydligare bakgrund */
tr.is-expanded + tr .variant-head{
  color:#111;
  opacity:1;               /* tar bort "blek rubrik" */
  font-weight:900;
  background:#ededed;
  border-radius:8px;
  padding:10px 10px;
}

/* Variantrader: mörk text + tydlig bakgrund */
tr.is-expanded + tr .variant-row{
  color:#111;
  background:#f4f4f4;
  border-radius:8px;
  margin:6px 0;
}

/* Linjer mellan celler/rader: lite tydligare */
tr.is-expanded + tr .variant-row{
  border-bottom:1px solid #d6d6d6;
}
tr.is-expanded + tr .variant-row:last-child{
  border-bottom:none;
}

/* Inputs i variantdelen: vit bakgrund + mörk text */
tr.is-expanded + tr .input{
  background:#fff;
  color:#111;
  border:1px solid #cfcfcf;
}

/* PDF-ikonen: mer synlig på ljus bakgrund */
tr.is-expanded + tr .pdf-icon{
  background:#fff;
  border-color:#cfcfcf;
}
tr.is-expanded + tr .pdf-icon.has-file{
  background:#dfe7ff;      /* mild blå hint när fil finns */
  border-color:#98b1ff;
}
/* =========================================================
   Variant-del – maximal läsbarhet när PO är expanderad
   ========================================================= */

/* PO-rad + variant-ytan */
tr.is-expanded{
  background:#e6e6e6;
}
tr.is-expanded td{
  color:#111;
}

/* Hela variant-delen */
tr.is-expanded + tr .details{
  background:#e6e6e6;
  padding:12px;
  color:#111;
}

/* Variant-rubrik */
tr.is-expanded + tr .variant-head{
  background:#ededed;
  color:#111;
  opacity:1;              /* tar bort blek rubrik */
  font-weight:900;
  border-radius:8px;
  padding:10px 10px;
  margin-bottom:8px;
}

/* Variantrader */
tr.is-expanded + tr .variant-row{
  background:#f4f4f4;
  color:#111;
  border-radius:8px;
  margin:6px 0;
  padding:10px;
}

/* Hover på variantrad (valbar feedback) */
tr.is-expanded + tr .variant-row:hover{
  background:#eeeeee;
}

/* Inputs i variantdelen */
tr.is-expanded + tr .input{
  background:#ffffff;
  color:#111;
  border:1px solid #cfcfcf;
}

/* PDF-ikon – tom */
tr.is-expanded + tr .pdf-icon{
  background:#ffffff;
  border-color:#cfcfcf;
}

/* PDF-ikon – fil finns */
tr.is-expanded + tr .pdf-icon.has-file{
  background:#dfe7ff;
  border-color:#98b1ff;
}

/* Små justeringar för läsbarhet */
tr.is-expanded + tr .readonly-pill{
  background:#ffffff;
  border-color:#cfcfcf;
  color:#111;
}


/* Expanded details box */
.details{
  padding:10px 0 0;
}

/* Variant table layout */
.variant-table{
  padding:12px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
}
.variant-head{
  display:grid;
  gap:12px;
  font-size:12px;
  opacity:.75;
  padding:8px 10px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.variant-row{
  display:grid;
  gap:12px;
  padding:10px 10px;
  border-bottom:1px solid rgba(255,255,255,.08);
  align-items:center;
}
.variant-row:last-child{ border-bottom:none; }

/* Inputs */
.input{
  width:100%;
  padding:10px 10px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.25);
  color:var(--text);
}
.input::placeholder{ color:rgba(255,255,255,.45); }

/* ERD changed */
.input.erd-changed{
  color:#ff4d4d;
  border-color:rgba(255,77,77,.65);
  font-weight:800;
}

/* Read-only pill */
.readonly-pill{
  display:inline-flex;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.18);
  color:rgba(255,255,255,.86);
  font-weight:900;
  font-size:13px;
}

/* PDF icon in Notes */
.pdf-icon{
  width:34px;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.18);
  cursor:pointer;
  user-select:none;
}
.pdf-icon.has-file{
  background:rgba(92,124,250,.18);
  border-color:rgba(92,124,250,.35);
}
.pdf-icon span{
  font-size:16px;
  opacity:.95;
}
.pdf-icon.empty span{ opacity:.45; }

/* 3-dots menu */
.menu-wrap{ position:relative; display:inline-flex; }
.menu{
  position:absolute;
  right:0;
  top:110%;
  min-width:180px;
  background:rgba(15,16,22,.98);
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  overflow:hidden;
  z-index:50;
  box-shadow:0 22px 60px rgba(0,0,0,.55);
}
.menu button{
  display:block;
  width:100%;
  padding:10px 12px;
  border:none;
  background:transparent;
  color:#fff;
  cursor:pointer;
  text-align:left;
  font-weight:900;
}
.menu button:hover{ background:rgba(255,255,255,.08); }
.menu button.danger{ color:var(--danger); }

/* Login */
.login-wrap{
  display:flex;
  justify-content:center;
  padding:70px 18px;
}
.login-card{
  width:420px;
  border-radius:18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  padding:22px;
}
.login-title{ font-size:22px; font-weight:900; }
.login-sub{ margin-top:6px; opacity:.75; }
.login-actions{
  margin-top:14px;
  display:flex;
  justify-content:flex-end;
}
.label{
  font-size:12px;
  opacity:.75;
  margin-bottom:6px;
  font-weight:900;
}
.form-field{ margin-top:14px; }
.hint{
  font-size:12px;
  opacity:.65;
  margin-top:6px;
}

/* Modal */
.modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  display:none;
  align-items:center;
  justify-content:center;
  padding:16px;
  z-index:100;
}
.modal-backdrop.is-open{ display:flex; }
.modal{
  width:min(780px, 100%);
  background:#e6e6e6;              /* färgen från bilden */
  border:1px solid #d0d0d0;
  border:1px solid rgba(255,255,255,.12);
  padding:18px;
}
.modal,
.modal .modal-title,
.modal .modal-sub,
.modal .label {
  color:#111;
}
.modal .input,
.modal textarea,
.modal select {
  background:#ffffff;
  color:#111;
  border:1px solid #cfcfcf;
}
.modal-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.modal-title{ font-size:20px; font-weight:900; }
.modal-sub{ font-size:13px; opacity:.7; margin-top:4px; }
.modal-body{ margin-top:14px; }
.modal-footer{
  margin-top:18px;
  display:flex;
  justify-content:flex-end;
  gap:10px;
}
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.form-grid .full{ grid-column:1 / -1; }

/* Autocomplete */
.suggest{
  margin-top:8px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  overflow:hidden;
  background:rgba(0,0,0,.25);
}
.suggest button{
  width:100%;
  border:none;
  background:transparent;
  color:#fff;
  padding:10px 12px;
  cursor:pointer;
  text-align:left;
  font-weight:800;
}
.suggest button:hover{ background:rgba(255,255,255,.08); }
.suggest small{ opacity:.7; font-weight:700; }
/* =========================================================
   Tydliga actions-knappar i PO-listan
   ========================================================= */

/* To Dispatch – primär action */
.pill-dispatch{
  background:#2563eb;          /* tydlig blå */
  border:1px solid #1e4ed8;
  color:#ffffff;
  font-weight:900;
}
.pill-dispatch:hover{
  background:#1e4ed8;
}

/* New Row – sekundär action */
.pill-newrow{
  background:#16a34a;          /* tydlig grön */
  border:1px solid #15803d;
  color:#ffffff;
  font-weight:900;
}
.pill-newrow:hover{
  background:#15803d;
}

/* Säkerställ kontrast även på ljusgrå expanderad yta */
tr.is-expanded .pill-dispatch,
tr.is-expanded .pill-newrow{
  box-shadow:0 0 0 1px rgba(0,0,0,.15);
}
/* =========================================================
   Disabled state – tydlig skillnad för To Dispatch / New Row
   ========================================================= */

/* Default disabled: grå + “blocked” känsla */
.pill:disabled{
  background:#9ca3af;            /* neutral grå */
  border:1px solid #6b7280;
  color:rgba(255,255,255,.85);
  cursor:not-allowed;
  opacity:1;                     /* vi vill inte att den bara "försvinner" */
  filter:grayscale(25%);
}

/* Extra tydligt just för To Dispatch */
.pill-dispatch:disabled{
  background:#94a3b8;            /* lite blågrå, känns "inaktiv" */
  border-color:#64748b;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
}

/* På expanderad (ljusgrå) yta: bibehåll kontrast */
tr.is-expanded .pill:disabled{
  box-shadow:0 0 0 1px rgba(0,0,0,.18);
}
/* =========================================================
   Light theme override (matchar referensbilder)
   Endast färg + font – ingen textlogik
   ========================================================= */
:root{
  --bg:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --line:#e5e7eb;
  --card:#ffffff;
  --card2:#f3f4f6;

  /* behåll accent, ok, danger */
  --radius:16px;
  --font:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial;
}

body{
  background:#ffffff;   /* bort med dark radial gradient */
  color:var(--text);
}

/* Topbar */
.topbar{
  border-bottom:1px solid var(--line);
  background:#ffffff;
}

/* Tabs */
.tabs{
  background:#eeeeee;
  border:1px solid #e2e2e2;
  border-radius:12px;
  padding:8px;
  gap:8px;
}

.tab{
  color:#6b7280;
  border-radius:10px;
  padding:10px 18px;
  font-weight:700;
}

.tab.is-active{
  background:#ffffff;      /* vit aktiv tab som i bilden */
  color:#111827;
  box-shadow:0 1px 2px rgba(0,0,0,.08);
}

/* Page header row */
.hero{
  border-bottom:1px solid var(--line);
  background:#ffffff;
}

/* Tabeller (PO-listan) */
.table{
  background:#ffffff;
}

.table thead th{
  opacity:1;
  color:#6b7280;
  font-weight:700;
  border-bottom:1px solid var(--line);
  padding:14px 10px;
}

.table tbody td{
  border-top:1px solid var(--line);
  padding:16px 10px;
  color:#111827;
}

/* Inputs i ljus vy */
.input{
  background:#ffffff;
  color:#111827;
  border:1px solid #d1d5db;
}

.input::placeholder{
  color:#9ca3af;
}

/* Pills / buttons i ljus vy (neutral bas) */
.btn, .pill, .icon-btn{
  color:#111827;
  background:#ffffff;
  border:1px solid #d1d5db;
}

.btn:hover, .pill:hover, .icon-btn:hover{
  background:#f3f4f6;
}

/* Behåll tydliga actions-färger du redan lagt */
.pill-dispatch{
  color:#ffffff;
  border:none;
}
.pill-newrow{
  color:#ffffff;
  border:none;
}

/* Meny (3-dots) i ljus vy */
.menu{
  background:#ffffff;
  border:1px solid #e5e7eb;
  box-shadow:0 16px 40px rgba(0,0,0,.12);
}
.menu button{
  color:#111827;
}
.menu button:hover{
  background:#f3f4f6;
}

/* Autocomplete i ljus vy */
.suggest{
  background:#ffffff;
  border:1px solid #e5e7eb;
}
.suggest button{
  color:#111827;
}
.suggest button:hover{
  background:#f3f4f6;
}
/* ===== Analytical PO table row separators + done highlight ===== */
.po-table{
  border-collapse: separate;
  border-spacing: 0;
}

.po-table tbody td{
  border-top: 1px solid var(--line);
}

/* Matcha "Shopify-linje": lite mer luft */
.po-table tbody td{
  padding-top: 18px;
  padding-bottom: 18px;
}

/* Ljusgrön markering när Amount > 0 */
.po-table tbody tr.ap-done td{
  background: rgba(34, 197, 94, 0.10);
}
/* ===== Create PO ready state (Analytical) ===== */
.btn-ready{
  background: rgba(34, 197, 94, 0.15);   /* ljusgrön */
  border: 1px solid rgba(34, 197, 94, 0.6);
  color: #065f46;
}

.btn-ready:hover{
  background: rgba(34, 197, 94, 0.25);
}

.btn-ready:disabled{
  background: #e5e7eb;
  border-color: #d1d5db;
  color: #9ca3af;
}
/* ===== Light green when action is clickable ===== */
.pill-ready{
  background: rgba(34, 197, 94, 0.16);
  border: 1px solid rgba(34, 197, 94, 0.55);
  color:#065f46;
}

.pill-ready:hover{
  background: rgba(34, 197, 94, 0.24);
}

/* Done action in PO list */
.pill-done{
  background:#111827;
  border:1px solid rgba(17,24,39,0.35);
  color:#fff;
  font-weight:900;
}
