<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=2560, initial-scale=1">
<title>Amazon - Mock Results</title>
<style>
  :root{
    --nav:#131921;
    --nav2:#232f3e;
    --text:#111;
    --muted:#565959;
    --link:#007185;
    --prime:#232f3e;
    --yellow:#ffd814;
    --yellow-hover:#f7ca00;
    --btn:#ffa41c;
    --star:#fdbd4f;
    --grid-gap:24px;
  }
  *{box-sizing:border-box}
  body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial,sans-serif;color:var(--text);background:#fff}
  a{color:var(--link);text-decoration:none}
  .topbar{
    background:var(--nav);color:#fff;height:68px;display:flex;align-items:center;gap:16px;padding:0 18px;position:sticky;top:0;z-index:50
  }
  .logo{
    font-size:28px;font-weight:700;letter-spacing:.5px;display:flex;align-items:end;line-height:1
  }
  .logo small{font-size:12px;margin-left:6px;color:#ff9900;font-weight:600}
  .deliver{display:flex;align-items:center;font-size:12px;color:#ddd;gap:6px;margin-left:8px;white-space:nowrap}
  .deliver img{filter:invert(1)}
  .searchWrap{flex:1;display:flex;align-items:center}
  .cat{
    background:#eee;color:#111;border:0;border-radius:6px 0 0 6px;padding:10px 12px;font-size:14px
  }
  .search{
    flex:1;border:0;padding:12px 14px;font-size:16px;outline:none
  }
  .searchBtn{
    width:52px;border:0;background:#febd69;border-radius:0 6px 6px 0;display:flex;align-items:center;justify-content:center;cursor:pointer
  }
  .rightTop{display:flex;align-items:center;gap:22px;margin-left:8px}
  .topLink{font-size:12px;color:#eee}
  .cart{display:flex;align-items:center;gap:6px;color:#fff}
  .subbar{background:var(--nav2);color:#fff;height:42px;display:flex;align-items:center;padding:0 18px;gap:20px;font-size:14px}
  .subbar .all{display:flex;align-items:center;gap:8px}
  .page{max-width:1880px;margin:0 auto;padding:18px 22px}
  .resultsLayout{display:grid;grid-template-columns:340px 1fr;gap:18px}
  .sidebar{border-right:1px solid #e6e6e6;padding-right:10px}
  .s-title{font-weight:700;margin:8px 0 6px}
  .brandList label{display:flex;align-items:center;gap:10px;margin:7px 0;font-size:14px;cursor:pointer}
  .clearBtn{color:#555;border:0;background:#f3f3f3;border-radius:16px;padding:6px 10px;font-size:12px;margin:6px 0;cursor:pointer}
  .resultsHeader{display:flex;align-items:end;justify-content:space-between;margin:2px 0 12px}
  .resultsHeader h2{margin:0;font-size:22px;font-weight:700}
  .sort{position:relative;font-size:14px}
  .sortBtn{border:1px solid #ccc;padding:8px 12px;border-radius:8px;background:#fff;cursor:pointer;min-width:180px;text-align:left}
  .sortMenu{position:absolute;right:0;top:42px;background:#fff;border:1px solid #ccc;border-radius:8px;box-shadow:0 6px 18px rgba(0,0,0,.12);display:none;min-width:220px;z-index:3}
  .sortMenu button{display:block;width:100%;text-align:left;background:#fff;border:0;padding:10px 12px;cursor:pointer}
  .sortMenu button:hover{background:#f3f3f3}
  .grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--grid-gap)}
  .card{border:1px solid #e5e7ea;border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:10px;background:#fff;cursor:pointer}
  .card:hover{box-shadow:0 6px 16px rgba(0,0,0,.08)}
  .c-img{display:flex;align-items:center;justify-content:center;height:190px}
  .c-img img{max-width:100%;max-height:100%}
  .title{font-size:15px;line-height:1.35;height:40px;overflow:hidden}
  .rating{font-size:13px;color:#555}
  .stars{color:var(--star);letter-spacing:1px}
  .price{font-size:20px;font-weight:700}
  .addBtn{background:var(--yellow);border:1px solid #f0c14b;border-radius:8px;padding:9px 10px;font-weight:600;cursor:pointer}
  .addBtn:hover{background:var(--yellow-hover)}
  .loadingMask{
    position:fixed;inset:0;background:rgba(255,255,255,.9);display:none;align-items:center;justify-content:center;flex-direction:column;gap:18px;z-index:40
  }
  .loadingMask .spins{display:flex;gap:30px;align-items:center}
  .footer{background:#0f1722;color:#d1d5db;padding:60px 20px;margin-top:60px}
  /* Product detail */
  .detailWrap{display:grid;grid-template-columns:100px 560px 1fr 380px;gap:24px}
  .thumbs{display:flex;flex-direction:column;gap:10px}
  .thumbs img{width:90px;height:90px;object-fit:contain;border:1px solid #e6e6e6;border-radius:8px;background:#fff}
  .bigImage{border:1px solid #e6e6e6;border-radius:10px;height:460px;display:flex;align-items:center;justify-content:center;background:#fff}
  .bigImage img{max-width:100%;max-height:95%}
  .pdTitle{font-size:24px;font-weight:700;line-height:1.3}
  .about{margin-top:14px}
  .about h4{margin:14px 0 8px}
  .about ul{margin:0;padding-left:18px;color:#333}
  .buyBox{border:1px solid #e6e6e6;border-radius:10px;padding:16px;height:max-content;position:sticky;top:90px;background:#fff}
  .qtyRow{display:flex;align-items:center;gap:8px;margin:8px 0}
  .yellow{background:var(--yellow);border:1px solid #f0c14b;border-radius:20px;padding:10px 14px;font-weight:700;width:100%;cursor:pointer}
  .orange{background:var(--btn);border:1px solid #e07a00;border-radius:20px;padding:10px 14px;font-weight:700;width:100%;color:#111;cursor:pointer;margin-top:8px}
  .fbt{margin-top:36px;border-top:1px solid #e6e6e6;padding-top:14px}
  .fbt h3{margin:0 0 12px}
  .fbtRow{display:grid;grid-template-columns:repeat(3, 1fr) auto;align-items:center;gap:18px}
  .fbtItem{border:1px solid #e6e6e6;border-radius:10px;padding:10px;text-align:center}
  .fbtItem img{max-width:100%;max-height:120px}
  /* Added to cart page */
  .addedWrap{max-width:1600px;margin:0 auto}
  .addedTop{display:flex;align-items:center;gap:14px;border:1px solid #e5e7ea;background:#f8fbf4;border-radius:12px;padding:16px;margin:8px 0 22px}
  .addedTop .cta{margin-left:auto;display:flex;gap:12px}
  .btn{border-radius:8px;border:1px solid #c7c7c7;background:#fff;padding:10px 14px;cursor:pointer}
  .btn.primary{background:var(--yellow);border-color:#f0c14b}
  .carousel{margin:26px 0}
  .carousel h3{margin:0 0 12px}
  .rowProducts{display:grid;grid-template-columns:repeat(9,1fr);gap:16px}
  .smallCard{border:1px solid #e6e6e6;border-radius:10px;padding:10px;text-align:center;background:#fff}
  .smallCard img{max-width:100%;max-height:110px}
  .stickyCart{
    position:fixed;top:86px;right:24px;width:320px;border:1px solid #e5e7ea;border-radius:14px;background:#fff;padding:12px;box-shadow:0 6px 18px rgba(0,0,0,.08);display:none
  }
  .stickyCart.show{display:block}
  .scRow{display:flex;gap:10px}
  .qtyCtl{display:flex;align-items:center;gap:10px;margin-top:10px}
  .qtyCtl button{width:32px;height:32px;border-radius:8px;border:1px solid #ccc;background:#f6f6f6;cursor:pointer}
  .subtotal{margin-left:auto;font-weight:700}
</style>
</head>
<body>

<!-- Header -->
<div class="topbar">
  <div class="logo">amazon <small>.mock</small></div>
  <div class="deliver">
    <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/063.png" width="16" height="16" alt="pin">
    Deliver to Singapore
  </div>
  <div class="searchWrap">
    <select class="cat" aria-label="category">
      <option>Computers & Tablets</option>
      <option>All Departments</option>
      <option>Electronics</option>
    </select>
    <input class="search" placeholder="Search Amazon" />
    <button class="searchBtn" title="Search">
      <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/117.bmp" width="22" height="22" alt="search">
    </button>
  </div>
  <div class="rightTop">
    <div class="topLink">EN</div>
    <div class="topLink">
      <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/223.png" width="22" height="22" alt="account"> Hello, sign in
    </div>
    <div class="topLink">Returns & Orders</div>
    <div class="cart">
      <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/107.svg" width="28" height="28" alt="cart">
      Cart
    </div>
  </div>
</div>
<div class="subbar">
  <div class="all">☰ All</div>
  <div>Today's Deals</div>
  <div>Prime Video</div>
  <div>Registry</div>
  <div>Customer Service</div>
  <div>Gift Cards</div>
  <div>Sell</div>
</div>

<!-- Main content -->
<main class="page" id="app"></main>

<!-- Loading mask used between sorts -->
<div class="loadingMask" id="loader">
  <div class="spins">
    <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/065.gif" width="64" height="64" alt="loading">
    <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/119.gif" width="64" height="64" alt="loading">
  </div>
</div>

<!-- Sticky cart for "Added to cart" page -->
<div class="stickyCart" id="stickyCart">
  <div class="scRow">
    <img id="scImg" src="__PLACEHOLDER_ASSETS_BASE_DIR__/089.jpg" width="80" height="80" alt="item">
    <div style="flex:1">
      <div id="scTitle" style="font-weight:600;font-size:14px;line-height:1.2">Item</div>
      <div class="qtyCtl">
        <button id="minus">-</button><span id="qty">1</span><button id="plus">+</button>
        <span class="subtotal" id="scSubtotal">$0.00</span>
      </div>
    </div>
  </div>
</div>

<!-- Footer -->
<div class="footer">
  <div style="max-width:1600px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:24px">
    <div>
      <div style="font-weight:700;margin-bottom:8px">Get to Know Us</div>
      <div>Careers</div><div>Blog</div><div>About Amazon</div><div>Amazon Devices</div>
    </div>
    <div>
      <div style="font-weight:700;margin-bottom:8px">Make Money with Us</div>
      <div>Sell on Amazon</div><div>Become an Affiliate</div><div>Advertise Your Products</div>
    </div>
    <div>
      <div style="font-weight:700;margin-bottom:8px">Amazon Payment Products</div>
      <div>Amazon Business Card</div><div>Shop with Points</div><div>Reload Your Balance</div>
    </div>
    <div>
      <div style="font-weight:700;margin-bottom:8px">Let Us Help You</div>
      <div>Your Account</div><div>Shipping Rates & Policies</div><div>Returns & Replacements</div>
    </div>
  </div>
</div>

<script>
/* ---------- Fake Data (assets-only images) ---------- */
const featuredProducts = [
  {id:'p180', title:'Samsung Galaxy Tab A9+ 11" Android Tablet, Quad Speakers, Upgraded Chipset', price:159.90, img:'180.jpg'},
  {id:'p202', title:'HP 14 Laptop, Intel Celeron N4020, 4GB RAM, 64GB Storage, 14" HD', price:172.20, img:'202.jpg'},
  {id:'p218', title:'HP Chromebook 14 - Intel Celeron N4120, 4GB RAM, 64GB eMMC', price:174.10, img:'218.jpg'},
  {id:'p228', title:'reMarkable Paper Pro Bundle 11.8" Paper Tablet + Marker Plus', price:679.00, img:'228.jpg'},
  {id:'p231', title:'Acer Aspire 3 15.6" Slim Laptop | Ryzen 3 | 8GB | 128GB', price:319.99, img:'231.jpg'},
  {id:'p234', title:'Dell Inspiron Touchscreen Laptop 15.6" Windows 11 Pro', price:389.99, img:'234.jpg'},
  {id:'p244', title:'Lenovo Tab M11 11" Display 4GB RAM 128GB SSD', price:229.00, img:'244.jpg'},
  {id:'p241', title:'HP Pavilion 15.6" HD Touchscreen 16GB RAM 1TB SSD', price:549.99, img:'241.jpg'},
  {id:'p246', title:'Lenovo ThinkPad E16 Gen 1 Business Laptop 16"', price:699.00, img:'246.jpg'},
  {id:'p247', title:'Dell OptiPlex 3060 Desktop Computer Intel i5 | 32GB | 1TB', price:389.00, img:'247.jpg'}
];
const lowToHighProducts = [
  {id:'p089', title:'Lenovo ThinkCentre M700 Tiny Business Micro PC (Renewed)', price:66.94, img:'089.jpg'},
  {id:'p170', title:'Minimal Smart Home Sensor Kit – budget starter', price:80.99, img:'170.jpg'},
  {id:'p244b', title:'Lenovo Tab M8 (4th Gen) 8" Tablet – Family', price:84.00, img:'244.jpg'},
  {id:'p093', title:'Lenovo ThinkStation P300 SFF Desktop PC (Renewed)', price:84.99, img:'093.jpg'},
  {id:'p243', title:'Lenovo ThinkCentre M900 Tiny Business Desktop', price:89.00, img:'243.jpg'},
  {id:'p206', title:'Portable Mini Docking Station USB-C to HDMI/USB/PD', price:23.99, img:'206.jpg'},
  {id:'p242', title:'Amazon Basics DisplayPort 1.4 Cable, 32.4Gbps', price:12.99, img:'242.jpg'},
  {id:'p173', title:'4K DisplayPort to HDMI Adapter 24K Gold', price:6.99, img:'173.jpg'},
  {id:'p174', title:'Gigabit 8‑Port unmanaged switch – compact metal', price:39.99, img:'174.jpg'},
  {id:'p171', title:'USB‑C to HDMI Adapter, Uni‑Directional', price:7.99, img:'171.jpg'}
];

const recommendations = [
  {id:'r1', title:'DisplayPort to HDMI Cable', price:6.95, img:'242.jpg'},
  {id:'r2', title:'DP to HDMI Adapter', price:7.99, img:'171.jpg'},
  {id:'r3', title:'Mini PC Mounting Bracket', price:23.99, img:'099.jpg'},
  {id:'r4', title:'DP to HDMI Plug – Compact', price:3.99, img:'024.jpg'},
  {id:'r5', title:'Highwings DP to HDMI Adapter', price:8.99, img:'034.jpg'},
  {id:'r6', title:'USB Z‑Wave Stick', price:59.99, img:'118.gif'},
  {id:'r7', title:'DP to VGA Adapter', price:5.60, img:'010.jpg'},
  {id:'r8', title:'Wireless Touch TV Keyboard', price:24.99, img:'035.jpg'},
  {id:'r9', title:'Cat6e Patch Cables (5‑pack)', price:5.99, img:'064.png'}
];

const youMayLike = [
  {id:'y1', title:'USB‑C to USB‑A Female Adapter', price:7.99, img:'121.jpg'},
  {id:'y2', title:'2.4GHz Wireless Keyboard and Mouse', price:22.49, img:'036.png'},
  {id:'y3', title:'Mini DisplayPort to HDMI Adapter', price:10.99, img:'118.gif'},
  {id:'y4', title:'RJ45 Cat6 Ethernet Cable 16Gbps', price:11.72, img:'055.png'},
  {id:'y5', title:'Aluminum USB‑C VGA Adapter', price:15.99, img:'102.jpg'},
  {id:'y6', title:'DP 1.4 Cable, High‑Speed', price:12.99, img:'242.jpg'},
  {id:'y7', title:'USB‑C to Ethernet Adapter', price:19.49, img:'064.png'},
  {id:'y8', title:'HP EliteDesk 800 G2 Mini PC', price:109.00, img:'193.jpg'},
  {id:'y9', title:'Tiny Desktop Mount Kit', price:23.99, img:'099.jpg'}
];

/* ---------- State ---------- */
const state = {
  view:'results',             // results | detail | added
  sort:'Featured',
  products:[...featuredProducts],
  selected:null,
  cart:{item:null, qty:1}
};

const $app = document.getElementById('app');
const $loader = document.getElementById('loader');

/* ---------- Utilities ---------- */
function money(n){ return '$' + n.toFixed(2); }
function ratingLine(){
  return `<span class="stars">★★★★★</span> <span style="color:#0f1111">·</span> <span class="rating">10k+ bought in past month</span>`;
}
function productImgTag(img,w=300,h=200,alt='product'){
  return `<img src="__PLACEHOLDER_ASSETS_BASE_DIR__/${img}" width="${w}" height="${h}" alt="${alt}">`;
}

/* ---------- Renderers ---------- */
function renderResults(){
  state.view='results';
  const sidebar = `
    <div class="sidebar">
      <div style="font-size:12px;color:#555">Department</div>
      <div class="s-title">Computers</div>
      <div style="font-size:14px;color:#777;margin-bottom:10px">Computers & Tablets › Electronics</div>

      <div class="s-title">Brands</div>
      <button class="clearBtn" id="clearBrands">Clear</button>
      <div class="brandList" id="brandList">
        ${['Lenovo','Apple','Samsung','HP','ASUS','Dell','acer'].map(b=>{
          const checked = (b==='Lenovo'||b==='Apple') ? 'checked' : '';
          return `<label><input type="checkbox" ${checked} data-brand="${b}"> ${b}</label>`;
        }).join('')}
      </div>

      <div class="s-title">Deals & Discounts</div>
      <label style="display:flex;gap:10px;align-items:center;font-size:14px"><input type="checkbox"> Today’s Deals</label>

      <div class="s-title">Top Brands in Electronics</div>
      <label style="display:flex;gap:10px;align-items:center;font-size:14px"><input type="checkbox"> Top Brands</label>
    </div>
  `;

  const grid = state.products.map(p=>`
    <div class="card" data-id="${p.id}">
      <div class="c-img">${productImgTag(p.img,300,200,p.title)}</div>
      <div class="title">${p.title}</div>
      <div class="rating">${ratingLine()}</div>
      <div class="price">${money(p.price)}</div>
      <button class="addBtn" data-id="${p.id}">Add to cart</button>
    </div>
  `).join('');

  const sortMenu = `
    <div class="sort">
      <button class="sortBtn" id="sortBtn">Sort by: ${state.sort}</button>
      <div class="sortMenu" id="sortMenu">
        ${['Featured','Price: Low to High','Price: High to Low','Avg. Customer Review','Newest Arrivals','Best Sellers'].map(s=>`
          <button data-sort="${s}">${s}</button>
        `).join('')}
      </div>
    </div>
  `;

  const results = `
    <div class="resultsLayout">
      ${sidebar}
      <div>
        <div class="resultsHeader">
          <h2>Results</h2>
          ${sortMenu}
        </div>
        <div class="grid" id="grid">${grid}</div>
      </div>
    </div>
  `;

  $app.innerHTML = results;
  bindResultsEvents();
}

function renderDetail(p){
  state.view='detail';
  state.selected = p;
  const thumbs = [p.img,'089.jpg','093.jpg','099.jpg','173.jpg'].map(t=>`
    <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/${t}" width="90" height="90" alt="thumb">
  `).join('');
  const detail = `
    <div class="detailWrap">
      <div class="thumbs">${thumbs}</div>
      <div class="bigImage">${productImgTag(p.img,560,460,p.title)}</div>
      <div>
        <div class="pdTitle">${p.title}</div>
        <div class="rating" style="margin:8px 0">${ratingLine()}</div>
        <div style="font-size:22px;font-weight:700;margin:6px 0">${money(p.price)}</div>
        <div class="about">
          <h4>About this item</h4>
          <ul>
            <li>This is a mock product page built for a front‑end coding challenge.</li>
            <li>All logic is client‑side; no network requests are performed.</li>
            <li>Images are placeholders coming from the provided stitched asset set.</li>
            <li>Buttons and selectors mimic the look & feel of the original site.</li>
          </ul>
        </div>

        <div class="fbt">
          <h3>Frequently bought together</h3>
          <div class="fbtRow">
            ${[p, recommendations[1], recommendations[2]].map((x,i)=>`
              <div class="fbtItem">
                ${productImgTag(i===0?p.img:x.img,180,120,'fbt')}
                <div style="font-weight:600;margin-top:6px">${money(i===0?p.price:x.price)}</div>
              </div>
            `).join('')}
            <button class="yellow" id="addAll">Total price: ${money(p.price + recommendations[1].price + recommendations[2].price)} · Add all 3 to Cart</button>
          </div>
        </div>
      </div>

      <div class="buyBox">
        <div style="font-size:26px;font-weight:700">${money(p.price)}</div>
        <div style="color:#0f1111;font-size:14px;margin:6px 0">Free delivery to Singapore</div>
        <div class="qtyRow">Qty:
          <select id="qtySel">
            ${[...Array(10)].map((_,i)=>`<option value="${i+1}">${i+1}</option>`).join('')}
          </select>
        </div>
        <button class="yellow" id="addToCartDetail">Add to Cart</button>
        <button class="orange">Buy Now</button>
        <div style="margin-top:10px">
          <label style="display:flex;align-items:center;gap:8px"><input type="checkbox"> Add a gift receipt for easy returns</label>
        </div>
      </div>
    </div>
  `;
  $app.innerHTML = detail;

  document.getElementById('addToCartDetail').onclick=()=>{
    const q = parseInt(document.getElementById('qtySel').value,10);
    addToCart(p,q);
  };
  document.getElementById('addAll').onclick=()=>{
    addToCart(p,1);
  };
}

function renderAddedToCart(){
  state.view='added';
  const p = state.cart.item;
  const top = `
    <div class="addedWrap">
      <div class="addedTop">
        ${productImgTag(p.img,80,60,p.title)}
        <img src="__PLACEHOLDER_ASSETS_BASE_DIR__/045.svg" width="28" height="28" alt="check">
        <div style="font-weight:700">Added to cart</div>
        <div class="cta">
          <button class="btn primary">Proceed to checkout</button>
          <button class="btn">Go to Cart</button>
        </div>
      </div>

      <div class="carousel">
        <h3>Customers who bought this item also bought</h3>
        <div class="rowProducts">
          ${recommendations.map(r=>`
            <div class="smallCard">
              ${productImgTag(r.img,160,110,r.title)}
              <div style="font-size:12px;height:36px;overflow:hidden;margin-top:6px">${r.title}</div>
              <div style="font-weight:700;margin:4px 0">${money(r.price)}</div>
              <button class="addBtn" data-id="${r.id}" data-price="${r.price}">Add to cart</button>
            </div>
          `).join('')}
        </div>
      </div>

      <div class="carousel">
        <h3>Featured items you may like</h3>
        <div class="rowProducts">
          ${youMayLike.map(r=>`
            <div class="smallCard">
              ${productImgTag(r.img,160,110,r.title)}
              <div style="font-size:12px;height:36px;overflow:hidden;margin-top:6px">${r.title}</div>
              <div style="font-weight:700;margin:4px 0">${money(r.price)}</div>
              <button class="addBtn" data-id="${r.id}" data-price="${r.price}">Add to cart</button>
            </div>
          `).join('')}
        </div>
      </div>
    </div>
  `;
  $app.innerHTML = top;

  // Show sticky mini cart
  const sc = document.getElementById('stickyCart');
  sc.classList.add('show');
  document.getElementById('scImg').src = `__PLACEHOLDER_ASSETS_BASE_DIR__/${p.img}`;
  document.getElementById('scTitle').textContent = p.title;
  document.getElementById('qty').textContent = state.cart.qty;
  updateStickySubtotal();

  document.getElementById('plus').onclick = ()=>{ state.cart.qty++; document.getElementById('qty').textContent = state.cart.qty; updateStickySubtotal(); };
  document.getElementById('minus').onclick = ()=>{ state.cart.qty=Math.max(1,state.cart.qty-1); document.getElementById('qty').textContent = state.cart.qty; updateStickySubtotal(); };
}

function updateStickySubtotal(){
  const price = state.cart.item.price * state.cart.qty;
  document.getElementById('scSubtotal').textContent = money(price);
}

/* ---------- Event Bindings ---------- */
function bindResultsEvents(){
  const sortBtn = document.getElementById('sortBtn');
  const sortMenu = document.getElementById('sortMenu');
  sortBtn.onclick = ()=> sortMenu.style.display = sortMenu.style.display==='block' ? 'none' : 'block';
  document.addEventListener('click', e=>{
    if(!sortBtn.contains(e.target) && !sortMenu.contains(e.target)){
      sortMenu.style.display='none';
    }
  });
  sortMenu.querySelectorAll('button').forEach(b=>{
    b.onclick = ()=>{
      sortMenu.style.display='none';
      const val = b.dataset.sort;
      if(val===state.sort) return;
      state.sort = val;
      sortBtn.textContent = 'Sort by: ' + state.sort;
      // fake load
      $loader.style.display='flex';
      setTimeout(()=>{
        if(val==='Price: Low to High'){
          state.products=[...lowToHighProducts];
        }else if(val==='Price: High to Low'){
          state.products=[...featuredProducts].sort((a,b)=>b.price-a.price);
        }else{
          state.products=[...featuredProducts];
        }
        $loader.style.display='none';
        renderResults();
        window.scrollTo(0,0);
      }, 900);
    };
  });

  // Product selection and add buttons
  document.getElementById('grid').onclick=(e)=>{
    const id = e.target.dataset.id || e.target.closest('.card')?.dataset.id;
    if(!id) return;
    const p = [...featuredProducts, ...lowToHighProducts].find(x=>x.id===id);
    if(e.target.classList.contains('addBtn')){
      addToCart(p,1);
    }else{
      renderDetail(p);
    }
  };

  // Brand filters (visual only)
  document.getElementById('clearBrands').onclick=()=>{
    document.querySelectorAll('#brandList input[type="checkbox"]').forEach(cb=>cb.checked=false);
  };
}

function addToCart(p, qty){
  state.cart.item = p;
  state.cart.qty = qty;
  renderAddedToCart();
}

/* ---------- Start ---------- */
renderResults();
</script>
</body>
</html>