:root{
  --dark-green: #1B261F;
  --green: #1F4C3D;
  --green-mid: #2F6650;
  --green-light: #4C8A6E;
  --beige: #EFE7D6;
  --beige-dark: #DCCFAC;
  --white: #FFFFFF;
  --cream: #FAF7EE;
  --ink: #172420;
  --ink-soft: #47564F;
  --gold: #A9834D;
  --radius: 2px;
  --maxw: 1180px;
  --shadow: 0 18px 40px -20px rgba(15, 40, 30, 0.35);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter', sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
section{scroll-margin-top:86px;}
h1,h2,h3,h4{
  font-family:'Archivo', sans-serif;
  line-height:1.15;
  letter-spacing:-0.01em;
  color:var(--dark-green);
}
.mono{
  font-family:'JetBrains Mono', monospace;
  letter-spacing:0.04em;
}
.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 28px;
}
.eyebrow{
  font-family:'JetBrains Mono', monospace;
  font-size:0.75rem;
  font-weight:600;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--gold);
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
}
.eyebrow::before{
  content:"";
  width:22px;height:2px;
  background:var(--gold);
  display:inline-block;
}

/* reveal animation */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 26px;
  font-family:'Inter',sans-serif;
  font-weight:600;
  font-size:0.95rem;
  border-radius:var(--radius);
  border:1.5px solid transparent;
  cursor:pointer;
  transition:transform .2s ease, background .25s ease, color .25s ease, border-color .25s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn-primary{
  background:var(--gold);
  color:var(--dark-green);
}
.btn-primary:hover{background:#bd9a63;}
.btn-outline{
  background:transparent;
  border-color:rgba(255,255,255,0.55);
  color:var(--white);
}
.btn-outline:hover{background:rgba(255,255,255,0.12);border-color:#fff;}
.btn-dark{
  background:var(--dark-green);
  color:var(--white);
  border-color:var(--dark-green);
}
.btn-dark:hover{background:var(--green-mid);}
.btn-ghost-dark{
  background:transparent;
  border-color:var(--dark-green);
  color:var(--dark-green);
}
.btn-ghost-dark:hover{background:var(--dark-green);color:#fff;}
.btn-tel::before{content:"\260E \0020";}

/* TOPBAR */
.topbar{
  background:#0E1712;
  border-bottom:1px solid rgba(255,255,255,0.08);
  overflow:hidden;
  max-height:40px;
  transition:max-height .35s ease, padding .35s ease, opacity .3s ease;
}
.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:9px 0;
  flex-wrap:wrap;
}
.topbar-badges{
  display:flex;
  align-items:center;
  gap:0;
}
.topbar-badges span{
  font-family:'JetBrains Mono',monospace;
  font-size:0.72rem;
  color:#CBD8CE;
  letter-spacing:0.02em;
  padding:0 18px;
  border-right:1px solid rgba(255,255,255,0.14);
  display:flex;
  align-items:center;
  gap:7px;
  white-space:nowrap;
}
.topbar-badges span:first-child{padding-left:0;}
.topbar-badges span:last-child{border-right:none;}
.topbar-badges .ic{color:var(--gold);}
.topbar-contact{
  display:flex;
  gap:22px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.72rem;
}
.topbar-contact a{color:#CBD8CE;transition:color .2s ease;}
.topbar-contact a:hover{color:var(--gold);}
header.scrolled .topbar, header.solid.scrolled .topbar{max-height:0;padding:0;opacity:0;border-bottom:none;}
@media (max-width:900px){.topbar-contact{display:none;}}
@media (max-width:640px){
  .topbar-badges span:nth-child(3){display:none;}
}

/* NAV */
header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  background:rgba(20,48,42,0.0);
  transition:background .35s ease, box-shadow .35s ease;
}
header.scrolled, header.solid{
  background:rgba(20,38,31,0.97);
  box-shadow:0 6px 24px rgba(0,0,0,0.18);
  backdrop-filter:blur(6px);
}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
  padding:18px 0;
  transition:padding .3s ease;
}
header.scrolled .nav-inner, header.solid .nav-inner{padding:14px 0;}
.logo{
  display:flex;
  align-items:center;
  gap:12px;
  flex-shrink:0;
}
.logo img{
  height:52px;
  width:auto;
  display:block;
  transition:height .3s ease;
}
header.scrolled .logo img, header.solid .logo img{height:44px;}
.logo .wordmark{
  display:flex;
  flex-direction:column;
  line-height:1.2;
}
.logo .wordmark b{
  font-family:'Archivo',sans-serif;
  font-weight:800;
  font-size:1.15rem;
  color:#fff;
  letter-spacing:0.01em;
}
.logo .wordmark small{
  font-family:'JetBrains Mono',monospace;
  font-size:0.6rem;
  letter-spacing:0.16em;
  color:var(--beige-dark);
  font-weight:500;
  text-transform:uppercase;
}
nav{flex:1;display:flex;justify-content:center;}
nav ul{
  display:flex;
  gap:46px;
  align-items:center;
}
nav a{
  color:#EFEAE0;
  font-size:0.82rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.07em;
  position:relative;
  padding:8px 0;
  transition:color .2s ease;
}
nav a::after{
  content:"";
  position:absolute;
  left:0;bottom:0;
  width:0%;height:2px;
  background:var(--gold);
  transition:width .25s ease;
}
nav a:hover, nav a.active{color:#fff;}
nav a:hover::after, nav a.active::after{width:100%;}
.nav-actions{display:flex;align-items:center;gap:16px;flex-shrink:0;}
.nav-actions::before{
  content:"";
  width:1px;height:28px;
  background:rgba(255,255,255,0.18);
  margin-right:4px;
}
.nav-actions .btn{padding:11px 20px;font-size:0.82rem;}
.burger{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;border:none;cursor:pointer;
  padding:6px;
}
.burger span{width:24px;height:2px;background:#fff;display:block;}

@media (max-width:1080px){
  nav ul{gap:28px;}
}
@media (max-width:980px){
  nav{
    position:fixed;
    top:0; right:-100%;
    width:min(320px,80%);
    height:100vh;
    background:var(--dark-green);
    flex-direction:column;
    padding:100px 32px 40px;
    transition:right .35s ease;
    box-shadow:-10px 0 40px rgba(0,0,0,0.3);
    justify-content:flex-start;
  }
  nav.open{right:0;}
  nav ul{flex-direction:column;gap:22px;align-items:flex-start;}
  .nav-actions{display:none;}
  .nav-actions::before{display:none;}
  .burger{display:flex;}
}

/* HERO (homepage) */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  color:#fff;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(120deg, rgba(15,35,29,0.92) 10%, rgba(20,48,42,0.72) 55%, rgba(20,48,42,0.5) 100%);
  z-index:1;
}
.hero::after{
  content:"";
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(233,222,192,0.09) 1px, transparent 1px),
    linear-gradient(90deg, rgba(233,222,192,0.09) 1px, transparent 1px);
  background-size:44px 44px;
  z-index:1;
  mix-blend-mode:overlay;
}
.hero-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  filter:saturate(0.9);
}
.hero-content{
  position:relative;z-index:2;
  padding-top:158px;
  max-width:680px;
}
.hero-content h1{
  font-size:clamp(2.4rem, 5vw, 3.6rem);
  color:#fff;
  margin-bottom:22px;
}
.hero-content h1 em{
  font-style:normal;
  color:var(--gold);
}
.hero-content p{
  font-size:1.08rem;
  color:#E7E2D2;
  max-width:540px;
  margin-bottom:34px;
}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;}
.hero-stats{
  position:relative;z-index:2;
  display:flex;
  gap:0;
  margin-top:64px;
  border-top:1px solid rgba(255,255,255,0.18);
  padding-top:26px;
  max-width:680px;
  flex-wrap:wrap;
}
.hero-stats div{padding-right:40px;}
.hero-stats strong{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:1.7rem;
  color:#fff;
}
.hero-stats span{
  font-family:'JetBrains Mono',monospace;
  font-size:0.72rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--beige-dark);
}

/* PAGE HERO (sub-pages) */
.page-hero{
  position:relative;
  min-height:44vh;
  display:flex;
  align-items:flex-end;
  color:#fff;
  overflow:hidden;
  padding-bottom:56px;
}
.page-hero::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(120deg, rgba(15,35,29,0.94) 20%, rgba(20,48,42,0.78) 100%);
  z-index:1;
}
.page-hero::after{
  content:"";
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(233,222,192,0.09) 1px, transparent 1px),
    linear-gradient(90deg, rgba(233,222,192,0.09) 1px, transparent 1px);
  background-size:44px 44px;
  z-index:1;
  mix-blend-mode:overlay;
}
.page-hero-img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  filter:saturate(0.9);
}
.page-hero-content{
  position:relative;z-index:2;
  padding-top:158px;
  max-width:720px;
}
.page-hero-content h1{
  font-size:clamp(2rem, 4vw, 2.8rem);
  color:#fff;
}
.page-hero-content p{
  color:#D7E0D9;
  margin-top:14px;
  max-width:560px;
  font-size:1.02rem;
}
.crumb{
  font-family:'JetBrains Mono',monospace;
  font-size:0.75rem;
  color:var(--beige-dark);
  text-transform:uppercase;
  letter-spacing:0.08em;
  margin-bottom:16px;
  display:block;
}
.crumb a{color:var(--gold);}

/* Generic section styling */
.section{padding:100px 0;}
.section-beige{background:var(--beige);}
.section-dark{background:var(--dark-green); color:#EFEAE0;}
.section-dark h2, .section-dark h3{color:#fff;}
.section-head{
  max-width:640px;
  margin-bottom:56px;
}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head h2{font-size:clamp(1.9rem,3.4vw,2.6rem);}
.section-head p{color:var(--ink-soft);margin-top:14px;font-size:1.05rem;}
.section-dark .section-head p{color:#C9D6CE;}

/* PRODUCTS */
.badge-strip{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:50px;
}
.pill{
  font-family:'JetBrains Mono',monospace;
  font-size:0.78rem;
  padding:8px 16px;
  border:1px solid var(--green-mid);
  color:var(--green);
  border-radius:20px;
  background:#fff;
}
.product-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
@media (max-width:980px){.product-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.product-grid{grid-template-columns:1fr;}}

.part-card{
  position:relative;
  background:#fff;
  border:1px solid var(--beige-dark);
  padding:26px 22px 22px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.part-card::before, .part-card::after,
.part-card .cbl, .part-card .cbr{
  content:"";
  position:absolute;
  width:14px;height:14px;
  border:2px solid var(--gold);
  opacity:0;
  transition:opacity .25s ease;
}
.part-card::before{top:-1px;left:-1px;border-right:none;border-bottom:none;}
.part-card::after{top:-1px;right:-1px;border-left:none;border-bottom:none;}
.part-card .cbl{bottom:-1px;left:-1px;border-right:none;border-top:none;}
.part-card .cbr{bottom:-1px;right:-1px;border-left:none;border-top:none;}
.part-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent;}
.part-card:hover::before,.part-card:hover::after,.part-card:hover .cbl,.part-card:hover .cbr{opacity:1;}
.part-code{
  font-size:0.68rem;
  color:var(--gold);
  margin-bottom:10px;
  display:block;
}
.part-icon{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  background:var(--beige);
  color:var(--green);
  margin-bottom:16px;
  border-radius:var(--radius);
}
.part-photo{
  width:calc(100% + 44px);
  height:150px;
  margin:-26px -22px 18px;
  overflow:hidden;
  background:#0b7d6e;
  position:relative;
}
.part-photo img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 62%;
  display:block;
  transition:transform .4s ease;
}
.part-card:hover .part-photo img{transform:scale(1.06);}
.part-card h4{font-size:1.02rem;margin-bottom:6px;}
.part-card p{font-size:0.87rem;color:var(--ink-soft);}
.product-more{
  grid-column:1/-1;
  text-align:center;
  padding:22px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.85rem;
  color:var(--green);
  border:1px dashed var(--green-mid);
  background:rgba(255,255,255,0.5);
}

/* Gallery strip */
.gallery-wrap{margin-top:56px;}
.gallery-label{
  font-family:'JetBrains Mono',monospace;
  font-size:0.78rem;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:0.08em;
  margin-bottom:16px;
  display:block;
}
.gallery-strip{
  display:flex;
  gap:14px;
  overflow-x:auto;
  padding-bottom:10px;
  scrollbar-width:thin;
}
.gallery-strip::-webkit-scrollbar{height:6px;}
.gallery-strip::-webkit-scrollbar-thumb{background:var(--beige-dark);}
.gallery-item{
  flex:0 0 auto;
  width:190px;
  height:150px;
  border:1px solid var(--beige-dark);
  overflow:hidden;
  background:#0b7d6e;
}
.gallery-item img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 62%;
  transition:transform .4s ease;
}
.gallery-item:hover img{transform:scale(1.08);}

.guarantee-banner{
  margin-top:56px;
  display:flex;
  align-items:center;
  gap:26px;
  background:var(--dark-green);
  color:#fff;
  padding:34px 38px;
  flex-wrap:wrap;
  justify-content:space-between;
}
.guarantee-banner .txt{max-width:640px;}
.guarantee-banner h3{color:#fff;font-size:1.3rem;margin-bottom:8px;}
.guarantee-banner p{color:#CBD8CF;font-size:0.95rem;}
.guarantee-icons{display:flex;gap:26px;flex-wrap:wrap;}
.guarantee-icons div{
  text-align:center;
  font-family:'JetBrains Mono',monospace;
  font-size:0.68rem;
  color:var(--beige-dark);
  text-transform:uppercase;
  letter-spacing:0.06em;
}
.guarantee-icons .gicon{
  width:46px;height:46px;
  border:1px solid rgba(255,255,255,0.3);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 8px;
  color:var(--gold);
}

/* ABOUT */
.about-grid{
  display:grid;
  grid-template-columns:0.9fr 1.1fr;
  gap:64px;
  align-items:center;
}
@media (max-width:900px){.about-grid{grid-template-columns:1fr;}}
.about-media{
  position:relative;
}
.about-media img{
  width:100%;height:460px;object-fit:cover;
  border:6px solid var(--beige);
}
.about-since{
  position:absolute;
  bottom:-26px; left:-26px;
  background:var(--gold);
  color:var(--dark-green);
  padding:20px 24px;
  font-family:'Archivo',sans-serif;
  font-weight:800;
  box-shadow:var(--shadow);
}
.about-since strong{display:block;font-size:1.8rem;}
.about-since span{font-family:'JetBrains Mono',monospace;font-size:0.66rem;letter-spacing:0.08em;text-transform:uppercase;}
.about-list{margin-top:26px;}
.about-list li{
  display:flex;
  gap:14px;
  padding:16px 0;
  border-bottom:1px solid var(--beige-dark);
  font-size:0.98rem;
  color:var(--ink-soft);
}
.about-list li:last-child{border-bottom:none;}
.about-list b{color:var(--dark-green);}
.num{
  font-family:'JetBrains Mono',monospace;
  color:var(--gold);
  font-weight:600;
  flex-shrink:0;
}

/* WHY US */
.why-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:rgba(255,255,255,0.14);
  border:1px solid rgba(255,255,255,0.14);
}
@media (max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.why-grid{grid-template-columns:1fr;}}
.why-item{
  background:var(--dark-green);
  padding:36px 30px;
  transition:background .25s ease;
}
.why-item:hover{background:#1B3E33;}
.why-item .n{
  font-family:'JetBrains Mono',monospace;
  color:var(--gold);
  font-size:0.78rem;
  display:block;
  margin-bottom:14px;
}
.why-item h4{color:#fff;font-size:1.08rem;margin-bottom:8px;}
.why-item p{color:#BFCFC5;font-size:0.9rem;}

/* REVIEWS */
.review-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
@media (max-width:980px){.review-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.review-grid{grid-template-columns:1fr;}}
.review-card{
  background:#fff;
  border:1px solid var(--beige-dark);
  padding:28px 24px;
}
.stars{color:var(--gold);letter-spacing:2px;margin-bottom:14px;font-size:1rem;}
.review-card p{font-size:0.95rem;color:var(--ink-soft);margin-bottom:20px;min-height:70px;}
.reviewer{display:flex;align-items:center;gap:12px;}
.avatar{
  width:38px;height:38px;
  border-radius:50%;
  background:var(--beige);
  color:var(--green);
  display:flex;align-items:center;justify-content:center;
  font-family:'Archivo',sans-serif;
  font-weight:700;
  font-size:0.85rem;
}
.reviewer b{font-size:0.9rem;color:var(--dark-green);display:block;}
.reviewer span{font-size:0.75rem;color:var(--ink-soft);}

/* FAQ */
.faq-list{max-width:820px;}
details{
  border-bottom:1px solid var(--beige-dark);
  padding:22px 0;
}
details summary{
  list-style:none;
  cursor:pointer;
  font-family:'Archivo',sans-serif;
  font-weight:600;
  font-size:1.05rem;
  color:var(--dark-green);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
}
details summary::-webkit-details-marker{display:none;}
details summary::after{
  content:"+";
  font-family:'JetBrains Mono',monospace;
  font-size:1.4rem;
  color:var(--gold);
  transition:transform .25s ease;
  flex-shrink:0;
}
details[open] summary::after{transform:rotate(45deg);}
details p{
  margin-top:14px;
  color:var(--ink-soft);
  font-size:0.96rem;
  max-width:640px;
}

/* CONTACT */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;}}
.contact-card{
  background:var(--dark-green);
  color:#fff;
  padding:40px;
  margin-bottom:24px;
}
.contact-card h3{color:#fff;margin-bottom:22px;font-size:1.2rem;}
.contact-row{
  display:flex;
  gap:14px;
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,0.14);
  font-size:0.92rem;
}
.contact-row:last-child{border-bottom:none;}
.contact-row .lbl{
  font-family:'JetBrains Mono',monospace;
  font-size:0.68rem;
  text-transform:uppercase;
  letter-spacing:0.06em;
  color:var(--beige-dark);
  min-width:88px;
}
.phone-cta{
  display:flex;
  align-items:center;
  gap:16px;
  background:var(--gold);
  color:var(--dark-green);
  padding:22px 26px;
  margin-bottom:24px;
  flex-wrap:wrap;
}
.phone-cta .num{font-family:'Archivo',sans-serif;font-weight:800;font-size:1.3rem;color:var(--dark-green);}
.phone-cta p{font-size:0.85rem;font-weight:600;}
.map-frame{
  width:100%;height:260px;
  border:0;
  filter:grayscale(0.3) contrast(1.05);
}
.form-card{
  background:#fff;
  border:1px solid var(--beige-dark);
  padding:40px;
}
.form-card h3{margin-bottom:6px;}
.form-card > p{color:var(--ink-soft);font-size:0.92rem;margin-bottom:24px;}
.field{margin-bottom:18px;}
.field label{
  display:block;
  font-size:0.78rem;
  font-family:'JetBrains Mono',monospace;
  text-transform:uppercase;
  letter-spacing:0.05em;
  color:var(--green);
  margin-bottom:7px;
}
.field input, .field select, .field textarea{
  width:100%;
  padding:12px 14px;
  border:1px solid var(--beige-dark);
  background:var(--cream);
  font-family:'Inter',sans-serif;
  font-size:0.94rem;
  color:var(--ink);
  border-radius:var(--radius);
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:2px solid var(--green-mid);
  outline-offset:1px;
  background:#fff;
}
.field textarea{resize:vertical;min-height:100px;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media (max-width:540px){.two-col{grid-template-columns:1fr;}}
.form-note{
  font-size:0.8rem;
  color:var(--ink-soft);
  margin-top:14px;
}
.form-success{
  display:none;
  background:var(--beige);
  border:1px solid var(--green-mid);
  color:var(--dark-green);
  padding:16px 18px;
  font-size:0.9rem;
  margin-top:16px;
}
.form-success.show{display:block;}

/* CTA BAND */
.cta-band{
  background:linear-gradient(120deg, var(--green) 0%, var(--dark-green) 100%);
  color:#fff;
  padding:60px 0;
  text-align:center;
}
.cta-band h3{color:#fff;font-size:1.6rem;margin-bottom:14px;}
.cta-band p{color:#CBD8CF;margin-bottom:28px;}
.cta-band .hero-cta{justify-content:center;}

/* TRUST BADGES (inline strip, reused across pages) */
.trust-row{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:36px;
}
.trust-chip{
  display:flex;
  align-items:center;
  gap:10px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.16);
  padding:12px 18px;
  font-size:0.85rem;
  color:#EFEAE0;
  font-weight:500;
}
.trust-chip .ic{color:var(--gold);font-size:1.05rem;flex-shrink:0;}
.trust-row.light .trust-chip{
  background:#fff;
  border-color:var(--beige-dark);
  color:var(--ink);
}

/* PROCESS STEPS */
.process-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:10px;
}
@media (max-width:860px){.process-grid{grid-template-columns:1fr;}}
.process-step{
  position:relative;
  background:#fff;
  border:1px solid var(--beige-dark);
  padding:34px 28px;
}
.process-step .pnum{
  font-family:'Archivo',sans-serif;
  font-weight:800;
  font-size:2.6rem;
  color:var(--beige);
  position:absolute;
  top:14px; right:20px;
  line-height:1;
  -webkit-text-stroke:1.5px var(--beige-dark);
  color:transparent;
}
.process-step .pic{
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  background:var(--beige);
  color:var(--green);
  margin-bottom:20px;
  font-size:1.3rem;
}
.process-step h4{font-size:1.1rem;margin-bottom:10px;}
.process-step p{color:var(--ink-soft);font-size:0.92rem;}
.process-arrow{
  display:none;
}
@media (min-width:861px){
  .process-grid{position:relative;}
}

/* FEATURE (text + image) SECTION */
.feature-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
@media (max-width:900px){.feature-grid{grid-template-columns:1fr;}}
.feature-grid.reverse .feature-media{order:2;}
.feature-grid.reverse .feature-text{order:1;}
@media (max-width:900px){
  .feature-grid.reverse .feature-media{order:1;}
  .feature-grid.reverse .feature-text{order:2;}
}
.feature-media img{
  width:100%;height:420px;object-fit:cover;
}
.feature-text p{color:var(--ink-soft);margin-top:14px;}
.feature-list{margin-top:22px;}
.feature-list li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:10px 0;
  font-size:0.95rem;
  color:var(--ink-soft);
}
.feature-list li .tick{
  color:var(--gold);
  font-weight:700;
  flex-shrink:0;
}

/* COLLAGE (2-3 images grid) */
.collage-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:16px;
  height:460px;
}
@media (max-width:700px){
  .collage-grid{grid-template-columns:1fr 1fr;height:320px;}
}
.collage-grid img{
  width:100%;height:100%;object-fit:cover;
}
.collage-main{grid-row:1/3;}
.collage-tag{
  position:absolute;
  bottom:20px; left:20px;
  background:var(--dark-green);
  color:#fff;
  padding:14px 20px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.72rem;
  letter-spacing:0.06em;
  text-transform:uppercase;
}
.collage-wrap{position:relative;}

/* STAT STRIP (numbers band) */
.stat-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--beige-dark);
  border-bottom:1px solid var(--beige-dark);
}
@media (max-width:760px){.stat-strip{grid-template-columns:repeat(2,1fr);}}
.stat-cell{
  padding:30px 20px;
  text-align:center;
  border-right:1px solid var(--beige-dark);
}
.stat-cell:last-child{border-right:none;}
.stat-cell strong{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:2rem;
  color:var(--dark-green);
}
.stat-cell span{
  font-family:'JetBrains Mono',monospace;
  font-size:0.7rem;
  text-transform:uppercase;
  letter-spacing:0.06em;
  color:var(--ink-soft);
}
.tile-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
@media (max-width:900px){.tile-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.tile-grid{grid-template-columns:1fr;}}
.tile{
  background:#fff;
  border:1px solid var(--beige-dark);
  padding:30px 26px;
  display:block;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent;}
.tile .n{font-family:'JetBrains Mono',monospace;color:var(--gold);font-size:0.75rem;display:block;margin-bottom:12px;}
.tile h4{font-size:1.1rem;margin-bottom:8px;}
.tile p{font-size:0.9rem;color:var(--ink-soft);margin-bottom:14px;}
.tile .go{font-family:'JetBrains Mono',monospace;font-size:0.78rem;color:var(--green);}
.tile:hover .go{color:var(--gold);}

/* FOOTER */
footer{
  background:#0F251F;
  color:#B9C7BE;
  padding:70px 0 26px;
  font-size:0.9rem;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:50px;
  margin-bottom:50px;
}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}
.footer-logo{
  display:flex;align-items:center;gap:12px;
  margin-bottom:18px;
}
.footer-logo img{height:64px;width:auto;}
.footer-logo b{
  font-family:'Archivo',sans-serif;
  font-weight:800;
  color:#fff;
  font-size:1.15rem;
}
footer h5{
  font-family:'JetBrains Mono',monospace;
  font-size:0.72rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:18px;
}
footer ul li{margin-bottom:11px;}
footer a:hover{color:#fff;}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.1);
  padding-top:24px;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  font-size:0.78rem;
  color:#7E8F86;
}
.footer-legal{display:flex;gap:18px;flex-wrap:wrap;}

/* back to top */
.totop{
  position:fixed;
  right:24px; bottom:24px;
  width:48px;height:48px;
  background:var(--dark-green);
  color:#fff;
  border:none;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease, transform .3s ease;
  z-index:90;
  box-shadow:var(--shadow);
}
.totop.show{opacity:1;pointer-events:auto;}
.totop:hover{transform:translateY(-3px);}

::selection{background:var(--gold);color:#fff;}

/* MARQUEE TICKER */
.marquee{
  background:var(--dark-green);
  border-top:1px solid rgba(255,255,255,0.1);
  border-bottom:1px solid rgba(255,255,255,0.1);
  overflow:hidden;
  padding:16px 0;
  position:relative;
  z-index:2;
}
.marquee-track{
  display:flex;
  width:max-content;
  animation:marquee-scroll 32s linear infinite;
}
.marquee-track span{
  display:flex;
  align-items:center;
  gap:14px;
  font-family:'JetBrains Mono',monospace;
  font-size:0.82rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#EFEAE0;
  padding:0 34px;
  white-space:nowrap;
}
.marquee-track span::after{
  content:"✦";
  color:var(--gold);
  margin-left:34px;
}
@keyframes marquee-scroll{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}
@media (prefers-reduced-motion: reduce){
  .marquee-track{animation:none;}
}

/* BUTTON SHINE */
.btn{position:relative;overflow:hidden;}
.btn::before{
  content:"";
  position:absolute;
  top:0;left:-60%;
  width:40%;height:100%;
  background:linear-gradient(120deg, transparent, rgba(255,255,255,0.35), transparent);
  transform:skewX(-20deg);
  transition:left .6s ease;
}
.btn:hover::before{left:120%;}

/* DIAGONAL SECTION DIVIDER */
.divider-cut{
  position:relative;
  margin-top:-40px;
  clip-path:polygon(0 40px, 100% 0, 100% 100%, 0 100%);
  z-index:3;
}
@media (max-width:700px){
  .divider-cut{margin-top:-24px;clip-path:polygon(0 24px, 100% 0, 100% 100%, 0 100%);}
}

/* FLOATING WHATSAPP */
.float-whatsapp{
  position:fixed;
  left:24px; bottom:24px;
  width:56px;height:56px;
  background:#25D366;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px -8px rgba(0,0,0,0.5);
  z-index:95;
  transition:transform .25s ease;
}
.float-whatsapp:hover{transform:translateY(-3px) scale(1.04);}
.float-whatsapp svg{width:28px;height:28px;fill:#fff;}
.float-whatsapp .ping{
  position:absolute;
  inset:0;
  border-radius:50%;
  background:#25D366;
  opacity:0.6;
  animation:wa-ping 2.4s ease-out infinite;
}
@keyframes wa-ping{
  0%{transform:scale(1);opacity:0.55;}
  100%{transform:scale(1.7);opacity:0;}
}
@media (max-width:640px){
  .float-whatsapp{width:50px;height:50px;left:16px;bottom:78px;}
}

/* MOBILE STICKY CALL BAR */
.mobile-callbar{
  display:none;
}
@media (max-width:640px){
  .mobile-callbar{
    display:flex;
    position:fixed;
    left:0; right:0; bottom:0;
    z-index:96;
    background:var(--dark-green);
    box-shadow:0 -8px 24px rgba(0,0,0,0.25);
  }
  .mobile-callbar a{
    flex:1;
    text-align:center;
    padding:14px 10px;
    font-family:'Inter',sans-serif;
    font-weight:700;
    font-size:0.85rem;
    color:#fff;
  }
  .mobile-callbar a.wa{background:#1f6e50;}
  .mobile-callbar a.call{background:var(--gold);color:var(--dark-green);}
  body{padding-bottom:56px;}
}

/* NUMBER COUNT-UP TARGET */
.count-up{display:inline-block;}

/* ACCENT SHIMMER BAR */
.accent-bar{
  height:5px;
  background:linear-gradient(90deg, var(--gold), var(--green-mid), var(--gold));
  background-size:200% 100%;
  animation:accent-shift 6s linear infinite;
  position:relative;
  z-index:3;
}
@keyframes accent-shift{
  0%{background-position:0% 50%;}
  100%{background-position:200% 50%;}
}
@media (prefers-reduced-motion: reduce){
  .accent-bar{animation:none;}
}
