/* ── SHINE Designs – Customer CSS (matches template) ── */

:root {
  --teal:   #2BB7B0;
  --teal-d: #1f8e88;
  --teal-l: #e8faf9;
  --bg:     #f5fffe;   /* exact template background */
  --dark:   #0f1923;
  --text:   #1e293b;
  --muted:  #64748b;
  --border: #e2e8f0;
  --white:  #ffffff;
  --green:  #16a34a;
  --red:    #dc2626;
  --orange: #ea580c;
  --radius: 12px;
  --shadow: 0 2px 16px rgba(0,0,0,.07);
}
* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:'Outfit','Segoe UI',sans-serif; background:var(--bg); color:var(--text); min-height:100vh; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }

/* ── Topbar ── */
.topbar-strip {
  background:var(--teal); color:#fff; text-align:center;
  font-size:.78rem; padding:7px 16px; font-weight:500; letter-spacing:.3px;
}

/* ── Navbar (matches template) ── */
.navbar {
  background:var(--teal);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 16px; height:60px;
  position:sticky; top:0; z-index:200;
  box-shadow:0 2px 12px rgba(0,0,0,.12);
  gap:10px;
}
.navbar-logo { display:flex; align-items:center; gap:8px; flex-shrink:0; text-decoration:none; }
.navbar-logo img { height:36px; width:auto; filter:none; display:block; }
.navbar-logo .brand { color:#fff; font-size:1.05rem; font-weight:800; letter-spacing:-.3px; white-space:nowrap; }
.navbar-logo .brand small { display:block; font-size:.58rem; font-weight:400; opacity:.75; }

.navbar-links { display:flex; align-items:center; gap:2px; }
.navbar-links a {
  color:rgba(255,255,255,.9); padding:6px 10px; border-radius:7px;
  font-size:.82rem; font-weight:500; transition:all .2s; white-space:nowrap;
}
.navbar-links a:hover, .navbar-links a.active { color:#fff; background:rgba(255,255,255,.15); }

.navbar-right { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.nav-icon-btn {
  width:36px; height:36px; border-radius:9px; display:flex; align-items:center;
  justify-content:center; background:rgba(255,255,255,.15); color:#fff;
  border:none; cursor:pointer; font-size:.9rem; position:relative; transition:all .2s; flex-shrink:0;
}
.nav-icon-btn:hover { background:rgba(255,255,255,.25); }
.cart-badge {
  position:absolute; top:-4px; right:-4px; background:#fff; color:var(--teal);
  font-size:.58rem; font-weight:800; width:16px; height:16px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.btn-nav-login {
  padding:7px 14px; background:#fff; color:var(--teal); border-radius:8px;
  font-size:.8rem; font-weight:700; transition:all .2s; white-space:nowrap; border:none; cursor:pointer; font-family:'Outfit',sans-serif;
}
.btn-nav-login:hover { background:rgba(255,255,255,.88); }
.hamburger { display:none; background:none; border:none; color:#fff; font-size:1.2rem; cursor:pointer; padding:4px; flex-shrink:0; align-items:center; }

/* ── Mobile nav ── */
.mobile-nav { display:none; background:var(--teal-d,#1f8e88); padding:6px 14px; position:sticky; top:60px; z-index:199; }
.mobile-nav a { display:block; color:rgba(255,255,255,.9); padding:10px 2px; font-size:.9rem; border-bottom:1px solid rgba(255,255,255,.1); text-decoration:none; }
.mobile-nav a:last-child { border-bottom:none; }

/* ── Page wrapper ── */
.wrap { max-width:1200px; margin:auto; padding:0 24px; }

/* ── Hero ── */
.hero {
  background:linear-gradient(135deg, #0f1923 0%, #162230 55%, #1a3050 100%);
  min-height:500px; display:flex; align-items:center;
  position:relative; overflow:hidden;
}
.hero::after {
  content:''; position:absolute; top:-80px; right:-80px;
  width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle, rgba(43,183,176,.22) 0%, transparent 70%);
}
.hero-content { max-width:600px; padding:60px 24px; position:relative; z-index:1; }
.hero-tag { display:inline-block; background:rgba(43,183,176,.2); border:1px solid rgba(43,183,176,.4); color:var(--teal); padding:5px 14px; border-radius:20px; font-size:.75rem; font-weight:700; letter-spacing:.5px; margin-bottom:16px; }
.hero h1 { font-size:2.8rem; font-weight:800; color:#fff; line-height:1.15; margin-bottom:14px; }
.hero h1 em { color:var(--teal); font-style:normal; }
.hero p { font-size:1rem; color:rgba(255,255,255,.65); line-height:1.7; margin-bottom:28px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.btn-hero { padding:13px 26px; border-radius:10px; font-size:.92rem; font-weight:700; transition:all .2s; display:inline-flex; align-items:center; gap:7px; }
.btn-hero-main { background:var(--teal); color:#fff; }
.btn-hero-main:hover { background:var(--teal-d); transform:translateY(-1px); box-shadow:0 8px 24px rgba(43,183,176,.4); }
.btn-hero-ghost { background:rgba(255,255,255,.1); color:#fff; border:1px solid rgba(255,255,255,.2); }
.btn-hero-ghost:hover { background:rgba(255,255,255,.18); }

/* ── Features bar ── */
.features-bar { background:#fff; border-bottom:2px solid var(--teal-l); }
.features-bar .wrap { display:grid; grid-template-columns:repeat(4,1fr); }
.feature-item { display:flex; align-items:center; gap:12px; padding:16px 20px; border-right:1px solid var(--border); }
.feature-item:last-child { border-right:none; }
.feature-icon { width:38px; height:38px; background:var(--teal-l); border-radius:9px; display:flex; align-items:center; justify-content:center; color:var(--teal); font-size:.95rem; flex-shrink:0; }
.feature-text strong { display:block; font-size:.82rem; font-weight:700; }
.feature-text span { font-size:.72rem; color:var(--muted); }

/* ── Section ── */
.section { padding:56px 0; }
.section-head { text-align:center; margin-bottom:36px; }
.section-tag { font-size:.7rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--teal); margin-bottom:7px; }
.section-title { font-size:1.9rem; font-weight:800; color:var(--text); }
.section-sub { color:var(--muted); margin-top:6px; font-size:.95rem; }

/* ── Categories ── */
.cat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px; }
.cat-card {
  background:#fff; border-radius:12px; border:1.5px solid var(--border);
  padding:22px 14px; text-align:center; transition:all .2s; cursor:pointer;
}
.cat-card:hover { border-color:var(--teal); background:var(--teal-l); transform:translateY(-2px); }
.cat-card i { font-size:1.6rem; color:var(--teal); display:block; margin-bottom:8px; }
.cat-card span { font-size:.85rem; font-weight:600; }

/* ── Products grid (matches template .products) ── */
.products {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:20px;
}

/* ── Product card (matches template .product-card) ── */
.product-card {
  background:white;           /* template exact */
  padding:0;
  border-radius:10px;         /* template exact */
  overflow:hidden;
  border:1px solid var(--border);
  transition:transform .2s, box-shadow .2s;
  cursor:pointer; display:block;
}
.product-card:hover { transform:translateY(-4px); box-shadow:0 10px 30px rgba(0,0,0,.1); }
.product-card-img {
  position:relative; aspect-ratio:1/1; overflow:hidden; background:#f1f5f9;
}
.product-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .35s; }
.product-card:hover .product-card-img img { transform:scale(1.06); }
.product-card-badge { position:absolute; top:8px; left:8px; padding:3px 9px; border-radius:6px; font-size:.67rem; font-weight:700; color:#fff; }
.badge-new  { background:var(--teal); }
.badge-sale { background:var(--red); }
.product-card-body { padding:14px 16px; }
.product-card-name { font-size:.9rem; font-weight:600; margin-bottom:6px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.product-card-price { color:var(--teal); font-weight:700; font-size:1rem; }
.product-card-old { color:var(--muted); font-size:.8rem; text-decoration:line-through; margin-left:5px; }
.product-card-action { padding:0 16px 14px; }
.btn-add { width:100%; padding:9px; background:var(--teal); color:#fff; border:none; border-radius:7px; font-family:'Outfit',sans-serif; font-size:.82rem; font-weight:600; cursor:pointer; transition:background .2s; display:flex; align-items:center; justify-content:center; gap:6px; }
.btn-add:hover { background:var(--teal-d); }
.btn-add.out { background:#e2e8f0; color:var(--muted); cursor:not-allowed; }

/* ── Buttons ── */
.btn { display:inline-flex; align-items:center; gap:7px; padding:10px 20px; border-radius:9px; font-size:.875rem; font-weight:600; cursor:pointer; transition:all .2s; border:none; font-family:'Outfit',sans-serif; }
.btn-primary  { background:var(--teal); color:#fff; }
.btn-primary:hover { background:var(--teal-d); }
.btn-outline  { background:#fff; color:var(--text); border:1.5px solid var(--border); }
.btn-outline:hover { border-color:var(--teal); color:var(--teal); }
.btn-dark     { background:var(--dark); color:#fff; }
.btn-green    { background:#25D366; color:#fff; }
.btn-green:hover { background:#1da851; }
.btn-lg { padding:13px 28px; font-size:.95rem; }
.btn-block { width:100%; justify-content:center; }
.btn-sm { padding:6px 12px; font-size:.78rem; }

/* ── Filter bar ── */
.filter-bar { display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-bottom:24px; }
.filter-pill { padding:7px 16px; border-radius:30px; font-size:.82rem; font-weight:500; border:1.5px solid var(--border); background:#fff; cursor:pointer; transition:all .2s; }
.filter-pill:hover, .filter-pill.active { background:var(--teal); color:#fff; border-color:var(--teal); }

/* ── Shop layout ── */
.shop-wrap { display:grid; grid-template-columns:220px 1fr; gap:24px; }
.filter-side { background:#fff; border-radius:10px; border:1px solid var(--border); padding:18px; height:fit-content; position:sticky; top:80px; }
.filter-side h4 { font-size:.85rem; font-weight:700; margin-bottom:14px; padding-bottom:10px; border-bottom:1px solid var(--border); }
.fgroup { margin-bottom:18px; }
.fgroup-label { font-size:.68rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.fcheck { display:flex; align-items:center; gap:8px; font-size:.84rem; padding:4px 0; cursor:pointer; }
.fcheck input { accent-color:var(--teal); }
.size-grid { display:flex; flex-wrap:wrap; gap:5px; }
.sz { padding:4px 10px; border-radius:6px; border:1.5px solid var(--border); font-size:.75rem; font-weight:600; cursor:pointer; background:#fff; transition:all .2s; }
.sz.on, .sz:hover { background:var(--teal); color:#fff; border-color:var(--teal); }

/* ── Product detail ── */
.pd-wrap { display:grid; grid-template-columns:1fr 1fr; gap:44px; align-items:start; }
.pd-imgs .main-img { border-radius:12px; overflow:hidden; aspect-ratio:1/1; background:#f1f5f9; margin-bottom:10px; }
.pd-imgs .main-img img { width:100%; height:100%; object-fit:cover; }
.pd-thumbs { display:flex; gap:8px; }
.pd-thumb { width:64px; height:64px; border-radius:8px; overflow:hidden; cursor:pointer; border:2px solid transparent; }
.pd-thumb.on { border-color:var(--teal); }
.pd-thumb img { width:100%; height:100%; object-fit:cover; }
.pd-info h1 { font-size:1.75rem; font-weight:800; margin-bottom:8px; }
.pd-price { font-size:1.5rem; font-weight:700; color:var(--teal); margin-bottom:14px; }
.pd-stock { font-size:.82rem; font-weight:600; margin-bottom:18px; display:flex; align-items:center; gap:6px; }
.pd-stock.in { color:var(--green); } .pd-stock.out { color:var(--red); }
.pd-stock::before { content:''; width:8px; height:8px; border-radius:50%; background:currentColor; flex-shrink:0; }
.var-label { font-size:.72rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.size-opts { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.sopt { padding:8px 16px; border-radius:8px; border:1.5px solid var(--border); font-size:.875rem; font-weight:600; cursor:pointer; background:#fff; transition:all .2s; }
.sopt.on { background:var(--teal); color:#fff; border-color:var(--teal); }
.sopt:disabled { opacity:.4; cursor:not-allowed; }
.color-opts { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:18px; }
.copt { width:28px; height:28px; border-radius:50%; cursor:pointer; border:3px solid transparent; box-shadow:0 0 0 1.5px rgba(0,0,0,.2); transition:all .2s; }
.copt.on { border-color:var(--teal); }
.qty-row { display:flex; align-items:center; gap:10px; margin-bottom:20px; }
.qty-row span { font-size:.78rem; font-weight:700; text-transform:uppercase; color:var(--muted); }
.qty-ctrl { display:flex; align-items:center; gap:8px; }
.qbtn { width:32px; height:32px; border-radius:7px; border:1.5px solid var(--border); background:#fff; cursor:pointer; font-size:1rem; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.qbtn:hover { background:var(--teal); color:#fff; border-color:var(--teal); }
.qval { font-size:1rem; font-weight:700; min-width:28px; text-align:center; }
.pd-actions { display:flex; flex-direction:column; gap:10px; margin-bottom:20px; }
.pd-info-box { background:#f8fafc; border-radius:10px; padding:14px 16px; font-size:.83rem; margin-top:16px; }
.pd-info-box li { display:flex; align-items:center; gap:8px; padding:4px 0; color:var(--muted); }
.pd-info-box li i { color:var(--teal); width:16px; }

/* ── Checkout ── */
.checkout-wrap { display:grid; grid-template-columns:1fr 360px; gap:24px; align-items:start; }
.co-section { background:#fff; border-radius:10px; border:1px solid var(--border); padding:22px; margin-bottom:14px; }
.co-section h3 { font-size:.95rem; font-weight:700; display:flex; align-items:center; gap:8px; margin-bottom:16px; padding-bottom:12px; border-bottom:1px solid var(--border); }
.co-section h3 i { color:var(--teal); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.fg { margin-bottom:13px; }
.fg label { display:block; font-size:.78rem; font-weight:600; color:#475569; margin-bottom:5px; }
.fc { width:100%; padding:10px 13px; border:1.5px solid var(--border); border-radius:8px; font-size:.88rem; font-family:'Outfit',sans-serif; outline:none; background:#fff; transition:border-color .2s; }
.fc:focus { border-color:var(--teal); box-shadow:0 0 0 3px rgba(43,183,176,.1); }
.pay-opt { display:flex; align-items:center; gap:12px; padding:13px 14px; border:1.5px solid var(--border); border-radius:10px; cursor:pointer; margin-bottom:9px; transition:all .2s; }
.pay-opt.on { border-color:var(--teal); background:var(--teal-l); }
.pay-opt input { accent-color:var(--teal); }
.pay-opt-ico { width:34px; height:34px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.95rem; flex-shrink:0; }
.pay-opt strong { display:block; font-size:.875rem; }
.pay-opt small { color:var(--muted); font-size:.75rem; }
.order-box { background:#fff; border-radius:10px; border:1px solid var(--border); padding:20px; position:sticky; top:80px; }
.order-box h3 { font-size:.95rem; font-weight:700; margin-bottom:16px; padding-bottom:12px; border-bottom:1px solid var(--border); }
.order-row { display:flex; justify-content:space-between; font-size:.875rem; padding:7px 0; border-bottom:1px solid var(--border); }
.order-row:last-of-type { border-bottom:none; }
.order-total { display:flex; justify-content:space-between; font-size:1.05rem; font-weight:700; padding-top:12px; border-top:2px solid var(--border); margin-top:8px; }
.coupon-bar { display:flex; gap:8px; margin:12px 0; }
.coupon-bar .fc { flex:1; }

/* ── Auth ── */
.auth-page { min-height:80vh; display:flex; align-items:center; justify-content:center; padding:40px 20px; background:var(--bg); }
.auth-box { background:#fff; border-radius:14px; overflow:hidden; width:100%; max-width:420px; box-shadow:0 8px 32px rgba(0,0,0,.1); border:1px solid var(--border); }
.auth-head { background:var(--teal); padding:28px; text-align:center; color:#fff; }
.auth-head .logo { height:48px; margin:0 auto 12px; filter:brightness(0) invert(1); }
.auth-head h2 { font-size:1.25rem; font-weight:700; }
.auth-head p { font-size:.82rem; opacity:.8; margin-top:4px; }
.auth-body { padding:26px; }
.auth-foot { text-align:center; font-size:.84rem; color:var(--muted); margin-top:14px; }
.auth-foot a { color:var(--teal); font-weight:600; }

/* ── Cart sidebar ── */
.cart-bg { position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:400; display:none; }
.cart-bg.show { display:block; }
.cart-panel { position:fixed; top:0; right:-420px; width:400px; max-width:100vw; height:100vh; background:#fff; z-index:500; display:flex; flex-direction:column; transition:right .3s; box-shadow:-6px 0 30px rgba(0,0,0,.15); }
.cart-panel.show { right:0; }
.cart-hdr { padding:18px 20px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; }
.cart-hdr h3 { font-size:1rem; font-weight:700; }
.cart-x { background:none; border:none; font-size:1.1rem; cursor:pointer; color:var(--muted); }
.cart-body { flex:1; overflow-y:auto; padding:14px 18px; }
.cart-item { display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--border); }
.cart-thumb { width:60px; height:60px; border-radius:8px; object-fit:cover; background:#f1f5f9; flex-shrink:0; }
.cart-info { flex:1; }
.cart-iname { font-size:.84rem; font-weight:600; margin-bottom:2px; }
.cart-ivar { font-size:.72rem; color:var(--muted); }
.cart-iprice { font-size:.82rem; font-weight:700; color:var(--teal); }
.cart-qty { display:flex; align-items:center; gap:5px; margin-top:5px; }
.cart-qbtn { width:22px; height:22px; border-radius:5px; border:1px solid var(--border); background:#fff; cursor:pointer; font-size:.85rem; display:flex; align-items:center; justify-content:center; }
.cart-qbtn:hover { background:var(--teal); color:#fff; border-color:var(--teal); }
.cart-qval { font-size:.82rem; font-weight:700; min-width:20px; text-align:center; }
.cart-del { background:none; border:none; color:var(--muted); cursor:pointer; margin-left:auto; align-self:flex-start; font-size:.82rem; }
.cart-del:hover { color:var(--red); }
.cart-ftr { padding:16px 18px; border-top:1px solid var(--border); background:#f8fafc; }
.cart-ftr-row { display:flex; justify-content:space-between; font-size:.875rem; margin-bottom:5px; }
.cart-ftr-total { display:flex; justify-content:space-between; font-size:1.05rem; font-weight:700; padding-top:10px; border-top:2px solid var(--border); margin:8px 0 14px; }
.cart-empty { text-align:center; padding:50px 20px; color:var(--muted); }
.cart-empty i { font-size:3rem; display:block; margin-bottom:12px; color:var(--border); }

/* ── Track ── */
.track-steps { display:flex; flex-direction:column; gap:0; }
.ts { display:flex; gap:14px; padding-bottom:22px; position:relative; }
.ts::before { content:''; position:absolute; left:13px; top:28px; bottom:0; width:2px; background:var(--border); }
.ts:last-child::before { display:none; }
.ts.done::before { background:var(--teal); }
.ts-icon { width:28px; height:28px; border-radius:50%; background:var(--border); display:flex; align-items:center; justify-content:center; font-size:.72rem; color:#fff; flex-shrink:0; z-index:1; }
.ts.done .ts-icon, .ts.cur .ts-icon { background:var(--teal); }
.ts.cur .ts-icon { box-shadow:0 0 0 4px rgba(43,183,176,.2); }
.ts-body { padding-top:2px; }
.ts-label { font-size:.875rem; font-weight:600; }
.ts-time { font-size:.73rem; color:var(--muted); margin-top:2px; }

/* ── Account ── */
.account-wrap { display:grid; grid-template-columns:230px 1fr; gap:22px; }
.account-side { background:#fff; border-radius:10px; border:1px solid var(--border); overflow:hidden; height:fit-content; }
.account-avatar { background:var(--teal); padding:22px; text-align:center; color:#fff; }
.account-avatar i { font-size:2.5rem; display:block; margin-bottom:8px; }
.account-nav a { display:flex; align-items:center; gap:10px; padding:11px 18px; font-size:.875rem; color:var(--muted); border-bottom:1px solid var(--border); transition:all .2s; }
.account-nav a:hover, .account-nav a.active { color:var(--teal); background:var(--teal-l); }
.account-nav a i { width:16px; }

/* ── Footer (teal brand) ── */
.footer { background:var(--dark); color:rgba(255,255,255,.65); padding:50px 0 22px; }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:36px; max-width:1200px; margin:auto; padding:0 24px 40px; }
.footer-brand img { height:40px; margin-bottom:12px; filter:brightness(0) invert(1); opacity:.8; }
.footer-brand p { font-size:.84rem; line-height:1.7; color:rgba(255,255,255,.45); }
.footer-col h4 { color:#fff; font-size:.88rem; font-weight:700; margin-bottom:14px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:8px; }
.footer-col ul li a { font-size:.82rem; color:rgba(255,255,255,.45); transition:color .2s; }
.footer-col ul li a:hover { color:var(--teal); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.08); padding:18px 24px; max-width:1200px; margin:auto; display:flex; justify-content:space-between; align-items:center; font-size:.75rem; color:rgba(255,255,255,.3); }
.socials { display:flex; gap:12px; margin-top:12px; }
.socials a { color:rgba(255,255,255,.4); font-size:1rem; transition:color .2s; }
.socials a:hover { color:var(--teal); }

/* ── Alerts / misc ── */
.alert { padding:12px 16px; border-radius:8px; font-size:.875rem; margin-bottom:14px; display:flex; align-items:center; gap:9px; }
.alert-success { background:#dcfce7; color:#166534; border:1px solid #bbf7d0; }
.alert-danger  { background:#fee2e2; color:#991b1b; border:1px solid #fecaca; }
.alert-info    { background:#eff6ff; color:#1e40af; border:1px solid #bfdbfe; }
.breadcrumb { font-size:.78rem; color:var(--muted); display:flex; align-items:center; gap:5px; padding:12px 0; }
.breadcrumb a { color:var(--teal); }
.text-teal { color:var(--teal); } .text-muted { color:var(--muted); }
.mono { font-family:'Courier New',monospace; }
.fw-bold { font-weight:700; }

/* ── Responsive ── */
@media(max-width:960px){
  .shop-wrap { grid-template-columns:1fr; }
  .filter-side { display:none; }
  .pd-wrap, .checkout-wrap, .account-wrap { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:24px; }
  .features-bar .wrap { grid-template-columns:1fr 1fr; }
}
@media(max-width:640px){
  .navbar-links { display:none; }
  .hamburger { display:block; }
  .wrap { padding:0 14px; }
  .hero h1 { font-size:2rem; }
  .hero-content { padding:40px 14px; }
  .products { grid-template-columns:1fr 1fr; gap:12px; }
  .footer-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .features-bar .wrap { grid-template-columns:1fr; }
}

/* ── SALE / DISCOUNT PRICE ──────────────────────── */
.price-original { font-size:.85rem; color:var(--muted); text-decoration:line-through; font-family:'JetBrains Mono',monospace; }
.price-sale     { color:var(--red); font-weight:700; font-family:'JetBrains Mono',monospace; }
.price-badge    { display:inline-block; background:var(--red); color:#fff; font-size:.65rem; font-weight:800; padding:2px 6px; border-radius:5px; margin-left:4px; vertical-align:middle; }

/* ── IMAGE LIGHTBOX ─────────────────────────────── */
.lightbox-overlay { position:fixed; inset:0; background:rgba(0,0,0,.92); z-index:9999; display:none; align-items:center; justify-content:center; }
.lightbox-overlay.open { display:flex; }
.lightbox-img-wrap { position:relative; max-width:90vw; max-height:90vh; display:flex; align-items:center; justify-content:center; }
.lightbox-img-wrap img { max-width:90vw; max-height:85vh; object-fit:contain; border-radius:8px; cursor:zoom-in; transition:transform .3s; }
.lightbox-img-wrap img.zoomed { cursor:zoom-out; transform:scale(2); transform-origin:var(--ox,50%) var(--oy,50%); }
.lightbox-close { position:fixed; top:16px; right:18px; background:rgba(255,255,255,.15); border:none; color:#fff; font-size:1.6rem; cursor:pointer; width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; z-index:10000; }
.lightbox-close:hover { background:rgba(255,255,255,.25); }

/* ── FULL MOBILE RESPONSIVE ─────────────────────── */
@media(max-width:900px){
  .shop-wrap { grid-template-columns:1fr; }
  .filter-side { display:none; }
  .pd-wrap { grid-template-columns:1fr; gap:20px; }
  .checkout-wrap { grid-template-columns:1fr; }
  .account-wrap { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:20px; }
  .features-bar .wrap { grid-template-columns:1fr 1fr; }
  .navbar-links { display:none; }
  .hamburger { display:flex !important; }
  .nav-search { max-width:180px; }
}
@media(max-width:600px){
  .wrap { padding:0 12px; }
  .products { grid-template-columns:1fr 1fr; gap:10px; }
  .footer-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .features-bar .wrap { grid-template-columns:1fr 1fr; }
  .hero-slide h1, .hero h1 { font-size:1.8rem !important; }
  .hero-content { padding:40px 14px !important; }
  .section { padding:40px 0; }
  .co-section { padding:16px; }
  .checkout-wrap, .order-box { gap:16px; }
  .pd-info h1 { font-size:1.4rem; }
  .auth-box { margin:10px; }
  .product-card-img { aspect-ratio:1/1; }
}
@media(max-width:400px){
  .navbar { padding:0 8px; gap:6px; }
  .navbar-logo .brand { font-size:.88rem; }
  .nav-search { max-width:120px; }
  .nav-search-input-wrap input { font-size:.74rem; padding:6px 22px 6px 26px; }
  .btn-nav-login { padding:5px 8px; font-size:.72rem; }
  .products { grid-template-columns:1fr 1fr; gap:8px; }
}

/* ── MOBILE RESPONSIVE — CUSTOMER VIEWS ─────────────── */
/* Product detail */
@media(max-width:700px){
  .pd-wrap { grid-template-columns:1fr !important; gap:16px; }
  .pd-imgs .pd-thumbs { display:flex; gap:6px; overflow-x:auto; }
  .pd-thumb { min-width:56px; height:56px; }
  .pd-info h1 { font-size:1.3rem; }
  .pd-price { font-size:1.4rem !important; }
}
/* Checkout */
@media(max-width:700px){
  .checkout-wrap { grid-template-columns:1fr !important; }
  .order-box { position:static !important; }
  .co-section { padding:14px; }
  .co-section h3 { font-size:.9rem; }
  .pay-opt { padding:10px 12px; }
}
/* Account */
@media(max-width:700px){
  .account-wrap { grid-template-columns:1fr !important; }
  .account-side { position:static; }
  .account-nav { display:flex; flex-wrap:wrap; gap:4px; }
  .account-nav a { padding:6px 12px; border-radius:20px; border:1px solid var(--border); font-size:.8rem; }
}
/* Shop */
@media(max-width:480px){
  .products { grid-template-columns:1fr 1fr !important; gap:8px; }
  .product-card-img { aspect-ratio:1/1; }
  .product-card-name { font-size:.82rem; }
  .product-card-price { font-size:.85rem; }
}
/* Auth pages */
@media(max-width:480px){
  .auth-page { padding:12px; }
  .auth-box { border-radius:12px !important; }
}
/* Hero slider mobile */
@media(max-width:600px){
  .hero-slide h1, .hero h1 { font-size:1.6rem !important; line-height:1.2; }
  .hero-content { padding:40px 16px 56px !important; }
  .hero-slide p { font-size:.85rem !important; }
  .btn-hero { padding:10px 18px !important; font-size:.84rem !important; }
  .hero-actions { flex-direction:column; gap:8px; }
  .slider-prev { left:8px; width:36px; height:36px; font-size:1.2rem; }
  .slider-next { right:8px; width:36px; height:36px; font-size:1.2rem; }
}
/* Category row */
.cat-img-card:hover > div:first-child { border-color:var(--teal) !important; }
/* Features bar */
@media(max-width:600px){
  .features-bar .wrap { grid-template-columns:1fr 1fr !important; gap:10px; }
  .feature-item { padding:10px; }
}
/* Cart sidebar */
@media(max-width:480px){
  .cart-panel { width:100% !important; max-width:100% !important; }
}
/* Nav search mobile */
@media(max-width:400px){
  .nav-search { max-width:100px; }
  .nav-search-input-wrap input { font-size:.74rem; padding:6px 22px 6px 26px; }
}