
  @import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700;900&family=DM+Sans:wght@300;400;500&display=swap');

  :root {
    --bg: #0a0a08;
    --surface: #131310;
    --card: #1a1a16;
    --accent: #d4f028;
    --accent2: #ff6b35;
    --text: #f0ede6;
    --muted: #6b6a62;
    --border: rgba(212,240,40,0.15);
  }

  * { margin:0; padding:0; box-sizing:border-box; }

  body {
    background: var(--bg);
    color: var(--text);
    font-family: 'DM Sans', sans-serif;
    min-height: 100vh;
    overflow-x: hidden;
  }

  /* Subtle grain overlay */
  body::before {
    content:'';
    position:fixed; inset:0; z-index:0; pointer-events:none;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
    opacity: 0.5;
  }

  /* NAV */
  nav {
    position: fixed; top:0; left:0; right:0; z-index:100;
    display:flex; align-items:center; justify-content:space-between;
    padding: 20px 40px;
    background: rgba(10,10,8,0.85);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border);
  }

  .logo {
    font-family: 'Playfair Display', serif;
    font-size: 1.6rem;
    font-weight: 900;
    letter-spacing: -0.03em;
    color: var(--text);
    cursor: pointer;
  }
  .logo span { color: var(--accent); }

  .search-wrap {
    display:flex; gap:8px; align-items:center;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 50px;
    padding: 6px 6px 6px 20px;
    width: 360px;
    transition: border-color 0.2s;
  }
  .search-wrap:focus-within { border-color: var(--accent); }

  .search-wrap input {
    background: none; border:none; outline:none;
    color: var(--text); font-family: 'DM Sans', sans-serif;
    font-size: 0.95rem; flex:1;
  }
  .search-wrap input::placeholder { color: var(--muted); }

  .search-wrap button {
    background: var(--accent); border:none; cursor:pointer;
    border-radius: 50px; padding: 9px 20px;
    font-family: 'DM Sans', sans-serif;
    font-weight: 600; font-size: 0.9rem; color: #0a0a08;
    transition: transform 0.15s, background 0.15s;
    white-space: nowrap;
  }
  .search-wrap button:hover { transform: scale(1.04); background: #e8ff4a; }

  /* HERO */
  .hero {
    padding: 160px 40px 60px;
    position:relative; z-index:1;
    text-align:center;
  }
  .hero-tag {
    display:inline-block;
    background: rgba(212,240,40,0.12);
    border: 1px solid var(--border);
    color: var(--accent);
    font-size: 0.78rem; font-weight:500; letter-spacing:0.12em;
    text-transform:uppercase; padding: 6px 16px; border-radius:50px;
    margin-bottom:20px;
  }
  .hero h1 {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.8rem, 6vw, 5.5rem);
    font-weight:900; line-height:1.05;
    letter-spacing:-0.03em;
    margin-bottom:16px;
  }
  .hero h1 em { font-style:italic; color:var(--accent); }
  .hero p {
    color: var(--muted); font-size:1.05rem; max-width:480px; margin:0 auto 40px;
    line-height:1.7;
  }

  /* SAMPLE CARDS GRID */
  .grid-label {
    padding: 0 40px 20px;
    display:flex; align-items:center; gap:16px;
    position:relative; z-index:1;
  }
  .grid-label h2 {
    font-family:'Playfair Display',serif;
    font-size:1.5rem; font-weight:700;
  }
  .grid-label span {
    width:40px; height:2px; background:var(--accent); display:inline-block;
  }

  .cards-grid {
    display:grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap:20px; padding:0 40px 60px;
    position:relative; z-index:1;
  }

  .recipe-card {
    background: var(--card);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 16px; overflow:hidden;
    cursor:pointer; transition: transform 0.2s, border-color 0.2s, box-shadow 0.2s;
    animation: fadeUp 0.5s ease both;
  }
  .recipe-card:hover {
    transform: translateY(-6px);
    border-color: rgba(212,240,40,0.3);
    box-shadow: 0 20px 40px rgba(0,0,0,0.4);
  }

  @keyframes fadeUp {
    from { opacity:0; transform:translateY(20px); }
    to   { opacity:1; transform:translateY(0); }
  }

  .card-img-wrap {
    position:relative; height:200px; overflow:hidden;
  }
  .card-img-wrap img {
    width:100%; height:100%; object-fit:cover;
    transition: transform 0.4s;
  }
  .recipe-card:hover .card-img-wrap img { transform:scale(1.07); }

  .card-badge {
    position:absolute; top:12px; right:12px;
    background: var(--accent); color:#0a0a08;
    font-size:0.72rem; font-weight:700; text-transform:uppercase;
    letter-spacing:0.08em; padding:4px 10px; border-radius:50px;
  }

  .card-body { padding:16px 18px 20px; }
  .card-body h3 {
    font-family:'Playfair Display',serif;
    font-size:1.25rem; font-weight:700; margin-bottom:6px;
  }
  .card-meta {
    display:flex; gap:14px; color:var(--muted); font-size:0.82rem; margin-bottom:14px;
  }
  .card-meta span { display:flex; align-items:center; gap:4px; }

  .card-btn {
    width:100%; padding:11px;
    background: transparent;
    border: 1px solid var(--border);
    border-radius:10px; color:var(--text);
    font-family:'DM Sans',sans-serif; font-size:0.9rem; font-weight:500;
    cursor:pointer; transition: background 0.2s, border-color 0.2s, color 0.2s;
  }
  .card-btn:hover {
    background: var(--accent); border-color:var(--accent); color:#0a0a08;
  }

  /* POPUP */
  .popup-overlay {
    display:none; position:fixed; inset:0; z-index:200;
    background: rgba(0,0,0,0.7); backdrop-filter:blur(8px);
    align-items:center; justify-content:center;
  }
  .popup-overlay.open { display:flex; }

  .popup {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius:24px; width:min(560px, 92vw);
    max-height:82vh; overflow-y:auto; scrollbar-width:none;
    padding:36px; position:relative;
    animation: popIn 0.25s ease;
  }
  @keyframes popIn {
    from { opacity:0; transform:scale(0.93); }
    to   { opacity:1; transform:scale(1); }
  }

  .popup-close {
    position:absolute; top:18px; right:18px;
    background: rgba(255,255,255,0.08); border:none;
    width:36px; height:36px; border-radius:50%;
    color:var(--text); font-size:1.1rem; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    transition: background 0.2s;
  }
  .popup-close:hover { background: rgba(255,255,255,0.16); }

  .popup img {
    width:100%; border-radius:14px; height:220px; object-fit:cover; margin-bottom:20px;
  }

  .popup h2 {
    font-family:'Playfair Display',serif;
    font-size:2rem; font-weight:900; margin-bottom:10px;
  }

  .popup-section-label {
    font-size:0.72rem; text-transform:uppercase; letter-spacing:0.12em;
    color:var(--accent); font-weight:600; margin: 20px 0 8px;
  }
  .popup p { color: #a0a090; line-height:1.8; font-size:0.95rem; }

  /* EMPTY STATE */
  .empty {
    text-align:center; padding:80px 20px; position:relative; z-index:1;
  }
  .empty .emoji { font-size:4rem; margin-bottom:16px; }
  .empty h2 {
    font-family:'Playfair Display',serif; font-size:2rem; margin-bottom:8px;
  }
  .empty p { color:var(--muted); }

  /* DEMO CARDS DATA */