
:root{
  --bg:#f3f4f6;
  --panel:#ffffff;
  --panel-soft:#f8fafc;
  --text:#0f172a;
  --muted:#475569;
  --line:#e2e8f0;
  --dark:#0f172a;
  --green:#8eaa28;
  --shadow:0 20px 60px rgba(15,23,42,.06);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.5;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(1280px, calc(100% - 48px)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.header-wrap{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:16px}
.brand{background:#2f3638;padding:12px 16px;border-radius:18px;box-shadow:var(--shadow)}
.brand img{height:36px}
.header-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:14px}
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,#f5f6f7 0%,#eef1f4 45%,#d5d9de 45%,#6a6c70 100%);
}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(115deg,transparent 0%,transparent 38%,rgba(255,255,255,.22) 38.5%,transparent 40%,transparent 100%),
    radial-gradient(circle at top left, rgba(255,255,255,.45), transparent 28%),
    radial-gradient(circle at bottom right, rgba(142,170,40,.12), transparent 24%);
}
.hero-grid{position:relative;display:grid;grid-template-columns:.92fr 1.08fr;gap:40px;padding:40px 0 64px}
.eyebrow{
  display:inline-flex;width:max-content;padding:10px 16px;border-radius:999px;
  background:rgba(255,255,255,.8); border:1px solid rgba(255,255,255,.7);
  color:#334155; box-shadow:var(--shadow); font-size:14px; font-weight:500
}
.kicker{margin:20px 0 0; text-transform:uppercase; letter-spacing:.18em; color:var(--green); font-weight:700}
.hero h1{margin:8px 0 0;font-size:clamp(42px, 6vw, 78px);line-height:1.05;letter-spacing:-.04em;max-width:760px}
.lead{margin:24px 0 0;max-width:700px;font-size:20px;line-height:1.8;color:#334155}
.hero-actions,.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 24px;border-radius:18px;font-weight:700;font-size:15px;
  transition:.2s ease;border:1px solid transparent
}
.btn:hover{transform:translateY(-1px)}
.btn-dark{background:var(--dark);color:#fff;box-shadow:0 12px 30px rgba(15,23,42,.14)}
.btn-dark:hover{background:#1e293b}
.btn-outline{background:rgba(255,255,255,.92);border-color:#cbd5e1;color:#1e293b}
.btn-light{background:#fff;border-color:#e2e8f0;color:#0f172a}
.btn-green{background:var(--green);color:#101827}
.btn-dark-border{border-color:rgba(255,255,255,.18);color:#fff}
.use-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:36px}
.use-card{
  border:1px solid rgba(255,255,255,.8);
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(6px);
  border-radius:24px;padding:20px;box-shadow:var(--shadow); color:#334155
}
.hero-panel{
  border:1px solid rgba(255,255,255,.5);
  background:rgba(255,255,255,.45);
  backdrop-filter:blur(8px);
  border-radius:36px;padding:20px;box-shadow:0 30px 80px rgba(15,23,42,.12);
  display:grid;grid-template-columns:1.05fr .95fr;gap:16px
}
.hero-main,.hero-small,.mini-card,.strip-card,.feature-box,.comp-card,.product-row,.contact-card{
  border:1px solid var(--line); background:#fff; box-shadow:var(--shadow)
}
.hero-main,.hero-small{
  border:none;
  background:linear-gradient(180deg,rgba(255,255,255,.75) 0%, rgba(255,255,255,.35) 100%);
  border-radius:28px; padding:16px
}
.hero-main img{height:288px;width:100%;object-fit:contain;filter:drop-shadow(0 20px 30px rgba(15,23,42,.18))}
.hero-side{display:grid;gap:16px}
.hero-small img{height:128px;width:100%;object-fit:contain;filter:drop-shadow(0 18px 25px rgba(15,23,42,.18))}
.mini-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:16px}
.mini-card{border-radius:28px;background:rgba(255,255,255,.8);backdrop-filter:blur(6px);padding:16px;border-color:rgba(255,255,255,.7)}
.mini-card img{height:112px;width:100%;object-fit:contain;filter:drop-shadow(0 16px 22px rgba(15,23,42,.16))}
.strip-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:24px;padding:24px 0}
.strip-card{overflow:hidden;border-radius:32px}
.strip-card img{width:100%;height:100%;object-fit:cover}
.strip-text{padding:32px}
.section-label{margin:0;text-transform:uppercase;letter-spacing:.24em;font-size:12px;font-weight:700;color:#94a3b8}
.strip-text h2,.section-head h2,.contact-grid h2{margin:12px 0 0;font-size:clamp(28px,4vw,42px);line-height:1.12;letter-spacing:-.03em}
.strip-text p:last-child,.contact-grid p:last-child{margin-top:18px;color:#475569;line-height:1.9}
.feature-band{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;padding:16px 0 24px}
.feature-box{border-radius:28px;padding:24px}
.feature-box span{display:block;text-transform:uppercase;letter-spacing:.22em;font-size:12px;color:#94a3b8}
.feature-box strong{display:block;margin-top:8px;font-size:22px;line-height:1.3}
.composition-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;padding:16px 0 32px}
.comp-card{border-radius:32px;padding:24px;overflow:hidden;background:linear-gradient(135deg,#fff 0%,#f3f4f6 100%)}
.comp-card img{margin-top:16px;height:170px;width:100%;object-fit:contain;filter:drop-shadow(0 16px 22px rgba(15,23,42,.14))}
.comp-double .double-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:16px}
.comp-double .double-grid div{border-radius:24px;background:#fff;padding:16px;box-shadow:var(--shadow)}
.comp-double img{margin-top:0;height:120px}
.products{padding:16px 0 96px}
.section-head{margin-bottom:24px}
.product-row{
  display:grid;grid-template-columns:.95fr 1.05fr;gap:0;
  overflow:hidden;border-radius:32px;margin-bottom:24px
}
.product-row.reverse{grid-template-columns:1.05fr .95fr}
.product-gallery{
  padding:24px;background:linear-gradient(135deg,#f8fafc 0%,#eef2f7 100%);
}
.product-gallery.single,.product-gallery.two-up{
  display:grid;align-items:center;gap:16px
}
.product-gallery.single img{height:320px;width:100%;object-fit:contain;filter:drop-shadow(0 20px 30px rgba(15,23,42,.16))}
.product-gallery.two-up{grid-template-columns:repeat(2,minmax(0,1fr))}
.product-gallery.two-up img{height:240px;width:100%;object-fit:contain;filter:drop-shadow(0 20px 30px rgba(15,23,42,.16))}
.product-content{padding:32px}
.badge{
  display:inline-flex;padding:8px 14px;border-radius:999px;background:#f1f5f9;
  border:1px solid var(--line);font-size:12px;font-weight:700;letter-spacing:.08em;color:#334155
}
.product-content h3{margin:16px 0 0;font-size:36px;line-height:1.15;letter-spacing:-.03em}
.product-content p{margin:14px 0 0;font-size:18px;color:#475569;line-height:1.8}
.product-content ul{margin:22px 0 0;padding:0;list-style:none;display:grid;gap:10px}
.product-content li{position:relative;padding-left:18px;color:#475569;line-height:1.7}
.product-content li::before{
  content:"";position:absolute;left:0;top:.72em;width:6px;height:6px;border-radius:50%;background:var(--green)
}
.contact-section{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;padding:56px 0}
.contact-card{
  border-radius:32px;padding:28px;background:#0f172a;color:#fff
}
.contact-card img{height:42px;width:auto}
.contact-card p{margin:10px 0 0;color:rgba(255,255,255,.8)}
@media (max-width: 1100px){
  .hero-grid,.strip-grid,.contact-grid,.product-row,.product-row.reverse{grid-template-columns:1fr}
  .feature-band,.composition-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 760px){
  .container{width:min(100% - 32px, 1280px)}
  .header-wrap{align-items:flex-start}
  .header-meta span,.header-meta a:first-child{display:none}
  .use-grid,.mini-grid,.feature-band,.composition-grid,.strip-grid,.comp-double .double-grid,.product-gallery.two-up{grid-template-columns:1fr}
  .hero-panel{grid-template-columns:1fr}
  .hero h1{font-size:44px}
  .lead{font-size:18px}
  .product-content h3{font-size:30px}
}


.header-cta{
  box-shadow:0 12px 30px rgba(142,170,40,.22);
}
.header-cta:hover{
  filter:brightness(.98);
}

.hero-panel-interactive{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) 200px;
  gap:16px;
  align-items:stretch;
}
.hero-main{
  min-height:0;
}
.hero-main-link{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
  min-height:288px;
}
.hero-main img{
  width:100%;
  height:288px;
  object-fit:contain;
  object-position:center;
  filter:drop-shadow(0 20px 30px rgba(15,23,42,.18));
}
.hero-side{
  display:grid;
  grid-template-rows:repeat(2, 136px);
  gap:16px;
  align-content:start;
}
.hero-side .hero-thumb{
  min-height:136px;
}
.hero-thumb{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
  border:none;
  cursor:pointer;
  padding:12px;
  border-radius:28px;
  background:linear-gradient(180deg,rgba(255,255,255,.75) 0%, rgba(255,255,255,.35) 100%);
  transition:transform .2s ease, box-shadow .2s ease, outline-color .2s ease;
}
.hero-thumb img{
  width:100%;
  height:96px;
  object-fit:contain;
  object-position:center;
  filter:drop-shadow(0 16px 22px rgba(15,23,42,.16));
}
.hero-thumb:hover{
  transform:translateY(-1px);
}
.hero-thumb.is-active{
  outline:3px solid rgba(142,170,40,.45);
  outline-offset:2px;
}
.mini-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
  margin-top:16px;
}
.mini-card.hero-thumb{
  min-height:136px;
  background:rgba(255,255,255,.8);
  backdrop-filter:blur(6px);
}
.mini-card.hero-thumb img{
  height:96px;
}
.hero-image-animate{
  animation:heroSwapFade .35s ease;
}
@keyframes heroSwapFade{
  from{opacity:.45; transform:scale(.985);}
  to{opacity:1; transform:scale(1);}
}
@media (max-width:760px){
  .hero-panel-interactive{
    grid-template-columns:1fr;
  }
  .hero-main-link{
    min-height:240px;
  }
  .hero-main img{
    height:240px;
  }
  .hero-side{
    grid-template-rows:repeat(2, 128px);
  }
  .hero-side .hero-thumb,
  .mini-card.hero-thumb{
    min-height:128px;
  }
  .hero-thumb img,
  .mini-card.hero-thumb img{
    height:88px;
  }
  .mini-grid{
    grid-template-columns:1fr;
  }
}
