:root{
  --blue: #0b5fa8;
  --blue2:#1aa7ff;
  --green:#2bd576;
  --orange:#ff8a34;
  --purple:#8b5cf6;

  --shadow: 0 18px 55px rgba(0,0,0,0.18);
  --radius: 18px;
  --radius2: 26px;
  --container: 1120px;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: #0b1220;
  background: #ffffff;
  overflow-x: hidden;
}
.container{ width: min(var(--container), calc(100% - 40px)); margin-inline: auto; }
.muted{ color: rgba(15, 23, 42, 0.72); }
.small{ font-size: 13px; }
.section{ padding: 96px 0; }
.section-alt{ background: linear-gradient(180deg, rgba(11,99,255,0.05), rgba(11,99,255,0.02)); }

/* Preloader */
.preloader{
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: radial-gradient(800px 400px at 20% 20%, rgba(11,95,168,0.10), transparent 60%),
              radial-gradient(800px 400px at 80% 20%, rgba(26,167,255,0.12), transparent 60%),
              #ffffff;
  display: grid;
  place-items: center;
  transition: opacity 300ms ease, visibility 300ms ease;
}
.preloader.hide{ opacity: 0; visibility: hidden; }
.preloader-card{
  width: min(460px, calc(100% - 32px));
  border: 1px solid rgba(15,23,42,0.10);
  border-radius: 26px;
  padding: 22px;
  background: rgba(255,255,255,0.88);
  box-shadow: 0 30px 90px rgba(0,0,0,0.12);
  text-align: center;
}
.preloader-logo{
  width: 82px; height: 82px;
  border-radius: 22px;
  border: 1px solid rgba(15,23,42,0.12);
  object-fit: cover;
}
.preloader-title{ font-weight: 800; margin-top: 10px; }
.preloader-sub{ font-size: 12px; color: rgba(15,23,42,0.68); margin-top: 2px; }
.spinner{
  width: 34px; height: 34px;
  margin: 14px auto 0;
  border-radius: 999px;
  border: 3px solid rgba(11,95,168,0.18);
  border-top-color: rgba(11,95,168,0.9);
  animation: spin 0.9s linear infinite;
}
@keyframes spin{ to { transform: rotate(360deg);} }

/* Progress */
.progress{
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  width: 0%;
  background: linear-gradient(90deg, var(--blue), var(--blue2));
  z-index: 9999;
}

/* Header */
.site-header{
  position: sticky;
  top: 0;
  z-index: 1200;
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}
.nav-wrap{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  text-decoration:none;
  color: #0b1220;
}
.brand-mark{
  width: 44px; height: 44px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: white;
  border: 1px solid rgba(15,23,42,0.10);
  box-shadow: 0 12px 26px rgba(0,0,0,0.06);
  overflow: hidden;
}
.brand-logo{ width:100%; height:100%; object-fit: cover; }
.brand-text strong{ display:block; }
.brand-text small{
  display:block;
  font-size: 11px;
  color: rgba(15, 23, 42, 0.62);
  margin-top: -2px;
}

/* Nav */
.nav{ display:flex; align-items:center; gap: 14px; }
.nav a{
  text-decoration:none;
  color: rgba(15, 23, 42, 0.82);
  font-weight: 700;
  font-size: 14px;
  padding: 8px 10px;
  border-radius: 12px;
  transition: background 180ms ease;
}
.nav a:hover{ background: rgba(11, 99, 255, 0.08); }

.nav-toggle{
  display:none;
  width: 44px; height: 40px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: white;
  border-radius: 14px;
  cursor: pointer;
  box-shadow: 0 10px 25px rgba(0,0,0,0.05);
}
.nav-toggle span{
  display:block;
  width: 18px; height: 2px;
  background: rgba(15,23,42,0.82);
  margin: 4px auto;
  border-radius: 2px;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  border-radius: 14px;
  padding: 12px 16px;
  border: 1px solid transparent;
  text-decoration:none;
  font-weight: 800;
  cursor: pointer;
  transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease, border-color 160ms ease;
  user-select: none;
}
.btn:active{ transform: translateY(1px); }
.btn-small{ padding: 10px 12px; border-radius: 12px; font-size: 14px; }

.btn-primary{
  color:white;
  background: linear-gradient(135deg, var(--blue), var(--blue2));
  box-shadow: 0 16px 35px rgba(11, 99, 255, 0.22);
}
.btn-primary:hover{ box-shadow: 0 18px 45px rgba(11, 99, 255, 0.28); transform: translateY(-1px); }

.btn-secondary{
  color: #071023;
  background: linear-gradient(135deg, rgba(255,255,255,0.95), rgba(255,255,255,0.78));
  border-color: rgba(15,23,42,0.12);
  box-shadow: 0 16px 35px rgba(0,0,0,0.10);
}
.btn-secondary:hover{ transform: translateY(-1px); box-shadow: 0 18px 45px rgba(0,0,0,0.14); }

.btn-outline{
  background: transparent;
  border-color: rgba(15,23,42,0.14);
  color: rgba(15,23,42,0.9);
}
.btn-outline:hover{ transform: translateY(-1px); border-color: rgba(11,99,255,0.32); background: rgba(11,99,255,0.06); }

.btn-ghost{
  color: rgba(15, 23, 42, 0.92);
  background: rgba(255,255,255,0.78);
  border-color: rgba(15,23,42,0.12);
}
.btn-ghost:hover{ transform: translateY(-1px); background: rgba(11,99,255,0.06); }

/* Hero */
.hero{ position: relative; padding: 78px 0 0; overflow:hidden; }
.hero-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(1200px 500px at 20% 0%, rgba(11,99,255,0.18), transparent 55%),
    radial-gradient(900px 420px at 90% 10%, rgba(26,167,255,0.16), transparent 55%),
    radial-gradient(900px 500px at 50% 110%, rgba(43,213,118,0.10), transparent 60%);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 28px;
  align-items: start;
  padding-bottom: 46px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(11,99,255,0.16);
  background: rgba(255,255,255,0.72);
  box-shadow: 0 20px 60px rgba(0,0,0,0.06);
  font-weight: 800;
  color: rgba(15,23,42,0.82);
  font-size: 13px;
}
.hero-copy h1{
  margin: 14px 0 10px;
  font-size: clamp(32px, 4.1vw, 54px);
  line-height: 1.05;
  letter-spacing: -0.6px;
}
.hero-copy p{ margin: 0 0 18px; max-width: 70ch; color: rgba(15,23,42,0.74); }
.accent{
  background: linear-gradient(135deg, var(--blue), var(--blue2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero-cta{ display:flex; flex-wrap: wrap; gap: 12px; margin-bottom: 14px; }

.trust-row{ display:flex; gap: 10px; flex-wrap: wrap; margin-top: 10px; }
.trust{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(15,23,42,0.08);
  box-shadow: 0 16px 40px rgba(0,0,0,0.05);
  font-weight: 800;
  font-size: 13px;
}
.trust i{ color: rgba(11,99,255,0.92); }

.hero-card-inner{
  background: rgba(255,255,255,0.84);
  border: 1px solid rgba(15,23,42,0.10);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  padding: 18px 18px 14px;
  overflow:hidden;
}
.hero-card-inner h3{ margin: 6px 0 10px; }
.features{
  list-style:none;
  padding:0;
  margin:0 0 14px;
  display:grid;
  gap: 10px;
}
.features li{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  color: rgba(15,23,42,0.76);
}
.features i{ margin-top: 2px; color: rgba(11,99,255,0.95); }
.mini-cta{ display:flex; gap: 12px; flex-wrap: wrap; }

.hero-wave, .hero-bottom-wave, .why-bottom-wave { pointer-events:none; }
.hero-wave{
  position:absolute; left:0; right:0; bottom:-1px;
  height:84px; opacity:0.65;
}
.hero-wave svg{ width:100%; height:100%; }
.hero-wave path{ fill: rgba(11,99,255,0.18); }

.hero-bottom-wave{ height:100px; }
.hero-bottom-wave svg{ width:100%; height:100%; }
.hero-bottom-wave path{ fill: rgba(11,99,255,0.06); }

/* Section head */
.section-head{ margin-bottom: 30px; }
.section-head h2{
  margin: 10px 0 8px;
  font-size: clamp(24px, 3.2vw, 38px);
  line-height: 1.12;
}
.section-head p{ margin:0; max-width: 72ch; }

.section-label{
  display:inline-flex;
  align-items:center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(11,99,255,0.10);
  color: rgba(15,23,42,0.85);
  font-weight: 900;
  letter-spacing: 0.8px;
  font-size: 12px;
}
.section-label.light{ background: rgba(255,255,255,0.12); color: rgba(255,255,255,0.92); }
.diamond{
  width: 10px; height: 10px;
  transform: rotate(45deg);
  background: linear-gradient(135deg, var(--blue), var(--blue2));
  border-radius: 2px;
}

/* Services */
.services-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.service-card{
  background: white;
  border: 1px solid rgba(15,23,42,0.08);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: 0 18px 50px rgba(0,0,0,0.05);
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.service-card:hover{
  transform: translateY(-3px);
  border-color: rgba(11,99,255,0.18);
  box-shadow: 0 20px 60px rgba(0,0,0,0.08);
}
.service-card h3{ margin: 12px 0 8px; }
.service-card p{ margin:0 0 12px; color: rgba(15,23,42,0.72); }
.card-link{
  display:inline-flex; align-items:center; gap:10px;
  font-weight: 900;
  color: rgba(11,99,255,0.95);
  text-decoration: none;
}
.link-btn{ background: transparent; border: 0; padding: 0; cursor:pointer; font: inherit; }

.icon{
  width: 46px; height: 46px;
  border-radius: 16px;
  display:grid; place-items:center;
  box-shadow: 0 16px 30px rgba(0,0,0,0.10);
  border: 1px solid rgba(255,255,255,0.55);
}
.icon-blue{ background: linear-gradient(135deg, var(--blue), var(--blue2)); color: white; }
.icon-green{ background: linear-gradient(135deg, var(--green), #9af3be); color: #052012; }
.icon-orange{ background: linear-gradient(135deg, var(--orange), #ffd2ad); color: #2a1203; }
.icon-purple{ background: linear-gradient(135deg, var(--purple), #dacbff); color: #190b32; }
.icon-light{ background: rgba(255,255,255,0.14); border-color: rgba(255,255,255,0.22); color: white; box-shadow: none; }

/* Plants */
.two-col{ display:grid; grid-template-columns: 1.2fr 0.8fr; gap: 18px; align-items:start; }
.plant-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 14px; }
.plant-card{
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(15,23,42,0.08);
  border-radius: var(--radius);
  padding: 14px;
  box-shadow: 0 18px 45px rgba(0,0,0,0.06);
}
.plant-top{ display:flex; align-items:flex-start; gap: 10px; }
.plant-card h3{ margin:0; font-size: 15px; }
.plant-card p{ margin: 10px 0 0; color: rgba(15,23,42,0.72); font-size: 13.5px; }

.tag{
  font-weight: 900; font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,0.12);
  background: rgba(255,255,255,0.95);
}
.tag-blue{ color: rgba(11,99,255,0.95); }
.tag-orange{ color: rgba(235,110,15,0.95); }
.tag-green{ color: rgba(35,150,95,0.95); }
.tag-purple{ color: rgba(122,70,245,0.95); }

.visual-card{
  background: rgba(255,255,255,0.94);
  border: 1px solid rgba(15,23,42,0.10);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.visual-header{
  padding: 14px 16px;
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid rgba(15,23,42,0.08);
}

.plant-visual{
  height: 245px;
  background:
    radial-gradient(120px 120px at 25% 35%, rgba(26,167,255,0.35), transparent 60%),
    radial-gradient(140px 140px at 70% 30%, rgba(11,99,255,0.30), transparent 60%),
    linear-gradient(135deg, rgba(7,11,24,0.92), rgba(12,20,48,0.92));
  background-size: cover;
  background-position: center;
  position: relative;

  /* Transition (zoom + fade) */
  opacity: 1;
  transform: scale(1);
  transition: opacity 220ms ease, transform 520ms cubic-bezier(.2,.8,.2,1);
  will-change: opacity, transform;
}
.plant-visual.is-switching{
  opacity: 0;
  transform: scale(1.03);
}
.plant-visual::after{
  content:"";
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 26px 26px;
  opacity: 0.35;
}

.chips{ display:flex; gap: 10px; flex-wrap: wrap; padding: 12px 16px 10px; }
.chip{
  border: 1px solid rgba(15,23,42,0.12);
  background: rgba(255,255,255,0.86);
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 900;
  cursor:pointer;
}
.chip.active{
  color: white;
  background: linear-gradient(135deg, var(--blue), var(--blue2));
  border-color: transparent;
}
.chip-text{ margin:0; padding: 0 16px 12px; color: rgba(15,23,42,0.72); }
.visual-actions{ padding: 0 16px 16px; display:flex; gap: 10px; flex-wrap: wrap; }

/* Why */
.why{
  position: relative;
  background: linear-gradient(135deg, #071024, #0c2b66);
  color: white;
  overflow:hidden;
}
.why-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(800px 380px at 20% 0%, rgba(26,167,255,0.22), transparent 60%),
    radial-gradient(700px 380px at 85% 20%, rgba(11,99,255,0.26), transparent 60%),
    radial-gradient(700px 380px at 50% 120%, rgba(43,213,118,0.10), transparent 60%);
  pointer-events:none;
}
.why-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.why-card{
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: var(--radius2);
  padding: 18px;
  backdrop-filter: blur(8px);
}
.why-card h3{ margin: 12px 0 0; font-size: 16px; }
.muted.lightish{ color: rgba(255,255,255,0.78); }
.light{ color: white; }
.why-bottom-wave{ height: 100px; margin-top: 40px; }
.why-bottom-wave svg{ width:100%; height:100%; }
.why-bottom-wave path{ fill: rgba(255,255,255,0.06); }

/* Contact */
.contact-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.contact-card, .location-card{
  background: white;
  border: 1px solid rgba(15,23,42,0.08);
  border-radius: var(--radius2);
  padding: 18px;
  box-shadow: 0 18px 50px rgba(0,0,0,0.05);
}
.contact-actions{ display:flex; flex-wrap: wrap; gap: 10px; margin: 12px 0 14px; }

.contact-row{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,0.08);
  background: rgba(11,99,255,0.04);
}
.contact-row-left{ display:flex; align-items:flex-start; gap: 12px; }
.contact-row .label{ font-size: 12px; color: rgba(15,23,42,0.62); font-weight: 800; }
.contact-row .value{ font-weight: 900; color: rgba(11,99,255,0.95); text-decoration:none; }
.contact-row .value:hover{ text-decoration: underline; }
.copy-btn{
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,0.10);
  background: rgba(255,255,255,0.9);
  cursor:pointer;
}
.copy-btn:hover{ background: rgba(11,99,255,0.06); border-color: rgba(11,99,255,0.22); }

.divider{ height:1px; background: rgba(15,23,42,0.08); margin: 14px 0; }
.form{ display:grid; gap: 12px; }
.field label{ display:block; font-weight: 900; font-size: 13px; margin-bottom: 6px; }
.field input, .field select, .field textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,0.12);
  padding: 12px 12px;
  font: inherit;
  outline:none;
  background: rgba(255,255,255,0.95);
  transition: border-color 160ms ease, box-shadow 160ms ease;
}

/* Make <select> consistent across browsers */
.field select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;

  padding-right: 44px; /* space for arrow */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%230b5fa8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 18px 18px;
}

/* Prevent some older browsers from adding extra UI */
.field select::-ms-expand{
  display: none;
}
.field, .form, .contact-card{
  min-width: 0;
}
.field input, .field select, .field textarea{
  max-width: 100%;
}



.field input:focus, .field select:focus, .field textarea:focus{
  border-color: rgba(11,99,255,0.35);
  box-shadow: 0 0 0 4px rgba(11,99,255,0.10);
}

.map-embed{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(15,23,42,0.10);
  height: 320px;
}
.map-embed iframe{
  width: 100%;
  height: 100%;
  border: 0;
}
.map-actions{ display:flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }

/* Footer */
.footer{ padding: 26px 0; border-top: 1px solid rgba(15,23,42,0.06); }
.footer-row{ display:flex; justify-content: space-between; align-items:center; gap: 14px; flex-wrap: wrap; }
.foot-social{ display:flex; gap: 10px; }
.soc{
  width: 40px; height: 40px;
  display:grid; place-items:center;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,0.10);
  color: rgba(15,23,42,0.82);
  text-decoration:none;
  background: rgba(255,255,255,0.85);
}
.soc:hover{ border-color: rgba(11,99,255,0.28); background: rgba(11,99,255,0.06); }

/* Modal (desktop center + mobile bottom-sheet) */
.modal{ position: fixed; inset:0; display:none; z-index: 5000; }
.modal.show{ display:block; }
.modal-backdrop{ position:absolute; inset:0; background: rgba(2,6,23,0.64); }

.modal-panel{
  position: relative;
  width: min(980px, calc(100% - 32px));
  margin: 6vh auto 0;
  background: white;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.2);
  box-shadow: 0 35px 120px rgba(0,0,0,0.35);
  max-height: 90vh;
  overflow: auto;
}
.modal-top{
  position: sticky;
  top:0;
  background: white;
  padding: 12px 12px 0;
  z-index: 2;
}
.modal-close{
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,0.10);
  background: rgba(255,255,255,0.92);
  cursor:pointer;
  margin-left:auto;
  display:block;
}
.modal-content{ padding: 10px 18px 18px; }
.modal-content h3{ margin: 0 0 8px; }
.modal-content p{ margin: 0 0 10px; color: rgba(15,23,42,0.74); }

.brochure-img{
  width: 100%;
  height: auto;
  max-height: 75vh;
  object-fit: contain;
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,0.10);
  display:block;
}

.qe-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 12px;
}
.qe-card{
  border: 1px solid rgba(15,23,42,0.10);
  border-radius: 18px;
  padding: 14px;
  background: rgba(11,99,255,0.04);
}
.qe-card strong{ display:block; }
.qe-card p{ margin: 6px 0 10px; color: rgba(15,23,42,0.70); font-size: 13px; }
.qe-card .btn{ width: 100%; }

@media (max-width: 700px){
  .modal-panel{
    position: absolute;
    left: 0; right: 0; bottom: 0;
    width: 100%;
    margin: 0;
    border-radius: 22px 22px 0 0;
    max-height: 88vh;
    animation: sheetUp 180ms ease;
  }
  @keyframes sheetUp{
    from { transform: translateY(12px); opacity: 0.98; }
    to { transform: translateY(0); opacity: 1; }
  }
  .qe-grid{ grid-template-columns: 1fr; }
}

/* Toast */
.toast{
  position: fixed;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(15,23,42,0.92);
  color: white;
  padding: 12px 14px;
  border-radius: 14px;
  box-shadow: 0 20px 70px rgba(0,0,0,0.25);
  opacity: 0;
  pointer-events:none;
  transition: opacity 180ms ease, transform 180ms ease;
  z-index: 6000;
}
.toast.show{ opacity: 1; transform: translateX(-50%) translateY(-2px); }

/* Reveal */
.reveal{ opacity: 0; transform: translateY(14px); }
.reveal.in{
  opacity: 1;
  transform: translateY(0);
  transition: opacity 650ms ease, transform 650ms ease;
}

/* Floating Contact FAB */
.fab{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 4000;
}
.fab-main{
  width: 56px;
  height: 56px;
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,0.12);
  background: linear-gradient(135deg, var(--blue), var(--blue2));
  color: white;
  cursor: pointer;
  box-shadow: 0 20px 70px rgba(11,99,255,0.25);
}
.fab-menu{
  position: absolute;
  right: 0;
  bottom: 66px;
  width: 220px;
  display: none;
  flex-direction: column;
  gap: 10px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(15,23,42,0.10);
  box-shadow: 0 25px 80px rgba(0,0,0,0.14);
  backdrop-filter: blur(10px);
}
.fab-menu.show{ display:flex; }

/* Consistent typography for FAB items */
.fab-item{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,0.10);
  background: white;
  text-decoration:none;
  color: rgba(15,23,42,0.86);
  font-weight: 800;
  font-size: 14px;
  line-height: 1.1;
  cursor: pointer;
  width: 100%;
}
.fab-item i{ width: 18px; text-align:center; font-size: 15px; }
button.fab-item{ font-family: inherit; }
.fab-item:hover{ border-color: rgba(11,99,255,0.24); background: rgba(11,99,255,0.05); }

/* Floating Back to Top */
.to-top{
  position: fixed;
  right: 18px;
  bottom: 88px;
  width: 48px;
  height: 48px;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,0.12);
  background: rgba(255,255,255,0.92);
  box-shadow: 0 18px 60px rgba(0,0,0,0.12);
  cursor:pointer;
  opacity: 0;
  pointer-events: none;
  transform: translateY(6px);
  transition: opacity 180ms ease, transform 180ms ease;
  z-index: 4000;
}
.to-top.show{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .services-grid{ grid-template-columns: repeat(2, 1fr); }
  .two-col{ grid-template-columns: 1fr; }
  .why-grid{ grid-template-columns: repeat(2, 1fr); }
  .contact-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 760px){
  .nav-toggle{ display:block; }
  .nav{
    position: fixed;
    top: 70px;
    right: 14px; left: 14px;
    padding: 12px;
    border-radius: 18px;
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(15,23,42,0.10);
    box-shadow: 0 25px 80px rgba(0,0,0,0.12);
    display:none;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    z-index: 1500;
  }
  .nav.show{ display:flex; }
  .nav a{ padding: 12px 12px; }
  .services-grid{ grid-template-columns: 1fr; }
  .plant-grid{ grid-template-columns: 1fr; }
}
/* Show full plant images on small screens (no cropping) */
@media (max-width: 560px){
  .plant-visual{
    height: 210px;                 /* slightly smaller on phones */
    background-size: contain;      /* show full image */
    background-repeat: no-repeat;
    background-position: center;
    background-color: #f7fbff;     /* fills empty space nicely */
  }

  /* Optional: reduce overlay grid so it doesn't distract on small screens */
  .plant-visual::after{
    opacity: 0.18;
  }
}