/* ============================
   CALVEO — CSS
   Sage green + violet · glassmorphism
   ============================ */

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

/* ── Variables ── */
:root {
  /* Sage-emerald greens */
  --green-p:      #4d9e78;
  --green-l:      #72c498;
  --green-d:      #2d7a56;
  --green-xl:     #d4f0e4;
  /* Violet accent */
  --purple:       #7c5cbf;
  --purple-l:     #a480e0;
  --purple-d:     #5a3a9e;
  --purple-xl:    #ede0ff;
  /* Teal bridge */
  --teal:         #2ab8a0;
  --teal-l:       #56d4be;
  /* Warm sage */
  --sage:         #9ab87a;
  /* Glass system */
  --glass-bg:     rgba(255, 255, 255, 0.56);
  --glass-bg-deep:rgba(255, 255, 255, 0.72);
  --glass-border: rgba(120, 180, 150, 0.32);
  --glass-hover:  rgba(255, 255, 255, 0.76);
  /* Text */
  --text:         #162820;
  --text-m:       #3d6850;
  --text-d:       #7aaa90;
  --white:        rgba(255,255,255,0.96);
  /* Radius */
  --r-s:  10px;
  --r-m:  18px;
  --r-l:  28px;
  --r-xl: 44px;
  /* Motion */
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --tr:   0.3s var(--ease);
  /* Shadows */
  --shadow:   0 8px 30px rgba(20, 70, 50, 0.11);
  --shadow-l: 0 24px 60px rgba(15, 50, 35, 0.15);
  --shadow-v: 0 8px 30px rgba(90, 58, 158, 0.12);
}

/* ── 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(150deg, #f0faf4 0%, #f6f2ff 55%, #eef8f4 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(100px); opacity:0.55;
}
.bg-orb-1 {
  width:720px; height:720px;
  background:radial-gradient(circle, rgba(77,158,120,0.55) 0%, transparent 70%);
  top:-220px; left:-180px;
}
.bg-orb-2 {
  width:540px; height:540px;
  background:radial-gradient(circle, rgba(124,92,191,0.50) 0%, transparent 70%);
  top:35vh; right:-180px;
}
.bg-orb-3 {
  width:620px; height:620px;
  background:radial-gradient(circle, rgba(42,184,160,0.42) 0%, transparent 70%);
  bottom:-120px; left:18%;
}
.bg-orb-4 {
  width:400px; height:400px;
  background:radial-gradient(circle, rgba(160,128,224,0.40) 0%, transparent 70%);
  top:65vh; left:-120px; opacity:0.38;
}

/* ── Typography ── */
h1,h2,h3,h4 { line-height:1.2; }
.display {
  font-family:'DM Serif Display', serif;
  font-size:clamp(2.8rem, 6vw, 5rem);
  font-weight:400; letter-spacing:-0.01em;
}
.section-title {
  font-family:'DM Serif Display', serif;
  font-size:clamp(2rem, 4vw, 3rem); font-weight:400; margin-bottom:1rem;
  background: linear-gradient(135deg, var(--green-d) 0%, var(--purple) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-subtitle { font-size:1.1rem; color:var(--text-m); max-width:560px; line-height:1.7; }

/* ── Tag pill ── */
.tag {
  display:inline-block; font-size:0.74rem; font-weight:600;
  letter-spacing:0.10em; text-transform:uppercase;
  color:var(--purple-d);
  background: linear-gradient(135deg, rgba(77,158,120,0.14), rgba(124,92,191,0.12));
  border:1px solid rgba(124,92,191,0.28);
  border-radius:100px; padding:5px 16px; margin-bottom:1.2rem;
}

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  font-size:0.95rem; font-weight:600; border-radius:100px;
  padding:14px 32px; transition:var(--tr);
  position:relative; overflow:hidden; white-space:nowrap;
}
.btn::after { content:''; position:absolute; inset:0; background:rgba(255,255,255,0); transition:background var(--tr); }
.btn:hover::after { background:rgba(255,255,255,0.14); }
.btn-primary {
  background: linear-gradient(135deg, var(--green-p) 0%, var(--purple) 100%);
  color:#fff;
  box-shadow: 0 4px 22px rgba(100,80,180,0.32);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(100,80,180,0.44); }
.btn-glass {
  background:var(--glass-bg); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border:1px solid var(--glass-border); color:var(--text);
}
.btn-glass:hover { background:var(--glass-hover); transform:translateY(-2px); }
.store-btn {
  display:inline-flex; align-items:center; gap:12px;
  padding:12px 24px; background:rgba(255,255,255,0.62);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(120,180,150,0.32); border-radius:var(--r-m);
  color:var(--text); font-size:0.9rem; transition:var(--tr);
}
.store-btn:hover { background:rgba(255,255,255,0.84); transform:translateY(-2px); box-shadow:var(--shadow); }
.store-btn .store-icon { width:28px; height:28px; }
.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(242,252,246,0.92);
  backdrop-filter:blur(22px); -webkit-backdrop-filter:blur(22px);
  border-bottom:1px solid rgba(120,180,150,0.28);
  box-shadow:0 4px 24px rgba(20,70,50,0.07);
}
.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);
  letter-spacing:-0.01em;
}
.nav-logo .logo-icon {
  width:36px; height:36px;
  background: linear-gradient(135deg, var(--green-p) 0%, var(--purple) 100%);
  border-radius:10px; display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 14px rgba(100,80,180,0.28);
}
.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(242,252,246,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(240,252,246,0.95) 0%,
    rgba(244,242,255,0.88) 45%,
    rgba(235,250,242,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(--purple) 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-visual { display:flex; justify-content:center; align-items:center; position:relative; }

/* ── iPhone Mockup — light glass ── */
.hero-phone-scene { position:relative; width:380px; height:570px; flex-shrink:0; }
.iphone-mockup {
  position:absolute; top:28px; left:70px;
  width:240px; height:512px;
  background:rgba(246,252,250,0.97);
  border-radius:48px;
  border:1.5px solid rgba(255,255,255,0.94);
  overflow:hidden; z-index:2;
  box-shadow:
    0 0 0 1px rgba(120,180,160,0.16),
    inset 0 0 0 1px rgba(255,255,255,0.78),
    0 40px 80px rgba(20,60,40,0.20);
}
.iphone-island {
  position:absolute; top:12px; left:50%; transform:translateX(-50%);
  width:88px; height:26px;
  background:linear-gradient(135deg, #162820, #2d3a58);
  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,248,0.38) 0%,
    rgba(244,240,255,0.65) 38%,
    rgba(242,250,248,0.91) 65%,
    rgba(240,252,248,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(22,40,32,0.48);
  text-transform:uppercase; letter-spacing:0.12em; display:block; margin-bottom:4px;
}
.iphone-headline {
  font-family:'DM Serif Display', serif;
  font-size:1.1rem; font-weight:400; color:var(--text); line-height:1.3;
}
.iphone-headline em {
  background: linear-gradient(135deg, var(--green-p), var(--purple));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-style:italic;
}
.iphone-weather-row {
  display:flex; align-items:center; gap:7px;
  background:rgba(255,255,255,0.70); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(120,180,150,0.30); border-radius:12px; padding:6px 10px;
}
.iw-icon { width:15px; height:15px; color:var(--purple); stroke:currentColor; flex-shrink:0; }
.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.70);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(120,180,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(22,40,32,0.44); 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(22,40,32,0.18); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.itc-checked { background:var(--green-p); border-color:var(--green-p); }
.itc-checked svg { width:10px; height:10px; stroke:#fff; stroke-width:3; }
.iphone-dock { display:flex; justify-content:center; gap:18px; padding:5px 0; border-top:1px solid rgba(22,40,32,0.07); }
.iphone-dock-btn { width:30px; height:30px; border-radius:9px; display:flex; align-items:center; justify-content:center; color:rgba(22,40,32,0.42); }
.iphone-dock-btn svg { width:15px; height:15px; }
.iphone-dock-add { background:linear-gradient(135deg, var(--green-p), var(--purple)); color:#fff; }
.iphone-home-bar { width:72px; height:4px; border-radius:2px; background:rgba(22,40,32,0.16); margin:3px auto 0; }

/* Float cards */
.float-card {
  position:absolute; z-index:5;
  background:rgba(255,255,255,0.78);
  backdrop-filter:blur(22px); -webkit-backdrop-filter:blur(22px);
  border-radius:18px;
  box-shadow:0 12px 36px rgba(20,60,40,0.12);
}
.float-frost {
  top:20px; left:0;
  display:flex; align-items:center; gap:10px; padding:10px 14px;
  border:1px solid rgba(124,92,191,0.30);
  animation:fc-float 4s ease-in-out infinite;
}
.float-plant {
  top:110px; right:0;
  display:flex; align-items:center; gap:10px; padding:10px 14px;
  border:1px solid rgba(77,158,120,0.35);
  animation:fc-float 4.5s ease-in-out infinite 1s;
}
.float-week  {
  bottom:22px; right:0; padding:12px 14px;
  border:1px solid rgba(42,184,160,0.30);
  animation:fc-float 5s ease-in-out infinite 0.5s;
}
@keyframes fc-float { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-7px); } }
.fc-icon { width:32px; height:32px; border-radius:10px; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.fc-icon svg { width:15px; height:15px; }
.fc-icon-frost { background:rgba(124,92,191,0.14); color:var(--purple); }
.fc-label { font-size:0.58rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:rgba(22,40,32,0.48); }
.fc-value { font-size:0.8rem; font-weight:600; color:var(--text); margin-top:2px; }
.fc-plant-thumb { width:40px; height:40px; border-radius:12px; flex-shrink:0; background:rgba(77,158,120,0.14); border:1px solid rgba(77,158,120,0.25); display:flex; align-items:center; justify-content:center; color:var(--green-p); }
.fc-plant-thumb svg { width:20px; height:20px; }
.fc-plant-name { font-size:0.78rem; font-weight:600; color:var(--text); white-space:nowrap; }
.fc-plant-sci  { font-size:0.6rem; color:var(--text-m); font-style:italic; }
.fc-match { display:flex; align-items:center; gap:6px; margin-top:5px; }
.fc-match-bar { flex:1; height:3px; min-width:70px; background:rgba(22,40,32,0.08); border-radius:2px; overflow:hidden; }
.fc-match-fill { width:92%; height:100%; background:linear-gradient(90deg, var(--green-p), var(--purple)); border-radius:2px; }
.fc-match-pct { font-size:0.65rem; font-weight:700; color:var(--purple); }
.fc-week-label { font-size:0.57rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:rgba(22,40,32,0.44); margin-bottom:8px; }
.fc-week-item { display:flex; align-items:center; gap:7px; font-size:0.68rem; color:rgba(22,40,32,0.74); margin-bottom:5px; white-space:nowrap; }
.fc-week-item:last-child { margin-bottom:0; }
.fc-week-item svg { width:12px; height:12px; flex-shrink:0; }
.fc-week-done { text-decoration:line-through; opacity:0.40; }
.fc-week-done svg { stroke:var(--green-p); }
.fc-week-item:not(.fc-week-done) svg { stroke:rgba(22,40,32,0.26); }

/* ── Stats bar — individual cards ── */
#stats-bar { position:relative; z-index:1; padding:0 24px; }
.stats-inner {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.stat-item {
  padding:28px 24px; text-align:center;
  background:var(--glass-bg);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border-radius:var(--r-m);
  border:1px solid rgba(255,255,255,0.70);
  position:relative; overflow:hidden;
  transition:transform var(--tr), box-shadow var(--tr);
}
.stat-item::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px; border-radius:var(--r-m) var(--r-m) 0 0;
}
.stat-item:hover { transform:translateY(-4px); }
.stat-item:nth-child(1)::before { background:linear-gradient(90deg, var(--green-p), var(--teal)); }
.stat-item:nth-child(2)::before { background:linear-gradient(90deg, var(--purple), var(--teal)); }
.stat-item:nth-child(3)::before { background:linear-gradient(90deg, var(--teal), var(--green-p)); }
.stat-item:nth-child(4)::before { background:linear-gradient(90deg, var(--purple-l), var(--purple-d)); }
.stat-item:nth-child(1) { box-shadow:0 4px 24px rgba(77,158,120,0.12); }
.stat-item:nth-child(2) { box-shadow:0 4px 24px rgba(124,92,191,0.12); }
.stat-item:nth-child(3) { box-shadow:0 4px 24px rgba(42,184,160,0.12); }
.stat-item:nth-child(4) { box-shadow:0 4px 24px rgba(124,92,191,0.10); }
.stat-num { font-size:2.2rem; font-weight:700; color:var(--text); line-height:1; margin-bottom:6px; }
.stat-item:nth-child(1) .stat-num span { color:var(--green-p); }
.stat-item:nth-child(2) .stat-num span { color:var(--purple); }
.stat-item:nth-child(3) .stat-num span { color:var(--teal); }
.stat-item:nth-child(4) .stat-num span { color:var(--purple-l); }
.stat-lbl { font-size:0.85rem; color:var(--text-m); }

/* ── Features ── */
#features { padding:100px 0 80px; }
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.feat-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 rgba(255,255,255,0.68); border-radius:var(--r-l);
  position:relative; overflow:hidden;
  transition:transform var(--tr), box-shadow var(--tr);
}
.feat-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  border-radius:var(--r-l) var(--r-l) 0 0;
  opacity:0.8; transition:opacity var(--tr);
}
.feat-card:hover { transform:translateY(-6px); box-shadow:0 20px 50px rgba(20,50,40,0.11); }
.feat-card:hover::before { opacity:1; }
.feat-card:nth-child(1)::before { background:linear-gradient(90deg, var(--green-p), var(--teal)); }
.feat-card:nth-child(2)::before { background:linear-gradient(90deg, var(--purple), var(--purple-l)); }
.feat-card:nth-child(3)::before { background:linear-gradient(90deg, var(--teal), var(--green-l)); }
.feat-card:nth-child(4)::before { background:linear-gradient(90deg, var(--purple-l), var(--teal)); }
.feat-card:nth-child(5)::before { background:linear-gradient(90deg, var(--green-l), var(--green-p)); }
.feat-card:nth-child(6)::before { background:linear-gradient(90deg, var(--purple-d), var(--purple)); }
.feat-icon { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
.feat-icon svg { width:26px; height:26px; stroke-width:1.8; }
.feat-icon-1 { background:linear-gradient(135deg, rgba(77,158,120,0.18), rgba(114,196,152,0.25));  color:var(--green-p); }
.feat-icon-2 { background:linear-gradient(135deg, rgba(124,92,191,0.18), rgba(164,128,224,0.25)); color:var(--purple); }
.feat-icon-3 { background:linear-gradient(135deg, rgba(42,184,160,0.18), rgba(86,212,190,0.25));  color:var(--teal); }
.feat-icon-4 { background:linear-gradient(135deg, rgba(164,128,224,0.18), rgba(124,92,191,0.25)); color:var(--purple-l); }
.feat-icon-5 { background:linear-gradient(135deg, rgba(114,196,152,0.18), rgba(77,158,120,0.25)); color:var(--green-d); }
.feat-icon-6 { background:linear-gradient(135deg, rgba(90,58,158,0.16), rgba(124,92,191,0.22));   color:var(--purple-d); }
.feat-card h3 { font-size:1.05rem; font-weight:600; margin-bottom:10px; color:var(--text); }
.feat-card p  { font-size:0.9rem; color:var(--text-m); line-height:1.7; }

/* ── How it works ── */
#how-it-works { padding:80px 0 100px; }
.hiw-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:40px; position:relative; }
.hiw-grid::before {
  content:''; position:absolute; top:47px;
  left:calc(16.66% + 32px); right:calc(16.66% + 32px); height:2px;
  background:linear-gradient(90deg, var(--green-p), var(--purple), var(--teal)); opacity:0.38;
  border-radius:2px;
}
.hiw-step { text-align:center; }
.hiw-step-num {
  width:94px; height:94px; border-radius:50%; margin:0 auto 24px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.9rem; font-weight:700; font-family:'DM Serif Display', serif;
  background:rgba(255,255,255,0.68); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  transition:transform var(--tr), box-shadow var(--tr);
}
.hiw-step:nth-child(1) .hiw-step-num { border:2px solid rgba(77,158,120,0.42); color:var(--green-p); }
.hiw-step:nth-child(2) .hiw-step-num { border:2px solid rgba(124,92,191,0.42); color:var(--purple); }
.hiw-step:nth-child(3) .hiw-step-num { border:2px solid rgba(42,184,160,0.42); color:var(--teal); }
.hiw-step:hover .hiw-step-num { transform:scale(1.08); box-shadow:0 0 0 8px rgba(124,92,191,0.08); }
.hiw-step h3 { font-size:1.1rem; font-weight:600; margin-bottom:10px; color:var(--text); }
.hiw-step p  { font-size:0.9rem; color:var(--text-m); line-height:1.7; max-width:240px; margin:0 auto; }

/* ── Feature rows ── */
.feat-row { padding:80px 0; position:relative; z-index:1; }
.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:'DM Serif Display', serif;
  font-size:clamp(1.8rem,3.5vw,2.6rem); font-weight:400; margin-bottom:1rem;
  background: linear-gradient(135deg, var(--green-d) 0%, var(--purple) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: 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:22px; height:22px; flex-shrink:0; border-radius:50%;
  background:linear-gradient(135deg, rgba(77,158,120,0.16), rgba(124,92,191,0.12));
  border:1px solid rgba(124,92,191,0.26);
  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='%234d9e78' 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(255,255,255,0.70);
  border-radius:var(--r-l); overflow:hidden; box-shadow:var(--shadow-l); padding:24px;
  position:relative;
}
.map-mockup::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--green-p), var(--purple));
}
.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(--purple-l); } .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; }
.map-bed:hover { transform:scale(1.08); }
.map-bed svg { width:28px; height:28px; stroke-width:1.8; }
.bed-tomato  { background:rgba(124,92,191,0.16); border:1px solid rgba(124,92,191,0.28); color:var(--purple); }
.bed-carrot  { background:rgba(42,184,160,0.16);  border:1px solid rgba(42,184,160,0.28);  color:var(--teal); }
.bed-lettuce { background:rgba(77,158,120,0.18);  border:1px solid rgba(77,158,120,0.30);  color:var(--green-p); }
.bed-herb    { background:rgba(164,128,224,0.16); border:1px solid rgba(164,128,224,0.28); color:var(--purple-l); }
.bed-pumpkin { background:rgba(114,196,152,0.18); border:1px solid rgba(114,196,152,0.28); color:var(--green-d); }
.bed-pepper  { background:rgba(90,58,158,0.16);   border:1px solid rgba(90,58,158,0.28);   color:var(--purple-d); }
.bed-basil   { background:rgba(77,158,120,0.14);  border:1px solid rgba(77,158,120,0.26);  color:var(--green-p); }
.bed-empty   { background:rgba(210,220,240,0.45); border:1px dashed rgba(124,92,191,0.28); color:rgba(124,92,191,0.45); }
.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(255,255,255,0.70); border-radius:var(--r-l); overflow:hidden; box-shadow:var(--shadow-l);
  position:relative;
}
.ai-mockup::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px; z-index:2;
  background:linear-gradient(90deg, var(--green-p), var(--purple));
}
.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(230,220,248,0.22); border-bottom:1px solid rgba(124,92,191,0.20); }
.ai-scan-ring { position:relative; z-index:1; width:120px; height:120px; border-radius:50%; border:2px solid rgba(124,92,191,0.85); box-shadow:0 0 0 4px rgba(124,92,191,0.14), 0 0 30px rgba(124,92,191,0.28); 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(124,92,191,0.10); border:1px solid rgba(124,92,191,0.28); border-radius:100px; padding:6px 14px; font-size:0.75rem; font-weight:600; color:var(--purple-d); margin-bottom:14px; }
.ai-result-badge::before { content:''; width:8px; height:8px; border-radius:50%; background:var(--purple); animation:pulse-dot 2s infinite; }
@keyframes pulse-dot { 0%,100% { box-shadow:0 0 6px var(--purple); } 50% { box-shadow:0 0 18px var(--purple); } }
.ai-result h4 { font-size:1.05rem; 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(124,92,191,0.24); color:var(--text-m); background:rgba(124,92,191,0.07); }

/* 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 rgba(255,255,255,0.68); border-radius:var(--r-m); padding:20px;
  position:relative; overflow:hidden;
  transition:transform var(--tr), box-shadow var(--tr);
}
.w-card::before { content:''; position:absolute; top:0; left:0; width:3px; bottom:0; border-radius:var(--r-m) 0 0 var(--r-m); }
.w-card:nth-child(1)::before { background:var(--purple); }
.w-card:nth-child(2)::before { background:var(--teal); }
.w-card:nth-child(3)::before { background:var(--green-p); }
.w-card:nth-child(4)::before { background:var(--green-l); }
.w-card:hover { transform:translateX(5px); 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; display:flex; align-items:center; gap:8px; color:var(--text); padding-left:12px; }
.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(124,92,191,0.14); color:var(--purple-d); border:1px solid rgba(124,92,191,0.25); }
.w-badge-info  { background:rgba(42,184,160,0.14); color:var(--teal);      border:1px solid rgba(42,184,160,0.25); }
.w-badge-ok    { background:rgba(77,158,120,0.14); color:var(--green-d);   border:1px solid rgba(77,158,120,0.28); }
.w-card p { font-size:0.82rem; color:var(--text-m); line-height:1.6; padding-left:12px; }
.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.58); border:1px solid rgba(120,100,180,0.14); 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 { width:18px; height:18px; flex-shrink:0; }
.w-icon-purple { color:var(--purple); }
.w-icon-teal   { color:var(--teal); }
.w-icon-green  { color:var(--green-p); }
.w-forecast-icon { width:20px; height:20px; display:block; }
.w-day .day-temp { font-weight:600; color:var(--text); }

/* ── Screenshots ── */
#screenshots { padding:100px 0; }
.screenshots-phones { display:flex; justify-content:center; align-items:flex-end; gap:20px; flex-wrap:nowrap; }
.phone-wrap { flex-shrink:0; transition:transform var(--tr); }
.phone-wrap:hover { transform:translateY(-10px); }
.phone-wrap.center { transform:scale(1.07); }
.phone-wrap.center:hover { transform:scale(1.07) translateY(-10px); }
.phone-frame {
  border-radius:38px;
  border:1.5px solid rgba(255,255,255,0.92);
  background:rgba(246,252,250,0.97);
  overflow:hidden;
  box-shadow:0 0 0 1px rgba(120,100,180,0.10), 0 30px 60px rgba(20,50,40,0.15);
  position:relative;
}
.phone-frame .pn-notch { position:absolute; top:10px; left:50%; transform:translateX(-50%); width:68px; height:18px; background:linear-gradient(135deg, #162820, #2d3a58); border-radius:100px; z-index:2; }
.phone-ss    { width:216px; }
.phone-ss-lg { width:244px; }
.phone-screen-ui {
  width:100%; aspect-ratio:9/19;
  background:linear-gradient(180deg, rgba(244,242,255,0.96) 0%, rgba(242,252,248,0.98) 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.70); border:1px solid rgba(124,92,191,0.20); 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; }
.ss-bed svg { width:22px; height:22px; stroke-width:1.8; }
.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(124,92,191,0.16); 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; stroke:var(--text-d); }
.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(210,195,240,0.55), rgba(225,215,255,0.70)); border-radius:14px; border:1px solid rgba(124,92,191,0.28); display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; color:var(--purple); }
.ss-ai-scan svg { width:34px; height:34px; position:relative; z-index:1; }
.ss-ai-scan::after { content:''; position:absolute; width:74px; height:74px; border-radius:50%; border:2px solid rgba(124,92,191,0.50); animation:scan-pulse 2s infinite; }
.ss-ai-result { background:rgba(255,255,255,0.72); border:1px solid rgba(124,92,191,0.22); 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(22,40,32,0.07); overflow:hidden; }
.ss-ai-conf .conf-fill { height:100%; border-radius:2px; width:93%; background:linear-gradient(90deg, var(--green-p), var(--purple)); }
.ss-ai-conf small { font-size:0.63rem; color:var(--purple-d); }

/* ── FAQ ── */
#faq { padding:100px 0; }
.faq-list { max-width:760px; margin:0 auto; 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 rgba(255,255,255,0.65);
  border-radius:var(--r-m); overflow:hidden;
  transition:border-color var(--tr), box-shadow var(--tr);
  position:relative;
}
.faq-item::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:0;
  background:linear-gradient(180deg, var(--green-p), var(--purple));
  transition:width var(--tr); border-radius:var(--r-m) 0 0 var(--r-m);
}
.faq-item.open { border-color:rgba(124,92,191,0.38); box-shadow:0 4px 20px rgba(90,58,158,0.08); }
.faq-item.open::before { width:3px; }
.faq-q { display:flex; align-items:center; justify-content:space-between; padding:22px 28px; font-size:1rem; font-weight:500; color:var(--text); cursor:pointer; transition:background var(--tr); gap:16px; }
.faq-q:hover { background:rgba(124,92,191,0.04); }
.faq-q-icon { width:24px; height:24px; flex-shrink:0; border-radius:50%; border:1px solid rgba(124,92,191,0.28); display:flex; align-items:center; justify-content:center; transition:transform var(--tr), background var(--tr), border-color var(--tr); }
.faq-item.open .faq-q-icon { transform:rotate(45deg); background:rgba(124,92,191,0.14); border-color:rgba(124,92,191,0.42); }
.faq-q-icon svg { width:14px; height:14px; stroke:var(--text-m); }
.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 28px; color:var(--text-m); font-size:0.9rem; line-height:1.8; }
.faq-item.open .faq-a-inner { padding-bottom:22px; }

/* ── CTA ── */
#final-cta { padding:100px 0; text-align:center; }
.cta-box {
  max-width:700px; margin:0 auto;
  background:var(--glass-bg); backdrop-filter:blur(22px); -webkit-backdrop-filter:blur(22px);
  border:1px solid rgba(255,255,255,0.70);
  border-radius:var(--r-xl); padding:60px 40px;
  position:relative; overflow:hidden;
}
.cta-box::before {
  content:''; position:absolute; inset:-1px;
  background:linear-gradient(135deg, rgba(77,158,120,0.12), rgba(124,92,191,0.14), rgba(42,184,160,0.10));
  border-radius:var(--r-xl); pointer-events:none;
  mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite:xor;
  -webkit-mask-composite:xor;
  border:1.5px solid transparent;
}
.cta-box::after {
  content:''; position:absolute; width:600px; height:600px;
  background:radial-gradient(circle, rgba(124,92,191,0.07) 0%, rgba(77,158,120,0.05) 50%, transparent 70%);
  top:-150px; left:50%; transform:translateX(-50%); border-radius:50%; pointer-events:none;
}
.cta-box h2 { font-family:'DM Serif Display', serif; font-size:clamp(2rem,4vw,2.8rem); margin-bottom:1rem; color:var(--text); position:relative; z-index:1; }
.cta-box p  { color:var(--text-m); font-size:1.05rem; max-width:480px; margin:0 auto 2rem; line-height:1.7; position:relative; z-index:1; }
.cta-platforms { display:flex; justify-content:center; gap:28px; margin-top:28px; flex-wrap:wrap; position:relative; z-index:1; }
.cta-platforms span { display:flex; align-items:center; gap:6px; font-size:0.82rem; color:var(--text-d); }
.cta-platforms svg { width:14px; height:14px; }

/* ── Footer ── */
#footer { position:relative; z-index:1; background:rgba(215,238,228,0.80); backdrop-filter:blur(20px); border-top:1px solid rgba(120,180,150,0.22); 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(120,180,150,0.18); }
.footer-brand .nav-logo { margin-bottom:16px; }
.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(120,180,150,0.30); border-radius:10px; color:var(--text-m); transition:var(--tr); }
.social-btn:hover { color:var(--text); background:rgba(255,255,255,0.85); border-color:rgba(124,92,191,0.38); 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(--purple); }
.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(--purple); }
.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,140,210,0.38); 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.92); backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px); border:1px solid rgba(124,92,191,0.28); 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); position:relative; overflow:hidden; }
.modal-box::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg, var(--green-p), var(--purple)); }
.modal-overlay.open .modal-box { transform:translateY(0) scale(1); }
.modal-header { padding:28px 32px; border-bottom:1px solid rgba(124,92,191,0.16); display:flex; align-items:center; justify-content:space-between; margin-top:3px; }
.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.08); color:var(--text-m); transition:var(--tr); }
.modal-close:hover { background:rgba(124,92,191,0.08); color:var(--purple); }
.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(124,92,191,0.25); 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(250,248,255,0.95); backdrop-filter:blur(22px); -webkit-backdrop-filter:blur(22px); border:1px solid rgba(124,92,191,0.30); border-radius:var(--r-m); padding:18px 24px; box-shadow:0 16px 40px rgba(90,58,158,0.12); 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; }
.cookie-text a { color:var(--purple); text-decoration:underline; }
.link-btn { color:var(--purple); 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(--green-p), var(--purple)); 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-inner { grid-template-columns:repeat(2,1fr); }
  .features-grid { grid-template-columns:repeat(2,1fr); }
  .footer-top { grid-template-columns:1fr 1fr; gap:32px; }
}
@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-visual { display:none; }
  .hero-stats { justify-content:center; }
  .hero-actions { justify-content:center; }
  .features-grid { grid-template-columns:1fr; }
  .feat-row-inner, .feat-row-inner.rev { grid-template-columns:1fr; direction:ltr; gap:40px; }
  .hiw-grid { grid-template-columns:1fr; }
  .hiw-grid::before { display:none; }
  .footer-top { grid-template-columns:1fr; gap:24px; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }
  .screenshots-phones { justify-content:center; overflow-x:hidden; padding:0; }
  .phone-wrap:not(.center) { display:none; }
  .phone-ss-lg { width:min(290px,78vw); }
  .cta-box { padding:40px 24px; }
  #cookie-banner { left:12px; right:12px; bottom:12px; }
}
@media (max-width:480px) {
  .stats-inner { grid-template-columns:1fr 1fr; }
  .stat-item { padding:20px 16px; }
}
