:root{ --bg:#0f172a; --panel:#111827; --card:#0b1220; --muted:#94a3b8; --txt:#e5e7eb; --primary:#22c55e; --danger:#f43f5e; --border:#1f2937; }
*{box-sizing:border-box} body{ margin:0; font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,'Helvetica Neue',Arial; background: radial-gradient(1200px 600px at 10% -20%, #1f2937, transparent), var(--bg); color:var(--txt); }
.container{ max-width:1100px; margin:0 auto; padding:16px; } .header,.footer{ display:flex; align-items:center; justify-content:space-between; gap:16px; }
.header{ border-bottom:1px solid var(--border);} .footer{ border-top:1px solid var(--border); color:var(--muted);}
.brand{ display:flex; align-items:center; gap:10px;} .brand img.logo{ height:48px; width:auto; border-radius:8px;}
.nav .nav-btn, .nav a.nav-btn{ background:transparent; border:1px solid var(--border); color:var(--txt); padding:8px 12px; border-radius:12px; cursor:pointer; margin-left:8px; text-decoration:none;}
.nav .nav-btn.active{ border-color:var(--primary);} .view.hidden{ display:none;}
.toolbar{ display:flex; gap:10px; align-items:center; margin:10px 0 16px;} .toolbar .spacer{ flex:1;}
input[type='search'],input[type='text'],input[type='number'],input[type='email'],textarea,select,input:not([type]){ width:100%; padding:10px 12px; border-radius:12px; border:1px solid var(--border); background:var(--card); color:var(--txt);} textarea{ min-height:88px;}
#catalog{ display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:16px;} .card{ border:1px solid var(--border); background:linear-gradient(transparent, rgba(255,255,255,0.02)); border-radius:16px; padding:12px; display:flex; flex-direction:column; gap:10px;}
.card .thumb{ height:160px; background:var(--card); border:1px dashed var(--border); border-radius:12px; background-size:cover; background-position:center;} .card h4{ margin:0; font-size:18px;} .price{ font-weight:700;} .badge{ display:inline-flex; gap:6px; font-size:12px; color:var(--muted);}
.qty-input{ display:flex; align-items:center; gap:6px;} .qty-input input{ width:72px; text-align:center;} .actions{ display:flex; gap:10px; align-items:center; flex-wrap:wrap;}
.primary{ background:var(--primary); border:none; color:#052e13; font-weight:700; padding:10px 14px; border-radius:12px; cursor:pointer;} .outline{ border:1px solid var(--border); background:transparent; color:var(--txt); padding:10px 14px; border-radius:12px; cursor:pointer;}
.muted{ color:var(--muted);} .danger{ background:var(--danger); color:white; border:none;} .success{ border:1px solid #14532d; background:#052e13; color:#a7f3d0; padding:12px; border-radius:12px;}
.grid{ display:grid; gap:12px;} .grid.two{ grid-template-columns:1fr 1fr;} @media (max-width:900px){ .grid.two{ grid-template-columns:1fr; } }
.table{ width:100%; border-collapse:collapse;} .table th,.table td{ text-align:left; padding:8px 6px; border-bottom:1px solid var(--border);} .table button{ padding:6px 10px;}
.summary{ border:1px solid var(--border); border-radius:12px; padding:10px; max-width:420px; margin:10px 0 20px;} .total-line{ display:flex; align-items:center; justify-content:space-between; margin:6px 0;} .total-line.grand{ font-size:18px; font-weight:800;}
.checkout-form .grid{ grid-template-columns:1fr 1fr;} @media (max-width:700px){ .checkout-form .grid{ grid-template-columns:1fr; } }
.hint{ color:var(--muted); font-size:12px;} .hidden{ display:none; }
/* --- Category chips --- */
.chips { display: flex; gap: 8px; flex-wrap: wrap; }
.chip {
  padding: 6px 10px; border: 1px solid var(--border); border-radius: 999px;
  background: rgba(255,255,255,0.02); color: var(--txt); cursor: pointer;
  font-size: 13px;
}
.chip.active { border-color: var(--primary); background: rgba(34,197,94,0.12); }

/* --- View toggle + catalog modes --- */
.view-toggle .nav-btn { padding: 8px 10px; border-radius: 10px; }
#catalog.catalog.grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(240px,1fr)); gap: 16px; }
#catalog.catalog.list { display: grid; grid-template-columns: 1fr; gap: 12px; }
.card.product { transition: transform .15s ease, box-shadow .15s ease; }
.card.product:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,0.25); }
.card.product .thumb { cursor: zoom-in; }
.row { display: grid; grid-template-columns: 140px 1fr auto; gap: 14px; align-items: center; }
.row .thumb { height: 90px; border-radius: 10px; }

/* --- Add to cart interactions --- */
#cart-count.pop { animation: bump .35s ease; }
@keyframes bump { 0%{transform:scale(1)} 20%{transform:scale(1.25)} 100%{transform:scale(1)} }
.toast-show { animation: fadein .2s ease, fadeout .2s ease 2.4s forwards; }
@keyframes fadein { from{opacity:.0; transform:translateY(6px)} to{opacity:1; transform:none} }
@keyframes fadeout { to{opacity:0; transform:translateY(6px)} }
#toast { position: fixed; bottom: 96px; right: 24px; max-width: 320px; z-index: 60; }
.toast { background: #0b1220; border:1px solid var(--border); padding: 10px 12px; border-radius: 12px; margin-top: 8px; }

/* --- Floating checkout button --- */
.fab {
  position: fixed; right: 22px; bottom: 22px; z-index: 50;
  border-radius: 999px; padding: 12px 16px; border: none; cursor: pointer;
  font-weight: 700; background: var(--primary); color: #052e13; box-shadow: 0 12px 24px rgba(0,0,0,0.35);
}
.fab.hidden { display: none; }

/* --- Lightbox --- */
.lightbox { position: fixed; inset: 0; background: rgba(0,0,0,0.75);
  display: flex; align-items: center; justify-content: center; z-index: 70; }
.lightbox.hidden { display: none; }
.lightbox img { max-width: 92vw; max-height: 88vh; border-radius: 12px; }
.lightbox-close {
  position: absolute; top: 16px; right: 22px; font-size: 26px;
  background: transparent; border: 1px solid var(--border);
  color: var(--txt); border-radius: 10px; padding: 4px 10px; cursor: pointer;
}

/* --- List card buttons --- */
.actions .btn-qty { display: inline-flex; align-items:center; gap:8px; }
.actions .btn-qty input { width: 72px; text-align:center; }
/* --- Compact view --- */
#catalog.catalog.compact { 
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; 
}
.card.product.compact .thumb { height: 110px; border-radius: 10px; }
.card.product.compact h4 { font-size: 15px; }

/* --- Mini-cart drawer --- */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 79; }
.overlay.hidden { display: none; }
.drawer {
  position: fixed; top: 0; right: 0; height: 100vh; width: 360px; max-width: 92vw;
  background: var(--panel); border-left: 1px solid var(--border);
  transform: translateX(100%); transition: transform .25s ease; z-index: 80; padding: 12px; overflow: auto;
  box-shadow: -12px 0 24px rgba(0,0,0,0.35);
}
.drawer.open { transform: translateX(0); }
.drawer-head { display: flex; align-items:center; justify-content: space-between; margin-bottom: 10px; }
.mini-item { display: grid; grid-template-columns: 56px 1fr auto; gap: 10px; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--border); }
.mini-item .thumb { height: 56px; border-radius: 8px; background-size: cover; background-position: center; }
.mini-title { font-size: 14px; margin: 0 0 2px 0; }
.mini-meta { font-size: 12px; color: var(--muted); }
.mini-actions { display: flex; align-items: center; gap: 6px; }
.mini-actions input { width: 56px; text-align: center; }
/* icon-only view buttons */
#view-grid, #view-list, #view-compact { width:40px; height:40px; display:inline-grid; place-items:center; padding:0; }

/* Beautiful gradient category chips */
.chips { display:flex; gap:8px; flex-wrap:wrap; }
.chip { position:relative; padding:8px 12px 8px 10px; border:1px solid var(--border); border-radius:999px; cursor:pointer; }
.chip::before { content: attr(data-icon); margin-right:6px; }
.chip.active { border-color: var(--primary); box-shadow: 0 0 0 2px rgba(34,197,94,.18) inset; }
.tone-0{ background:linear-gradient(90deg,#0b1220,rgba(255,255,255,0.03)); }
.tone-1{ background:linear-gradient(90deg,#121a2b,rgba(255,255,255,0.03)); }
.tone-2{ background:linear-gradient(90deg,#0e1b2f,rgba(255,255,255,0.03)); }
.tone-3{ background:linear-gradient(90deg,#132032,rgba(255,255,255,0.03)); }
.tone-4{ background:linear-gradient(90deg,#0e1a28,rgba(255,255,255,0.03)); }
.tone-5{ background:linear-gradient(90deg,#101c2d,rgba(255,255,255,0.03)); }

/* Disabled state for Place Order */
#place-order-btn[disabled]{ opacity:.6; cursor:not-allowed; }
.fab.disabled,
#mini-checkout:disabled,
#place-order-btn[disabled] {
  opacity: .6;
  cursor: not-allowed;
}
/* Cart layout & items */
.cart-layout{display:grid;grid-template-columns:2fr 1fr;gap:20px}
@media(max-width:900px){.cart-layout{grid-template-columns:1fr}}
.cart-item{display:grid;grid-template-columns:96px 1fr auto;gap:12px;align-items:center;border-bottom:1px solid var(--border);padding:12px 0}
.cart-item .thumb{height:96px;border-radius:12px;background-size:cover;background-position:center}

/* Quantity stepper */
.stepper{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.stepper button{background:transparent;border:none;padding:8px 10px;color:var(--txt);cursor:pointer}
.stepper input{width:56px;text-align:center;border-left:1px solid var(--border);border-right:1px solid var(--border);background:var(--card);color:var(--txt);outline:none}

/* Summary */
.summary-card{position:sticky;top:12px}
.progress{height:10px;background:#111a2c;border:1px solid var(--border);border-radius:999px;overflow:hidden;margin:8px 0}
.progress .bar{height:100%;background:var(--primary);width:0%}
.min-msg{font-size:12px;color:var(--muted)}
.remove-btn{border:1px solid var(--border);background:transparent;border-radius:12px;padding:8px 10px}

/* Disabled look */
.fab.disabled,#mini-checkout:disabled,#place-order-btn[disabled]{opacity:.6;cursor:not-allowed}
/* Lightbox (robust) */
.lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:70}
.lightbox.hidden{display:none}
.lb-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.75)}
.lb-content{position:relative;z-index:1;max-width:92vw;max-height:88vh;display:flex;flex-direction:column;align-items:center}
.lb-content img{max-width:92vw;max-height:80vh;border-radius:12px}
.lightbox-close{position:absolute;top:-14px;right:-14px;font-size:26px;background:transparent;border:1px solid var(--border);color:var(--txt);border-radius:10px;padding:4px 10px;cursor:pointer}
body.modal-open{overflow:hidden}
/* Nicer product hover */
.card.product{transition:transform .15s ease, box-shadow .15s ease}
.card.product:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.28)}
#products-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px }
#products-grid.as-list{ grid-template-columns:1fr }
#products-grid.as-compact .shop-card{ display:flex; align-items:center }
.shop-card{ background:#0f172a;border:1px solid #1f2937;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 30px rgba(0,0,0,.35) }
.shop-card.list{ flex-direction:row; }
.shop-card .thumb-wrap{ position:relative; flex:0 0 220px }
.shop-card.list .thumb-wrap{ flex:0 0 200px }
.shop-card .thumb{ width:100%; object-fit:fill; background:#020617 }
.icon.quick-add{ position:absolute;right:10px;bottom:10px;border:none;cursor:pointer;width:36px;height:36px;border-radius:999px;background:#22c55e;color:#051007;font-weight:800;box-shadow:0 6px 16px rgba(0,0,0,.35) }
.shop-card .meta{ padding:10px 12px; flex:1 }
.shop-card .title{ font-weight:700;margin-bottom:4px }
.shop-card .sub{ display:flex;justify-content:space-between;color:#cbd5e1;font-size:12px }
.stepper{ display:flex;gap:8px;margin-top:10px;align-items:center }
.stepper .qty-dec,.stepper .qty-inc,.stepper .add-btn{
  border:1px solid #1f2937;background:#0b1326;color:#e5e7eb;border-radius:10px;padding:8px 10px;cursor:pointer
}
.stepper .add-btn{ background:#22c55e;color:#051007;border-color:transparent;font-weight:700 }
.stepper .qty-input{ width:64px;text-align:center;border:1px solid #1f2937;background:#0b1326;color:#e5e7eb;border-radius:10px }
.chip{ border:1px solid #1f2937;background:#0b1326;color:#cbd5e1;border-radius:999px;padding:6px 10px;cursor:pointer }
.chip.active{ background:#22c55e;color:#051007;border-color:transparent;font-weight:700 }
.empty{ color:#94a3b8;text-align:center;padding:24px }
/* ---- Layout: sidebar (chips) + content (grid) ---- */
#shop-layout{ display:grid; grid-template-columns: 260px 1fr; gap:18px; align-items:start; }
@media (max-width: 960px){ #shop-layout{ grid-template-columns: 1fr; } }

/* Sidebar stacks nicely */
#category-chips{ display:flex; flex-direction:column; gap:10px; position:sticky; top:84px; }

/* Controls row (views + search) lines up */
.shop-controls{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

/* ---- Products grid + view variations ---- */
#products-grid{ display:grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap:14px; }
#products-grid.as-list{ grid-template-columns: 1fr; }
#products-grid.as-compact{ grid-template-columns: 1fr; }

/* Card base */
.shop-card{ background:#0f172a; border:1px solid #1f2937; border-radius:16px; overflow:hidden; display:flex; flex-direction:column; box-shadow:0 10px 30px rgba(0,0,0,.35); }
.shop-card .thumb-wrap{ position:relative; }
.shop-card .thumb{ width:100%; object-fit:fill; background:#020617; }
.shop-card .meta{ padding:10px 12px; }
.shop-card .title{ font-weight:700; margin-bottom:4px; }
.shop-card .sub{ display:flex; justify-content:space-between; color:#cbd5e1; font-size:12px; }
.stepper{ display:flex; gap:8px; margin-top:10px; align-items:center; }
.stepper .qty-dec,.stepper .qty-inc,.stepper .add-btn{ border:1px solid #1f2937; background:#0b1326; color:#e5e7eb; border-radius:10px; padding:8px 10px; cursor:pointer; }
.stepper .add-btn{ background:#22c55e; color:#051007; border-color:transparent; font-weight:700; }
.stepper .qty-input{ width:64px; text-align:center; border:1px solid #1f2937; background:#0b1326; color:#e5e7eb; border-radius:10px; }

/* Quick-add bubble */
.icon.quick-add{ position:absolute; right:10px; bottom:10px; border:none; width:36px; height:36px; border-radius:999px; background:#22c55e; color:#051007; font-weight:800; box-shadow:0 6px 16px rgba(0,0,0,.35); cursor:pointer; }

/* ---- LIST view ---- */
#products-grid.as-list .shop-card{ flex-direction:row; }
#products-grid.as-list .thumb-wrap{ flex:0 0 220px; }
#products-grid.as-list .thumb{ height:100%; aspect-ratio:auto; }

/* ---- COMPACT view ---- */
#products-grid.as-compact .shop-card{ flex-direction:row; align-items:center; }
#products-grid.as-compact .thumb-wrap{ flex:0 0 120px; }
#products-grid.as-compact .thumb{ height:100%; aspect-ratio:auto; }
#products-grid.as-compact .stepper{ margin-top:0; }
#shop-layout{ display:grid; grid-template-columns: 260px 1fr; gap:18px; align-items:start; }
@media (max-width: 960px){ #shop-layout{ grid-template-columns: 1fr; } }

#category-chips{ display:flex; flex-direction:column; gap:10px; position:sticky; top:84px; }
.shop-controls{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

#products-grid{ display:grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap:14px; }
#products-grid.as-list{ grid-template-columns: 1fr; }
#products-grid.as-compact{ grid-template-columns: 1fr; }

.shop-card{ background:#0f172a; border:1px solid #1f2937; border-radius:16px; overflow:hidden; display:flex; flex-direction:column; box-shadow:0 10px 30px rgba(0,0,0,.35) }
.shop-card .thumb-wrap{ position:relative }
.shop-card .thumb{ width:100%;  object-fit:fill; background:#020617 }
.shop-card .meta{ padding:10px 12px }
.shop-card .title{ font-weight:700; margin-bottom:4px }
.shop-card .sub{ display:flex; justify-content:space-between; color:#cbd5e1; font-size:12px }
.stepper{ display:flex; gap:8px; margin-top:10px; align-items:center }
.stepper .qty-dec,.stepper .qty-inc,.stepper .add-btn{
  border:1px solid #1f2937; background:#0b1326; color:#e5e7eb; border-radius:10px; padding:8px 10px; cursor:pointer;
}
.stepper .add-btn{ background:#22c55e; color:#051007; border-color:transparent; font-weight:700 }
.stepper .qty-input{ width:64px; text-align:center; border:1px solid #1f2937; background:#0b1326; color:#e5e7eb; border-radius:10px }

.icon.quick-add{ position:absolute; right:10px; bottom:10px; width:36px; height:36px; border-radius:999px; background:#22c55e; color:#051007; font-weight:800; border:0; cursor:pointer; box-shadow:0 6px 16px rgba(0,0,0,.35) }

#products-grid.as-list .shop-card{ flex-direction:row }
#products-grid.as-list .thumb-wrap{ flex:0 0 220px }
#products-grid.as-list .thumb{ height:100%; aspect-ratio:auto }

#products-grid.as-compact .shop-card{ flex-direction:row; align-items:center }
#products-grid.as-compact .thumb-wrap{ flex:0 0 120px }
#products-grid.as-compact .thumb{ height:100%; aspect-ratio:auto }
#products-grid.as-compact .stepper{ margin-top:0 }
/* Banner */
.notice{display:inline-flex;gap:8px;align-items:center;background:#0f1c32;border:1px solid #1e2b45;
  color:#cfe3ff;padding:8px 12px;border-radius:10px;margin:10px 0; width:100%}
.notice .dot{width:8px;height:8px;border-radius:999px;background:#22c55e;display:inline-block;}

/* Modal shell */
#cart-modal{width:min(860px,92vw);border:none;border-radius:18px;padding:0;background:#0b1326;color:#e5e7eb}
#cart-modal::backdrop{background:rgba(0,0,0,.55)}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid #1f2937}
.cart-head h2{margin:0;font:700 22px/1.1 system-ui}
.icon-close{width:36px;height:36px;border-radius:12px;border:1px solid #1f2937;background:#0b1326;color:#e5e7eb}

/* Body + items */
.cart-body{padding:14px 18px;max-height:70vh;overflow:auto}
.cart-items .cart-row{display:grid;grid-template-columns:1fr auto auto auto;gap:12px;align-items:center;
  padding:12px;border-bottom:1px dashed #1e293b;border-radius:12px}
.cart-row .info .t{font-weight:700}
.cart-row .m{color:#cbd5e1;font-size:12px}

/* Summary */
.cart-summary{margin-top:14px;background:#0f1c32;border:1px solid #1e293b;border-radius:14px;padding:14px;display:grid;gap:8px}
.cart-summary .label{font-weight:700}
.cart-summary .sub-hint{font-size:12px;color:#9fb6d9}
.cart-summary .right{justify-self:end;font-weight:800}
.cart-summary .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}
button.primary{background:#22c55e;border:none;color:#051207;font-weight:800;border-radius:12px;padding:10px 14px}
button.outline{background:#0b1326;border:1px solid #1f2937;color:#e5e7eb;border-radius:12px;padding:10px 14px}
button[disabled]{opacity:.6;cursor:not-allowed}

/* Checkout form */
.checkout-form{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.checkout-form .field{display:flex;flex-direction:column;gap:6px}
.checkout-form .field label{font-size:12px;color:#9fb6d9}
.checkout-form input,.checkout-form textarea{background:#0b1326;border:1px solid #1f2937;color:#e5e7eb;border-radius:12px;padding:10px 12px}
.checkout-form .full{grid-column:1 / -1}
.checkout-form .form-actions{grid-column:1 / -1;display:flex;justify-content:flex-end}

/* “Checkout mode” (hide long item list when user proceeds) */
#cart-modal.checkout-mode .cart-items{display:none}

/* Tiny shake when min order not met */
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
.shake{animation:shake .45s}
/* ----- Cart / Checkout polish ----- */
#cart-modal{width:min(900px,94vw);border:none;border-radius:18px;padding:0;background:#0b1326;color:#e5e7eb}
#cart-modal::backdrop{background:rgba(0,0,0,.55)}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid #1e293b}
.cart-head h2{margin:0;font:800 24px/1.1 system-ui, -apple-system, Segoe UI, Roboto}

.icon-close{width:36px;height:36px;border-radius:12px;border:1px solid #1f2937;background:#0b1326;color:#e5e7eb}
.cart-body{padding:14px 18px;max-height:68vh;overflow:auto}

/* list */
.cart-items{display:flex;flex-direction:column;gap:12px}
.cart-row{display:grid;grid-template-columns:64px 1fr auto;gap:12px;align-items:center;
  background:#0f1c32;border:1px solid #1e2b45;border-radius:14px;padding:10px 12px}
.cart-thumb{width:64px;height:64px;object-fit:cover;border-radius:10px;background:#030711}
.cart-info .title{font-weight:800;margin:0 0 2px}
.cart-info .meta{font-size:12px;color:#9fb6d9}

/* stepper */
.stepper{display:inline-flex;gap:8px;align-items:center;margin-top:6px}
.stepper .btn{width:30px;height:30px;border-radius:10px;border:1px solid #21304a;background:#0b1326;color:#e5e7eb}
.stepper .qty{width:56px;text-align:center;border:1px solid #21304a;background:#0b1326;color:#e5e7eb;border-radius:10px;padding:6px 8px}

/* right column: line total + remove */
.cart-right{display:flex;flex-direction:column;align-items:end;gap:6px}
.cart-right .line{font-weight:800}
.remove-btn{width:30px;height:30px;border-radius:10px;border:1px solid #21304a;background:#0b1326;color:#e5e7eb}

/* summary */
.cart-summary{position:sticky;bottom:0;margin-top:12px;background:#0f1c32;border:1px solid #1e293b;border-radius:14px;padding:14px;display:grid;grid-template-columns:1fr auto;gap:10px}
.cart-summary .label{font-weight:800}
.cart-summary .sub-hint{font-size:12px;color:#9fb6d9}
.cart-summary .right{font-weight:900;justify-self:end}
.cart-summary .actions{grid-column:1/-1;display:flex;justify-content:flex-end;gap:10px;margin-top:4px}

button.primary{background:#22c55e;color:#051207;border:none;border-radius:12px;padding:10px 14px;font-weight:800}
button.outline{background:#0b1326;color:#e5e7eb;border:1px solid #1e293b;border-radius:12px;padding:10px 14px}
button[disabled]{opacity:.6;cursor:not-allowed}

/* checkout form */
.checkout-form{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.checkout-form .field{display:flex;flex-direction:column;gap:6px}
.checkout-form .field label{font-size:12px;color:#9fb6d9}
.checkout-form input,.checkout-form textarea{background:#0b1326;border:1px solid #1e293b;color:#e5e7eb;border-radius:12px;padding:10px 12px}
.checkout-form .full{grid-column:1/-1}
.checkout-form .form-actions{grid-column:1/-1;display:flex;justify-content:flex-end}

/* hints + min order */
.hint{color:#9fb6d9;margin:6px 0 0}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
.shake{animation:shake .45s}

/* compact inputs inside dialog on mobile */
@media (max-width:640px){
  .cart-row{grid-template-columns:56px 1fr auto}
  .checkout-form{grid-template-columns:1fr}
}
.shop-toast {
  position: fixed;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%) scale(0.9);
  background: #1976d2;
  color: #fff;
  padding: 1em 2em;
  border-radius: 2em;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  display: flex;
  align-items: center;
  gap: 0.75em;
  font-size: 1.1em;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s, transform 0.3s;
  z-index: 9999;
}
.shop-toast.show {
  opacity: 1;
  transform: translateX(-50%) scale(1);
  pointer-events: auto;
}
.toast-icon {
  font-size: 1.5em;
  animation: bounce 0.6s;
}
@keyframes bounce {
  0%   { transform: scale(1); }
  30%  { transform: scale(1.3); }
  60%  { transform: scale(0.9); }
  100% { transform: scale(1); }
}
/* Responsive Toast */
.shop-toast {
  position: fixed;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%) scale(0.95);
  background: #1976d2;
  color: #fff;
  padding: 0.75em 1.5em;
  border-radius: 2em;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  display: flex;
  align-items: center;
  gap: 0.75em;
  font-size: 1em;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s, transform 0.3s;
  z-index: 9999;
  max-width: 90vw;
  word-break: break-word;
}
.shop-toast.show {
  opacity: 1;
  transform: translateX(-50%) scale(1);
  pointer-events: auto;
}
.toast-icon {
  font-size: 1.5em;
  animation: bounce 0.6s;
}
@keyframes bounce {
  0%   { transform: scale(1); }
  30%  { transform: scale(1.3); }
  60%  { transform: scale(0.9); }
  100% { transform: scale(1); }
}

/* Cart Modal Responsive */
#cart-modal {
  max-width: 420px;
  width: 96vw;
  margin: 0 auto;
  border-radius: 16px;
  padding: 0;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18);
  background: var(--bg);
}
@media (max-width: 600px) {
  #cart-modal {
    max-width: 100vw;
    width: 100vw;
    border-radius: 0;
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    overflow-y: auto;
    margin: 0;
    padding: 0;
  }
  .shop-toast {
    font-size: 0.95em;
    padding: 0.7em 1em;
    bottom: 8px;
    max-width: 98vw;
  }
  .cart-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .cart-info, .cart-right {
    width: 100%;
    text-align: left;
  }
}

/* Cart Items */
.cart-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid #eee;
}
.cart-thumb {
  width: 48px;
  height: 48px;
  object-fit: cover;
  border-radius: 8px;
  background: #f3f4f6;
}
.cart-info {
  flex: 1;
  min-width: 0;
}
.cart-right {
  text-align: right;
  min-width: 70px;
}
.stepper {
  display: flex;
  align-items: center;
  gap: 4px;
}
.stepper .btn, .stepper .qty {
  font-size: 1em;
  padding: 4px 8px;
  border-radius: 6px;
  border: 1px solid #ddd;
}
.stepper .qty {
  width: 48px;
  text-align: center;
}

/* Buttons */
button, .btn {
  font-size: 1em;
  padding: 8px 16px;
  border-radius: 8px;
  border: none;
  background: #1976d2;
  color: #fff;
  cursor: pointer;
  transition: background 0.2s;
}
button:active, .btn:active {
  background: #115293;
}
button[disabled], .btn[disabled] {
  background: #bdbdbd;
  cursor: not-allowed;
}

/* Inputs */
input, textarea {
  font-size: 1em;
  padding: 8px;
  border-radius: 6px;
  border: 1px solid #ddd;
  width: 100%;
  box-sizing: border-box;
}

/* Hide scrollbars on mobile modal */
#cart-modal::-webkit-scrollbar {
  display: none;
}
#cart-modal {
  -ms-overflow-style: none;
  scrollbar-width: none;
}


/* Responsive Product Grid */
#products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
  padding: 12px;
}
@media (max-width: 600px) {
  #products-grid {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 6px;
  }
}

/* Responsive Product Card */
.shop-card {
  background: var(--border);
  border-radius: 14px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.07);
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
  transition: box-shadow 0.2s;
}
.shop-card.list, .shop-card.compact {
  flex-direction: row;
  align-items: center;
  gap: 12px;
}
@media (max-width: 600px) {
  .shop-card {
    padding: 10px;
    border-radius: 8px;
    font-size: 0.98em;
  }
  .shop-card.list, .shop-card.compact {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
}

/* Product Image */
.thumb-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
}
.thumb {
  width: 100%;
  object-fit: fill;
  border-radius: 10px;
  background: var(--bg);
  transition: box-shadow 0.2s;
}
@media (max-width: 600px) {
  .thumb {
  
    border-radius: 8px;
  }
}

/* Loader */
.loader {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 180px;
  font-size: 1.1em;
  color: #1976d2;
}
@media (max-width: 600px) {
  .loader {
    min-height: 120px;
    font-size: 1em;
  }
}

/* Category Chips */
#category-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.chip {
  background: var(--border);
  border: none;
  border-radius: 16px;
  padding: 6px 16px;
  font-size: 1em;
  cursor: pointer;
  transition: background 0.2s;
}
.chip.active {
  background: #1976d2;
  color: #fff;
}
@media (max-width: 600px) {
  .chip {
    padding: 5px 10px;
    font-size: 0.95em;
  }
}

/* Search Input */
#product-search {
  width: 100%;
  max-width: 320px;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid #ddd;
  margin-bottom: 14px;
  font-size: 1em;
}
@media (max-width: 600px) {
  #product-search {
    max-width: 100%;
    font-size: 0.98em;
    padding: 7px 10px;
  }
}

/* Stepper and Buttons */
.stepper {
  display: flex;
  align-items: center;
  gap: 4px;
}
.qty-input {
  width: 48px;
  text-align: center;
  font-size: 1em;
  border-radius: 6px;
  border: 1px solid #ddd;
  padding: 4px;
}
button, .icon, .add-btn {
  font-size: 1em;
  padding: 7px 14px;
  border-radius: 8px;
  border: none;
  background: #1976d2;
  color: #fff;
  cursor: pointer;
  transition: background 0.2s;
}
button:active, .icon:active, .add-btn:active {
  background: #115293;
}
@media (max-width: 600px) {
  .qty-input {
    width: 38px;
    font-size: 0.95em;
  }
  button, .icon, .add-btn {
    font-size: 0.95em;
    padding: 6px 10px;
    border-radius: 7px;
  }
}

/* Modal Image Preview */
#img-modal {
  max-width: 420px;
  width: 96vw;
  margin: 0 auto;
  border-radius: 16px;
  padding: 0;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18);
  background: #fff;
}
@media (max-width: 600px) {
  #img-modal {
    max-width: 100vw;
    width: 100vw;
    border-radius: 0;
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    min-height: 100vh;
    margin: 0;
    padding: 0;
  }
}

/* Empty State */
.empty {
  text-align: center;
  color: #888;
  padding: 40px 0;
  font-size: 1.1em;
}
@media (max-width: 600px) {
  .empty {
    padding: 24px 0;
    font-size: 1em;
  }
}

/* List view: horizontal on desktop, vertical on mobile */
.shop-card.list {
  display: flex;
    flex-direction: column !important;
  align-items: center;
  gap: 12px;
}
@media (max-width: 600px) {
  .shop-card.list {
    flex-direction: column !important;
    align-items: flex-start;
    gap: 8px;
    width: 100%;
  }
  .shop-card.list .thumb-wrap {
    margin-bottom: 6px;
  }
  .shop-card.list .meta {
    width: 100%;
  }
}
/* List view: horizontal on desktop, vertical on mobile */
#img-modal {
  max-width: 420px;
  width: 96vw;
  margin: 0 auto;
  border-radius: 16px;
  padding: 0;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18);
  background: var(--bg);
  display: flex;
  flex-direction: column;
  align-items: center;
}
#img-preview {
  max-width: 100%;
  max-height: 70vh;
  border-radius: 12px;
  margin: 24px 0;
  box-shadow: 0 2px 16px rgba(0,0,0,0.12);
}
@media (max-width: 600px) {
  #img-modal {
    max-width: 100vw;
    width: 100vw;
    border-radius: 0;
    min-height: 100vh;
    margin: 0;
    padding: 0;
  }
  #img-preview {
    max-width: 96vw;
    max-height: 60vh;
    margin: 16px 0;
  }
}
.shop-toast {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  background: #1976d2;
  color: #fff;
  padding: 1em 2em;
  border-radius: 2em;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  display: flex;
  align-items: center;
  gap: 0.75em;
  font-size: 1.1em;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s, transform 0.3s;
  z-index: 9999; /* Ensure it's above all modals/dialogs */
  max-width: 90vw;
  word-break: break-word;
}
.shop-toast.show {
  opacity: 1;
  transform: translateX(-50%) scale(1.05);
  pointer-events: auto;
}

/* Cart Modal */
#cart-modal {
  max-width: 420px;
  width: 96vw;
  margin: 0 auto;
  border-radius: 18px;
  padding: 0;
  box-shadow: 0 8px 32px rgba(25, 118, 210, 0.18);
  background: var(--panel);
  border: none;
  overflow: hidden;
  z-index: 9000; /* Lower than toast */
  animation: modalIn 0.3s;
}
@keyframes modalIn {
  from { transform: translateY(40px) scale(0.98); opacity: 0; }
  to   { transform: translateY(0) scale(1); opacity: 1; }
}
.cart-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px 10px 22px;
  background: var(--bg);
  border-bottom: 1px solid #e3e8f0;
}
.cart-head h2 {
  font-size: 1.2em;
  font-weight: 600;
  margin: 0;
}
.icon-close {
  font-size: 1.6em;
  background: none;
  border: none;
  color: #1976d2;
  cursor: pointer;
  transition: color 0.2s;
}
.icon-close:hover {
  color: #d32f2f;
}
.cart-body {
  padding: 18px 22px;
  max-height: 70vh;
  overflow-y: auto;
}
.cart-items {
  margin-bottom: 14px;
}
.cart-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid #eee;
}
.cart-thumb {
  width: 54px;
  height: 54px;
  object-fit: cover;
  border-radius: 10px;
  background: var(--bg);
  box-shadow: 0 2px 8px rgba(0,0,0,0.07);
}
.cart-info {
  flex: 1;
  min-width: 0;
}
.cart-right {
  text-align: right;
  min-width: 70px;
}
.stepper {
  display: flex;
  align-items: center;
  gap: 4px;
}
.stepper .btn, .stepper .qty {
  font-size: 1em;
  padding: 4px 8px;
  border-radius: 6px;
  border: 1px solid #ddd;
}
.stepper .qty {
  width: 48px;
  text-align: center;
}
.remove-btn {
  font-size: 1.3em;
  background: none;
  border: none;
  color: #d32f2f;
  cursor: pointer;
  transition: color 0.2s;
}
.remove-btn:hover {
  color: #b71c1c;
}
.cart-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--border);
  border-radius: 12px;
  padding: 12px 18px;
  margin-bottom: 12px;
  box-shadow: 0 2px 8px rgba(25,118,210,0.04);
}
.cart-summary .left {
  flex: 1;
}
.cart-summary .right {
  font-weight: 600;
  font-size: 1.1em;
}
.cart-summary .actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}
.hint {
  font-size: 0.98em;
  color: #d32f2f;
  margin-bottom: 8px;
}
.form-actions {
  margin-top: 12px;
  display: flex;
  justify-content: flex-end;
}
.checkout-form .field {
  margin-bottom: 10px;
}
.checkout-form .field.full {
  width: 100%;
}
.checkout-form label {
  font-size: 0.98em;
  font-weight: 500;
  margin-bottom: 2px;
  display: block;
}
.checkout-form input, .checkout-form textarea {
  width: 100%;
  padding: 8px;
  border-radius: 6px;
  border: 1px solid #ddd;
  font-size: 1em;
  margin-top: 2px;
  box-sizing: border-box;
}
.checkout-form button.primary {
  background: #1976d2;
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 8px 18px;
  font-size: 1em;
  cursor: pointer;
  transition: background 0.2s;
}
.checkout-form button.primary:active {
  background: #115293;
}

/* Responsive for mobile */
@media (max-width: 600px) {
  #cart-modal {
    max-width: 100vw;
    width: 100vw;
    border-radius: 0;
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    min-height: 100vh;
    margin: 0;
    padding: 0;
  }
  .cart-head, .cart-body {
    padding: 12px 8px;
  }
  .cart-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .cart-info, .cart-right {
    width: 100%;
    text-align: left;
  }
  .cart-thumb {
    width: 44px;
    height: 44px;
    border-radius: 8px;
  }
  .cart-summary {
    flex-direction: column;
    align-items: flex-start;
    padding: 10px 8px;
  }
  .cart-summary .actions {
    flex-direction: column;
    width: 100%;
    gap: 6px;
  }
}

/* Toast always overlaps modal */
.shop-toast {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  background: #1976d2;
  color: #fff;
  padding: 1em 2em;
  border-radius: 2em;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  display: flex;
  align-items: center;
  gap: 0.75em;
  font-size: 1.1em;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s, transform 0.3s;
  z-index: 9999; /* Higher than modal */
  max-width: 90vw;
  word-break: break-word;
}
.shop-toast.show {
  opacity: 1;
  transform: translateX(-50%) scale(1.05);
  pointer-events: auto;
}
.hidden {
  display: none;
}

.image-container {
  position: relative;
  display: inline-flex; /* Or block, depending on your layout */
  justify-content: center;
  align-items: center;
  min-width: 100px;  /* Example size */
  min-height: 100px; /* Example size */
}

.loader {
  position: absolute;
}