Spaces:
Sleeping
Sleeping
| import gradio as gr | |
| b64 = "<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8"/>
  <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0"/>
  <title>NourishNet</title>
  <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap" rel="stylesheet">
  <style>
    *{box-sizing:border-box;margin:0;padding:0;scroll-behavior:smooth}
    body{font-family:'Inter',sans-serif;background:#F7F5F0;color:#1a1a1a;overflow-x:hidden;min-width:100%;width:100%}
    .grad{background:linear-gradient(120deg,#1D9E75 0%,#0a7a52 60%,#38c98a 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

    /* NAV */
    nav{display:flex;align-items:center;justify-content:space-between;padding:18px 48px;background:#1D9E75;position:sticky;top:0;z-index:100;border-bottom:1px solid #0a6350}
    .logo{font-size:21px;font-weight:700;color:#fff;cursor:pointer;letter-spacing:-0.01em}
    .nav-links{display:flex;gap:32px}
    .nav-link{font-size:14px;color:#d0f5e8;cursor:pointer;transition:color 0.2s;font-weight:500}
    .nav-link:hover{color:#fff}
    .nav-cta{font-size:13px;color:#1D9E75;background:#fff;border:none;border-radius:8px;padding:9px 20px;cursor:pointer;font-weight:700;transition:background 0.2s,transform 0.1s}
    .nav-cta:hover{background:#d0f5e8;transform:translateY(-1px)}

    /* PAGES */
    .page{display:none;animation:fadeIn 0.4s ease}
    .page.active{display:block}
    @keyframes fadeIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

    /* HERO */
    .hero{padding:100px 48px 84px;text-align:center;max-width:820px;margin:0 auto}
    .hero-eyebrow{font-size:12px;color:#0F6E56;background:#dff4ec;display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;margin-bottom:26px;font-weight:600;letter-spacing:0.04em;border:1px solid #b6e8d3}
    .dot{width:7px;height:7px;border-radius:50%;background:#1D9E75;animation:pulse 2s infinite}
    @keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(1.5)}}
    .hero h1{font-size:54px;font-weight:700;line-height:1.15;margin-bottom:24px;letter-spacing:-0.025em;color:#111}
    .hero p{font-size:18px;color:#5a5a5a;line-height:1.8;max-width:520px;margin:0 auto 42px}
    .hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
    .btn-primary{background:#1D9E75;color:#fff;font-size:15px;font-weight:600;padding:15px 32px;border-radius:10px;border:none;cursor:pointer;transition:background 0.2s,transform 0.15s;font-family:'Inter',sans-serif}
    .btn-primary:hover{background:#0a6350;transform:translateY(-2px)}
    .btn-outline{background:transparent;color:#1D9E75;font-size:15px;font-weight:600;padding:15px 32px;border-radius:10px;border:1.5px solid #1D9E75;cursor:pointer;transition:all 0.2s;font-family:'Inter',sans-serif}
    .btn-outline:hover{background:#dff4ec;transform:translateY(-2px)}
    .hero-sub{font-size:12px;color:#b0a898;margin-top:16px}

    /* STATS */
    .stats-bar{display:grid;grid-template-columns:repeat(4,1fr);background:#1D9E75}
    .stat{padding:36px 20px;text-align:center;border-right:1px solid #0a6350}
    .stat:last-child{border-right:none}
    .stat-val{font-size:32px;font-weight:700;color:#fff}
    .stat-lbl{font-size:13px;color:#d0f5e8;margin-top:6px;font-weight:500}

    /* SECTIONS */
    .section{padding:84px 48px;max-width:1020px;margin:0 auto}
    .section-label{font-size:12px;color:#999;text-align:center;margin-bottom:12px;letter-spacing:0.1em;text-transform:uppercase;font-weight:600}
    .section-title{font-size:36px;font-weight:700;text-align:center;margin-bottom:14px;letter-spacing:-0.015em;color:#111}
    .section-sub{font-size:16px;color:#666;text-align:center;margin-bottom:52px;line-height:1.75;max-width:560px;margin-left:auto;margin-right:auto}
    .grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
    .grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
    .card{background:#fff;border:1px solid #e4e0d8;border-radius:16px;padding:32px 26px;transition:border-color 0.2s,transform 0.2s}
    .card:hover{border-color:#1D9E75;transform:translateY(-4px)}
    .card-icon{width:48px;height:48px;border-radius:12px;background:#dff4ec;display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:22px}
    .card-title{font-size:17px;font-weight:700;margin-bottom:10px;color:#111}
    .card-desc{font-size:14px;color:#666;line-height:1.75}

    /* ROUTING */
    .routing-section{background:#eeeae2;padding:84px 48px;border-top:1px solid #e4e0d8;border-bottom:1px solid #e4e0d8}
    .routing-inner{max-width:920px;margin:0 auto}
    .routing-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:28px;align-items:center;margin-top:52px}
    .routing-col{display:flex;flex-direction:column;gap:12px}
    .routing-card{background:#fff;border:1px solid #e4e0d8;border-radius:12px;padding:14px 16px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:12px;transition:border-color 0.2s;color:#1a1a1a}
    .routing-card:hover{border-color:#1D9E75}
    .rinfo{font-size:12px;color:#888;font-weight:400;margin-top:2px}
    .routing-mid{display:flex;flex-direction:column;align-items:center;gap:10px}
    .ai-box{background:#1D9E75;color:#fff;border-radius:14px;padding:22px 16px;text-align:center;font-weight:700;font-size:14px;width:118px}
    .ai-sub{font-size:11px;font-weight:400;opacity:0.75;margin-top:5px}
    .arrow{font-size:22px;color:#1D9E75;font-weight:700}

    /* CTA BANNER */
    .cta-section{margin:0 48px 84px;background:#1D9E75;border-radius:24px;padding:68px 48px;text-align:center}
    .cta-title{font-size:36px;font-weight:700;margin-bottom:14px;color:#fff;letter-spacing:-0.01em}
    .cta-sub{font-size:16px;color:#d0f5e8;margin-bottom:32px;line-height:1.75}
    .cta-btn{background:#fff;color:#1D9E75;font-size:15px;font-weight:700;padding:15px 32px;border-radius:10px;border:none;cursor:pointer;transition:background 0.2s,transform 0.15s;font-family:'Inter',sans-serif}
    .cta-btn:hover{background:#d0f5e8;transform:translateY(-2px)}

    /* DASHBOARD */
    .dash-header{background:#1D9E75;padding:28px 48px;display:flex;align-items:center;justify-content:space-between}
    .dash-header h2{font-size:20px;font-weight:700;color:#fff}
    .dash-header p{font-size:13px;color:#d0f5e8;margin-top:2px}
    .dash-body{max-width:1020px;margin:0 auto;padding:40px 48px}
    .metric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}
    .metric-card{background:#fff;border:1px solid #e4e0d8;border-radius:14px;padding:24px;text-align:center}
    .metric-val{font-size:32px;font-weight:700;color:#1D9E75}
    .metric-lbl{font-size:13px;color:#888;margin-top:6px;font-weight:500}
    .dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
    .dash-card{background:#fff;border:1px solid #e4e0d8;border-radius:14px;padding:24px}
    .dash-card-title{font-size:12px;font-weight:700;color:#999;text-transform:uppercase;letter-spacing:0.07em;margin-bottom:16px}
    .badge{display:inline-block;font-size:11px;padding:3px 10px;border-radius:20px;font-weight:600}
    .badge-green{background:#dff4ec;color:#0F6E56}
    .badge-amber{background:#FAEEDA;color:#854F0B}
    .badge-blue{background:#E6F1FB;color:#185FA5}
    .badge-coral{background:#FAECE7;color:#993C1D}
    .progress{height:8px;border-radius:4px;background:#e4e0d8;margin-top:10px;overflow:hidden}
    .progress-fill{height:100%;border-radius:4px;background:#1D9E75;transition:width 0.6s ease}

    /* FORM */
    .form-page{max-width:720px;margin:0 auto;padding:48px}
    .form-label{font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:0.07em;margin-bottom:8px;display:block}
    select,input[type=range]{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #e4e0d8;font-size:14px;background:#fff;color:#1a1a1a;margin-bottom:20px;font-family:'Inter',sans-serif}
    input[type=range]{padding:6px 0;accent-color:#1D9E75}
    .ai-rec-box{background:#f0fdf8;border:1px solid #9FE1CB;border-radius:12px;padding:16px 18px;font-size:14px;color:#085041;line-height:1.7;margin-bottom:20px}
    .recipient-card{border:1px solid #e4e0d8;border-radius:12px;padding:16px;margin-bottom:12px;display:flex;align-items:center;gap:14px;cursor:pointer;background:#fff;transition:border-color 0.2s,background 0.2s}
    .recipient-card.selected{border-color:#1D9E75;background:#f0fdf8}
    .r-icon{width:44px;height:44px;border-radius:50%;background:#dff4ec;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}

    /* CONFIRM */
    .confirm-page{max-width:600px;margin:0 auto;padding:60px 48px;text-align:center}
    .success-circle{width:88px;height:88px;border-radius:50%;background:#dff4ec;display:flex;align-items:center;justify-content:center;font-size:44px;margin:0 auto 24px}
    .tracker{background:#fff;border:1px solid #e4e0d8;border-radius:14px;padding:28px;margin:28px 0;text-align:left}
    .track-step{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px}
    .track-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
    .tdone{background:#dff4ec;color:#0F6E56}
    .tactive{background:#FAEEDA;color:#854F0B}
    .tpending{background:#eee;color:#bbb}
    .tconnect{width:2px;height:20px;background:#e4e0d8;margin:3px 0 3px 13px}

    /* IMPACT */
    .impact-page{max-width:1020px;margin:0 auto;padding:48px}
    .bar-row{margin-bottom:16px}
    .bar-label{display:flex;justify-content:space-between;font-size:14px;font-weight:600;color:#111;margin-bottom:6px}
    .bar-track{height:10px;border-radius:5px;background:#e4e0d8;overflow:hidden}
    .bar-fill{height:100%;border-radius:5px;transition:width 0.8s ease}

    /* LEADERBOARD */
    .lb-page{max-width:800px;margin:0 auto;padding:48px}
    .city-tabs{display:flex;gap:8px;margin-bottom:28px}
    .city-tab{padding:8px 20px;border-radius:8px;border:1.5px solid #e4e0d8;background:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s;font-family:'Inter',sans-serif;color:#666}
    .city-tab.active{background:#1D9E75;color:#fff;border-color:#1D9E75}
    .lb-row{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid #f0ede6;transition:background 0.2s}
    .lb-row.me{background:#f0fdf8;border-radius:10px;border-bottom:none;margin:4px 0}
    .lb-rank{font-size:15px;font-weight:700;color:#ccc;width:24px}
    .lb-rank.gold{color:#BA7517}
    .lb-rank.silver{color:#888}
    .lb-rank.me-rank{color:#1D9E75}
    .lb-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}

    /* ABOUT */
    .about-hero-banner{background:#1D9E75;padding:80px 48px 72px;text-align:center}
    .about-hero-banner h1{font-size:48px;font-weight:700;color:#fff;letter-spacing:-0.025em;line-height:1.15;margin-bottom:20px}
    .about-hero-banner p{font-size:17px;color:#9FE1CB;max-width:540px;margin:0 auto;line-height:1.8}
    .stat-strip{display:grid;grid-template-columns:repeat(3,1fr);background:#F7F5F0;border-bottom:1px solid #e4e0d8}
    .stat-block{padding:40px 20px;text-align:center;border-right:1px solid #e4e0d8}
    .stat-block:last-child{border-right:none}
    .stat-big{font-size:36px;font-weight:700;color:#1D9E75;margin-bottom:6px}
    .stat-small{font-size:13px;color:#888;font-weight:500}
    .compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
    .compare-card{background:#fff;border:1px solid #e4e0d8;border-radius:16px;padding:28px}
    .compare-card.featured{border:2px solid #1D9E75}
    .compare-row{display:flex;gap:10px;align-items:center;font-size:14px;margin-bottom:10px}

    /* FOOTER */
    footer{padding:28px 48px;background:#1D9E75;display:flex;align-items:center;justify-content:space-between;border-top:1px solid #0a6350}
    .footer-logo{font-size:16px;font-weight:700;color:#fff}
    .footer-links{display:flex;gap:20px}
    .footer-link{font-size:13px;color:#d0f5e8;cursor:pointer;transition:color 0.2s}
    .footer-link:hover{color:#fff}
    .footer-text{font-size:12px;color:#d0f5e8}

    @media(max-width:640px){
      nav{padding:14px 20px}
      .nav-links{display:none}
      .hero{padding:56px 20px 48px}
      .hero h1{font-size:32px}
      .stats-bar{grid-template-columns:repeat(2,1fr)}
      .section{padding:56px 20px}
      .grid-3,.grid-2{grid-template-columns:1fr}
      .routing-grid{grid-template-columns:1fr}
      .cta-section{margin:0 20px 56px;padding:40px 24px}
      .dash-body,.form-page,.impact-page,.lb-page{padding:24px 20px}
      .dash-grid,.metric-grid{grid-template-columns:1fr}
      .compare-grid{grid-template-columns:1fr}
      footer{padding:20px;flex-direction:column;gap:10px;text-align:center}
      .about-hero-banner{padding:56px 20px}
      .about-hero-banner h1{font-size:30px}
      .stat-strip{grid-template-columns:1fr}
    }
  </style>
</head>
<body>

<nav>
  <div class="logo" onclick="showPage('home')">NourishNet</div>
  <div class="nav-links">
    <span class="nav-link" onclick="showPage('home')">Home</span>
    <span class="nav-link" onclick="document.getElementById('how').scrollIntoView({behavior:'smooth'});showPage('home')">How it works</span>
    <span class="nav-link" onclick="showPage('about')">About</span>
    <span class="nav-link" onclick="showPage('leaderboard')">Leaderboard</span>
  </div>
  <button class="nav-cta" onclick="showPage('dashboard')">Restaurant dashboard</button>
</nav>

<!-- ═══════════════ HOME ═══════════════ -->
<div class="page active" id="page-home">
  <section class="hero">
    <div class="hero-eyebrow"><span class="dot"></span> Live in UAE · Powered by AI</div>
    <h1>Turn tonight's surplus<br>into <span class="grad">tomorrow's meal</span></h1>
    <p>3.27 million tons of food wasted in the UAE every year. NourishNet automatically routes your surplus to elderly homes, refugee centers, and families in need.</p>
    <div class="hero-btns">
      <button class="btn-primary" onclick="showPage('dashboard')">Go to dashboard</button>
      <button class="btn-outline" onclick="document.getElementById('how').scrollIntoView({behavior:'smooth'})">See how it works</button>
    </div>
    <div class="hero-sub">Free to join · No technical setup · Takes 2 minutes</div>
  </section>

  <div class="stats-bar">
    <div class="stat"><div class="stat-val" id="c1">0</div><div class="stat-lbl">Meals saved</div></div>
    <div class="stat"><div class="stat-val" id="c2">0</div><div class="stat-lbl">Restaurants</div></div>
    <div class="stat"><div class="stat-val" id="c3">0</div><div class="stat-lbl">CO₂ avoided</div></div>
    <div class="stat"><div class="stat-val" id="c4">0</div><div class="stat-lbl">Communities</div></div>
  </div>

  <section class="section" id="how">
    <div class="section-label">How it works</div>
    <div class="section-title">Three steps. <span class="grad">Zero waste.</span></div>
    <div class="section-sub">No complicated setup. No manual coordination. Just surplus food reaching people who need it.</div>
    <div class="grid-3">
      <div class="card"><div class="card-icon">📋</div><div class="card-title">Log your surplus</div><div class="card-desc">Tell us what food you have, the quantity, and when it expires. Our simple form takes under 30 seconds.</div></div>
      <div class="card"><div class="card-icon">🤖</div><div class="card-title">AI routes it instantly</div><div class="card-desc">Our AI analyzes food type, quantity, expiry, and location to match surplus with the perfect recipient community.</div></div>
      <div class="card"><div class="card-icon">🚗</div><div class="card-title">Volunteer delivers it</div><div class="card-desc">A verified volunteer picks up and delivers. You get a live tracker and confirmed impact report when done.</div></div>
    </div>
  </section>

  <div class="routing-section">
    <div class="routing-inner">
      <div class="section-label">Smart routing engine</div>
      <div class="section-title">Right food. <span class="grad">Right people.</span></div>
      <div class="section-sub">Quantity and food type determine who gets the food — not chance.</div>
      <div class="routing-grid">
        <div class="routing-col">
          <div style="font-size:12px;font-weight:700;color:#999;margin-bottom:6px;letter-spacing:0.06em;text-transform:uppercase">Donors</div>
          <div class="routing-card"><span style="font-size:20px">🍽️</span><div><div>Al Baik Restaurant</div><div class="rinfo">60 portions · halal · 4hrs</div></div></div>
          <div class="routing-card"><span style="font-size:20px">🥖</span><div><div>Sunset Bakery</div><div class="rinfo">120 bread loaves · 2hrs</div></div></div>
          <div class="routing-card"><span style="font-size:20px">🏨</span><div><div>Grand Hyatt Hotel</div><div class="rinfo">200 portions · varied · today</div></div></div>
        </div>
        <div class="routing-mid">
          <div class="arrow">→</div>
          <div class="ai-box">🤖 AI<div class="ai-sub">Matches in seconds</div></div>
          <div class="arrow">→</div>
        </div>
        <div class="routing-col">
          <div style="font-size:12px;font-weight:700;color:#999;margin-bottom:6px;letter-spacing:0.06em;text-transform:uppercase">Recipients</div>
          <div class="routing-card"><span style="font-size:20px">🧓</span><div><div>Al Qasba Elderly Home</div><div class="rinfo">Needs 40–80 · halal ✓</div></div></div>
          <div class="routing-card"><span style="font-size:20px">🛖</span><div><div>Sharjah Refugee Center</div><div class="rinfo">Needs 100+ · any food</div></div></div>
          <div class="routing-card"><span style="font-size:20px">👨‍👩‍👧</span><div><div>Low-income Families</div><div class="rinfo">Flexible · neighborhood</div></div></div>
        </div>
      </div>
    </div>
  </div>

  <section class="section">
    <div class="section-label">Gamification</div>
    <div class="section-title">Donate. Earn. <span class="grad">Compete.</span></div>
    <div class="section-sub">Every donation earns points, badges, and public recognition — turning sustainability into a brand advantage.</div>
    <div class="grid-3">
      <div class="card"><div class="card-icon">🏆</div><div class="card-title">City leaderboard</div><div class="card-desc">Compete with restaurants across Dubai and Sharjah. Top donors get featured on Google Maps and press coverage.</div></div>
      <div class="card"><div class="card-icon">🔥</div><div class="card-title">Donation streaks</div><div class="card-desc">Donate 7 days in a row and earn the Community Hero badge. Keep going for Zero Waste Champion status.</div></div>
      <div class="card"><div class="card-icon">📊</div><div class="card-title">Impact dashboard</div><div class="card-desc">See exactly who you fed, how much CO₂ you saved, and receive real messages from recipient communities.</div></div>
    </div>
  </section>

  <section class="cta-section">
    <div class="cta-title">Ready to make an impact?</div>
    <div class="cta-sub">Join 186 restaurants already feeding communities across the UAE.<br>Free, takes 2 minutes, first pickup is same-day.</div>
    <button class="cta-btn" onclick="showPage('dashboard')">Go to dashboard →</button>
  </section>

  <footer>
    <div class="footer-logo">NourishNet</div>
    <div class="footer-links">
      <span class="footer-link" onclick="showPage('home')">Home</span>
      <span class="footer-link" onclick="showPage('dashboard')">Dashboard</span>
      <span class="footer-link" onclick="showPage('leaderboard')">Leaderboard</span>
      <span class="footer-link" onclick="showPage('about')">About</span>
    </div>
    <div class="footer-text">UAE · 2025 · Partnered with UAE Food Bank & Ne'ma</div>
  </footer>
</div>

<!-- ═══════════════ DASHBOARD ═══════════════ -->
<div class="page" id="page-dashboard">
  <div class="dash-header">
    <div>
      <h2>Al Baik Restaurant</h2>
      <p>Dubai · Member since Jan 2025</p>
    </div>
    <div style="display:flex;gap:10px;align-items:center">
      <span class="badge badge-green">● Active</span>
      <button class="nav-cta" onclick="showPage('log')">+ Log surplus</button>
    </div>
  </div>
  <div class="dash-body">
    <div style="font-size:13px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:0.07em;margin-bottom:16px">This week's impact</div>
    <div class="metric-grid">
      <div class="metric-card"><div class="metric-val">142</div><div class="metric-lbl">Meals saved</div></div>
      <div class="metric-card"><div class="metric-val">38kg</div><div class="metric-lbl">CO₂ avoided</div></div>
      <div class="metric-card"><div class="metric-val">720</div><div class="metric-lbl">Points earned</div></div>
    </div>
    <div class="dash-grid">
      <div class="dash-card">
        <div class="dash-card-title">AI prediction — tonight</div>
        <div style="display:flex;align-items:center;justify-content:space-between;margin-bottom:12px">
          <div><div style="font-size:16px;font-weight:700;color:#111">~60 surplus portions</div><div style="font-size:13px;color:#888;margin-top:2px">Lamb kofta · expires in 5 hrs</div></div>
          <span class="badge badge-amber">Urgent</span>
        </div>
        <div style="height:1px;background:#f0f0f0;margin:14px 0"></div>
        <div style="font-size:12px;color:#888;margin-bottom:10px;font-weight:500">Best AI match</div>
        <div style="display:flex;align-items:center;gap:12px;margin-bottom:16px">
          <div style="width:40px;height:40px;border-radius:50%;background:#dff4ec;display:flex;align-items:center;justify-content:center;font-size:18px">🏠</div>
          <div><div style="font-size:14px;font-weight:600;color:#111">Al Qasba Elderly Home</div><div style="font-size:12px;color:#888">2.1 km · capacity 80 · halal ✓</div></div>
        </div>
        <button class="btn-primary" style="width:100%;padding:12px" onclick="showPage('log')">Log surplus & route →</button>
      </div>
      <div>
        <div class="dash-card" style="margin-bottom:16px">
          <div class="dash-card-title">Donation streak</div>
          <div style="display:flex;align-items:center;justify-content:space-between;margin-bottom:8px">
            <div style="font-size:18px;font-weight:700;color:#111">🔥 7 days</div>
            <span class="badge badge-blue">Community Hero</span>
          </div>
          <div class="progress"><div class="progress-fill" style="width:70%"></div></div>
          <div style="font-size:12px;color:#aaa;margin-top:8px">3 more days → Zero Waste Champion</div>
        </div>
        <div class="dash-card">
          <div class="dash-card-title">Quick actions</div>
          <div style="display:flex;flex-direction:column;gap:10px">
            <button class="btn-primary" style="padding:11px" onclick="showPage('log')">+ Log surplus now</button>
            <button class="btn-outline" style="padding:11px" onclick="showPage('impact')">View impact report</button>
            <button class="btn-outline" style="padding:11px" onclick="showPage('leaderboard')">See leaderboard</button>
          </div>
        </div>
      </div>
    </div>
  </div>
  <footer>
    <div class="footer-logo">NourishNet</div>
    <div class="footer-links">
      <span class="footer-link" onclick="showPage('home')">Home</span>
      <span class="footer-link" onclick="showPage('dashboard')">Dashboard</span>
      <span class="footer-link" onclick="showPage('impact')">Impact</span>
      <span class="footer-link" onclick="showPage('leaderboard')">Leaderboard</span>
    </div>
    <div class="footer-text">UAE · 2025</div>
  </footer>
</div>

<!-- ═══════════════ LOG SURPLUS ═══════════════ -->
<div class="page" id="page-log">
  <div class="dash-header">
    <div><h2>Log surplus food</h2><p>Takes under 30 seconds</p></div>
    <button class="nav-cta" onclick="showPage('dashboard')">← Back</button>
  </div>
  <div class="form-page">
    <label class="form-label">Food type</label>
    <select id="food-type" onchange="updateRouting()">
      <option>Cooked meals (halal)</option>
      <option>Baked goods / bread</option>
      <option>Raw produce</option>
      <option>Packaged / dry goods</option>
    </select>

    <label class="form-label">Number of portions: <span id="qty-val" style="color:#1D9E75;font-weight:700">60</span></label>
    <input type="range" min="1" max="250" value="60" step="1" id="qty-slider" oninput="updateQty(this.value)">

    <label class="form-label">Expires in</label>
    <select id="expiry" onchange="updateRouting()">
      <option>Less than 2 hours</option>
      <option selected>2–6 hours</option>
      <option>Same day</option>
      <option>Tomorrow</option>
    </select>

    <div style="height:1px;background:#e4e0d8;margin:8px 0 20px"></div>
    <div style="font-size:13px;font-weight:700;color:#1D9E75;margin-bottom:10px">🤖 AI recommendation</div>
    <div class="ai-rec-box" id="ai-rec">
      Based on 60 halal portions expiring in 2–6 hrs: best match is an <strong>elderly care home</strong> within 3km. Nutritional profile suits soft-meal needs.
    </div>

    <div style="font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:0.07em;margin-bottom:12px">Matched recipients</div>
    <div id="recipients">
      <div class="recipient-card selected" onclick="selectRecipient(this)">
        <div class="r-icon">🏠</div>
        <div style="flex:1"><div style="font-size:14px;font-weight:600;color:#111" id="r1-name">Al Qasba Elderly Home</div><div style="font-size:12px;color:#888;margin-top:2px">2.1 km · halal ✓ · capacity 40–80</div></div>
        <span class="badge badge-green">Best match</span>
      </div>
      <div class="recipient-card" onclick="selectRecipient(this)">
        <div class="r-icon" style="background:#E6F1FB">🛖</div>
        <div style="flex:1"><div style="font-size:14px;font-weight:600;color:#111" id="r2-name">Sharjah Refugee Center</div><div style="font-size:12px;color:#888;margin-top:2px">4.3 km · halal ✓ · capacity 100–200</div></div>
      </div>
      <div class="recipient-card" onclick="selectRecipient(this)">
        <div class="r-icon" style="background:#FAEEDA">👨‍👩‍👧</div>
        <div style="flex:1"><div style="font-size:14px;font-weight:600;color:#111" id="r3-name">Al Nahda Families</div><div style="font-size:12px;color:#888;margin-top:2px">3.6 km · any food · flexible capacity</div></div>
      </div>
    </div>
    <button class="btn-primary" style="width:100%;padding:14px;margin-top:8px;font-size:15px" onclick="showPage('confirm')">Confirm donation →</button>
    <button class="btn-outline" style="width:100%;padding:14px;margin-top:10px" onclick="showPage('dashboard')">Cancel</button>
  </div>
</div>

<!-- ═══════════════ CONFIRM ═══════════════ -->
<div class="page" id="page-confirm">
  <div class="confirm-page">
    <div class="success-circle">✓</div>
    <div style="font-size:24px;font-weight:700;color:#1D9E75;margin-bottom:8px">Pickup scheduled!</div>
    <div style="font-size:15px;color:#888;margin-bottom:8px">Volunteer confirmed · ETA 35 minutes</div>
    <div class="tracker">
      <div class="track-step"><div class="track-dot tdone">✓</div><div><div style="font-size:14px;font-weight:600;color:#111">Surplus logged</div><div style="font-size:12px;color:#888;margin-top:2px">60 portions · halal cooked meals</div></div></div>
      <div class="tconnect"></div>
      <div class="track-step"><div class="track-dot tdone">✓</div><div><div style="font-size:14px;font-weight:600;color:#111">AI matched recipient</div><div style="font-size:12px;color:#888;margin-top:2px">Al Qasba Elderly Home · 2.1km away</div></div></div>
      <div class="tconnect"></div>
      <div class="track-step"><div class="track-dot tactive">→</div><div><div style="font-size:14px;font-weight:600;color:#111">Volunteer en route</div><div style="font-size:12px;color:#888;margin-top:2px">Ahmed K. · pickup at 8:30 PM</div></div></div>
      <div class="tconnect"></div>
      <div class="track-step"><div class="track-dot tpending">4</div><div><div style="font-size:14px;font-weight:600;color:#bbb">Delivery confirmed</div><div style="font-size:12px;color:#ccc;margin-top:2px">Pending</div></div></div>
    </div>
    <div style="background:#fff;border:1px solid #e4e0d8;border-radius:14px;padding:22px;margin-bottom:24px;text-align:left">
      <div style="font-size:11px;font-weight:700;color:#999;text-transform:uppercase;letter-spacing:0.07em;margin-bottom:12px">Points earned</div>
      <div style="display:flex;align-items:center;justify-content:space-between">
        <div style="font-size:20px;font-weight:700;color:#111">+120 points</div>
        <span class="badge badge-green">Streak +1 🔥</span>
      </div>
      <div style="font-size:13px;color:#888;margin-top:6px">Total: 840 pts · Rank #3 in Dubai</div>
    </div>
    <button class="btn-primary" style="width:100%;padding:14px;font-size:15px;margin-bottom:10px" onclick="showPage('dashboard')">Back to dashboard</button>
    <button class="btn-outline" style="width:100%;padding:14px" onclick="showPage('impact')">View my impact →</button>
  </div>
</div>

<!-- ═══════════════ IMPACT ═══════════════ -->
<div class="page" id="page-impact">
  <div class="dash-header">
    <div><h2>Your impact</h2><p>Al Baik Restaurant · All time</p></div>
    <button class="nav-cta" onclick="showPage('dashboard')">← Dashboard</button>
  </div>
  <div class="impact-page">
    <div class="metric-grid" style="margin-bottom:32px">
      <div class="metric-card"><div class="metric-val">1,240</div><div class="metric-lbl">Total meals saved</div></div>
      <div class="metric-card"><div class="metric-val">312kg</div><div class="metric-lbl">CO₂ avoided</div></div>
      <div class="metric-card"><div class="metric-val">AED 4,200</div><div class="metric-lbl">Disposal costs saved</div></div>
    </div>
    <div class="dash-grid">
      <div>
        <div class="dash-card" style="margin-bottom:20px">
          <div class="dash-card-title">Who you've fed</div>
          <div class="bar-row">
            <div class="bar-label"><span>🧓 Elderly homes</span><span style="color:#1D9E75">48%</span></div>
            <div class="bar-track"><div class="bar-fill" style="width:48%;background:#1D9E75"></div></div>
          </div>
          <div class="bar-row">
            <div class="bar-label"><span>🛖 Refugee centers</span><span style="color:#185FA5">31%</span></div>
            <div class="bar-track"><div class="bar-fill" style="width:31%;background:#185FA5"></div></div>
          </div>
          <div class="bar-row">
            <div class="bar-label"><span>👨‍👩‍👧 Low-income families</span><span style="color:#BA7517">21%</span></div>
            <div class="bar-track"><div class="bar-fill" style="width:21%;background:#BA7517"></div></div>
          </div>
        </div>
        <div class="dash-card">
          <div class="dash-card-title">Latest message from recipient</div>
          <div style="font-size:14px;color:#333;line-height:1.75;font-style:italic">"Your Monday surplus fed 47 elderly residents at Al Qasba Care Home, saving 12kg of CO₂ and providing a warm halal meal to people who needed it most."</div>
          <div style="font-size:12px;color:#1D9E75;margin-top:10px;font-weight:600">— Al Qasba Elderly Home · 2 days ago</div>
        </div>
      </div>
      <div class="dash-card">
        <div class="dash-card-title">Badges earned</div>
        <div style="display:flex;flex-direction:column;gap:14px">
          <div style="display:flex;align-items:center;gap:14px;padding:14px;background:#dff4ec;border-radius:10px">
            <span style="font-size:28px">🏆</span>
            <div><div style="font-size:14px;font-weight:700;color:#085041">Community Hero</div><div style="font-size:12px;color:#1D9E75;margin-top:2px">7-day donation streak achieved</div></div>
          </div>
          <div style="display:flex;align-items:center;gap:14px;padding:14px;background:#E6F1FB;border-radius:10px">
            <span style="font-size:28px">⭐</span>
            <div><div style="font-size:14px;font-weight:700;color:#0C447C">1,000 Meals</div><div style="font-size:12px;color:#185FA5;margin-top:2px">Over 1,000 meals donated</div></div>
          </div>
          <div style="display:flex;align-items:center;gap:14px;padding:14px;background:#FAEEDA;border-radius:10px">
            <span style="font-size:28px">🌱</span>
            <div><div style="font-size:14px;font-weight:700;color:#633806">Top Donor Dubai</div><div style="font-size:12px;color:#854F0B;margin-top:2px">Ranked #3 in Dubai this month</div></div>
          </div>
          <div style="display:flex;align-items:center;gap:14px;padding:14px;background:#FAECE7;border-radius:10px">
            <span style="font-size:28px">🔥</span>
            <div><div style="font-size:14px;font-weight:700;color:#712B13">Streak Master</div><div style="font-size:12px;color:#993C1D;margin-top:2px">Donated 30 days in a row</div></div>
          </div>
        </div>
      </div>
    </div>
  </div>
  <footer>
    <div class="footer-logo">NourishNet</div>
    <div class="footer-links">
      <span class="footer-link" onclick="showPage('home')">Home</span>
      <span class="footer-link" onclick="showPage('dashboard')">Dashboard</span>
      <span class="footer-link" onclick="showPage('leaderboard')">Leaderboard</span>
    </div>
    <div class="footer-text">UAE · 2025</div>
  </footer>
</div>

<!-- ═══════════════ LEADERBOARD ═══════════════ -->
<div class="page" id="page-leaderboard">
  <div class="dash-header">
    <div><h2>City leaderboard 🏆</h2><p>Top restaurants by meals donated</p></div>
    <button class="nav-cta" onclick="showPage('home')">← Home</button>
  </div>
  <div class="lb-page">
    <div class="city-tabs">
      <button class="city-tab active" onclick="switchCity(this,'dubai')">Dubai</button>
      <button class="city-tab" onclick="switchCity(this,'sharjah')">Sharjah</button>
      <button class="city-tab" onclick="switchCity(this,'abudhabi')">Abu Dhabi</button>
    </div>

    <div style="background:#fff;border:1px solid #e4e0d8;border-radius:16px;padding:8px 0;margin-bottom:28px">
      <div class="lb-row"><div class="lb-rank gold">1</div><div class="lb-avatar" style="background:#FAEEDA">🍽️</div><div style="flex:1"><div style="font-size:15px;font-weight:600;color:#111">Ravi's Kitchen</div><div style="font-size:12px;color:#888;margin-top:2px">2,340 meals · 580kg CO₂</div></div><span class="badge badge-amber">Champion 🥇</span></div>
      <div class="lb-row"><div class="lb-rank silver">2</div><div class="lb-avatar" style="background:#dff4ec">🌿</div><div style="flex:1"><div style="font-size:15px;font-weight:600;color:#111">Green Feast</div><div style="font-size:12px;color:#888;margin-top:2px">1,980 meals · 494kg CO₂</div></div><span class="badge badge-green">Hero</span></div>
      <div class="lb-row me"><div class="lb-rank me-rank">3</div><div class="lb-avatar" style="background:#dff4ec;border:2px solid #1D9E75">🍖</div><div style="flex:1"><div style="font-size:15px;font-weight:600;color:#1D9E75">Al Baik (You)</div><div style="font-size:12px;color:#1D9E75;margin-top:2px">1,240 meals · 312kg CO₂</div></div><span class="badge badge-green">You ✦</span></div>
      <div class="lb-row"><div class="lb-rank">4</div><div class="lb-avatar" style="background:#f0f0f0">🥗</div><div style="flex:1"><div style="font-size:15px;font-weight:600;color:#111">Salad Days</div><div style="font-size:12px;color:#888;margin-top:2px">980 meals · 245kg CO₂</div></div></div>
      <div class="lb-row" style="border-bottom:none"><div class="lb-rank">5</div><div class="lb-avatar" style="background:#f0f0f0">🍜</div><div style="flex:1"><div style="font-size:15px;font-weight:600;color:#111">Noodle House</div><div style="font-size:12px;color:#888;margin-top:2px">740 meals · 185kg CO₂</div></div></div>
    </div>

    <div class="dash-card" style="margin-bottom:28px">
      <div class="dash-card-title">Your next milestone</div>
      <div style="font-size:16px;font-weight:600;color:#111;margin-bottom:8px">740 more meals to reach #2</div>
      <div class="progress"><div class="progress-fill" style="width:62%"></div></div>
      <div style="font-size:12px;color:#aaa;margin-top:8px">Keep donating daily to climb the ranks</div>
    </div>

    <div style="font-size:15px;font-weight:700;color:#111;margin-bottom:16px">Badge tiers</div>
    <div class="grid-3">
      <div style="background:#dff4ec;border-radius:12px;padding:18px;text-align:center">
        <div style="font-size:28px;margin-bottom:8px">🏅</div>
        <div style="font-size:14px;font-weight:700;color:#085041">Community Hero</div>
        <div style="font-size:12px;color:#1D9E75;margin-top:4px">7-day streak</div>
      </div>
      <div style="background:#FAEEDA;border-radius:12px;padding:18px;text-align:center">
        <div style="font-size:28px;margin-bottom:8px">🥇</div>
        <div style="font-size:14px;font-weight:700;color:#633806">Zero Waste Champion</div>
        <div style="font-size:12px;color:#854F0B;margin-top:4px">Top city donor</div>
      </div>
      <div style="background:#E6F1FB;border-radius:12px;padding:18px;text-align:center">
        <div style="font-size:28px;margin-bottom:8px">⭐</div>
        <div style="font-size:14px;font-weight:700;color:#0C447C">1,000 Meals</div>
        <div style="font-size:12px;color:#185FA5;margin-top:4px">1,000+ donated</div>
      </div>
    </div>
  </div>
  <footer>
    <div class="footer-logo">NourishNet</div>
    <div class="footer-links">
      <span class="footer-link" onclick="showPage('home')">Home</span>
      <span class="footer-link" onclick="showPage('dashboard')">Dashboard</span>
      <span class="footer-link" onclick="showPage('about')">About</span>
    </div>
    <div class="footer-text">UAE · 2025</div>
  </footer>
</div>

<!-- ═══════════════ ABOUT ═══════════════ -->
<div class="page" id="page-about">
  <div class="about-hero-banner">
    <div style="font-size:12px;color:#9FE1CB;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;margin-bottom:14px">Our mission</div>
    <h1>No food left behind<br>in the UAE</h1>
    <p>NourishNet was built to close one of the Gulf's most pressing gaps — 3.27 million tons wasted every year, while thousands go without a meal.</p>
  </div>

  <div class="stat-strip">
    <div class="stat-block"><div class="stat-big">3.27M</div><div class="stat-small">Tons wasted in UAE yearly</div></div>
    <div class="stat-block"><div class="stat-big">60%</div><div class="stat-small">Food wasted during Ramadan</div></div>
    <div class="stat-block"><div class="stat-big">$3.5B</div><div class="stat-small">Annual economic cost</div></div>
  </div>

  <div style="max-width:900px;margin:0 auto;padding:80px 48px;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center">
    <div>
      <div style="font-size:12px;font-weight:700;color:#1D9E75;letter-spacing:0.08em;text-transform:uppercase;margin-bottom:14px">Why we built this</div>
      <div style="font-size:28px;font-weight:700;color:#111;line-height:1.3;margin-bottom:18px">A problem hiding in plain sight</div>
      <p style="font-size:15px;color:#555;line-height:1.85;margin-bottom:16px">Dubai wastes 38% of prepared food daily. Every evening, restaurants throw away perfectly good meals while elderly residents, refugee families, and low-income households nearby go without.</p>
      <p style="font-size:15px;color:#555;line-height:1.85">Existing solutions are manual and one-size-fits-all. NourishNet's AI matches food intelligently — every single time.</p>
    </div>
    <div style="display:flex;flex-direction:column;gap:14px">
      <div style="background:#fff;border-left:4px solid #1D9E75;border-radius:0 12px 12px 0;padding:18px 20px;border:1px solid #e4e0d8">
        <div style="font-size:22px;font-weight:700;color:#1D9E75;margin-bottom:4px">38%</div>
        <div style="font-size:13px;color:#555;line-height:1.6">of prepared food wasted daily in Dubai alone</div>
      </div>
      <div style="background:#fff;border-left:4px solid #185FA5;border-radius:0 12px 12px 0;padding:18px 20px;border:1px solid #e4e0d8">
        <div style="font-size:22px;font-weight:700;color:#185FA5;margin-bottom:4px">80–90%</div>
        <div style="font-size:13px;color:#555;line-height:1.6">of UAE food is imported — every wasted meal is a double loss</div>
      </div>
      <div style="background:#fff;border-left:4px solid #BA7517;border-radius:0 12px 12px 0;padding:18px 20px;border:1px solid #e4e0d8">
        <div style="font-size:22px;font-weight:700;color:#BA7517;margin-bottom:4px">50%</div>
        <div style="font-size:13px;color:#555;line-height:1.6">UAE national target to reduce food waste by 2030</div>
      </div>
    </div>
  </div>

  <div style="background:#eeeae2;padding:80px 48px;border-top:1px solid #e4e0d8;border-bottom:1px solid #e4e0d8">
    <div style="max-width:860px;margin:0 auto">
      <div class="section-label">What makes us different</div>
      <div class="section-title" style="margin-bottom:48px">Not just redistribution. <span class="grad">Smart redistribution.</span></div>
      <div class="compare-grid">
        <div class="compare-card">
          <div style="font-size:13px;font-weight:700;color:#999;margin-bottom:16px;text-transform:uppercase;letter-spacing:0.06em">Other platforms</div>
          <div class="compare-row"><span style="color:#E24B4A;font-weight:700;font-size:16px">✗</span><span style="font-size:14px;color:#666">Manual donor-recipient matching</span></div>
          <div class="compare-row"><span style="color:#E24B4A;font-weight:700;font-size:16px">✗</span><span style="font-size:14px;color:#666">One-size-fits-all distribution</span></div>
          <div class="compare-row"><span style="color:#E24B4A;font-weight:700;font-size:16px">✗</span><span style="font-size:14px;color:#666">No dietary or cultural filters</span></div>
          <div class="compare-row"><span style="color:#E24B4A;font-weight:700;font-size:16px">✗</span><span style="font-size:14px;color:#666">No impact tracking for donors</span></div>
          <div class="compare-row"><span style="color:#E24B4A;font-weight:700;font-size:16px">✗</span><span style="font-size:14px;color:#666">No incentives for restaurants</span></div>
        </div>
        <div class="compare-card featured">
          <div style="font-size:13px;font-weight:700;color:#1D9E75;margin-bottom:16px;text-transform:uppercase;letter-spacing:0.06em">NourishNet</div>
          <div class="compare-row"><span style="color:#1D9E75;font-weight:700;font-size:16px">✓</span><span style="font-size:14px;color:#111">AI-powered smart matching</span></div>
          <div class="compare-row"><span style="color:#1D9E75;font-weight:700;font-size:16px">✓</span><span style="font-size:14px;color:#111">Quantity-based recipient routing</span></div>
          <div class="compare-row"><span style="color:#1D9E75;font-weight:700;font-size:16px">✓</span><span style="font-size:14px;color:#111">Halal, dietary & cultural matching</span></div>
          <div class="compare-row"><span style="color:#1D9E75;font-weight:700;font-size:16px">✓</span><span style="font-size:14px;color:#111">Full impact dashboard per donor</span></div>
          <div class="compare-row"><span style="color:#1D9E75;font-weight:700;font-size:16px">✓</span><span style="font-size:14px;color:#111">Gamification, badges & leaderboard</span></div>
        </div>
      </div>
    </div>
  </div>

  <section class="section">
    <div class="section-label">Our partners</div>
    <div class="section-title">Built with the <span class="grad">right people</span></div>
    <div class="section-sub">We partnered with the organisations already doing the work on the ground.</div>
    <div class="grid-3">
      <div class="card" style="text-align:center">
        <div style="width:56px;height:56px;border-radius:14px;background:#dff4ec;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 16px">🏦</div>
        <div class="card-title">UAE Food Bank</div>
        <div class="card-desc">Primary distribution partner. Handles last-mile delivery to families and shelters across all seven Emirates.</div>
      </div>
      <div class="card" style="text-align:center">
        <div style="width:56px;height:56px;border-radius:14px;background:#dff4ec;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 16px">🌿</div>
        <div class="card-title">Ne'ma Initiative</div>
        <div class="card-desc">UAE's national food waste reduction initiative, targeting 50% reduction by 2030. We're aligned with their roadmap.</div>
      </div>
      <div class="card" style="text-align:center">
        <div style="width:56px;height:56px;border-radius:14px;background:#dff4ec;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 16px">🤖</div>
        <div class="card-title">Groq AI</div>
        <div class="card-desc">Powers the intelligent routing engine that matches surplus to communities in real time with ultra-low latency.</div>
      </div>
    </div>
  </section>

  <section class="cta-section">
    <div class="cta-title">Join the movement</div>
    <div class="cta-sub">186 restaurants are already making a difference across the UAE.<br>Your surplus can feed someone tonight.</div>
    <button class="cta-btn" onclick="showPage('dashboard')">Go to dashboard →</button>
  </section>

  <footer>
    <div class="footer-logo">NourishNet</div>
    <div class="footer-links">
      <span class="footer-link" onclick="showPage('home')">Home</span>
      <span class="footer-link" onclick="showPage('dashboard')">Dashboard</span>
      <span class="footer-link" onclick="showPage('leaderboard')">Leaderboard</span>
      <span class="footer-link" onclick="showPage('about')">About</span>
    </div>
    <div class="footer-text">UAE · 2025 · Partnered with UAE Food Bank & Ne'ma</div>
  </footer>
</div>

<script>
  function showPage(id) {
    document.querySelectorAll('.page').forEach(p => p.classList.remove('active'));
    document.getElementById('page-' + id).classList.add('active');
    window.scrollTo({top:0,behavior:'smooth'});
  }

  function selectRecipient(el) {
    document.querySelectorAll('.recipient-card').forEach(c => c.classList.remove('selected'));
    el.classList.add('selected');
  }

  function updateQty(val) {
    document.getElementById('qty-val').textContent = val;
    updateRouting();
  }

  function updateRouting() {
    const qty = parseInt(document.getElementById('qty-slider').value);
    const food = document.getElementById('food-type').value;
    const expiry = document.getElementById('expiry').value;
    let rec, r1, r2, r3;
    if (qty <= 15) {
      rec = `Small batch of <strong>${qty} portions</strong> — best routed to <strong>homebound elderly individuals</strong> nearby. Quick pickup, minimal logistics needed.`;
      r1 = '🏠 Al Qasba Elderly Home'; r2 = '👨‍👩‍👧 Al Nahda Families'; r3 = '🏠 Deira Elderly Care';
    } else if (qty <= 80) {
      rec = `<strong>${qty} portions</strong> of ${food.toLowerCase()} expiring <strong>${expiry.toLowerCase()}</strong> — best match is an <strong>elderly care home</strong>. Volume and nutritional profile align well.`;
      r1 = '🏠 Al Qasba Elderly Home'; r2 = '🛖 Sharjah Refugee Center'; r3 = '👨‍👩‍👧 Al Nahda Families';
    } else if (qty <= 150) {
      rec = `<strong>${qty} portions</strong> — volume suits a <strong>refugee center</strong> or large community shelter. Multiple families can benefit from this batch.`;
      r1 = '🛖 Sharjah Refugee Center'; r2 = '👨‍👩‍👧 Al Nahda Families'; r3 = '🏠 Al Qasba Elderly Home';
    } else {
      rec = `Large batch of <strong>${qty} portions</strong> — route to <strong>UAE Food Bank</strong> or a large NGO with storage capacity to redistribute efficiently.`;
      r1 = '🏛️ UAE Food Bank'; r2 = '🛖 Sharjah Refugee Center'; r3 = '🌍 Dubai NGO Network';
    }
    document.getElementById('ai-rec').innerHTML = rec;
    document.getElementById('r1-name').textContent = r1;
    document.getElementById('r2-name').textContent = r2;
    document.getElementById('r3-name').textContent = r3;
  }

  function switchCity(el, city) {
    document.querySelectorAll('.city-tab').forEach(t => t.classList.remove('active'));
    el.classList.add('active');
  }

  function animateCounter(id, target, suffix) {
    const el = document.getElementById(id);
    if (!el) return;
    let current = 0;
    const step = Math.ceil(target / 60);
    const timer = setInterval(() => {
      current = Math.min(current + step, target);
      el.textContent = current.toLocaleString() + suffix;
      if (current >= target) clearInterval(timer);
    }, 24);
  }


  // Report height to parent for iframe auto-resize
  function reportHeight() {
    window.parent.postMessage({height: document.body.scrollHeight}, '*');
  }
  window.addEventListener('load', reportHeight);
  window.addEventListener('resize', reportHeight);
  // Report after page switches
  const origShowPage = showPage;
  function showPage(id) {
    origShowPage(id);
    setTimeout(reportHeight, 100);
  }

  window.addEventListener('load', () => {
    animateCounter('c1', 14200, '');
    animateCounter('c2', 186, '');
    animateCounter('c3', 3800, 'kg');
    animateCounter('c4', 42, '');
  });
</script>
</body>
</html>
"""

with gr.Blocks(css="""
  .gradio-container{padding:0!important;margin:0!important;max-width:100%!important}
  footer{display:none!important}
  #component-0{padding:0!important}
 """

# Write to a temp HTML file and serve via iframe
def get_app():
    return html_content

with gr.Blocks(css="""
  .gradio-container{padding:0!important;margin:0!important;max-width:100%!important}
  footer{display:none!important}
  #component-0{padding:0!important}
  iframe{width:100%;border:none;height:100vh}" | |
| iframe_html = f''' | |
| <style> | |
| .gradio-container {{padding:0!important;margin:0!important;max-width:100%!important;min-height:0!important}} | |
| footer.svelte-1ax1toq {{display:none!important}} | |
| footer {{display:none!important}} | |
| #component-0 {{padding:0!important;margin:0!important}} | |
| .wrap {{padding:0!important}} | |
| iframe {{display:block;width:100%;height:100vh;border:none;overflow:hidden}} | |
| </style> | |
| <iframe src="data:text/html;base64,{b64}" style="display:block;width:100%;height:100vh;border:none" scrolling="yes"></iframe> | |
| ''' | |
| with gr.Blocks(css=""" | |
| .gradio-container{padding:0!important;margin:0!important;max-width:100%!important} | |
| footer{display:none!important} | |
| #component-0{padding:0!important} | |
| """) as demo: | |
| gr.HTML(iframe_html) | |
| demo.launch() | |