:root{
  --bg:#070a13;
  --bg2:#0b1735;
  --card:rgba(255,255,255,.06);
  --card2:rgba(13,42,118,.16);
  --text:#eaf0ff;
  --muted:rgba(234,240,255,.72);
  --line:rgba(255,255,255,.12);
  --shadow:0 18px 60px rgba(0,0,0,.45);
  --brand1:#f97220;
  --brand2:#0d2a76;
  --brand3:#ff9618;
  --brand4:#0653ab;
  --radius:18px;
  --radius2:28px;
  --container:1120px;
  --ease:cubic-bezier(.2,.85,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{max-width:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
             radial-gradient(900px 560px at 86% 10%, rgba(249,114,32,.10), transparent 62%),
             linear-gradient(180deg, #060606 0%, #0b0b0b 45%, #050505 100%);
  color:var(--text);
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
svg,video,canvas,iframe{max-width:100%}
button,input,textarea,select{font:inherit}
h1,h2,h3,p,li{overflow-wrap:anywhere}

.container{width:min(var(--container), calc(100% - 40px)); margin:0 auto}

.skip-link{
  position:absolute; left:-999px; top:12px;
  padding:10px 14px; border-radius:999px;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18);
  color:var(--text); z-index:1000;
}
.skip-link:focus{left:12px}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 18px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  color:var(--text);
  box-shadow:0 12px 30px rgba(0,0,0,.28);
  transition:transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
  will-change:transform;
}
.btn:hover{transform:translateY(-1px); border-color:rgba(255,255,255,.26); background:rgba(255,255,255,.09)}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline:2px solid rgba(255,150,24,.75); outline-offset:2px}
.btn-lg{padding:14px 22px; font-weight:700}
.btn-primary{
  border-color:rgba(255,150,24,.45);
  background:linear-gradient(135deg, rgba(255,150,24,.95), rgba(249,114,32,.92));
  color:#120a05;
}
.btn-primary:hover{box-shadow:0 20px 55px rgba(255,150,24,.22), 0 12px 30px rgba(0,0,0,.35)}
.btn-secondary{
  border-color:rgba(6,83,171,.45);
  background:linear-gradient(135deg, rgba(6,83,171,.85), rgba(13,42,118,.85));
}
.btn-outline{background:transparent; border-color:rgba(255,255,255,.22)}
.btn-wa{
  position:relative;
  padding:11px 16px;
  background:rgba(255,255,255,.06);
  border-color:rgba(255,150,24,.25);
}
.site-header .btn-wa{
  background:linear-gradient(135deg, rgba(255,150,24,.96), rgba(249,114,32,.94));
  border-color:rgba(249,114,32,.50);
  color:#120a05;
  box-shadow:0 14px 32px rgba(0,0,0,.12);
}
.site-header .btn-wa:hover{
  box-shadow:0 20px 48px rgba(249,114,32,.22), 0 14px 32px rgba(0,0,0,.14);
}
.btn-wa-dot{
  width:8px; height:8px; border-radius:999px;
  background:linear-gradient(135deg, var(--brand3), var(--brand1));
  box-shadow:0 0 0 0 rgba(255,150,24,.55);
  animation:pulse 2.1s var(--ease) infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(255,150,24,.55)}
  60%{box-shadow:0 0 0 12px rgba(255,150,24,0)}
  100%{box-shadow:0 0 0 0 rgba(255,150,24,0)}
}

.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid rgba(0,0,0,.08);
  box-shadow:0 18px 50px rgba(0,0,0,.10);
  color:#0b0f1a;
}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:10px 0}
.header-inner{min-width:0}
.brand{display:flex; align-items:center}
.brand-logo{height:58px; width:auto; filter:drop-shadow(0 12px 24px rgba(0,0,0,.16))}

.nav{display:flex; align-items:center; gap:18px}
.nav{min-width:0}
.nav-link{
  font-weight:600; font-size:14px;
  color:rgba(13,42,118,.92);
  padding:10px 10px;
  border-radius:999px;
  text-transform:uppercase;
  letter-spacing:.08em;
  line-height:1.2;
  white-space:nowrap;
  transition:background .25s var(--ease), color .25s var(--ease);
}
.nav-link:hover{background:rgba(13,42,118,.08); color:rgba(13,42,118,1)}
.nav-link.is-active{background:rgba(13,42,118,.10); border:1px solid rgba(13,42,118,.22)}

.header-actions{display:flex; align-items:center; gap:10px}
.social{
  width:38px; height:38px;
  display:grid; place-items:center;
  border-radius:999px;
  background:rgba(0,0,0,.04);
  border:1px solid rgba(0,0,0,.10);
  transition:transform .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.social:hover{transform:translateY(-1px); border-color:rgba(0,0,0,.16); background:rgba(0,0,0,.06)}

.nav-toggle{
  display:none;
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.12);
  background:rgba(0,0,0,.04);
}
.nav-toggle span{
  display:block;
  width:20px; height:2px;
  background:rgba(13,42,118,.92);
  margin:5px auto;
  border-radius:2px;
  transition:transform .25s var(--ease), opacity .25s var(--ease);
}
.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-open .nav-toggle span:nth-child(2){opacity:0}
.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.hero{
  position:relative;
  min-height:92vh;
  display:grid;
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:-30px;
  background-image:url("../Imghero.png");
  background-image:image-set(
    url("../Imghero.jpg") type("image/jpeg") 1x,
    url("../Imghero.png") type("image/png") 1x
  );
  background-size:cover;
  background-position:center;
  filter:saturate(1.05) contrast(1.03);
  transform:translateZ(0);
  will-change:transform;
}
.hero-overlay{
  position:absolute; inset:0;
  background:
             radial-gradient(700px 420px at 86% 22%, rgba(255,150,24,.16), transparent 58%),
             linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.86));
}
.hero-inner{position:relative; display:grid; place-items:center; padding:90px 0 70px}
.hero-glass{
  width:min(860px, 100%);
  border-radius:var(--radius2);
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  backdrop-filter:blur(14px) saturate(140%);
  box-shadow:var(--shadow);
  padding:28px 26px;
}
.hero-kicker{
  margin:0 0 10px;
  display:inline-flex; align-items:center; gap:10px;
  color:rgba(234,240,255,.78);
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:12px;
}
.hero-title{
  margin:0 0 12px;
  font-size:clamp(34px, 4.2vw, 56px);
  line-height:1.03;
  letter-spacing:-.02em;
}
.hero-subtitle{
  margin:0 0 18px;
  color:var(--muted);
  font-size:clamp(15px, 1.6vw, 18px);
  line-height:1.6;
}
.hero-cta{display:flex; flex-wrap:wrap; gap:12px}
.hero-badges{display:flex; flex-wrap:wrap; gap:10px; margin-top:18px}
.badge{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:rgba(234,240,255,.82);
  font-weight:600;
  font-size:13px;
}
.badge-dot{
  width:10px; height:10px; border-radius:999px;
  background:linear-gradient(135deg, var(--brand3), var(--brand1));
  box-shadow:0 0 0 6px rgba(255,150,24,.10);
}

.scroll-hint{
  position:absolute;
  left:50%;
  bottom:26px;
  transform:translateX(-50%);
  width:34px; height:54px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.05);
  display:grid; place-items:center;
  transition:transform .25s var(--ease), background .25s var(--ease);
}
.scroll-hint:hover{transform:translateX(-50%) translateY(-1px); background:rgba(255,255,255,.08)}
.scroll-hint span{
  width:6px; height:6px; border-radius:999px;
  background:rgba(255,255,255,.9);
  box-shadow:0 0 0 0 rgba(255,255,255,.35);
  animation:scrollDot 1.9s var(--ease) infinite;
}
@keyframes scrollDot{
  0%{transform:translateY(-10px); opacity:.2}
  30%{opacity:1}
  60%{transform:translateY(10px); opacity:.2}
  100%{transform:translateY(10px); opacity:.1}
}

.section{
  padding:84px 0;
  position:relative;
}
.section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(0,0,0,.55);
  opacity:.55;
}
.section-soft{
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
}
.section-dark{
  background:
             radial-gradient(900px 520px at 88% 18%, rgba(249,114,32,.10), transparent 64%),
             linear-gradient(180deg, rgba(0,0,0,.40), rgba(0,0,0,.84));
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(0,0,0,.72);
}
.section-head{max-width:820px}
.section-head h2{
  margin:0 0 10px;
  font-size:clamp(26px, 3vw, 38px);
  letter-spacing:-.02em;
}
.section-head p{margin:0; color:var(--muted); line-height:1.7}

.services-grid{
  margin-top:26px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
}
.card{
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow:0 18px 60px rgba(0,0,0,.36);
}
.service-card{
  padding:18px 16px;
  transition:transform .28s var(--ease), border-color .28s var(--ease), background .28s var(--ease);
  position:relative;
  overflow:hidden;
}
.service-card::before{
  content:"";
  position:absolute; inset:-60px;
  background:radial-gradient(320px 240px at 20% 20%, rgba(255,150,24,.14), transparent 62%),
             radial-gradient(320px 240px at 80% 40%, rgba(255,255,255,.06), transparent 62%);
  opacity:.65;
  transform:translateY(16px);
  transition:transform .28s var(--ease), opacity .28s var(--ease);
}
.service-card > *{position:relative}
.service-media{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  margin:0 0 12px;
}
.service-media img{
  width:100%;
  height:132px;
  object-fit:cover;
  transform:scale(1.02);
  transition:transform .35s var(--ease), filter .35s var(--ease);
  will-change:transform;
}
.service-card:hover .service-media img{
  transform:scale(1.06);
  filter:saturate(1.04) contrast(1.02);
}
.service-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,150,24,.26);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
}
.service-card:hover::before{transform:translateY(0); opacity:.9}
.service-icon{
  width:42px; height:42px;
  border-radius:14px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(255,150,24,.22), rgba(255,255,255,.08));
  border:1px solid rgba(255,150,24,.22);
  color:rgba(255,255,255,.92);
  margin-bottom:12px;
}
.service-card h3{margin:0 0 8px; font-size:16px}
.service-card p{margin:0; color:var(--muted); line-height:1.65; font-size:14px}

.project-split{
  margin-top:26px;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
  align-items:start;
}
.project-copy,.project-cards{min-width:0}
.feature-list{list-style:none; padding:0; margin:0 0 18px; display:grid; gap:12px}
.feature-list li{
  padding:12px 12px;
  display:grid;
  grid-template-columns:88px 1fr;
  gap:14px;
  align-items:center;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:rgba(234,240,255,.86);
  line-height:1.6;
  transition:transform .28s var(--ease), border-color .28s var(--ease), background .28s var(--ease);
}
.feature-list li:hover{
  transform:translateY(-2px);
  border-color:rgba(255,150,24,.22);
  background:rgba(255,255,255,.06);
}
.feature-media{
  display:block;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
}
.feature-media img{
  width:100%;
  height:66px;
  object-fit:cover;
  transform:scale(1.02);
  transition:transform .35s var(--ease), filter .35s var(--ease);
  will-change:transform;
}
.feature-list li:hover .feature-media img{transform:scale(1.08); filter:saturate(1.04) contrast(1.02)}
.feature-body{display:block}
.feature-body strong{color:rgba(255,255,255,.95)}
.project-cta{display:flex; flex-wrap:wrap; gap:12px}

.project-cards{display:grid; gap:14px}
.project-mini{
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  padding:18px 16px;
  transition:transform .28s var(--ease), border-color .28s var(--ease);
}
.project-mini:hover{transform:translateY(-2px); border-color:rgba(255,150,24,.20)}
.mini-top{display:flex; align-items:center; justify-content:space-between; margin-bottom:10px}
.mini-media{
  margin:10px 0 12px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
}
.mini-media img{
  width:100%;
  height:148px;
  object-fit:cover;
  transform:scale(1.02);
  transition:transform .35s var(--ease), filter .35s var(--ease);
  will-change:transform;
}
.project-mini:hover .mini-media img{transform:scale(1.06); filter:saturate(1.04) contrast(1.02)}
.mini-tag{
  display:inline-flex; align-items:center;
  font-weight:700;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.86);
}
.mini-dot{
  width:10px; height:10px; border-radius:999px;
  background:linear-gradient(135deg, var(--brand4), var(--brand2));
  box-shadow:0 0 0 7px rgba(6,83,171,.14);
}
.project-mini h3{margin:0 0 8px; font-size:16px}
.project-mini p{margin:0; color:var(--muted); line-height:1.65; font-size:14px}

.compare{
  position:relative;
  margin-top:26px;
  border-radius:var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  box-shadow:var(--shadow);
  overflow:hidden;
  min-height:320px;
}
.compare-img{width:100%; height:clamp(320px, 52vw, 520px); object-fit:cover}
.compare-after-wrap{
  position:absolute; inset:0;
  width:50%;
  overflow:hidden;
  will-change:width;
  transition:width .12s var(--ease);
}
.compare-handle{
  position:absolute;
  top:0; bottom:0;
  left:50%;
  width:0;
  cursor:ew-resize;
  outline:none;
}
.compare-line{
  position:absolute; top:0; bottom:0; left:-1px;
  width:2px;
  background:linear-gradient(180deg, rgba(255,150,24,.95), rgba(249,114,32,.92));
  box-shadow:0 0 0 6px rgba(255,150,24,.08);
}
.compare-knob{
  position:absolute; left:-22px; top:50%;
  transform:translateY(-50%);
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(7,10,19,.55);
  backdrop-filter:blur(10px) saturate(140%);
  display:grid; place-items:center;
  color:rgba(255,255,255,.92);
  box-shadow:0 20px 60px rgba(0,0,0,.45);
}
.compare-range{
  position:absolute; inset:auto 14px 14px 14px;
  width:calc(100% - 28px);
  accent-color:var(--brand3);
  opacity:0;
  height:28px;
}
.compare-labels{
  position:absolute; top:16px; left:16px; right:16px;
  display:flex; justify-content:space-between;
  font-weight:800;
  letter-spacing:.18em;
  font-size:12px;
  color:rgba(255,255,255,.82);
  text-transform:uppercase;
  text-shadow:0 18px 40px rgba(0,0,0,.45);
  pointer-events:none;
}

.gallery-grid{
  margin-top:26px;
  column-count:3;
  column-gap:16px;
}
.gallery-item{break-inside:avoid; margin:0 0 16px}
.gallery-link{
  position:relative;
  display:block;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
}
.gallery-link img{
  width:100%;
  height:auto;
  transform:scale(1.02);
  transition:transform .35s var(--ease), filter .35s var(--ease);
  will-change:transform;
}
.gallery-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(7,10,19,0), rgba(7,10,19,.46));
  opacity:.0;
  transition:opacity .35s var(--ease);
}
.gallery-zoom{
  position:absolute;
  right:12px; bottom:12px;
  width:40px; height:40px;
  display:grid; place-items:center;
  border-radius:999px;
  background:rgba(7,10,19,.55);
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(12px) saturate(140%);
  opacity:0;
  transform:translateY(8px);
  transition:opacity .35s var(--ease), transform .35s var(--ease);
}
.gallery-link:hover img{transform:scale(1.08); filter:saturate(1.05) contrast(1.02)}
.gallery-link:hover .gallery-overlay{opacity:1}
.gallery-link:hover .gallery-zoom{opacity:1; transform:translateY(0)}

.empty-state{
  padding:22px 18px;
  border-radius:var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
}
.empty-state h3{margin:0 0 8px}
.empty-state p{margin:0; color:var(--muted); line-height:1.7}

.lightbox{
  position:fixed;
  inset:0;
  display:none;
  z-index:80;
}
.lightbox.is-open{display:block}
.lightbox-backdrop{
  position:absolute; inset:0;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(10px);
}
.lightbox-panel{
  position:absolute;
  inset:40px 18px;
  max-width:1080px;
  margin:0 auto;
  display:grid;
  grid-template-columns:52px minmax(0, 1fr) 52px;
  align-items:center;
  gap:10px;
  padding:14px;
  border-radius:var(--radius2);
  border:1px solid rgba(255,255,255,.14);
  background:rgba(10,14,24,.62);
  box-shadow:var(--shadow);
}
.lightbox-img{
  width:100%;
  max-height:calc(100vh - 150px);
  object-fit:contain;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
}
.lightbox-close{
  position:absolute;
  top:12px; right:12px;
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.92);
}
.lightbox-nav{
  width:48px; height:48px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.92);
}

.about-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:22px;
  align-items:start;
}
.about-copy,.stats{min-width:0}
.about-copy h2{margin:0 0 10px; font-size:clamp(24px, 2.7vw, 36px); letter-spacing:-.02em}
.about-copy p{margin:0 0 12px; color:var(--muted); line-height:1.75}

.stats{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}
.stat{
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  padding:18px 16px;
  position:relative;
  overflow:hidden;
}
.stat::before{
  content:"";
  position:absolute; inset:-40px;
  background:radial-gradient(260px 200px at 15% 20%, rgba(255,150,24,.14), transparent 60%);
  opacity:.8;
}
.stat > *{position:relative}
.stat-num{
  font-size:36px;
  font-weight:800;
  letter-spacing:-.02em;
  background:linear-gradient(135deg, rgba(255,150,24,.95), rgba(255,255,255,.92));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.stat-label{margin-top:8px; color:rgba(234,240,255,.8); font-weight:600}

.cta-final{
  padding:84px 0;
  background:
             radial-gradient(950px 550px at 15% 20%, rgba(255,150,24,.18), transparent 62%),
             linear-gradient(180deg, rgba(0,0,0,.14), rgba(0,0,0,.42));
  border-top:1px solid rgba(255,255,255,.10);
}
.cta-final-inner{
  border-radius:var(--radius2);
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow:var(--shadow);
  padding:26px 22px;
  text-align:center;
}
.cta-final-inner h2{margin:0 0 10px; font-size:clamp(24px, 3vw, 38px); letter-spacing:-.02em}
.cta-final-inner p{margin:0 0 18px; color:var(--muted); line-height:1.7}
.cta-final-actions{display:flex; justify-content:center; flex-wrap:wrap; gap:12px}

.contact-grid{
  margin-top:26px;
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:18px;
  align-items:start;
}
.contact-cards,.contact-form{min-width:0}
.contact-cards{display:grid; gap:14px}
.contact-card{
  border-radius:var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  padding:18px 16px;
}
.contact-card h3{margin:0 0 8px}
.contact-card p{margin:0 0 14px; color:var(--muted); line-height:1.7}
.contact-form{
  border-radius:var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  padding:18px 16px;
}
.contact-form label{display:grid; gap:8px; margin-bottom:12px}
.contact-form span{font-weight:700; color:rgba(234,240,255,.85); font-size:13px}
.contact-form input,.contact-form textarea,.contact-form select{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(7,10,19,.55);
  color:rgba(255,255,255,.92);
  outline:none;
  max-width:100%;
  transition:border-color .2s var(--ease), background .2s var(--ease);
}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{
  border-color:rgba(255,150,24,.42);
  background:rgba(7,10,19,.68);
}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.form-note{margin:10px 0 0; color:rgba(234,240,255,.68); font-size:13px; line-height:1.6}

.site-footer{
  background:#000;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer-grid{
  padding:56px 0 30px;
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 1fr;
  gap:18px;
  align-items:start;
}
.footer-brand p{margin:12px 0 0; color:rgba(234,240,255,.72); line-height:1.7}
.footer-col h3{margin:0 0 12px; font-size:15px}
.footer-list{list-style:none; padding:0; margin:0; display:grid; gap:10px}
.footer-list li{overflow-wrap:anywhere; word-break:break-word}
.footer-list a{color:rgba(234,240,255,.78)}
.footer-list a:hover{color:rgba(255,255,255,.96)}
.footer-social{display:flex; gap:10px; margin-bottom:12px}
.footer-bottom{
  padding:18px 0 24px;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer-bottom p{margin:0; color:rgba(234,240,255,.65); font-size:13px}

.wa-float{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:75;
  display:flex;
  align-items:flex-end;
  gap:10px;
  pointer-events:none;
}
.wa-float > *{pointer-events:auto}
.wa-mascot{
  filter:drop-shadow(0 22px 70px rgba(0,0,0,.55));
  transform:translateY(2px);
  animation:floaty 3.2s var(--ease) infinite;
}
@keyframes floaty{
  0%,100%{transform:translateY(2px)}
  50%{transform:translateY(-4px)}
}
.wa-pill{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(255,150,24,.28);
  background:rgba(7,10,19,.62);
  backdrop-filter:blur(16px) saturate(140%);
  box-shadow:0 24px 80px rgba(0,0,0,.52);
  overflow:hidden;
  max-width:calc(100vw - 36px);
}
.wa-icon{
  width:44px; height:44px;
  border-radius:16px;
  display:grid; place-items:center;
  color:#0b120a;
  background:linear-gradient(135deg, #25d366, #1bbf58);
}
.wa-text strong{display:block; font-weight:800; letter-spacing:-.01em}
.wa-text small{display:block; margin-top:2px; color:rgba(234,240,255,.72)}
.wa-glow{
  position:absolute; inset:-40px;
  background:radial-gradient(260px 180px at 20% 40%, rgba(255,150,24,.18), transparent 62%);
  opacity:.8;
  pointer-events:none;
}
.wa-pill:hover{border-color:rgba(255,150,24,.45)}

.reveal{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
  transition-delay:var(--d, 0ms);
}
.reveal.is-in{
  opacity:1;
  transform:translateY(0);
}

@media (max-width: 1180px){
  .nav{gap:12px}
  .nav-link{font-size:13px; padding:8px 8px; letter-spacing:.06em}
  .header-actions{gap:8px}
  .header-actions .social{display:none}
  .brand-logo{height:54px}
}

@media (max-width: 980px){
  .section{padding:72px 0}
  .hero{min-height:86vh}
  .hero-inner{padding:84px 0 64px}
  .hero-glass{border-radius:22px}
  .services-grid{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .project-split{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{column-count:2}
  .lightbox-panel{grid-template-columns:48px minmax(0, 1fr) 48px}
}

@media (max-width: 720px){
  .section{padding:64px 0}
  .header-inner{padding:8px 0}
  .header-actions .social{display:none}
  .nav-toggle{display:inline-grid; place-items:center}
  .nav{
    position:fixed;
    top:78px; left:18px; right:18px;
    padding:12px;
    border-radius:18px;
    border:1px solid rgba(0,0,0,.10);
    background:rgba(255,255,255,.97);
    backdrop-filter:blur(14px) saturate(140%);
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:6px;
    box-shadow:0 24px 80px rgba(0,0,0,.55);
    max-height:calc(100vh - 96px);
    overflow:auto;
  }
  .nav-open .nav{display:flex}
  .nav-link{padding:12px 12px; white-space:normal; letter-spacing:.04em}
  .btn-wa{padding:10px 12px}
  .hero{min-height:84vh}
  .hero-inner{padding:78px 0 64px}
  .hero-glass{padding:22px 18px}
  .hero-cta{width:100%}
  .services-grid{grid-template-columns:1fr}
  .service-media img{height:150px}
  .feature-list li{grid-template-columns:72px 1fr}
  .feature-media img{height:58px}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .gallery-grid{column-count:1}
  .wa-mascot{display:none}
  .lightbox-panel{inset:22px 12px; grid-template-columns:44px minmax(0, 1fr) 44px}
  .lightbox-img{max-height:calc(100vh - 140px)}
}

@media (max-width: 480px){
  .container{width:min(var(--container), calc(100% - 28px))}
  .hero-glass{padding:20px 16px}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%}
  .btn{max-width:100%}
  .cta-final-actions{flex-direction:column}
  .cta-final-actions .btn{width:100%}
  .feature-list li{grid-template-columns:66px 1fr; gap:12px}
  .mini-media img{height:140px}
  .compare-knob{width:40px; height:40px; left:-20px}
  .lightbox-panel{inset:18px 10px; padding:12px}
  .lightbox-nav{width:44px; height:44px; border-radius:14px}
  .lightbox-close{width:42px; height:42px; border-radius:14px}
  .wa-float{right:12px; bottom:12px}
}

@media (max-width: 400px){
  .section{padding:56px 0}
  .hero-title{font-size:clamp(30px, 9vw, 40px)}
  .hero-kicker{letter-spacing:.14em}
  .badge{padding:9px 10px; font-size:12px}
  .wa-text small{display:none}
  .wa-pill{padding:10px 12px; gap:10px}
  .wa-icon{width:42px; height:42px; border-radius:14px}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .btn,.service-card,.gallery-link img,.reveal,.wa-mascot{transition:none; animation:none}
  .compare-after-wrap{transition:none}
}
