/* ============================================================
   Yates Produce — admin console
   ============================================================ */
.admin-gate { min-height: 100dvh; display: grid; place-items: center; gap: var(--sp-4); color: var(--ink-muted); }
.spinner { width: 38px; height: 38px; border: 3px solid var(--border); border-top-color: var(--primary); border-radius: 50%; animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

.admin-tag { font-family: var(--font-mono); font-weight: 500; font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--on-primary);
  background: var(--green-700); padding: .3rem .7rem; border-radius: var(--r-xs); margin-left: var(--sp-3); }

/* KPI */
.kpi-row { display: grid; grid-template-columns: repeat(auto-fit,minmax(150px,1fr)); gap: var(--sp-3);
  max-width: 1280px; margin: 0 auto; padding: var(--sp-4) clamp(.8rem,3vw,1.5rem) 0; }
.kpi { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-4); box-shadow: var(--shadow-sm); }
.kpi .k-val { font-family: var(--font-display); font-size: 1.8rem; font-weight: 700; color: var(--green-700); line-height: 1; }
:root[data-theme="dark"] .kpi .k-val { color: var(--green-300); }
.kpi .k-lbl { font-family: var(--font-mono); font-size: .72rem; color: var(--ink-muted); margin-top: .3rem; text-transform: uppercase; letter-spacing: .06em; }
.kpi.accent .k-val { color: var(--accent); }

/* Filters */
.admin-filters { display: flex; gap: .45rem; flex-wrap: wrap; margin-bottom: var(--sp-4); }

/* Orders */
.admin-orders { display: grid; gap: var(--sp-4); }
.adm-order { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); box-shadow: var(--shadow-sm); padding: var(--sp-4) var(--sp-5); }
.adm-order-head { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--sp-3); flex-wrap: wrap; }
.adm-order-head h3 { font-size: 1.05rem; }
.adm-cust { font-weight: 700; }
.adm-sub { font-size: .82rem; color: var(--ink-muted); }
.adm-items { margin: var(--sp-3) 0; font-size: .88rem; }
.adm-items div { display: flex; justify-content: space-between; padding: .25rem 0; border-bottom: 1px dashed var(--border-soft); }
.adm-order-foot { display: flex; justify-content: space-between; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.adm-total { font-family: var(--font-display); font-size: 1.3rem; font-weight: 700; color: var(--green-700); }
:root[data-theme="dark"] .adm-total { color: var(--green-300); }
.status-select, .term-select { padding: .45rem .7rem; border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--surface); color: var(--ink); font: inherit; font-weight: 600; }

/* Catalog */
.admin-catalog-head { display: flex; justify-content: space-between; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.admin-catalog { display: grid; gap: var(--sp-5); }
.cat-group h3 { font-size: 1.1rem; margin-bottom: var(--sp-3); padding-bottom: .4rem; border-bottom: 2px solid var(--border); }
.adm-prod { display: grid; grid-template-columns: 1.6fr 1fr 1.2fr auto; gap: var(--sp-3); align-items: center;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm); padding: .7rem var(--sp-4); margin-bottom: .5rem; }
.adm-prod .ap-name { font-weight: 700; }
.adm-prod .ap-sku { font-family: var(--font-mono); font-size: .72rem; color: var(--ink-muted); }
.price-input { width: 100px; padding: .45rem .6rem; border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--surface); color: var(--ink); font: inherit; font-weight: 700; }
.av-select { padding: .45rem; border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--surface); color: var(--ink); font: inherit; }
.ap-toggle { display: inline-flex; align-items: center; gap: .4rem; font-size: .8rem; color: var(--ink-muted); }
.save-dot { font-size: .76rem; color: var(--green-600); font-weight: 700; opacity: 0; transition: opacity .2s; }
.save-dot.show { opacity: 1; }

/* Table */
.admin-table-wrap { overflow-x: auto; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); }
.admin-table { width: 100%; border-collapse: collapse; min-width: 720px; }
.admin-table th, .admin-table td { text-align: left; padding: .8rem 1rem; border-bottom: 1px solid var(--border-soft); font-size: .9rem; }
.admin-table th { font-family: var(--font-mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-muted); background: var(--surface-2); }
.admin-table .t-biz { font-weight: 700; }
.admin-table tabular, .admin-table .t-num { font-variant-numeric: tabular-nums; }

.specials-panel { max-width: 640px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); box-shadow: var(--shadow-sm); padding: var(--sp-5); }
.specials-panel label { display: block; font-weight: 600; font-size: .85rem; margin: var(--sp-4) 0 .35rem; }
.specials-panel input, .specials-panel select {
  width: 100%; padding: .65rem .8rem; border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--surface); color: var(--ink); font: inherit; }
.route-dispatch { margin-top: var(--sp-5); padding-top: var(--sp-5); border-top: 1px solid var(--border); }
.route-dispatch h3 { font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-muted); margin-bottom: .3rem; }
.route-dispatch .grid-2 { align-items: stretch; margin-top: var(--sp-3); }
.route-dispatch .btn { width: 100%; }
.fleet-list { display: grid; gap: .6rem; }
.fleet-row { display: grid; grid-template-columns: 1fr auto auto; gap: var(--sp-3); align-items: center;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm); padding: .7rem var(--sp-4); }
.fleet-row .ap-name { font-weight: 700; }
.fleet-row .veh-date { padding: .35rem .5rem; border: 1px solid var(--border); border-radius: var(--r-xs); background: var(--surface); color: var(--ink); font: inherit; }
@media (max-width: 640px) { .fleet-row { grid-template-columns: 1fr; } }

/* Load sheet bar */
.ls-bar { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-sm); padding: .7rem var(--sp-4); margin-bottom: var(--sp-4); }
.ls-bar .mono { font-family: var(--font-mono); font-size: .8rem; letter-spacing: .04em; color: var(--ink-soft); margin-right: auto; }
.ls-bar input { padding: .45rem .6rem; border: 1px solid var(--border); border-radius: var(--r-xs); background: var(--surface); color: var(--ink); font: inherit; }

/* Invoices */
.admin-invoices { display: grid; gap: .55rem; }
.adm-inv { display: grid; grid-template-columns: 1fr auto auto auto auto; gap: var(--sp-3); align-items: center;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm); padding: .65rem var(--sp-4); }
.adm-inv .ap-name { font-weight: 700; }
.adm-inv .adm-total { font-family: var(--font-mono); font-weight: 700; }
.adm-inv .inv-method, .adm-inv .inv-status { padding: .4rem .5rem; border: 1px solid var(--border); border-radius: var(--r-xs); background: var(--surface); color: var(--ink); font: inherit; font-size: .82rem; }
@media (max-width: 700px) { .adm-inv { grid-template-columns: 1fr 1fr; } }

/* Contract pricing modal */
.pm-list { max-height: 50vh; overflow-y: auto; display: grid; gap: .4rem; margin: var(--sp-3) 0; }
.pm-row { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); padding: .5rem .2rem; border-bottom: 1px solid var(--border-soft); }
.pm-row .ap-name { font-weight: 600; }
.pm-price { width: 110px; padding: .45rem .6rem; border: 1px solid var(--border); border-radius: var(--r-xs); background: var(--surface); color: var(--ink); font: inherit; font-variant-numeric: tabular-nums; text-align: right; }
.specials-panel .chk.big { font-size: 1rem; font-weight: 700; margin-top: 0; }
.sp-preview-label { font-size: .74rem; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-muted); margin: var(--sp-4) 0 .4rem; }
.sp-preview { border-radius: var(--r-sm); }

.chk { display: flex; align-items: center; gap: .5rem; margin-top: .6rem; font-size: .88rem; }
.modal-wide { max-width: 520px; }

@media (max-width: 700px) {
  .adm-prod { grid-template-columns: 1fr 1fr; }
}
