/* ============================================================
   BagsyGo storefront — "tech-pack" identity
   Display: Space Grotesk · Body: Inter · Specs/prices: Space Mono
   ============================================================ */

:root{
  --ink:#141414;          /* near-black, matches logo ground */
  --ink-soft:#5B5B5E;
  --paper:#FAF8F5;        /* warm off-white for readable light sections */
  --panel:#F1ECE4;        /* warm kraft panel */
  --panel-2:#E9E2D7;
  --line:#E6E0D6;         /* stitch line */
  --line-strong:#C9C1B4;
  --accent:#F7941E;       /* BagsyGo orange */
  --accent-deep:#E97B00;
  --magenta:#F7941E;      /* alias kept so legacy rules recolor to orange */
  --orange:#F7941E;
  --grad:linear-gradient(100deg,#F7941E,#FF7A1A);
  --display:'Space Grotesk',system-ui,sans-serif;
  --body:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'Space Mono','SFMono-Regular',ui-monospace,monospace;
  --maxw:1180px;
  --r:14px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--body);font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.05;margin:0;letter-spacing:-.02em}
p{margin:0}
button{font-family:inherit;cursor:pointer}

.skip{position:absolute;left:-999px;top:8px;background:var(--ink);color:#fff;padding:8px 14px;border-radius:8px;z-index:200}
.skip:focus{left:12px}

:focus-visible{outline:2.5px solid var(--magenta);outline-offset:2px;border-radius:4px}

.mono{font-family:var(--mono)}
.spec-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--ink);
  background:transparent;color:var(--ink);padding:12px 20px;border-radius:999px;
  font-weight:600;font-size:14.5px;transition:transform .12s ease,background .15s,color .15s;
}
.btn:hover{transform:translateY(-1px)}
.btn.solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn.solid:hover{background:#000}
.btn.go{border:none;color:#fff;background:var(--grad);box-shadow:0 6px 18px -8px rgba(214,52,111,.7)}
.btn.go:hover{filter:brightness(1.04)}
.btn.sm{padding:9px 15px;font-size:13px}
.btn.block{width:100%;justify-content:center}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:100;background:rgba(251,250,248,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:14px 24px;display:flex;align-items:center;gap:24px}
.brand{font-family:var(--display);font-weight:700;font-size:23px;letter-spacing:-.03em}
.brand .go{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nav-links{margin-left:auto;display:flex;align-items:center;gap:26px}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--ink-soft);transition:color .15s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-cta{padding:9px 17px;border-radius:999px;color:#fff!important;background:var(--grad);font-weight:600}
.nav-cta:hover{filter:brightness(1.05)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px;margin-left:auto}
.nav-toggle span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* ---- layout primitives ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:88px 0}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--magenta);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--magenta)}
.stitch{border:none;border-top:1.6px dashed var(--line-strong);margin:0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:36px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(28px,4vw,42px)}
.sec-head p{color:var(--ink-soft);max-width:46ch}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero-in{max-width:var(--maxw);margin:0 auto;padding:72px 24px 64px;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(40px,6.6vw,76px);font-weight:700}
.hero h1 em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-lede{margin-top:22px;font-size:19px;color:var(--ink-soft);max-width:40ch}
.hero-cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.spec-strip{margin-top:40px;display:grid;grid-template-columns:repeat(4,1fr);border-top:1.6px dashed var(--line-strong)}
.spec-strip .cell{padding:16px 14px 0 0;border-right:1px dashed var(--line)}
.spec-strip .cell:last-child{border-right:none}
.spec-strip .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.spec-strip .v{font-family:var(--display);font-weight:600;font-size:20px;margin-top:4px}

/* blueprint signature */
.blueprint{width:100%;height:auto}
.bp-grid{stroke:var(--line);stroke-width:1}
.bp-body{fill:var(--panel);stroke:var(--ink);stroke-width:2.2}
.bp-stitch{fill:none;stroke:var(--ink);stroke-width:1.3;stroke-dasharray:5 5;opacity:.6}
.bp-strap{fill:none;stroke:var(--ink);stroke-width:9;stroke-linecap:round}
.bp-strap-i{fill:none;stroke:var(--panel);stroke-width:1.4;stroke-dasharray:4 4}
.bp-print{fill:url(#bpgrad);stroke:var(--magenta);stroke-width:1.6;stroke-dasharray:6 5}
.bp-dim{stroke:var(--ink-soft);stroke-width:1}
.bp-call{stroke:var(--magenta);stroke-width:1.2}
.bp-dot{fill:var(--magenta)}
.bp-txt{font-family:var(--mono);font-size:11px;fill:var(--ink);letter-spacing:.06em}
.bp-txt.dim{fill:var(--ink-soft)}

/* ============================================================
   VALUE ROW
   ============================================================ */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff}
.value{padding:30px 26px;border-right:1px dashed var(--line)}
.value:last-child{border-right:none}
.value .n{font-family:var(--mono);font-size:12px;color:var(--magenta);letter-spacing:.1em}
.value h3{font-size:19px;margin:12px 0 8px}
.value p{font-size:14.5px;color:var(--ink-soft)}

/* ============================================================
   CARDS (catalogue / surplus)
   ============================================================ */
.grid{display:grid;gap:20px}
.grid.cats{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.grid.prods{grid-template-columns:repeat(auto-fill,minmax(270px,1fr))}

.cat-card{display:block;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;transition:transform .15s,box-shadow .15s,border-color .15s}
.cat-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px -18px rgba(26,22,32,.4);border-color:var(--line-strong)}
.cat-card .thumb{height:128px}
.cat-card .body{padding:16px 18px}
.cat-card h3{font-size:18px}
.cat-card .meta{font-family:var(--mono);font-size:11px;color:var(--ink-soft);margin-top:6px;letter-spacing:.04em}

.card{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s,border-color .15s}
.card:hover{transform:translateY(-3px);box-shadow:0 16px 34px -20px rgba(26,22,32,.45);border-color:var(--line-strong)}
.card .thumb{height:190px;position:relative}
.card .tag{position:absolute;top:12px;left:12px;z-index:3;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;background:var(--ink);color:#fff;padding:5px 9px;border-radius:6px}
.card .tag.featured{background:var(--grad)}
.card .body{padding:18px;display:flex;flex-direction:column;gap:12px;flex:1}
.card h3{font-size:19px}
.card .desc{font-size:14px;color:var(--ink-soft)}
.spec-rows{display:flex;flex-direction:column;gap:7px;border-top:1.4px dashed var(--line);padding-top:12px}
.spec-row{display:flex;gap:10px;font-size:13px}
.spec-row .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);min-width:78px;padding-top:2px}
.spec-row .vv{flex:1}
.swatches{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.swatch{width:15px;height:15px;border-radius:50%;border:1px solid rgba(0,0,0,.18);box-shadow:inset 0 0 0 2px #fff}
.card .act{margin-top:auto;padding-top:4px}

/* placeholder thumbnail (no image files shipped) */
.thumb.ph{background:
  repeating-linear-gradient(45deg,rgba(214,52,111,.05) 0 12px,transparent 12px 24px),
  var(--panel);
  display:flex;align-items:center;justify-content:center;color:var(--line-strong)}
.thumb.ph svg{width:62px;height:62px;opacity:.85}
.thumb.ph.cat svg{width:46px;height:46px}

/* category filter chips */
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.chip{font-family:var(--mono);font-size:12px;letter-spacing:.06em;padding:8px 14px;border:1.4px solid var(--line-strong);border-radius:999px;background:#fff;color:var(--ink-soft);transition:.15s}
.chip:hover{border-color:var(--ink)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ============================================================
   SURPLUS — dark band + tier ladder
   ============================================================ */
.surplus-band{background:var(--ink);color:var(--paper)}
.surplus-band .eyebrow{color:var(--orange)}
.surplus-band .eyebrow::before{background:var(--orange)}
.surplus-band .sec-head p{color:#b8b1bf}
.surplus-band .stitch{border-top-color:#3a3441}
.lot{display:grid;grid-template-columns:1fr 1.1fr;gap:0;border:1px solid #3a3441;border-radius:var(--r);overflow:hidden;background:#221d29;margin-bottom:20px}
.lot .media{min-height:200px;position:relative}
.lot .media .thumb{height:100%}
.lot .info{padding:26px 28px}
.lot h3{font-size:23px;color:#fff}
.lot .avail{font-family:var(--mono);font-size:12px;color:var(--orange);letter-spacing:.08em;margin-top:8px}
.lot .desc{color:#c4bdcc;font-size:14.5px;margin-top:12px}
.ladder{margin-top:18px;border-top:1.4px dashed #3a3441}
.ladder .row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:13px;padding:9px 0;border-bottom:1px dashed #2f2935}
.ladder .row .q{color:#c4bdcc}
.ladder .row .p{color:#fff;font-weight:700}
.calc{margin-top:18px;display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.calc .f{flex:1;min-width:120px}
.calc label{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#9a93a3;display:block;margin-bottom:6px}
.calc input{width:100%;background:#16121c;border:1.4px solid #3a3441;color:#fff;border-radius:10px;padding:11px 12px;font-family:var(--mono);font-size:15px}
.calc input:focus{border-color:var(--orange);outline:none}
.calc .out{font-family:var(--mono);font-size:13px;color:#fff;min-width:150px;padding-bottom:11px}
.calc .out b{color:var(--orange)}

/* ============================================================
   CUSTOM — process
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff}
.step{padding:28px 24px;border-right:1px dashed var(--line);position:relative}
.step:last-child{border-right:none}
.step .num{font-family:var(--mono);font-size:13px;color:var(--magenta);letter-spacing:.1em}
.step h3{font-size:18px;margin:14px 0 8px}
.step p{font-size:14px;color:var(--ink-soft)}
.custom-cta{margin-top:40px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;border:1px solid var(--line);border-radius:var(--r);background:var(--panel);padding:40px}
.custom-cta h3{font-size:28px}
.custom-cta p{color:var(--ink-soft);margin-top:12px}
.note{font-family:var(--mono);font-size:12px;color:var(--ink-soft);margin-top:16px;padding:12px 14px;border:1.4px dashed var(--line-strong);border-radius:10px;background:#fff;line-height:1.5}

/* ============================================================
   FORMS (modal + contact)
   ============================================================ */
.field{margin-bottom:14px}
.field label{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-bottom:6px}
.field .req{color:var(--magenta)}
.field input,.field textarea{width:100%;border:1.5px solid var(--line-strong);border-radius:10px;padding:12px 13px;font-family:var(--body);font-size:15px;background:#fff;color:var(--ink)}
.field textarea{min-height:110px;resize:vertical}
.field input:focus,.field textarea:focus{border-color:var(--magenta);outline:none}
.field.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field.two>div{margin:0}
.form-err{color:var(--magenta);font-size:13px;min-height:18px;margin:2px 0 8px;font-weight:500}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-aside .spec-label{display:block;margin-bottom:8px}
.contact-aside .big{font-family:var(--display);font-size:clamp(28px,4vw,40px);margin-bottom:20px}
.contact-aside .line{display:flex;gap:12px;padding:14px 0;border-top:1.4px dashed var(--line);font-size:14.5px}
.contact-aside .line .k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);min-width:90px}

/* ============================================================
   MODAL + TOAST
   ============================================================ */
.overlay{position:fixed;inset:0;background:rgba(26,22,32,.5);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:300;padding:20px}
.overlay.show{display:flex}
.sheet{background:var(--paper);border-radius:18px;border:1px solid var(--line);width:100%;max-width:520px;max-height:90vh;overflow:auto;padding:30px 30px 26px;box-shadow:0 30px 70px -25px rgba(0,0,0,.5)}
.sheet h3{font-size:24px;margin-bottom:6px}
.sheet .sub{color:var(--ink-soft);font-size:14.5px;margin-bottom:22px}
.sheet .x{float:right;border:none;background:none;font-size:24px;line-height:1;color:var(--ink-soft);padding:0 2px;margin:-6px -4px 0 0}
.sheet .actions{margin-top:18px;display:flex;gap:12px;justify-content:flex-end}

.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:13px 22px;border-radius:999px;font-size:14px;font-weight:500;opacity:0;pointer-events:none;transition:.25s;z-index:400;max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--magenta)}
.toast.ok{background:#198754}

/* ---- empty / loading ---- */
.state{text-align:center;padding:70px 20px;color:var(--ink-soft)}
.state .spec-label{display:block;margin-bottom:8px}
.skeleton{border:1px solid var(--line);border-radius:var(--r);height:300px;background:linear-gradient(90deg,var(--panel) 25%,#f6f1ea 50%,var(--panel) 75%);background-size:200% 100%;animation:sk 1.3s infinite}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--ink);color:#cfc8d6;border-top:1px solid #3a3441}
.foot-in{max-width:var(--maxw);margin:0 auto;padding:60px 24px 36px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.foot-word{color:#fff;font-size:24px}
.foot-tag{margin-top:14px;font-size:14px;max-width:32ch;color:#a79fb0}
.foot-h{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#7e7689;display:block;margin-bottom:14px}
.foot-col a{display:block;color:#cfc8d6;font-size:14.5px;margin-bottom:10px;transition:color .15s}
.foot-col a:hover{color:#fff}
.foot-note{font-size:13px;color:#8e8699;line-height:1.5}
.foot-link{color:var(--orange)!important;font-weight:600}
.foot-bar{max-width:var(--maxw);margin:0 auto;padding:18px 24px;border-top:1px solid #3a3441;display:flex;justify-content:space-between;font-size:12.5px;color:#7e7689}
.foot-mono{font-family:var(--mono);letter-spacing:.1em}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:880px){
  .hero-in{grid-template-columns:1fr;padding-top:48px}
  .blueprint{max-width:380px;margin:0 auto}
  .values,.steps{grid-template-columns:1fr}
  .value{border-right:none;border-bottom:1px dashed var(--line)}
  .value:last-child{border-bottom:none}
  .step{border-right:none;border-bottom:1px dashed var(--line)}
  .step:last-child{border-bottom:none}
  .lot{grid-template-columns:1fr}
  .custom-cta,.contact-grid{grid-template-columns:1fr;gap:26px}
  .spec-strip{grid-template-columns:1fr 1fr}
  .spec-strip .cell:nth-child(2){border-right:none}
}
@media(max-width:680px){
  .section{padding:60px 0}
  .nav-toggle{display:flex}
  .nav-links{position:fixed;inset:62px 0 auto 0;background:var(--paper);flex-direction:column;align-items:stretch;gap:0;padding:8px 0 14px;border-bottom:1px solid var(--line);box-shadow:0 16px 30px -20px rgba(0,0,0,.4);display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 24px}
  .nav-cta{margin:10px 24px 0;text-align:center}
  .field.two{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}}

/* ============================================================
   AUTH + ACCOUNT + ORDERS  (added)
   ============================================================ */
.nav-auth{display:flex;align-items:center;gap:16px;margin-left:6px}
.nav-auth a.link{font-size:14.5px;font-weight:500;color:var(--ink-soft)}
.nav-auth a.link:hover{color:var(--ink)}
.nav-user{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--ink);background:var(--panel);border:1px solid var(--line-strong);border-radius:999px;padding:6px 12px}
.nav-user .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.btn.tiny{padding:7px 13px;font-size:12.5px}

.field select{width:100%;border:1.5px solid var(--line-strong);border-radius:10px;padding:12px 13px;font-family:var(--body);font-size:15px;background:#fff;color:var(--ink)}
.field select:focus{border-color:var(--accent);outline:none}

/* status badges (orders) */
.badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border-radius:999px;border:1px solid transparent}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.placed{color:#9a6b00;background:#fff3df;border-color:#f6dcab}
.badge.confirmed{color:#1d6fb8;background:#e8f1fb;border-color:#c4ddf5}
.badge.inproduction{color:#7a4dd6;background:#f0eaff;border-color:#dccbff}
.badge.shipped{color:#0a8a6f;background:#e3f7f1;border-color:#bfeadd}
.badge.completed{color:#198754;background:#e6f5ec;border-color:#bfe4cd}
.badge.cancelled{color:#b23b3b;background:#fbecec;border-color:#f0c9c9}

/* my orders */
.orders{display:flex;flex-direction:column;gap:16px}
.order{border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:20px 22px;display:grid;grid-template-columns:64px 1fr auto;gap:18px;align-items:center}
.order .oimg{width:64px;height:64px;border-radius:10px;overflow:hidden}
.order .oimg .thumb,.order .oimg .thumb.ph{height:64px}
.order .ono{font-family:var(--mono);font-size:11.5px;color:var(--ink-soft);letter-spacing:.06em}
.order h3{font-size:18px;margin:3px 0 6px}
.order .ometa{font-size:13.5px;color:var(--ink-soft);display:flex;gap:14px;flex-wrap:wrap}
.order .ometa .mono{font-size:12.5px}
.order .oside{display:flex;flex-direction:column;align-items:flex-end;gap:10px}

.account-head{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:30px}
.account-head .who{display:flex;align-items:center;gap:12px}
.account-head .who .av{width:46px;height:46px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:20px}

.auth-switch{font-size:13.5px;color:var(--ink-soft);margin-top:16px;text-align:center}
.auth-switch a{color:var(--accent);font-weight:600;cursor:pointer}

/* staff notice on storefront */
.staff-note{border:1.4px dashed var(--line-strong);background:var(--panel);border-radius:var(--r);padding:22px 24px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}

/* ============================================================
   ABOUT  (added)
   ============================================================ */
.about-hero{background:var(--ink);color:#fff;border-bottom:1px solid #000}
.about-hero .wrap{padding:64px 24px}
.about-hero img.logo{max-width:340px;width:70%;margin-bottom:26px}
.about-hero h1{font-size:clamp(30px,5vw,52px);max-width:18ch}
.about-hero h1 .go{color:var(--accent)}
.about-hero p{color:#c7c3bd;max-width:54ch;margin-top:18px;font-size:18px}
.about-script{font-family:var(--display);font-style:italic;color:var(--accent);font-size:20px;margin-top:18px}
.about-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;margin-top:8px}
.about-col{padding:28px 26px;border-right:1px dashed var(--line)}
.about-col:last-child{border-right:none}
.about-col .spec-label{display:block;margin-bottom:10px;color:var(--accent)}
.about-col h3{font-size:18px;margin-bottom:8px}
.about-col p{font-size:14.5px;color:var(--ink-soft)}
@media(max-width:880px){
  .about-cols{grid-template-columns:1fr}
  .about-col{border-right:none;border-bottom:1px dashed var(--line)}
  .about-col:last-child{border-bottom:none}
  .order{grid-template-columns:56px 1fr;}
  .order .oside{grid-column:1 / -1;flex-direction:row;justify-content:space-between;align-items:center}
}

/* staff preview banner + product preview note (added) */
#staffBanner{background:var(--ink);color:#f3efe9;border-bottom:1px solid #000}
#staffBanner .sb-in{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 24px;flex-wrap:wrap;font-size:13.5px}
#staffBanner b{color:var(--accent)}
.staff-act{font-family:var(--mono);font-size:12px;color:var(--ink-soft);letter-spacing:.02em;line-height:1.5}
.staff-act a{color:var(--accent);font-weight:600}

/* account dashboard + artwork + whatsapp (added) */
.acct-actions{display:flex;gap:10px;flex-wrap:wrap}
.acct-panel{border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:22px 24px;margin-top:22px}
.acct-panel-h{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px}
.acct-panel-h h3{font-size:20px}
.acct-sub{font-size:13.5px;color:var(--ink-soft);margin:-4px 0 14px}
.art-row .art-ico{display:flex;align-items:center;justify-content:center;background:var(--panel);border-radius:10px;font-size:26px}
.badge.pending{color:#9a6b00;background:#fff3df;border-color:#f6dcab}
.badge.approved{color:#198754;background:#e6f5ec;border-color:#bfe4cd}
.badge.rejected{color:#b23b3b;background:#fbecec;border-color:#f0c9c9}

#waFab{position:fixed;right:20px;bottom:20px;z-index:150;width:54px;height:54px;border-radius:50%;
  background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px -8px rgba(37,211,102,.7);transition:transform .15s}
#waFab:hover{transform:translateY(-2px) scale(1.04)}
@media(max-width:680px){ #waFab{right:14px;bottom:14px} }

/* file dropzone (added) */
.dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;text-align:center;
  border:1.6px dashed var(--line-strong);border-radius:12px;padding:22px 18px;cursor:pointer;background:#fff;transition:border-color .15s,background .15s}
.dropzone:hover{border-color:var(--accent)}
.dropzone.drag{border-color:var(--accent);background:#fff6ec}
.dropzone .dz-ico{font-size:22px;color:var(--accent);line-height:1}
.dropzone .dz-main{font-size:14.5px;color:var(--ink)}
.dropzone .dz-main b{color:var(--accent)}
.dropzone .dz-sub{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-soft)}
.dropzone .dz-file{font-size:13px;color:var(--ink);font-weight:600;margin-top:4px}
.dropzone .dz-file:empty{display:none}

/* logo image in nav (dark badge so the on-black logo reads on the light header) */
.brand-logo{display:inline-flex;align-items:center;line-height:0}
.brand-logo img{height:42px;width:auto;display:block}
@media(max-width:680px){ .brand-logo img{height:34px} }

/* clickable card media/title + product detail page (added) */
.card-media{display:block;position:relative;text-decoration:none}
.card-title{color:inherit;text-decoration:none}
.card-title:hover{color:var(--accent)}
.pd-back{margin-bottom:18px}
.pd-back a{font-family:var(--mono);font-size:13px;color:var(--ink-soft);text-decoration:none}
.pd-back a:hover{color:var(--accent)}
.pd{display:grid;grid-template-columns:1fr 1fr;gap:38px;align-items:start}
.pd-media{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);aspect-ratio:1/1}
.pd-media .thumb{height:100%}
.pd-info .eyebrow{color:var(--accent);font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.pd-title{font-family:var(--display);font-size:38px;line-height:1.05;letter-spacing:-.02em;margin:8px 0 14px}
.pd-desc{color:var(--ink-soft);font-size:15.5px;line-height:1.6;margin-bottom:18px}
.pd-specs{margin-bottom:22px}
.pd-act{display:flex;gap:10px;flex-wrap:wrap}
.pd-act .btn{padding:13px 22px;font-size:15px}
.pd-note{font-size:12.5px;color:var(--ink-soft);margin-top:14px}
@media(max-width:760px){ .pd{grid-template-columns:1fr;gap:22px} .pd-title{font-size:30px} }

/* product detail gallery (added) */
.pd-thumbs{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.pd-thumb{width:64px;height:64px;border-radius:9px;overflow:hidden;border:1.5px solid var(--line);background:#fff;padding:0;cursor:pointer}
.pd-thumb.active{border-color:var(--accent)}
.pd-thumb img{width:100%;height:100%;object-fit:cover;display:block}

/* surplus order sheet live price (added) */
.so-quote{margin:-4px 0 14px;font-size:14px}
.so-quote b{color:var(--accent)}
