/* ======================================================
   DESIGN TOKENS  (shared with index.php)
====================================================== */
:root {
  --primary:      #0098D9;
  --primary-dk:   #1A7AC4;
  --secondary:    #1A7AC4;
  --secondary-lt: #2192D0;
  --dark:         #0d2a45;
  --white:        #fff;
  --off:          #F0F7FC;
  --g50:          #F5FAFE;
  --g100:         #EAF4FB;
  --g150:         #D6EAF7;
  --g200:         #BDD9EF;
  --g300:         #93BDD9;
  --g400:         #6A9AB8;
  --g500:         #4A7A99;
  --g600:         #3A6480;
  --g800:         #1A3A52;
  --danger:       #ef4444;
  --heading:      'Poppins', sans-serif;
  --body:         'Manrope', sans-serif;
  --hh:           68px;
  --max:          1260px;
  --px:           24px;
  --radius:       14px;
}
*,*::before,*::after { box-sizing: border-box; margin:0; padding:0; }
html  { scroll-behavior: smooth; font-size:16px; overflow-x:hidden; -webkit-text-size-adjust:100%; }
body  { font-family:var(--body); background:var(--white); color:var(--g800); -webkit-font-smoothing:antialiased; overflow-x:hidden; line-height:1.6; max-width:100vw; }
img   { display:block; max-width:100%; }
a     { text-decoration:none; color:inherit; }
ul,ol { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
input,button,select,textarea { font-family:inherit; }
.wrap { width:100%; max-width:var(--max); margin:0 auto; padding:0 var(--px); }
h1,h2,h3,h4,h5,h6 { font-family:var(--heading); line-height:1.15; letter-spacing:-.01em; color:var(--secondary); }
p     { font-family:var(--body); font-size:.9375rem; line-height:1.7; color:var(--g600); }
.label { display:inline-block; font-family:var(--heading); font-weight:600; font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--primary); margin-bottom:10px; }
/* ── Buttons ── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:var(--heading); font-weight:600; font-size:.875rem; padding:13px 26px; border-radius:9px; transition:background .2s,color .2s,transform .15s,box-shadow .2s; white-space:nowrap; border:2px solid transparent; cursor:pointer; letter-spacing:.01em; }
.btn:active { transform:translateY(1px); }
.btn-primary { background:var(--secondary); color:var(--white); border-color:var(--secondary); }
.btn-primary:hover { background:var(--primary); border-color:var(--primary); }
.btn-outline { background:transparent; color:var(--secondary); border-color:var(--secondary); }
.btn-outline:hover { background:var(--secondary); color:var(--white); }
.btn-cart { background:var(--secondary); color:var(--white); border-color:var(--secondary); font-size:.925rem; padding:15px 32px; border-radius:10px; flex:1; }
.btn-cart:hover { background:var(--primary); border-color:var(--primary); box-shadow:0 8px 24px rgba(0,152,217,.25); }
.btn-cart:disabled { background:var(--g300); border-color:var(--g300); cursor:not-allowed; }
.btn-wish { background:var(--g100); border:2px solid var(--g200); color:var(--secondary); border-radius:10px; padding:13px 18px; transition:all .2s; flex-shrink:0; display:flex; align-items:center; gap:8px; font-family:var(--heading); font-weight:600; font-size:.875rem; }
.btn-wish:hover { border-color:var(--primary); color:var(--primary); background:rgba(0,152,217,.06); }
.btn-wish.active { background:rgba(239,68,68,.07); border-color:#ef4444; color:#ef4444; }
.btn-wish.active svg { fill:#ef4444; }
.btn-ghost { color:var(--primary); font-family:var(--heading); font-weight:600; font-size:.85rem; display:inline-flex; align-items:center; gap:5px; border-bottom:1.5px solid var(--primary); padding-bottom:1px; transition:color .2s,border-color .2s; }
.btn-ghost:hover { color:var(--secondary); border-color:var(--secondary); }
.icon-btn { width:40px; height:40px; border-radius:8px; display:flex; align-items:center; justify-content:center; color:var(--g600); transition:color .2s,background .2s; position:relative; flex-shrink:0; }
.icon-btn:hover { color:var(--secondary); background:var(--g100); }
.icon-btn .badge { position:absolute; top:4px; right:4px; background:var(--primary); color:var(--white); font-size:.6rem; font-weight:700; width:16px; height:16px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
/* ── Announcement ── */
#ann-bar { background:var(--secondary); color:var(--white); text-align:center; padding:9px var(--px); font-family:var(--body); font-size:.8125rem; font-weight:500; display:flex; align-items:center; justify-content:center; gap:12px; position:relative; letter-spacing:.01em; }
#ann-bar strong { color:var(--primary); font-weight:700; }
#ann-bar .ann-close { position:absolute; right:14px; top:50%; transform:translateY(-50%); color:rgba(255,255,255,.5); transition:color .2s; padding:4px; }
#ann-bar .ann-close:hover { color:var(--white); }
/* ── Header ── */
#hdr { position:sticky; top:0; z-index:900; background:var(--white); border-bottom:1px solid var(--g200); height:var(--hh); }
.hdr-inner { display:flex; align-items:center; gap:20px; height:100%; }
.logo { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.logo img { height:34px; width:auto; }
.logo-txt { font-family:var(--heading); font-weight:700; font-size:1.125rem; color:var(--secondary); }
.logo-txt span { color:var(--primary); }
.nav-desk { display:flex; align-items:center; gap:2px; flex-shrink:0; }
.nav-desk a { font-family:var(--heading); font-weight:500; font-size:.8375rem; color:var(--g600); padding:7px 12px; border-radius:6px; transition:color .2s,background .2s; white-space:nowrap; }
.nav-desk a:hover,.nav-desk a.active { color:var(--secondary); background:var(--g100); }
.hdr-search { flex:1; max-width:300px; position:relative; }
.hdr-search input { width:100%; height:38px; background:var(--g100); border:1.5px solid var(--g200); border-radius:8px; padding:0 38px 0 14px; font-family:var(--body); font-size:.8375rem; color:var(--g800); outline:none; transition:border-color .2s; }
.hdr-search input:focus { border-color:var(--primary); }
.hdr-search input::placeholder { color:var(--g400); }
.hdr-search .si { position:absolute; right:10px; top:50%; transform:translateY(-50%); color:var(--g400); pointer-events:none; }
.search-results { position:absolute; top:calc(100% + 6px); left:0; right:0; background:var(--white); border:1.5px solid var(--g200); border-radius:10px; box-shadow:0 8px 32px rgba(26,58,82,.12); max-height:360px; overflow-y:auto; display:none; z-index:999; }
.search-results.show { display:block; }
.sr-item { display:flex; align-items:center; gap:12px; padding:10px 14px; transition:background .15s; }
.sr-item:hover { background:var(--g100); }
.sr-item img { width:42px; height:42px; object-fit:contain; border-radius:6px; background:var(--g100); flex-shrink:0; }
.sr-item-name { font-family:var(--heading); font-weight:600; font-size:.825rem; color:var(--secondary); }
.sr-item-price { font-family:var(--body); font-size:.72rem; color:var(--primary); font-weight:600; }
.sr-empty,.sr-all { padding:12px 16px; font-size:.85rem; color:var(--g400); text-align:center; }
.sr-all { border-top:1px solid var(--g200); color:var(--primary); font-weight:600; display:block; }
.hdr-actions { display:flex; align-items:center; gap:4px; flex-shrink:0; }
.ham { display:none; width:40px; height:40px; border-radius:8px; align-items:center; justify-content:center; color:var(--g600); transition:background .2s; }
.ham:hover { background:var(--g100); }
/* ── Mobile nav ── */
.mob-nav { display:none; position:fixed; inset:0; z-index:9999; }
.mob-nav.open { display:block; }
.mob-overlay { position:absolute; inset:0; background:rgba(26,58,82,.5); }
.mob-drawer { position:absolute; top:0; left:0; bottom:0; width:min(300px,88vw); background:var(--white); padding:20px; display:flex; flex-direction:column; gap:4px; transform:translateX(-100%); transition:transform .3s cubic-bezier(.4,0,.2,1); overflow-y:auto; }
.mob-nav.open .mob-drawer { transform:translateX(0); }
.mob-hd { display:flex; align-items:center; justify-content:space-between; padding-bottom:16px; border-bottom:1px solid var(--g200); margin-bottom:8px; }
.mob-close { width:36px; height:36px; border-radius:8px; display:flex; align-items:center; justify-content:center; color:var(--g600); transition:background .2s; }
.mob-close:hover { background:var(--g100); }
.mob-search { position:relative; margin-bottom:12px; }
.mob-search input { width:100%; height:40px; background:var(--g100); border:1.5px solid var(--g200); border-radius:8px; padding:0 38px 0 14px; font-family:var(--body); font-size:.85rem; outline:none; color:var(--g800); }
.mob-search .si { position:absolute; right:10px; top:50%; transform:translateY(-50%); color:var(--g400); pointer-events:none; }
.mob-nav-links a { display:flex; align-items:center; gap:12px; padding:11px 12px; border-radius:8px; font-family:var(--heading); font-weight:500; font-size:.875rem; color:var(--g600); transition:color .2s,background .2s; }
.mob-nav-links a:hover,.mob-nav-links a.active { color:var(--secondary); background:var(--g100); }
.mob-divider { height:1px; background:var(--g200); margin:8px 0; }
.mob-footer { margin-top:auto; padding-top:16px; }
.mob-footer a { display:flex; align-items:center; justify-content:center; gap:8px; background:var(--secondary); color:var(--white); font-family:var(--heading); font-weight:600; font-size:.875rem; padding:13px; border-radius:10px; }
/* ── Breadcrumb ── */
.breadcrumb { padding:18px 0 0; }
.breadcrumb nav { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.breadcrumb a { font-family:var(--body); font-size:.8rem; color:var(--g400); transition:color .2s; }
.breadcrumb a:hover { color:var(--primary); }
.breadcrumb .sep { color:var(--g300); font-size:.75rem; }
.breadcrumb .cur { font-family:var(--body); font-size:.8rem; color:var(--g600); font-weight:500; max-width:240px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
/* ── Product layout ── */
.product-section { padding:28px 0 64px; }
.product-grid { display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:start; }
/* ── Gallery ── */
.gallery { position:sticky; top:calc(var(--hh) + 20px); }
.gallery-main { position:relative; background:var(--g100); border-radius:16px; overflow:hidden; aspect-ratio:1/1; border:1.5px solid var(--g200); margin-bottom:12px; }
.gallery-main img { width:100%; height:100%; object-fit:contain; padding:32px; transition:opacity .2s; cursor:zoom-in; }
.gallery-main img.zoomed { cursor:zoom-out; transform:scale(1.5); transform-origin:var(--zx,50%) var(--zy,50%); }
.gallery-badge { position:absolute; top:14px; left:14px; display:flex; flex-direction:column; gap:6px; }
.g-badge { font-family:var(--heading); font-weight:700; font-size:.65rem; letter-spacing:.05em; text-transform:uppercase; padding:4px 10px; border-radius:6px; }
.b-sale { background:var(--secondary); color:var(--white); }
.b-new  { background:var(--primary); color:var(--white); }
.b-hot  { background:#f97316; color:var(--white); }
.b-oos  { background:var(--g400); color:var(--white); }
.gallery-nav-btn { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.9); border:1px solid var(--g200); border-radius:50%; width:36px; height:36px; display:flex; align-items:center; justify-content:center; color:var(--secondary); z-index:2; transition:background .2s; box-shadow:0 2px 8px rgba(0,0,0,.08); }
.gallery-nav-btn:hover { background:var(--white); }
.gallery-nav-btn.prev { left:12px; }
.gallery-nav-btn.next { right:12px; }
.gallery-thumbs { display:flex; gap:8px; overflow-x:auto; padding-bottom:4px; scrollbar-width:thin; }
.gallery-thumbs::-webkit-scrollbar { height:4px; }
.gallery-thumbs::-webkit-scrollbar-track { background:var(--g100); border-radius:2px; }
.gallery-thumbs::-webkit-scrollbar-thumb { background:var(--g300); border-radius:2px; }
.g-thumb { flex-shrink:0; width:72px; height:72px; border-radius:10px; overflow:hidden; border:2px solid var(--g200); background:var(--g100); cursor:pointer; transition:border-color .2s; padding:6px; }
.g-thumb img { width:100%; height:100%; object-fit:contain; }
.g-thumb.active { border-color:var(--primary); }
.g-thumb:hover { border-color:var(--secondary); }
/* ── Product info ── */
.prod-info {}
.pi-brand-cat { display:flex; align-items:center; gap:10px; margin-bottom:12px; flex-wrap:wrap; }
.pi-brand { font-family:var(--body); font-size:.75rem; font-weight:700; color:var(--g400); letter-spacing:.07em; text-transform:uppercase; }
.pi-cat-tag { background:rgba(0,152,217,.1); color:var(--primary); border:1px solid rgba(0,152,217,.2); font-family:var(--heading); font-weight:600; font-size:.65rem; letter-spacing:.08em; text-transform:uppercase; padding:3px 10px; border-radius:100px; }
.pi-title { font-size:clamp(1.35rem,3vw,1.95rem); font-weight:700; line-height:1.2; color:var(--secondary); margin-bottom:14px; letter-spacing:-.02em; }
.pi-rating-row { display:flex; align-items:center; gap:10px; margin-bottom:18px; flex-wrap:wrap; }
.stars { display:flex; gap:2px; color:var(--primary); }
.stars svg { width:14px; height:14px; fill:currentColor; flex-shrink:0; }
.stars svg.emp  { color:var(--g200); }
.stars svg.half { color:var(--g200); }
.rat-avg { font-family:var(--heading); font-weight:700; font-size:.875rem; color:var(--secondary); }
.rat-count { font-family:var(--body); font-size:.8rem; color:var(--g400); }
.rat-sep { color:var(--g300); }
.pi-sku { font-family:var(--body); font-size:.75rem; color:var(--g400); }
.pi-sku span { color:var(--g600); font-weight:600; }
.price-block { background:var(--g100); border-radius:12px; padding:18px 20px; margin-bottom:20px; }
.price-main { font-family:var(--heading); font-weight:700; font-size:1.85rem; color:var(--secondary); line-height:1; margin-bottom:4px; }
.price-main.sale { color:var(--primary); }
.price-row-inner { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.price-old { font-family:var(--body); font-size:.9rem; color:var(--g400); text-decoration:line-through; }
.price-save { background:var(--secondary); color:var(--white); font-family:var(--heading); font-weight:700; font-size:.72rem; padding:3px 9px; border-radius:6px; }
.price-note { font-family:var(--body); font-size:.775rem; color:var(--g400); margin-top:6px; }
/* ── Variants ── */
.variants-block { margin-bottom:20px; }
.variant-group { margin-bottom:14px; }
.variant-label { font-family:var(--heading); font-weight:600; font-size:.825rem; color:var(--secondary); margin-bottom:8px; display:flex; align-items:center; gap:6px; }
.variant-label span { font-weight:400; color:var(--g400); font-family:var(--body); font-size:.8rem; }
.variant-opts { display:flex; gap:8px; flex-wrap:wrap; }
.v-opt { padding:7px 16px; border-radius:8px; border:2px solid var(--g200); font-family:var(--heading); font-weight:600; font-size:.8rem; color:var(--g600); background:var(--white); cursor:pointer; transition:all .2s; }
.v-opt:hover { border-color:var(--secondary); color:var(--secondary); }
.v-opt.active { border-color:var(--primary); background:rgba(0,152,217,.08); color:var(--primary); }
.v-opt.unavailable { opacity:.4; cursor:not-allowed; text-decoration:line-through; }
.v-color { width:36px; height:36px; border-radius:50%; padding:0; border:3px solid var(--g200); position:relative; flex-shrink:0; }
.v-color.active { border-color:var(--primary); }
.v-color.active::after { content:''; position:absolute; inset:-5px; border:2px solid var(--primary); border-radius:50%; }
/* ── Qty & CTA ── */
.qty-cta { display:flex; gap:10px; align-items:center; margin-bottom:16px; }
.qty-wrap { display:flex; align-items:center; border:2px solid var(--g200); border-radius:10px; overflow:hidden; flex-shrink:0; }
.qty-btn { width:42px; height:50px; display:flex; align-items:center; justify-content:center; color:var(--secondary); background:var(--g100); transition:background .2s; font-size:1.1rem; }
.qty-btn:hover { background:var(--g200); }
.qty-inp { width:52px; height:50px; text-align:center; border:none; border-left:2px solid var(--g200); border-right:2px solid var(--g200); font-family:var(--heading); font-weight:700; font-size:1rem; color:var(--secondary); outline:none; background:var(--white); }
.qty-inp::-webkit-inner-spin-button { -webkit-appearance:none; }
/* ── Stock badge ── */
.stock-status { display:inline-flex; align-items:center; gap:6px; font-family:var(--heading); font-weight:600; font-size:.78rem; margin-bottom:16px; }
.stock-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.stock-in   { color:#16a34a; } .stock-in .stock-dot   { background:#16a34a; box-shadow:0 0 0 3px rgba(22,163,74,.15); }
.stock-low  { color:#f97316; } .stock-low .stock-dot  { background:#f97316; box-shadow:0 0 0 3px rgba(249,115,22,.15); }
.stock-out  { color:var(--g400); } .stock-out .stock-dot { background:var(--g300); }
.stock-pre  { color:var(--primary); } .stock-pre .stock-dot { background:var(--primary); }
/* ── Perks list ── */
.perks-list { display:flex; flex-direction:column; gap:8px; padding:16px 18px; background:var(--g100); border-radius:12px; margin-bottom:20px; }
.perk { display:flex; align-items:center; gap:10px; font-family:var(--body); font-size:.8375rem; color:var(--g600); }
.perk svg { color:var(--primary); flex-shrink:0; width:15px; height:15px; }
/* ── Share ── */
.share-row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-top:4px; }
.share-lbl { font-family:var(--body); font-size:.78rem; color:var(--g400); }
.share-btn { width:34px; height:34px; border-radius:8px; border:1px solid var(--g200); display:flex; align-items:center; justify-content:center; color:var(--g400); transition:all .2s; }
.share-btn:hover { color:var(--primary); border-color:var(--primary); }
/* ── Tabs (Description / Specs / Reviews) ── */
.ptabs-wrap { margin-top:52px; }
.ptabs-nav { display:flex; gap:0; border-bottom:2px solid var(--g200); margin-bottom:32px; overflow-x:auto; }
.ptab-btn { font-family:var(--heading); font-weight:600; font-size:.875rem; color:var(--g400); padding:12px 22px; border-bottom:2.5px solid transparent; margin-bottom:-2px; white-space:nowrap; transition:color .2s,border-color .2s; }
.ptab-btn:hover { color:var(--secondary); }
.ptab-btn.active { color:var(--secondary); border-bottom-color:var(--primary); }
.ptab-panel { display:none; }
.ptab-panel.active { display:block; }
/* ── Description ── */
.prod-desc { font-family:var(--body); font-size:.9375rem; color:var(--g600); line-height:1.8; }
.prod-desc h2,.prod-desc h3 { font-family:var(--heading); color:var(--secondary); margin:20px 0 10px; }
.prod-desc ul,.prod-desc ol { padding-left:1.5em; margin:12px 0; }
.prod-desc li { margin-bottom:6px; }
.prod-desc p  { margin-bottom:12px; }
.prod-desc strong { color:var(--secondary); }
/* ── Specs table ── */
.spec-group { margin-bottom:32px; }
.spec-group-title { font-family:var(--heading); font-weight:700; font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; color:var(--primary); margin-bottom:12px; padding-bottom:8px; border-bottom:1px solid var(--g200); }
.spec-table { width:100%; border-collapse:collapse; }
.spec-table tr { border-bottom:1px solid var(--g100); }
.spec-table tr:last-child { border-bottom:none; }
.spec-table td { padding:11px 14px; font-family:var(--body); font-size:.875rem; vertical-align:top; }
.spec-table td:first-child { color:var(--g400); font-weight:600; width:38%; white-space:nowrap; }
.spec-table td:last-child  { color:var(--g800); }
.spec-table tr.highlighted td { background:rgba(0,152,217,.04); }
.spec-table tr.highlighted td:first-child { color:var(--primary); }
/* ── Reviews ── */
.rev-summary { display:grid; grid-template-columns:auto 1fr; gap:32px; align-items:center; background:var(--g100); border-radius:16px; padding:28px 32px; margin-bottom:36px; }
.rev-big-num { text-align:center; }
.rev-big-num .num { font-family:var(--heading); font-weight:700; font-size:3.5rem; color:var(--secondary); line-height:1; }
.rev-big-num .out { font-family:var(--body); font-size:.8rem; color:var(--g400); }
.rev-big-num .stars { justify-content:center; margin:6px 0; }
.rev-big-num .stars svg { width:16px; height:16px; }
.rev-big-num .count { font-family:var(--body); font-size:.8rem; color:var(--g400); }
.rev-bars { flex:1; display:flex; flex-direction:column; gap:7px; }
.rev-bar-row { display:flex; align-items:center; gap:10px; }
.rev-bar-lbl { font-family:var(--body); font-size:.775rem; color:var(--g600); min-width:42px; font-weight:600; white-space:nowrap; }
.rev-bar-track { flex:1; height:8px; background:var(--g200); border-radius:4px; overflow:hidden; }
.rev-bar-fill { height:100%; background:var(--primary); border-radius:4px; transition:width .4s ease; }
.rev-bar-count { font-family:var(--body); font-size:.72rem; color:var(--g400); min-width:26px; text-align:right; }
.rev-list { display:flex; flex-direction:column; gap:20px; margin-bottom:28px; }
.rev-card { background:var(--white); border:1.5px solid var(--g200); border-radius:14px; padding:22px 24px; }
.rev-card-hd { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:12px; flex-wrap:wrap; }
.rev-card-hd .rev-author { display:flex; align-items:center; gap:10px; }
.rev-av { width:38px; height:38px; border-radius:50%; overflow:hidden; background:var(--g200); flex-shrink:0; }
.rev-av img { width:100%;height:100%;object-fit:cover; }
.rev-name { font-family:var(--heading); font-weight:600; font-size:.875rem; color:var(--secondary); }
.rev-meta { font-family:var(--body); font-size:.72rem; color:var(--g400); margin-top:2px; display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.rev-verified { color:var(--primary); font-weight:600; display:inline-flex; align-items:center; gap:3px; }
.rev-rating { display:flex; flex-direction:column; align-items:flex-end; gap:3px; }
.rev-rating .stars svg { width:13px; height:13px; }
.rev-date { font-family:var(--body); font-size:.72rem; color:var(--g400); }
.rev-title { font-family:var(--heading); font-weight:600; font-size:.925rem; color:var(--secondary); margin-bottom:7px; }
.rev-content { font-family:var(--body); font-size:.875rem; color:var(--g600); line-height:1.7; margin-bottom:12px; }
.rev-pros-cons { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px; }
.rev-pc-box { background:var(--g100); border-radius:8px; padding:10px 13px; }
.rev-pc-box .pc-title { font-family:var(--heading); font-weight:700; font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; margin-bottom:5px; }
.rev-pc-box.pros .pc-title { color:#16a34a; }
.rev-pc-box.cons .pc-title { color:#ef4444; }
.rev-pc-box p { font-family:var(--body); font-size:.8rem; color:var(--g600); line-height:1.5; margin:0; }
.rev-helpful { display:flex; align-items:center; gap:8px; }
.helpful-btn { display:inline-flex; align-items:center; gap:5px; font-family:var(--body); font-size:.78rem; color:var(--g400); transition:color .2s; padding:4px 0; }
.helpful-btn:hover { color:var(--secondary); }
.helpful-btn svg { width:13px; height:13px; }
.rev-empty { text-align:center; padding:40px; color:var(--g400); }
.rev-empty svg { width:44px; height:44px; margin:0 auto 12px; opacity:.3; }
/* Write review */
.write-review { background:var(--g100); border-radius:16px; padding:28px 30px; }
.write-review h3 { margin-bottom:20px; font-size:1.05rem; }
.form-group { margin-bottom:16px; }
.form-label { display:block; font-family:var(--heading); font-weight:600; font-size:.8rem; color:var(--secondary); margin-bottom:6px; }
.form-label .req { color:#ef4444; }
.star-picker { display:flex; gap:6px; margin-bottom:4px; }
.star-picker svg { width:28px; height:28px; color:var(--g300); cursor:pointer; fill:currentColor; transition:color .15s; }
.star-picker svg.lit { color:var(--primary); }
.form-input { width:100%; padding:10px 14px; background:var(--white); border:1.5px solid var(--g200); border-radius:8px; font-family:var(--body); font-size:.875rem; color:var(--g800); outline:none; transition:border-color .2s; }
.form-input:focus { border-color:var(--primary); }
textarea.form-input { resize:vertical; min-height:110px; }
.form-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-check { display:flex; align-items:center; gap:8px; font-family:var(--body); font-size:.8375rem; color:var(--g600); cursor:pointer; }
.form-check input { accent-color:var(--primary); width:16px; height:16px; }
/* ── Related products ── */
.related-section { padding:56px 0; background:var(--off); }
.prod-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.prod-card { background:var(--white); border:1.5px solid var(--g200); border-radius:var(--radius); overflow:hidden; transition:border-color .2s,transform .2s; }
.prod-card:hover { border-color:var(--primary); transform:translateY(-5px); }
.prod-img { position:relative; background:var(--g100); aspect-ratio:4/3; overflow:hidden; }
.prod-img img { width:100%; height:100%; object-fit:contain; padding:16px; transition:transform .4s; }
.prod-card:hover .prod-img img { transform:scale(1.04); }
.prod-badge-sm { position:absolute; top:8px; left:8px; font-family:var(--heading); font-weight:700; font-size:.6rem; letter-spacing:.05em; text-transform:uppercase; padding:3px 8px; border-radius:5px; }
.prod-body { padding:14px 16px; }
.prod-brand { font-family:var(--body); font-size:.68rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--g400); margin-bottom:4px; }
.prod-name { font-family:var(--heading); font-weight:600; font-size:.875rem; color:var(--secondary); margin-bottom:8px; line-height:1.35; }
.prod-name a { color:inherit; }
.prod-card:hover .prod-name a { color:var(--primary); }
.rat-row { display:flex; align-items:center; gap:6px; margin-bottom:10px; }
.rat-row .stars svg { width:11px; height:11px; }
.rat-ct { font-family:var(--body); font-size:.72rem; color:var(--g400); }
.price-row-card { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.price-card-main { font-family:var(--heading); font-weight:700; font-size:.95rem; color:var(--secondary); }
.price-card-old  { font-family:var(--body); font-size:.72rem; color:var(--g400); text-decoration:line-through; margin-top:1px; }
.price-card-sale { color:var(--primary); }
.card-cart-btn { width:32px; height:32px; background:var(--g100); border-radius:7px; display:flex; align-items:center; justify-content:center; color:var(--secondary); transition:background .2s,color .2s; }
.card-cart-btn:hover { background:var(--primary); color:var(--white); }
/* ── Features bar ── */
.feat-bar { border-top:1px solid var(--g200); border-bottom:1px solid var(--g200); }
.feat-grid { display:grid; grid-template-columns:repeat(4,1fr); }
.feat-item { display:flex; align-items:center; gap:14px; padding:28px 24px; border-right:1px solid var(--g200); }
.feat-item:last-child { border-right:none; }
.feat-ic { width:44px; height:44px; background:rgba(0,152,217,.1); border-radius:11px; display:flex; align-items:center; justify-content:center; color:var(--primary); flex-shrink:0; }
.feat-ic svg { width:19px; height:19px; }
.feat-item h4 { font-family:var(--heading); font-weight:600; font-size:.85rem; color:var(--secondary); margin-bottom:2px; }
.feat-item p  { font-family:var(--body); font-size:.75rem; color:var(--g400); line-height:1.5; margin:0; }
/* ── Newsletter ── */
.nl-section { background:var(--secondary); padding:60px 0; position:relative; overflow:hidden; }
.nl-section::before { content:''; position:absolute; top:-80px; right:-80px; width:380px; height:380px; border:2px solid rgba(255,255,255,.04); border-radius:50%; }
.nl-section::after  { content:''; position:absolute; bottom:-100px; left:-60px; width:280px; height:280px; border:2px solid rgba(255,255,255,.04); border-radius:50%; }
.nl-inner { max-width:560px; margin:0 auto; text-align:center; position:relative; z-index:1; }
.nl-tag { display:inline-flex; align-items:center; gap:8px; background:rgba(0,152,217,.15); border:1px solid rgba(0,152,217,.3); color:var(--primary); font-family:var(--heading); font-weight:600; font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; padding:5px 14px; border-radius:100px; margin-bottom:18px; }
.nl-inner h2 { color:var(--white); font-size:clamp(1.5rem,3vw,2rem); margin-bottom:8px; }
.nl-inner h2 .ac { color:var(--primary); }
.nl-inner p { color:rgba(255,255,255,.6); font-size:.875rem; margin-bottom:24px; }
.nl-form { display:flex; gap:10px; max-width:460px; margin:0 auto; }
.nl-form input { flex:1; height:50px; padding:0 18px; background:rgba(255,255,255,.12); border:1.5px solid rgba(255,255,255,.25); border-radius:9px; font-family:var(--body); font-size:.875rem; color:var(--white); outline:none; transition:border-color .2s; min-width:0; }
.nl-form input::placeholder { color:rgba(255,255,255,.45); }
.nl-form input:focus { border-color:var(--primary); }
.nl-form button { height:50px; padding:0 26px; background:var(--primary); color:var(--white); font-family:var(--heading); font-weight:600; font-size:.875rem; border-radius:9px; cursor:pointer; border:none; transition:background .2s; flex-shrink:0; display:flex; align-items:center; }
.nl-form button:hover { background:var(--primary-dk); }
.nl-note { font-family:var(--body); font-size:.7rem; color:rgba(255,255,255,.35); margin-top:10px; }
/* ── Footer ── */
.footer { background:var(--white); border-top:1px solid var(--g200); }
.footer-top { padding:52px 0 40px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:36px; }
.footer-brand p { font-family:var(--body); font-size:.84rem; color:var(--g600); line-height:1.7; margin:12px 0 18px; max-width:270px; }
.soc { display:flex; gap:8px; }
.soc-btn { width:34px; height:34px; border-radius:8px; border:1px solid var(--g200); display:flex; align-items:center; justify-content:center; color:var(--g400); transition:all .2s; }
.soc-btn:hover { border-color:var(--primary); color:var(--primary); }
.footer-col-h { font-family:var(--heading); font-weight:700; font-size:.72rem; color:var(--secondary); letter-spacing:.08em; text-transform:uppercase; margin-bottom:16px; }
.flinks { display:flex; flex-direction:column; gap:9px; }
.flinks a { font-family:var(--body); font-size:.84rem; color:var(--g600); transition:color .2s; }
.flinks a:hover { color:var(--primary); }
.fcontact { display:flex; flex-direction:column; gap:11px; }
.fci { display:flex; align-items:flex-start; gap:10px; }
.fci svg { width:14px; height:14px; color:var(--primary); flex-shrink:0; margin-top:2px; }
.fci span { font-family:var(--body); font-size:.84rem; color:var(--g600); line-height:1.5; }
.fhours { margin-top:14px; }
.fhours p { font-family:var(--body); font-size:.8rem; color:var(--g600); line-height:1.75; margin:0; }
.footer-bottom { border-top:1px solid var(--g200); padding:16px 0; }
.footer-bottom-inner { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.footer-bottom p { font-family:var(--body); font-size:.75rem; color:var(--g400); }
.pay-row { display:flex; align-items:center; gap:6px; }
.pay-row span:first-child { font-family:var(--body); font-size:.72rem; color:var(--g400); }
.pay-badge { padding:3px 9px; background:var(--g100); border:1px solid var(--g200); border-radius:6px; font-family:var(--heading); font-weight:600; font-size:.68rem; color:var(--g600); }
/* ── Utilities ── */
#btt { position:fixed; bottom:24px; right:24px; width:42px; height:42px; background:var(--secondary); color:var(--white); border-radius:50%; display:flex; align-items:center; justify-content:center; z-index:800; opacity:0; transform:translateY(10px); transition:opacity .3s,transform .3s,background .2s; pointer-events:none; }
#btt.show { opacity:1; transform:translateY(0); pointer-events:all; }
#btt:hover { background:var(--primary); }
.toast { position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--secondary); color:var(--white); padding:12px 22px; border-radius:10px; font-family:var(--heading); font-weight:600; font-size:.85rem; z-index:9999; opacity:0; transition:opacity .3s,transform .3s; white-space:nowrap; pointer-events:none; display:flex; align-items:center; gap:10px; }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.success .ti { color:var(--primary); }
.toast.error   .ti { color:#f97316; }
/* ── WhatsApp button ── */
.btn-whatsapp {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 13px 20px;
  background: #25D366;
  color: #fff;
  border-radius: 10px;
  font-family: var(--heading);
  font-weight: 600;
  font-size: .95rem;
  text-decoration: none;
  margin-top: 10px;
  transition: background .2s, transform .15s;
}
.btn-whatsapp:hover {
  background: #1ebe5d;
  transform: translateY(-1px);
}
.btn-whatsapp:active {
  transform: translateY(0);
}
/* ── Responsive ── */
@media(max-width:1100px) {
  .product-grid { gap:32px; }
  .prod-grid { grid-template-columns:repeat(3,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:860px) {
  :root { --hh:60px; --px:18px; }
  .nav-desk,.hdr-search { display:none; }
  .ham { display:flex; }
  .product-grid { grid-template-columns:1fr; }
  .gallery { position:static; }
  .rev-summary { grid-template-columns:1fr; }
  .rev-big-num { display:flex; align-items:center; gap:16px; }
  .rev-pros-cons { grid-template-columns:1fr; }
  .feat-grid { grid-template-columns:1fr 1fr; }
  .feat-item:nth-child(2) { border-right:none; }
  .feat-item:nth-child(3) { border-right:1px solid var(--g200); }
  .feat-item:nth-child(4) { border-right:none; }
  .prod-grid { grid-template-columns:repeat(2,1fr); }
  .nl-form { flex-direction:column; }
  .footer-grid { grid-template-columns:1fr; }
  .form-grid-2 { grid-template-columns:1fr; }
}
@media(max-width:560px) {
  .qty-cta { flex-wrap:wrap; }
  .btn-cart { min-width:100%; }
  .feat-grid { grid-template-columns:1fr; }
  .feat-item { border-right:none; }
  .price-main { font-size:1.6rem; }
  .rev-summary { padding:20px; }
  .write-review { padding:20px; }
}