/* WeirdGifts.co — Dark, quirky, mobile-first */
:root {
  --bg: #0d0d1a;
  --surface: #161628;
  --surface2: #1e1e36;
  --accent: #f59e0b;
  --accent2: #8b5cf6;
  --text: #e4e4e7;
  --text-dim: #9ca3af;
  --radius: 14px;
  --max-w: 1100px;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
body { font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background:var(--bg); color:var(--text); min-height:100vh; line-height:1.6; }
a { color:var(--accent); text-decoration:none; }
a:hover { text-decoration:underline; }
img { max-width:100%; display:block; }

/* NAV */
.nav { background:var(--surface); border-bottom:1px solid #ffffff10; position:sticky; top:0; z-index:100; }
.nav-inner { max-width:var(--max-w); margin:0 auto; padding:14px 20px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.nav-logo { font-size:1.4rem; font-weight:800; color:#fff; }
.nav-logo span { color:var(--accent); }
.nav-links { display:flex; gap:20px; align-items:center; font-size:.95rem; }
.nav-links a { color:var(--text-dim); transition:color .2s; }
.nav-links a:hover { color:var(--accent); text-decoration:none; }
.ai-badge { display:inline-flex; align-items:center; gap:6px; background:linear-gradient(135deg,var(--accent2),var(--accent)); color:#000; font-weight:700; font-size:.75rem; padding:4px 12px; border-radius:20px; }

/* HERO */
.hero { text-align:center; padding:60px 20px 40px; max-width:var(--max-w); margin:0 auto; }
.hero h1 { font-size:clamp(2rem,5vw,3.2rem); font-weight:800; margin-bottom:.5rem; }
.hero h1 span { color:var(--accent); }
.hero p { color:var(--text-dim); font-size:1.1rem; max-width:560px; margin:0 auto; }

/* SECTION */
.section { max-width:var(--max-w); margin:0 auto; padding:0 20px 50px; }
.section-title { font-size:1.5rem; font-weight:700; margin-bottom:24px; display:flex; align-items:center; gap:10px; }

/* PRODUCT GRID */
.product-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:24px; }
.card { background:var(--surface); border-radius:var(--radius); overflow:hidden; transition:transform .2s, box-shadow .2s; display:flex; flex-direction:column; }
.card:hover { transform:translateY(-4px); box-shadow:0 12px 32px #0008; }
.card-img { width:100%; aspect-ratio:3/2; object-fit:contain; background:#fff; padding:8px; border-radius:var(--radius) var(--radius) 0 0; }
.card-body { padding:20px; flex:1; display:flex; flex-direction:column; }
.card-body h3 { font-size:1.15rem; margin-bottom:6px; }
.card-body h3 a { color:#fff; }
.card-body h3 a:hover { color:var(--accent); text-decoration:none; }
.weirdness { color:var(--accent); font-size:.85rem; margin-bottom:8px; }
.card-body .desc { color:var(--text-dim); font-size:.92rem; flex:1; margin-bottom:12px; }
.card-meta { display:flex; align-items:center; justify-content:space-between; margin-top:auto; }
.price { font-weight:700; color:var(--accent); font-size:1.05rem; }
.tags { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:12px; }
.tag { background:var(--surface2); padding:3px 10px; border-radius:20px; font-size:.78rem; color:var(--text-dim); }
.btn { display:inline-block; background:var(--accent); color:#000; font-weight:700; padding:10px 20px; border-radius:8px; font-size:.9rem; text-align:center; transition:background .2s; }
.btn:hover { background:#d97706; text-decoration:none; }
.btn-sm { padding:8px 16px; font-size:.82rem; }

/* CATEGORIES */
.cat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:14px; }
.cat-card { background:var(--surface); border-radius:var(--radius); padding:20px; text-align:center; transition:transform .2s; }
.cat-card:hover { transform:translateY(-3px); }
.cat-card .icon { font-size:2rem; margin-bottom:6px; }
.cat-card .label { font-size:.9rem; color:var(--text); }

/* FOOTER */
.footer { background:var(--surface); border-top:1px solid #ffffff10; padding:40px 20px; margin-top:40px; }
.footer-inner { max-width:var(--max-w); margin:0 auto; text-align:center; }
.footer-inner p { color:var(--text-dim); font-size:.88rem; margin:6px 0; }
.footer-links { display:flex; justify-content:center; gap:20px; flex-wrap:wrap; margin-bottom:16px; }
.footer-links a { color:var(--text-dim); font-size:.88rem; }
.footer-links a:hover { color:var(--accent); }
.disclosure { font-size:.75rem; color:#666; max-width:600px; margin:16px auto 0; }

/* PRODUCT PAGE */
.product-hero { max-width:var(--max-w); margin:0 auto; padding:30px 20px; display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; }
.product-hero-img { border-radius:var(--radius); width:100%; aspect-ratio:3/2; object-fit:contain; background:#fff; padding:12px; }
.product-info h1 { font-size:1.8rem; margin-bottom:8px; }
.product-info .weirdness { font-size:1rem; margin-bottom:12px; }
.product-info .price { font-size:1.4rem; margin-bottom:16px; display:block; }
.product-info .desc { color:var(--text-dim); margin-bottom:20px; }
.why-picked { background:var(--surface2); border-left:4px solid var(--accent); padding:16px 20px; border-radius:0 var(--radius) var(--radius) 0; margin:24px 0; }
.why-picked h3 { font-size:.95rem; color:var(--accent); margin-bottom:6px; }
.why-picked p { color:var(--text-dim); font-size:.9rem; }
.breadcrumb { max-width:var(--max-w); margin:0 auto; padding:16px 20px; font-size:.85rem; color:var(--text-dim); }
.breadcrumb a { color:var(--text-dim); }
.related { max-width:var(--max-w); margin:0 auto; padding:20px 20px 50px; }
.related h2 { font-size:1.3rem; margin-bottom:20px; }
@media(max-width:700px){
  .product-hero { grid-template-columns:1fr; }
  .product-grid { grid-template-columns:1fr; }
}

/* Mobile menu - added 2026-02-16 - MUST come after other media queries */
@media (max-width: 768px) {
  .menu-toggle {
    display: block !important;
  }
  
  nav .container {
    position: relative;
  }
  
  .nav-links {
    display: none !important;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--surface);
    flex-direction: column !important;
    gap: 0 !important;
    padding: 0;
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
    z-index: 1000;
  }
  
  .nav-links.open {
    display: flex !important;
  }
  
  .nav-links a {
    padding: 16px 20px;
    border-bottom: 1px solid #ffffff10;
    display: block;
    width: 100%;
    font-size: 0.95rem !important;
  }
}
