/* ============================================================
   PAPR Solutions — STORE stylesheet (commerce layer)
   Built on the brand tokens + camera chrome in site.css.
   Load order:  <link site.css>  then  <link store.css>
   ============================================================ */

body { overflow-x: hidden; }
.store-main { padding: 128px 5vw 120px; max-width: 1360px; margin: 0 auto; position: relative; z-index: 2; }
a.plain { text-decoration: none; color: inherit; }
.muted { color: var(--dim); }
.air { color: var(--sage); }
.haz { color: var(--gold); }
.mono { font-family: var(--mono); }

/* ---------- store header extras ---------- */
.cartbtn { position: relative; font-family: var(--mono); font-size: .6rem; letter-spacing: .24em; text-transform: uppercase;
  color: var(--ivory); border: 1px solid var(--hairline); padding: 9px 16px; background: rgba(12,15,18,.4); cursor: pointer; text-decoration: none; }
.cartbtn:hover { background: var(--ivory); color: var(--bg); }
.cartbtn .cnt { color: var(--gold); margin-left: 8px; }
.cartbtn:hover .cnt { color: var(--bg); }

/* ---------- hero band ---------- */
.store-hero { padding: 8px 0 40px; border-bottom: 1px solid var(--hairline); margin-bottom: 34px; }
.store-hero .eyebrow { display: block; margin-bottom: 18px; }
.store-hero h1 { font-family: var(--serif); font-weight: 500; font-size: clamp(2.2rem, 5.4vw, 4.2rem); line-height: 1.02;
  text-transform: uppercase; letter-spacing: .01em; max-width: 15ch; }
.store-hero h1 .it { color: var(--sage); font-style: italic; text-transform: none; }
.store-hero p { margin-top: 20px; max-width: 52ch; color: var(--dim); font-size: .9rem; }

/* data-source banner */
.srcbar { margin-top: 22px; display: inline-flex; align-items: center; gap: 12px; font-family: var(--mono);
  font-size: .55rem; letter-spacing: .2em; text-transform: uppercase; color: var(--dim);
  border: 1px solid var(--hairline); padding: 8px 14px; }
.srcbar b { width: 7px; height: 7px; border-radius: 50%; background: var(--sage); display: inline-block; }
.srcbar.sample b { background: var(--gold); }

/* ---------- filters ---------- */
.filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 30px; }
.filters button { font-family: var(--mono); font-size: .56rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--dim); background: transparent; border: 1px solid var(--hairline); padding: 9px 15px; cursor: pointer; transition: all .25s; white-space: nowrap; }
.filters button:hover { color: var(--ivory); border-color: rgba(233,238,241,.4); }
.filters button.on { color: var(--bg); background: var(--ivory); border-color: var(--ivory); }

.searchrow { margin-bottom: 26px; }
.searchrow input { width: min(420px, 100%); background: transparent; border: 1px solid var(--hairline);
  color: var(--ivory); font-family: var(--mono); font-size: .72rem; letter-spacing: .08em; padding: 12px 14px; outline: none; }
.searchrow input::placeholder { color: var(--dim); letter-spacing: .18em; text-transform: uppercase; font-size: .6rem; }
.searchrow input:focus { border-color: var(--sage); }

/* ---------- product grid ---------- */
.pgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; background: var(--hairline);
  border: 1px solid var(--hairline); }
@media (max-width: 1100px) { .pgrid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 820px)  { .pgrid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px)  { .pgrid { grid-template-columns: 1fr; } }

.pcard { background: var(--bg); padding: 24px 22px 22px; display: flex; flex-direction: column; min-height: 300px;
  position: relative; transition: background .3s; }
.pcard:hover { background: #0f1318; }
.pcard .cat { font-family: var(--mono); font-size: .5rem; letter-spacing: .26em; text-transform: uppercase; color: var(--gold); }
.pcard .brand { font-family: var(--mono); font-size: .52rem; letter-spacing: .18em; text-transform: uppercase; color: var(--dim); margin-top: 14px; }
.pcard h3 { font-family: var(--serif); font-weight: 500; font-size: 1.28rem; line-height: 1.18; margin-top: 6px; letter-spacing: .005em; text-transform: none; }
.pcard .desc { margin-top: 12px; font-size: .74rem; color: var(--dim); line-height: 1.6;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.pcard .sku { font-family: var(--mono); font-size: .5rem; letter-spacing: .14em; color: rgba(139,148,156,.7); margin-top: 12px; }
.pcard .foot { margin-top: auto; padding-top: 18px; display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; }
.pcard .price { font-family: var(--serif); font-size: 1.5rem; color: var(--ivory); line-height: 1; }
.pcard .price small { font-family: var(--mono); font-size: .5rem; letter-spacing: .12em; color: var(--dim); display: block; margin-top: 6px; }
.stock { font-family: var(--mono); font-size: .5rem; letter-spacing: .18em; text-transform: uppercase; display: inline-flex; align-items: center; gap: 6px; }
.stock b { width: 6px; height: 6px; border-radius: 50%; display: inline-block; }
.stock.in { color: var(--sage); } .stock.in b { background: var(--sage); }
.stock.lead { color: var(--gold); } .stock.lead b { background: var(--gold); }
.stock.out { color: var(--dim); } .stock.out b { background: var(--dim); }

.addbtn { font-family: var(--mono); font-size: .55rem; letter-spacing: .22em; text-transform: uppercase; color: var(--ivory);
  border: 1px solid rgba(233,238,241,.4); background: transparent; padding: 11px 16px; cursor: pointer; transition: all .25s; white-space: nowrap; }
.addbtn:hover { background: var(--sage); color: var(--bg); border-color: var(--sage); }
.addbtn:disabled { opacity: .4; cursor: not-allowed; }
.addbtn.added { background: var(--gold); border-color: var(--gold); color: var(--bg); }

.empty { padding: 80px 0; text-align: center; color: var(--dim); font-family: var(--mono); font-size: .7rem; letter-spacing: .18em; text-transform: uppercase; }
.loadwrap { padding: 80px 0; text-align: center; }
.spin { display: inline-block; width: 26px; height: 26px; border: 2px solid var(--hairline); border-top-color: var(--gold); border-radius: 50%; animation: sp 1s linear infinite; }
@keyframes sp { to { transform: rotate(360deg); } }

/* ---------- qty stepper ---------- */
.qty { display: inline-flex; align-items: center; border: 1px solid var(--hairline); }
.qty button { background: transparent; border: none; color: var(--ivory); font-family: var(--mono); font-size: .9rem; width: 34px; height: 34px; cursor: pointer; }
.qty button:hover { background: rgba(233,238,241,.08); }
.qty input { width: 42px; text-align: center; background: transparent; border: none; color: var(--ivory); font-family: var(--mono); font-size: .8rem; outline: none; }

/* ---------- mini-cart drawer ---------- */
.cart-drawer { position: fixed; top: 0; right: 0; z-index: 130; height: 100dvh; width: min(420px, 92vw);
  background: rgba(10,13,16,.98); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-left: 1px solid var(--hairline); transform: translateX(100%); transition: transform .38s cubic-bezier(.4,0,.1,1);
  display: flex; flex-direction: column; }
.cart-drawer.open { transform: none; }
.cart-scrim { position: fixed; inset: 0; z-index: 129; background: rgba(6,8,10,.55); opacity: 0; pointer-events: none; transition: opacity .38s; }
.cart-scrim.open { opacity: 1; pointer-events: auto; }
.cart-head { display: flex; align-items: center; justify-content: space-between; padding: 24px 24px 18px; border-bottom: 1px solid var(--hairline); }
.cart-head .t { font-family: var(--mono); font-size: .6rem; letter-spacing: .3em; text-transform: uppercase; color: var(--ivory); }
.cart-head button { background: none; border: none; color: var(--dim); font-family: var(--mono); font-size: .75rem; cursor: pointer; letter-spacing: .2em; }
.cart-head button:hover { color: var(--ivory); }
.cart-items { flex: 1; overflow-y: auto; padding: 8px 24px; }
.ci { display: grid; grid-template-columns: 1fr auto; gap: 8px 12px; padding: 18px 0; border-bottom: 1px solid var(--hairline); }
.ci .nm { font-family: var(--serif); font-size: 1rem; line-height: 1.25; }
.ci .meta { font-family: var(--mono); font-size: .52rem; letter-spacing: .12em; color: var(--dim); margin-top: 5px; text-transform: uppercase; }
.ci .lt { font-family: var(--serif); font-size: 1rem; text-align: right; }
.ci .rm { background: none; border: none; color: var(--dim); font-family: var(--mono); font-size: .5rem; letter-spacing: .16em; cursor: pointer; text-transform: uppercase; padding: 0; margin-top: 6px; }
.ci .rm:hover { color: var(--gold); }
.cart-foot { padding: 20px 24px calc(24px + env(safe-area-inset-bottom,0)); border-top: 1px solid var(--hairline); }
.cart-foot .row { display: flex; justify-content: space-between; font-family: var(--mono); font-size: .62rem; letter-spacing: .12em; text-transform: uppercase; color: var(--dim); margin-bottom: 10px; }
.cart-foot .row.total { color: var(--ivory); font-size: .72rem; }
.cart-foot .row.total b { font-family: var(--serif); font-size: 1.4rem; font-weight: 500; letter-spacing: 0; }
.cart-empty { padding: 60px 24px; text-align: center; color: var(--dim); font-family: var(--mono); font-size: .62rem; letter-spacing: .18em; text-transform: uppercase; }

/* ---------- generic buttons ---------- */
.btn { display: inline-block; width: 100%; text-align: center; padding: 15px 24px; border: 1px solid rgba(233,238,241,.45);
  font-family: var(--sans); font-size: .62rem; font-weight: 600; letter-spacing: .3em; text-transform: uppercase; color: var(--ivory);
  background: rgba(12,15,18,.35); cursor: pointer; text-decoration: none; transition: all .3s; }
.btn:hover { background: var(--ivory); color: var(--bg); }
.btn.solid { background: var(--sage); border-color: var(--sage); color: var(--bg); }
.btn.solid:hover { background: var(--ivory); border-color: var(--ivory); }
.btn:disabled { opacity: .45; cursor: not-allowed; }
.btn i { font-style: normal; color: var(--gold); margin-left: 8px; }
.btn:hover i, .btn.solid i { color: var(--bg); }

/* ---------- cart / checkout page ---------- */
.cart-page { display: grid; grid-template-columns: 1.4fr 1fr; gap: 5vw; align-items: start; }
@media (max-width: 900px) { .cart-page { grid-template-columns: 1fr; } }
.linebig { display: grid; grid-template-columns: 1fr auto auto; gap: 22px; align-items: center; padding: 22px 0; border-bottom: 1px solid var(--hairline); }
.linebig .nm { font-family: var(--serif); font-size: 1.2rem; }
.linebig .meta { font-family: var(--mono); font-size: .52rem; letter-spacing: .14em; color: var(--dim); text-transform: uppercase; margin-top: 6px; }
.linebig .lt { font-family: var(--serif); font-size: 1.2rem; min-width: 90px; text-align: right; }
.summary { border: 1px solid var(--hairline); padding: 30px 28px; position: sticky; top: 120px; }
.summary h2 { font-family: var(--mono); font-weight: 400; font-size: .62rem; letter-spacing: .3em; text-transform: uppercase; color: var(--dim); margin-bottom: 22px; }
.summary .row { display: flex; justify-content: space-between; font-family: var(--mono); font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: var(--dim); padding: 9px 0; }
.summary .row.total { border-top: 1px solid var(--hairline); margin-top: 10px; padding-top: 18px; color: var(--ivory); }
.summary .row.total b { font-family: var(--serif); font-size: 1.5rem; font-weight: 500; }
.summary .note { margin-top: 18px; font-family: var(--mono); font-size: .5rem; line-height: 1.7; letter-spacing: .08em; color: var(--dim); }

.formsec { margin-top: 10px; }
.formsec h2 { font-family: var(--mono); font-weight: 400; font-size: .62rem; letter-spacing: .3em; text-transform: uppercase; color: var(--dim); margin: 30px 0 4px; }
.field2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 26px; }
@media (max-width: 560px) { .field2 { grid-template-columns: 1fr; } }
.field input, .field select, .field textarea { font-family: var(--sans) !important; font-size: 1rem !important; }
.field input::placeholder { color: rgba(139,148,156,.5); }

.msg { font-family: var(--mono); font-size: .6rem; letter-spacing: .1em; padding: 12px 14px; border: 1px solid var(--hairline); margin-top: 16px; display: none; }
.msg.show { display: block; }
.msg.err { border-color: rgba(224,75,58,.6); color: #f0a89f; }
.msg.ok { border-color: var(--sage); color: var(--sage); }

/* ---------- confirmation ---------- */
.confirm { max-width: 680px; }
.confirm .big { font-family: var(--serif); font-size: clamp(2rem,5vw,3.4rem); text-transform: uppercase; line-height: 1.05; }
.confirm .big .it { color: var(--sage); font-style: italic; text-transform: none; }
.confirm .oid { font-family: var(--mono); font-size: .62rem; letter-spacing: .2em; color: var(--gold); margin-top: 20px; }
.pill { display: inline-block; font-family: var(--mono); font-size: .5rem; letter-spacing: .2em; text-transform: uppercase;
  padding: 6px 12px; border: 1px solid var(--hairline); color: var(--dim); }
.pill.warn { color: var(--gold); border-color: rgba(255,122,41,.5); }
.pill.good { color: var(--sage); border-color: rgba(92,208,200,.5); }

/* ============================================================
   ADMIN dashboard
   ============================================================ */
.adm-gate { max-width: 420px; margin: 0 auto; padding: 120px 0; }
.adm-gate h1 { font-family: var(--serif); font-weight: 500; font-size: 2rem; text-transform: uppercase; letter-spacing: .04em; }
.adm-gate p { color: var(--dim); font-size: .82rem; margin: 12px 0 24px; }

.adm-top { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; justify-content: space-between; margin-bottom: 26px; padding-bottom: 22px; border-bottom: 1px solid var(--hairline); }
.adm-stats { display: flex; flex-wrap: wrap; gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); }
.adm-stats div { background: var(--bg); padding: 12px 16px; min-width: 96px; }
.adm-stats b { font-family: var(--serif); font-size: 1.35rem; font-weight: 500; display: block; }
.adm-stats span { font-family: var(--mono); font-size: .48rem; letter-spacing: .18em; text-transform: uppercase; color: var(--dim); }
.cfgbadges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; }
.cfgbadge { font-family: var(--mono); font-size: .5rem; letter-spacing: .16em; text-transform: uppercase; color: var(--dim); border: 1px solid var(--hairline); padding: 7px 12px; }
.cfgbadge b { color: var(--sage); font-weight: 400; }
.cfgbadge.warn b { color: var(--gold); }

.adm-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }

.otable { border: 1px solid var(--hairline); }
.orow { border-bottom: 1px solid var(--hairline); }
.orow:last-child { border-bottom: none; }
.orow .ohead { display: grid; grid-template-columns: 1.4fr 1fr 1fr .8fr auto; gap: 16px; align-items: center; padding: 16px 20px; cursor: pointer; transition: background .2s; }
.orow .ohead:hover { background: #0f1318; }
.orow .ohead .oid { font-family: var(--mono); font-size: .6rem; letter-spacing: .1em; color: var(--ivory); }
.orow .ohead .who { font-size: .8rem; }
.orow .ohead .who small { display: block; font-family: var(--mono); font-size: .5rem; color: var(--dim); letter-spacing: .1em; margin-top: 3px; }
.orow .ohead .amt { font-family: var(--serif); font-size: 1.1rem; }
.orow .ohead .amt small { display: block; font-family: var(--mono); font-size: .5rem; color: var(--sage); letter-spacing: .1em; }
.statuspill { font-family: var(--mono); font-size: .5rem; letter-spacing: .16em; text-transform: uppercase; padding: 6px 10px; border: 1px solid var(--hairline); white-space: nowrap; text-align: center; }
.statuspill.PENDING_APPROVAL { color: var(--gold); border-color: rgba(255,122,41,.55); }
.statuspill.APPROVED { color: var(--sage); border-color: rgba(92,208,200,.4); }
.statuspill.SUBMITTED_TO_ORS { color: var(--sage); border-color: rgba(92,208,200,.55); background: rgba(92,208,200,.08); }
.statuspill.REJECTED, .statuspill.CANCELLED { color: var(--dim); }
.statuspill.AWAITING_PAYMENT { color: var(--dim); }
.statuspill.FULFILLED { color: var(--sage); }

.odetail { display: none; padding: 4px 20px 26px; background: #0d1114; }
.odetail.open { display: block; }
.odetail .di { display: grid; grid-template-columns: 1fr auto auto auto; gap: 16px; padding: 10px 0; border-bottom: 1px solid var(--hairline); font-family: var(--mono); font-size: .62rem; letter-spacing: .06em; }
.odetail .di .n { color: var(--ivory); font-family: var(--sans); font-size: .8rem; }
.odetail .di .c { color: var(--dim); text-align: right; }
.odetail .di .c b { color: var(--sage); font-weight: 400; }
.odetail .totals { display: flex; gap: 26px; flex-wrap: wrap; margin: 18px 0; font-family: var(--mono); font-size: .6rem; letter-spacing: .1em; text-transform: uppercase; color: var(--dim); }
.odetail .totals b { color: var(--ivory); font-weight: 400; }
.odetail .totals .profit b { color: var(--sage); }
.payload { background: #0a0d10; border: 1px solid var(--hairline); padding: 16px; font-family: var(--mono); font-size: .58rem; line-height: 1.6; color: var(--dim); overflow-x: auto; white-space: pre; margin: 6px 0 18px; max-height: 260px; overflow-y: auto; }
.oactions { display: flex; gap: 10px; flex-wrap: wrap; }
.oactions button { font-family: var(--mono); font-size: .55rem; letter-spacing: .2em; text-transform: uppercase; padding: 11px 20px; cursor: pointer; border: 1px solid var(--hairline); background: transparent; color: var(--ivory); transition: all .25s; }
.oactions .approve:hover { background: var(--sage); border-color: var(--sage); color: var(--bg); }
.oactions .reject:hover { background: #e04b3a; border-color: #e04b3a; color: var(--bg); }
.oactions button:disabled { opacity: .4; cursor: not-allowed; }
.ship { font-family: var(--mono); font-size: .58rem; letter-spacing: .06em; color: var(--dim); line-height: 1.7; margin: 6px 0 16px; }
.ship b { color: var(--ivory); font-weight: 400; }
