:root {
  --bg: #1a1a1a;
  --bg-dark: #111;
  --bg-light: #222;
  --primary: #5B8C51;
  --primary-dark: #095540;
  --primary-light: rgba(91,140,81,.12);
  --white: #fff;
  --white-soft: rgba(255,255,255,.6);
  --white-muted: rgba(255,255,255,.4);
  --black: #404A3D;
  --grey: #888;
  --font: "Plus Jakarta Sans", sans-serif;
  --font-head: "Signika", sans-serif;
  --max-w: 1280px;
  --transition: .3s ease;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:10px; scroll-behavior:smooth; }
body { font-family:var(--font); background:var(--bg); color:var(--white); line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
img { max-width:100%; height:auto; display:block; }
h1,h2,h3,h4,h5,h6 { font-family:var(--font-head); font-weight:400; }

.container { width:100%; max-width:var(--max-w); margin:0 auto; padding:0 2.4rem; }

/* ===================== HEADER ===================== */
header {
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  padding:1.8rem 0;
  background:rgba(17,17,17,.8);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:background var(--transition), padding var(--transition);
}
header.scrolled { padding:1rem 0; background:rgba(17,17,17,.96); }
.header-inner { display:flex; align-items:center; justify-content:space-between; }
.header-logo img { height:4rem; }
.header-nav ul { display:flex; gap:3rem; }
.header-nav a {
  font-size:1.4rem; font-weight:500; color:var(--white-soft);
  transition:color var(--transition); position:relative;
}
.header-nav a::after {
  content:''; position:absolute; bottom:-6px; left:0; width:0; height:2px;
  background:var(--primary); transition:width var(--transition);
}
.header-nav a:hover, .header-nav a.active { color:var(--white); }
.header-nav a:hover::after, .header-nav a.active::after { width:100%; }
.header-lang { display:flex; gap:.6rem; margin-left:2rem; }
.header-lang a {
  font-size:1.2rem; font-weight:700; padding:.4rem .8rem; border-radius:.4rem;
  color:var(--white-muted); transition:all var(--transition); letter-spacing:.02rem;
}
.header-lang a.active { color:var(--white); background:var(--primary); }
.header-lang a:hover { color:var(--white); }
.header-mobile {
  display:none; font-size:2.2rem; color:var(--white); cursor:pointer;
  background:none; border:none;
}

/* ===================== HERO SLIDER ===================== */
.hero { position:relative; height:100vh; min-height:600px; max-height:900px; overflow:hidden; }
.hero-slide {
  position:absolute; inset:0; opacity:0;
  transition:opacity 1.2s ease;
}
.hero-slide.active { opacity:1; }
.hero-slide img { width:100%; height:100%; object-fit:cover; }
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.3) 0%, rgba(0,0,0,.55) 60%, rgba(0,0,0,.75) 100%);
}
.hero-content {
  position:absolute; bottom:16%; left:0; width:100%; z-index:2;
}
.hero-content h1 {
  font-size:6rem; color:var(--white); margin-bottom:1.6rem;
  max-width:650px; line-height:1.12; font-weight:300;
}
.hero-content p {
  font-size:1.7rem; color:var(--white-soft); max-width:520px;
  line-height:1.8; font-weight:400;
}
.hero-dots {
  position:absolute; bottom:4rem; left:50%; transform:translateX(-50%);
  display:flex; gap:1rem; z-index:3;
}
.hero-dots button {
  width:1rem; height:1rem; border-radius:50%; border:2px solid var(--white-soft);
  background:transparent; cursor:pointer; transition:all var(--transition);
}
.hero-dots button.active { background:var(--primary); border-color:var(--primary); transform:scale(1.3); }
.hero-scroll {
  position:absolute; bottom:4rem; right:4rem; z-index:3;
  display:flex; flex-direction:column; align-items:center; gap:.6rem;
  color:var(--white-muted); font-size:1.1rem; letter-spacing:.15rem; text-transform:uppercase;
}
.hero-scroll .scroll-line {
  width:1px; height:4rem; background:rgba(255,255,255,.2); position:relative; overflow:hidden;
}
.hero-scroll .scroll-line::after {
  content:''; position:absolute; top:-100%; left:0; width:100%; height:100%;
  background:var(--primary); animation:scrollDown 2s ease infinite;
}
@keyframes scrollDown { 0%{top:-100%} 50%{top:0} 100%{top:100%} }

/* ===================== FEATURES ===================== */
.features { padding:6rem 0; background:var(--bg-dark); border-bottom:1px solid rgba(255,255,255,.04); }
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3rem; }
.feature-card { display:flex; gap:1.8rem; align-items:flex-start; }
.feature-icon {
  width:5rem; height:5rem; min-width:5rem;
  background:var(--primary); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.8rem; color:var(--white);
}
.feature-card h3 { font-size:1.8rem; margin-bottom:.4rem; color:var(--white); }
.feature-card p { font-size:1.35rem; color:var(--white-soft); line-height:1.7; }

/* ===================== SECTION TITLES ===================== */
.section-tag {
  display:inline-flex; align-items:center; gap:.6rem;
  font-size:1.2rem; font-weight:700; color:var(--primary);
  text-transform:uppercase; letter-spacing:.12rem; margin-bottom:1.2rem;
}
.section-tag i { font-size:1.1rem; }
.section-title { font-size:4.2rem; color:var(--white); margin-bottom:2rem; line-height:1.2; }
.section-desc { font-size:1.5rem; color:var(--white-soft); max-width:520px; line-height:1.8; }

/* ===================== ABOUT ===================== */
.about { padding:8rem 0; position:relative; overflow:hidden; }
.about-inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.about-image { position:relative; }
.about-image img { border-radius:1rem; width:100%; aspect-ratio:4/3; object-fit:cover; }
.about-badge {
  position:absolute; bottom:2rem; left:2rem;
  background:var(--primary); padding:1.6rem 2rem; border-radius:.8rem;
  text-align:center;
}
.about-badge h3 { font-size:3rem; font-weight:700; color:var(--white); line-height:1; }
.about-badge p { font-size:1.2rem; color:rgba(255,255,255,.8); margin-top:.4rem; }
.about-text p { font-size:1.5rem; color:var(--white-soft); line-height:1.8; margin-bottom:2rem; }
.about-features { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin-top:2.4rem; }
.about-feat { display:flex; gap:1.2rem; align-items:flex-start; }
.about-feat-icon {
  width:4rem; height:4rem; min-width:4rem;
  background:var(--primary-light); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--primary); font-size:1.4rem;
}
.about-feat h4 { font-size:1.5rem; color:var(--white); margin-bottom:.2rem; }
.about-feat p { font-size:1.25rem; color:var(--white-soft); line-height:1.6; }

.btn {
  display:inline-flex; align-items:center; gap:.8rem;
  padding:1.3rem 2.8rem; border-radius:5rem; font-size:1.4rem; font-weight:600;
  font-family:var(--font-head); transition:all var(--transition); cursor:pointer; border:none;
}
.btn-primary { background:var(--primary); color:var(--white); }
.btn-primary:hover { background:var(--primary-dark); transform:translateY(-2px); box-shadow:0 .6rem 1.6rem rgba(91,140,81,.3); }
.btn-white { background:var(--white); color:var(--black); }
.btn-white:hover { background:var(--primary); color:var(--white); }
.btn-outline { background:transparent; color:var(--white); border:2px solid var(--primary); }
.btn-outline:hover { background:var(--primary); }

/* ===================== PROCESSES ===================== */
.processes { padding:8rem 0; background:var(--bg-dark); }
.processes-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:1.8rem; margin-top:3.6rem; }
.process-card {
  background:var(--bg); border-radius:1rem; overflow:hidden;
  transition:transform var(--transition), box-shadow var(--transition);
}
.process-card:hover { transform:translateY(-.5rem); box-shadow:0 1rem 2rem rgba(0,0,0,.3); }
.process-card img { width:100%; height:18rem; object-fit:cover; }
.process-info { padding:1.6rem; }
.process-step {
  font-size:1rem; font-weight:700; color:var(--primary);
  text-transform:uppercase; letter-spacing:.1rem; margin-bottom:.3rem; display:block;
}
.process-card h3 { font-size:1.6rem; color:var(--white); margin-bottom:.5rem; }
.process-card p { font-size:1.2rem; color:var(--white-soft); line-height:1.6; }

/* ===================== PRODUCTS ===================== */
.products { padding:8rem 0; position:relative; }
.products-header { text-align:center; margin-bottom:4rem; }
.products-header .section-desc { margin:0 auto; }
.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.product-card {
  position:relative; border-radius:1rem; overflow:hidden;
  cursor:pointer; aspect-ratio:4/3; display:block;
}
.product-card img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.product-card:hover img { transform:scale(1.06); }
.product-card-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.8) 0%, rgba(0,0,0,.1) 50%, transparent 100%);
  display:flex; align-items:flex-end; padding:2rem;
  transition:background var(--transition);
}
.product-card:hover .product-card-overlay {
  background:linear-gradient(to top, rgba(91,140,81,.85) 0%, rgba(0,0,0,.2) 50%, transparent 100%);
}
.product-card h3 { font-size:1.8rem; color:var(--white); font-weight:500; }

/* ===================== SLOGAN ===================== */
.slogan {
  padding:8rem 0; text-align:center;
  background:linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
  position:relative;
}
.slogan h2 { font-size:3.6rem; color:var(--white); margin-bottom:2.4rem; line-height:1.3; }
.slogan .btn { margin-top:.8rem; }

/* ===================== FOOTER ===================== */
footer { background:var(--bg-dark); position:relative; padding-top:4rem; }
.footer-wave { display:none; }
footer::before {
  content:''; position:absolute; top:0; left:0; width:100%;
  height:1px; background:rgba(255,255,255,.06);
}
.footer-inner {
  display:grid; grid-template-columns:1.4fr 1fr 1.2fr; gap:4rem;
  padding-bottom:3rem;
}
.footer-brand img { height:6rem; margin-bottom:1.6rem; }
.footer-brand p { font-size:1.3rem; color:var(--white-soft); line-height:1.7; max-width:300px; }
.footer-social { display:flex; gap:1rem; margin-top:1.6rem; }
.footer-social a {
  width:3.6rem; height:3.6rem; border-radius:50%;
  background:rgba(255,255,255,.06); display:flex; align-items:center; justify-content:center;
  color:var(--white-soft); font-size:1.4rem; transition:all var(--transition);
  border:1px solid rgba(255,255,255,.08);
}
.footer-social a:hover { background:var(--primary); color:var(--white); border-color:var(--primary); }
.footer-links h4 { font-size:1.6rem; color:var(--white); margin-bottom:1.4rem; font-weight:600; }
.footer-links li { margin-bottom:.8rem; }
.footer-links a { font-size:1.3rem; color:var(--white-soft); transition:color var(--transition); }
.footer-links a:hover { color:var(--primary); }
.footer-contact h4 { font-size:1.6rem; color:var(--white); margin-bottom:1.4rem; font-weight:600; }
.footer-contact-item { display:flex; gap:1rem; align-items:flex-start; margin-bottom:1.4rem; }
.footer-contact-item i {
  width:3.2rem; height:3.2rem; min-width:3.2rem;
  background:var(--primary-light); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--primary); font-size:1.2rem; margin-top:.2rem;
}
.footer-contact-item p,
.footer-contact-item a { font-size:1.3rem; color:var(--white-soft); line-height:1.6; }
.footer-contact-item a:hover { color:var(--primary); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.06);
  padding:1.8rem 0; text-align:center;
}
.footer-bottom p { font-size:1.2rem; color:var(--grey); }

/* ===================== PAGE HEADER ===================== */
.page-header {
  position:relative; height:36rem; display:flex; align-items:center;
  justify-content:center; text-align:center; margin-top:7.6rem;
}
.page-header > img {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
}
.page-header-overlay {
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.4) 0%, rgba(0,0,0,.7) 100%);
}
.page-header-content { position:relative; z-index:2; }
.page-header h1 { font-size:4.4rem; color:var(--white); margin-bottom:1rem; font-weight:300; }
.breadcrumb { display:flex; gap:.8rem; justify-content:center; align-items:center; }
.breadcrumb a { font-size:1.3rem; color:var(--white-soft); transition:color var(--transition); }
.breadcrumb a:hover { color:var(--primary); }
.breadcrumb span { font-size:1.3rem; color:var(--white); font-weight:600; }
.breadcrumb i { font-size:.9rem; color:var(--grey); }

/* ===================== ABOUT PAGE ===================== */
.about-page { padding:7rem 0; }
.about-page-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.vision-mission { padding:7rem 0; background:var(--bg-dark); }
.vm-grid { display:grid; grid-template-columns:1fr 1fr; gap:3rem; }
.vm-card {
  background:var(--bg); padding:3.6rem; border-radius:1rem;
  border-left:3px solid var(--primary);
}
.vm-card h3 { font-size:2.2rem; color:var(--white); margin-bottom:1.4rem; }
.vm-card p { font-size:1.4rem; color:var(--white-soft); line-height:1.8; }

/* ===================== PRODUCTS PAGE ===================== */
.products-page { padding:7rem 0; }
.categories-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.category-card {
  position:relative; border-radius:1rem; overflow:hidden;
  aspect-ratio:4/3; cursor:pointer; display:block;
}
.category-card img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.category-card:hover img { transform:scale(1.06); }
.category-card-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.8) 0%, transparent 45%);
  display:flex; align-items:flex-end; padding:2rem;
}
.category-card:hover .category-card-overlay {
  background:linear-gradient(to top, rgba(91,140,81,.85) 0%, rgba(0,0,0,.15) 45%, transparent 100%);
}
.category-card h3 { font-size:2rem; color:var(--white); font-weight:500; }

/* ===================== PRODUCT DETAIL PAGE ===================== */
.detail-page { padding:7rem 0; }
.detail-header {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:3.6rem; flex-wrap:wrap; gap:1.6rem;
}
.detail-section-title {
  font-size:1.3rem; color:var(--primary); font-weight:700;
  text-transform:uppercase; letter-spacing:.1rem; margin-bottom:1.8rem;
  padding-bottom:.8rem; border-bottom:1px solid rgba(255,255,255,.08);
}
.detail-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:2rem; margin-bottom:3.6rem;
}
.detail-product {
  background:var(--bg-dark); border-radius:1rem; overflow:hidden;
  transition:transform var(--transition);
  border:1px solid rgba(255,255,255,.04);
}
.detail-product:hover { transform:translateY(-.3rem); border-color:rgba(91,140,81,.2); }
.detail-product img { width:100%; height:20rem; object-fit:cover; }
.detail-product-info { padding:1.8rem; }
.detail-product h4 { font-size:1.7rem; color:var(--white); margin-bottom:1rem; }
.detail-product-meta { display:flex; flex-direction:column; gap:.6rem; }
.detail-product-meta li { display:flex; justify-content:space-between; gap:1rem; padding:.4rem 0; border-bottom:1px solid rgba(255,255,255,.04); }
.detail-product-meta li:last-child { border-bottom:none; }
.detail-product-meta .label { font-size:1.1rem; color:var(--grey); text-transform:uppercase; letter-spacing:.05rem; }
.detail-product-meta .value { font-size:1.25rem; color:var(--white-soft); text-align:right; }
.detail-note {
  text-align:center; padding:2.4rem 2rem; font-size:1.4rem; color:var(--primary);
  font-style:italic; border-top:1px solid rgba(255,255,255,.06); margin-top:2rem;
  background:var(--primary-light); border-radius:.8rem;
}

/* ===================== CONTACT PAGE ===================== */
.contact-page { padding:7rem 0; }
.contact-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2.4rem; }
.contact-card {
  background:var(--bg-dark); border-radius:1rem; padding:3rem 2.4rem;
  text-align:center; transition:transform var(--transition);
  border:1px solid rgba(255,255,255,.04);
}
.contact-card:hover { transform:translateY(-.3rem); border-color:rgba(91,140,81,.2); }
.contact-card-icon {
  width:5.4rem; height:5.4rem; margin:0 auto 1.8rem;
  background:var(--primary-light); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--primary); font-size:2rem;
}
.contact-card h3 { font-size:1.8rem; color:var(--white); margin-bottom:1.2rem; }
.contact-card a {
  display:block; font-size:1.35rem; color:var(--white-soft);
  line-height:1.8; transition:color var(--transition);
}
.contact-card a:hover { color:var(--primary); }
.contact-card p { font-size:1.35rem; color:var(--white-soft); line-height:1.8; }

/* ===================== NEWS PAGE ===================== */
.news-page { padding:7rem 0; }
.news-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:2.4rem; }
.news-card {
  background:var(--bg-dark); border-radius:1rem; overflow:hidden;
  transition:transform var(--transition); border:1px solid rgba(255,255,255,.04);
}
.news-card:hover { transform:translateY(-.3rem); border-color:rgba(91,140,81,.2); }
.news-card img { width:100%; height:20rem; object-fit:cover; }
.news-card-body { padding:2rem; }
.news-card-date { font-size:1.1rem; color:var(--primary); font-weight:700; margin-bottom:.6rem; text-transform:uppercase; letter-spacing:.05rem; }
.news-card h3 { font-size:1.8rem; color:var(--white); margin-bottom:.8rem; line-height:1.4; }
.news-card p { font-size:1.3rem; color:var(--white-soft); line-height:1.7; margin-bottom:1.4rem; }
.news-detail-page { padding:7rem 0; }
.news-detail-page .nd-date { font-size:1.2rem; color:var(--primary); font-weight:700; margin-bottom:.8rem; text-transform:uppercase; letter-spacing:.05rem; }
.news-detail-page .nd-title { font-size:3.2rem; color:var(--white); margin-bottom:2rem; line-height:1.3; }
.news-detail-page .nd-image { width:100%; max-height:48rem; object-fit:cover; border-radius:1rem; margin-bottom:2.4rem; }
.news-detail-page .nd-desc { font-size:1.7rem; color:var(--white); font-weight:500; line-height:1.7; margin-bottom:1.6rem; }
.news-detail-page .nd-body { font-size:1.5rem; color:var(--white-soft); line-height:1.9; }
.news-detail-page .nd-body p { margin-bottom:1.4rem; }

/* ===================== MOBILE NAV ===================== */
.mobile-nav {
  position:fixed; top:0; right:-100%; width:80%; max-width:340px; height:100vh;
  background:var(--bg-dark); z-index:1001; padding:7rem 2.4rem 2.4rem;
  transition:right .35s ease; border-left:1px solid rgba(255,255,255,.06);
}
.mobile-nav.open { right:0; }
.mobile-nav ul { display:flex; flex-direction:column; gap:1.8rem; }
.mobile-nav a { font-size:1.7rem; color:var(--white-soft); font-weight:500; transition:color var(--transition); }
.mobile-nav a:hover { color:var(--primary); }
.mobile-nav-close {
  position:absolute; top:2rem; right:2rem; font-size:2.2rem;
  color:var(--white); background:none; border:none; cursor:pointer;
}
.mobile-nav-lang { display:flex; gap:.8rem; margin-top:2.4rem; }
.mobile-nav-lang a { font-size:1.4rem; padding:.5rem 1rem; border-radius:.4rem; color:var(--white-soft); font-weight:600; }
.mobile-nav-lang a.active { background:var(--primary); color:var(--white); }
.mobile-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.55);
  z-index:1000; opacity:0; pointer-events:none;
  transition:opacity .35s ease;
}
.mobile-overlay.open { opacity:1; pointer-events:auto; }

/* ===================== RESPONSIVE ===================== */
@media(max-width:1100px) {
  .processes-grid { grid-template-columns:repeat(3,1fr); }
}
@media(max-width:1024px) {
  .hero-content h1 { font-size:4.6rem; }
  .section-title { font-size:3.6rem; }
  .footer-inner { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  .header-nav, .header-lang { display:none; }
  .header-mobile { display:block; }
  .hero { max-height:none; }
  .hero-content h1 { font-size:3.6rem; }
  .hero-content p { font-size:1.4rem; max-width:90%; }
  .hero-scroll { display:none; }
  .features-grid { grid-template-columns:1fr; gap:2.4rem; }
  .about-inner, .about-page-grid { grid-template-columns:1fr; gap:3rem; }
  .processes-grid { grid-template-columns:repeat(2,1fr); }
  .products-grid, .categories-grid { grid-template-columns:repeat(2,1fr); }
  .footer-inner { grid-template-columns:1fr; gap:2.4rem; }
  .vm-grid { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .section-title { font-size:3rem; }
  .page-header { height:28rem; }
  .page-header h1 { font-size:3.2rem; }
  .slogan h2 { font-size:2.6rem; }
  .slogan { padding:6rem 0; }
  .about, .processes, .products { padding:6rem 0; }
  .about-page, .products-page, .contact-page, .news-page, .detail-page { padding:5rem 0; }
  .vision-mission { padding:5rem 0; }
}
@media(max-width:480px) {
  .hero-content h1 { font-size:2.8rem; }
  .hero-content { bottom:12%; }
  .products-grid, .categories-grid { grid-template-columns:1fr; }
  .processes-grid { grid-template-columns:1fr; }
  .about-features { grid-template-columns:1fr; }
  .section-title { font-size:2.6rem; }
  .page-header { height:24rem; }
  .page-header h1 { font-size:2.6rem; }
  .detail-grid { grid-template-columns:1fr; }
}

/* ===================== NEWS CARDS ===================== */
.news-card {
  display:block;
  background:var(--bg-light);
  border-radius:1.6rem;
  overflow:hidden;
  transition:transform var(--transition), box-shadow var(--transition);
}
.news-card:hover {
  transform:translateY(-.4rem);
  box-shadow:0 1rem 3rem rgba(0,0,0,.3);
}
.news-card-img {
  width:100%;
  aspect-ratio:16/10;
  overflow:hidden;
}
.news-card-img img {
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform var(--transition);
}
.news-card:hover .news-card-img img {
  transform:scale(1.05);
}
.news-card-content {
  padding:2rem;
}
.news-card-date {
  font-size:1.2rem;
  color:var(--primary);
  font-weight:600;
  display:flex;
  align-items:center;
  gap:.5rem;
  margin-bottom:1rem;
}
.news-card-content h3 {
  font-size:1.8rem;
  font-weight:600;
  color:var(--white);
  margin-bottom:.8rem;
  line-height:1.3;
}
.news-card-content p {
  font-size:1.3rem;
  color:var(--white-soft);
  line-height:1.5;
}
.news-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:2.4rem;
}
@media(max-width:768px) {
  .news-grid { grid-template-columns:repeat(2, 1fr); }
}
@media(max-width:480px) {
  .news-grid { grid-template-columns:1fr; }
}

/* ===================== CONTACT FORM ===================== */
.btn-primary {
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:.8rem 2rem;
  background:var(--primary);
  color:var(--white);
  font-family:var(--font-head);
  font-size:1.4rem;
  font-weight:600;
  border:none;
  border-radius:3rem;
  cursor:pointer;
  transition:background var(--transition);
}
.btn-primary:hover { background:var(--primary-dark); }
