/* === COLOR VARIABLES === */
:root{
  --bg-deep:#031c14;
  --dark-green:#004e35;
  --bright-green:#63ff6b;
  --bright-green-2:#b3ff84;
  --light-green:#d7ffd0;
  --text:#eaffea;
}

/* === RESET === */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  font-family:"Lato", Arial, sans-serif;
  color:var(--text);
  background:radial-gradient(1200px 700px at 50% -200px,#0b3325 0%,var(--bg-deep) 60%,#00120c 100%);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* === HERO SECTION === */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-between;
  padding:20px clamp(16px,3vw,28px);
  overflow:hidden;
}
.looper-bg{
  position:absolute;
  left:50%;
  bottom:-8%;
  transform:translateX(-50%);
  width:160%;
  max-width:none;
  height:auto;
  object-fit:cover;
  filter:drop-shadow(0 40px 60px rgba(0,0,0,.55));
  opacity:.95;
  z-index:1;
  pointer-events:none;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:radial-gradient(60% 55% at 50% 18%,rgba(0,0,0,0) 0%,rgba(0,0,0,.35) 55%,rgba(0,0,0,.75) 100%);
  z-index:2;
}
.hero::after{
  content:"";
  position:absolute;
  left:50%; top:24%;
  transform:translateX(-50%);
  width:min(1100px,82vw);
  height:44%;
  background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:14px 14px;
  opacity:.35;
  z-index:2;
  pointer-events:none;
}

/* === NAVBAR === */
.navbar{
  width:100%;
  max-width:1200px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  z-index:3;
}
.logo img{
  height:22px;
  width:auto;
  display:block;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.45));
}
.nav-menu{
  display:flex;
  gap:1.2rem;
  align-items:center;
  padding:10px 16px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--bright-green),var(--bright-green-2));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 10px 24px rgba(0,0,0,.45);
}
.nav-menu a{
  color:#0b3a28;
  font-weight:700;
  text-decoration:none;
  font-size:.98rem;
  line-height:1;
  padding:8px 10px;
  border-radius:999px;
}
.nav-menu a:focus-visible{
  outline:2px solid #0b3a28;
  outline-offset:2px;
}

/* ===== MOBILE NAVBAR (hamburger) ===== */
.menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: space-between;
  width: 26px;
  height: 20px;
  background: transparent;
  border: none;
  cursor: pointer;
  z-index: 999;
}
.menu-toggle .bar {
  height: 3px;
  width: 100%;
  background-color: var(--bright-green);
  border-radius: 2px;
}

/* === HERO CONTENT === */
.hero-content{
  z-index:3;
  text-align:center;
  max-width:960px;
  margin-top:clamp(32px,8vh,72px);
  padding-inline:8px;
}
.hero-content h1{
  color:#caffbf;
  font-weight:800;
  letter-spacing:-0.01em;
  line-height:1.08;
  font-size:clamp(2rem,4.2vw + 1rem,3.75rem);
  text-shadow:0 0 10px rgba(99,255,107,.25),0 0 35px rgba(99,255,107,.22);
}
.subtitle{
  margin-top:14px;
  font-weight:700;
  color:var(--bright-green);
  opacity:.95;
}
.description{
  margin-top:14px;
  color:#e9ffe6;
  font-size:1.06rem;
  line-height:1.6;
  max-width:720px;
  margin-inline:auto;
  opacity:.95;
}

/* === CTA BUTTONS === */
.cta-buttons{
  margin-top:28px;
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}
.btn{
  min-width:170px;
  padding:.95rem 1.6rem;
  border-radius:999px;
  font-weight:800;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:none;
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease;
  will-change:transform;
}
.btn:hover{transform:translateY(-3px) scale(1.01)}
.btn:active{transform:translateY(0) scale(.99)}
.btn-light{
  background:linear-gradient(180deg,var(--bright-green) 0%,var(--bright-green-2) 100%);
  color:#0b3a28;
  box-shadow:0 0 28px rgba(99,255,107,.35);
}
.btn-light:focus-visible{outline:3px solid #0b3a28;outline-offset:2px}
.btn-dark{
  background:rgba(0,0,0,.25);
  color:var(--light-green);
  border:2px solid var(--bright-green);
  box-shadow:0 12px 24px rgba(0,0,0,.45);
}

/* === TRUSTED BADGE === */
.trusted{
  margin-top:16px;
  font-size:.92rem;
  color:#d6ffd1;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  opacity:.92;
}
.trusted-icon{
  width:14px;
  height:14px;
  display:inline-grid;
  place-items:center;
  border-radius:2px;
  background:linear-gradient(180deg,#ff6b6b,#ff3838);
  box-shadow:0 2px 6px rgba(0,0,0,.35);
  position:relative;
}
.trusted-icon::before,
.trusted-icon::after{
  content:"";
  position:absolute;
  inset:0;
  margin:auto;
  background:#fff;
}
.trusted-icon::before{width:60%;height:2px}
.trusted-icon::after{height:60%;width:2px}

/* === SUPPORT BANNER === */
.support-banner{
  margin:clamp(18px,4vh,28px) auto 6px;
  background:linear-gradient(90deg,var(--bright-green),var(--bright-green-2)); 
  color:#0b3a28;
  font-weight:700;
  text-align:center;
  padding:.9rem 1.2rem;
  border-radius:999px;
  max-width:980px;
  width:calc(100% - 24px);
  box-shadow:0 18px 50px rgba(0,120,30,.18);
  z-index:3;
}
.support-banner a{color:#063f1f;text-decoration:underline}

/* ===== Utilities ===== */
.visually-hidden{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;
  border:0;
}

/* ===== STORY SECTION ===== */
.story {
  background: #000;
  color: #fff;
  padding: clamp(60px, 10vh, 100px) 0;
}
.story-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 32px);
  display: grid;
  grid-template-columns: 1.1fr 0.9fr; /* text / image on desktop */
  align-items: center;
  gap: clamp(32px, 6vw, 72px);
}
.story-copy {
  font-size: clamp(0.95rem, 0.7rem + 0.7vw, 1.05rem);
  line-height: 1.6;
  opacity: 0.95;
}
.story-copy p + p { margin-top: 16px; }
.story-lede { font-weight: 600; color: #f2fff0; opacity: .96; }
.story-eyebrow {
  color: var(--bright-green);
  font-weight: 700;
  text-transform: uppercase;
  margin-top: clamp(10px, 2vh, 16px);
  letter-spacing: 0.05em;
}
.story-body { color: #dfffe0; opacity: .9; }
.story-art { display:flex; justify-content:center; align-items:center; }
.story-art img {
  width:100%; max-width:380px; height:auto; display:block;
  border-radius:14px; filter:drop-shadow(0 18px 40px rgba(0,0,0,0.5));
}
.story-closer {
  text-align:center; color:#e0ffe0;
  margin-top: clamp(40px, 8vh, 60px);
  font-size: clamp(1rem, 0.7rem + 1vw, 1.2rem);
  line-height:1.6;
}
.story-closer .otherwise { color: var(--bright-green); font-weight:800; }

/* ===== Solutions Section ===== */
.solutions{
  background:#000; color:#fff;
  padding:clamp(60px,8vh,100px) 0;
  text-align:center;
  min-height:100svh;
  display:flex; align-items:center;
}
.solutions-inner{
  max-width:1200px; margin:0 auto;
  padding:0 clamp(16px,3vw,32px); width:100%;
}
.solutions h2{
  color:var(--bright-green); font-weight:800;
  font-size:clamp(1.8rem,1rem + 2.2vw,2.6rem);
  margin-bottom:clamp(40px,5vh,64px);
}
.solutions .solutions-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:clamp(28px,4vw,40px);
}
.solution-card{
  background:#000;
  border:1px solid rgba(80,255,80,.1);
  border-radius:14px;
  padding:clamp(24px,3vw,36px);
  text-align:left;
  transition:all .25s ease;
  display:block;            /* anchor as block card */
  text-decoration:none;
  color:inherit;
  cursor:pointer;
}
.solution-card:hover{
  background:linear-gradient(180deg,rgba(10,30,10,1) 0%,rgba(0,0,0,1) 100%);
  border:1.5px solid var(--bright-green);
  box-shadow:0 0 18px rgba(80,255,80,.25),0 8px 22px rgba(0,255,100,.15);
  transform:translateY(-4px);
}
.solution-card:focus-visible{
  outline:2px solid var(--bright-green);
  outline-offset:4px;
}
/* remove visited underline/blue */
.solution-card:link, .solution-card:visited{
  color:inherit;
  text-decoration:none;
}
.solution-header{
  display:flex; align-items:center; gap:.75rem; margin-bottom:1rem;
}
.solution-number{font-weight:700;color:var(--bright-green);font-size:1rem}
.solution-icon{font-size:1.25rem}
.solution-badge{
  font-size:.75rem; background:var(--bright-green); color:#003012;
  padding:.25rem .6rem; border-radius:999px; font-weight:700;
}
.solution-card h3{
  color:var(--bright-green); font-weight:800; margin-bottom:.65rem; font-size:1.1rem;
}
.solution-card p{color:#e6ffe3;font-size:.98rem;line-height:1.55}

/* ===== CTA SECTION ===== */
.cta{
  background:#000; color:#fff;
  padding:clamp(56px,8vh,96px) 0 clamp(64px,10vh,120px);
  min-height:100svh; display:flex; align-items:center;
}
.cta-inner{
  max-width:1200px; margin:0 auto;
  padding:0 clamp(16px,3vw,32px);
  display:flex; flex-direction:column; align-items:center;
  text-align:center; width:100%;
}
.cta-title{
  text-align:center; font-weight:800;
  font-size:clamp(2.2rem, 1.2rem + 5vw, 4.5rem);
  letter-spacing:.02em; line-height:1;
  margin-bottom:clamp(16px, 3vh, 32px);
  background:linear-gradient(180deg,#9dff9f 0%,#2b8a3e 55%,rgba(43,138,62,0.15) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.cta-card{
  background:#222; border-radius:28px;
  padding:clamp(32px,5vw,56px);
  display:grid; grid-template-columns:1fr 1.6fr;
  gap:clamp(24px,4vw,60px);
  box-shadow:0 18px 44px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.06);
  max-width:1100px; width:100%;
}
.cta-side-kicker{
  font-style:italic; text-transform:uppercase; font-weight:700; letter-spacing:.02em;
  color:#f4fff2; opacity:.95; align-self:center; line-height:1.4;
  font-size:clamp(1rem,0.5rem + 1.3vw,1.4rem);
}
.cta-content{ display:flex; flex-direction:column; justify-content:center; gap:18px; }
.cta-copy{ font-size:clamp(1.05rem,0.6rem + 1.1vw,1.3rem); line-height:1.65; color:#dfffe0; }
.cta-button{
  align-self:flex-start; padding:.85rem 1.5rem;
  box-shadow:0 6px 0 rgba(0,0,0,.25),0 14px 30px rgba(0,120,30,.18);
  border:1px solid rgba(0,0,0,.25);
}

/* ===== FOOTER ===== */
.site-footer{
  background:#000; color:#fff;
  padding:clamp(40px, 7vh, 72px) 0 16px;
}
.footer-inner{
  max-width:1200px; margin:0 auto;
  padding:0 clamp(16px,3vw,32px);
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:clamp(24px, 4vw, 64px); align-items:start;
}
/* Brand block */
.footer-logo img{
  height:24px; width:auto; display:block; margin-bottom:14px;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.35));
}
.footer-address{margin:12px 0 20px}
.footer-address a{ color:#cfead0; font-size:.95rem; text-decoration:underline; }
.footer-kicker{color:var(--bright-green);font-weight:800;margin-bottom:8px}
.footer-email{ color:#e9ffe6; text-decoration:none; display:inline-block; margin-bottom:12px; }
.footer-email:hover{text-decoration:underline}
/* Social icon */
.footer-social{display:flex; gap:10px}
.social-linkedin svg{width:26px; height:26px; display:block}
.social-linkedin rect{fill:var(--bright-green)}
.social-linkedin path{fill:#052a17}
.social-linkedin:hover rect{filter:brightness(1.05)}
/* Columns */
.footer-columns{display:contents}
.footer-col h3{ color:var(--bright-green); font-size:1.05rem; margin:2px 0 10px; font-weight:800; }
.footer-col ul{
  list-style:none; margin:0; padding:0;
  display:grid; gap:clamp(8px, 0.7rem, 12px);
}
.footer-col a{
  color:#f1fff0; text-decoration:none; font-weight:600;
  line-height:1.55; padding-block:2px;
}
.footer-col a:hover{text-decoration:underline}
/* Bottom line */
.footer-bottom{
  max-width:1200px; margin:18px auto 0;
  padding:0 clamp(16px,3vw,32px);
  display:flex; justify-content:flex-end; color:#c8e9c9; font-size:.9rem;
}

/* === RESPONSIVE === */
@media (max-width:1024px){
  .looper-bg{width:190%;bottom:-14%}
}
@media (max-width:980px){
  .story-inner{grid-template-columns:1fr;align-items:center}
  .story-art{order:2}
  .story-copy{order:1}
  .story-art img{max-width:520px}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media (max-width:900px){
  .cta-card{grid-template-columns:1fr;text-align:center}
  .cta-side-kicker{align-self:center}
  .cta-content{align-items:center}
}
@media (max-width:768px){
  .nav-menu{gap:.7rem;padding:8px 12px}
  .nav-menu a{font-size:.9rem;padding:6px 8px}
  .hero-content h1{font-size:clamp(1.9rem,6.2vw,2.2rem)}
  .description{font-size:1rem}
  .btn{min-width:145px;padding:.78rem 1.2rem}
  .support-banner{font-size:.95rem;padding:.7rem .9rem}
  .looper-bg{width:230%;bottom:-24%}
  .solution-card{padding:22px 18px}
  .solution-card h3{font-size:1rem}
}
@media (max-width:680px){
  .footer-inner{grid-template-columns:1fr}
  .footer-bottom{justify-content:center;text-align:center}
  .footer-col ul{gap:14px}
}

/* Optional: Scroll-snap (desktop only) */
@media (min-width:900px){
  body{ scroll-snap-type:y proximity; }
  .hero, .story, .solutions, .cta{
    scroll-snap-align:start;
    scroll-snap-stop:always;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .btn,.solution-card,.cta-button{transition:none}
  .solution-card:hover{transform:none}
  body{ scroll-snap-type:none; }
}

/* Short screens fail-safe */
@media (max-height:640px){
  .story, .solutions, .cta{
    align-items:flex-start;
    padding-top:max(24px,3vh);
    padding-bottom:max(24px,3vh);
  }
}

/* === SUPPORT BANNER FADE-IN === */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.support-banner { opacity: 0; animation: fadeInUp 1.2s ease-out 0.4s forwards; }

/* === STORY SECTION FADE-IN === */
@keyframes fadeInStory {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.story-copy p, .story-closer {
  opacity: 0; transform: translateY(20px);
  transition: opacity .4s ease, transform .4s ease;
}
.story.animate .story-copy p,
.story.animate .story-closer { animation: fadeInStory 1.2s ease-out forwards; }
.story.animate .story-copy p:nth-of-type(1) { animation-delay: .1s; }
.story.animate .story-copy p:nth-of-type(2) { animation-delay: 1.4s; }
.story.animate .story-copy p:nth-of-type(3) { animation-delay: 2.7s; }
.story.animate .story-closer { animation-delay: 4.0s; }

/* ===== Smooth Scroll ===== */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: no-preference) {
  html { scroll-behavior: smooth; scroll-padding-top: 80px; }
}

/* ===== Mobile layout tweaks ===== */
@media (max-width: 960px){
  .nav-menu{ display:none; }  /* hide pill menu on mobile */
  .menu-toggle{ display:flex; }

  /* hero background tweak for mobile */
  .hero { background: linear-gradient(180deg, #000 0%, #041b11 100%); }
  .hero .looper-bg{
    object-fit: contain;
    object-position: top center;
    opacity: .65;
    transform: scale(1.2);
  }
  .hero-content{
    padding-top: clamp(80px, 16vh, 140px);
    padding-bottom: clamp(60px, 10vh, 100px);
  }
}

/* ===== Solutions: mobile single column + tighter spacing ===== */
@media (max-width: 900px){
  .solutions{
    min-height:auto;
    align-items:flex-start;
    padding: clamp(40px, 8vh, 80px) 0;
  }
  .solutions .solutions-grid{
    grid-template-columns:1fr;
    gap: clamp(16px, 4vw, 22px);
  }
  .solution-card{ padding:22px 18px; }
}

/* === MOBILE WHITESPACE COMPACTOR === */
@media (max-width: 900px){
  .story, .solutions, .cta {
    min-height: auto !important;
    padding: clamp(20px, 4vh, 32px) 0 !important;
  }
  .solutions { align-items: flex-start !important; }
  .solutions h2 { margin-bottom: clamp(14px, 3vh, 20px) !important; }
  .solutions .solutions-grid { gap: clamp(14px, 3vw, 18px) !important; }
  .story-inner { gap: clamp(16px, 3vh, 22px) !important; }
  .story-closer { margin-top: clamp(14px, 3vh, 20px) !important; }
  .cta-inner { gap: clamp(12px, 2vh, 16px) !important; }
  .cta-card { padding: clamp(16px, 3vw, 20px) !important; row-gap: 12px !important; }
  .story p:last-child,
  .solution-card p:last-child,
  .cta-content p:last-child { margin-bottom: 0 !important; }
  .cta-button{ margin:12px auto 0; display:inline-block; }
}

/* ===== Mobile Sidebar & Overlay (TOP-LEVEL) ===== */
.sidebar{
  position: fixed;
  top: 0; right: -100%;
  width: 72%;
  max-width: 320px;
  height: 100vh;
  background: #0b1f16; /* solid */
  display: flex;
  flex-direction: column;
  gap: 1.4rem;
  padding: 80px 28px 28px;
  box-shadow: -24px 0 60px rgba(0,0,0,.6);
  transition: right .28s cubic-bezier(.22,.61,.36,1);
  z-index: 10000; /* above everything */
}
.sidebar.active{ right: 0; }
.sidebar a{
  color: var(--bright-green);
  text-decoration: none;
  font-weight: 700;
  font-size: 1.1rem;
}
.sidebar a:hover{ color: var(--bright-green-2); }

.close-btn{
  position: absolute;
  top: 18px; right: 22px;
  background: none; border: 0;
  font-size: 2rem; color: var(--bright-green);
  cursor: pointer; line-height: 1;
}

.sidebar-overlay{
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
  z-index: 9999;
}
.sidebar-overlay.active{
  opacity: 1; pointer-events: auto;
}

/* Hide hamburger while menu is open + lock scroll */
body.nav-open .menu-toggle{ display:none; }
body.nav-open{ overflow:hidden; }

/* Desktop: hide sidebar components */
@media (min-width: 901px){
  .sidebar, .sidebar-overlay{ display:none !important; }
}

.solution-icon-img {
  width: 40px;
  height: 40px;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 4px 8px rgba(0,0,0,0.4));
}