/* VESTRA — shared design system (shop) */
:root{
  --bg:#0e0e11; --bg2:#15151a; --bg3:#1b1b21; --ink:#f4f1ea; --mut:#9a988f;
  --acc:#c9a86a; --line:rgba(255,255,255,.08); --ok:#7ad6a0; --bad:#ef9a9a;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:'Playfair Display',Georgia,serif;font-weight:700;letter-spacing:-.5px;line-height:1.15}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.acc{color:var(--acc)}
svg{display:block}
img{max-width:100%}

/* nav */
header{position:sticky;top:0;z-index:30;background:rgba(14,14,17,.78);
  backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line)}
nav{display:flex;align-items:center;justify-content:space-between;height:64px;gap:18px}
.logo{display:flex;align-items:center;gap:9px;font-family:'Playfair Display',serif;font-size:21px;font-weight:700;letter-spacing:1.5px}
.logo .mark{width:28px;height:28px}
.nav-links{display:flex;align-items:center;gap:22px;font-size:14px;font-weight:500}
.nav-links a{color:var(--mut);transition:.2s}
.nav-links a:hover,.nav-links a.on{color:var(--ink)}
.cartlink{position:relative}
.cartlink .badge{position:absolute;top:-8px;right:-12px;background:var(--acc);color:#1a1408;
  font-size:11px;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 4px}
.memberpill{font-size:12px;color:var(--acc);border:1px solid rgba(201,168,106,.3);padding:5px 11px;border-radius:999px;background:rgba(201,168,106,.07)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:999px;font-weight:600;
  font-size:14px;cursor:pointer;border:1px solid var(--acc);transition:.2s;font-family:inherit}
.btn-p{background:var(--acc);color:#1a1408}
.btn-p:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn-o{background:transparent;color:var(--ink)}
.btn-o:hover{background:rgba(201,168,106,.1)}
.btn-sm{padding:9px 15px;font-size:13px}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none}

/* page header */
.phead{padding:40px 0 18px}
.phead h1{font-size:clamp(26px,4vw,40px);margin:0 0 6px}
.phead p{color:var(--mut);margin:0}
.crumbs{font-size:13px;color:var(--mut);margin-bottom:14px}
.crumbs a:hover{color:var(--ink)}

/* toolbar */
.toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:18px 0 26px}
.toolbar .grow{flex:1}
.chip{font-size:13px;padding:8px 14px;border-radius:999px;border:1px solid var(--line);color:var(--mut);cursor:pointer;background:transparent;font:inherit;transition:.2s}
.chip:hover{color:var(--ink);border-color:var(--mut)}
.chip.on{background:var(--acc);color:#1a1408;border-color:var(--acc)}
input,select,textarea{background:#0c0c0f;border:1px solid var(--line);border-radius:10px;padding:11px 13px;
  color:var(--ink);font:inherit;font-size:14px}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--acc)}
.search{min-width:210px}

/* product grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pcard{background:var(--bg2);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.25s;display:flex;flex-direction:column}
.pcard:hover{border-color:rgba(201,168,106,.35);transform:translateY(-4px)}
.thumb{aspect-ratio:4/3;display:grid;place-items:center;position:relative;color:#fff}
.thumb .bname{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;opacity:.92;text-align:center;padding:0 14px}
.thumb .vbadge{position:absolute;top:10px;left:10px;font-size:11px;font-weight:600;background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.25);padding:4px 9px;border-radius:999px;display:flex;gap:5px;align-items:center}
.pcard .body{padding:16px;display:flex;flex-direction:column;gap:6px;flex:1}
.pcard .brand{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--acc)}
.pcard .title{font-weight:600;font-size:15px}
.pcard .meta{font-size:12.5px;color:var(--mut)}
.pcard .price{margin-top:auto;padding-top:10px;font-size:14px}
.pcard .from{color:var(--mut);font-size:12px}
.pcard .amt{font-size:19px;font-weight:700}
.lock{color:var(--mut);font-size:13px;display:flex;align-items:center;gap:6px}

/* product detail */
.pdetail{display:grid;grid-template-columns:1fr 1fr;gap:34px;margin:14px 0 40px}
.pdetail .hero-thumb{aspect-ratio:1/1;border-radius:18px;display:grid;place-items:center;color:#fff;border:1px solid var(--line)}
.pdetail .hero-thumb .bname{font-family:'Playfair Display',serif;font-size:40px;font-weight:700;text-align:center;padding:0 20px}
.pdetail h1{font-size:30px;margin:6px 0 4px}
.pdetail .sub{color:var(--mut);margin:0 0 16px}
.spec{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--mut);margin:14px 0}
.spec b{color:var(--ink);font-weight:600}
.tiers{width:100%;border-collapse:collapse;margin:18px 0;font-size:14px}
.tiers th,.tiers td{padding:11px 12px;border-bottom:1px solid var(--line);text-align:left}
.tiers th{color:var(--mut);font-weight:500;font-size:12.5px}
.tiers tr.active{background:rgba(201,168,106,.09)}
.tiers .amt{font-weight:700;color:var(--acc)}

.order-box{background:var(--bg2);border:1px solid var(--line);border-radius:16px;padding:22px;margin-top:8px}
.qtyrow{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.stepper{display:flex;align-items:center;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.stepper button{background:#0c0c0f;border:0;color:var(--ink);width:40px;height:44px;font-size:18px;cursor:pointer}
.stepper button:hover{background:#15151a}
.stepper input{border:0;border-radius:0;width:84px;text-align:center;font-size:16px;font-weight:600}
.calc{margin:16px 0;display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:8px}
.calc .unit{color:var(--mut);font-size:13px}
.calc .total{font-size:26px;font-weight:800}
.calc .total small{font-size:13px;color:var(--mut);font-weight:500}
.hint{font-size:12.5px;color:var(--mut)}
.warn{color:var(--bad);font-size:13px}

/* cart */
.ctable{width:100%;border-collapse:collapse;font-size:14px}
.ctable th,.ctable td{padding:14px 10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}
.ctable th{color:var(--mut);font-weight:500;font-size:12.5px}
.ctable .r{text-align:right}
.ctable .x{color:var(--mut);cursor:pointer}
.ctable .x:hover{color:var(--bad)}
.summary{display:flex;justify-content:flex-end;margin:22px 0}
.summary .box{min-width:280px}
.summary .line{display:flex;justify-content:space-between;padding:8px 0;color:var(--mut)}
.summary .line.big{color:var(--ink);font-size:20px;font-weight:800;border-top:1px solid var(--line);margin-top:8px;padding-top:14px}

/* banners / notes */
.banner{padding:13px 16px;border-radius:12px;margin:18px 0;font-size:14px}
.banner.ok{background:rgba(122,214,160,.1);border:1px solid rgba(122,214,160,.4);color:var(--ok)}
.banner.info{background:rgba(201,168,106,.08);border:1px solid rgba(201,168,106,.3);color:var(--ink)}
.gate{background:var(--bg2);border:1px solid var(--line);border-radius:16px;padding:26px;text-align:center}
.empty{text-align:center;color:var(--mut);padding:60px 0}

/* footer */
footer{border-top:1px solid var(--line);padding:34px 0;color:var(--mut);font-size:13px;margin-top:40px}
.foot{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.foot a:hover{color:var(--ink)}

@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}.pdetail{grid-template-columns:1fr}}
@media(max-width:620px){
  .grid{grid-template-columns:1fr}
  .nav-links{gap:14px;font-size:13px}
  .nav-links .hidem{display:none}
}
/* pricing modes */
.hero-thumb{position:relative}
.modetag{position:absolute;top:12px;right:12px;font-size:11px;font-weight:700;padding:5px 11px;border-radius:999px;letter-spacing:.3px}
.modetag.sale{background:#e0533a;color:#fff}
.modetag.offer{background:rgba(0,0,0,.5);color:#fff;border:1px solid rgba(255,255,255,.35)}
.price .was{color:var(--mut);text-decoration:line-through;font-size:13px;margin-right:6px}
.offerprice{color:var(--acc);font-weight:600;font-size:14px}
.saleline{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:10px 0 0}
.saleline .was{color:var(--mut);text-decoration:line-through}
.saleline .now{font-size:22px;font-weight:800}
.saleline .badge-sale{background:#e0533a;color:#fff;font-weight:700;font-size:12px;padding:3px 9px;border-radius:999px}

/* sourcing board */
.reqstats{display:flex;gap:30px;flex-wrap:wrap;margin:6px 0 24px;padding:18px 22px;background:var(--bg2);border:1px solid var(--line);border-radius:14px}
.reqstats .stat{display:flex;flex-direction:column}
.reqstats .stat b{font-family:'Playfair Display',serif;font-size:23px;color:var(--acc);line-height:1.1}
.reqstats .stat span{font-size:12.5px;color:var(--mut)}
.reqlayout{display:grid;grid-template-columns:1.4fr 1fr;gap:26px;align-items:start}
.blocktitle{font-size:18px;margin:0 0 14px}
.reqlist{display:flex;flex-direction:column;gap:12px}
.reqcard{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:15px 18px;transition:.2s}
.reqcard:hover{border-color:rgba(201,168,106,.3)}
.reqcard.mine{border-color:rgba(201,168,106,.45);background:rgba(201,168,106,.06)}
.reqtop{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
.qpos{font-size:12px;color:var(--mut);letter-spacing:.4px}
.status{font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:999px}
.status.open{background:rgba(201,168,106,.13);color:var(--acc)}
.status.offers{background:rgba(122,214,160,.14);color:var(--ok)}
.reqtitle{font-weight:600;font-size:15px;margin-bottom:8px}
.reqmeta{display:flex;gap:14px;flex-wrap:wrap;font-size:12.5px;color:var(--mut)}
.reqmeta b{color:var(--ink)}
.reqact{margin-top:12px}
.postbox{background:var(--bg2);border:1px solid var(--line);border-radius:16px;padding:22px;position:sticky;top:80px}
.postbox label{display:block;margin-bottom:5px}
@media(max-width:820px){.reqlayout{grid-template-columns:1fr}.postbox{position:static}}

/* dashboard (seller / buyer panels) */
.dashtop{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;padding:34px 0 18px}
.dashtop h1{font-size:clamp(24px,3.5vw,34px);margin:4px 0 0}
.rolepill{font-size:12.5px;color:var(--acc);border:1px solid rgba(201,168,106,.3);padding:6px 13px;border-radius:999px;background:rgba(201,168,106,.07);white-space:nowrap}
.dashlayout{display:grid;grid-template-columns:210px 1fr;gap:24px;align-items:start;padding-bottom:30px}
.dashside{display:flex;flex-direction:column;gap:3px;position:sticky;top:80px}
.dashside a{padding:10px 14px;border-radius:10px;color:var(--mut);font-size:14px;font-weight:500;transition:.18s}
.dashside a:hover{color:var(--ink);background:var(--bg2)}
.dashside a.on{color:var(--ink);background:var(--bg2);border:1px solid var(--line)}
.dashside .signout{margin-top:10px;color:var(--mut);font-size:13px}
.dashside .signout:hover{color:var(--bad)}
.dashmain{min-width:0}
.statgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.statcard{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:18px}
.statcard .sv{font-family:'Playfair Display',serif;font-size:28px;font-weight:700}
.statcard .sl{color:var(--mut);font-size:12.5px;margin-top:2px}
.panelcard{background:var(--bg2);border:1px solid var(--line);border-radius:16px;padding:22px;margin-bottom:16px}
.pcfhead{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}
.pcfhead h3{margin:0;font-size:17px}
.quickrow{display:flex;gap:10px;flex-wrap:wrap}
.modechip{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;text-transform:capitalize}
.modechip.fixed{background:rgba(201,168,106,.13);color:var(--acc)}
.modechip.sale{background:rgba(224,83,58,.16);color:#f0a08c}
.modechip.offer{background:rgba(122,214,160,.14);color:var(--ok)}
.addform label{display:block;font-size:13px;color:var(--mut);margin:0 0 5px}
.addform input,.addform select,.addform textarea{width:100%}
.addform>label{margin-top:6px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.frow.four{grid-template-columns:repeat(4,1fr)}
.moderow{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 14px}
.moderadio{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:10px;padding:10px 14px;cursor:pointer;font-size:14px;color:var(--ink)}
.moderadio input{width:auto}
.tiergrid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin:6px 0 14px}
.tiergrid .hint{display:block;margin-bottom:4px}

/* legal */
.legallayout{display:grid;grid-template-columns:240px 1fr;gap:30px;align-items:start;padding-bottom:30px}
.legalnav{display:flex;flex-direction:column;gap:3px;position:sticky;top:80px}
.legalnav a{padding:9px 13px;border-radius:9px;color:var(--mut);font-size:13.5px;transition:.18s}
.legalnav a:hover{color:var(--ink);background:var(--bg2)}
.legalnav a.on{color:var(--ink);background:var(--bg2);border:1px solid var(--line)}
.legalbody{min-width:0;max-width:760px}
.legalbody h2{font-size:24px;margin:0 0 4px}
.legalmeta{color:var(--mut);font-size:12.5px;margin-bottom:18px}
.legalbody h3{font-size:16px;margin:22px 0 6px}
.legalbody p,.legalbody li{color:#c9c6bd;font-size:14.5px}
.legalbody ul,.legalbody ol{padding-left:20px}
.legalbody .muted{color:var(--mut);font-size:13px}
.legalbody a{color:var(--acc)}

@media(max-width:820px){
  .dashlayout{grid-template-columns:1fr}
  .dashside{position:static;flex-direction:row;flex-wrap:wrap;overflow:auto}
  .statgrid{grid-template-columns:repeat(2,1fr)}
  .frow,.frow.four{grid-template-columns:1fr 1fr}
  .tiergrid{grid-template-columns:repeat(2,1fr)}
  .legallayout{grid-template-columns:1fr}
  .legalnav{position:static;flex-direction:row;flex-wrap:wrap}
}

/* print (PDF catalog) */
@media print{
  header,footer,.noprint{display:none!important}
  body{background:#fff;color:#000}
  .pdfdoc{padding:0}
}
