:root{
  --accent:#235f3c;
  --accent-2:#7fa66b;
  --ink:#142019;
  --muted:#667069;
  --surface:#f5f7f3;
  --paper:#fff;
  --dark:#101813;
  --line:rgba(20,32,25,.14);
  --shadow:0 24px 70px rgba(16,24,19,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  min-height:100vh;
  color:var(--ink);
  background:var(--surface);
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
}
body.demo-lock{overflow:hidden}
img{display:block;width:100%;height:auto}
a{color:inherit}
button,input,textarea{font:inherit}
.demo-shell{width:min(1180px,calc(100% - 40px));margin-inline:auto}
.demo-notice{
  min-height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:7px 20px;
  color:#d9e2dd;
  background:#0b100d;
  font-size:12px;
  font-weight:750;
  text-align:center;
}
.demo-header{
  position:sticky;
  z-index:40;
  top:0;
  border-bottom:1px solid var(--line);
  background:color-mix(in srgb,var(--paper) 91%,transparent);
  backdrop-filter:blur(18px);
}
.demo-nav{
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
}
.demo-brand{
  display:flex;
  align-items:center;
  gap:11px;
  color:var(--ink);
  text-decoration:none;
  font-size:17px;
  font-weight:950;
}
.demo-brand-mark{
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:7px;
  color:#fff;
  background:var(--accent);
  font-size:13px;
  font-weight:950;
}
.demo-nav-links{display:flex;align-items:center;gap:25px}
.demo-nav-links a{
  color:var(--muted);
  text-decoration:none;
  font-size:13px;
  font-weight:800;
}
.demo-nav-links a:hover{color:var(--ink)}
.demo-nav-links .demo-nav-cta{
  min-height:44px;
  display:inline-flex;
  align-items:center;
  padding:0 18px;
  border-radius:999px;
  color:#fff;
  background:var(--accent);
}
.demo-menu-button{
  width:44px;
  height:42px;
  display:none;
  border:1px solid var(--line);
  border-radius:7px;
  color:var(--ink);
  background:var(--paper);
  cursor:pointer;
}
.demo-menu-button span{
  width:19px;
  height:2px;
  display:block;
  margin:4px auto;
  background:currentColor;
}
.demo-label{
  position:fixed;
  z-index:60;
  right:14px;
  bottom:14px;
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 11px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  color:#fff;
  background:rgba(11,16,13,.9);
  box-shadow:0 12px 34px rgba(0,0,0,.2);
  font-size:11px;
  font-weight:900;
  backdrop-filter:blur(12px);
}
.demo-label::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--accent-2);
}
.demo-hero{
  position:relative;
  min-height:720px;
  display:grid;
  align-items:end;
  overflow:hidden;
  color:#fff;
  background:#172019;
}
.demo-hero-media{position:absolute;inset:0}
.demo-hero-media img{width:100%;height:100%;object-fit:cover}
.demo-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(7,12,9,.86) 0%,rgba(7,12,9,.58) 50%,rgba(7,12,9,.18) 100%),
    linear-gradient(0deg,rgba(7,12,9,.72),transparent 46%);
}
.demo-hero-content{
  position:relative;
  z-index:1;
  max-width:850px;
  padding-top:110px;
  padding-bottom:82px;
}
.demo-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:9px;
  margin-bottom:22px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.demo-eyebrow::before{
  content:"";
  width:30px;
  height:2px;
  background:var(--accent-2);
}
.demo-hero h1{
  max-width:820px;
  font-size:clamp(48px,7vw,92px);
  line-height:1.02;
  font-weight:950;
}
.demo-hero p{
  max-width:650px;
  margin-top:24px;
  color:#e0e8e3;
  font-size:18px;
  line-height:1.65;
}
.demo-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.demo-button{
  min-height:52px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:0 21px;
  border:1px solid transparent;
  border-radius:999px;
  text-decoration:none;
  font-size:14px;
  font-weight:900;
  cursor:pointer;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
.demo-button:hover{transform:translateY(-2px)}
.demo-button.primary{
  color:#fff;
  background:var(--accent);
  box-shadow:0 18px 40px color-mix(in srgb,var(--accent) 34%,transparent);
}
.demo-button.secondary{
  color:#fff;
  border-color:rgba(255,255,255,.42);
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(10px);
}
.demo-trust-strip{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border-top:1px solid rgba(255,255,255,.18);
}
.demo-trust-item{padding:22px 0}
.demo-trust-item + .demo-trust-item{padding-left:26px;border-left:1px solid rgba(255,255,255,.18)}
.demo-trust-item strong{display:block;font-size:15px}
.demo-trust-item span{display:block;margin-top:5px;color:#c6d1ca;font-size:12px}
.demo-section{padding:94px 0}
.demo-section.alt{background:var(--paper)}
.demo-section.dark{color:#fff;background:var(--dark)}
.demo-section-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,.58fr);
  gap:44px;
  align-items:end;
  margin-bottom:42px;
}
.demo-kicker{
  display:block;
  margin-bottom:14px;
  color:var(--accent);
  font-size:12px;
  font-weight:950;
  letter-spacing:.07em;
  text-transform:uppercase;
}
.dark .demo-kicker{color:var(--accent-2)}
.demo-section h2{
  max-width:780px;
  font-size:clamp(34px,4.5vw,58px);
  line-height:1.08;
}
.demo-section-head p,.demo-about-copy p{
  color:var(--muted);
  font-size:16px;
  line-height:1.75;
}
.dark .demo-section-head p{color:#b7c3bc}
.demo-usp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.demo-usp{
  min-height:210px;
  padding:24px;
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--paper);
  box-shadow:0 12px 32px rgba(16,24,19,.06);
  transition:transform .25s ease,border-color .25s ease;
}
.demo-usp:hover{transform:translateY(-5px);border-color:color-mix(in srgb,var(--accent) 45%,transparent)}
.demo-number{
  display:block;
  margin-bottom:42px;
  color:var(--accent);
  font-size:12px;
  font-weight:950;
}
.demo-usp h3{font-size:20px;line-height:1.2}
.demo-usp p{margin-top:10px;color:var(--muted);font-size:14px;line-height:1.65}
.demo-about{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(380px,.7fr);
  gap:64px;
  align-items:center;
}
.demo-about-image{
  aspect-ratio:4/3;
  overflow:hidden;
  border-radius:8px;
  box-shadow:var(--shadow);
}
.demo-about-image img{width:100%;height:100%;object-fit:cover}
.demo-about-copy h2{font-size:clamp(34px,4.2vw,56px);line-height:1.08}
.demo-about-copy p{margin-top:22px}
.demo-checks{display:grid;gap:10px;margin-top:25px;list-style:none}
.demo-checks li{display:flex;gap:11px;color:var(--ink);font-size:14px;font-weight:800}
.demo-checks li::before{content:"✓";color:var(--accent);font-weight:950}
.demo-services{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.demo-service{
  min-height:300px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:26px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:8px;
  background:rgba(255,255,255,.055);
  transition:background .25s ease,transform .25s ease;
}
.demo-service:hover{transform:translateY(-4px);background:rgba(255,255,255,.09)}
.demo-service-icon{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:7px;
  color:var(--dark);
  background:var(--accent-2);
  font-size:17px;
  font-weight:950;
}
.demo-service h3{margin-top:46px;font-size:24px}
.demo-service p{margin-top:12px;color:#b7c3bc;font-size:14px;line-height:1.65}
.demo-service span{display:block;margin-top:28px;color:var(--accent-2);font-size:13px;font-weight:900}
.demo-process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line)}
.demo-step{position:relative;padding:27px 28px 0 0}
.demo-step + .demo-step{padding-left:28px;border-left:1px solid var(--line)}
.demo-step strong{color:var(--accent);font-size:13px}
.demo-step h3{margin-top:34px;font-size:20px}
.demo-step p{margin-top:10px;color:var(--muted);font-size:14px;line-height:1.65}
.demo-projects{display:grid;grid-template-columns:1.35fr .65fr;grid-template-rows:1fr 1fr;gap:12px;min-height:620px}
.demo-project{
  position:relative;
  min-height:300px;
  overflow:hidden;
  border-radius:8px;
  color:#fff;
  background:#1a211d;
}
.demo-project:first-child{grid-row:1 / 3}
.demo-project img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.demo-project:hover img{transform:scale(1.04)}
.demo-project::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(6,10,8,.82),transparent 64%)}
.demo-project-copy{position:absolute;z-index:1;left:24px;right:24px;bottom:23px}
.demo-project-copy small{color:#d5dfd9;font-size:11px;font-weight:850;text-transform:uppercase}
.demo-project-copy h3{margin-top:7px;font-size:25px}
.demo-project-placeholder{
  width:100%;
  height:100%;
  background:
    linear-gradient(140deg,color-mix(in srgb,var(--accent) 82%,#111),color-mix(in srgb,var(--accent-2) 52%,#111));
}
.demo-reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.demo-review{
  min-height:250px;
  padding:25px;
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--paper);
}
.demo-review-label{
  display:inline-flex;
  padding:6px 9px;
  border-radius:999px;
  color:var(--accent);
  background:color-mix(in srgb,var(--accent) 10%,#fff);
  font-size:10px;
  font-weight:950;
  text-transform:uppercase;
}
.demo-review blockquote{margin-top:32px;font-size:17px;line-height:1.55;font-weight:750}
.demo-review footer{margin-top:28px;color:var(--muted);font-size:13px}
.demo-faq-layout{display:grid;grid-template-columns:minmax(0,.62fr) minmax(360px,.72fr);gap:64px}
.demo-faq-intro h2{font-size:clamp(34px,4.3vw,56px);line-height:1.08}
.demo-faq-intro p{margin-top:18px;color:var(--muted);line-height:1.7}
.demo-faq-list{border-top:1px solid var(--line)}
.demo-faq{border-bottom:1px solid var(--line)}
.demo-faq summary{
  min-height:67px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  list-style:none;
  cursor:pointer;
  font-size:16px;
  font-weight:900;
}
.demo-faq summary::-webkit-details-marker{display:none}
.demo-faq summary::after{content:"+";color:var(--accent);font-size:22px}
.demo-faq[open] summary::after{content:"−"}
.demo-faq p{padding:0 36px 22px 0;color:var(--muted);font-size:14px;line-height:1.7}
.demo-contact{
  display:grid;
  grid-template-columns:minmax(0,.76fr) minmax(390px,.62fr);
  gap:52px;
  align-items:start;
}
.demo-contact-copy h2{font-size:clamp(38px,5vw,64px);line-height:1.05}
.demo-contact-copy p{max-width:560px;margin-top:22px;color:#b7c3bc;line-height:1.7}
.demo-contact-meta{display:grid;gap:12px;margin-top:32px}
.demo-contact-meta span{color:#e0e8e3;font-size:14px;font-weight:800}
.demo-form{
  display:grid;
  gap:12px;
  padding:27px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:8px;
  background:rgba(255,255,255,.055);
}
.demo-form label{display:grid;gap:7px;color:#dce5e0;font-size:12px;font-weight:800}
.demo-form input,.demo-form textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.16);
  border-radius:6px;
  outline:0;
  color:#fff;
  background:rgba(255,255,255,.07);
  padding:13px;
}
.demo-form input:focus,.demo-form textarea:focus{border-color:var(--accent-2)}
.demo-form textarea{min-height:104px;resize:vertical}
.demo-form-note{color:#9daca4;font-size:11px;line-height:1.5}
.demo-form-message{min-height:20px;color:var(--accent-2);font-size:13px;font-weight:800}
.demo-footer{color:#d7e0db;background:#070c09}
.demo-footer-main{
  display:grid;
  grid-template-columns:1.2fr repeat(3,.58fr);
  gap:42px;
  padding-top:52px;
  padding-bottom:42px;
}
.demo-footer-brand strong{font-size:20px}
.demo-footer-brand p{max-width:330px;margin-top:17px;color:#899990;font-size:13px;line-height:1.65}
.demo-footer-column{display:grid;align-content:start;gap:11px}
.demo-footer-column small{margin-bottom:5px;color:var(--accent-2);font-size:10px;font-weight:950;text-transform:uppercase}
.demo-footer-column a{color:#b8c5be;text-decoration:none;font-size:12px}
.demo-footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:20px;
  padding:22px 0 30px;
  border-top:1px solid rgba(255,255,255,.1);
  color:#728078;
  font-size:11px;
}
.demo-back{
  position:fixed;
  z-index:55;
  left:14px;
  bottom:14px;
  min-height:40px;
  display:inline-flex;
  align-items:center;
  padding:0 14px;
  border:1px solid rgba(255,255,255,.2);
  border-radius:999px;
  color:#fff;
  background:rgba(11,16,13,.9);
  text-decoration:none;
  font-size:11px;
  font-weight:900;
  backdrop-filter:blur(12px);
}
.demo-reveal{opacity:1;transform:none}
body.demo-ready .demo-reveal{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .65s ease,transform .65s cubic-bezier(.16,1,.3,1);
}
body.demo-ready .demo-reveal.is-visible{opacity:1;transform:none}
@media(max-width:980px){
  .demo-nav-links{gap:14px}
  .demo-nav-links a{font-size:12px}
  .demo-usp-grid,.demo-process{grid-template-columns:repeat(2,1fr)}
  .demo-about,.demo-contact{grid-template-columns:1fr}
  .demo-services,.demo-reviews{grid-template-columns:1fr 1fr}
  .demo-footer-main{grid-template-columns:1.2fr repeat(2,.7fr)}
  .demo-footer-column:last-child{grid-column:2}
}
@media(max-width:720px){
  .demo-shell{width:min(100% - 28px,1180px)}
  .demo-notice{padding:7px 14px;font-size:10px}
  .demo-nav{min-height:68px}
  .demo-menu-button{display:block}
  .demo-nav-links{
    position:absolute;
    top:calc(100% + 1px);
    left:0;
    right:0;
    display:none;
    padding:12px 14px 18px;
    border-bottom:1px solid var(--line);
    background:var(--paper);
    box-shadow:0 22px 40px rgba(16,24,19,.12);
  }
  .demo-header.menu-open .demo-nav-links{display:grid}
  .demo-nav-links a{min-height:43px;display:flex;align-items:center;padding:0 12px;border-bottom:1px solid var(--line)}
  .demo-nav-links .demo-nav-cta{justify-content:center;border:0}
  .demo-hero{min-height:680px}
  .demo-hero::after{background:linear-gradient(0deg,rgba(7,12,9,.88),rgba(7,12,9,.28))}
  .demo-hero-content{padding-top:72px;padding-bottom:52px}
  .demo-hero h1{font-size:clamp(40px,13vw,60px)}
  .demo-hero p{font-size:16px}
  .demo-actions .demo-button{width:100%}
  .demo-trust-strip{grid-template-columns:1fr}
  .demo-trust-item{padding:14px 0}
  .demo-trust-item + .demo-trust-item{padding-left:0;border-left:0;border-top:1px solid rgba(255,255,255,.18)}
  .demo-section{padding:68px 0}
  .demo-section-head{grid-template-columns:1fr;gap:18px;margin-bottom:30px}
  .demo-usp-grid,.demo-services,.demo-process,.demo-reviews{grid-template-columns:1fr}
  .demo-usp{min-height:auto}
  .demo-number{margin-bottom:26px}
  .demo-about{gap:34px}
  .demo-about-image{min-width:0;aspect-ratio:4/3}
  .demo-step{padding:24px 0;border-top:1px solid var(--line)}
  .demo-step + .demo-step{padding-left:0;border-left:0}
  .demo-step h3{margin-top:16px}
  .demo-projects{grid-template-columns:1fr;grid-template-rows:auto;min-height:0}
  .demo-project,.demo-project:first-child{grid-row:auto;min-height:300px}
  .demo-faq-layout{grid-template-columns:1fr;gap:32px}
  .demo-contact{gap:34px}
  .demo-form{padding:20px}
  .demo-footer-main{grid-template-columns:1fr 1fr;gap:32px 20px}
  .demo-footer-brand{grid-column:1 / -1}
  .demo-footer-column:last-child{grid-column:auto}
  .demo-footer-bottom{padding-bottom:78px;flex-direction:column}
  .demo-label{bottom:12px;right:12px}
  .demo-back{display:none}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  body.demo-ready .demo-reveal{opacity:1;transform:none}
}
