
/* ══════════════════════════════════════════════
   NutrientsCalculator — home.css (front page only)
   ══════════════════════════════════════════════ */

/* ── HERO ── */
.hero{min-height:calc(100vh - var(--nav-h));display:grid;grid-template-columns:1fr 1fr;align-items:start;gap:4rem;padding:5rem 5% 4rem;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 60% 40%,rgba(46,194,126,0.08) 0%,transparent 70%);pointer-events:none}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--green-50);border:1px solid var(--green-100);color:var(--green-600);padding:6px 14px;border-radius:50px;font-size:13px;font-weight:600;margin-bottom:1.5rem;animation:fadeUp .6s ease both}
.badge-dot{width:7px;height:7px;border-radius:50%;background:var(--green-400);animation:pulse 2s infinite}
.hero h1{font-family:var(--font-display);font-size:clamp(2.8rem,5vw,4.2rem);font-weight:700;line-height:1.12;letter-spacing:-1.5px;animation:fadeUp .7s .1s ease both}
.hero h1 em{font-style:normal;color:var(--green-500)}
.hero > div > p{font-size:17px;color:var(--ink-60);margin:1.4rem 0 2.2rem;max-width:500px;line-height:1.75;animation:fadeUp .7s .2s ease both}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeUp .7s .3s ease both}
.hero-stats{display:flex;gap:2.5rem;margin-top:2.5rem;animation:fadeUp .7s .4s ease both}
.stat-num{font-family:var(--font-display);font-size:26px;font-weight:700;color:var(--ink)}
.stat-label{font-size:12px;color:var(--ink-60);font-weight:500;text-transform:uppercase;letter-spacing:.5px}
.hero-visual{animation:fadeUp .8s .2s ease both;position:relative;padding-top:58px}

/* ── SCANNER CARD ── */
.scanner-card{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--ink-20)}
.scanner-header{background:var(--green-900);padding:1.5rem 1.75rem 1.25rem;display:flex;align-items:center;justify-content:space-between}
.scanner-title{color:#fff;font-size:15px;font-weight:600}
.scanner-status{background:rgba(46,194,126,0.2);color:var(--lime-400);padding:4px 10px;border-radius:50px;font-size:12px;font-weight:600;font-family:var(--font-mono);display:flex;align-items:center;gap:6px}
.scanner-body{padding:1.5rem}
.food-img-ph{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#e8f5ec,#d4f0e0);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:72px;margin-bottom:1.5rem;position:relative;overflow:hidden}
.scan-line{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--green-400),transparent);animation:scanDown 2s ease-in-out infinite}
.macro-bars{display:flex;flex-direction:column;gap:12px}
.macro-row{display:flex;align-items:center;gap:12px}
.macro-label{font-size:13px;color:var(--ink-60);font-weight:500;width:90px}
.macro-bar-bg{flex:1;height:8px;background:var(--green-50);border-radius:4px;overflow:hidden}
.macro-bar{height:100%;border-radius:4px}
.macro-val{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--ink);width:50px;text-align:right}
.cal-badge{display:flex;align-items:center;justify-content:space-between;background:var(--green-50);border:1px solid var(--green-100);border-radius:var(--radius-md);padding:1rem 1.25rem;margin-bottom:1.25rem}
.cal-label{font-size:13px;color:var(--green-600);font-weight:600}
.cal-number{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--green-500)}
.cal-unit{font-size:12px;color:var(--ink-60)}
.floating-tags{position:absolute;right:-16px;top:20%;display:flex;flex-direction:column;gap:10px}
.ftag{background:var(--white);border:1px solid var(--ink-20);border-radius:var(--radius-md);padding:8px 14px;font-size:12px;font-weight:600;color:var(--ink);box-shadow:var(--shadow-sm);animation:floatTag 3s ease-in-out infinite}
.ftag:nth-child(2){animation-delay:1s}.ftag:nth-child(3){animation-delay:2s}

/* ── HERO INLINE AFF BANNER ── */
.aff-hero{margin-top:2rem;background:var(--white);border:1.5px solid var(--green-100);border-radius:var(--radius-lg);padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;text-decoration:none;color:var(--ink);transition:border-color .2s,box-shadow .2s;max-width:480px}
.aff-hero:hover{border-color:var(--green-400);box-shadow:var(--shadow-sm)}
.aff-hero-icon{font-size:32px;flex-shrink:0}
.aff-hero-text{flex:1}
.aff-hero-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--green-500)}
.aff-hero-title{font-size:14px;font-weight:600;line-height:1.35}
.aff-hero-sub{font-size:12px;color:var(--ink-60)}
.aff-hero-btn{background:var(--green-500);color:#fff;padding:8px 16px;border-radius:50px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0}

/* ── STEPS ── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3.5rem}
.step-card{background:var(--white);border-radius:var(--radius-lg);padding:2rem;border:1px solid var(--ink-20);position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s}
.step-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.step-num{font-family:var(--font-display);font-size:72px;font-weight:700;color:var(--green-50);position:absolute;top:-8px;right:16px;line-height:1;user-select:none}
.step-icon{width:52px;height:52px;border-radius:14px;background:var(--green-50);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:1.25rem}
.step-card h3{font-size:18px;font-weight:600;margin-bottom:.6rem}
.step-card p{font-size:15px;color:var(--ink-60);line-height:1.65}
.step-tag{display:inline-block;margin-top:1rem;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--green-600);background:var(--green-50);padding:4px 10px;border-radius:50px}

/* ── AFF PRODUCT ROW ── */
.aff-prod-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin:2.5rem 0}
.aff-prod{background:var(--white);border:1.5px solid var(--ink-20);border-radius:var(--radius-lg);padding:1.25rem;text-decoration:none;color:var(--ink);display:flex;flex-direction:column;transition:border-color .25s,transform .2s,box-shadow .2s;position:relative}
.aff-prod:hover{border-color:var(--green-400);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.aff-prod-badge{position:absolute;top:-1px;left:16px;background:var(--amber);color:#7c4a00;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;padding:3px 10px;border-radius:0 0 8px 8px}
.aff-prod-icon{font-size:40px;margin:.75rem 0}
.aff-prod-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--green-500);margin-bottom:4px}
.aff-prod-title{font-size:15px;font-weight:600;line-height:1.4;margin-bottom:6px}
.aff-prod-desc{font-size:13px;color:var(--ink-60);line-height:1.55;flex:1}
.aff-prod-footer{display:flex;align-items:center;justify-content:space-between;margin-top:1rem}
.aff-prod-price{font-family:var(--font-mono);font-size:16px;font-weight:700}
.aff-prod-btn{background:var(--green-500);color:#fff;padding:7px 14px;border-radius:50px;font-size:12px;font-weight:700}

/* ── MACRO DARK SECTION ── */
.macro-sec{background:var(--green-900);color:#fff;border-radius:var(--radius-xl);margin:0 3%;padding:5rem 6%;overflow:hidden;position:relative}
.macro-sec::before{content:'';position:absolute;top:-80px;right:-80px;width:400px;height:400px;background:radial-gradient(circle,rgba(46,194,126,0.2) 0%,transparent 70%)}
.macro-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.macro-content .section-label{color:var(--lime-400)}
.macro-content .section-title{color:#fff;max-width:480px}
.macro-content .section-sub{color:rgba(255,255,255,0.65)}
.macro-pillars{display:flex;flex-direction:column;gap:1.25rem;margin-top:2rem}
.pillar{display:flex;align-items:flex-start;gap:1rem;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:var(--radius-md);padding:1.25rem;transition:background .2s}
.pillar:hover{background:rgba(255,255,255,0.1)}
.pillar-icon{font-size:28px;flex-shrink:0}
.pillar-body h4{font-size:15px;font-weight:600;color:#fff;margin-bottom:4px}
.pillar-body p{font-size:14px;color:rgba(255,255,255,0.6);line-height:1.55}
.macro-panel{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:var(--radius-lg);padding:2rem}
.donut-wrap{display:flex;justify-content:center;margin-bottom:2rem}
.donut-svg{width:180px;height:180px}
.macro-legend{display:flex;flex-direction:column;gap:12px}
.leg-row{display:flex;align-items:center;gap:12px}
.leg-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.leg-name{font-size:14px;color:rgba(255,255,255,0.8);flex:1}
.leg-pct{font-family:var(--font-mono);font-size:14px;color:#fff;font-weight:500}
.leg-bg{width:80px;height:4px;background:rgba(255,255,255,0.1);border-radius:2px;overflow:hidden}
.leg-bar{height:100%;border-radius:2px}

/* ── AUDIENCE ── */
.audience-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.aud-card{border-radius:var(--radius-lg);padding:2rem;border:1.5px solid var(--ink-20);transition:border-color .25s,transform .25s,box-shadow .25s;background:var(--white)}
.aud-card:hover{border-color:var(--green-400);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.aud-emoji{font-size:40px;margin-bottom:1rem;display:block}
.aud-card h3{font-size:16px;font-weight:600;margin-bottom:.5rem}
.aud-card p{font-size:14px;color:var(--ink-60);line-height:1.6}
.aud-more{display:inline-flex;align-items:center;gap:5px;margin-top:1rem;font-size:13px;font-weight:600;color:var(--green-500);text-decoration:none}

/* ── ARTICLES ── */
.art-section{background:var(--white)}
.art-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2.5rem}
.view-all{text-decoration:none;color:var(--green-500);font-weight:600;font-size:15px;display:flex;align-items:center;gap:6px;white-space:nowrap}
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.art-card{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--ink-20);background:var(--white);transition:transform .25s,box-shadow .25s;text-decoration:none;color:inherit;display:flex;flex-direction:column}
.art-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.art-img{width:100%;aspect-ratio:16/9;background:var(--green-50);display:flex;align-items:center;justify-content:center;font-size:48px;overflow:hidden;position:relative}
.art-img img{width:100%;height:100%;object-fit:cover}
.art-cat{position:absolute;top:12px;left:12px;background:var(--green-500);color:#fff;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;padding:4px 10px;border-radius:50px}
.art-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.art-meta{font-size:12px;color:var(--ink-60);margin-bottom:.6rem}
.art-title{font-size:16px;font-weight:600;line-height:1.45;flex:1;margin-bottom:1rem;color:var(--ink)}
.art-read{font-size:13px;font-weight:600;color:var(--green-500);display:flex;align-items:center;gap:5px}

/* ── TOOLS ── */
.tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.tool-card{background:var(--white);border-radius:var(--radius-lg);padding:1.75rem;border:1px solid var(--ink-20);transition:transform .25s,box-shadow .25s,border-color .25s;text-decoration:none;color:inherit;display:flex;flex-direction:column}
.tool-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--green-100)}
.tool-icon{font-size:36px;margin-bottom:1rem}
.tool-card h3{font-size:16px;font-weight:600;margin-bottom:.5rem}
.tool-card p{font-size:14px;color:var(--ink-60);line-height:1.6;flex:1}
.tool-link{display:inline-flex;align-items:center;gap:5px;margin-top:1rem;font-size:13px;font-weight:600;color:var(--green-500)}

/* ══════════════════════════════════════════════
   HOME.CSS — MOBILE RESPONSIVE
   ══════════════════════════════════════════════ */

@media(max-width:900px){
  /* HERO */
  .hero{grid-template-columns:1fr;min-height:auto;padding:2.5rem 5% 3rem;gap:2rem}
  .hero-visual,.floating-tags{display:none}
  .hero h1{font-size:clamp(2rem,8vw,3rem);letter-spacing:-1px}
  .hero > div > p{font-size:15px;margin:1rem 0 1.5rem}
  .hero-actions{flex-direction:column;gap:.75rem}
  .hero-actions .btn-primary,.hero-actions .btn-secondary{width:100%;justify-content:center;text-align:center}
  .hero-stats{gap:1.5rem}
  .badge-dot{width:6px;height:6px}

  /* HERO AFF BANNER */
  .aff-hero{max-width:100%;flex-direction:column;align-items:flex-start}
  .aff-hero-btn{width:100%;text-align:center;margin-top:.25rem}

  /* STEPS */
  .steps{grid-template-columns:1fr;gap:1rem;margin-top:2rem}
  .step-card{padding:1.5rem}
  .step-num{font-size:56px;top:-6px;right:12px}

  /* PRODUCT CARDS */
  .aff-prod-row{grid-template-columns:1fr;gap:1rem}

  /* MACRO */
  .macro-sec{border-radius:var(--radius-lg);margin:0 4%;padding:3rem 5%}
  .macro-grid{grid-template-columns:1fr;gap:2.5rem}
  .macro-content .section-title{font-size:1.8rem}
  .macro-pillars{gap:1rem}
  .donut-wrap{margin-bottom:1.5rem}

  /* SPOTLIGHT */
  .aff-spotlight{grid-template-columns:1fr;gap:1.5rem;margin:0 4%;padding:2rem 5%}
  .aff-spot-right{display:flex;align-items:center;gap:1.5rem;text-align:left}
  .aff-spot-img{font-size:52px;margin-bottom:0}
  .aff-spot-btn{white-space:nowrap}
  .aff-spot-checks{gap:.75rem}

  /* AUDIENCE */
  .audience-grid{grid-template-columns:1fr;gap:1rem;margin-top:2rem}
  .aud-card{padding:1.5rem}

  /* ARTICLES */
  .art-header{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem}
  .art-grid{grid-template-columns:1fr;gap:1.25rem}

  /* TOOLS */
  .tools-grid{grid-template-columns:1fr;gap:1rem;margin-top:2rem}
  .tool-card{padding:1.25rem}
}

@media(max-width:480px){
  .hero{padding:2rem 4% 2.5rem}
  .hero h1{font-size:clamp(1.75rem,7.5vw,2.4rem)}
  .hero-stats .stat-num{font-size:20px}
  .hero-stats .stat-label{font-size:10px}

  .macro-sec{margin:0 3%;padding:2.5rem 4%}
  .donut-svg{width:140px;height:140px}

  .aff-spotlight{margin:0 3%}
  .aff-spot-right{flex-direction:column;align-items:flex-start}
  .aff-spot-img{font-size:40px}

  .step-card{padding:1.25rem}
  .aud-card{padding:1.25rem}
  .aud-emoji{font-size:32px}
}

/* ════════════════════════════════════════════
   JOIN / REGISTER SECTION
════════════════════════════════════════════ */
.nc-join-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: var(--green-900);
  overflow: hidden;
}

/* ── LEFT PANEL ── */
.nc-join-left {
  padding: 5rem 3.5rem 5rem 5%;
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
  justify-content: center;
}
.nc-join-left .section-label { color: var(--lime); }
.nc-join-title {
  font-family: var(--font-head);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -1px;
  color: #fff;
  margin: 0;
}
.nc-join-title em { color: var(--green-400); font-style: italic; }
.nc-join-sub {
  font-size: 16px;
  color: rgba(255,255,255,0.6);
  line-height: 1.7;
  margin: 0;
  max-width: 440px;
}

/* Benefits */
.nc-join-benefits { display: flex; flex-direction: column; gap: 1rem; }
.nc-join-benefit {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}
.nc-join-benefit-icon {
  font-size: 22px;
  width: 44px; height: 44px;
  background: rgba(46,194,126,0.12);
  border: 1px solid rgba(46,194,126,0.25);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.nc-join-benefit strong {
  display: block;
  font-size: 15px;
  font-weight: 600;
  color: #fff;
  margin-bottom: 2px;
}
.nc-join-benefit span {
  font-size: 13px;
  color: rgba(255,255,255,0.5);
  line-height: 1.5;
}

/* Social proof */
.nc-join-proof {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.25rem;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 14px;
  max-width: 380px;
}
.nc-join-avatars { display: flex; }
.nc-join-av {
  width: 34px; height: 34px;
  border-radius: 50%;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  border: 2.5px solid var(--green-900);
  margin-left: -8px;
  font-family: var(--font-body);
}
.nc-join-avatars .nc-join-av:first-child { margin-left: 0; }
.nc-join-proof-text { display: flex; flex-direction: column; gap: 2px; }
.nc-join-proof-text strong { font-size: 14px; color: #fff; font-weight: 600; }
.nc-join-proof-text span { font-size: 12px; color: rgba(255,255,255,0.5); }

/* ── RIGHT PANEL — form ── */
.nc-join-right {
  background: var(--cream);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4rem 5% 4rem 3rem;
}
.nc-join-form-wrap {
  width: 100%;
  max-width: 420px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.nc-join-form-header { margin-bottom: 1.5rem; }
.nc-join-form-header h3 {
  font-family: var(--font-head);
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: -0.4px;
  color: var(--ink);
  margin: 0 0 .4rem;
}
.nc-join-form-header p {
  font-size: 13px;
  color: var(--ink-60);
  margin: 0;
}

.nc-join-form { display: flex; flex-direction: column; gap: 10px; }
.nc-join-field input,
.nc-join-field select {
  width: 100%;
  padding: 13px 16px;
  border: 1.5px solid rgba(15,26,18,0.12);
  border-radius: 12px;
  font-size: 15px;
  font-family: var(--font-body);
  color: var(--ink);
  background: #fff;
  transition: border-color .2s, box-shadow .2s;
  box-sizing: border-box;
}
.nc-join-field input:focus,
.nc-join-field select:focus {
  outline: none;
  border-color: var(--green-500);
  box-shadow: 0 0 0 3px rgba(31,168,104,0.1);
}

/* Messages */
.nc-join-msg {
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.5;
}
.nc-join-msg--error  { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.nc-join-msg--success{ background: #f0faf4; color: #17865a; border: 1px solid #d4f0e0; }
.nc-hidden { display: none !important; }

/* Submit button */
.nc-join-submit {
  width: 100%;
  padding: 14px;
  background: var(--green-500);
  color: #fff;
  border: none;
  border-radius: 50px;
  font-size: 16px;
  font-weight: 700;
  font-family: var(--font-body);
  cursor: pointer;
  box-shadow: 0 4px 24px rgba(31,168,104,0.4);
  transition: background .2s, transform .15s;
  margin-top: 2px;
}
.nc-join-submit:hover { background: #17865a; transform: translateY(-2px); }
.nc-join-submit:disabled { opacity: .7; pointer-events: none; }
.nc-join-submit-loader { letter-spacing: 3px; animation: ncJoinPulse 1s infinite; display: inline-block; }
@keyframes ncJoinPulse { 0%,100%{opacity:1} 50%{opacity:.3} }

.nc-join-terms {
  font-size: 11px;
  color: var(--ink-60);
  text-align: center;
  margin: .5rem 0 0;
  line-height: 1.5;
}
.nc-join-terms a { color: var(--green-500); text-decoration: none; }

/* Divider */
.nc-join-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 1.25rem 0;
  color: var(--ink-60);
  font-size: 12px;
}
.nc-join-divider::before,
.nc-join-divider::after { content:''; flex:1; height:1px; background:rgba(15,26,18,0.1); }

/* Sign in link */
.nc-join-signin-link {
  display: block;
  text-align: center;
  font-size: 14px;
  color: var(--ink-60);
  text-decoration: none;
  transition: color .2s;
  margin-bottom: 1rem;
}
.nc-join-signin-link:hover { color: var(--ink); }
.nc-join-signin-link strong { color: var(--green-500); }

/* Free note */
.nc-join-free-note {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #f0faf4;
  border: 1px solid #d4f0e0;
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 13px;
  color: rgba(15,26,18,0.65);
  line-height: 1.5;
}
.nc-join-free-note strong { color: var(--green-600); }

/* ── MOBILE ── */
@media (max-width: 768px) {
  .nc-join-section { grid-template-columns: 1fr; }
  .nc-join-left { padding: 3rem 5%; order: 2; }
  .nc-join-right { padding: 3rem 5%; order: 1; }
  .nc-join-form-wrap { max-width: 100%; }
  .nc-join-proof { max-width: 100%; }
  .nc-join-sub { max-width: 100%; }
}

/* ════════════════════════════════════════════
   FOODS SECTION
════════════════════════════════════════════ */
.nc-foods-section {
  background: var(--cream);
  padding: 5rem 5%;
}
.nc-foods-inner { max-width: 1180px; margin: 0 auto; }

.nc-foods-header {
  display: flex; align-items: flex-end;
  justify-content: space-between; gap: 2rem;
  margin-bottom: 2rem; flex-wrap: wrap;
}
.nc-foods-view-all {
  font-size: 14px; font-weight: 700;
  color: var(--green-500); text-decoration: none;
  white-space: nowrap; flex-shrink: 0;
  padding: 10px 20px; border-radius: 50px;
  border: 1.5px solid var(--green-500);
  transition: all .2s;
}
.nc-foods-view-all:hover { background: var(--green-500); color: #fff; }

/* Filter tabs */
.nc-foods-tabs {
  display: flex; gap: .5rem; flex-wrap: wrap;
  margin-bottom: 1.75rem;
}
.nc-foods-tab {
  padding: 7px 16px; border-radius: 50px;
  border: 1.5px solid rgba(15,26,18,.12);
  background: #fff; color: rgba(15,26,18,.6);
  font-size: 13px; font-weight: 600;
  font-family: var(--font-body);
  cursor: pointer; transition: all .2s;
}
.nc-foods-tab:hover { border-color: var(--green-500); color: var(--green-500); }
.nc-foods-tab-active { background: var(--green-500)!important; color: #fff!important; border-color: var(--green-500)!important; }

/* Foods grid */
.nc-foods-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: 2rem;
}
.nc-food-card {
  background: #fff;
  border: 1.5px solid rgba(15,26,18,.1);
  border-radius: 16px;
  overflow: hidden;
  text-decoration: none;
  display: flex; flex-direction: column;
  transition: all .22s;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
  position: relative;
}
.nc-food-card:hover {
  border-color: var(--green-500);
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,0,0,.1);
}
.nc-food-card.nc-food-hidden { display: none; }

/* Card image */
.nc-food-card-img {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: linear-gradient(135deg, #f0faf4, #faf9f5);
  position: relative; flex-shrink: 0;
}
.nc-food-card-img img { width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s; }
.nc-food-card:hover .nc-food-card-img img { transform: scale(1.05); }
.nc-food-card-emoji {
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-size:52px;
}
.nc-food-card-score {
  position:absolute;top:8px;right:8px;
  font-size:11px;font-weight:700;
  padding:3px 8px;border-radius:50px;
  font-family:var(--font-mono);
}

/* Card body */
.nc-food-card-body { padding:.85rem 1rem;flex:1;display:flex;flex-direction:column;gap:4px; }
.nc-food-card-name { font-size:14px;font-weight:700;color:var(--ink);line-height:1.35; }
.nc-food-card-serving { font-size:11px;color:rgba(15,26,18,.5); }
.nc-food-card-cal { font-family:var(--font-mono);font-size:1.25rem;font-weight:700;line-height:1;margin-top:2px; }
.nc-food-card-cal span { font-size:11px;font-weight:600;color:rgba(15,26,18,.5); }
.nc-food-card-macros { display:flex;gap:.3rem;flex-wrap:wrap;margin-top:4px; }
.nc-food-macro { font-size:10px;font-weight:700;padding:2px 7px;border-radius:50px; }
.nc-fm-p { background:#eff6ff;color:#2563eb; }
.nc-fm-c { background:#fffbeb;color:#92400e; }
.nc-fm-f { background:#faf5ff;color:#7c3aed; }
.nc-food-card-tags { display:flex;gap:.3rem;flex-wrap:wrap;margin-top:4px; }
.nc-food-tag { font-size:10px;font-weight:600;background:var(--green-50);color:var(--green-600);padding:2px 7px;border-radius:50px; }

/* Arrow */
.nc-food-card-arrow {
  position:absolute;bottom:10px;right:12px;
  font-size:14px;color:var(--green-500);
  opacity:0;transform:translateX(-4px);
  transition:all .2s;
}
.nc-food-card:hover .nc-food-card-arrow { opacity:1;transform:translateX(0); }

/* Footer */
.nc-foods-footer { text-align:center;margin-top:.5rem; }
.nc-foods-all-btn {
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 28px;border-radius:50px;
  background:var(--green-900);color:#fff;
  font-size:15px;font-weight:700;text-decoration:none;
  transition:background .2s;
  box-shadow:0 4px 20px rgba(10,56,40,.2);
}
.nc-foods-all-btn:hover { background:#0d4a30; }

/* Responsive */
@media (max-width:1024px) { .nc-foods-grid { grid-template-columns:repeat(3,1fr); } }
@media (max-width:768px)  {
  .nc-foods-grid { grid-template-columns:repeat(2,1fr); }
  .nc-foods-header { flex-direction:column;align-items:flex-start; }
  .nc-foods-view-all { align-self:flex-start; }
}
@media (max-width:480px)  { .nc-foods-grid { grid-template-columns:repeat(2,1fr);gap:.6rem; } }

/* ── Homepage Images ───────────────────────────────── */
.nc-hero-photo {
  margin: 0 0 -16px;
  position: relative;
  z-index: 1;
}
.nc-hero-photo img {
  border-radius: 16px 16px 0 0;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12);
}
.nc-section-img {
  margin: 2.5rem 0 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}
.nc-section-img img {
  display: block;
  width: 100%;
  transition: transform .4s ease;
}
.nc-section-img:hover img {
  transform: scale(1.02);
}
.nc-section-img figcaption {
  font-size: 12px;
  color: var(--ink-60);
  padding: 8px 12px;
  text-align: center;
  font-style: italic;
}

/* ══════════════════════════════════════════════
   SCANNER CARD v2 — rich animated AI analysis
══════════════════════════════════════════════ */
.scanner-card.sc2 {
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.13), 0 4px 16px rgba(0,0,0,0.06);
  overflow: hidden;
  width: 100%;
  max-width: 100%;
  font-family: var(--font-sans, 'DM Sans', sans-serif);
}

/* ── Header ── */
.sc2 .scanner-header {
  background: #0a3828;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.sc2 .scanner-title { color: #fff; font-size: 15px; font-weight: 600; }
.sc2 .scanner-status {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; letter-spacing: 1px;
  color: #4ade80;
}
.sc-pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: #4ade80;
  animation: pulse-dot 1.4s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%,100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.5); opacity: 0.6; }
}

/* ── Food photo zone ── */
.sc-photo-wrap {
  position: relative;
  background: linear-gradient(135deg, #f0faf4 0%, #e6f7ee 100%);
  height: 160px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.sc-food-emojis { font-size: 72px; letter-spacing: 8px; line-height: 1; }

/* Scan line */
.sc-scan-line {
  position: absolute; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent 0%, #2ec27e 30%, #2ec27e 70%, transparent 100%);
  box-shadow: 0 0 8px #2ec27e, 0 0 16px rgba(46,194,126,0.4);
  animation: scan-sweep 2s ease-in-out infinite;
}
@keyframes scan-sweep {
  0%   { top: 10%; opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { top: 90%; opacity: 0; }
}

/* Detection boxes */
.sc-detect-box {
  position: absolute;
  background: rgba(10, 56, 40, 0.85);
  color: #fff;
  font-size: 11px; font-weight: 600;
  padding: 3px 7px;
  border-radius: 6px;
  display: flex; align-items: center; gap: 4px;
  border: 1px solid rgba(46,194,126,0.6);
  opacity: 0;
  animation: pop-in 0.4s ease forwards;
}
.sc-detect-box span { color: #4ade80; }
.sc-db1 { top: 12px; left: 14px;  animation-delay: 0.8s; }
.sc-db2 { top: 12px; right: 14px; animation-delay: 1.2s; }
.sc-db3 { bottom: 10px; left: 50%; transform: translateX(-50%); animation-delay: 1.6s; }
@keyframes pop-in {
  from { opacity: 0; transform: scale(0.8) translateY(4px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
.sc-db3 { transform: translateX(-50%) scale(0.8); }
.sc-db3 { animation-name: pop-in-center; }
@keyframes pop-in-center {
  from { opacity: 0; transform: translateX(-50%) scale(0.8); }
  to   { opacity: 1; transform: translateX(-50%) scale(1); }
}

.sc-ai-badge {
  position: absolute; top: 8px; right: 50%; transform: translateX(50%);
  background: rgba(46,194,126,0.15);
  border: 1px solid rgba(46,194,126,0.4);
  color: #17865a;
  font-size: 10px; font-weight: 700; letter-spacing: 0.5px;
  padding: 2px 8px; border-radius: 50px;
  opacity: 0;
  animation: pop-in 0.4s ease 2.2s forwards;
}

/* ── Calorie row ── */
.sc-cal-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px 10px;
  border-bottom: 1px solid #f0f4f2;
}
.sc-cal-label { font-size: 12px; font-weight: 700; color: #0a3828; text-transform: uppercase; letter-spacing: 0.5px; }
.sc-cal-sub   { font-size: 11px; color: #888; margin-top: 2px; }
.sc-cal-num   { font-size: 30px; font-weight: 800; color: #0a3828; line-height: 1; }
.sc-kcal      { font-size: 13px; font-weight: 500; color: #888; }

/* Count-up animation target */
.sc-count { display: inline-block; }

/* ── Macro bars ── */
.sc-macros { padding: 12px 18px; border-bottom: 1px solid #f0f4f2; }
.sc-macro-row {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 8px;
}
.sc-macro-row:last-child { margin-bottom: 0; }
.sc-mlabel { font-size: 12px; font-weight: 600; color: #555; width: 52px; flex-shrink: 0; }
.sc-mbar-bg {
  flex: 1; height: 9px; background: #f0f4f2;
  border-radius: 50px; overflow: hidden;
}
.sc-mbar {
  height: 100%; border-radius: 50px;
  background: var(--c);
  width: 0;
  animation: bar-grow 1s ease forwards;
  animation-delay: calc(var(--i, 0) * 0.15s + 0.5s);
}
.sc-macros .sc-macro-row:nth-child(1) .sc-mbar { --i:0; }
.sc-macros .sc-macro-row:nth-child(2) .sc-mbar { --i:1; }
.sc-macros .sc-macro-row:nth-child(3) .sc-mbar { --i:2; }
.sc-macros .sc-macro-row:nth-child(4) .sc-mbar { --i:3; }
@keyframes bar-grow {
  from { width: 0; }
  to   { width: var(--w); }
}
.sc-mval { font-size: 13px; font-weight: 700; color: #0a3828; width: 32px; text-align: right; flex-shrink: 0; }

/* ── Micronutrient chips ── */
.sc-micros {
  padding: 10px 18px;
  display: flex; flex-wrap: wrap; gap: 6px;
  border-bottom: 1px solid #f0f4f2;
}
.sc-chip {
  font-size: 11px; color: #444;
  background: #f5f9f7;
  border: 1px solid #deeee7;
  border-radius: 50px;
  padding: 4px 10px;
  opacity: 0;
  animation: chip-fade 0.3s ease forwards;
}
.sc-c1 { animation-delay: 1.2s; }
.sc-c2 { animation-delay: 1.4s; }
.sc-c3 { animation-delay: 1.6s; }
.sc-c4 { animation-delay: 1.8s; }
.sc-c5 { animation-delay: 2.0s; }
.sc-c6 { animation-delay: 2.2s; }
@keyframes chip-fade {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sc-chip b { color: #0a6640; font-weight: 700; }

/* ── Health score ── */
.sc-health-row {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 18px;
  border-bottom: 1px solid #f0f4f2;
}
.sc-hlabel { font-size: 12px; font-weight: 600; color: #555; width: 90px; flex-shrink: 0; }
.sc-hbar-bg {
  flex: 1; height: 9px; background: #f0f4f2;
  border-radius: 50px; overflow: hidden;
}
.sc-hbar {
  height: 100%; border-radius: 50px;
  background: linear-gradient(90deg, #f59e0b 0%, #2ec27e 60%);
  width: 0;
  animation: bar-grow 1.2s ease 1.2s forwards;
  --w: var(--hw);
}
.sc-hscore { font-size: 13px; font-weight: 700; color: #2ec27e; width: 48px; text-align: right; flex-shrink: 0; }

/* ── Footer badges ── */
.sc-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 18px;
  background: #f8fbf9;
}
.sc-footer span { font-size: 12px; font-weight: 600; color: #555; }

