﻿/* ============================================================
   ZÖLDKERT MEZŐGAZDASÁGI ÁRUHÁZ — MAIN STYLESHEET
   Version:  1.0.0
   Author:   Hajdú Lajos — kreativoldal.hu
   ============================================================ */

:root {
  --green-950: #071a0e;
  --green-900: #0d2616;
  --green-800: #1a4d2e;
  --green-700: #1f5c36;
  --green-600: #2d6e47;
  --green-500: #3d8860;
  --green-400: #55a67a;
  --green-lime: #7cb518;
  --green-lime-h: #8fd420;
  --green-200: #c8e6d4;
  --green-100: #e8f4ed;
  --green-50:  #f2faf6;
  --cream-300: #e8e3d8;
  --cream-200: #ede9e0;
  --cream-100: #f8f6f0;
  --cream-50:  #fdfcf9;
  --white:     #ffffff;
  --text-900: #0d0d0d;
  --text-700: #1a1a1a;
  --text-500: #4a5568;
  --text-300: #8a9aaa;
  --text-200: #b8c5ce;
  --red-sale:  #d63031;
  --amber:     #f59e0b;
  --success:   #00b894;
  --border:    #dde8e1;
  --shadow-xs: 0 1px 3px rgba(26,77,46,.07);
  --shadow-sm: 0 2px 10px rgba(26,77,46,.09);
  --shadow-md: 0 8px 32px rgba(26,77,46,.13);
  --shadow-lg: 0 20px 60px rgba(26,77,46,.18);
  --shadow-xl: 0 40px 100px rgba(26,77,46,.22);
  --r-sm:  6px; --r-md: 12px; --r-lg: 20px; --r-xl: 30px; --r-pill: 50px;
  --font-sans:  'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --font-serif: 'DM Serif Display', Georgia, serif;
  --t-fast: .15s cubic-bezier(.4,0,.2,1);
  --t-base: .22s cubic-bezier(.4,0,.2,1);
  --t-slow: .4s  cubic-bezier(.4,0,.2,1);
  --container: 1320px;
  --section-y: 80px;
}

/* RESET */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body { font-family: var(--font-sans); background: var(--cream-100); color: var(--text-700); line-height: 1.65; -webkit-font-smoothing: antialiased; }
img, svg { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
ul, ol { list-style: none; }
input, textarea, select { font-family: inherit; }
:focus-visible { outline: 2px solid var(--green-lime); outline-offset: 3px; border-radius: 3px; }
::-webkit-scrollbar { width: 7px; }
::-webkit-scrollbar-track { background: var(--cream-200); }
::-webkit-scrollbar-thumb { background: var(--green-200); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--green-600); }
h1, h2, h3, h4, h5 { font-family: var(--font-sans); font-weight: 800; letter-spacing: -.03em; line-height: 1.1; color: var(--text-900); }
em { font-style: normal; }
.container { max-width: var(--container); margin: 0 auto; padding: 0 32px; }
.section { padding: var(--section-y) 0; }
.section--white { background: var(--white); }
.section--cream { background: var(--cream-100); }
.section--dark  { background: var(--green-800); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; gap: 8px; padding: 12px 24px; border-radius: var(--r-pill); font-size: .9rem; font-weight: 700; font-family: var(--font-sans); letter-spacing: -.01em; transition: var(--t-base); white-space: nowrap; cursor: pointer; border: none; }
.btn--lg  { padding: 15px 30px; font-size: .95rem; }
.btn--sm  { padding: 10px 18px; font-size: .84rem; }
.btn--full { width: 100%; justify-content: center; }
.btn--lime { background: var(--green-lime); color: var(--green-800); box-shadow: 0 4px 20px rgba(124,181,24,.35); }
.btn--lime:hover { background: var(--green-lime-h); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(124,181,24,.5); }
.btn--lime:active { transform: translateY(0); }
.btn--dark { background: var(--green-800); color: var(--white); }
.btn--dark:hover { background: var(--green-600); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--ghost { background: transparent; color: rgba(255,255,255,.82); border: 1.5px solid rgba(255,255,255,.28); }
.btn--ghost:hover { color: var(--white); border-color: rgba(255,255,255,.55); background: rgba(255,255,255,.08); }
.btn--outline { background: transparent; color: var(--green-800); border: 1.5px solid var(--green-200); }
.btn--outline:hover { background: var(--green-100); border-color: var(--green-600); }
.btn.is-added { background: var(--success) !important; pointer-events: none; }

/* BADGES */
.badge { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: var(--r-pill); font-size: .72rem; font-weight: 800; }
.badge--sale  { background: var(--red-sale); color: var(--white); }
.badge--new   { background: var(--success); color: var(--white); }
.badge--stock { background: rgba(0,184,148,.12); color: var(--success); border: 1px solid rgba(0,184,148,.28); }

/* EYEBROW */
.eyebrow { display: inline-block; font-size: .73rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--green-lime); background: rgba(124,181,24,.1); border: 1px solid rgba(124,181,24,.28); padding: 5px 14px; border-radius: var(--r-pill); margin-bottom: 16px; }
.eyebrow--lime { background: rgba(124,181,24,.18); border-color: rgba(124,181,24,.38); }

/* SECTION HEADERS */
.section-header { text-align: center; margin-bottom: 52px; }
.section-header--left { text-align: left; margin-bottom: 28px; }
.section-header-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 36px; flex-wrap: wrap; }
.section-title { font-size: clamp(1.8rem, 3vw, 2.7rem); font-weight: 800; letter-spacing: -.04em; color: var(--text-900); line-height: 1.08; }
.section-title--left { font-size: clamp(1.6rem, 2.5vw, 2.2rem); }
.section-title em { font-family: var(--font-serif); font-weight: 400; color: var(--green-600); }
.section--dark .section-title { color: var(--white); }
.section--dark .section-title em { color: var(--green-lime); }
.section-sub { color: var(--text-500); margin-top: 14px; font-size: .95rem; max-width: 520px; margin-left: auto; margin-right: auto; }
.link-all { display: inline-flex; align-items: center; gap: 6px; font-size: .88rem; font-weight: 700; color: var(--green-600); padding: 9px 20px; border: 1.5px solid var(--green-200); border-radius: var(--r-pill); transition: var(--t-base); white-space: nowrap; }
.link-all:hover { background: var(--green-100); border-color: var(--green-600); }

/* KEYFRAMES */
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.7)} }
@keyframes fade-up   { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes orb-drift { from{transform:translate(0,0) scale(1)} to{transform:translate(30px,20px) scale(1.05)} }
@keyframes float-tag { from{transform:translateY(0)} to{transform:translateY(-7px)} }
@keyframes marquee   { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes badge-spin{ from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
@keyframes badge-rspin{from{transform:rotate(0deg)} to{transform:rotate(-360deg)} }

/* ANNOUNCE BAR */
.announce-bar { background: var(--green-900); color: rgba(255,255,255,.85); text-align: center; padding: 10px 20px; font-size: .8rem; font-weight: 500; letter-spacing: .02em; position: relative; z-index: 200; }
.announce-bar__inner { display: flex; align-items: center; justify-content: center; gap: 10px; }
.announce-bar strong { color: var(--green-lime); }
.announce-bar__dot { width: 7px; height: 7px; background: var(--green-lime); border-radius: 50%; animation: pulse-dot 2s infinite; flex-shrink: 0; }

/* HEADER */
.site-header { position: sticky; top: 0; z-index: 150; background: rgba(255,255,255,.96); backdrop-filter: blur(16px) saturate(180%); -webkit-backdrop-filter: blur(16px) saturate(180%); border-bottom: 1px solid var(--border); box-shadow: var(--shadow-sm); transition: box-shadow var(--t-base); }
.site-header.is-scrolled { box-shadow: 0 4px 24px rgba(26,77,46,.14); }
.header-inner { display: grid; grid-template-columns: 200px 1fr auto; align-items: center; gap: 24px; padding: 12px 32px; max-width: var(--container); margin: 0 auto; }
.site-logo img, .site-logo .custom-logo { height: 60px; width: auto; display: block; }
.site-logo__text,
.footer-logo__text { display: inline-flex; flex-direction: column; line-height: 1; color: var(--green-800); }
.site-logo__text strong,
.footer-logo__text strong { font-size: 1.35rem; font-weight: 800; letter-spacing: -.04em; }
.site-logo__text small,
.footer-logo__text small { margin-top: 4px; font-size: .67rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--text-500); }

/* Search */
.header-search { position: relative; }
.header-search form { display: flex; align-items: center; position: relative; }
.header-search__icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--text-300); display: flex; align-items: center; z-index: 1; transition: var(--t-fast); }
.header-search__input { width: 100%; padding: 11px 48px 11px 44px; border: 1.5px solid var(--border); border-radius: var(--r-pill); font-size: .88rem; background: var(--cream-100); color: var(--text-700); outline: none; transition: var(--t-base); }
.header-search__input:focus { border-color: var(--green-600); background: var(--white); box-shadow: 0 0 0 3px rgba(45,110,71,.1); }
.header-search__input::placeholder { color: var(--text-300); }
.header-search__submit { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); color: var(--text-300); display: flex; padding: 4px; transition: var(--t-fast); }
.header-search__submit:hover { color: var(--green-800); }

/* Actions */
.header-actions { display: flex; align-items: center; gap: 4px; }
.header-btn { display: flex; align-items: center; gap: 7px; padding: 9px 14px; border-radius: var(--r-pill); font-size: .82rem; font-weight: 600; color: var(--text-700); transition: var(--t-base); position: relative; }
.header-btn:hover { background: var(--green-100); color: var(--green-800); }
.header-btn__label { display: none; }
@media(min-width:1100px){.header-btn__label{display:inline}}
.header-btn--cart { background: var(--green-800); color: var(--white); padding: 9px 18px; }
.header-btn--cart:hover { background: var(--green-600); color: var(--white); }
.cart-badge { position: absolute; top: -3px; right: -3px; background: var(--green-lime); color: var(--green-800); border-radius: 50%; width: 18px; height: 18px; font-size: .65rem; font-weight: 800; display: flex; align-items: center; justify-content: center; transition: var(--t-fast); }
.cart-badge:empty { display: none; }
.header-btn--menu { display: none; }
@media(max-width:900px){.header-btn--menu{display:flex}}
.hamburger { display: flex; flex-direction: column; gap: 5px; width: 22px; }
.hamburger span { display: block; height: 2px; background: var(--green-800); border-radius: 2px; transition: var(--t-base); }
.is-open .hamburger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.is-open .hamburger span:nth-child(2) { opacity: 0; }
.is-open .hamburger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* NAVIGATION */
.main-nav { background: var(--green-800); border-top: 1px solid rgba(255,255,255,.06); }
.nav-inner { max-width: var(--container); margin: 0 auto; padding: 0 32px; display: flex; align-items: center; gap: 2px; }
.nav-all-cats { display: flex; align-items: center; gap: 8px; padding: 11px 16px; font-size: .84rem; font-weight: 700; color: var(--white); background: rgba(255,255,255,.1); border-radius: var(--r-sm); margin-right: 4px; transition: var(--t-base); white-space: nowrap; }
.nav-all-cats:hover { background: rgba(255,255,255,.18); }
.nav-menu { display: flex; align-items: center; gap: 2px; }
.nav-menu li>a { display: block; padding: 11px 14px; font-size: .84rem; font-weight: 600; color: rgba(255,255,255,.8); border-radius: var(--r-sm); transition: var(--t-base); white-space: nowrap; }
.nav-menu li>a:hover, .nav-menu li.current-menu-item>a { color: var(--white); background: rgba(255,255,255,.1); }
.nav-menu li.current-menu-item>a { color: var(--green-lime); background: rgba(124,181,24,.12); }
.nav-phone { display: inline-flex; align-items: center; gap: 7px; margin-left: auto; padding: 8px 18px; background: var(--green-lime); color: var(--green-800); border-radius: var(--r-pill); font-size: .82rem; font-weight: 800; transition: var(--t-base); white-space: nowrap; }
.nav-phone:hover { background: var(--green-lime-h); transform: translateY(-1px); }

/* MOBILE MENU */
.mobile-menu-overlay { position: fixed; inset: 0; background: rgba(13,38,22,.75); backdrop-filter: blur(6px); z-index: 300; opacity: 0; pointer-events: none; transition: opacity var(--t-slow); }
.mobile-menu-overlay.is-active { opacity: 1; pointer-events: auto; }
.mobile-menu { position: absolute; top: 0; right: 0; width: min(340px,90vw); height: 100%; background: var(--white); padding: 24px; overflow-y: auto; transform: translateX(100%); transition: transform var(--t-slow); display: flex; flex-direction: column; gap: 24px; }
.mobile-menu-overlay.is-active .mobile-menu { transform: translateX(0); }
.mobile-menu__close { align-self: flex-end; padding: 8px; color: var(--text-700); border-radius: var(--r-sm); transition: var(--t-fast); }
.mobile-menu__close:hover { background: var(--green-100); color: var(--green-800); }
.mobile-nav-list { display: flex; flex-direction: column; gap: 2px; }
.mobile-nav-list li a { display: block; padding: 12px 16px; font-size: 1rem; font-weight: 600; color: var(--text-700); border-radius: var(--r-md); transition: var(--t-fast); }
.mobile-nav-list li a:hover { background: var(--green-100); color: var(--green-800); }
.mobile-menu__footer { margin-top: auto; display: flex; flex-direction: column; gap: 10px; padding-top: 20px; border-top: 1px solid var(--border); }
.mobile-menu__footer a { font-size: .88rem; color: var(--text-500); font-weight: 600; }

/* HERO */
.hero { background: var(--green-800); position: relative; overflow: hidden; min-height: 580px; display: flex; align-items: center; }
.hero__noise { position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.055'/%3E%3C/svg%3E"); background-repeat: repeat; pointer-events: none; mix-blend-mode: overlay; opacity: .5; }
.hero__orb { position: absolute; border-radius: 50%; filter: blur(80px); pointer-events: none; }
.hero__orb--1 { width: 520px; height: 520px; background: radial-gradient(circle,rgba(124,181,24,.22) 0%,transparent 70%); right: 5%; top: -20%; animation: orb-drift 8s ease-in-out infinite alternate; }
.hero__orb--2 { width: 400px; height: 400px; background: radial-gradient(circle,rgba(45,110,71,.35) 0%,transparent 70%); left: -5%; bottom: -20%; }
.hero__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px); background-size: 64px 64px; pointer-events: none; }
.hero__leaf { position: absolute; pointer-events: none; color: var(--green-lime); }
.hero__leaf--tl { top: -40px; left: -20px; width: 180px; opacity: .6; }
.hero__leaf--br { bottom: -30px; right: -10px; width: 140px; opacity: .5; transform: rotate(20deg); }
.hero__inner { position: relative; display: grid; grid-template-columns: 1fr 420px; gap: 60px; align-items: center; padding: 80px 32px; width: 100%; max-width: var(--container); margin: 0 auto; }
.hero__content { animation: fade-up .7s ease both; }
.hero__visual   { animation: fade-up .7s .15s ease both; }
.hero__badge { display: inline-flex; align-items: center; gap: 9px; background: rgba(124,181,24,.18); border: 1px solid rgba(124,181,24,.4); color: var(--green-lime); padding: 6px 16px; border-radius: var(--r-pill); font-size: .76rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; margin-bottom: 24px; }
.hero__badge-dot { width: 7px; height: 7px; background: var(--green-lime); border-radius: 50%; animation: pulse-dot 2s infinite; }
.hero__title { font-size: clamp(2.2rem,4.2vw,3.8rem); font-weight: 800; color: var(--white); line-height: 1.06; letter-spacing: -.04em; margin-bottom: 10px; }
.hero__title em { font-family: var(--font-serif); font-weight: 400; color: var(--green-lime); display: block; letter-spacing: -.02em; font-size: .92em; }
.hero__sub { color: rgba(255,255,255,.62); font-size: 1rem; max-width: 500px; margin: 18px 0 36px; line-height: 1.72; }
.hero__actions { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.hero__stats { display: flex; gap: 36px; margin-top: 48px; padding-top: 32px; border-top: 1px solid rgba(255,255,255,.1); }
.hero__stat-num { display: block; font-size: 1.9rem; font-weight: 800; color: var(--white); letter-spacing: -.04em; line-height: 1; }
.hero__stat-sup { color: var(--green-lime); font-size: .75em; }
.hero__stat-label { display: block; font-size: .72rem; color: rgba(255,255,255,.45); font-weight: 600; margin-top: 5px; text-transform: uppercase; letter-spacing: .08em; }

/* Hero visual card */
.hero__visual { position: relative; }
.hero__float-tag { position: absolute; top: -18px; right: -12px; background: var(--white); border-radius: var(--r-md); padding: 10px 16px; display: flex; align-items: center; gap: 9px; box-shadow: var(--shadow-lg); font-size: .8rem; font-weight: 600; color: var(--text-700); z-index: 5; animation: float-tag 3s ease-in-out infinite alternate; }
.hero__float-dot { width: 8px; height: 8px; background: var(--success); border-radius: 50%; }
.hero-card { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.13); backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px); border-radius: var(--r-xl); padding: 20px; }
.hero-card__img { position: relative; background: rgba(255,255,255,.06); border-radius: var(--r-lg); height: 210px; overflow: hidden; display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.hero-card__img img { width: 100%; height: 100%; object-fit: contain; padding: 12px; }
.hero-card__img .badge { position: absolute; top: 12px; left: 12px; }
.hero-card__placeholder { color: rgba(255,255,255,.3); }
.hero-card__body { color: var(--white); }
.hero-card__title { font-size: .95rem; font-weight: 700; margin-bottom: 10px; letter-spacing: -.02em; }
.hero-card__prices { display: flex; align-items: baseline; gap: 10px; margin-bottom: 14px; }
.price--highlight .woocommerce-Price-amount { font-size: 1.35rem; color: var(--green-lime); font-weight: 800; }
.price--new { font-size: 1.35rem; color: var(--green-lime); font-weight: 800; letter-spacing: -.03em; }
.price--old { font-size: .85rem; color: rgba(255,255,255,.38); text-decoration: line-through; }

/* USP STRIP */
.usp-strip { background: var(--white); border-bottom: 1px solid var(--border); padding: 22px 0; }
.usp-strip__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; }
.usp-item { display: flex; align-items: center; gap: 14px; padding: 10px 16px; }
.usp-item__icon { width: 44px; height: 44px; background: var(--green-100); border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; color: var(--green-800); flex-shrink: 0; }
.usp-item strong { display: block; font-size: .88rem; font-weight: 700; color: var(--text-900); margin-bottom: 2px; }
.usp-item span   { font-size: .78rem; color: var(--text-500); }

/* CATEGORY CARDS */
.cats-grid { display: grid; grid-template-columns: repeat(7,1fr); gap: 14px; }
.cat-card { position: relative; background: var(--white); border: 1.5px solid var(--border); border-radius: var(--r-lg); padding: 28px 12px 22px; text-align: center; color: var(--text-700); transition: var(--t-base); overflow: hidden; display: flex; flex-direction: column; align-items: center; }
.cat-card__bg { position: absolute; inset: 0; overflow: hidden; border-radius: inherit; }
.cat-card__bg img { width: 100%; height: 100%; object-fit: cover; opacity: .08; transition: var(--t-slow); }
.cat-card:hover .cat-card__bg img { opacity: .16; transform: scale(1.06); }
.cat-card::after { content: ''; position: absolute; inset: 0; background: var(--green-800); opacity: 0; transition: var(--t-base); border-radius: inherit; }
.cat-card:hover { border-color: var(--green-800); transform: translateY(-5px); box-shadow: var(--shadow-md); }
.cat-card:hover::after { opacity: 1; }
.cat-card__icon { position: relative; z-index: 1; width: 58px; height: 58px; background: var(--green-100); border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; margin: 0 auto 14px; color: var(--green-800); transition: var(--t-base); }
.cat-card:hover .cat-card__icon { background: rgba(255,255,255,.14); color: var(--white); }
.cat-card__name { position: relative; z-index: 1; font-size: .84rem; font-weight: 700; color: var(--text-900); line-height: 1.25; letter-spacing: -.01em; transition: var(--t-base); }
.cat-card:hover .cat-card__name { color: var(--white); }
.cat-card__count { position: relative; z-index: 1; font-size: .7rem; color: var(--text-300); margin-top: 4px; transition: var(--t-base); }
.cat-card:hover .cat-card__count { color: rgba(255,255,255,.5); }

/* PRODUCT CARDS */
.products-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.product-card { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--r-lg); overflow: hidden; transition: var(--t-base); display: flex; flex-direction: column; }
.product-card:hover { border-color: var(--green-600); box-shadow: var(--shadow-md); transform: translateY(-4px); }
.product-card__img-wrap { position: relative; background: var(--cream-100); height: 200px; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.product-card__img { width: 100%; height: 100%; object-fit: contain; padding: 14px; transition: transform .4s ease; }
.product-card:hover .product-card__img { transform: scale(1.05); }
.product-card__img-wrap .badge { position: absolute; top: 10px; }
.product-card__img-wrap .badge--sale  { left: 10px; }
.product-card__img-wrap .badge--stock { right: 10px; }
.product-card__actions { position: absolute; bottom: 10px; right: 10px; display: flex; flex-direction: column; gap: 6px; opacity: 0; transform: translateY(4px); transition: var(--t-base); }
.product-card:hover .product-card__actions { opacity: 1; transform: translateY(0); }
.action-btn { width: 34px; height: 34px; background: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--text-500); box-shadow: var(--shadow-sm); transition: var(--t-fast); }
.action-btn:hover { background: var(--green-800); color: var(--white); }
.product-card__body { padding: 16px 18px 18px; flex: 1; display: flex; flex-direction: column; }
.product-card__brand { font-size: .68rem; font-weight: 700; color: var(--green-lime); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 5px; }
.product-card__name { font-size: .88rem; font-weight: 700; line-height: 1.32; color: var(--text-900); letter-spacing: -.01em; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; flex: 1; margin-bottom: 12px; }
.product-card__pricing { display: flex; align-items: baseline; gap: 8px; margin-bottom: 14px; }
.product-card__pricing .price--new { font-size: 1.15rem; color: var(--text-900); letter-spacing: -.03em; }
.product-card__pricing .price--old { font-size: .8rem; color: var(--text-200); text-decoration: line-through; }

/* SEASONAL BANNER */
.seasonal-banner { background: var(--green-800); position: relative; overflow: hidden; padding: 72px 0; }
.seasonal-banner__noise { position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.055'/%3E%3C/svg%3E"); mix-blend-mode: overlay; opacity: .4; pointer-events: none; }
.seasonal-banner__leaf { position: absolute; bottom: -20px; color: var(--green-lime); opacity: .12; pointer-events: none; width: 200px; }
.seasonal-banner__leaf--l { left: -20px; }
.seasonal-banner__leaf--r { right: -20px; transform: scaleX(-1); }
.seasonal-banner__inner { position: relative; display: flex; align-items: center; justify-content: space-between; gap: 48px; flex-wrap: wrap; }
.seasonal-banner__content { max-width: 560px; }
.seasonal-banner__title { font-size: clamp(2rem,3.5vw,3.2rem); font-weight: 800; color: var(--white); letter-spacing: -.04em; margin: 12px 0 18px; line-height: 1.08; }
.seasonal-banner__title em { font-family: var(--font-serif); font-weight: 400; color: var(--green-lime); display: block; }
.seasonal-banner__sub { color: rgba(255,255,255,.6); font-size: .95rem; margin-bottom: 32px; line-height: 1.7; }
.seasonal-banner__badge { background: rgba(124,181,24,.15); border: 2px solid rgba(124,181,24,.35); border-radius: 50%; width: 160px; height: 160px; display: flex; flex-direction: column; align-items: center; justify-content: center; flex-shrink: 0; animation: badge-spin 14s linear infinite; }
.seasonal-banner__pct { font-size: 3rem; font-weight: 800; color: var(--green-lime); letter-spacing: -.06em; line-height: 1; animation: badge-rspin 14s linear infinite; }
.seasonal-banner__pct small { font-size: 1.8rem; }
.seasonal-banner__pct-label { font-size: .72rem; color: rgba(255,255,255,.55); font-weight: 600; text-transform: uppercase; letter-spacing: .08em; text-align: center; line-height: 1.4; margin-top: 6px; animation: badge-rspin 14s linear infinite; }

/* BRANDS MARQUEE */
.brands-section { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 32px 0; overflow: hidden; }
.brands-section__label { text-align: center; font-size: .73rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--text-300); margin-bottom: 24px; }
.brands-marquee { overflow: hidden; position: relative; }
.brands-marquee__track { display: flex; align-items: center; animation: marquee 24s linear infinite; width: max-content; }
.brands-marquee__track:hover { animation-play-state: paused; }
.brands-marquee__item { font-size: 1.3rem; font-weight: 800; letter-spacing: -.03em; color: var(--text-900); padding: 0 32px; opacity: .28; transition: opacity var(--t-base); white-space: nowrap; cursor: default; }
.brands-marquee__item:hover { opacity: .85; }
.brands-marquee__sep { color: var(--green-lime); font-size: 1.2rem; opacity: .4; }

/* ABOUT */
.about-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.about-video-link { display: block; position: relative; border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--shadow-xl); aspect-ratio: 16/9; }
.about-video-link__thumb { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform var(--t-slow); }
.about-video-link:hover .about-video-link__thumb { transform: scale(1.04); }
.about-video-link__play { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,.25); transition: var(--t-base); }
.about-video-link:hover .about-video-link__play { background: rgba(0,0,0,.38); }
.about-video-link__play div { width: 68px; height: 68px; background: rgba(255,255,255,.96); border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 24px rgba(0,0,0,.3); transition: transform var(--t-base); }
.about-video-link:hover .about-video-link__play div { transform: scale(1.1); }
.about-info-card { margin-top: 20px; background: var(--green-800); border-radius: var(--r-lg); padding: 24px 28px; color: var(--white); box-shadow: var(--shadow-md); }
.about-info-card h3 { font-size: 1.1rem; font-weight: 800; margin-bottom: 8px; color: var(--white); }
.about-info-card p  { font-size: .85rem; color: rgba(255,255,255,.62); line-height: 1.65; margin-bottom: 14px; }
.about-info-card__location { display: inline-flex; align-items: center; gap: 7px; font-size: .78rem; font-weight: 700; background: rgba(124,181,24,.2); color: var(--green-lime); padding: 5px 12px; border-radius: var(--r-pill); border: 1px solid rgba(124,181,24,.3); transition: var(--t-fast); }
.about-info-card__location:hover { background: rgba(124,181,24,.3); }
.about-text { color: var(--text-500); line-height: 1.78; font-size: .95rem; margin-bottom: 28px; }
.about-features { display: flex; flex-direction: column; gap: 14px; margin-bottom: 32px; }
.about-feature { display: flex; gap: 14px; align-items: flex-start; }
.about-feature__icon { width: 38px; height: 38px; background: var(--green-100); border-radius: var(--r-sm); display: flex; align-items: center; justify-content: center; color: var(--green-800); flex-shrink: 0; }
.about-feature strong { display: block; font-size: .88rem; font-weight: 700; color: var(--text-900); margin-bottom: 2px; }
.about-feature span   { font-size: .8rem; color: var(--text-500); }

/* TESTIMONIALS */
.testimonials-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.testimonial-card { background: var(--cream-100); border: 1.5px solid var(--border); border-radius: var(--r-lg); padding: 28px 24px; transition: var(--t-base); display: flex; flex-direction: column; gap: 16px; }
.testimonial-card:hover { border-color: var(--green-200); box-shadow: var(--shadow-sm); transform: translateY(-3px); }
.testimonial-card__stars { color: var(--amber); font-size: 1rem; letter-spacing: .08em; }
.testimonial-card__quote { font-size: .9rem; color: var(--text-700); line-height: 1.72; font-style: italic; flex: 1; }
.testimonial-card__author { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.testimonial-card__name { font-size: .84rem; font-weight: 700; color: var(--text-900); }
.testimonial-card__location { font-size: .78rem; color: var(--text-300); }
.testimonial-card__location::before { content: '— '; }

/* NEWSLETTER */
.newsletter-section { background: var(--green-800); position: relative; overflow: hidden; padding: 80px 0; }
.newsletter-section__noise { position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.055'/%3E%3C/svg%3E"); mix-blend-mode: overlay; opacity: .35; pointer-events: none; }
.newsletter-section__leaf { position: absolute; right: -40px; bottom: -60px; color: var(--green-lime); opacity: .1; width: 280px; pointer-events: none; }
.newsletter-inner { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.newsletter-title { font-size: clamp(1.8rem,2.8vw,2.6rem); font-weight: 800; color: var(--white); letter-spacing: -.04em; margin: 12px 0 16px; line-height: 1.1; }
.newsletter-title em { font-family: var(--font-serif); font-weight: 400; color: var(--green-lime); display: block; }
.newsletter-sub { color: rgba(255,255,255,.58); font-size: .93rem; line-height: 1.7; }
.newsletter-form__row { display: flex; gap: 10px; margin-bottom: 12px; }
.newsletter-form__input { flex: 1; padding: 14px 20px; border-radius: var(--r-pill); border: 1.5px solid rgba(255,255,255,.18); background: rgba(255,255,255,.09); color: var(--white); font-family: var(--font-sans); font-size: .9rem; outline: none; transition: var(--t-base); }
.newsletter-form__input::placeholder { color: rgba(255,255,255,.38); }
.newsletter-form__input:focus { border-color: var(--green-lime); background: rgba(255,255,255,.13); }
.newsletter-form__note { font-size: .75rem; color: rgba(255,255,255,.38); }
.newsletter-form__note a { color: rgba(255,255,255,.55); text-decoration: underline; }
.newsletter-form__note a:hover { color: var(--green-lime); }

/* CONTACT STRIP */
.contact-strip { background: var(--green-800); padding: 48px 0; }
.contact-strip__inner { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; align-items: center; }
.contact-item { display: flex; align-items: center; gap: 16px; }
.contact-item__icon { width: 50px; height: 50px; background: rgba(124,181,24,.18); border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; color: var(--green-lime); flex-shrink: 0; }
.contact-item strong { display: block; font-size: .88rem; font-weight: 700; color: var(--white); margin-bottom: 3px; }
.contact-item strong a { color: var(--white); transition: var(--t-fast); }
.contact-item strong a:hover { color: var(--green-lime); }
.contact-item span { font-size: .8rem; color: rgba(255,255,255,.5); line-height: 1.5; }

/* FOOTER */
.site-footer { background: var(--green-950); color: rgba(255,255,255,.55); }
.footer-main { padding: 64px 0 0; }
.footer-grid { display: grid; grid-template-columns: 300px repeat(3,1fr); gap: 48px; padding-bottom: 48px; }
.footer-brand .custom-logo, .footer-brand img { height: 64px; width: auto; margin-bottom: 6px; }
.footer-logo__text { color: var(--white); margin-bottom: 8px; }
.footer-logo__text small { color: rgba(255,255,255,.45); }
.footer-logo { display: block; margin-bottom: 18px; }
.footer-brand__desc { font-size: .84rem; line-height: 1.72; margin-bottom: 22px; }
.footer-socials { display: flex; gap: 10px; margin-bottom: 24px; }
.social-btn { width: 36px; height: 36px; background: rgba(255,255,255,.07); border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.45); transition: var(--t-base); }
.social-btn:hover { background: var(--green-600); color: var(--white); }
.footer-delivery-box { background: rgba(124,181,24,.1); border: 1px solid rgba(124,181,24,.22); border-radius: var(--r-md); padding: 16px; }
.footer-delivery-box__title { display: flex; align-items: center; gap: 7px; font-size: .78rem; font-weight: 700; color: var(--green-lime); margin-bottom: 10px; }
.footer-delivery-box li { font-size: .78rem; color: rgba(255,255,255,.45); line-height: 1.7; }
.footer-delivery-box strong { color: rgba(255,255,255,.7); }
.footer-col__title { font-size: .78rem; font-weight: 700; color: var(--white); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 20px; }
.footer-links { display: flex; flex-direction: column; gap: 10px; }
.footer-links a { font-size: .84rem; color: rgba(255,255,255,.45); transition: var(--t-fast); }
.footer-links a:hover { color: var(--green-lime); padding-left: 5px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.07); padding: 18px 32px; }
.footer-bottom__inner { max-width: var(--container); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; font-size: .78rem; flex-wrap: wrap; }
.footer-bottom__copy   { color: rgba(255,255,255,.3); }
.footer-bottom__credit { color: rgba(255,255,255,.35); }
.footer-bottom__credit a { color: var(--green-lime); font-weight: 700; transition: var(--t-fast); }
.footer-bottom__credit a:hover { color: var(--green-lime-h); }
.footer-bottom__links { display: flex; gap: 22px; }
.footer-bottom__links a { color: rgba(255,255,255,.3); transition: var(--t-fast); }
.footer-bottom__links a:hover { color: rgba(255,255,255,.6); }

/* REVEAL ANIMATION */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .55s ease, transform .55s ease; transition-delay: var(--delay,0ms); }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

/* BACK TO TOP */
.back-to-top { position: fixed; bottom: 28px; right: 28px; width: 44px; height: 44px; background: var(--green-800); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-md); opacity: 0; pointer-events: none; transform: translateY(12px); transition: var(--t-base); z-index: 100; }
.back-to-top.is-visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
.back-to-top:hover { background: var(--green-600); transform: translateY(-2px); }

/* PAGE CONTENT */
.page-content-wrapper { min-height: 60vh; padding: var(--section-y) 0; }
.page-content-wrapper .container { max-width: 860px; }
.entry-title { font-size: clamp(2rem,4vw,3rem); font-weight: 800; letter-spacing: -.04em; margin-bottom: 28px; line-height: 1.08; }
.entry-content { font-size: .97rem; line-height: 1.8; color: var(--text-700); }
.entry-content h2 { font-size: 1.5rem; margin: 2em 0 .8em; }
.entry-content h3 { font-size: 1.2rem; margin: 1.8em 0 .7em; }
.entry-content p  { margin-bottom: 1.2em; }
.entry-content ul, .entry-content ol { padding-left: 1.5em; margin-bottom: 1.2em; }
.entry-content li { margin-bottom: .4em; }
.entry-content a  { color: var(--green-600); text-decoration: underline; }
.entry-content a:hover { color: var(--green-800); }
.error-404-wrap { text-align: center; padding: 120px 0; }
.error-404-wrap .error-num { font-size: clamp(7rem,15vw,13rem); font-weight: 800; color: var(--green-100); letter-spacing: -.06em; line-height: 1; }
.error-404-wrap h1 { font-size: 2rem; margin-bottom: 16px; }
.error-404-wrap p  { color: var(--text-500); margin-bottom: 32px; }

/* RESPONSIVE */
@media(max-width:1280px){ .cats-grid{grid-template-columns:repeat(4,1fr)} .footer-grid{grid-template-columns:260px repeat(3,1fr);gap:32px} }
@media(max-width:1024px){
  :root{--section-y:64px}
  .header-inner{grid-template-columns:180px 1fr auto}
  .hero__inner{grid-template-columns:1fr;gap:40px;padding:60px 32px}
  .hero__visual{display:none}
  .hero{min-height:auto}
  .usp-strip__grid{grid-template-columns:repeat(2,1fr)}
  .cats-grid{grid-template-columns:repeat(4,1fr)}
  .products-grid{grid-template-columns:repeat(3,1fr)}
  .about-inner{grid-template-columns:1fr;gap:48px}
  .newsletter-inner{grid-template-columns:1fr;gap:40px}
  .contact-strip__inner{grid-template-columns:1fr;gap:20px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .testimonials-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .main-nav{display:none}
  .header-inner{grid-template-columns:160px 1fr auto;padding:10px 20px}
  .cats-grid{grid-template-columns:repeat(3,1fr)}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .section-header-row{flex-direction:column;align-items:flex-start}
}
@media(max-width:600px){
  :root{--section-y:52px}
  .container{padding:0 20px}
  .header-inner{grid-template-columns:140px 1fr auto;gap:12px;padding:10px 16px}
  .hero__inner{padding:48px 20px}
  .hero__title{font-size:2rem}
  .hero__stats{gap:24px}
  .hero__stat-num{font-size:1.5rem}
  .usp-strip__grid{grid-template-columns:1fr}
  .cats-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .products-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .seasonal-banner__badge{display:none}
  .footer-grid{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .footer-bottom__inner{flex-direction:column;align-items:flex-start;gap:10px}
  .footer-bottom__links{flex-wrap:wrap;gap:14px}
  .newsletter-form__row{flex-direction:column}
}
@media(max-width:380px){
  .cats-grid{grid-template-columns:1fr 1fr}
  .hero__actions{flex-direction:column;align-items:flex-start}
  .hero__actions .btn{width:100%;justify-content:center}
}
