/* IKALOGIC Inventory — prototype styling on top of Pico.css */

/* ---- IKALOGIC brand palette (from ikalogic.com: coral accent + slate ink) ----
   Links/buttons keep Pico's IKALOGIC blue; the coral is reserved as an accent for
   the home-page cards and the search box only. Headings use the slate logo ink. */
:root {
  --ika-coral: #ee5454;
  --ika-coral-hover: #d83b3b;
  --ika-slate: #2b3b4b;
}
:root:not([data-theme=dark]), [data-theme=light] {
  --pico-h1-color: var(--ika-slate);
  --pico-h2-color: var(--ika-slate);
  --pico-h3-color: var(--ika-slate);
  --pico-h4-color: var(--ika-slate);
  --pico-h5-color: var(--ika-slate);
  --pico-h6-color: var(--ika-slate);
}

.brand { text-decoration: none; display: inline-flex; align-items: center; gap: 0.55rem; }

/* Sticky top toolbar — stays visible while scrolling. The ::before paints a
   full-width background bar behind the centered nav container. */
body > header.container {
  position: sticky; top: 0; z-index: 100;
  margin-bottom: 0; padding-top: 0.6rem; padding-bottom: 0.6rem;
}
body > header.container::before {
  content: ""; position: absolute; top: 0; bottom: 0; left: 50%;
  width: 100vw; transform: translateX(-50%); z-index: -1;
  background: var(--pico-background-color);
  border-bottom: 1px solid var(--pico-muted-border-color);
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.05);
}

/* Language switcher (used on the Settings page) */
.lang-switch { display: inline-flex; gap: 0; border: 1px solid var(--pico-muted-border-color); border-radius: 6px; overflow: hidden; }
.lang-btn { margin: 0; padding: 0.15rem 0.45rem; font-size: 0.72rem; font-weight: 700; line-height: 1.4;
  background: transparent; color: var(--pico-muted-color); border: 0; border-radius: 0; box-shadow: none; cursor: pointer; }
.lang-btn.active { background: var(--ika-coral); color: #fff; }
.lang-btn:not(.active):hover { background: rgba(43, 59, 75, 0.08); }
.logo { height: 26px; display: block; }
.brand-sub { font-weight: 600; color: var(--pico-muted-color); }

/* ---- Full-page loader overlay ---- */
.page-loader {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  background: rgba(248, 250, 249, 0.82);
  -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
  cursor: progress;
}
.page-loader[hidden] { display: none; }
.loader-art { display: flex; flex-direction: column; align-items: center; gap: 1rem; }
.loader-svg { width: 150px; height: 150px; filter: drop-shadow(0 0 10px rgba(238, 84, 84, 0.32)); }
.loader-core { animation: loader-pulse 1.1s ease-in-out infinite; }
@keyframes loader-pulse { 0%, 100% { opacity: 0.4; } 50% { opacity: 1; } }
.loader-text {
  margin: 0; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
  font-size: 0.8rem; color: var(--pico-muted-color);
  animation: loader-pulse 1.1s ease-in-out infinite;
}
@media (prefers-reduced-motion: reduce) {
  .loader-svg *, .loader-core, .loader-text { animation: none !important; }
}

/* ---- Inline SVG icons ---- */
.icon { width: 1.2em; height: 1.2em; vertical-align: -0.22em; }
.icon-lg { width: 2.4rem; height: 2.4rem; }

/* Compact icon-only / icon+label buttons. */
.icon-btn { display: inline-flex; align-items: center; gap: 0.4rem; width: auto;
  padding: 0.5rem 0.7rem; margin: 0; }
.icon-btn .icon { width: 1.25rem; height: 1.25rem; vertical-align: middle; }

/* Smooth-scroll target for the "Consolidated by source" jump (cart button). */
#consolidated { scroll-margin-top: 5rem; }

/* Commit bar under the purchase plan. */
.commit-bar { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; margin: 1rem 0 2rem; }
.commit-bar form { margin: 0; }
.commit-bar button { width: auto; margin: 0; }

/* Purchasing toolbar: sourcing mode + qty + destination + ready, aligned on one line. */
.purchase-toolbar { display: flex; align-items: flex-end; gap: 1rem; flex-wrap: wrap; }
/* Every control is a uniform label-on-top column so labels and boxes line up. */
.purchase-toolbar label {
  margin: 0; display: flex; flex-direction: column; gap: 0.25rem; font-size: 0.85rem;
}
.purchase-toolbar select, .purchase-toolbar input { margin: 0; }
.purchase-toolbar input[type="number"] { width: 7rem; }
/* width:auto beats Pico's button[type=submit]{width:100%} via higher specificity. */
.purchase-toolbar .icon-btn { flex: 0 0 auto; width: auto; }

.muted { color: var(--pico-muted-color); font-size: 0.9em; }
.num { text-align: right; font-variant-numeric: tabular-nums; }
table a { text-decoration: none; }

/* ---- Home hero ---- */
.hero {
  max-width: 960px;
  margin: 4rem auto 0;
  text-align: center;
}
.workflow-buttons {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: 2.5rem;
}
/* Settings cards: at most 3 per row, each card sized by its own content (no row-stretch). */
.settings-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  align-items: start;
}
.settings-grid > article { margin: 0; }
@media (max-width: 900px) { .settings-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .settings-grid { grid-template-columns: 1fr; } }
/* Sortable table-header links. */
.th-sort { color: inherit; text-decoration: none; cursor: pointer; white-space: nowrap; }
.th-sort:hover { text-decoration: underline; }
.th-sort.active { font-weight: 700; }
.workflow-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  padding: 1.75rem 1rem;
  border-radius: var(--pico-border-radius);
  background: var(--pico-card-background-color);
  border: 1px solid var(--pico-card-border-color);
  text-decoration: none;
  color: var(--pico-color);
  transition: transform 0.08s ease, border-color 0.08s ease;
}
.workflow-btn:hover {
  transform: translateY(-2px);
  border-color: var(--ika-coral);   /* coral accent — home cards only */
}
.wf-icon { line-height: 1; color: var(--ika-coral); }   /* coral accent — home cards only */
.wf-label { font-weight: 600; }
.wf-sub { font-size: 0.8rem; color: var(--pico-muted-color); }

.search-wrap { position: relative; }
.big-search {
  font-size: 1.4rem;
  padding: 1rem 1.25rem;
  height: auto;
  border-radius: 2rem;
}
/* coral accent — search box focus only */
.big-search:focus {
  border-color: var(--ika-coral);
  box-shadow: 0 0 0 0.18rem rgba(238, 84, 84, 0.25);
}

/* ---- Search results dropdown ---- */
.results {
  list-style: none;
  margin: 0.5rem 0 0;
  padding: 0;
  text-align: left;
  border: 1px solid var(--pico-card-border-color);
  border-radius: var(--pico-border-radius);
  overflow: hidden;
}
.results li { margin: 0; }
.results li + li { border-top: 1px solid var(--pico-card-border-color); }
.results a {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.6rem 1rem;
  text-decoration: none;
  color: var(--pico-color);
}
.results a:hover { background: var(--pico-card-sectioning-background-color); }
.r-icon { display: inline-flex; color: var(--pico-primary); }
.r-icon .icon { width: 1.4rem; height: 1.4rem; vertical-align: middle; }
.r-text { display: flex; flex-direction: column; flex: 1; }
.r-title { font-weight: 600; }
.r-sub { font-size: 0.8rem; color: var(--pico-muted-color); }
.r-kind {
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--pico-muted-color); border: 1px solid var(--pico-card-border-color);
  border-radius: 1rem; padding: 0.1rem 0.5rem;
}

/* ---- Stats row ---- */
.stat-row { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem; }
.stat {
  flex: 1; min-width: 140px; margin: 0; padding: 1rem;
  text-align: center;
}
.stat-val { display: block; font-size: 1.8rem; font-weight: 700; }

.action-buttons { margin-bottom: 1rem; }
/* Active (selected) action button — thick underline. */
.action-buttons button.active {
  box-shadow: inset 0 -5px 0 0 var(--pico-color);
}
.action-form { margin-top: 1rem; }
.inline-form { display: flex; gap: 1rem; align-items: end; flex-wrap: wrap; }
.inline-form label { margin: 0; }
/* Drop Pico's input margin-bottom so inputs bottom-align with the (margin-0) buttons. */
.inline-form input, .inline-form select { margin: 0; }
.inline-form .icon-btn { flex: 0 0 auto; width: auto; margin: 0; }
/* Group the action buttons so they sit aligned with the input boxes, not the labels. */
.inline-form-actions { display: flex; gap: 0.5rem; align-items: flex-end; }
.inline-form-actions .icon-btn { margin: 0; }
/* "Use PNP components" toggle on its own line below the units/location/buttons row. */
.inline-form .pnp-row {
  flex-basis: 100%; margin: 0.4rem 0 0; display: flex; align-items: center;
  gap: 0.4rem; white-space: nowrap;
}
/* The "go to confirm" check button — green, distinct from the grey refresh button. */
.icon-btn.go { background: #16a34a; border-color: #16a34a; color: #fff; }
.icon-btn.go:hover, .icon-btn.go:focus { background: #15803d; border-color: #15803d; color: #fff; }

/* Per-line source indicator on the purchase plan (reel / buy / from-stock). */
.src-icon { text-align: center; }
.src-icon .icon { width: 1.3rem; height: 1.3rem; vertical-align: middle; }
.src-reel { color: #7c3aed; }   /* PNP reel  */
.src-buy { color: #d97706; }    /* buy       */
.src-stock { color: #16a34a; }  /* from stock */

/* Per-line buy source picker (click the cart) */
.src-menu { position: relative; display: inline-block; }
.src-menu > summary { list-style: none; cursor: pointer; display: inline-flex; }
.src-menu > summary::-webkit-details-marker { display: none; }
.src-menu > summary::marker { content: ""; }
.src-menu > summary:hover { filter: brightness(1.15); }
.src-menu-panel {
  position: absolute; z-index: 30; top: 100%; left: 50%; transform: translateX(-50%);
  margin-top: 0.3rem; min-width: 14rem; max-width: 20rem;
  background: var(--pico-card-background-color, #fff);
  border: 1px solid var(--pico-muted-border-color, #cfd8dc); border-radius: 8px;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.16); padding: 0.3rem; text-align: left;
}
.src-menu-head { margin: 0.2rem 0.4rem 0.35rem; font-size: 0.7rem; text-transform: uppercase;
  letter-spacing: 0.05em; color: var(--pico-muted-color, #6b7280); }
.src-opt {
  display: flex; align-items: center; justify-content: space-between; gap: 0.6rem;
  width: 100%; margin: 0; padding: 0.4rem 0.55rem; border: 0; border-radius: 6px;
  background: transparent; color: inherit; font-size: 0.85rem; text-align: left;
  cursor: pointer; box-shadow: none;
}
.src-opt:hover { background: rgba(43, 59, 75, 0.08); color: var(--ika-slate); }
.src-opt-link:hover { color: var(--pico-primary); }
.src-opt.active { background: rgba(238, 84, 84, 0.12); font-weight: 600; }
.src-opt-link { text-decoration: none; color: var(--pico-primary, #ee5454); }

/* Manufacturer shown in small all-caps above an MPN; truncates with an ellipsis. */
.mfr-tag {
  display: block; max-width: 16rem; overflow: hidden; text-overflow: ellipsis;
  white-space: nowrap; font-size: 0.62rem; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--pico-muted-color); line-height: 1.3;
}

/* Searchable location dropdown (see combobox.js). */
.cb-wrap { position: relative; display: block; width: 100%; min-width: 9rem; max-width: 26rem; }
.cb-native { display: none !important; }
.cb-input { width: 100%; margin: 0; }
.cb-panel {
  position: absolute; z-index: 60; left: 0; top: 100%; margin: 0.15rem 0 0; padding: 0.25rem 0;
  list-style: none; min-width: 100%; width: max-content; max-width: 26rem;
  max-height: 15rem; overflow-y: auto; background: var(--pico-background-color);
  border: 1px solid var(--pico-muted-border-color); border-radius: 0.4rem;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15);
}
.cb-opt { padding: 0.3rem 0.7rem; cursor: pointer; white-space: nowrap; }
.cb-opt:hover, .cb-opt.cb-sel { background: rgba(22, 163, 74, 0.15); }
.cb-empty { padding: 0.3rem 0.7rem; color: var(--pico-muted-color); }

/* ---- Badges ---- */
.badge {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.03em;
  padding: 0.12rem 0.5rem; border-radius: 1rem; color: #fff; white-space: nowrap;
}
.badge-opening { background: #6b7280; }
.badge-add, .badge-receive { background: #16a34a; }
.badge-remove, .badge-build { background: #dc2626; }
.badge-move { background: #2563eb; }
.badge-correction { background: #d97706; }
.badge-short { background: #facc15; color: #1f2937; }  /* yellow, dark text */
.badge-reel { background: #7c3aed; }                   /* violet — matches the reel icon */

.row-short td { background: rgba(250, 204, 21, 0.18); }       /* short -> yellow */
.row-short td:first-child { box-shadow: inset 4px 0 0 0 #eab308; }
.row-nostock td { background: rgba(239, 68, 68, 0.10); }      /* no stock -> light red */
.row-nostock td:first-child { box-shadow: inset 4px 0 0 0 #ef4444; }
.row-error td { background: rgba(220, 38, 38, 0.15); }
.row-error td:first-child { box-shadow: inset 4px 0 0 0 #dc2626; }
/* Small ✕ next to the DRAFT chip to cancel/reset the draft.
   `h2 button.reset-draft` (0,1,2) beats Pico's button[type=submit]{width:100%} (0,1,1). */
h2 button.reset-draft {
  display: inline-flex; align-items: center; justify-content: center;
  width: 1.5rem; height: 1.5rem; padding: 0; margin: 0 0 0 0.5rem;
  font-size: 0.8rem; line-height: 1; vertical-align: middle;
  background: transparent; color: var(--pico-muted-color);
  border: 1px solid var(--pico-muted-border-color); border-radius: 50%;
}
h2 button.reset-draft:hover, h2 button.reset-draft:focus {
  background: #dc2626; border-color: #dc2626; color: #fff;
}

/* Clickable "N lines need …" hint that jumps to the next blocking row. */
.hindrance-link { cursor: pointer; text-decoration: underline; }
@keyframes row-flash { 0%, 100% { background: rgba(220, 38, 38, 0.15); } 35% { background: #fde68a; } }
.row-flash td { animation: row-flash 0.9s ease; }

.mock-tag {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.05em;
  background: #d97706; color: #fff; padding: 0.1rem 0.45rem; border-radius: 0.3rem;
}

/* ---- Pagination ---- */
.pager {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; margin-top: 0.5rem; flex-wrap: wrap;
}
.pager-btns { display: flex; align-items: center; gap: 0.75rem; }
.pager-btns [role="button"] { padding: 0.25rem 0.75rem; margin: 0; }

/* ---- Small action buttons in tables ---- */
.btn-sm { padding: 0.2rem 0.6rem; margin: 0; font-size: 0.8rem; width: auto; }
.row-actions { display: flex; gap: 0.4rem; align-items: center; }
.row-actions form { margin: 0; }
.row-actions button { width: auto; white-space: nowrap; margin: 0; }
.row-actions .btn-sm { display: inline-flex; align-items: center; gap: 0.3rem; }

/* ---- Link lists (project pickers) ---- */
.link-list { list-style: none; padding: 0; }
.link-list li { padding: 0.35rem 0; border-bottom: 1px solid var(--pico-card-border-color); }

/* ---- Login ---- */
.login-wrap { max-width: 420px; margin: 4rem auto; }
.nav-user { display: flex; align-items: center; gap: 0.6rem; }
.nav-user .muted { font-size: 0.85rem; }

/* ---- BOM review / resolver ---- */
.finalize-bar {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  margin: 1rem 0; padding: 0.5rem 0;
}
.finalize-bar .flash { margin: 0; }
.resolver {
  margin-top: 0.5rem; padding: 0.75rem;
  border: 1px solid var(--pico-card-border-color); border-radius: var(--pico-border-radius);
  background: var(--pico-card-sectioning-background-color);
}
.resolver input[type="search"], .resolver input[type="text"] { margin-bottom: 0.5rem; }

/* Wide, full-row resolve card — indented to stand out from the BOM lines */
.row-editing td {
  background: var(--pico-card-sectioning-background-color);
  box-shadow: inset 5px 0 0 0 var(--pico-primary);
  padding: 0.5rem 0.75rem 0.75rem;
}
.resolve-wide { margin-left: 1.5rem; padding: 0.5rem 0.25rem; }
.resolve-context {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; margin-bottom: 0.5rem; flex-wrap: wrap;
}
.resolve-search { font-size: 1.1rem; margin-bottom: 0.5rem; }
.resolver-actions { display: flex; gap: 0.5rem; margin: 0.5rem 0; }
.resolver-create { margin-top: 0.5rem; }
.link-results .results { margin: 0 0 0.5rem; padding: 0; list-style: none; max-height: 300px; overflow-y: auto; }
.link-results .results li { margin: 0 0 0.3rem; }
.link-result {
  width: 100%; text-align: left; margin: 0;
  display: flex; gap: 0.5rem; align-items: baseline;
  /* Reset Pico's button custom-props so text isn't white-on-hover. */
  --pico-background-color: transparent;
  --pico-border-color: transparent;
  --pico-color: var(--pico-contrast);
  color: var(--pico-contrast);
  border: 1px solid rgba(22, 163, 74, 0.35);
  background: rgba(22, 163, 74, 0.10);
  border-radius: var(--pico-border-radius);
  padding: 0.45rem 0.7rem;
}
.link-result strong, .link-result .muted { color: var(--pico-contrast); }
.link-result:hover {
  background: rgba(22, 163, 74, 0.28);
  border-color: rgba(22, 163, 74, 0.7);
}

/* ---- Flash messages ---- */
.flash { padding: 0.6rem 1rem; border-radius: var(--pico-border-radius); }
.flash.ok  { background: rgba(22, 163, 74, 0.12); }
.flash.err { background: rgba(220, 38, 38, 0.12); }
.flash.warn { background: rgba(217, 119, 6, 0.15); }
.flash-link { display: inline-block; text-decoration: none; cursor: pointer; }
.flash-link:hover { text-decoration: underline; }

/* Smooth-scroll to a targeted BOM line, clear of the page top. */
html { scroll-behavior: smooth; }
tr[id^="line-"] { scroll-margin-top: 5rem; }
tr[id^="line-"]:target td { box-shadow: inset 0 0 0 2px var(--pico-primary); }

/* ---- BOM manager ---- */
.hover-actions { visibility: hidden; }
.hover-row:hover .hover-actions, .hover-row:focus-within .hover-actions { visibility: visible; }
.row-ignored td { background: rgba(217, 119, 6, 0.10); }
.ignore-toggle { display: inline-flex; align-items: center; gap: 0.3rem; font-size: 0.8rem; margin: 0; }
.ignore-toggle input { margin: 0; width: auto; }
.bom-head { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
.bom-head h2 { margin: 0; }

/* Subtle text-style action bar under the BOM name. */
.bom-actions { display: flex; justify-content: flex-start; align-items: center; gap: 1.25rem; margin: 0.25rem 0 1.25rem; flex-wrap: wrap; }
.bom-actions form { margin: 0; }
.bom-action {
  background: none; border: none; box-shadow: none; padding: 0; margin: 0;
  width: auto; font-size: 0.9rem; cursor: pointer; text-decoration: none;
  --pico-background-color: transparent; --pico-color: var(--pico-primary);
  color: var(--pico-primary);
}
.bom-action { line-height: 1.4; vertical-align: baseline; }
.bom-action:hover { text-decoration: underline; }
.bom-action-danger { --pico-color: #dc2626; color: #dc2626; }
.rename-box { margin: -0.5rem 0 1rem; }
.rename-box[hidden] { display: none; }
