/*
 * design-upgrade.css — Al Madar UI/UX Migration
 * Applies Kimi Agent design layout/structure while preserving Al Madar brand colors.
 * RULE: New layout + typography + spacing + components | Old brand colors only.
 * Loaded AFTER shared.css so these rules take precedence.
 */

/* ═══════════════════════════════════════════════════════════════
   TYPOGRAPHY UPGRADE — New design uses tighter, bolder type scale
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed:wght@300;400;500;600;700;800;900&family=Open+Sans:wght@300;400;500;600;700&display=swap');

:root {
  /* Tighter spacing scale from new design */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;
  --space-24: 96px;

  /* New design radius tokens */
  --r-xs: 2px;
  --r-sm: 4px;
  --r-md: 8px;
  --r-lg: 12px;
  --r-xl: 16px;
  --r-full: 9999px;

  /* New design easing */
  --ease-smooth: cubic-bezier(0.165, 0.84, 0.44, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Section rhythm from new design */
  --section-py: 96px;
  --section-px: 6%;
}

/* ═══════════════════════════════════════════════════════════════
   GLOBAL BODY — New design is consistently dark, tight tracking
   ═══════════════════════════════════════════════════════════════ */

body {
  letter-spacing: -0.01em;
  -webkit-font-smoothing: antialiased;
}

/* ═══════════════════════════════════════════════════════════════
   TOPBAR — New design: minimal, clean, no topbar on mobile
   Replace current topbar with a sleeker single-line version
   ═══════════════════════════════════════════════════════════════ */

.topbar {
  padding: 8px var(--section-px) !important;
  background: #050505 !important;
  border-bottom: 1px solid rgba(67, 168, 38, 0.15) !important;
}

.topbar-item {
  font-size: 11.5px !important;
  letter-spacing: 0.3px !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,0.65) !important;
  gap: 6px !important;
  transition: color 0.2s var(--ease-smooth) !important;
}

.topbar-item:hover { color: var(--green-light) !important; }
.topbar-hours { font-size: 11px !important; color: rgba(255,255,255,0.45) !important; }
.topbar-svg { width: 12px !important; height: 12px !important; }

/* ═══════════════════════════════════════════════════════════════
   NAV — New design: full-width, glass, larger height, pill CTAs
   ═══════════════════════════════════════════════════════════════ */

nav {
  height: 76px !important;
  padding: 0 var(--section-px) !important;
  background: rgba(15, 15, 15, 0.92) !important;
  backdrop-filter: blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  box-shadow: 0 1px 0 rgba(67,168,38,0.12), 0 8px 32px rgba(0,0,0,0.4) !important;
  transition: background 0.3s ease, box-shadow 0.3s ease !important;
}

nav.scrolled {
  background: rgba(8, 8, 8, 0.97) !important;
  box-shadow: 0 1px 0 rgba(67,168,38,0.2), 0 12px 40px rgba(0,0,0,0.6) !important;
}

/* Nav links — new design style: lighter weight, more spacing */
.nav-links { height: 76px !important; }
.nav-links > li > a {
  height: 76px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0.1px !important;
  color: rgba(255,255,255,0.72) !important;
  padding: 0 16px !important;
  position: relative !important;
  border-bottom: none !important;
}

.nav-links > li > a::after {
  content: '';
  position: absolute;
  bottom: 16px;
  left: 50%;
  width: 0;
  height: 2px;
  background: var(--green);
  border-radius: 999px;
  transition: width 0.3s var(--ease-smooth), left 0.3s var(--ease-smooth);
}

.nav-links > li > a:hover { color: #fff !important; background: none !important; }
.nav-links > li > a:hover::after,
.nav-links > li > a.active::after {
  width: calc(100% - 32px);
  left: 16px;
}

.nav-links > li > a.active {
  color: #fff !important;
  border-bottom: none !important;
  background: none !important;
}

/* Nav CTA buttons — new design uses pill/rounded buttons */
.btn-wa {
  background: var(--wa) !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  padding: 10px 18px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  box-shadow: 0 2px 12px rgba(37,211,102,0.25) !important;
  transition: all 0.25s var(--ease-smooth) !important;
}
.btn-wa:hover {
  background: var(--wa-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 20px rgba(37,211,102,0.4) !important;
}

.btn-quote {
  border: 1px solid rgba(255,255,255,0.2) !important;
  border-radius: var(--r-full) !important;
  padding: 10px 18px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.85) !important;
  background: transparent !important;
  transition: all 0.25s var(--ease-smooth) !important;
}
.btn-quote:hover {
  border-color: rgba(255,255,255,0.5) !important;
  background: rgba(255,255,255,0.06) !important;
  color: #fff !important;
}

/* Dropdown — new design: generous padding, subtle border */
.dropdown {
  border-radius: 0 0 var(--r-lg) var(--r-lg) !important;
  border-top: 2px solid var(--green) !important;
  padding: 8px 0 12px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.05) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  min-width: 360px !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
}

.dropdown a {
  font-size: 12.5px !important;
  padding: 10px 18px !important;
  color: rgba(255,255,255,0.75) !important;
  letter-spacing: 0.1px !important;
  border-left: 2px solid transparent !important;
  border-bottom: 1px solid rgba(255,255,255,0.04) !important;
  transition: all 0.15s ease !important;
  white-space: normal !important;
  line-height: 1.3 !important;
}
.dropdown a:hover, .dropdown a:focus {
  background: rgba(67,168,38,0.1) !important;
  color: var(--green-light) !important;
  border-left-color: var(--green) !important;
  padding-left: 22px !important;
}
.dropdown a.active {
  background: rgba(67,168,38,0.08) !important;
  color: var(--green-light) !important;
  border-left-color: var(--green) !important;
  font-weight: 600 !important;
}

/* Mobile dropdown — single column */
.mob-menu-open .has-dropdown .dropdown,
.mob-menu-open .has-dropdown.dd-open .dropdown {
  display: flex !important;
  flex-direction: column !important;
  grid-template-columns: none !important;
}

/* ═══════════════════════════════════════════════════════════════
   SECTIONS — New design: more generous padding, no alt bg shift
   ═══════════════════════════════════════════════════════════════ */

section {
  padding: var(--section-py) var(--section-px) !important;
}

section.alt {
  background: var(--bg-section) !important;
  padding: var(--section-py) var(--section-px) !important;
}

/* Section headings — new design: all-caps, tighter tracking, bold */
.section-tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 3.5px !important;
  text-transform: uppercase !important;
  color: var(--green) !important;
  margin-bottom: 12px !important;
}

.section-tag::before {
  content: '';
  width: 20px;
  height: 2px;
  background: var(--green);
  border-radius: 999px;
  display: inline-block;
  flex-shrink: 0;
}

.section-title {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: clamp(32px, 4.5vw, 58px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
  line-height: 1.02 !important;
  text-transform: uppercase !important;
  color: var(--text-h) !important;
  margin-bottom: 16px !important;
}

.section-sub {
  font-size: 15px !important;
  line-height: 1.8 !important;
  color: var(--text-grey) !important;
  max-width: 600px !important;
}

.divider {
  width: 48px !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--green), var(--green-light)) !important;
  border-radius: 999px !important;
  margin: 16px 0 40px !important;
}

/* ═══════════════════════════════════════════════════════════════
   HERO — New design: full-viewport, bold headline, overlay grid
   ═══════════════════════════════════════════════════════════════ */

.hero {
  min-height: 100svh !important;
  padding: 0 var(--section-px) !important;
  display: flex !important;
  align-items: center !important;
  position: relative !important;
  overflow: hidden !important;
}

.hero-bg {
  background: linear-gradient(135deg, #080d10 0%, #0f1a20 40%, #131e28 70%, #0a1215 100%) !important;
}

/* Geometric grid overlay — new design aesthetic */
.hero-pattern {
  opacity: 0.025 !important;
  background-image:
    linear-gradient(rgba(67,168,38,0.4) 1px, transparent 1px),
    linear-gradient(90deg, rgba(67,168,38,0.4) 1px, transparent 1px) !important;
  background-size: 64px 64px !important;
}

.hero-bar { display: none !important; }

.hero-content {
  position: relative;
  z-index: 2;
  max-width: 780px !important;
  width: 62% !important;
  padding: 0 !important;
}

/* Hero badge — new design: pill, glass */
.hero-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 7px 16px 7px 12px !important;
  background: rgba(67,168,38,0.1) !important;
  border: 1px solid rgba(67,168,38,0.25) !important;
  border-radius: var(--r-full) !important;
  margin-bottom: 28px !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
}

.hero-badge span {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  color: var(--green-light) !important;
  text-transform: uppercase !important;
}

/* Hero headline — new design: huge, all-caps, editorial */
.hero h1 {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: clamp(48px, 7.5vw, 96px) !important;
  font-weight: 900 !important;
  letter-spacing: -0.04em !important;
  line-height: 0.95 !important;
  text-transform: uppercase !important;
  color: #fff !important;
  margin-bottom: 8px !important;
}

.hero h1 em {
  color: var(--green-light) !important;
  font-style: normal !important;
}

.hero-sub {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.45) !important;
  margin-bottom: 20px !important;
}

.hero-desc {
  font-size: 15px !important;
  line-height: 1.75 !important;
  color: rgba(255,255,255,0.65) !important;
  max-width: 540px !important;
  margin-bottom: 36px !important;
}

/* Hero CTA buttons — pill style from new design */
.hero-btns { gap: 12px !important; }

.hero .btn-wa.btn-lg,
.hero .btn-lg.btn-wa {
  background: var(--green) !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  padding: 14px 28px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  color: #fff !important;
  box-shadow: 0 4px 24px rgba(67,168,38,0.35) !important;
  min-height: 50px !important;
  transition: all 0.25s var(--ease-smooth) !important;
}
.hero .btn-wa.btn-lg:hover {
  background: var(--green-dark) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 32px rgba(67,168,38,0.5) !important;
}

.hero .btn-quote.btn-lg {
  background: transparent !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
  border-radius: var(--r-full) !important;
  padding: 14px 28px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.85) !important;
  min-height: 50px !important;
  transition: all 0.25s var(--ease-smooth) !important;
}
.hero .btn-quote.btn-lg:hover {
  border-color: rgba(255,255,255,0.6) !important;
  background: rgba(255,255,255,0.06) !important;
  color: #fff !important;
}

/* Hero stats — new design: minimal separator line */
.hero-stats {
  margin-top: 48px !important;
  padding-top: 32px !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  gap: 0 !important;
}

.hstat {
  padding: 0 28px !important;
  border-right: 1px solid rgba(255,255,255,0.1) !important;
}
.hstat:first-child { padding-left: 0 !important; }
.hstat:last-child { border-right: none !important; }

.hstat-num {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 40px !important;
  font-weight: 800 !important;
  color: var(--green-light) !important;
  line-height: 1 !important;
  letter-spacing: -0.02em !important;
}

.hstat-label {
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.45) !important;
  margin-top: 6px !important;
}

/* Hero right panel — new design keeps it */
.hero-right {
  background: rgba(0,0,0,0.2) !important;
  border-left: 1px solid rgba(67,168,38,0.1) !important;
}

.hfeature {
  padding: 14px 16px !important;
  border-radius: var(--r-md) !important;
  border: 1px solid rgba(255,255,255,0.05) !important;
  background: rgba(255,255,255,0.03) !important;
  transition: all 0.25s ease !important;
}
.hfeature:hover {
  background: rgba(67,168,38,0.08) !important;
  border-color: rgba(67,168,38,0.2) !important;
  transform: translateX(4px) !important;
}
.hfeature-name { font-size: 13px !important; font-weight: 600 !important; }
.hfeature-sub { font-size: 11px !important; color: rgba(255,255,255,0.4) !important; }

/* ═══════════════════════════════════════════════════════════════
   MARQUEE — New design: tighter, green strip
   ═══════════════════════════════════════════════════════════════ */

.marquee-wrap {
  background: var(--green) !important;
  padding: 12px 0 !important;
}

.marquee-item {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
}

/* ═══════════════════════════════════════════════════════════════
   CTA STRIP — New design: full bleed, bolder
   ═══════════════════════════════════════════════════════════════ */

.cta-strip {
  background: var(--green) !important;
  padding: 40px var(--section-px) !important;
}

.cta-strip h3 {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  text-transform: uppercase !important;
}

.btn-white {
  background: #fff !important;
  color: var(--green-dark) !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  padding: 12px 24px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  transition: all 0.25s var(--ease-smooth) !important;
}
.btn-white:hover {
  background: rgba(255,255,255,0.92) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 20px rgba(0,0,0,0.15) !important;
}

.btn-outline-white {
  background: transparent !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.5) !important;
  border-radius: var(--r-full) !important;
  padding: 12px 24px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  transition: all 0.25s var(--ease-smooth) !important;
}
.btn-outline-white:hover {
  border-color: #fff !important;
  background: rgba(255,255,255,0.1) !important;
}

/* ═══════════════════════════════════════════════════════════════
   SERVICE CARDS — New design: image-first, bold overlay, hover zoom
   ═══════════════════════════════════════════════════════════════ */

.products-grid {
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
  gap: 20px !important;
}

.prod-card {
  background: var(--bg-card) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  overflow: hidden !important;
  transition: transform 0.3s var(--ease-smooth), box-shadow 0.3s var(--ease-smooth), border-color 0.25s ease !important;
  will-change: transform !important;
}

.prod-card:hover {
  transform: translateY(-6px) !important;
  border-color: rgba(67,168,38,0.4) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.25), 0 4px 16px rgba(0,0,0,0.15) !important;
}

.prod-img-wrap {
  aspect-ratio: 16/10 !important;
  border-radius: 0 !important;
  border-bottom: none !important;
  overflow: hidden !important;
  position: relative !important;
}

.prod-img-wrap img {
  transition: transform 0.5s var(--ease-smooth) !important;
}
.prod-card:hover .prod-img-wrap img {
  transform: scale(1.06) !important;
}

/* Gradient overlay on card image for text readability */
.prod-img-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.5) 0%, transparent 60%);
  z-index: 1;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.prod-card:hover .prod-img-wrap::after { opacity: 1; }

.prod-body { padding: 22px 22px 20px !important; }

.prod-name {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 19px !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  color: var(--text-h) !important;
  text-transform: uppercase !important;
  margin-bottom: 8px !important;
}

.prod-desc {
  font-size: 13px !important;
  line-height: 1.7 !important;
  color: var(--text-grey) !important;
  margin-bottom: 14px !important;
}

.spec-tag {
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  padding: 3px 10px !important;
  background: var(--green-pale) !important;
  color: var(--green-text) !important;
  border: 1px solid var(--green-border) !important;
  border-radius: var(--r-full) !important;
}

.pcta {
  border-radius: var(--r-full) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  padding: 9px 16px !important;
}

/* Service chips */
.service-chips { gap: 8px !important; margin-bottom: 32px !important; }
.svc-chip {
  border-radius: var(--r-full) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
  padding: 6px 14px !important;
}
.svc-chip:hover {
  background: var(--green) !important;
  color: #fff !important;
  border-color: var(--green) !important;
}

/* ═══════════════════════════════════════════════════════════════
   ABOUT SECTION — New design: editorial grid layout
   ═══════════════════════════════════════════════════════════════ */

.about-grid {
  gap: 72px !important;
  align-items: start !important;
}

.about-text p {
  font-size: 15px !important;
  line-height: 1.85 !important;
  color: var(--text-grey) !important;
}

.vm-card {
  border-radius: var(--r-md) !important;
  border-left: 3px solid var(--green) !important;
  background: var(--bg-card) !important;
  border: 1px solid var(--border) !important;
  border-left: 3px solid var(--green) !important;
  padding: 20px 22px !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}
.vm-card:hover {
  transform: translateX(4px) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.1) !important;
}

.vm-title {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--green) !important;
  margin-bottom: 8px !important;
}

.about-img {
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
  border: 1px solid var(--border) !important;
  transition: border-color 0.25s ease, box-shadow 0.25s ease !important;
}
.about-img:hover {
  border-color: var(--green-border) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12) !important;
}

/* ═══════════════════════════════════════════════════════════════
   INFRASTRUCTURE STATS — New design: card grid
   ═══════════════════════════════════════════════════════════════ */

.istat {
  border-radius: var(--r-md) !important;
  padding: 24px 22px !important;
  border-left: 3px solid var(--green) !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}
.istat:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12) !important;
}

.istat-num {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 38px !important;
  font-weight: 800 !important;
  color: var(--green) !important;
  letter-spacing: -0.02em !important;
  line-height: 1 !important;
}

.istat-label {
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--text-grey) !important;
  margin-top: 8px !important;
}

.infra-point {
  border-radius: var(--r-md) !important;
  padding: 18px 20px !important;
  transition: transform 0.25s ease !important;
}
.infra-point:hover { transform: translateX(4px) !important; }

.infra-icon {
  background: var(--green-pale) !important;
  border-radius: var(--r-sm) !important;
  width: 44px !important;
  height: 44px !important;
}

/* ═══════════════════════════════════════════════════════════════
   GALLERY — New design: tight grid, full overlay on hover
   ═══════════════════════════════════════════════════════════════ */

.gallery-grid {
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
  gap: 8px !important;
}

.gal-item {
  border-radius: var(--r-sm) !important;
  overflow: hidden !important;
  border: none !important;
  transition: transform 0.3s var(--ease-smooth) !important;
}
.gal-item:hover {
  transform: scale(1.02) !important;
  z-index: 2 !important;
  position: relative !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.4) !important;
}

.gal-overlay {
  background: linear-gradient(to top, rgba(0,0,0,0.75) 0%, rgba(67,168,38,0.3) 60%, transparent 100%) !important;
}

/* ═══════════════════════════════════════════════════════════════
   TESTIMONIALS — New design: clean card, star rating
   ═══════════════════════════════════════════════════════════════ */

.testi-card {
  border-radius: var(--r-lg) !important;
  padding: 28px !important;
  border: 1px solid var(--border) !important;
  background: var(--bg-card) !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}
.testi-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 16px 48px rgba(0,0,0,0.15) !important;
  border-color: var(--green-border) !important;
}

.stars { color: var(--green) !important; letter-spacing: 3px !important; }

/* ═══════════════════════════════════════════════════════════════
   CONTACT FORM — New design: clean inputs, green accent
   ═══════════════════════════════════════════════════════════════ */

.fg input, .fg textarea, .fg select {
  border-radius: var(--r-sm) !important;
  border: 1px solid var(--border-dark) !important;
  border-left: 3px solid var(--green) !important;
  background: var(--bg-input) !important;
  font-size: 14px !important;
  padding: 12px 15px !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}
.fg input:focus, .fg textarea:focus, .fg select:focus {
  border-color: var(--green) !important;
  box-shadow: 0 0 0 3px rgba(67,168,38,0.1) !important;
}

.form-submit {
  background: var(--green) !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  padding: 14px 36px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(67,168,38,0.25) !important;
  transition: all 0.25s ease !important;
}
.form-submit:hover {
  background: var(--green-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 8px 24px rgba(67,168,38,0.4) !important;
}

/* Contact info items */
.contact-item {
  border-radius: var(--r-md) !important;
  border: 1px solid var(--border) !important;
  background: var(--bg-card) !important;
  padding: 16px 18px !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}
.contact-item:hover {
  border-color: var(--green-border) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08) !important;
}

.c-icon {
  background: var(--green-pale) !important;
  border-radius: var(--r-sm) !important;
}

/* ═══════════════════════════════════════════════════════════════
   PRICING CARDS — New design: featured card treatment
   ═══════════════════════════════════════════════════════════════ */

.price-card {
  border-radius: var(--r-lg) !important;
  border: 1px solid var(--border) !important;
  padding: 28px !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease !important;
}
.price-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.2) !important;
  border-color: var(--green-border) !important;
}
.price-card.featured {
  border-color: var(--green) !important;
  box-shadow: 0 8px 32px rgba(67,168,38,0.15) !important;
}

.price-plan {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: var(--green) !important;
}

/* ═══════════════════════════════════════════════════════════════
   FAQ SECTION — New design: accordion with green accent
   ═══════════════════════════════════════════════════════════════ */

details.faq-item {
  border-radius: 0 var(--r-sm) var(--r-sm) 0 !important;
  border-left-width: 3px !important;
}

details.faq-item summary {
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 18px 20px !important;
}

/* ═══════════════════════════════════════════════════════════════
   FOOTER — New design: clean, dark, generous spacing
   ═══════════════════════════════════════════════════════════════ */

footer {
  background: var(--footer-bg) !important;
  border-top: 1px solid rgba(255,255,255,0.06) !important;
}

.footer-main {
  padding: 72px var(--section-px) 48px !important;
}

.footer-name {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  letter-spacing: 0.3px !important;
  color: #fff !important;
}

.footer-sub {
  font-size: 10px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.4) !important;
  display: block !important;
  margin-top: 3px !important;
  margin-bottom: 16px !important;
}

.footer-desc {
  font-size: 13px !important;
  line-height: 1.8 !important;
  color: rgba(255,255,255,0.6) !important;
  max-width: 340px !important;
}

.footer-col h4 {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.85) !important;
  margin-bottom: 20px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}

.footer-links a {
  font-size: 13px !important;
  color: rgba(255,255,255,0.62) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 5px 0 !important;
  transition: color 0.2s ease, padding-left 0.2s ease !important;
}
.footer-links a::before { color: var(--green-light) !important; }
.footer-links a:hover { color: #fff !important; padding-left: 4px !important; }

.soc-btn {
  width: 38px !important;
  height: 38px !important;
  border-radius: var(--r-sm) !important;
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  color: rgba(255,255,255,0.65) !important;
  transition: all 0.2s ease !important;
}
.soc-btn:hover {
  background: rgba(67,168,38,0.15) !important;
  border-color: var(--green-border) !important;
  color: var(--green-light) !important;
  transform: translateY(-2px) !important;
}

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.06) !important;
  padding: 20px var(--section-px) !important;
  background: rgba(0,0,0,0.3) !important;
}

.footer-cat {
  border-radius: var(--r-full) !important;
  padding: 8px 18px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  background: var(--green) !important;
  color: #fff !important;
  border: none !important;
}
.footer-cat:hover { background: var(--green-dark) !important; }

/* ═══════════════════════════════════════════════════════════════
   WHATSAPP FAB — New design: branded, floating, always visible
   ═══════════════════════════════════════════════════════════════ */

.wa-fab {
  width: 60px !important;
  height: 60px !important;
  border-radius: 50% !important;
  background: #25D366 !important;
  box-shadow: 0 4px 24px rgba(37,211,102,0.45) !important;
  transition: all 0.25s var(--ease-smooth) !important;
}
.wa-fab:hover {
  background: #128C7E !important;
  transform: scale(1.1) !important;
  box-shadow: 0 8px 32px rgba(37,211,102,0.55) !important;
}

/* ═══════════════════════════════════════════════════════════════
   SERVICE PAGES — New design: full-bleed hero, clean layout
   ═══════════════════════════════════════════════════════════════ */

.svc-hero {
  padding: 72px var(--section-px) 60px !important;
  background: var(--bg-section) !important;
}

.svc-hero-text h1 {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: clamp(30px, 5vw, 54px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
  text-transform: uppercase !important;
  line-height: 1.0 !important;
}

.svc-hero-img {
  border-radius: var(--r-lg) !important;
  overflow: hidden !important;
  border: 1px solid var(--border) !important;
}

.btn-svc-wa {
  background: var(--wa) !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  padding: 14px 28px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.6px !important;
  text-transform: uppercase !important;
  box-shadow: 0 4px 16px rgba(37,211,102,0.25) !important;
  transition: all 0.25s ease !important;
}
.btn-svc-wa:hover {
  background: var(--wa-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 8px 24px rgba(37,211,102,0.4) !important;
}

.btn-svc-call {
  background: transparent !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
  border-radius: var(--r-full) !important;
  padding: 13px 26px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  color: var(--text-h) !important;
  transition: all 0.25s ease !important;
}
.btn-svc-call:hover {
  border-color: var(--green-border) !important;
  color: var(--green) !important;
  background: var(--green-pale) !important;
}

details.svc-faq {
  border-radius: 0 var(--r-sm) var(--r-sm) 0 !important;
}
details.svc-faq summary { font-size: 14px !important; font-weight: 600 !important; }

.related-card {
  border-radius: var(--r-md) !important;
  padding: 22px !important;
  border: 1px solid var(--border) !important;
  background: var(--bg-card) !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease !important;
}
.related-card:hover {
  transform: translateY(-3px) !important;
  border-color: var(--green-border) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.1) !important;
}

.cta-band {
  background: var(--green) !important;
  padding: 60px var(--section-px) !important;
  text-align: center !important;
}

.cta-band h2 {
  font-family: 'Roboto Condensed', sans-serif !important;
  font-size: clamp(26px, 4vw, 42px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  text-transform: uppercase !important;
}

/* ═══════════════════════════════════════════════════════════════
   SCROLL REVEAL — New design: smoother, staggered
   ═══════════════════════════════════════════════════════════════ */

.reveal {
  opacity: 0 !important;
  transform: translateY(24px) !important;
  transition: opacity 0.7s var(--ease-smooth), transform 0.7s var(--ease-smooth) !important;
}
.reveal.visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* ═══════════════════════════════════════════════════════════════
   CATALOGUE BUTTON — pill version
   ═══════════════════════════════════════════════════════════════ */

.btn-catalogue {
  border-radius: var(--r-full) !important;
  font-family: 'Roboto Condensed', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  padding: 14px 32px !important;
  background: var(--green) !important;
  box-shadow: 0 4px 20px rgba(67,168,38,0.3) !important;
  transition: all 0.25s ease !important;
}
.btn-catalogue:hover {
  background: var(--green-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 8px 28px rgba(67,168,38,0.45) !important;
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — New design mobile rules
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 900px) {
  :root {
    --section-py: 72px;
    --section-px: 5%;
  }

  .hero { min-height: auto !important; padding: 80px var(--section-px) 60px !important; }
  .hero-content { width: 100% !important; max-width: 100% !important; }
  .hero-right { display: none !important; }
  .hero h1 { font-size: clamp(38px, 9vw, 64px) !important; }

  .mob-menu-open .nav-links {
    background: #0a0a0a !important;
    border-bottom: 2px solid var(--green) !important;
  }

  /* Mobile nav links — new design: taller items */
  .mob-menu-open .nav-links > li > a {
    height: 56px !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    padding: 0 24px !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  }
}

@media (max-width: 768px) {
  :root {
    --section-py: 60px;
    --section-px: 5%;
  }

  .hero { padding: 60px var(--section-px) 48px !important; }
  .hero h1 { font-size: clamp(36px, 11vw, 54px) !important; line-height: 0.96 !important; }
  .hstat-num { font-size: 28px !important; }

  .products-grid { grid-template-columns: 1fr !important; }

  nav { height: 64px !important; }
  .nav-links { height: 64px !important; }
}

@media (max-width: 480px) {
  :root {
    --section-py: 48px;
    --section-px: 4%;
  }

  nav { height: 58px !important; }

  .hero h1 { font-size: clamp(32px, 10vw, 48px) !important; }
  .hero-btns { flex-direction: column !important; align-items: stretch !important; }
  .hero-btns a, .hero-btns button { width: 100% !important; justify-content: center !important; }

  .hero-stats { gap: 0 !important; flex-wrap: wrap !important; }
  .hstat { flex: 1 1 50% !important; padding: 10px 8px !important; border-right: none !important; text-align: center !important; }
  .hstat-num { font-size: 24px !important; }
  .hstat-label { font-size: 9px !important; }

  .cta-strip { flex-direction: column !important; text-align: center !important; padding: 36px 16px !important; }
  .cta-btns { flex-direction: column !important; width: 100% !important; }
  .cta-btns a { width: 100% !important; }

  .footer-main { padding: 48px var(--section-px) 32px !important; }

  .dropdown { display: flex !important; flex-direction: column !important; grid-template-columns: none !important; }
}

/* ═══════════════════════════════════════════════════════════════
   ADMIN PAGES — Preserve admin UI from design changes
   ═══════════════════════════════════════════════════════════════ */

/* Admin pages don't use these classes in the same way — safe */

/* ═══════════════════════════════════════════════════════════════
   DARK THEME ADJUSTMENTS — New design works on both themes
   ═══════════════════════════════════════════════════════════════ */

[data-theme="dark"] .prod-card { background: var(--bg-card) !important; }
[data-theme="dark"] .testi-card { background: var(--bg-card) !important; }
[data-theme="dark"] .price-card { background: var(--bg-card) !important; }
[data-theme="dark"] .vm-card { background: var(--bg-card) !important; }
[data-theme="dark"] .contact-item { background: var(--bg-card) !important; }
[data-theme="dark"] .istat { background: var(--bg-card) !important; }
[data-theme="dark"] .infra-point { background: var(--bg-card) !important; }
[data-theme="dark"] .related-card { background: var(--bg-card) !important; }

[data-theme="light"] .btn-svc-call {
  border-color: rgba(0,0,0,0.15) !important;
  color: var(--text-h) !important;
}

/* ═══════════════════════════════════════════════════════════════
   PREFERS REDUCED MOTION — Respect user preference
   ═══════════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
  .prod-card, .testi-card, .price-card, .vm-card,
  .gal-item, .istat, .infra-point, .related-card,
  .hfeature, .soc-btn, .btn-wa, .btn-quote,
  .btn-svc-wa, .btn-svc-call, .form-submit,
  .wa-fab, .chat-bubble {
    transition: none !important;
    animation: none !important;
  }
  .reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}
