/* ============================
   HARVESTY — CSS v2
   Bold Organic · Bento + Steps
   ============================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,500;0,600;1,500&display=swap');

/* ── Variables ── */
:root {
  --bg:           #f0f9ec;
  --bg-alt:       #e6f2e2;
  --glass-bg:     rgba(255, 255, 255, 0.54);
  --glass-bg-deep:rgba(255, 255, 255, 0.70);
  --glass-border: rgba(130, 200, 150, 0.38);
  --glass-hover:  rgba(255, 255, 255, 0.74);
  --green-p:      #3a9e52;
  --green-l:      #62bf78;
  --green-d:      #267838;
  --green-xl:     #d4f4dc;
  --amber:        #e8a83a;
  --amber-l:      #f5c660;
  --amber-d:      #b87820;
  --sky:          #4a9ed8;
  --sky-l:        #7abce8;
  --coral:        #e0643a;
  --coral-l:      #f08458;
  --gold-p:       #3a9e52;
  --gold-l:       #62bf78;
  --gold-d:       #267838;
  --gold-xl:      #d4f4dc;
  --green-s:      #6ab870;
  --green-sl:     #8ed090;
  --accent:       #e0643a;
  --accent-l:     #f08458;
  --text:         #1a3a22;
  --text-m:       #4a7a58;
  --text-d:       #88b49a;
  --white:        rgba(255,255,255,0.95);
  --r-s:  12px;
  --r-m:  20px;
  --r-l:  32px;
  --r-xl: 48px;
  --ease: cubic-bezier(0.4,0,0.2,1);
  --tr:   0.3s var(--ease);
  --shadow:   0 8px 32px rgba(30,100,50,0.13);
  --shadow-l: 0 24px 64px rgba(20,80,40,0.18);
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Inter',sans-serif;
  background: linear-gradient(155deg, #fdf8ee 0%, #edf8e6 45%, #e6f4f2 100%);
  background-attachment: fixed;
  color: var(--text);
  line-height:1.6;
  overflow-x:hidden;
}
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
ul { list-style:none; }

/* ── Background orbs ── */
.bg-orb {
  position:fixed; border-radius:50%; pointer-events:none; z-index:0;
  filter:blur(90px); opacity:0.60;
}
.bg-orb-1 { width:700px; height:700px; background:radial-gradient(circle, rgba(255,205,90,0.60) 0%, transparent 70%); top:-200px; left:-200px; }
.bg-orb-2 { width:500px; height:500px; background:radial-gradient(circle, rgba(58,158,82,0.55) 0%, transparent 70%); top:40vh; right:-150px; }
.bg-orb-3 { width:600px; height:600px; background:radial-gradient(circle, rgba(74,158,216,0.45) 0%, transparent 70%); bottom:-100px; left:20%; }
.bg-orb-4 { width:380px; height:380px; background:radial-gradient(circle, rgba(224,100,58,0.42) 0%, transparent 70%); top:60vh; left:-100px; opacity:0.40; }

/* ── Typography ── */
h1,h2,h3,h4 { line-height:1.2; }
.display {
  font-family:'Playfair Display',serif;
  font-size:clamp(2.8rem,6vw,5rem);
  font-weight:600; letter-spacing:-0.02em;
}
.section-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,4vw,3rem); font-weight:500; margin-bottom:1rem;
}
.section-subtitle { font-size:1.1rem; color:var(--text-m); max-width:560px; line-height:1.7; }
.tag {
  display:inline-block; font-size:0.75rem; font-weight:600;
  letter-spacing:0.12em; text-transform:uppercase;
  color:var(--green-d);
  background:rgba(58,158,82,0.12); border:1px solid rgba(58,158,82,0.30);
  border-radius:100px; padding:4px 14px; margin-bottom:1.2rem;
}
.tag-dark {
  color:rgba(255,255,255,0.7);
  background:rgba(255,255,255,0.14); border-color:rgba(255,255,255,0.28);
}

/* ── Phosphor icon sizing ── */
i[class*="ph"] { display:inline-flex; align-items:center; justify-content:center; }
i[class*="ph"] svg { width:1em; height:1em; }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  font-size:0.95rem; font-weight:600; border-radius:100px;
  padding:14px 28px; transition:var(--tr);
  position:relative; overflow:hidden; white-space:nowrap;
}
.btn-primary {
  background:linear-gradient(135deg, var(--amber) 0%, var(--coral) 100%);
  color:#fff;
  box-shadow:0 4px 20px rgba(224,100,58,0.35);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 30px rgba(224,100,58,0.48); }
.store-btn {
  display:inline-flex; align-items:center; gap:12px;
  padding:12px 24px; background:rgba(255,255,255,0.60);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(130,200,150,0.35); border-radius:var(--r-m);
  color:var(--text); font-size:0.9rem; transition:var(--tr);
}
.store-btn:hover { background:rgba(255,255,255,0.82); transform:translateY(-2px); box-shadow:var(--shadow); }
.store-btn .store-icon { width:28px; height:28px; flex-shrink:0; }
.store-btn .store-label { text-align:left; line-height:1.3; }
.store-btn .store-label small { display:block; font-size:0.7rem; color:var(--text-m); font-weight:400; }
.store-btn .store-label strong { font-size:1rem; font-weight:600; }

/* ── Layout ── */
section { position:relative; z-index:1; }
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.section-pad { padding:100px 0; }
.section-header { text-align:center; margin-bottom:60px; }
.section-header .section-subtitle { margin:0 auto; }

/* ── Nav ── */
#navbar {
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:0 24px; transition:background var(--tr), box-shadow var(--tr);
}
#navbar.scrolled {
  background:rgba(240,252,236,0.92);
  backdrop-filter:blur(22px); -webkit-backdrop-filter:blur(22px);
  border-bottom:1px solid rgba(130,200,150,0.30);
  box-shadow:0 4px 24px rgba(30,100,50,0.08);
}
.nav-inner {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; height:72px;
}
.nav-logo {
  display:flex; align-items:center; gap:10px;
  font-size:1.3rem; font-weight:700; color:var(--text);
}
.nav-logo .logo-icon {
  width:36px; height:36px;
  background:linear-gradient(135deg, var(--amber) 0%, var(--coral) 100%);
  border-radius:10px; display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 12px rgba(224,100,58,0.30);
  font-size:18px; color:#fff;
}
.nav-logo .logo-icon svg { width:18px; height:18px; }
.nav-links { display:flex; align-items:center; gap:36px; }
.nav-links a { font-size:0.9rem; font-weight:500; color:var(--text-m); transition:color var(--tr); }
.nav-links a:hover { color:var(--text); }
.nav-cta { display:flex; gap:12px; }
.hamburger { display:none; flex-direction:column; gap:5px; padding:8px; border-radius:8px; }
.hamburger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:var(--tr); }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.mobile-menu {
  display:none; position:fixed; inset:0; z-index:99;
  padding:100px 24px 40px;
  background:rgba(240,252,236,0.97); backdrop-filter:blur(24px);
  flex-direction:column; align-items:center; gap:32px;
  opacity:0; pointer-events:none; transition:opacity var(--tr);
}
.mobile-menu.open { opacity:1; pointer-events:all; display:flex; }
.mobile-menu a { font-size:1.4rem; font-weight:500; color:var(--text); }

/* ══════════════════════════════
   HERO
══════════════════════════════ */
#hero {
  min-height:100vh; display:flex; align-items:center;
  padding-top:72px; position:relative; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0; z-index:0;
  background-image:url('https://images.unsplash.com/photo-1523348837708-15d4a09cfac2?auto=format&fit=crop&w=1920&q=80');
  background-size:cover; background-position:center;
}
.hero-bg::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(253,248,238,0.94) 0%, rgba(237,250,230,0.88) 40%, rgba(228,246,224,0.72) 100%);
}
.hero-inner {
  position:relative; z-index:1;
  max-width:1200px; margin:0 auto; padding:80px 24px;
  display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;
}
.hero-text .display { color:var(--text); margin-bottom:1.5rem; }
.hero-text .display span {
  background: linear-gradient(135deg, var(--green-p) 0%, var(--amber) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-desc { font-size:1.15rem; color:var(--text-m); line-height:1.8; margin-bottom:2.5rem; max-width:520px; }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:3rem; }
.hero-stats { display:flex; gap:32px; flex-wrap:wrap; }
.hero-stat .num { font-size:1.8rem; font-weight:700; color:var(--text); line-height:1; }
.hero-stat .lbl { font-size:0.8rem; color:var(--text-m); margin-top:4px; }

/* Hero showcase (phone, no floating cards) */
.hero-showcase {
  display:flex; justify-content:center; align-items:center;
  position:relative; height:570px;
}
.showcase-glow {
  position:absolute;
  width:420px; height:420px; border-radius:50%;
  background:radial-gradient(circle, rgba(58,158,82,0.18) 0%, rgba(232,168,58,0.12) 45%, transparent 70%);
  animation:hero-glow 4s ease-in-out infinite;
  pointer-events:none;
}
.showcase-glow::before {
  content:''; position:absolute; inset:24px; border-radius:50%;
  border:1.5px solid rgba(58,158,82,0.18);
}
.showcase-glow::after {
  content:''; position:absolute; inset:52px; border-radius:50%;
  border:1px dashed rgba(232,168,58,0.22);
}
@keyframes hero-glow {
  0%,100% { transform:scale(1); opacity:0.8; }
  50% { transform:scale(1.04); opacity:1; }
}

/* ── iPhone Mockup ── */
.iphone-mockup {
  position:relative; z-index:2;
  width:240px; height:512px;
  background:rgba(248,254,250,0.96);
  border-radius:48px;
  border:1.5px solid rgba(255,255,255,0.92);
  overflow:hidden;
  box-shadow: 0 0 0 1px rgba(130,200,150,0.18), inset 0 0 0 1px rgba(255,255,255,0.75), 0 40px 80px rgba(30,100,50,0.22);
}
.iphone-island {
  position:absolute; top:12px; left:50%; transform:translateX(-50%);
  width:88px; height:26px; background:#1a3a22; border-radius:20px; z-index:10;
}
.iphone-bg {
  position:absolute; inset:0;
  background-image:url('https://images.unsplash.com/photo-1416879595882-3373a0480b5b?auto=format&fit=crop&w=400&q=80');
  background-size:cover; background-position:center;
}
.iphone-bg::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(240,252,242,0.40) 0%, rgba(238,250,240,0.68) 38%, rgba(236,250,240,0.90) 65%, rgba(234,248,238,0.97) 100%);
}
.iphone-ui {
  position:relative; z-index:3; height:100%;
  padding:50px 16px 10px; display:flex; flex-direction:column; gap:9px;
}
.iphone-greeting-name { font-size:0.58rem; color:rgba(26,58,34,0.48); text-transform:uppercase; letter-spacing:0.1em; display:block; margin-bottom:4px; }
.iphone-headline { font-family:'Playfair Display',serif; font-size:1.12rem; font-weight:600; color:var(--text); line-height:1.25; }
.iphone-headline em { color:var(--green-p); font-style:italic; }
.iphone-weather-row {
  display:flex; align-items:center; gap:7px;
  background:rgba(255,255,255,0.68); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(130,200,150,0.30); border-radius:12px; padding:6px 10px;
}
.iw-icon { font-size:15px; color:var(--amber); flex-shrink:0; }
.iw-icon svg { width:15px; height:15px; }
.iw-temp { font-size:0.9rem; font-weight:700; color:var(--text); }
.iw-stats { display:flex; gap:8px; margin-left:auto; }
.iws { text-align:center; font-size:0.57rem; color:var(--text-m); line-height:1.4; }
.iws span { display:block; text-transform:uppercase; font-size:0.49rem; opacity:0.65; }
.iws b { font-weight:600; color:var(--text); }
.iphone-tasks-card {
  flex:1; background:rgba(255,255,255,0.68); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(130,200,150,0.28); border-radius:18px; padding:11px 12px;
}
.itc-header { font-size:0.6rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:rgba(26,58,34,0.45); margin-bottom:9px; }
.itc-task { display:flex; align-items:center; gap:8px; margin-bottom:7px; }
.itc-task:last-child { margin-bottom:0; }
.itc-accent { width:3px; height:30px; border-radius:2px; flex-shrink:0; }
.itc-body { flex:1; min-width:0; }
.itc-title { font-size:0.68rem; font-weight:600; color:var(--text); line-height:1.2; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.itc-sub { font-size:0.58rem; color:var(--text-m); margin-top:1px; }
.itc-done .itc-title { text-decoration:line-through; opacity:0.40; }
.itc-circle { width:19px; height:19px; border-radius:50%; border:1.5px solid rgba(26,58,34,0.18); flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.itc-checked { background:var(--green-p); border-color:var(--green-p); color:#fff; font-size:10px; }
.iphone-dock { display:flex; justify-content:center; gap:18px; padding:5px 0; border-top:1px solid rgba(26,58,34,0.08); }
.iphone-dock-btn { width:30px; height:30px; border-radius:9px; display:flex; align-items:center; justify-content:center; color:rgba(26,58,34,0.40); font-size:15px; }
.iphone-dock-add { background:linear-gradient(135deg, var(--amber), var(--coral)); color:#fff; }
.iphone-home-bar { width:72px; height:4px; border-radius:2px; background:rgba(26,58,34,0.18); margin:3px auto 0; }

/* ══════════════════════════════
   STATS STRIP (dark)
══════════════════════════════ */
#stats-bar { position:relative; z-index:1; padding:0 24px; }
.stats-strip {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; justify-content:center;
  background:var(--text);
  border-radius:var(--r-l);
  overflow:hidden;
  box-shadow:0 20px 48px rgba(20,60,30,0.22);
}
.stat-strip-item {
  flex:1; padding:36px 24px; text-align:center;
  display:flex; flex-direction:column; gap:8px;
  transition:background var(--tr);
}
.stat-strip-item:hover { background:rgba(255,255,255,0.06); }
.stat-strip-num {
  font-size:2.4rem; font-weight:700; line-height:1;
  background:linear-gradient(135deg, var(--amber-l) 0%, var(--green-l) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-strip-lbl { font-size:0.82rem; color:rgba(255,255,255,0.52); letter-spacing:0.04em; }
.stat-strip-div { width:1px; height:48px; background:rgba(255,255,255,0.10); flex-shrink:0; }

/* ══════════════════════════════
   FEATURES — BENTO GRID
══════════════════════════════ */
#features { padding:100px 0 80px; }
.bento-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
}
.bento-card {
  padding:32px 28px;
  background:var(--glass-bg); backdrop-filter:blur(18px) saturate(1.5); -webkit-backdrop-filter:blur(18px) saturate(1.5);
  border:1px solid var(--glass-border); border-radius:var(--r-l);
  transition:transform var(--tr), background var(--tr), border-color var(--tr), box-shadow var(--tr);
}
.bento-card:hover { transform:translateY(-5px); background:var(--glass-hover); border-color:rgba(130,200,150,0.55); box-shadow:0 20px 48px rgba(30,100,50,0.13); }
.bento-card h3 { font-size:1.1rem; font-weight:600; margin-bottom:10px; color:var(--text); margin-top:16px; }
.bento-card p  { font-size:0.9rem; color:var(--text-m); line-height:1.7; }

/* Wide bento card: horizontal layout */
.bento-w2 {
  grid-column:span 2;
  display:flex; flex-direction:row; align-items:flex-start; gap:28px;
}
.bento-w2 .bento-text { flex:1; }
.bento-w2 h3 { margin-top:0; }
.bento-w2 .bento-icon { flex-shrink:0; margin-top:4px; }

.bento-icon {
  width:60px; height:60px; border-radius:18px; display:flex; align-items:center; justify-content:center;
  font-size:28px;
}
.bento-icon svg { width:28px; height:28px; }
.bento-icon-1 { background:linear-gradient(135deg, rgba(58,158,82,0.20), rgba(98,191,120,0.28));  color:var(--green-p); }
.bento-icon-2 { background:linear-gradient(135deg, rgba(232,168,58,0.20), rgba(245,198,96,0.28)); color:var(--amber-d); }
.bento-icon-3 { background:linear-gradient(135deg, rgba(74,158,216,0.20), rgba(122,188,232,0.28));color:var(--sky); }
.bento-icon-4 { background:linear-gradient(135deg, rgba(158,100,232,0.18), rgba(190,140,248,0.26));color:#8040c8; }
.bento-icon-5 { background:linear-gradient(135deg, rgba(224,100,58,0.18), rgba(248,132,88,0.26)); color:var(--coral); }
.bento-icon-6 { background:linear-gradient(135deg, rgba(82,184,160,0.20), rgba(100,210,186,0.28));color:#2a9880; }

/* ══════════════════════════════
   HOW IT WORKS — STEP CARDS
══════════════════════════════ */
#how-it-works { padding:80px 0 100px; }
.steps-grid {
  display:grid;
  grid-template-columns:1fr 40px 1fr 40px 1fr;
  gap:0; align-items:start;
}
.step-card {
  padding:40px 32px;
  background:var(--glass-bg); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border:1px solid var(--glass-border); border-radius:var(--r-l);
  position:relative; overflow:hidden;
  transition:transform var(--tr), box-shadow var(--tr);
}
.step-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-l); }
.step-num-ghost {
  position:absolute; top:-12px; right:12px;
  font-size:5.5rem; font-weight:900; line-height:1;
  color:rgba(58,158,82,0.07); pointer-events:none; user-select:none;
  font-family:'Inter',sans-serif;
}
.step-icon-wrap {
  width:56px; height:56px; border-radius:16px;
  display:flex; align-items:center; justify-content:center; margin-bottom:20px;
  font-size:26px;
}
.step-icon-wrap svg { width:26px; height:26px; }
.step-icon-1 { background:rgba(58,158,82,0.14); color:var(--green-p); }
.step-icon-2 { background:rgba(232,168,58,0.16); color:var(--amber-d); }
.step-icon-3 { background:rgba(224,100,58,0.14); color:var(--coral); }
.step-card h3 { font-size:1.15rem; font-weight:600; margin-bottom:10px; color:var(--text); }
.step-card p  { font-size:0.9rem; color:var(--text-m); line-height:1.7; }
.step-connector {
  display:flex; align-items:center; justify-content:center;
  color:var(--text-d); font-size:1.4rem; padding-top:60px;
}
.step-connector svg { width:22px; height:22px; }

/* ══════════════════════════════
   FEATURE ROWS
══════════════════════════════ */
.feat-row { padding:80px 0; position:relative; z-index:1; }
.feat-row-amber  { background:rgba(232,168,58,0.055); }
.feat-row-purple { background:rgba(158,100,232,0.045); }
.feat-row-sky    { background:rgba(74,158,216,0.055); }
.feat-row-inner { max-width:1200px; margin:0 auto; padding:0 24px; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.feat-row-inner.rev { direction:rtl; }
.feat-row-inner.rev > * { direction:ltr; }
.feat-row-text h2 { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,3.5vw,2.6rem); font-weight:500; margin-bottom:1rem; color:var(--text); }
.feat-row-text p  { color:var(--text-m); line-height:1.8; margin-bottom:1.8rem; }
.feat-row-list { list-style:none; display:flex; flex-direction:column; gap:12px; }
.feat-row-list li { display:flex; align-items:center; gap:12px; font-size:0.95rem; color:var(--text-m); }
.feat-row-list li::before {
  content:''; width:20px; height:20px; flex-shrink:0; border-radius:50%;
  background:rgba(58,158,82,0.14); border:1px solid rgba(58,158,82,0.30);
  background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%233a9e52' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center;
}
.feat-row-visual { position:relative; display:flex; justify-content:center; align-items:center; }

/* Garden map mockup */
.map-mockup {
  width:100%; max-width:460px;
  background:var(--glass-bg-deep); backdrop-filter:blur(20px); border:1px solid rgba(130,200,150,0.40);
  border-radius:var(--r-l); overflow:hidden; box-shadow:var(--shadow-l); padding:24px;
}
.map-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.map-header h4 { font-size:1rem; font-weight:600; color:var(--text); }
.map-controls { display:flex; gap:8px; }
.map-controls span { width:10px; height:10px; border-radius:50%; }
.c-red { background:#e84a4a; } .c-amber { background:var(--amber); } .c-green { background:var(--green-p); }
.map-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:16px; }
.map-bed {
  aspect-ratio:1; border-radius:12px; display:flex; align-items:center; justify-content:center;
  transition:transform var(--tr); cursor:default; font-size:24px;
}
.map-bed:hover { transform:scale(1.08); }
.map-bed svg { width:24px; height:24px; }
.bed-tomato  { background:rgba(224,100,58,0.16); border:1px solid rgba(224,100,58,0.28); color:var(--coral); }
.bed-carrot  { background:rgba(232,168,58,0.18); border:1px solid rgba(232,168,58,0.30); color:var(--amber-d); }
.bed-lettuce { background:rgba(58,158,82,0.18);  border:1px solid rgba(58,158,82,0.30);  color:var(--green-p); }
.bed-herb    { background:rgba(82,184,160,0.18);  border:1px solid rgba(82,184,160,0.30); color:#2a9880; }
.bed-pumpkin { background:rgba(232,168,58,0.14);  border:1px solid rgba(232,168,58,0.26); color:var(--amber); }
.bed-pepper  { background:rgba(224,100,58,0.14);  border:1px solid rgba(224,100,58,0.26); color:var(--coral); }
.bed-basil   { background:rgba(58,158,82,0.14);   border:1px solid rgba(58,158,82,0.26);  color:var(--green-d); }
.bed-empty   { background:rgba(200,240,212,0.50);  border:1px dashed rgba(100,180,130,0.36); color:rgba(100,160,120,0.55); }
.map-legend { display:flex; flex-wrap:wrap; gap:8px; }
.map-legend-item { display:flex; align-items:center; gap:6px; font-size:0.72rem; color:var(--text-m); }
.legend-dot { width:10px; height:10px; border-radius:4px; flex-shrink:0; }

/* AI mockup */
.ai-mockup { width:100%; max-width:420px; background:var(--glass-bg-deep); backdrop-filter:blur(20px); border:1px solid rgba(130,200,150,0.40); border-radius:var(--r-l); overflow:hidden; box-shadow:var(--shadow-l); }
.ai-camera-view {
  height:220px; background-image:url('../assets/plant.png');
  background-size:cover; background-position:center;
  position:relative; display:flex; align-items:center; justify-content:center;
}
.ai-camera-view::after { content:''; position:absolute; inset:0; background:rgba(218,244,230,0.28); border-bottom:1px solid rgba(130,200,150,0.32); }
.ai-scan-ring { position:relative; z-index:1; width:120px; height:120px; border-radius:50%; border:2px solid rgba(58,158,82,0.85); box-shadow:0 0 0 4px rgba(58,158,82,0.15), 0 0 30px rgba(58,158,82,0.30); animation:scan-pulse 2s ease-in-out infinite; }
@keyframes scan-pulse { 0%,100% { transform:scale(1); opacity:1; } 50% { transform:scale(1.08); opacity:0.7; } }
.ai-result { padding:20px; }
.ai-result-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(58,158,82,0.12); border:1px solid rgba(58,158,82,0.28); border-radius:100px; padding:6px 14px; font-size:0.75rem; font-weight:600; color:var(--green-d); margin-bottom:14px; }
.ai-result-badge::before { content:''; width:8px; height:8px; border-radius:50%; background:var(--green-p); animation:pulse-dot 2s infinite; }
@keyframes pulse-dot { 0%,100% { box-shadow:0 0 6px var(--green-p); } 50% { box-shadow:0 0 18px var(--green-p); } }
.ai-result h4 { font-size:1.1rem; font-weight:600; margin-bottom:6px; color:var(--text); }
.ai-result p  { font-size:0.8rem; color:var(--text-m); line-height:1.6; margin-bottom:14px; }
.ai-tags { display:flex; flex-wrap:wrap; gap:8px; }
.ai-tag { font-size:0.72rem; padding:4px 12px; border-radius:100px; border:1px solid rgba(58,158,82,0.28); color:var(--text-m); background:rgba(58,158,82,0.08); }

/* Weather mockup */
.weather-mockup { width:100%; max-width:420px; display:flex; flex-direction:column; gap:12px; }
.w-card { background:var(--glass-bg); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px); border:1px solid var(--glass-border); border-radius:var(--r-m); padding:20px; transition:transform var(--tr), box-shadow var(--tr); }
.w-card:hover { transform:translateX(6px); box-shadow:var(--shadow); }
.w-card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.w-card-title { font-size:0.9rem; font-weight:600; color:var(--text); display:flex; align-items:center; gap:8px; }
.w-badge { font-size:0.68rem; font-weight:700; padding:3px 10px; border-radius:100px; text-transform:uppercase; letter-spacing:0.06em; }
.w-badge-alert { background:rgba(224,100,58,0.14); color:var(--coral); border:1px solid rgba(224,100,58,0.25); }
.w-badge-info  { background:rgba(74,158,216,0.14); color:var(--sky);   border:1px solid rgba(74,158,216,0.25); }
.w-badge-ok    { background:rgba(58,158,82,0.14);  color:var(--green-d); border:1px solid rgba(58,158,82,0.28); }
.w-card p { font-size:0.82rem; color:var(--text-m); line-height:1.6; }
.w-forecast { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; }
.w-day { text-align:center; padding:10px 6px; background:rgba(255,255,255,0.60); border:1px solid rgba(130,200,150,0.22); border-radius:var(--r-s); font-size:0.72rem; }
.w-day .day-name { color:var(--text-m); margin-bottom:6px; }
.w-day .day-icon { font-size:1.2rem; margin-bottom:6px; display:flex; justify-content:center; align-items:center; min-height:24px; }
.w-title-icon { font-size:18px; width:18px; height:18px; flex-shrink:0; }
.w-icon-sky   { color:var(--sky); }
.w-icon-green { color:var(--green-p); }
.w-forecast-icon { font-size:20px; width:20px; height:20px; display:block; }
.w-day .day-temp { font-weight:600; color:var(--text); }

/* ══════════════════════════════
   SCREENSHOTS — 3D PERSPECTIVE
══════════════════════════════ */
#screenshots { padding:100px 0; }
.screenshots-perspective {
  display:flex; justify-content:center; align-items:flex-end;
  perspective:1400px; perspective-origin:50% 40%;
  gap:0; padding:20px 0 40px;
}
.persp-phone { flex-shrink:0; transition:transform 0.5s var(--ease); }
.persp-left {
  transform:rotateY(22deg) rotateX(3deg) translateX(40px) scale(0.86);
  transform-origin:right center; z-index:1;
  width:216px;
}
.persp-right {
  transform:rotateY(-22deg) rotateX(3deg) translateX(-40px) scale(0.86);
  transform-origin:left center; z-index:1;
  width:216px;
}
.persp-center {
  transform:scale(1.08) translateZ(0);
  z-index:3; width:244px;
}
.screenshots-perspective:hover .persp-left {
  transform:rotateY(12deg) rotateX(2deg) translateX(24px) scale(0.90);
}
.screenshots-perspective:hover .persp-right {
  transform:rotateY(-12deg) rotateX(2deg) translateX(-24px) scale(0.90);
}

.phone-frame {
  border-radius:38px;
  border:1.5px solid rgba(255,255,255,0.90);
  background:rgba(245,253,248,0.96);
  overflow:hidden;
  box-shadow:0 0 0 1px rgba(130,200,150,0.15), 0 30px 60px rgba(30,100,50,0.16);
  position:relative;
}
.phone-frame .pn-notch { position:absolute; top:10px; left:50%; transform:translateX(-50%); width:68px; height:18px; background:#1a3a22; border-radius:100px; z-index:2; }
.phone-screen-ui { width:100%; aspect-ratio:9/19; background:linear-gradient(180deg, rgba(242,252,244,0.97) 0%, rgba(238,250,242,0.99) 100%); padding:36px 13px 14px; display:flex; flex-direction:column; gap:9px; overflow:hidden; }
.ss-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:4px; }
.ss-header h5    { font-size:0.73rem; font-weight:700; color:var(--text); }
.ss-header small { font-size:0.62rem; color:var(--text-d); }
.ss-map-mini { border-radius:14px; background:rgba(255,255,255,0.72); border:1px solid rgba(130,200,150,0.28); display:grid; grid-template-columns:repeat(2,1fr); gap:7px; padding:10px; }
.ss-bed { border-radius:10px; aspect-ratio:1; display:flex; align-items:center; justify-content:center; font-size:18px; }
.ss-bed svg { width:18px; height:18px; }
.ss-plant-list { display:flex; flex-direction:column; gap:6px; margin-top:4px; }
.ss-plant-row  { display:flex; align-items:center; gap:7px; font-size:0.66rem; color:var(--text-m); }
.ss-pdot       { width:7px; height:7px; border-radius:50%; flex-shrink:0; display:inline-block; }
.ss-task-list { display:flex; flex-direction:column; gap:7px; }
.ss-task { display:flex; align-items:center; gap:7px; background:rgba(255,255,255,0.74); border:1px solid rgba(130,200,150,0.22); border-radius:10px; padding:7px 9px; }
.ss-task .ss-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.ss-task-info { flex:1; min-width:0; }
.ss-task-title { font-size:0.63rem; font-weight:600; color:var(--text); display:flex; align-items:center; gap:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ss-task-title svg { width:10px; height:10px; flex-shrink:0; }
.ss-task-sub  { font-size:0.58rem; color:var(--text-m); margin-top:1px; }
.ss-time      { font-size:0.58rem; color:var(--text-d); margin-left:auto; white-space:nowrap; flex-shrink:0; }
.ss-task-done { opacity:0.42; }
.ss-task-done .ss-task-title { text-decoration:line-through; }
.ss-ai-scan { flex:0 0 auto; height:118px; background:linear-gradient(135deg, rgba(200,240,210,0.60), rgba(220,248,228,0.76)); border-radius:14px; border:1px solid rgba(130,200,150,0.32); display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; color:var(--green-p); font-size:32px; }
.ss-ai-scan svg { width:32px; height:32px; position:relative; z-index:1; }
.ss-ai-scan::after { content:''; position:absolute; width:70px; height:70px; border-radius:50%; border:2px solid rgba(58,158,82,0.55); animation:scan-pulse 2s infinite; }
.ss-ai-result { background:rgba(255,255,255,0.72); border:1px solid rgba(130,200,150,0.28); border-radius:12px; padding:9px 11px; }
.ss-ai-result .ai-r-name { font-size:0.73rem; font-weight:700; color:var(--text); }
.ss-ai-result .ai-r-sub  { font-size:0.62rem; color:var(--text-m); }
.ss-ai-conf { display:flex; align-items:center; gap:6px; margin-top:5px; }
.ss-ai-conf .conf-bar { flex:1; height:4px; border-radius:2px; background:rgba(26,58,34,0.08); overflow:hidden; }
.ss-ai-conf .conf-fill { height:100%; border-radius:2px; width:93%; background:linear-gradient(90deg, var(--green-d), var(--green-p)); }
.ss-ai-conf small { font-size:0.63rem; color:var(--green-d); }

/* ══════════════════════════════
   FAQ — TWO COLUMNS
══════════════════════════════ */
#faq { padding:100px 0; }
.faq-cols {
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
  max-width:1100px; margin:0 auto;
}
.faq-col { display:flex; flex-direction:column; gap:12px; }
.faq-item { background:var(--glass-bg); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px); border:1px solid var(--glass-border); border-radius:var(--r-m); overflow:hidden; transition:border-color var(--tr); }
.faq-item.open { border-color:rgba(58,158,82,0.48); }
.faq-q { display:flex; align-items:center; justify-content:space-between; padding:22px 24px; font-size:0.95rem; font-weight:500; color:var(--text); cursor:pointer; transition:background var(--tr); gap:16px; }
.faq-q:hover { background:rgba(58,158,82,0.05); }
.faq-q-icon {
  width:26px; height:26px; flex-shrink:0; border-radius:50%;
  border:1px solid var(--glass-border); display:flex; align-items:center; justify-content:center;
  transition:transform var(--tr), background var(--tr), border-color var(--tr);
  font-size:14px; color:var(--text-m);
}
.faq-item.open .faq-q-icon { transform:rotate(45deg); background:rgba(58,158,82,0.14); border-color:rgba(58,158,82,0.42); color:var(--green-p); }
.faq-q-icon svg { width:14px; height:14px; }
.faq-a { display:grid; grid-template-rows:0fr; transition:grid-template-rows 0.35s var(--ease); }
.faq-item.open .faq-a { grid-template-rows:1fr; }
.faq-a-inner { overflow:hidden; padding:0 24px; color:var(--text-m); font-size:0.88rem; line-height:1.8; }
.faq-item.open .faq-a-inner { padding-bottom:20px; }

/* ══════════════════════════════
   CTA
══════════════════════════════ */
#final-cta { padding:100px 24px; text-align:center; }
.cta-box {
  max-width:1100px; margin:0 auto;
  background:linear-gradient(135deg, #1e4a28 0%, var(--text) 60%, #0e2a14 100%);
  border-radius:var(--r-xl); padding:80px 60px;
  position:relative; overflow:hidden;
}
.cta-box-bg {
  position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse at 20% 50%, rgba(232,168,58,0.18) 0%, transparent 50%),
             radial-gradient(ellipse at 80% 50%, rgba(58,158,82,0.14) 0%, transparent 50%);
}
.cta-box h2 {
  font-family:'Playfair Display',serif; font-size:clamp(2rem,4vw,3rem);
  margin-bottom:1rem; color:#fff; position:relative;
}
.cta-box p { color:rgba(255,255,255,0.68); font-size:1.05rem; max-width:520px; margin:0 auto 2rem; line-height:1.7; position:relative; }
.cta-box p strong { color:rgba(255,255,255,0.88); }
.cta-platforms {
  display:flex; justify-content:center; gap:28px; flex-wrap:wrap;
  position:relative;
}
.cta-platforms span {
  display:flex; align-items:center; gap:8px;
  font-size:0.85rem; color:rgba(255,255,255,0.50);
  background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12);
  padding:10px 20px; border-radius:100px;
}
.cta-platforms span svg { width:14px; height:14px; }

/* ── Footer ── */
#footer { position:relative; z-index:1; background:rgba(215,242,222,0.82); backdrop-filter:blur(20px); border-top:1px solid rgba(130,200,150,0.24); padding:60px 24px 30px; }
.footer-inner { max-width:1200px; margin:0 auto; }
.footer-top { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(130,200,150,0.20); }
.footer-brand p { font-size:0.875rem; color:var(--text-m); line-height:1.7; max-width:260px; }
.footer-social { display:flex; gap:12px; margin-top:20px; }
.social-btn { width:36px; height:36px; display:flex; align-items:center; justify-content:center; background:rgba(255,255,255,0.58); border:1px solid rgba(130,200,150,0.32); border-radius:10px; color:var(--text-m); transition:var(--tr); }
.social-btn:hover { color:var(--text); background:rgba(255,255,255,0.84); border-color:rgba(58,158,82,0.45); transform:translateY(-2px); }
.social-btn svg { width:16px; height:16px; fill:currentColor; }
.footer-col h5 { font-size:0.85rem; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; color:var(--text); margin-bottom:16px; }
.footer-col ul li { margin-bottom:10px; }
.footer-col ul li a { font-size:0.875rem; color:var(--text-m); transition:color var(--tr); }
.footer-col ul li a:hover { color:var(--green-p); }
.footer-col ul li button.link-btn { font-size:0.875rem; color:var(--text-m); transition:color var(--tr); background:none; border:none; padding:0; cursor:pointer; }
.footer-col ul li button.link-btn:hover { color:var(--green-p); }
.footer-bottom { padding-top:28px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:0.8rem; color:var(--text-d); }
.footer-bottom-links { display:flex; gap:20px; flex-wrap:wrap; }
.footer-bottom-links button, .footer-bottom-links a { font-size:0.8rem; color:var(--text-d); background:none; border:none; cursor:pointer; transition:color var(--tr); padding:0; }
.footer-bottom-links button:hover, .footer-bottom-links a:hover { color:var(--text-m); }

/* ── Modals ── */
.modal-overlay { position:fixed; inset:0; z-index:200; background:rgba(160,220,180,0.40); backdrop-filter:blur(10px); display:flex; align-items:center; justify-content:center; padding:24px; opacity:0; pointer-events:none; transition:opacity var(--tr); }
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal-box { background:rgba(255,255,255,0.90); backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px); border:1px solid rgba(130,200,150,0.40); border-radius:var(--r-l); width:100%; max-width:660px; max-height:80vh; display:flex; flex-direction:column; transform:translateY(20px) scale(0.97); transition:transform var(--tr); box-shadow:var(--shadow-l); }
.modal-overlay.open .modal-box { transform:translateY(0) scale(1); }
.modal-header { padding:28px 32px; border-bottom:1px solid rgba(130,200,150,0.22); display:flex; align-items:center; justify-content:space-between; }
.modal-header h3 { font-size:1.2rem; font-weight:600; color:var(--text); }
.modal-close { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:rgba(0,0,0,0.04); border:1px solid rgba(0,0,0,0.09); color:var(--text-m); transition:var(--tr); }
.modal-close:hover { background:rgba(0,0,0,0.08); color:var(--text); }
.modal-close svg { width:16px; height:16px; stroke:currentColor; }
.modal-body { padding:32px; overflow-y:auto; }
.modal-body::-webkit-scrollbar { width:4px; }
.modal-body::-webkit-scrollbar-thumb { background:rgba(58,158,82,0.28); border-radius:2px; }
.modal-body h4 { font-size:1rem; font-weight:600; margin:1.5rem 0 0.5rem; color:var(--text); }
.modal-body h4:first-child { margin-top:0; }
.modal-body p  { font-size:0.875rem; color:var(--text-m); line-height:1.8; margin-bottom:0.75rem; }
.modal-body ul { padding-left:20px; }
.modal-body ul li { font-size:0.875rem; color:var(--text-m); line-height:1.8; margin-bottom:6px; }

/* ── Cookie banner ── */
#cookie-banner { position:fixed; bottom:24px; left:24px; right:24px; z-index:150; display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; background:rgba(248,255,250,0.95); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border:1px solid rgba(130,200,150,0.38); border-radius:var(--r-m); padding:18px 24px; box-shadow:0 16px 40px rgba(30,100,50,0.13); transform:translateY(120%); transition:transform 0.5s var(--ease); max-width:900px; margin:0 auto; }
#cookie-banner.visible { transform:translateY(0); }
.cookie-text { flex:1; font-size:0.85rem; color:var(--text-m); line-height:1.6; min-width:220px; }
.link-btn { color:var(--green-p); text-decoration:underline; cursor:pointer; font:inherit; background:none; border:none; padding:0; }
.cookie-actions { display:flex; gap:10px; flex-wrap:wrap; }
.btn-cookie-decline { padding:9px 18px; border-radius:100px; font-size:0.82rem; font-weight:500; background:rgba(0,0,0,0.04); border:1px solid rgba(0,0,0,0.10); color:var(--text-m); transition:var(--tr); }
.btn-cookie-decline:hover { background:rgba(0,0,0,0.08); color:var(--text); }
.btn-cookie-accept { padding:9px 18px; border-radius:100px; font-size:0.82rem; font-weight:600; background:linear-gradient(135deg, var(--amber), var(--coral)); color:#fff; transition:var(--tr); }
.btn-cookie-accept:hover { opacity:0.9; transform:translateY(-1px); }

/* ── Scroll animations ── */
.reveal { opacity:0; transform:translateY(32px); transition:opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-left  { opacity:0; transform:translateX(-32px); transition:opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal-right { opacity:0; transform:translateX(32px);  transition:opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal-left.visible, .reveal-right.visible { opacity:1; transform:translateX(0); }
.delay-1{transition-delay:.1s} .delay-2{transition-delay:.2s} .delay-3{transition-delay:.3s}
.delay-4{transition-delay:.4s} .delay-5{transition-delay:.5s}

/* ── Responsive ── */
@media (max-width:1024px) {
  .stats-strip { flex-wrap:wrap; }
  .stat-strip-div { display:none; }
  .stat-strip-item { flex:1 1 40%; }
  .bento-grid { grid-template-columns:repeat(2,1fr); }
  .bento-w2 { grid-column:span 2; }
  .steps-grid { grid-template-columns:1fr; gap:20px; }
  .step-connector { display:none; }
  .footer-top { grid-template-columns:1fr 1fr; gap:32px; }
  .faq-cols { grid-template-columns:1fr; }
}
@media (max-width:768px) {
  .nav-links, .nav-cta { display:none; }
  .hamburger { display:flex; }
  .hero-inner { grid-template-columns:1fr; padding:60px 24px; text-align:center; }
  .hero-showcase { display:none; }
  .hero-stats { justify-content:center; }
  .hero-actions { justify-content:center; }
  .bento-grid { grid-template-columns:1fr; }
  .bento-w2 { grid-column:span 1; flex-direction:column; }
  .feat-row-inner, .feat-row-inner.rev { grid-template-columns:1fr; direction:ltr; gap:40px; }
  .footer-top { grid-template-columns:1fr; gap:24px; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }
  .screenshots-perspective { gap:0; }
  .persp-left, .persp-right { display:none; }
  .persp-center { transform:scale(1); width:min(290px,78vw); }
  .cta-box { padding:48px 28px; }
  .cta-platforms { flex-direction:column; align-items:center; gap:12px; }
  #cookie-banner { left:12px; right:12px; bottom:12px; }
}
@media (max-width:480px) {
  .stat-strip-item { flex:1 1 100%; }
  .stats-strip { border-radius:var(--r-m); }
}
