:root{
  /* TAV-LA brand palette (dark) */
  --bg:#0D0D0D;
  --bg-2:#121212;
  --card:#141414;
  --surface2:#1A1A1A;
  --ink:#F5F0E8;
  --ink-soft:#a8a8a8;
  --muted:#6e6e6e;
  --green:#1D9E75;
  --green-deep:#085041;
  --green-tint:#E1F5EE;
  --warn:#E0795F;
  --border:#2A2A2A;
  --border-strong:#363636;
  --shadow:0 1px 2px rgba(0,0,0,.3), 0 18px 40px -18px rgba(0,0,0,.7);
  --shadow-lg:0 40px 80px -28px rgba(0,0,0,.8);
  --glow:0 0 40px -6px rgba(29,158,117,.45);
  --radius:18px;
  --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.08;letter-spacing:-.01em;color:var(--ink)}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}
.eyebrow{font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--green)}
.muted{color:var(--ink-soft)}
.sec-alt{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* Badge */
.badge{display:inline-flex;align-items:center;gap:8px;background:rgba(29,158,117,.12);color:var(--green);
  border:1px solid rgba(29,158,117,.32);padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600}
.badge .star{color:var(--green)}

/* Animated bars inside badge */
.badge-bars{display:inline-flex;align-items:flex-end;gap:2px;height:14px;flex-shrink:0}
.bb{display:block;width:3px;border-radius:2px;background:var(--green);opacity:.85}
.bb1{height:6px;animation:bar-bounce 1.4s ease-in-out infinite;animation-delay:0s}
.bb2{height:10px;animation:bar-bounce 1.4s ease-in-out infinite;animation-delay:.2s}
.bb3{height:14px;animation:bar-bounce 1.4s ease-in-out infinite;animation-delay:.4s}
.bb4{height:8px;animation:bar-bounce 1.4s ease-in-out infinite;animation-delay:.6s}
@keyframes bar-bounce{
  0%,100%{transform:scaleY(1);opacity:.7}
  50%{transform:scaleY(1.5);opacity:1}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;
  font-weight:600;font-size:15px;padding:13px 22px;cursor:pointer;border:1px solid transparent;font-family:inherit;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s, color .2s;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--green);color:#08110d;box-shadow:0 10px 24px -10px rgba(29,158,117,.7)}
.btn-primary:hover{background:#23b485;box-shadow:var(--glow)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--border-strong)}
.btn-outline:hover{border-color:var(--green);color:var(--green);background:var(--surface2)}
.btn-lg{padding:16px 28px;font-size:16px}
.btn-block{width:100%}

/* Nav */
header.nav{position:sticky;top:0;z-index:50;background:rgba(13,13,13,.78);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;transition:border-color .2s, background .2s}
header.nav.scrolled{border-color:var(--border);background:rgba(13,13,13,.92)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:56px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink)}
.logo .mark{width:42px;height:42px;border-radius:12px;background:#111;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:5px;padding:8px;flex-shrink:0}
.logo .mark-dot{width:100%;height:100%;border-radius:3px;display:block}
.logo .mark-dot:nth-child(1){background:#1D9E75}
.logo .mark-dot:nth-child(2){background:#0d7a59}
.logo .mark-dot:nth-child(3){background:#0d7a59}
.logo .mark-dot:nth-child(4){background:#1D9E75}
.logo .logo-text{font-family:'DM Sans','Inter',sans-serif;font-weight:700;font-size:28px;letter-spacing:-0.5px;color:#fff}
.logo .logo-dash{color:#1D9E75}
.nav-links{display:flex;align-items:center;gap:22px}
.nav-links a{font-size:14px;color:var(--ink-soft);font-weight:500;white-space:nowrap}
.nav-links a:hover{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:14px}
.lang{display:inline-flex;border:1px solid var(--border);border-radius:999px;overflow:hidden;background:var(--surface2)}
.lang a,.lang button{border:none;background:transparent;padding:6px 12px;font-size:13px;font-weight:600;color:var(--ink-soft);cursor:pointer}
.lang a.active,.lang button.active{background:rgba(29,158,117,.18);color:var(--green)}
.hamburger{display:none;background:none;border:none;cursor:pointer;font-size:24px;color:var(--ink)}
.mobile-menu{
  display:none;
  border-top:1px solid var(--border);
  background:var(--bg);
  padding:24px;
  text-align:center;
}
.mobile-menu.open{
  display:block;
  animation:mm-in .4s cubic-bezier(0.22,1,0.36,1) forwards;
}
.mobile-menu.closing{
  animation:mm-out .3s cubic-bezier(0.55,0,1,0.45) forwards;
}
@keyframes mm-in{
  0%  {opacity:0;transform:perspective(600px) rotateX(-25deg) translateY(-30px) scale(.94);filter:blur(8px)}
  60% {opacity:1;transform:perspective(600px) rotateX(4deg) translateY(4px) scale(1.01);filter:blur(0)}
  80% {transform:perspective(600px) rotateX(-2deg) translateY(-2px) scale(.995)}
  100%{transform:perspective(600px) rotateX(0deg) translateY(0) scale(1)}
}
@keyframes mm-out{
  0%  {opacity:1;transform:perspective(600px) rotateX(0deg) translateY(0) scale(1);filter:blur(0)}
  40% {opacity:.6;transform:perspective(600px) rotateX(8deg) translateY(-10px) scale(.97);filter:blur(2px)}
  100%{opacity:0;transform:perspective(600px) rotateX(-20deg) translateY(-40px) scale(.9);filter:blur(10px)}
}
.mobile-menu a{
  display:block;
  padding:14px 0;
  color:var(--ink);
  font-weight:500;
  font-size:16px;
  border-bottom:1px solid var(--border);
  transition:color .15s;
}
.mobile-menu a:hover{color:var(--green)}
.mm-lang{margin-top:16px;justify-content:center;border-color:var(--border)}

/* Hero */
.hero{padding:32px 0 40px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(38px,5.2vw,62px);margin:20px 0 18px}
.hero p.sub{font-size:19px;color:var(--ink-soft);max-width:520px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-note{margin-top:10px;font-size:14px;color:var(--ink-soft)}
.hero-cta+.hero-note{margin-top:28px}
.hero-note b{color:var(--green)}

/* Phone mockup */
.phone-wrap{position:relative;display:flex;justify-content:center}
.blob{position:absolute;border-radius:50%;filter:blur(50px);z-index:0}
.blob.a{width:260px;height:260px;background:rgba(29,158,117,.22);top:-20px;left:8%}
.blob.b{width:210px;height:210px;background:rgba(8,80,65,.40);bottom:0;right:6%}
/* Legacy phone (kept for demo section) */
.phone{position:relative;z-index:1;width:296px;background:#000;border-radius:42px;padding:10px;box-shadow:var(--shadow-lg);border:1px solid #222}
.phone .screen{background:var(--card);border-radius:33px;overflow:hidden;height:600px;border:1px solid var(--border)}
.ph-head{background:linear-gradient(160deg,var(--green),var(--green-deep));padding:34px 20px 18px;color:#fff}
.ph-head .name{font-family:'Fraunces',serif;font-size:21px;font-weight:600}
.ph-head .tag{font-size:12px;opacity:.85}
.ph-tabs{display:flex;gap:8px;padding:14px 16px;border-bottom:1px solid var(--border)}
.ph-tab{font-size:12px;font-weight:600;padding:6px 12px;border-radius:999px;background:var(--surface2);color:var(--ink-soft)}
.ph-tab.active{background:var(--green);color:#08110d}
.ph-body{padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.ph-item{border:1px solid var(--border);border-radius:14px;padding:12px;background:var(--surface2)}
.ph-item .row{display:flex;justify-content:space-between;align-items:center;gap:8px}
.ph-item .nm{font-size:14px;font-weight:600;color:var(--ink)}
.ph-item .pr{font-size:14px;font-weight:700;color:var(--green)}
.ph-item .ds{font-size:11px;color:var(--ink-soft);margin-top:2px}
.pill-top{font-size:9px;font-weight:700;color:var(--green);background:rgba(29,158,117,.15);padding:2px 7px;border-radius:999px;margin-left:6px}

/* ── Phone2: Animated customer menu mockup ─────────────────────── */
.phone2{
  position:relative;z-index:1;width:320px;
  background:#111;
  border-radius:48px;
  padding:10px 10px 6px;
  box-shadow:0 40px 80px -20px rgba(0,0,0,.8),0 0 0 1px rgba(255,255,255,.07),inset 0 0 0 1px rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  flex-shrink:0;
}
/* Status bar */
.sb{
  display:flex;justify-content:space-between;align-items:center;
  padding:6px 20px 4px;font-size:11px;font-weight:600;
}
/* Light sb – text is white (overlaid on photo) */
.sb-light{color:#fff}
.sb-icons{display:flex;align-items:center;gap:5px}
/* Screen – light theme */
.screen2{
  border-radius:40px;overflow:hidden;
  height:600px;
  display:flex;flex-direction:column;position:relative;
}
.screen2-light{background:#F9FAFB;border:none}
/* Home indicator */
.m-home-ind{
  width:90px;height:4px;background:rgba(0,0,0,.18);
  border-radius:999px;margin:6px auto 2px;
}
/* ── Hero with real photo ── */
.m-hero{position:relative;height:148px;flex-shrink:0;overflow:hidden}
.m-hero-bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
}
.m-hero-gradient{
  position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,.10) 0%, rgba(0,0,0,.72) 100%);
  opacity:.85;
  transition:opacity .3s;
}
/* Top row: lang + account buttons */
.m-hero-top{
  position:absolute;top:8px;right:10px;display:flex;gap:6px;align-items:center;z-index:2;
}
.m-lang-btn{
  font-size:9.5px;font-weight:600;color:rgba(255,255,255,.9);
  background:rgba(255,255,255,.18);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.22);border-radius:20px;padding:3px 8px;flex-shrink:0;
}
.m-acc-btn{
  width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.18);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.22);
}
/* Hero bottom content */
.m-hero-content{position:absolute;bottom:0;left:0;right:0;padding:10px 14px 10px;z-index:2}
.m-logo-row{display:flex;align-items:center;gap:9px;margin-bottom:6px}
/* TAV-LA grid logo */
.m-logo-tl{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:#111;
  display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:4px;
  padding:7px;
  box-shadow:0 3px 10px rgba(0,0,0,.45);
}
.m-logo-dot{
  width:100%;height:100%;border-radius:3px;display:block;
}
.m-logo-dot:nth-child(1){background:#1D9E75;}
.m-logo-dot:nth-child(2){background:#0d7a59;}
.m-logo-dot:nth-child(3){background:#0d7a59;}
.m-logo-dot:nth-child(4){background:#1D9E75;}
.m-venue-info{flex:1;min-width:0}
.m-venue-name{font-size:14px;font-weight:700;color:#fff;line-height:1.1;font-family:'Fraunces',serif}
.m-venue-meta{font-size:9.5px;color:rgba(255,255,255,.75);margin-top:2px}
/* Welcome message */
.m-welcome{
  font-size:9.5px;color:rgba(255,255,255,.82);
  font-style:italic;line-height:1.4;
  font-family:'Fraunces',Georgia,serif;
}
/* Happy Hour Banner */
.m-hh-banner{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:7px 14px;flex-shrink:0;
  background:linear-gradient(90deg,#15803d 0%,#16a34a 50%,#166534 100%);
  color:#fff;
}
.m-hh-left{display:flex;align-items:center;gap:8px}
.m-hh-icon{font-size:16px;flex-shrink:0}
.m-hh-title{font-size:10px;font-weight:700;line-height:1.2}
.m-hh-sub{font-size:9px;opacity:.82;line-height:1.2}
.m-hh-timer{
  font-size:14px;font-weight:700;font-family:monospace;
  background:rgba(0,0,0,.22);border-radius:8px;padding:4px 8px;flex-shrink:0;min-width:52px;text-align:center;
}
/* ── Sticky nav – light ── */
.m-nav{flex-shrink:0;padding-bottom:0}
.m-nav-light{background:#fff;border-bottom:1px solid rgba(0,0,0,.07)}
.m-nav-dark{background:#0d0d0d;border-bottom:1px solid rgba(255,255,255,.07)}
.m-search{
  display:flex;align-items:center;gap:6px;
  margin:8px 12px 6px;
  border-radius:12px;padding:7px 10px;
}
.m-search-light{background:#F9FAFB;border:1px solid rgba(0,0,0,.08)}
.m-search-dark{background:#0d0d0d;border:1px solid rgba(255,255,255,.08)}
.m-search-dark svg circle,.m-search-dark svg path{stroke:rgba(255,255,255,.3)!important}
.m-search-icon{display:flex;align-items:center;flex-shrink:0}
.m-search-text{font-size:11px;flex:1}
.m-search-text-light{color:#6B7280}
.m-search-text-dark{color:#6B7280}
.m-cursor{font-size:12px;color:#1D9E75;animation:blink-cursor .9s steps(1) infinite;flex-shrink:0}
@keyframes blink-cursor{0%,49%{opacity:1}50%,100%{opacity:0}}
/* Filter chips */
.m-filters{display:flex;gap:5px;padding:0 12px 6px;overflow:hidden}
.m-chip{
  font-size:9px;font-weight:600;padding:3.5px 8px;border-radius:999px;flex-shrink:0;
  transition:background .25s,color .25s,border-color .25s;
}
.m-chip-all{background:#F3F4F6;color:#6B7280;border:1px solid rgba(0,0,0,.08)}
.m-chip-active-all{background:#111827;color:#fff;border-color:#111827}
.m-chip-active-all-dark{background:#F9FAFB;color:#111827;border-color:#F9FAFB}
.m-chip-vegan-l{background:rgba(29,158,117,.1);color:#1D9E75;border:1px solid rgba(29,158,117,.25)}
.m-chip-best-l{background:rgba(245,158,11,.08);color:#d97706;border:1px solid rgba(245,158,11,.22)}
/* Dark nav chip overrides */
.m-nav-dark .m-chip-all{background:#1a1a1a;color:#6B7280;border-color:rgba(255,255,255,.1)}
.m-nav-dark .m-chip-active-all{background:#F9FAFB;color:#111827;border-color:#F9FAFB}
.m-nav-dark .m-chip-vegan-l{background:rgba(29,158,117,.15);color:#34d399;border-color:rgba(29,158,117,.3)}
.m-nav-dark .m-chip-best-l{background:rgba(245,158,11,.12);color:#fbbf24;border-color:rgba(245,158,11,.3)}
/* ── Dot-style tabs ── */
.m-tabs{display:flex;padding:0 8px;gap:0;overflow:hidden}
.m-tabs-light{background:#fff;border-bottom:1px solid rgba(0,0,0,.07)}
.m-tabs-dark{background:#0d0d0d;border-bottom:1px solid rgba(255,255,255,.07)}
.m-tab{
  font-size:10.5px;font-weight:600;padding:6px 9px;
  border-bottom:2px solid transparent;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;gap:4px;
  transition:color .25s,border-color .25s;
}
.m-tab-light{color:#9CA3AF}
.m-tab-light.active{color:#111827;border-color:#1D9E75}
.m-tab-dark{color:#4B5563}
.m-tab-dark.active{color:#F9FAFB;border-color:#1D9E75}
.m-tab-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;opacity:.7}
.m-tab-light.active .m-tab-dot{opacity:1}
.m-tab-dark.active .m-tab-dot{opacity:1}
/* ── Scrollable body ── */
.m-body{flex:1;overflow:hidden;position:relative}
.m-body-light{background:#F9FAFB}
/* ── Category cover photo ── */
.m-cat-cover{
  position:relative;height:70px;overflow:hidden;flex-shrink:0;
  background:#d1d5db;
}
.m-cat-cover-img{width:100%;height:100%;object-fit:cover;display:block}
.m-cat-cover-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.08) 0%,rgba(0,0,0,.55) 100%);
}
.m-cat-cover-label{
  position:absolute;bottom:8px;left:12px;display:flex;align-items:baseline;gap:6px;
}
.m-cat-cover-name{font-size:13px;font-weight:700;color:#fff;font-family:'Fraunces',serif}
.m-cat-cover-count{font-size:9.5px;color:rgba(255,255,255,.75)}
/* Category section */
.m-cat-section{padding:0 0 8px}
/* Items – light */
.m-items-light{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:0;overflow:hidden;margin:0 12px;border-radius:12px;margin-top:8px}
.m-item-light{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .15s}
.m-item-light:hover{background:#F9FAFB}
.m-item-body{flex:1;min-width:0}
.m-item-badges{display:flex;gap:4px;margin-bottom:3px;flex-wrap:nowrap;overflow:hidden}
.m-badge{font-size:8px;font-weight:600;padding:2px 6px;border-radius:999px}
.m-badge-top-l{background:rgba(245,158,11,.10);color:#b45309}
.m-badge-vegan-l{background:rgba(29,158,117,.10);color:#065f46}
.m-item-name-light{font-size:12px;font-weight:600;color:#111827;line-height:1.2}
.m-item-desc-light{font-size:9.5px;color:#6B7280;margin-top:1px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.m-item-price-light{font-size:12px;font-weight:700;color:#1D9E75;margin-top:4px}
.m-item-price-hh{font-size:10.5px;color:#9CA3AF;margin-top:3px;display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.m-item-price-hh s{font-size:9.5px}
.hh-price{color:#16a34a;font-weight:700;font-size:12px}
.hh-pill{font-size:7.5px;font-weight:700;background:#dcfce7;color:#15803d;padding:1.5px 5px;border-radius:999px}
/* Product image – real photo */
.m-item-img-real{
  width:72px;height:72px;border-radius:12px;flex-shrink:0;
  overflow:hidden;background:#E5E7EB;
}
.m-item-img-real img{width:100%;height:100%;object-fit:cover;display:block}
.m-item-divider-light{height:1px;background:rgba(0,0,0,.05);margin:0 12px}
/* Items – dark (cat1, cat3) */
/* ── Category home grid ── */
.m-home-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
  padding:10px 12px 12px;
}
.m-home-tile{
  position:relative;border-radius:14px;overflow:hidden;
  aspect-ratio:1/1;background:#1a1a1a;cursor:pointer;
}
.m-home-tile img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.m-home-tile::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.72) 0%, rgba(0,0,0,.1) 55%, transparent 100%);
}
.m-home-tile-label{
  position:absolute;bottom:0;left:0;right:0;padding:8px 10px;z-index:2;
}
.m-home-tile-name{
  display:block;font-size:11px;font-weight:700;color:#fff;line-height:1.2;
  font-family:'Fraunces',Georgia,serif;
}
.m-home-tile-count{
  display:block;font-size:8.5px;color:rgba(255,255,255,.65);margin-top:1px;
}
.m-body-dark{background:#0d0d0d}
.m-items-dark{background:#1a1a1a;border:1px solid rgba(255,255,255,.07);overflow:hidden;margin:0 12px;border-radius:12px;margin-top:8px}
.m-item-dark{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .15s}
.m-item-dark:hover{background:rgba(255,255,255,.04)}

/* ── Mint/Green custom palette (Cocktails – 4ο) ── */
.m-nav-navy{background:#ECFDF5;border-bottom:1px solid rgba(6,95,70,.12)}
.m-search-navy{background:#ECFDF5;border:1px solid rgba(6,95,70,.18)}
.m-search-navy svg circle,.m-search-navy svg path{stroke:#065F46!important}
.m-tabs-navy{background:#ECFDF5;border-bottom:1px solid rgba(6,95,70,.12)}
.m-body-navy{background:#ECFDF5}
.m-nav-navy .m-chip-all{background:#D1FAE5;color:#065F46;border-color:rgba(6,95,70,.2)}
.m-nav-navy .m-chip-active-all{background:#065F46;color:#fff;border-color:#065F46}
.m-nav-navy .m-chip-vegan-l{background:#A7F3D0;color:#064E3B;border-color:#6EE7B7}
.m-nav-navy .m-chip-best-l{background:#D1FAE5;color:#065F46;border-color:#6EE7B7}
.m-tab-navy{color:#6EE7B7}
.m-tab-navy.active{color:#064E3B;border-color:#065F46}
.m-tab-navy.active .m-tab-dot{opacity:1}

/* ── Premium dark reuse (Food – 5ο) — ίδια παλέτα με premium αλλά food category ── */
.m-body-wine .m-items-dark{background:#16202F;border-color:rgba(120,160,210,.13)}
.m-body-wine .m-item-dark:hover{background:rgba(120,160,210,.06)}
.m-nav-wine{background:#0F1623;border-bottom:1px solid rgba(120,160,210,.13)}
.m-search-wine{background:#16202F;border:1px solid rgba(120,160,210,.13)}
.m-search-wine svg circle,.m-search-wine svg path{stroke:rgba(220,230,240,.3)!important}
.m-tabs-wine{background:#0F1623;border-bottom:1px solid rgba(120,160,210,.13)}
.m-body-wine{background:#0F1623}
.m-nav-wine .m-chip-all{background:#1C2B3A;color:#6B7280;border-color:rgba(120,160,210,.15)}
.m-nav-wine .m-chip-active-all{background:#F9FAFB;color:#111827;border-color:#F9FAFB}
.m-nav-wine .m-chip-vegan-l{background:rgba(29,158,117,.15);color:#34d399;border-color:rgba(29,158,117,.3)}
.m-nav-wine .m-chip-best-l{background:rgba(245,158,11,.12);color:#fbbf24;border-color:rgba(245,158,11,.3)}
.m-tab-wine{color:rgba(220,230,240,.35)}
.m-tab-wine.active{color:#DCE6F0;border-color:#1D9E75}
.m-tab-wine.active .m-tab-dot{opacity:1}

/* ── Forest theme (Home grid) ── */
.m-nav-forest{background:#FEF3C7;border-bottom:1px solid rgba(120,53,15,.12)}
.m-search-forest{background:#FEF3C7;border:1px solid rgba(120,53,15,.18)}
.m-search-forest svg circle,.m-search-forest svg path{stroke:#78350F!important}
.m-tabs-forest{background:#FEF3C7;border-bottom:1px solid rgba(120,53,15,.12)}
.m-body-forest{background:#FEF3C7}
.m-nav-forest .m-chip-all{background:#FEF9E7;color:#78350F;border-color:rgba(120,53,15,.18)}
.m-nav-forest .m-chip-active-all{background:#D97706;color:#fff;border-color:#D97706}
.m-nav-forest .m-chip-vegan-l{background:#D1FAE5;color:#065F46;border-color:#6EE7B7}
.m-nav-forest .m-chip-best-l{background:#FEF9E7;color:#92400E;border-color:rgba(217,119,6,.3)}
.m-tab-forest{color:#D97706}
.m-tab-forest.active{color:#78350F;border-color:#D97706}
.m-tab-forest.active .m-tab-dot{opacity:1}
.m-item-name-dark{font-size:12px;font-weight:600;color:#F9FAFB;line-height:1.2}
.m-item-desc-dark{font-size:9.5px;color:#9CA3AF;margin-top:1px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.m-item-price-dark{font-size:12px;font-weight:700;color:#1D9E75;margin-top:4px}
.m-item-divider-dark{height:1px;background:rgba(255,255,255,.07);margin:0 12px}
.m-badge-top-d{background:rgba(245,158,11,.15);color:#fbbf24}
.m-badge-vegan-d{background:rgba(29,158,117,.15);color:#34d399}
/* Feedback button */
.m-feedback-btn{
  position:absolute;bottom:12px;right:12px;z-index:10;
  background:#1D9E75;color:#fff;font-size:10px;font-weight:700;
  padding:7px 12px;border-radius:999px;box-shadow:0 4px 16px rgba(29,158,117,.45);
  display:flex;align-items:center;gap:5px;cursor:pointer;
}
/* Tab switch animation */
@keyframes fadeSlideIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.m-cat-section{animation:fadeSlideIn .35s ease both}

/* Trust bar */
.trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-2)}
.trust-inner{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;padding:22px 24px;text-align:center}
.trust .stat{display:flex;align-items:baseline;gap:8px;color:var(--ink-soft);font-size:15px}
.trust .stat b{font-family:'Fraunces',serif;font-size:22px;color:var(--green)}

/* Section head */
.sec{padding:96px 0}
.sec-head{max-width:680px;margin:0 auto 56px;text-align:center}
.sec-head h2{font-size:clamp(30px,3.6vw,44px);margin:14px 0 14px}
.sec-head p{font-size:18px;color:var(--ink-soft)}

/* Problem / Solution */
.ps-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.ps-col{border-radius:var(--radius);padding:32px}
.ps-problem{background:rgba(224,121,95,.06);border:1px solid rgba(224,121,95,.22)}
.ps-solution{background:var(--card);border:1px solid rgba(29,158,117,.30);box-shadow:var(--shadow)}
.ps-col h3.lbl{font-size:13px;letter-spacing:.05em;text-transform:uppercase;font-family:'DM Sans',sans-serif;font-weight:700;margin-bottom:22px}
.ps-problem h3.lbl{color:var(--warn)}
.ps-solution h3.lbl{color:var(--green)}
.ps-item{display:flex;gap:14px;margin-bottom:20px}
.ps-item:last-child{margin-bottom:0}
.ps-ic{flex:none;width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px}
.ps-problem .ps-ic{background:rgba(224,121,95,.15);color:var(--warn)}
.ps-solution .ps-ic{background:rgba(29,158,117,.15);color:var(--green)}
.ps-item .t{font-weight:600;margin-bottom:2px;color:var(--ink)}
.ps-item .d{font-size:14.5px;color:var(--ink-soft)}

/* Features */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:26px;transition:transform .2s,box-shadow .2s,border-color .2s}
.feat:hover{transform:translateY(-4px);box-shadow:var(--glow);border-color:rgba(29,158,117,.4)}
.feat .ic{width:48px;height:48px;border-radius:13px;background:rgba(29,158,117,.12);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px}
.feat h3{font-family:'DM Sans',sans-serif;font-weight:600;font-size:17px;margin-bottom:8px;color:var(--ink)}
.feat p{font-size:14.5px;color:var(--ink-soft)}

/* Pricing + Features unified — ένα ενιαίο πράσινο card */
.pricing-unified{
  background:linear-gradient(150deg,#1a8f68 0%,#085041 100%);
  border-radius:28px;
  padding:44px 48px;
  margin-top:56px;
  position:relative;
  overflow:hidden;
  box-shadow:0 24px 64px -16px rgba(8,80,65,.55);
  color:#fff;
}
/* Header row: τιμή αριστερά, CTA δεξιά */
.pu-header{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.pu-left{}

/* Duration pills */
.dur-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;align-items:flex-end}
@media(max-width:900px){.dur-pills{justify-content:center}}
.dur-pill{background:rgba(255,255,255,.12);color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:7px 18px;font-size:13px;font-family:'DM Sans',sans-serif;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s;position:relative}
.dur-pill:hover{background:rgba(255,255,255,.2)}
.dur-pill.active{background:#fff;color:#085041;border-color:#fff}

.dur-pill-deal{padding-top:18px}
.dur-ribbon{
  position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  background:#f59e0b;color:#fff;
  font-size:10px;font-weight:700;letter-spacing:.4px;
  padding:2px 8px;
  border-radius:999px 999px 0 0;
  white-space:nowrap;
  line-height:1.4;
}
.dur-pill.active .dur-ribbon{background:#d97706}

/* Amount */
.amount-wrap{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.amount{font-family:'Fraunces',serif;font-size:62px;font-weight:700;line-height:1}
.amount-meta{display:flex;align-items:center;gap:8px}
.plan-old{font-size:18px;opacity:.55;text-decoration:line-through;font-family:'DM Sans',sans-serif}
.plan-badge{background:rgba(255,255,255,.2);color:#fff;font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px;letter-spacing:.04em}
.trial{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);padding:6px 16px;border-radius:999px;font-size:13.5px;margin-top:14px}
.pu-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.pu-btn{background:#fff;color:#085041;font-weight:700;font-size:16px;padding:14px 36px;border-radius:14px;white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.15);transition:transform .15s,box-shadow .15s}
.pu-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2);color:#085041}
.note{font-size:12.5px;opacity:.7;text-align:right}

/* Διαχωριστής */
.pu-divider{height:1px;background:rgba(255,255,255,.15);margin:36px 0 30px}

/* ── Feature Zones ─────────────────────────────────────── */

/* Zone 1: Analytics hero card */
.feat-zone-hero{margin-bottom:16px}
.feat-hero-card{
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  background:linear-gradient(105deg,rgba(255,255,255,.16) 0%,rgba(255,255,255,.06) 100%);
  border:1px solid rgba(255,255,255,.3);
  border-radius:16px;
  padding:18px 24px;
  box-shadow:0 0 32px rgba(255,255,255,.07);
}
.fhc-left{display:flex;align-items:center;gap:14px;flex-shrink:0}
.fhc-pulse{
  width:12px;height:12px;border-radius:50%;
  background:#fff;flex-shrink:0;
  box-shadow:0 0 8px 3px rgba(255,255,255,.6);
  animation:dot-pulse 2s ease-in-out infinite;
}
@keyframes dot-pulse{
  0%,100%{box-shadow:0 0 6px 2px rgba(255,255,255,.5)}
  50%{box-shadow:0 0 18px 6px rgba(255,255,255,.95)}
}
.fhc-title{font-size:24px;font-weight:800;color:#fff;letter-spacing:.01em;white-space:nowrap}
.fhc-desc{font-size:15px;color:rgba(255,255,255,.7);line-height:1.5;flex:1;text-align:center;}

/* Animated bar chart */
.fhc-chart{
  display:flex;align-items:flex-end;gap:5px;
  height:44px;flex-shrink:0;
  margin-left:auto;
  padding:0 4px;
}
.fhc-bar{
  display:block;
  width:8px;
  height:var(--h);
  border-radius:3px 3px 0 0;
  background:rgba(255,255,255,.5);
  animation:bar-live 2.4s ease-in-out infinite;
  animation-delay:var(--d);
}
@keyframes bar-live{
  0%,100%{height:var(--h);opacity:.5}
  50%{height:calc(var(--h) * 1.35);opacity:1;background:rgba(255,255,255,.95)}
}

/* Zone 2: Secondary feature cards */
.feat-zone-secondary{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:10px;
  margin-bottom:16px;
}
.feat-sec-card{
  display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  padding:12px 14px;
  transition:background .2s,border-color .2s;
}
.feat-sec-card:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.25)}
.fsc-icon{font-size:15px;flex-shrink:0;line-height:1;filter:grayscale(1) brightness(1.8)}
.fsc-text{font-size:12.5px;font-weight:600;color:rgba(255,255,255,.9);line-height:1.3}

/* Zone 3: Chip row */
.feat-zone-chips{
  display:flex;flex-wrap:wrap;gap:8px;
  padding-top:4px;margin-bottom:4px;
}
.feat-chip{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.7);
  font-size:12px;font-weight:500;
  padding:5px 14px;border-radius:999px;
  white-space:nowrap;
}

/* More features toggle button */
.feat-more-btn{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.8);
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  font-weight:600;
  padding:9px 22px;
  border-radius:999px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:background .2s, border-color .2s, color .2s;
}
.feat-more-btn:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.35);color:#fff}
.feat-more-arrow{font-size:12px;transition:transform .2s}

@media(max-width:1100px){
  .feat-zone-secondary{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
  .pricing-unified{padding:32px 24px}
  .pu-header{flex-direction:column;align-items:center}
  .pu-left{width:100%;display:flex;flex-direction:column;align-items:center;text-align:center}
  .pu-right{align-items:center;width:100%}
  .pu-btn{width:100%;text-align:center}
  .note{text-align:left}
}
@media(max-width:1100px){
  /* Tablet: chart κεντραριστεί κάτω */
  .feat-hero-card{flex-wrap:wrap;justify-content:flex-start}
  .fhc-desc{text-align:left;flex:1 1 100%}
  .fhc-chart{margin-left:auto;margin-right:auto}
}
@media(max-width:900px){
  /* Mobile: όλα stack, chart κεντραρισμένο */
  .feat-hero-card{flex-direction:column;align-items:center;text-align:center}
  .fhc-left{width:100%;justify-content:center}
  .fhc-desc{text-align:center;flex:unset;width:100%}
  .fhc-chart{margin-left:0;margin-right:0}
  /* Secondary grid: 1 column σε κινητό ώστε να μην κόβονται */
  .feat-zone-secondary{grid-template-columns:1fr}
}
@media(max-width:560px){
  .feat-zone-secondary{grid-template-columns:1fr}
  .amount{font-size:48px}
}

/* Demo / QR */
.demo{
  background: radial-gradient(ellipse at 50% 0%, rgba(29,158,117,.18) 0%, transparent 65%), var(--bg-2);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
.demo::before{
  content:'';position:absolute;inset:0;
  background-image: repeating-linear-gradient(0deg,rgba(29,158,117,.04) 0px,rgba(29,158,117,.04) 1px,transparent 1px,transparent 48px),
                    repeating-linear-gradient(90deg,rgba(29,158,117,.04) 0px,rgba(29,158,117,.04) 1px,transparent 1px,transparent 48px);
  pointer-events:none;
}
.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}

/* QR card */
.qr-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(29,158,117,.35);
  border-radius:28px;padding:40px 36px;
  box-shadow:0 0 0 1px rgba(29,158,117,.1), 0 0 60px rgba(29,158,117,.15), 0 24px 48px rgba(0,0,0,.4);
  text-align:center;max-width:380px;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.qr-card:hover{
  transform:scale(1.025);
  border-color:rgba(29,158,117,.7);
  box-shadow:0 0 0 1px rgba(29,158,117,.2), 0 0 80px rgba(29,158,117,.35), 0 28px 56px rgba(0,0,0,.5);
}
/* Corner brackets animate on hover */
.qr-card .qr-corner{transition:width .3s ease, height .3s ease, opacity .3s ease}
.qr-card:hover .qr-corner{width:28px;height:28px}
/* Scan line only runs on hover */
.qr-scan-line{animation:none;opacity:0;transition:opacity .2s}
.qr-card:hover .qr-scan-line{animation:scan-move 2s ease-in-out infinite;opacity:1}
@keyframes card-float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
.qr-card h3{color:var(--ink);font-family:'DM Sans',sans-serif;font-size:20px;display:flex;align-items:center;justify-content:center;gap:8px}
.qr-pulse-dot{width:9px;height:9px;border-radius:50%;background:#1D9E75;display:inline-block;animation:pulse-dot 1.8s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 0 rgba(29,158,117,.7);opacity:1}70%{box-shadow:0 0 0 8px rgba(29,158,117,0);opacity:.8}}

/* QR frame with scanning line */
.qr-real{
  position:relative;width:210px;height:210px;margin:20px auto;
  background:#fff;border-radius:16px;padding:10px;
  overflow:hidden;
}
.qr-real img{width:100%;height:100%;display:block;border-radius:6px}

/* Corner brackets */
.qr-corners{position:absolute;inset:0;pointer-events:none;z-index:3}
.qr-corner{position:absolute;width:22px;height:22px;border-color:#1D9E75;border-style:solid}
.qr-corner.tl{top:6px;left:6px;border-width:3px 0 0 3px;border-radius:4px 0 0 0}
.qr-corner.tr{top:6px;right:6px;border-width:3px 3px 0 0;border-radius:0 4px 0 0}
.qr-corner.bl{bottom:6px;left:6px;border-width:0 0 3px 3px;border-radius:0 0 0 4px}
.qr-corner.br{bottom:6px;right:6px;border-width:0 3px 3px 0;border-radius:0 0 4px 0}

/* Scan line */
.qr-scan-line{
  position:absolute;left:10px;right:10px;height:2px;
  background:linear-gradient(90deg,transparent,rgba(29,158,117,.9),transparent);
  box-shadow:0 0 8px rgba(29,158,117,.8);
  z-index:4;
  animation:scan-move 2.2s ease-in-out infinite;
}
@keyframes scan-move{
  0%{top:10px;opacity:0}
  10%{opacity:1}
  90%{opacity:1}
  100%{top:calc(100% - 10px);opacity:0}
}

/* Stats row */
.qr-stats{display:flex;gap:12px;justify-content:center;margin-top:20px;flex-wrap:wrap}
.qr-stat{background:rgba(29,158,117,.1);border:1px solid rgba(29,158,117,.2);border-radius:999px;padding:5px 12px;font-size:12px;color:rgba(255,255,255,.75);font-weight:500}
.qr-stat b{color:#1D9E75}

.qr-real #qrcode{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.qr-real #qrcode img,.qr-real #qrcode canvas{width:100%!important;height:100%!important}
.qr-logo{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2;pointer-events:none}
.qr-logo span{font-family:'Fraunces',serif;font-weight:700;color:var(--green);font-size:14px;background:#fff;padding:3px 6px;border-radius:6px}

/* Demo info panel */
.demo-info-panel{max-width:340px;display:flex;flex-direction:column;gap:28px}
.demo-info-eyebrow{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--green);margin-bottom:4px}
.demo-info-item{display:flex;gap:16px;align-items:flex-start}
.demo-info-icon{width:32px;height:32px;border-radius:10px;background:rgba(29,158,117,.12);border:1px solid rgba(29,158,117,.25);display:flex;align-items:center;justify-content:center;color:var(--green);font-size:13px;flex-shrink:0;margin-top:2px}
.demo-info-item strong{display:block;font-size:15px;font-weight:600;color:var(--ink);margin-bottom:6px}
.demo-info-item p{font-size:13.5px;color:var(--ink-soft);line-height:1.65;margin:0}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}

.step{
  text-align:center;
  padding:40px 28px 36px;
  border-radius:24px;
  position:relative;
  overflow:hidden;
  /* Glass morphism */
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  /* Gradient border via outline trick */
  border:1px solid transparent;
  background-clip:padding-box;
  box-shadow:inset 0 0 0 1px rgba(29,158,117,.2), 0 8px 32px rgba(0,0,0,.25);
  transition:box-shadow .35s ease, transform .35s ease;
}
/* Animated gradient border on hover */
.step::after{
  content:'';position:absolute;inset:-1px;border-radius:25px;
  background:linear-gradient(135deg,rgba(29,158,117,.8),rgba(8,80,65,.4),rgba(29,158,117,.6));
  background-size:300% 300%;
  z-index:-1;opacity:0;
  transition:opacity .35s ease;
  animation:grad-spin 3s ease infinite;
}
.step:hover::after{opacity:1}
.step:hover{
  transform:translateY(-5px);
  box-shadow:inset 0 0 0 1px transparent, 0 16px 48px rgba(0,0,0,.35), 0 0 40px rgba(29,158,117,.12);
}
@keyframes grad-spin{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}


.step .num{
  width:64px;height:64px;border-radius:20px;margin:0 auto 20px;
  background:rgba(29,158,117,.1);
  border:1px solid rgba(29,158,117,.3);
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-size:26px;font-weight:700;color:var(--green);
  position:relative;z-index:1;
}

/* Dotted connector between steps */
.steps-wrap{position:relative}
.steps-track{
  display:flex;align-items:center;gap:0;margin-bottom:0;
  position:absolute;top:52px;left:calc(16.66% + 32px);right:calc(16.66% + 32px);
  height:2px;z-index:0;pointer-events:none;
}
.steps-track-line{
  flex:1;height:2px;
  background:repeating-linear-gradient(90deg,rgba(29,158,117,.35) 0,rgba(29,158,117,.35) 6px,transparent 6px,transparent 14px);
  position:relative;overflow:hidden;
}
.steps-track-line::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(29,158,117,.8),transparent);
  animation:track-sweep 2.5s ease-in-out infinite;
}
@keyframes track-sweep{
  0%{transform:translateX(-100%)}
  100%{transform:translateX(100%)}
}
.steps-track-arrow{color:rgba(29,158,117,.5);font-size:14px;margin:0 2px}

.step h3{font-family:'DM Sans',sans-serif;font-size:18px;font-weight:600;margin-bottom:10px;color:var(--ink);position:relative;z-index:1}
.step p{font-size:14px;color:var(--ink-soft);line-height:1.65;position:relative;z-index:1}
.step-line{display:none}

/* FAQ */
.faq{max-width:760px;margin:0 auto}
details{background:var(--card);border:1px solid var(--border);border-radius:14px;margin-bottom:12px;overflow:hidden}
details[open]{border-color:rgba(29,158,117,.35)}
summary{list-style:none;cursor:pointer;padding:20px 22px;font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--ink)}
summary::-webkit-details-marker{display:none}
summary .ic{flex:none;color:var(--green);transition:transform .2s;font-size:22px;line-height:1}
details[open] summary .ic{transform:rotate(45deg)}
details .ans{padding:0 22px 22px;color:var(--ink-soft);font-size:15px}

/* Final CTA */
.final{padding:90px 0}
.final-band{background:linear-gradient(135deg,var(--green-deep),var(--green));color:#fff;border-radius:28px;padding:64px 40px;text-align:center;position:relative;overflow:hidden}
.final-band::before{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:rgba(29,158,117,.5);filter:blur(80px);bottom:-160px;left:50%;transform:translateX(-50%)}
.final-band h2{color:#fff;font-size:clamp(30px,4vw,46px);margin-bottom:16px;position:relative}
.final-band p{position:relative;font-size:18px;opacity:.92;max-width:560px;margin:0 auto 30px}
.final-band .row{position:relative;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final-band .btn-primary{background:#fff;color:var(--green-deep);box-shadow:none}
.final-band .btn-outline{border-color:rgba(255,255,255,.55);color:#fff}
.final-band .btn-outline:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff}

/* Contact */
.contact{max-width:620px;margin:0 auto;background:var(--card);border:1px solid var(--border);border-radius:24px;padding:40px;box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
label{font-size:14px;font-weight:600;color:var(--ink)}
input,select,textarea{font-family:inherit;font-size:15px;padding:12px 14px;border:1px solid var(--border);border-radius:11px;background:var(--surface2);color:var(--ink)}
input::placeholder,textarea::placeholder{color:var(--muted)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(29,158,117,.22)}
input.invalid,select.invalid,textarea.invalid{border-color:var(--warn)}
.form-success{text-align:center;padding:28px;border-radius:16px;background:rgba(29,158,117,.08);color:var(--ink);font-size:17px;font-weight:500}

/* Footer */
footer{background:var(--green-deep);color:#bfe3d6;padding:56px 0 28px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;margin-bottom:36px}
footer .logo .logo-text{color:#fff}
footer h3{color:#fff;font-family:'DM Sans',sans-serif;font-size:14px;margin-bottom:14px}
footer a{display:block;color:#bfe3d6;font-size:14px;padding:5px 0;opacity:.85}
footer a:hover{opacity:1;color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:13px;opacity:.8}
.socials{display:flex;gap:10px}
.socials a{border:1px solid rgba(255,255,255,.25);width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ── Support Plans ─────────────────────────────────────── */
.support-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  align-items:start;
}
.sup-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:20px;
  padding:28px 24px 24px;
  display:flex;
  flex-direction:column;
  gap:0;
  position:relative;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.sup-card:hover{
  transform:translateY(-4px);
  border-color:rgba(29,158,117,.4);
  box-shadow:0 12px 40px rgba(0,0,0,.35), 0 0 0 1px rgba(29,158,117,.15);
}
.sup-card-featured{
  background:linear-gradient(160deg,#0f2a22 0%,#0a1f1a 100%);
  border-color:rgba(29,158,117,.5);
  box-shadow:0 0 0 1px rgba(29,158,117,.2), 0 8px 32px rgba(0,0,0,.4);
}
.sup-card-featured:hover{
  border-color:rgba(29,158,117,.8);
  box-shadow:0 0 0 1px rgba(29,158,117,.35), 0 16px 48px rgba(0,0,0,.5), 0 0 40px rgba(29,158,117,.12);
}
.sup-popular{
  position:absolute;
  top:-1px;left:50%;
  transform:translateX(-50%);
  background:var(--green);
  color:#08110d;
  font-size:11px;
  font-weight:700;
  letter-spacing:.04em;
  padding:3px 14px;
  border-radius:0 0 10px 10px;
  white-space:nowrap;
}
.sup-name{
  font-family:'DM Sans',sans-serif;
  font-weight:700;
  font-size:15px;
  color:var(--ink);
  margin-bottom:12px;
  margin-top:12px;
}
.sup-price{
  font-family:'Fraunces',Georgia,serif;
  font-weight:700;
  font-size:34px;
  color:var(--green);
  line-height:1;
  margin-bottom:10px;
}
.sup-price span{
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  font-weight:500;
  color:var(--ink-soft);
  margin-left:2px;
}
.sup-tag{
  display:inline-block;
  background:rgba(29,158,117,.12);
  color:var(--green);
  border:1px solid rgba(29,158,117,.25);
  border-radius:999px;
  font-size:12px;
  font-weight:600;
  padding:4px 12px;
  margin-bottom:8px;
}
.sup-response{
  font-size:12px;
  color:var(--ink-soft);
  margin-bottom:16px;
}
.sup-divider{
  height:1px;
  background:var(--border);
  margin-bottom:16px;
}
.sup-perks{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:20px;
  flex:1;
}
.sup-perks li{
  font-size:13px;
  color:var(--ink-soft);
  padding-left:18px;
  position:relative;
}
.sup-perks li::before{
  content:'✓';
  position:absolute;
  left:0;
  color:var(--green);
  font-weight:700;
  font-size:12px;
}
.sup-btn{
  width:100%;
  font-size:14px;
  padding:11px 16px;
  margin-top:auto;
}
.sup-card-premium{
  background:linear-gradient(160deg,#1a1610 0%,#110f0a 100%);
  border-color:rgba(245,158,11,.3);
  box-shadow:0 0 0 1px rgba(245,158,11,.1), 0 8px 28px rgba(0,0,0,.35);
}
.sup-card-premium:hover{
  border-color:rgba(245,158,11,.55);
  box-shadow:0 0 0 1px rgba(245,158,11,.2), 0 14px 40px rgba(0,0,0,.45), 0 0 30px rgba(245,158,11,.07);
}
.sup-card-premium .sup-price{
  color:#f59e0b;
}
.sup-card-premium .sup-tag{
  background:rgba(245,158,11,.1);
  color:#f59e0b;
  border-color:rgba(245,158,11,.2);
}
.sup-card-premium .sup-perks li::before{
  color:#f59e0b;
}
.sup-footer-note{
  text-align:center;
  margin-top:28px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
}
.sup-footer-note > p{
  font-size:14px;
  color:var(--ink-soft);
  font-weight:500;
  letter-spacing:.01em;
}
.sup-adhoc{
  display:inline-flex;
  align-items:center;
  gap:12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:999px;
  padding:8px 20px;
  flex-wrap:wrap;
  justify-content:center;
}
.sup-adhoc-label{
  font-size:12px;
  font-weight:600;
  color:var(--ink-soft);
  letter-spacing:.03em;
  text-transform:uppercase;
  margin-right:4px;
}
.sup-adhoc-sep{
  color:var(--muted);
  font-size:14px;
}
.sup-adhoc-item{
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.sup-adhoc-time{
  font-size:12px;
  color:var(--ink-soft);
}
.sup-adhoc-price{
  font-size:13px;
  font-weight:700;
  color:var(--ink);
}
.sup-adhoc-hours{
  font-size:12px;
  color:var(--ink-soft);
  font-style:italic;
}

@media(max-width:1100px){
  .support-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .support-grid{grid-template-columns:1fr}
}

/* Tablet: compress nav links further before switching to hamburger */
@media(max-width:1100px) and (min-width:901px){
  .nav-links{gap:14px}
  .nav-links a{font-size:13px}
  .nav-right .lang a,.nav-right .lang button{padding:5px 9px;font-size:12px}
  .nav-inner{height:52px}
}

@media(max-width:900px){
  .hero-grid,.ps-grid,.demo-grid,.foot-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr;gap:36px}
  .step-line{display:none}
  .nav-links,.nav-right .lang,.nav-right .btn{display:none}
  .nav-right .hamburger{display:block}
  .hero{padding:48px 0 20px}
  .demo-grid .qr-card{margin:0 auto}
}
@media(max-width:560px){
  .feat-grid,.form-grid{grid-template-columns:1fr}
  .sec{padding:64px 0}
}
