/* ============================================================
   PLUS27PRO v3 — Premium Dark Design System
   #000000 base · #01BE58 brand green · Sharp corners
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800;900&family=Poppins:wght@300;400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap');

/* ============================================================
   TOKENS
   ============================================================ */
:root {
  --black:       #000000;
  --black-1:     #0A0A0A;
  --black-2:     #111111;
  --black-3:     #181818;
  --black-4:     #222222;
  --black-5:     #2A2A2A;

  --green:       #01BE58;
  --green-dim:   rgba(1,190,88,0.12);
  --green-glow:  rgba(1,190,88,0.25);
  --green-line:  rgba(1,190,88,0.4);

  --white:       #FFFFFF;
  --white-90:    rgba(255,255,255,0.90);
  --white-60:    rgba(255,255,255,0.60);
  --white-30:    rgba(255,255,255,0.30);
  --white-10:    rgba(255,255,255,0.10);
  --white-06:    rgba(255,255,255,0.06);
  --white-03:    rgba(255,255,255,0.03);

  --border:      rgba(255,255,255,0.08);
  --border-g:    rgba(1,190,88,0.3);

  --font-h:      'Manrope',     'Space Grotesk', sans-serif;
  --font-b:      'Poppins',     sans-serif;
  --font-g:      'Space Grotesk', sans-serif;

  --r0:  0px;
  --r2:  2px;
  --r4:  4px;
  --r8:  8px;
  --r12: 12px;

  --cont: 1320px;
  --pad:  clamp(20px,5vw,64px);

  --ease-out: cubic-bezier(0.16,1,0.3,1);
  --ease-in:  cubic-bezier(0.7,0,0.84,0);
  --t1: 0.15s;
  --t2: 0.3s;
  --t3: 0.5s;
  --t4: 0.8s;
}

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-b);
  background:var(--black);
  color:var(--white-90);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
::selection{background:var(--green);color:var(--black)}

/* ============================================================
   LAYOUT
   ============================================================ */
.container{
  max-width:var(--cont);
  margin:0 auto;
  padding:0 var(--pad);
  position:relative;
  z-index:1;
}
.section{padding:clamp(80px,10vw,140px) 0;position:relative}
.section--tight{padding:clamp(48px,6vw,80px) 0}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.h-xl{
  font-family:var(--font-h);
  font-size:clamp(3rem,6.5vw,6rem);
  font-weight:900;
  line-height:1.02;
  letter-spacing:-0.04em;
  color:var(--white);
}
.h-lg{
  font-family:var(--font-h);
  font-size:clamp(2.2rem,4.5vw,4rem);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-0.03em;
  color:var(--white);
}
.h-md{
  font-family:var(--font-h);
  font-size:clamp(1.6rem,3vw,2.4rem);
  font-weight:700;
  line-height:1.18;
  letter-spacing:-0.025em;
  color:var(--white);
}
.h-sm{
  font-family:var(--font-h);
  font-size:clamp(1.1rem,2vw,1.5rem);
  font-weight:700;
  line-height:1.3;
  letter-spacing:-0.02em;
  color:var(--white);
}
.eyebrow{
  font-family:var(--font-g);
  font-size:0.72rem;
  font-weight:600;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--green);
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:20px;
}
.eyebrow::before{
  content:'';
  width:28px;height:1px;
  background:var(--green);
}
.body-lg{font-size:clamp(1rem,1.6vw,1.15rem);line-height:1.75;color:var(--white-60);font-weight:400}
.body-md{font-size:0.95rem;line-height:1.7;color:var(--white-60)}
.body-sm{font-size:0.83rem;line-height:1.6;color:var(--white-30)}

.text-green{color:var(--green)}
.text-white{color:var(--white)}
.text-dim{color:var(--white-60)}

/* ============================================================
   BUTTONS — sharp corners, engineered
   ============================================================ */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 28px;
  font-family:var(--font-g);
  font-size:0.88rem;
  font-weight:600;
  letter-spacing:0.04em;
  text-transform:uppercase;
  border-radius:var(--r2);
  transition:all var(--t2) var(--ease-out);
  cursor:pointer;
  white-space:nowrap;
  position:relative;
  overflow:hidden;
}
.btn::after{
  content:'';
  position:absolute;
  inset:0;
  background:var(--white);
  opacity:0;
  transition:opacity var(--t1);
}
.btn:hover::after{opacity:0.05}

/* Primary — green fill */
.btn-primary{
  background:var(--green);
  color:var(--black);
  border:1px solid var(--green);
}
.btn-primary:hover{
  background:transparent;
  color:var(--green);
  transform:translateY(-1px);
  box-shadow:0 0 30px var(--green-glow);
}

/* Outline — green border */
.btn-outline{
  background:transparent;
  color:var(--green);
  border:1px solid var(--green);
}
.btn-outline:hover{
  background:var(--green);
  color:var(--black);
  transform:translateY(-1px);
}

/* Ghost — white border */
.btn-ghost{
  background:transparent;
  color:var(--white-90);
  border:1px solid var(--border);
}
.btn-ghost:hover{
  border-color:var(--white-30);
  color:var(--white);
}

/* Sizes */
.btn-lg{padding:18px 40px;font-size:0.92rem;letter-spacing:0.06em}
.btn-sm{padding:10px 20px;font-size:0.78rem}

/* Icon arrow */
.btn-arrow{gap:14px}
.btn-arrow .arrow{
  display:inline-block;
  transition:transform var(--t2) var(--ease-out);
}
.btn-arrow:hover .arrow{transform:translateX(4px)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  transition:background var(--t2),border-color var(--t2);
  padding:0;
}
.nav.scrolled{
  background:rgba(0,0,0,0.92);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(20px);
}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:72px;
  gap:24px;
}

/* Logo */
.nav-logo{
  display:flex;
  align-items:center;
  gap:2px;
  text-decoration:none;
  flex-shrink:0;
}
.nav-logo-mark{
  width:36px;height:36px;
  background:var(--green);
  border-radius:var(--r2);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-h);
  font-weight:900;font-size:0.78rem;
  color:var(--black);
  letter-spacing:-0.02em;
}
.nav-logo-text{
  font-family:var(--font-h);
  font-weight:900;
  font-size:1.2rem;
  letter-spacing:-0.04em;
  color:var(--white);
  padding-left:8px;
}
.nav-logo-text em{color:var(--green);font-style:normal}

/* Links */
.nav-links{
  display:flex;
  align-items:center;
  gap:2px;
  flex:1;
  justify-content:center;
}
.nav-links a{
  padding:8px 14px;
  font-family:var(--font-g);
  font-size:0.82rem;
  font-weight:500;
  color:var(--white-60);
  border-radius:var(--r2);
  transition:color var(--t1);
  letter-spacing:0.02em;
}
.nav-links a:hover,.nav-links a.active{color:var(--white)}

/* Dropdown */
.nav-dd{position:relative}
.nav-dd-menu{
  position:absolute;
  top:calc(100% + 12px);
  left:50%;
  transform:translateX(-50%) translateY(-6px);
  width:200px;
  background:var(--black-2);
  border:1px solid var(--border);
  border-radius:var(--r4);
  padding:6px;
  opacity:0;visibility:hidden;
  transition:all var(--t2) var(--ease-out);
}
.nav-dd:hover .nav-dd-menu{
  opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);
}
.nav-dd-menu a{
  display:block;padding:9px 12px;
  font-size:0.82rem;color:var(--white-60);
  border-radius:var(--r2);
  transition:color var(--t1),background var(--t1);
}
.nav-dd-menu a:hover{color:var(--green);background:var(--green-dim)}

/* Nav right */
.nav-right{display:flex;align-items:center;gap:12px;flex-shrink:0}

/* Hamburger */
.nav-burger{
  display:none;flex-direction:column;
  gap:5px;padding:8px;
  cursor:pointer;
}
.nav-burger span{
  display:block;width:22px;height:1.5px;
  background:var(--white);
  transition:all var(--t2);
}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile nav */
.nav-mobile{
  position:fixed;
  top:72px;left:0;right:0;bottom:0;
  background:var(--black);
  padding:32px var(--pad);
  transform:translateX(100%);
  transition:transform var(--t3) var(--ease-out);
  z-index:999;
  overflow-y:auto;
}
.nav-mobile.open{transform:translateX(0)}
.nav-mobile a{
  display:block;
  padding:16px 0;
  font-family:var(--font-h);
  font-size:1.3rem;font-weight:700;
  color:var(--white-60);
  border-bottom:1px solid var(--border);
  transition:color var(--t1),padding var(--t2);
}
.nav-mobile a:hover{color:var(--green);padding-left:8px}
.nav-mobile-cta{margin-top:32px;display:flex;flex-direction:column;gap:12px}

/* ============================================================
   HERO — VIDEO + SPLIT FORM
   ============================================================ */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;
  align-items:center;
  overflow:hidden;
  padding-top:72px;
}

/* Video background */
.hero-video-wrap{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero-video-wrap video{
  width:100%;height:100%;
  object-fit:cover;
  opacity:0.25;
}
.hero-video-wrap::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(
    to right,
    rgba(0,0,0,0.96) 0%,
    rgba(0,0,0,0.7) 50%,
    rgba(0,0,0,0.4) 100%
  );
}

/* Animated grid overlay */
.hero-grid-bg{
  position:absolute;inset:0;z-index:1;
  background-image:
    linear-gradient(rgba(1,190,88,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(1,190,88,0.04) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 0%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 0%,transparent 75%);
}

.hero-inner{
  position:relative;z-index:2;
  width:100%;
  display:grid;
  grid-template-columns:1fr 460px;
  gap:60px;
  align-items:center;
  padding:80px 0 60px;
}

/* Hero left */
.hero-left{}
.hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px 6px 8px;
  background:var(--green-dim);
  border:1px solid var(--green-line);
  border-radius:var(--r2);
  margin-bottom:28px;
}
.hero-tag-dot{
  width:6px;height:6px;
  border-radius:50%;
  background:var(--green);
  animation:blink 2s ease infinite;
}
@keyframes blink{0%,100%{opacity:1;box-shadow:0 0 8px var(--green)}50%{opacity:0.4;box-shadow:none}}
.hero-tag span{
  font-family:var(--font-g);font-size:0.72rem;
  font-weight:600;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--green);
}

.hero-headline{margin-bottom:24px}
.hero-headline mark{
  background:none;
  color:var(--green);
  -webkit-text-fill-color:var(--green);
}

.hero-sub{
  font-size:clamp(1rem,1.4vw,1.1rem);
  color:var(--white-60);
  line-height:1.75;
  max-width:540px;
  margin-bottom:36px;
}

.hero-ctas{
  display:flex;align-items:center;
  flex-wrap:wrap;gap:14px;
  margin-bottom:48px;
}

/* Social proof strip under CTAs */
.hero-proof{
  display:flex;align-items:center;gap:20px;
  flex-wrap:wrap;
}
.hero-proof-avatars{
  display:flex;
}
.hero-proof-avatars img,
.hero-proof-avatar{
  width:36px;height:36px;
  border-radius:50%;
  border:2px solid var(--black);
  margin-left:-10px;
  background:var(--black-3);
  display:flex;align-items:center;justify-content:center;
  font-size:0.7rem;font-weight:700;
  color:var(--white-60);
}
.hero-proof-avatars :first-child{margin-left:0}
.hero-proof-text{
  font-size:0.82rem;color:var(--white-60);
  font-family:var(--font-g);
}
.hero-proof-text strong{color:var(--white);font-weight:600}
.hero-proof-stars{color:var(--green);letter-spacing:2px;font-size:0.75rem}

/* ============================================================
   HERO FORM CARD
   ============================================================ */
.hero-form-card{
  background:var(--black-1);
  border:1px solid var(--border);
  border-radius:var(--r4);
  padding:36px 32px;
  position:relative;
}
.hero-form-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:2px;
  background:var(--green);
  border-radius:var(--r4) var(--r4) 0 0;
}
.hero-form-title{
  font-family:var(--font-h);font-weight:800;
  font-size:1.25rem;letter-spacing:-0.02em;
  color:var(--white);margin-bottom:4px;
}
.hero-form-sub{font-size:0.8rem;color:var(--white-30);margin-bottom:24px}
.hero-form-sub span{color:var(--green)}

/* Form inputs */
.form-row{display:grid;gap:12px}
.form-row.cols-2{grid-template-columns:1fr 1fr}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{
  font-family:var(--font-g);font-size:0.7rem;
  font-weight:600;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--white-30);
}
.form-input,
.form-select,
.form-textarea{
  width:100%;
  padding:11px 14px;
  background:var(--black-2);
  border:1px solid var(--border);
  border-radius:var(--r2);
  color:var(--white-90);
  font-family:var(--font-b);
  font-size:0.88rem;
  transition:border-color var(--t1),box-shadow var(--t1);
  outline:none;
  appearance:none;
  -webkit-appearance:none;
}
.form-input::placeholder,.form-textarea::placeholder{color:var(--white-30)}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:var(--green-line);
  box-shadow:0 0 0 3px var(--green-dim);
}
.form-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(255,255,255,0.3)' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:40px;
  cursor:pointer;
}
.form-select option{background:var(--black-2)}
.form-textarea{resize:vertical;min-height:90px;line-height:1.55}
.form-submit{width:100%;margin-top:8px}

/* Form success state */
.form-success{
  display:none;text-align:center;
  padding:32px 20px;
}
.form-success.show{display:block}
.form-success-icon{font-size:2.5rem;margin-bottom:12px}
.form-success-title{
  font-family:var(--font-h);font-weight:800;
  font-size:1.2rem;margin-bottom:6px;color:var(--white);
}

/* ============================================================
   MARQUEE / LOGO STRIP
   ============================================================ */
.marquee-section{
  padding:28px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--black-1);
  overflow:hidden;
}
.marquee-label{
  font-family:var(--font-g);font-size:0.68rem;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--white-30);text-align:center;
  margin-bottom:20px;
}
.marquee-track{
  display:flex;gap:56px;
  width:max-content;
  animation:marquee 30s linear infinite;
}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-logo{
  display:flex;align-items:center;gap:10px;
  white-space:nowrap;
  font-family:var(--font-h);font-size:0.9rem;
  font-weight:700;letter-spacing:-0.01em;
  color:var(--white-30);
  transition:color var(--t1);
  flex-shrink:0;
}
.marquee-logo:hover{color:var(--white-60)}
.marquee-logo-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--green);opacity:0.6;
  flex-shrink:0;
}
.marquee-overflow{
  overflow:hidden;
  position:relative;
}
.marquee-overflow::before,
.marquee-overflow::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;
}
.marquee-overflow::before{left:0;background:linear-gradient(90deg,var(--black-1),transparent)}
.marquee-overflow::after{right:0;background:linear-gradient(-90deg,var(--black-1),transparent)}

/* ============================================================
   STATS ROW
   ============================================================ */
.stats-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border:1px solid var(--border);
  border-radius:var(--r4);
  overflow:hidden;
  background:var(--black-1);
}
.stat-block{
  padding:40px 32px;
  border-right:1px solid var(--border);
  transition:background var(--t2);
  position:relative;
}
.stat-block:last-child{border-right:none}
.stat-block:hover{background:var(--black-2)}
.stat-block::after{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:2px;
  background:var(--green);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform var(--t3) var(--ease-out);
}
.stat-block:hover::after{transform:scaleX(1)}
.stat-num{
  font-family:var(--font-h);
  font-size:clamp(2.2rem,3.5vw,3.5rem);
  font-weight:900;letter-spacing:-0.05em;
  color:var(--green);line-height:1;
  margin-bottom:6px;
  display:block;
}
.stat-label{font-size:0.82rem;color:var(--white-30);font-family:var(--font-g)}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.portfolio-filters{
  display:flex;align-items:center;
  flex-wrap:wrap;gap:8px;
  margin-bottom:48px;
}
.pf-btn{
  padding:8px 18px;
  font-family:var(--font-g);font-size:0.78rem;
  font-weight:600;letter-spacing:0.06em;
  text-transform:uppercase;
  border:1px solid var(--border);
  border-radius:var(--r2);
  color:var(--white-60);
  background:transparent;
  cursor:pointer;
  transition:all var(--t2);
}
.pf-btn.active,.pf-btn:hover{
  border-color:var(--green);
  color:var(--green);
  background:var(--green-dim);
}

/* Portfolio grid */
.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:2px;
}
.pf-item{
  position:relative;
  overflow:hidden;
  cursor:pointer;
  background:var(--black-2);
}
/* Feature (large) */
.pf-item--lg{grid-column:span 8;grid-row:span 2}
.pf-item--md{grid-column:span 4;grid-row:span 1}
.pf-item--sm{grid-column:span 4;grid-row:span 1}

.pf-item-img{
  width:100%;height:100%;
  min-height:300px;
  object-fit:cover;
  transition:transform var(--t4) var(--ease-out);
  display:block;
}
.pf-item--lg .pf-item-img{min-height:480px}

/* Placeholder when no real image */
.pf-placeholder{
  width:100%;height:100%;
  min-height:300px;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:12px;
  background:var(--black-2);
  position:relative;
  overflow:hidden;
}
.pf-item--lg .pf-placeholder{min-height:480px}

.pf-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,0);
  display:flex;flex-direction:column;
  justify-content:flex-end;
  padding:28px;
  transition:background var(--t3);
}
.pf-item:hover .pf-overlay{background:rgba(0,0,0,0.75)}
.pf-item:hover .pf-item-img{transform:scale(1.04)}

.pf-meta{
  transform:translateY(20px);
  opacity:0;
  transition:all var(--t3) var(--ease-out);
}
.pf-item:hover .pf-meta{transform:translateY(0);opacity:1}
.pf-client{
  font-family:var(--font-g);font-size:0.7rem;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--green);margin-bottom:4px;
}
.pf-title{
  font-family:var(--font-h);font-weight:800;
  font-size:1.2rem;letter-spacing:-0.02em;
  color:var(--white);margin-bottom:8px;
}
.pf-tags{display:flex;flex-wrap:wrap;gap:6px}
.pf-tag{
  padding:3px 10px;
  border:1px solid var(--border);
  border-radius:var(--r2);
  font-size:0.7rem;font-family:var(--font-g);
  color:var(--white-60);letter-spacing:0.04em;
}

/* ============================================================
   SERVICE CARDS — horizontal layout
   ============================================================ */
.service-list{display:flex;flex-direction:column;gap:1px}
.service-item{
  display:grid;
  grid-template-columns:80px 1fr auto;
  align-items:center;
  gap:32px;
  padding:32px 0;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:padding var(--t2);
  position:relative;
}
.service-item::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;
  width:0;background:var(--green);
  transition:width var(--t2) var(--ease-out);
}
.service-item:hover{padding-left:16px}
.service-item:hover::before{width:2px}

.service-num{
  font-family:var(--font-h);
  font-size:3rem;font-weight:900;
  letter-spacing:-0.05em;
  color:var(--border);
  transition:color var(--t2);
  text-align:right;
  line-height:1;
}
.service-item:hover .service-num{color:var(--green);opacity:0.3}
.service-body h3{
  font-family:var(--font-h);font-weight:800;
  font-size:1.3rem;letter-spacing:-0.025em;
  color:var(--white);margin-bottom:6px;
  transition:color var(--t1);
}
.service-item:hover h3{color:var(--green)}
.service-body p{font-size:0.88rem;color:var(--white-30);line-height:1.55;max-width:500px}
.service-arrow{
  width:40px;height:40px;
  border:1px solid var(--border);
  border-radius:var(--r2);
  display:flex;align-items:center;justify-content:center;
  color:var(--white-30);font-size:1rem;
  transition:all var(--t2);flex-shrink:0;
}
.service-item:hover .service-arrow{
  border-color:var(--green);
  color:var(--green);
  background:var(--green-dim);
  transform:rotate(-45deg);
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonial-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  border:1px solid var(--border);
  border-radius:var(--r4);
  overflow:hidden;
  background:var(--border);
}
.testimonial-card{
  background:var(--black-1);
  padding:40px 36px;
  position:relative;
  transition:background var(--t2);
}
.testimonial-card:hover{background:var(--black-2)}
.testimonial-quote{
  font-size:3rem;line-height:1;
  color:var(--green);opacity:0.4;
  font-family:Georgia,serif;
  margin-bottom:16px;
  display:block;
}
.testimonial-text{
  font-size:0.95rem;line-height:1.75;
  color:var(--white-60);
  font-style:italic;
  margin-bottom:28px;
}
.testimonial-author{display:flex;align-items:center;gap:14px}
.t-avatar{
  width:44px;height:44px;
  border-radius:var(--r2);
  background:var(--green);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-h);font-weight:800;
  font-size:0.95rem;color:var(--black);
  flex-shrink:0;
}
.t-name{
  font-family:var(--font-h);font-weight:700;
  font-size:0.9rem;color:var(--white);margin-bottom:2px;
}
.t-role{font-size:0.75rem;color:var(--white-30)}
.t-stars{color:var(--green);font-size:0.7rem;letter-spacing:2px;margin-bottom:4px}

/* ============================================================
   PROCESS
   ============================================================ */
.process-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--r4);
  overflow:hidden;
}
.process-step{
  background:var(--black-1);
  padding:40px 32px;
  transition:background var(--t2);
  position:relative;
}
.process-step:hover{background:var(--black-2)}
.process-step::after{
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;height:2px;
  background:var(--green);
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--t3) var(--ease-out);
}
.process-step:hover::after{transform:scaleX(1)}
.process-step-num{
  font-family:var(--font-h);font-size:3.5rem;
  font-weight:900;letter-spacing:-0.06em;
  color:var(--border);line-height:1;
  margin-bottom:20px;
  transition:color var(--t2);
}
.process-step:hover .process-step-num{color:var(--green);opacity:0.25}
.process-step h4{
  font-family:var(--font-h);font-weight:800;
  font-size:1rem;letter-spacing:-0.01em;
  color:var(--white);margin-bottom:8px;
}
.process-step p{font-size:0.83rem;color:var(--white-30);line-height:1.6}

/* ============================================================
   BLOG CARD
   ============================================================ */
.blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--r4);
  overflow:hidden;
}
.blog-card{
  background:var(--black-1);
  transition:background var(--t2);
  display:flex;flex-direction:column;
}
.blog-card:hover{background:var(--black-2)}
.blog-img{
  aspect-ratio:16/9;
  overflow:hidden;
  background:var(--black-3);
}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--t4)}
.blog-card:hover .blog-img img{transform:scale(1.04)}
.blog-body{padding:28px;flex:1;display:flex;flex-direction:column}
.blog-cat{
  font-family:var(--font-g);font-size:0.68rem;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--green);margin-bottom:10px;
}
.blog-title{
  font-family:var(--font-h);font-weight:800;
  font-size:1.05rem;letter-spacing:-0.02em;
  color:var(--white);line-height:1.3;
  margin-bottom:10px;
  transition:color var(--t1);
  flex:1;
}
.blog-card:hover .blog-title{color:var(--green)}
.blog-meta{
  display:flex;align-items:center;gap:12px;
  font-size:0.72rem;color:var(--white-30);
  font-family:var(--font-g);margin-top:16px;
}
.blog-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--white-30)}

/* ============================================================
   LOCATION PAGE GRID
   ============================================================ */
.location-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--r4);
  overflow:hidden;
}
.location-card{
  background:var(--black-1);
  padding:28px 24px;
  transition:background var(--t2);
  position:relative;
  overflow:hidden;
}
.location-card::before{
  content:'';position:absolute;
  top:0;left:0;right:0;height:2px;
  background:var(--green);
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--t3) var(--ease-out);
}
.location-card:hover{background:var(--black-2)}
.location-card:hover::before{transform:scaleX(1)}
.location-city{
  font-family:var(--font-h);font-weight:800;
  font-size:1.1rem;letter-spacing:-0.02em;
  color:var(--white);margin-bottom:4px;
}
.location-region{font-size:0.75rem;color:var(--green);font-family:var(--font-g);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:12px}
.location-services{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:16px}
.loc-tag{
  padding:2px 8px;border:1px solid var(--border);
  border-radius:var(--r2);font-size:0.68rem;
  color:var(--white-30);font-family:var(--font-g);
}
.location-link{
  font-family:var(--font-g);font-size:0.75rem;
  color:var(--green);letter-spacing:0.04em;
  display:flex;align-items:center;gap:6px;
  transition:gap var(--t2);
}
.location-card:hover .location-link{gap:10px}

/* ============================================================
   FAQ
   ============================================================ */
.faq-stack{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r4);overflow:hidden}
.faq-item{background:var(--black-1)}
.faq-item.open{background:var(--black-2)}
.faq-q{
  width:100%;display:flex;align-items:center;
  justify-content:space-between;gap:20px;
  padding:22px 28px;
  font-family:var(--font-h);font-weight:700;
  font-size:0.95rem;letter-spacing:-0.01em;
  color:var(--white-90);text-align:left;
  cursor:pointer;
  transition:color var(--t1);
}
.faq-q:hover{color:var(--green)}
.faq-item.open .faq-q{color:var(--green)}
.faq-icon{
  width:24px;height:24px;
  border:1px solid var(--border);
  border-radius:var(--r2);
  display:flex;align-items:center;justify-content:center;
  font-size:0.75rem;color:var(--white-30);
  flex-shrink:0;
  transition:all var(--t2);
}
.faq-item.open .faq-icon{
  border-color:var(--green);
  color:var(--green);
  transform:rotate(45deg);
}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height var(--t3) var(--ease-out),padding var(--t2);
  font-size:0.9rem;line-height:1.75;
  color:var(--white-60);
}
.faq-item.open .faq-a{max-height:300px;padding:0 28px 22px}

/* ============================================================
   CTA SECTION
   ============================================================ */
.cta-section{
  background:var(--black-1);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:clamp(80px,10vw,140px) 0;
  position:relative;
  overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;
  top:50%;left:50%;
  width:600px;height:600px;
  background:radial-gradient(circle,var(--green-dim) 0%,transparent 65%);
  transform:translate(-50%,-50%);
  pointer-events:none;
}
.cta-inner{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:60px;align-items:center;
  position:relative;z-index:1;
}
.cta-title{margin-bottom:16px}
.cta-sub{max-width:520px;margin-bottom:32px}
.cta-btns{display:flex;gap:14px;flex-wrap:wrap}
.cta-form-wrap{
  background:var(--black-2);
  border:1px solid var(--border);
  border-radius:var(--r4);
  padding:32px 28px;
  position:relative;
}
.cta-form-wrap::before{
  content:'';position:absolute;
  top:0;left:0;right:0;height:2px;
  background:var(--green);
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--black-1);
  border-top:1px solid var(--border);
  padding:clamp(60px,8vw,100px) 0 0;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:60px;
}
.footer-brand p{font-size:0.88rem;color:var(--white-30);line-height:1.7;margin:16px 0 24px;max-width:280px}
.footer-address{
  display:flex;gap:10px;align-items:flex-start;
  padding:14px 16px;
  background:var(--black-2);
  border:1px solid var(--border);
  border-radius:var(--r4);
  margin-bottom:20px;
  text-decoration:none;
  transition:border-color var(--t1);
}
.footer-address:hover{border-color:var(--green-line)}
.footer-address-icon{font-size:1rem;flex-shrink:0;margin-top:2px}
.footer-address-text{font-size:0.8rem;color:var(--white-30);line-height:1.5}
.footer-address-text strong{color:var(--white-60);display:block;font-size:0.82rem;margin-bottom:2px}
.footer-address-link{font-size:0.68rem;color:var(--green);font-family:var(--font-g);letter-spacing:0.08em;text-transform:uppercase;margin-top:4px;display:block}

.footer-social{display:flex;gap:8px;margin-top:20px}
.footer-social a{
  width:34px;height:34px;
  border:1px solid var(--border);
  border-radius:var(--r2);
  display:flex;align-items:center;justify-content:center;
  font-size:0.78rem;color:var(--white-30);
  transition:all var(--t1);font-family:var(--font-g);font-weight:600;
}
.footer-social a:hover{border-color:var(--green);color:var(--green);background:var(--green-dim)}

.footer-col h5{
  font-family:var(--font-h);font-weight:700;
  font-size:0.82rem;letter-spacing:0.04em;
  color:var(--white);margin-bottom:18px;
  text-transform:uppercase;
}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul a{
  font-size:0.83rem;color:var(--white-30);
  transition:color var(--t1),padding var(--t2);
  display:block;
}
.footer-col ul a:hover{color:var(--green);padding-left:4px}

.footer-bottom{
  padding:24px 0;
  border-top:1px solid var(--border);
  display:flex;align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;gap:12px;
}
.footer-bottom p{font-size:0.78rem;color:var(--white-30)}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{font-size:0.78rem;color:var(--white-30);transition:color var(--t1)}
.footer-bottom-links a:hover{color:var(--green)}

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-btn{
  position:fixed;
  bottom:28px;right:28px;
  z-index:900;
  width:54px;height:54px;
  background:var(--green);
  border-radius:var(--r2);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;
  box-shadow:0 4px 24px rgba(1,190,88,0.4);
  transition:all var(--t2);
  text-decoration:none;
}
.wa-btn:hover{
  transform:scale(1.08) translateY(-2px);
  box-shadow:0 8px 36px rgba(1,190,88,0.6);
}
.wa-btn-tip{
  position:absolute;
  right:calc(100% + 12px);
  background:var(--black-2);
  border:1px solid var(--border);
  color:var(--white);
  font-size:0.78rem;font-weight:600;
  white-space:nowrap;padding:6px 12px;
  border-radius:var(--r2);
  opacity:0;pointer-events:none;
  transition:opacity var(--t1);
  font-family:var(--font-g);
}
.wa-btn:hover .wa-btn-tip{opacity:1}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
[data-reveal]{
  opacity:0;
  transform:translateY(28px);
  transition:opacity var(--t4) var(--ease-out),transform var(--t4) var(--ease-out);
}
[data-reveal].visible{opacity:1;transform:translateY(0)}
[data-reveal][data-delay="1"]{transition-delay:.1s}
[data-reveal][data-delay="2"]{transition-delay:.2s}
[data-reveal][data-delay="3"]{transition-delay:.3s}
[data-reveal][data-delay="4"]{transition-delay:.4s}
[data-reveal][data-delay="5"]{transition-delay:.5s}
[data-reveal][data-delay="6"]{transition-delay:.6s}

/* ============================================================
   DIVIDER
   ============================================================ */
.divider{
  height:1px;
  background:var(--border);
}
.divider--green{
  background:linear-gradient(90deg,transparent,var(--green),transparent);
  opacity:0.3;
}

/* ============================================================
   TAGS / BADGES
   ============================================================ */
.tag{
  display:inline-block;
  padding:3px 10px;
  border:1px solid var(--border);
  border-radius:var(--r2);
  font-family:var(--font-g);font-size:0.68rem;
  font-weight:600;letter-spacing:0.06em;
  text-transform:uppercase;color:var(--white-30);
}
.tag--green{border-color:var(--green-line);color:var(--green);background:var(--green-dim)}

/* ============================================================
   EXIT INTENT POPUP
   ============================================================ */
.exit-popup{
  position:fixed;inset:0;
  z-index:9999;
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;visibility:hidden;
  transition:all var(--t3);
}
.exit-popup.show{opacity:1;visibility:visible}
.exit-popup-bg{
  position:absolute;inset:0;
  background:rgba(0,0,0,0.88);
  backdrop-filter:blur(8px);
  cursor:pointer;
}
.exit-popup-card{
  position:relative;z-index:1;
  background:var(--black-1);
  border:1px solid var(--border);
  border-radius:var(--r4);
  padding:48px 40px;
  max-width:520px;width:100%;
  text-align:center;
}
.exit-popup-card::before{
  content:'';position:absolute;
  top:0;left:0;right:0;height:2px;
  background:var(--green);border-radius:var(--r4) var(--r4) 0 0;
}
.exit-popup-close{
  position:absolute;top:16px;right:16px;
  width:32px;height:32px;
  border:1px solid var(--border);
  border-radius:var(--r2);
  display:flex;align-items:center;justify-content:center;
  color:var(--white-30);font-size:0.9rem;
  cursor:pointer;
  transition:all var(--t1);
}
.exit-popup-close:hover{border-color:var(--green);color:var(--green)}
.exit-popup h3{
  font-family:var(--font-h);font-weight:900;
  font-size:1.6rem;letter-spacing:-0.03em;
  color:var(--white);margin-bottom:8px;
}
.exit-popup p{font-size:0.9rem;color:var(--white-30);margin-bottom:28px;line-height:1.6}
.exit-popup-green{color:var(--green)}

/* ============================================================
   UTILITY
   ============================================================ */
.text-center{text-align:center}
.mt-sm{margin-top:12px}
.mt-md{margin-top:24px}
.mt-lg{margin-top:40px}
.mb-sm{margin-bottom:12px}
.mb-md{margin-bottom:24px}
.mb-lg{margin-bottom:40px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.flex-center{display:flex;align-items:center;justify-content:center}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
