/* ============================================================
   Vayyari Vastram — luxury ethnic wear store · shared styles
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600&display=swap');
:root{
  --cream:#FBF7F2;--cream-2:#F4ECE2;--ink:#241019;--plum:#5A2A43;--plum-2:#3D1B2D;
  --gold:#C19A5B;--gold-2:#A87E3D;--rose:#C96B7E;--muted:#8A7A80;--line:#E7DBCF;--white:#FFFFFF;
  --radius:18px;--radius-sm:12px;--shadow:0 18px 40px -24px rgba(61,27,45,.45);--maxw:1200px;
  --font-display:"Fraunces",Georgia,serif;--font-body:"Plus Jakarta Sans",system-ui,sans-serif;--font-brand:"Cinzel",Georgia,serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--cream);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.serif{font-family:var(--font-display)}
.announce{background:var(--plum-2);color:var(--cream);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;text-align:center;padding:9px 16px}
.announce b{color:var(--gold);font-weight:600}
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,247,242,.86);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{font-family:var(--font-brand);font-weight:600;font-size:24px;letter-spacing:.02em;color:var(--plum-2);display:flex;flex-direction:row;align-items:center;gap:1px;line-height:1}
.brand small{font-family:var(--font-body);font-weight:500;font-size:9px;letter-spacing:.42em;color:var(--gold-2);text-transform:uppercase;margin-top:4px}
.brand-logo{height:48px;width:auto;flex:0 0 auto}
.brand-wm{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--font-brand);font-weight:600;font-size:23px;letter-spacing:.10em;color:var(--plum-2)}
.brand-tag{font-family:var(--font-body);font-weight:500;font-size:9px;letter-spacing:.30em;text-transform:uppercase;color:var(--muted);margin-top:5px;align-self:stretch;text-align:right}
.brand-tag:empty{display:none}
/* emblem "seal" — circular badge so the logo's cream background reads as intentional */
.emblem{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;background:var(--cream);box-shadow:var(--shadow);flex:0 0 auto}
.emblem img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.emblem-sm{width:62px;height:62px}
.emblem-md{width:96px;height:96px}
.hero-seal{position:absolute;top:16px;left:16px;z-index:3}
.foot-brand .brand{flex-direction:column;align-items:flex-start;gap:14px}
.login-emblem{display:flex;justify-content:center;margin-bottom:14px}
.login-card .brand{justify-content:center;text-align:center}
/* brand colours on dark admin sidebar + light login card */
.admin-side .brand-name{color:var(--cream)}
.login-card .brand-name{color:var(--plum-2)}
.foot-brand .brand-name{color:var(--cream)}
.nav-links{display:flex;gap:30px;list-style:none}
.nav-links a{font-size:14px;font-weight:500;color:var(--ink);position:relative;padding:6px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--gold);transition:width .25s ease}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-icons{display:flex;gap:18px;align-items:center;font-size:21px;color:var(--plum-2)}
.nav-icons a{display:flex;position:relative}
.cart-count{position:absolute;top:-7px;right:-10px;background:var(--rose);color:#fff;font-size:10.5px;font-weight:700;font-family:var(--font-body);min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.burger{display:none;font-size:24px;color:var(--plum-2)}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:14px;padding:13px 26px;border-radius:999px;transition:transform .15s ease,background .2s ease,box-shadow .2s ease}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--plum-2);color:var(--cream)}
.btn-primary:hover{background:var(--plum);box-shadow:var(--shadow)}
.btn-gold{background:var(--gold);color:var(--plum-2)}
.btn-gold:hover{background:var(--gold-2);color:#fff}
.btn-ghost{background:transparent;color:var(--plum-2);border:1.5px solid var(--plum-2)}
.btn-ghost:hover{background:var(--plum-2);color:var(--cream)}
.btn-wa{background:#1faa53;color:#fff}
.btn-wa:hover{background:#178a43}
.btn-block{width:100%;justify-content:center}
.eyebrow{font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.section{padding:84px 0}
.section-head{text-align:center;margin-bottom:46px}
.section-head h2{font-family:var(--font-display);font-weight:500;font-size:clamp(28px,4vw,44px);color:var(--plum-2);margin-top:10px;line-height:1.1}
.section-head p{color:var(--muted);margin-top:12px;font-size:16px}
.hero{position:relative;overflow:hidden;background:radial-gradient(1200px 500px at 80% -10%,#6e3350 0%,transparent 60%),linear-gradient(135deg,var(--plum-2) 0%,#2c1320 100%);color:var(--cream)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;min-height:560px;padding:70px 0}
.hero-copy .eyebrow{color:var(--gold)}
.hero-copy h1{font-family:var(--font-display);font-weight:500;font-size:clamp(40px,6vw,70px);line-height:1.02;margin:16px 0 18px;letter-spacing:-.01em}
.hero-copy h1 em{font-style:italic;color:var(--gold)}
.hero-copy p{font-size:17px;max-width:460px;color:#E7D6DE}
.hero-actions{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero-stats{display:flex;gap:34px;margin-top:44px}
.hero-stats div span{display:block;font-family:var(--font-display);font-size:26px;color:var(--gold)}
.hero-stats div small{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#C9B3BD}
.hero-art{position:relative;aspect-ratio:4/5;border-radius:26px;overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(193,154,91,.4)}
.hero-art img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;bottom:18px;left:18px;background:rgba(251,247,242,.94);color:var(--plum-2);border-radius:14px;padding:12px 16px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:9px}
.hero-badge i{color:var(--gold-2);font-size:18px}
.strip{background:var(--plum-2);color:var(--cream);overflow:hidden;isolation:isolate}
.strip-track{display:flex;gap:56px;white-space:nowrap;padding:16px 0;-webkit-animation:scroll 28s linear infinite;animation:scroll 28s linear infinite;width:max-content;will-change:transform}
.strip-track span{font-family:var(--font-display);font-size:17px;display:inline-flex;align-items:center;gap:56px}
.strip-track i{color:var(--gold);font-size:9px}
@-webkit-keyframes scroll{from{-webkit-transform:translateX(0)}to{-webkit-transform:translateX(-50%)}}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cat-card{position:relative;aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;display:flex;align-items:flex-end;box-shadow:var(--shadow)}
.cat-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.cat-card:hover img{transform:scale(1.06)}
.cat-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(36,16,25,.78),transparent 55%)}
.cat-card span{position:relative;z-index:2;color:#fff;padding:20px;font-family:var(--font-display);font-size:21px;width:100%;display:flex;justify-content:space-between;align-items:center}
.cat-card span i{font-size:18px;transition:transform .25s ease}
.cat-card:hover span i{transform:translateX(5px)}
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px 22px}
.card{background:var(--white);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card-media{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--cream-2)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card-media img{transform:scale(1.05)}
.tag{position:absolute;top:12px;left:12px;z-index:2;background:var(--gold);color:var(--plum-2);font-size:11px;font-weight:700;letter-spacing:.04em;padding:5px 11px;border-radius:999px;text-transform:uppercase}
.tag.sold{background:var(--ink);color:#fff}
.wish{position:absolute;top:10px;right:10px;z-index:2;width:34px;height:34px;border-radius:50%;background:rgba(251,247,242,.9);color:var(--plum-2);display:flex;align-items:center;justify-content:center;font-size:17px;transition:background .2s,color .2s}
.wish:hover{background:var(--rose);color:#fff}
.card-body{padding:15px 16px 18px;display:flex;flex-direction:column;gap:4px;flex:1}
.card-body .cat{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.card-body h3{font-family:var(--font-display);font-weight:500;font-size:18px;line-height:1.25}
.rating{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--muted)}
.rating i{color:var(--gold);font-size:13px}
.price-row{display:flex;align-items:center;gap:9px;margin-top:6px}
.price{font-weight:700;font-size:17px;color:var(--plum-2)}
.price-was{font-size:13px;color:var(--muted);text-decoration:line-through}
.price-off{font-size:12px;color:var(--rose);font-weight:700}
.card-add{margin-top:12px;width:100%;justify-content:center;background:var(--cream-2);color:var(--plum-2);font-weight:600;font-size:13.5px;padding:11px;border-radius:999px;display:inline-flex;align-items:center;gap:8px;transition:background .2s,color .2s}
.card-add:hover{background:var(--plum-2);color:var(--cream)}
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.features.features-2{grid-template-columns:repeat(2,1fr);max-width:820px;margin:0 auto}
.promo-band{margin:0 auto;max-width:var(--maxw);padding:0 24px}
.promo-band img{width:100%;height:auto;border-radius:var(--radius);box-shadow:var(--shadow)}
.feature{text-align:center;padding:26px 16px}
.feature i{font-size:28px;color:var(--gold-2)}
.feature h4{font-family:var(--font-display);font-weight:500;font-size:17px;margin:10px 0 4px;color:var(--plum-2)}
.feature p{font-size:13.5px;color:var(--muted)}
.story{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.story-art{aspect-ratio:5/4;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.story-art img{width:100%;height:100%;object-fit:cover}
.story h2{font-family:var(--font-display);font-weight:500;font-size:clamp(28px,3.6vw,40px);color:var(--plum-2);line-height:1.12;margin:12px 0 16px}
.story p{color:var(--ink);opacity:.82;margin-bottom:14px}
.news{background:linear-gradient(135deg,var(--plum-2),#2c1320);color:var(--cream);border-radius:26px;padding:56px;text-align:center}
.news h2{font-family:var(--font-display);font-weight:500;font-size:clamp(26px,3.4vw,38px)}
.news p{color:#E7D6DE;margin:10px auto 26px;max-width:460px}
.news-form{display:flex;gap:10px;max-width:440px;margin:0 auto}
.news-form input{flex:1;border:none;border-radius:999px;padding:14px 20px;font-family:inherit;font-size:14px;background:rgba(251,247,242,.12);color:#fff;outline:none;border:1px solid rgba(193,154,91,.5)}
.news-form input::placeholder{color:#C9B3BD}
.site-footer{background:var(--plum-2);color:#E7D6DE;padding:60px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
.foot-brand .brand{color:var(--cream)}
.foot-brand p{font-size:14px;margin:14px 0 18px;max-width:280px}
.foot-soc{display:flex;gap:12px;font-size:20px}
.foot-soc a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(193,154,91,.5);display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}
.foot-soc a:hover{background:var(--gold);color:var(--plum-2)}
.foot-col h5{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size:14px;opacity:.9}
.foot-col a:hover{color:var(--gold)}
.foot-bottom{border-top:1px solid rgba(193,154,91,.25);margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;font-size:12.5px;opacity:.8;flex-wrap:wrap;gap:8px}
.page-head{background:var(--cream-2);padding:44px 0;border-bottom:1px solid var(--line)}
.page-head h1{font-family:var(--font-display);font-weight:500;font-size:clamp(30px,4vw,46px);color:var(--plum-2)}
.crumbs{font-size:13px;color:var(--muted);margin-top:6px}
.crumbs a:hover{color:var(--gold-2)}
.shop-layout{padding:40px 0 80px}
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:8px}
.chip{font-size:13.5px;font-weight:600;padding:9px 18px;border-radius:999px;border:1.5px solid var(--line);color:var(--plum-2);background:var(--white);transition:all .2s ease}
.chip:hover{border-color:var(--gold)}
.chip.active{background:var(--plum-2);color:var(--cream);border-color:var(--plum-2)}
.shop-meta{display:flex;justify-content:space-between;align-items:center;margin:26px 0 22px;flex-wrap:wrap;gap:12px}
.shop-meta .count{font-size:14px;color:var(--muted)}
.shop-meta select{font-family:inherit;font-size:14px;padding:9px 14px;border-radius:999px;border:1.5px solid var(--line);background:var(--white);color:var(--plum-2)}
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:54px;padding:44px 0 80px}
.pdp-gallery{position:sticky;top:90px;align-self:start}
.pdp-main{aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:var(--cream-2)}
.pdp-main img{width:100%;height:100%;object-fit:cover}
.pdp-thumbs{display:flex;gap:12px;margin-top:14px}
.pdp-thumbs img{width:76px;height:96px;object-fit:cover;border-radius:10px;border:1.5px solid var(--line);cursor:pointer}
.pdp-thumbs img.active{border-color:var(--gold)}
.pdp-info .cat{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.pdp-info h1{font-family:var(--font-display);font-weight:500;font-size:clamp(28px,3.4vw,40px);color:var(--plum-2);line-height:1.1;margin:8px 0 12px}
.pdp-price{display:flex;align-items:center;gap:12px;margin:8px 0 18px}
.pdp-price .price{font-size:26px}
.pdp-desc{color:var(--ink);opacity:.82;margin-bottom:22px}
.opt-label{font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--plum-2);margin-bottom:10px}
.sizes{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.size{min-width:48px;padding:11px 14px;border-radius:12px;text-align:center;border:1.5px solid var(--line);font-weight:600;font-size:14px;color:var(--plum-2);background:#fff;transition:all .15s ease}
.size:hover{border-color:var(--gold)}
.size.active{background:var(--plum-2);color:var(--cream);border-color:var(--plum-2)}
.qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;overflow:hidden;margin-bottom:22px}
.qty button{width:42px;height:44px;font-size:20px;color:var(--plum-2)}
.qty span{width:44px;text-align:center;font-weight:700}
.pdp-actions{display:flex;gap:12px;flex-wrap:wrap}
.pdp-actions .btn{flex:1;min-width:180px}
.pdp-meta{margin-top:26px;border-top:1px solid var(--line);padding-top:20px;display:flex;flex-direction:column;gap:12px}
.pdp-meta div{display:flex;gap:10px;align-items:center;font-size:14px;color:var(--ink);opacity:.82}
.pdp-meta i{color:var(--gold-2);font-size:19px}
.cart-layout{display:grid;grid-template-columns:1.7fr 1fr;gap:40px;padding:44px 0 80px;align-items:start}
.cart-item{display:grid;grid-template-columns:96px 1fr auto;gap:18px;padding:18px 0;border-bottom:1px solid var(--line);align-items:center}
.cart-item img{width:96px;height:120px;object-fit:cover;border-radius:12px}
.cart-item h3{font-family:var(--font-display);font-weight:500;font-size:19px;color:var(--plum-2)}
.cart-item .meta{font-size:13px;color:var(--muted);margin:2px 0 8px}
.cart-item .line-price{font-weight:700;color:var(--plum-2)}
.ci-remove{font-size:13px;color:var(--rose);display:inline-flex;gap:5px;align-items:center;margin-top:8px}
.ci-qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px}
.ci-qty button{width:32px;height:34px;font-size:17px;color:var(--plum-2)}
.ci-qty span{width:34px;text-align:center;font-weight:700;font-size:14px}
.summary{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px;position:sticky;top:90px}
.summary h3{font-family:var(--font-display);font-weight:500;font-size:22px;color:var(--plum-2);margin-bottom:18px}
.sum-row{display:flex;justify-content:space-between;font-size:14.5px;margin-bottom:12px;color:var(--ink)}
.sum-row.total{border-top:1px solid var(--line);padding-top:14px;margin-top:6px;font-size:19px;font-weight:700;color:var(--plum-2)}
.sum-note{font-size:12.5px;color:var(--muted);margin:14px 0 18px;display:flex;gap:7px;align-items:flex-start}
.empty{text-align:center;padding:70px 20px}
.empty i{font-size:52px;color:var(--line)}
.empty h2{font-family:var(--font-display);font-weight:500;font-size:26px;color:var(--plum-2);margin:16px 0 8px}
.empty p{color:var(--muted);margin-bottom:22px}
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(120%);background:var(--plum-2);color:var(--cream);padding:14px 22px;border-radius:999px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:9px;box-shadow:var(--shadow);z-index:200;transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast i{color:var(--gold);font-size:18px}
@media(max-width:1000px){.product-grid,.cat-grid{grid-template-columns:repeat(3,1fr)}.features,.foot-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){.nav-links{display:none}.burger{display:block}.hero-grid,.story,.pdp,.cart-layout{grid-template-columns:1fr}.hero-art{max-width:420px;margin:0 auto}.pdp-gallery,.summary{position:static}.news{padding:40px 24px}}
@media(max-width:620px){.product-grid,.cat-grid{grid-template-columns:repeat(2,1fr);gap:16px}.foot-grid{grid-template-columns:1fr 1fr}.hero-stats{gap:22px}.section{padding:60px 0}.news-form{flex-direction:column}}

/* ============================================================
   ADMIN
   ============================================================ */
.admin-body{background:#F6F1EA}
.admin-shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.admin-side{background:var(--plum-2);color:#E7D6DE;padding:24px 18px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.admin-side .brand{color:var(--cream);margin-bottom:28px}
.admin-nav{display:flex;flex-direction:column;gap:4px;flex:1}
.admin-nav a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;font-size:14.5px;font-weight:500;color:#E7D6DE;transition:background .15s}
.admin-nav a i{font-size:20px}
.admin-nav a:hover{background:rgba(255,255,255,.07)}
.admin-nav a.active{background:var(--gold);color:var(--plum-2);font-weight:600}
.admin-side .side-foot{border-top:1px solid rgba(193,154,91,.25);padding-top:14px;font-size:12.5px}
.admin-side .side-foot a{color:#C9B3BD;display:flex;align-items:center;gap:8px;padding:8px 6px}
.admin-side .side-foot a:hover{color:var(--gold)}
.admin-main{padding:30px 34px}
.admin-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:26px;gap:16px;flex-wrap:wrap}
.admin-top h1{font-family:var(--font-display);font-weight:500;font-size:30px;color:var(--plum-2)}
.admin-top p{color:var(--muted);font-size:14px;margin-top:2px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px}
.kpi .lab{font-size:12.5px;color:var(--muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase;display:flex;align-items:center;gap:7px}
.kpi .lab i{color:var(--gold-2);font-size:17px}
.kpi .val{font-family:var(--font-display);font-size:30px;color:var(--plum-2);margin-top:8px}
.kpi .sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;margin-bottom:22px}
.panel h2{font-family:var(--font-display);font-weight:500;font-size:20px;color:var(--plum-2);margin-bottom:4px}
.panel .sub{color:var(--muted);font-size:13px;margin-bottom:16px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.atable{width:100%;border-collapse:collapse;font-size:14px}
.atable th{text-align:left;font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:600;padding:10px 12px;border-bottom:1px solid var(--line)}
.atable td{padding:12px;border-bottom:1px solid var(--line);vertical-align:middle}
.atable tr:last-child td{border-bottom:none}
.atable img{width:46px;height:58px;object-fit:cover;border-radius:8px;background:var(--cream-2)}
.ref{font-family:var(--font-mono,monospace);font-size:12.5px;font-weight:700;color:var(--gold-2);background:var(--cream-2);padding:3px 8px;border-radius:6px}
.pill{font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:999px;display:inline-block}
.pill-on{background:#E1F0E6;color:#1f7a45}
.pill-off{background:#F0E3E3;color:#9b3b3b}
.pill-low{background:#FBEEDA;color:#8a5a12}
.pill-new{background:#E6EEFB;color:#1d4f9c}
.pill-done{background:#E1F0E6;color:#1f7a45}
.pill-ship{background:#FBEEDA;color:#8a5a12}
.icon-btn{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);color:var(--plum-2);display:inline-flex;align-items:center;justify-content:center;font-size:17px;background:#fff;transition:all .15s}
.icon-btn:hover{background:var(--plum-2);color:#fff;border-color:var(--plum-2)}
.icon-btn.danger:hover{background:#9b3b3b;border-color:#9b3b3b}
.abtn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;padding:11px 20px;border-radius:10px;background:var(--plum-2);color:var(--cream);transition:background .2s}
.abtn:hover{background:var(--plum)}
.abtn.gold{background:var(--gold);color:var(--plum-2)}
.abtn.gold:hover{background:var(--gold-2);color:#fff}
.abtn.ghost{background:#fff;color:var(--plum-2);border:1.5px solid var(--line)}
.abtn.ghost:hover{border-color:var(--plum-2)}
.toolbar{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.toolbar input,.toolbar select{padding:10px 14px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:14px;background:#fff}
.toolbar input{min-width:240px}
.spacer{flex:1}
/* admin login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--plum-2),#2c1320);padding:24px}
.login-card{background:#fff;border-radius:20px;padding:40px;width:100%;max-width:400px;box-shadow:0 30px 60px -30px rgba(0,0,0,.5)}
.login-card .brand{color:var(--plum-2);margin-bottom:6px}
.login-card h1{font-family:var(--font-display);font-weight:500;font-size:24px;color:var(--plum-2);margin:14px 0 4px}
.login-card p.sub{color:var(--muted);font-size:14px;margin-bottom:24px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--plum-2);margin-bottom:7px}
.field input{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:15px}
.field input:focus{outline:none;border-color:var(--gold)}
.login-err{background:#F0E3E3;color:#9b3b3b;font-size:13.5px;font-weight:500;padding:11px 14px;border-radius:10px;margin-bottom:16px;display:none}
.login-hint{font-size:12.5px;color:var(--muted);text-align:center;margin-top:18px;line-height:1.6}
/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(36,16,25,.55);display:none;align-items:flex-start;justify-content:center;padding:40px 20px;z-index:300;overflow-y:auto}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:18px;padding:28px;width:100%;max-width:560px}
.modal h2{font-family:var(--font-display);font-weight:500;font-size:22px;color:var(--plum-2);margin-bottom:18px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1/-1}
.modal label{display:block;font-size:12.5px;font-weight:600;color:var(--plum-2);margin-bottom:6px}
.modal input,.modal select,.modal textarea{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:14px}
.modal textarea{resize:vertical}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}
.img-drop{border:1.5px dashed var(--line);border-radius:12px;padding:14px;display:flex;align-items:center;gap:14px}
.img-drop img{width:60px;height:76px;object-fit:cover;border-radius:8px;background:var(--cream-2)}
.empty-row{text-align:center;color:var(--muted);padding:40px}
@media(max-width:900px){
  .admin-shell{grid-template-columns:1fr}
  .admin-side{position:static;height:auto;flex-direction:row;align-items:center;gap:10px;flex-wrap:wrap}
  .admin-side .brand{margin:0 16px 0 0}
  .admin-nav{flex-direction:row;flex-wrap:wrap}
  .admin-side .side-foot{border:none;padding:0}
  .kpis{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
}

/* mobile dropdown menu (hamburger) */
@media(max-width:860px){
  .site-header .nav{position:relative}
  .nav-links.open{display:flex;flex-direction:column;gap:0;position:absolute;top:64p