/* ========== Base ========== */
:root{
  --bg0:#05080f;
  --bg1:#070b14;
  --bg2:#0b1424;
  --text:#e8eef8;
  --muted:#b9c7de;
  --muted2:#7f96bb;
  --line:rgba(255,255,255,.08);
  --line2:rgba(255,255,255,.05);
  --cyan:#5ad6ff;
  --blue:#2f7dff;
  --glow:rgba(90,214,255,.18);
  --shadow:rgba(0,0,0,.55);
  --radius:18px;
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, sans-serif;
  background: var(--bg0);
  color: var(--text);
  overflow-x:hidden;
  min-height:100vh;
  opacity:0;
  transition:opacity .35s ease;
}
body.ready{opacity:1;}

a{color:inherit; text-decoration:none;}
.wrap{width:min(1120px, calc(100% - 40px)); margin:0 auto;}

/* ========== Background ========== */
#fx{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
}

.bg{
  position:fixed;
  inset:0;
  z-index:0;
  background:
    radial-gradient(1200px 700px at 50% 35%, rgba(60,140,255,.20), transparent 60%),
    radial-gradient(900px 500px at 20% 60%, rgba(90,214,255,.12), transparent 65%),
    radial-gradient(900px 500px at 80% 62%, rgba(90,214,255,.10), transparent 65%),
    linear-gradient(180deg, #05080f 0%, #070b14 45%, #05080f 100%);
  transform: translate(0px,0px) scale(1.02);
  will-change: transform;
}

.bg::before{
  content:"";
  position:absolute;
  inset:0;
  background-image: url("assets/bg.png");
  background-size: cover;
  background-position: center;
  opacity:.32;
  filter: saturate(1.05) contrast(1.05);
  transform: scale(1.02);
}

.vignette{
  position:fixed;
  inset:-2px;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(circle at center, transparent 40%, rgba(0,0,0,.55) 100%);
  mix-blend-mode: multiply;
}

/* ========== Top nav ========== */
.top{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter: blur(10px);
  background: linear-gradient(180deg, rgba(5,8,15,.70), rgba(5,8,15,.25));
  border-bottom:1px solid rgba(255,255,255,.05);
}
.top__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:18px;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-weight:650;
  letter-spacing:.2px;
}
.brand__dot{
  width:10px; height:10px; border-radius:999px;
  background: linear-gradient(90deg, var(--cyan), var(--blue));
  box-shadow: 0 0 24px rgba(90,214,255,.45);
}
.brand__name{opacity:.95}

.nav{display:flex; gap:18px; align-items:center;}
.nav__a{
  color: rgba(232,238,248,.82);
  font-size:.95rem;
  padding:8px 10px;
  border-radius: 10px;
  transition: background .25s ease, transform .25s ease, opacity .25s ease;
}
.nav__a:hover{
  background: rgba(255,255,255,.05);
  transform: translateY(-1px);
}

/* ========== Buttons ========== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 18px;
  border-radius: 14px;
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(11,20,36,.85), rgba(7,11,20,.55));
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  position:relative;
  overflow:hidden;
}
.btn::after{
  content:"";
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(90,214,255,.28), transparent 60%);
  opacity:0;
  transition: opacity .25s ease;
}
.btn:hover{
  transform: translateY(-2px);
  border-color: rgba(90,214,255,.25);
  box-shadow: 0 26px 60px rgba(0,0,0,.45);
}
.btn:hover::after{opacity:1}
.btn--ghost{
  background: transparent;
  box-shadow:none;
}
.btn--small{padding:10px 14px; border-radius:12px; font-size:.95rem}

/* white buttons in contact */
.btn--white{
  color: #fff;
  border-color: rgba(255,255,255,.14);
}
.btn--white.btn--ghost{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.14);
}

/* ========== Hero ========== */
.hero{
  position:relative;
  z-index:2;
  padding: 86px 0 56px;
}
.hero__inner{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 36px;
  align-items:center;
}

.kicker{
  display:flex; align-items:center; gap:12px;
  color: rgba(232,238,248,.78);
  margin-bottom: 18px;
}
.pill{
  font-size:.78rem;
  padding:8px 12px;
  border-radius:999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.45);
}
.pulse-dot{
  width:10px; height:10px; border-radius:999px;
  background: var(--cyan);
  box-shadow: 0 0 0 0 rgba(90,214,255,.55);
  animation: pulse 1.6s ease infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(90,214,255,.55)}
  70%{box-shadow:0 0 0 14px rgba(90,214,255,0)}
  100%{box-shadow:0 0 0 0 rgba(90,214,255,0)}
}

.h1{
  font-size: clamp(2.3rem, 3.6vw, 3.6rem);
  line-height:1.05;
  letter-spacing: .2px;
}
.grad{
  background: linear-gradient(90deg, var(--cyan), var(--blue));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.shine{
  position:relative;
  display:inline-block;
}
.shine::after{
  content:"";
  position:absolute;
  inset:-4px -10px;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.18) 45%, transparent 70%);
  transform: translateX(-120%);
  animation: shine 2.6s ease infinite;
  pointer-events:none;
}
@keyframes shine{
  0%{transform: translateX(-120%)}
  60%{transform: translateX(120%)}
  100%{transform: translateX(120%)}
}

.lead{
  margin-top: 18px;
  max-width: 56ch;
  color: rgba(185,199,222,.92);
  font-size: 1.05rem;
}
.cta{margin-top:22px; display:flex; gap:12px; flex-wrap:wrap;}

.stats{
  margin-top: 24px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.stat{
  border:1px solid var(--line2);
  background: rgba(5,8,15,.35);
  border-radius: 14px;
  padding: 12px 12px;
}
.stat__n{
  font-weight:700;
  color: rgba(90,214,255,.95);
  letter-spacing:.5px;
}
.stat__t{font-size:.92rem; color: rgba(232,238,248,.80); margin-top:6px}

.hero__right{display:flex; flex-direction:column; gap:14px; align-items:center;}

/* logo card */
.logoCard{
  position:relative;
  width: min(420px, 100%);
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(11,20,36,.76), rgba(5,8,15,.35));
  padding: 26px 22px 18px;
  overflow:hidden;
  box-shadow: 0 35px 80px rgba(0,0,0,.5);
}
.logoCard__logo{
  width: 108px;
  height:auto;
  display:block;
  margin: 8px auto 10px;
  filter: drop-shadow(0 18px 45px rgba(0,0,0,.45));
  animation: floaty 4.8s ease-in-out infinite;
}
@keyframes floaty{
  0%,100%{transform: translateY(0)}
  50%{transform: translateY(-8px)}
}
.logoCard__ring{
  position:absolute;
  left:50%;
  top:46%;
  width: 540px;
  height: 540px;
  transform: translate(-50%,-50%);
  border-radius: 999px;
  border: 1px solid rgba(90,214,255,.16);
  box-shadow: inset 0 0 60px rgba(90,214,255,.08);
  animation: spin 18s linear infinite;
}
@keyframes spin{to{transform: translate(-50%,-50%) rotate(360deg)}}
.logoCard__glow{
  position:absolute;
  inset:-60%;
  background: radial-gradient(circle at 50% 45%, rgba(90,214,255,.18), transparent 55%);
  animation: breathe 4s ease-in-out infinite;
}
@keyframes breathe{
  0%,100%{opacity:.55}
  50%{opacity:.95}
}

/* typewriter */
.type{
  margin-top: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  color: rgba(232,238,248,.78);
  font-size:.95rem;
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.07);
  background: rgba(5,8,15,.35);
}
.type__label{opacity:.9}
.type__cursor{
  width:10px; height:16px;
  background: rgba(90,214,255,.75);
  border-radius:3px;
  animation: blink 1s steps(1) infinite;
}
@keyframes blink{50%{opacity:0}}
.type__text{min-width: 180px; text-align:left; color: rgba(232,238,248,.92);}

/* chips */
.chips{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  width:min(520px,100%);
}
.chip{
  padding: 10px 12px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.07);
  background: rgba(5,8,15,.32);
  color: rgba(232,238,248,.78);
  font-size:.9rem;
  transition: transform .22s ease, border-color .22s ease;
}
.chip:hover{transform: translateY(-2px); border-color: rgba(90,214,255,.18)}

/* TRUST STRIP */
.trustStrip{
  position:relative;
  z-index:2;
  margin-top: 28px;
}
.trustStrip__inner{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  padding: 14px 14px;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.06);
  background: rgba(5,8,15,.28);
  backdrop-filter: blur(8px);
}
.trustItem{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.06);
  background: rgba(11,20,36,.26);
  color: rgba(232,238,248,.82);
  font-size:.95rem;
}
.trustIcon{filter: drop-shadow(0 10px 20px rgba(0,0,0,.25));}

/* trails */
.trails{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.95;
}
.trail{
  position:absolute;
  width: 60vw;
  height: 60vh;
  top: 8%;
  filter: blur(0px);
  opacity:.9;
}
.trail--l{
  left:-12%;
  transform: rotate(10deg);
  background:
    radial-gradient(closest-side, rgba(90,214,255,.0) 0%, rgba(90,214,255,.0) 40%, rgba(90,214,255,.16) 65%, transparent 78%),
    linear-gradient(90deg, rgba(90,214,255,.0), rgba(90,214,255,.22), rgba(47,125,255,.06));
  clip-path: polygon(0 52%, 100% 0, 100% 12%, 0 64%);
  animation: trailMoveL 6.2s ease-in-out infinite;
}
.trail--r{
  right:-12%;
  transform: rotate(-10deg);
  background:
    radial-gradient(closest-side, rgba(90,214,255,.0) 0%, rgba(90,214,255,.0) 40%, rgba(90,214,255,.16) 65%, transparent 78%),
    linear-gradient(270deg, rgba(90,214,255,.0), rgba(90,214,255,.22), rgba(47,125,255,.06));
  clip-path: polygon(0 0, 100% 52%, 100% 64%, 0 12%);
  animation: trailMoveR 6.2s ease-in-out infinite;
}
@keyframes trailMoveL{
  0%,100%{transform: translateX(0) rotate(10deg); opacity:.75}
  50%{transform: translateX(10px) rotate(12deg); opacity:1}
}
@keyframes trailMoveR{
  0%,100%{transform: translateX(0) rotate(-10deg); opacity:.75}
  50%{transform: translateX(-10px) rotate(-12deg); opacity:1}
}

.spark{
  position:absolute;
  width: 240px;
  height: 240px;
  border-radius: 999px;
  filter: blur(0px);
  background: radial-gradient(circle at center, rgba(90,214,255,.16), transparent 60%);
  animation: spark 2.8s ease-in-out infinite;
  opacity:.85;
}
.spark--l{left: 6%; top: 46%;}
.spark--r{right: 6%; top: 46%;}
@keyframes spark{
  0%,100%{transform: scale(.9); opacity:.55}
  50%{transform: scale(1.1); opacity:1}
}

/* scroll hint */
.scrollHint{
  position:absolute;
  left:50%;
  bottom: 18px;
  transform: translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  z-index:2;
  opacity:.75;
}
.scrollHint__line{
  width:2px;
  height:42px;
  background: linear-gradient(180deg, rgba(90,214,255,.0), rgba(90,214,255,.55), rgba(90,214,255,.0));
  animation: scrollLine 1.8s ease-in-out infinite;
}
@keyframes scrollLine{
  0%,100%{transform: translateY(0); opacity:.55}
  50%{transform: translateY(6px); opacity:1}
}
.scrollHint__text{font-size:.85rem; color: rgba(232,238,248,.7)}

/* ========== Sections ========== */
.section{
  position:relative;
  z-index:2;
  padding: 84px 0;
}
.section--alt{
  background: linear-gradient(180deg, rgba(7,11,20,.55), rgba(5,8,15,.15));
  border-top:1px solid rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.sectionHead{display:flex; flex-direction:column; gap:10px; margin-bottom: 26px}
.h2{font-size: clamp(1.7rem, 2.2vw, 2.2rem); letter-spacing:.2px}
.muted{color: rgba(185,199,222,.86)}
.muted2{color: rgba(127,150,187,.9)}

.grid4{display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px;}
.grid3{display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px;}

/* cards */
.card{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(11,20,36,.72), rgba(5,8,15,.35));
  padding: 18px 16px;
  box-shadow: 0 22px 60px rgba(0,0,0,.35);
  position:relative;
  overflow:hidden;
  min-height: 190px;
}
.card::before{
  content:"";
  position:absolute;
  inset:-50%;
  background: radial-gradient(circle at 30% 30%, rgba(90,214,255,.14), transparent 55%);
  opacity:.0;
  transition: opacity .25s ease;
}
.card:hover::before{opacity:1}
.card h3{font-size:1.05rem; margin-bottom:10px}
.card p{color: rgba(185,199,222,.86); font-size:.95rem}
.tagRow{display:flex; gap:8px; flex-wrap:wrap; margin-top:14px}
.tag{
  font-size:.78rem;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.25);
  color: rgba(232,238,248,.72);
}

/* projects */
.proj{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.32);
  padding: 18px 16px;
  position:relative;
  overflow:hidden;
  min-height: 170px;
}
.proj::after{
  content:"";
  position:absolute;
  inset:-30%;
  background: radial-gradient(circle at 50% 20%, rgba(90,214,255,.16), transparent 60%);
  opacity:.35;
}
.proj__top{display:flex; align-items:center; gap:10px; margin-bottom:10px; position:relative; z-index:1}
.proj__dot{width:10px; height:10px; border-radius:999px; background: linear-gradient(90deg, var(--cyan), var(--blue)); box-shadow:0 0 20px rgba(90,214,255,.35)}
.proj__title{font-weight:650}
.proj__desc{color: rgba(185,199,222,.86); font-size:.95rem; position:relative; z-index:1}
.proj__foot{display:flex; gap:8px; flex-wrap:wrap; margin-top:14px; position:relative; z-index:1}
.mini{
  font-size:.78rem;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.25);
  color: rgba(232,238,248,.72);
}

/* steps */
.steps{display:grid; grid-template-columns: repeat(2, 1fr); gap: 14px;}
.step{
  display:flex;
  gap:14px;
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.28);
  padding: 16px;
}
.step__n{
  width:44px; height:44px; border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(90deg, rgba(90,214,255,.22), rgba(47,125,255,.10));
  border:1px solid rgba(90,214,255,.16);
  font-weight:800;
}
.step__t{font-weight:700}
.step__d{color: rgba(185,199,222,.86); margin-top:6px}

/* portfolio */
.portfolioGrid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.pCard{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.28);
  padding: 18px 16px;
  position:relative;
  overflow:hidden;
  cursor:pointer;
  min-height: 170px;
}
.pCard::before{
  content:"";
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(90,214,255,.16), transparent 60%);
  opacity:.0;
  transition: opacity .25s ease;
}
.pCard:hover::before{opacity:1}
.pTop{display:flex; align-items:center; gap:10px; margin-bottom:10px; position:relative; z-index:1}
.pDot{width:10px; height:10px; border-radius:999px; background: linear-gradient(90deg, var(--cyan), var(--blue)); box-shadow:0 0 20px rgba(90,214,255,.35)}
.pTitle{font-weight:650}
.pDesc{color: rgba(185,199,222,.86); font-size:.95rem; position:relative; z-index:1}
.pMeta{display:flex; gap:8px; flex-wrap:wrap; margin-top:14px; position:relative; z-index:1}
.pCta{margin-top:12px; color: rgba(90,214,255,.92); position:relative; z-index:1}
.portfolioBottom{margin-top: 18px; display:flex; justify-content:center;}

/* modal */
.modal{
  position:fixed;
  inset:0;
  z-index:120;
  display:none;
}
.modal.show{display:block;}
.modal__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
}
.modal__panel{
  position:relative;
  width:min(860px, calc(100% - 28px));
  margin: 7vh auto 0;
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(11,20,36,.85), rgba(5,8,15,.55));
  box-shadow: 0 40px 120px rgba(0,0,0,.6);
  padding: 18px 16px 16px;
}
.modal__x{
  position:absolute;
  right: 12px;
  top: 12px;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(5,8,15,.35);
  color: rgba(232,238,248,.92);
  cursor:pointer;
}
.kickerSmall{
  display:inline-flex;
  font-size:.75rem;
  letter-spacing:.14em;
  color: rgba(185,199,222,.82);
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.22);
}
.modal__title{margin-top:10px; font-size:1.35rem}
.modal__grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 12px;
  margin-top: 14px;
}
.modal__box{
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.28);
  padding: 14px;
}
.modal__label{font-weight:700; margin-bottom:10px}
.modal__list{padding-left: 16px; color: rgba(185,199,222,.9)}
.modal__list li{margin: 6px 0;}
.modal__chips{display:flex; flex-wrap:wrap; gap:8px;}
.modal__actions{margin-top: 14px; display:flex; gap:10px; flex-wrap:wrap;}

/* FAQ */
.faqGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.faqCard{
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(5,8,15,.28);
  padding: 18px 16px;
}
.faqKicker{font-size:.75rem; letter-spacing:.14em; color: rgba(185,199,222,.82); margin-bottom:10px}
.faqTitle{font-size:1.2rem; margin-bottom:10px}
.faqPills{display:flex; gap:8px; flex-wrap:wrap; margin-top: 14px}
.faqCTA{display:flex; gap:10px; flex-wrap:wrap; margin-top: 16px}
.faqAcc{
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(5,8,15,.22);
  overflow:hidden;
}
.faqItem{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding: 14px 14px;
  background: transparent;
  border:0;
  color: rgba(232,238,248,.92);
  cursor:pointer;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.faqItem:hover{background: rgba(255,255,255,.03);}
.faqQ{font-weight:650; text-align:left;}
.faqIcon{width:28px; height:28px; border-radius:10px; border:1px solid rgba(255,255,255,.10); display:flex; align-items:center; justify-content:center}
.faqA{
  padding: 12px 16px 16px;
  color: rgba(185,199,222,.9);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.faqA ul{margin-top:10px; padding-left: 18px}

/* ========== Testimonials (Rail) ========== */
.tHighlight{
  position:relative;
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.28);
  padding: 16px 14px;
  overflow:hidden;
}
.tHighlight__glow{
  position:absolute;
  inset:-60%;
  background: radial-gradient(circle at 50% 45%, rgba(90,214,255,.14), transparent 55%);
  opacity:.85;
}
.tScore{
  display:flex;
  align-items:center;
  gap:14px;
  position:relative;
  z-index:1;
}
.tScore__n{
  font-size: 2.2rem;
  font-weight: 900;
  letter-spacing: .5px;
  background: linear-gradient(90deg, var(--cyan), var(--blue));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.stars{letter-spacing:.18em; color: rgba(232,238,248,.92); font-size: .95rem;}
.tBadges{
  margin-top: 12px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  position:relative;
  z-index:1;
}
.tBadge{
  font-size:.78rem;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.22);
  color: rgba(232,238,248,.74);
}

/* rail wrapper */
.tRail{
  position:relative;
  margin-top: 14px;
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.18);
  overflow:hidden;
  cursor: grab;
  touch-action: pan-y;
}
.tRail:active{cursor: grabbing;}

.tTrack{
  display:flex;
  gap: 14px;
  padding: 14px;
  will-change: transform;
}

/* card */
.tCard{
  position:relative;
  flex: 0 0 auto;
  width: min(360px, 78vw);
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(11,20,36,.70), rgba(5,8,15,.35));
  box-shadow: 0 22px 60px rgba(0,0,0,.35);
  padding: 16px 14px 44px;
  overflow:hidden;
}
.tCard::before{
  content:"";
  position:absolute;
  inset:-50%;
  background: radial-gradient(circle at 30% 30%, rgba(90,214,255,.14), transparent 55%);
  opacity:.0;
  transition: opacity .25s ease;
}
.tCard:hover::before{opacity:1}
.tCard__top{display:flex; align-items:center; gap:10px; margin-bottom:10px; position:relative; z-index:1}
.tAvatar{
  width: 36px; height: 36px;
  border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  font-weight: 900;
  background: linear-gradient(90deg, rgba(90,214,255,.22), rgba(47,125,255,.10));
  border:1px solid rgba(90,214,255,.16);
}
.tName{font-weight: 750; line-height:1.1}
.tRole{font-size:.88rem}
.tStars{margin-left:auto; letter-spacing:.18em; color: rgba(232,238,248,.9); font-size:.9rem}
.tText{
  color: rgba(185,199,222,.92);
  font-size: .98rem;
  line-height: 1.45;
  position:relative;
  z-index:1;
}
.tFoot{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top: 12px;
  position:relative;
  z-index:1;
}
.tPill{
  font-size:.76rem;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.22);
  color: rgba(232,238,248,.72);
}
.tVerify{
  margin-left:auto;
  font-size:.76rem;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(90,214,255,.16);
  background: rgba(90,214,255,.10);
  color: rgba(232,238,248,.86);
}

/* google badge bottom-right */
.tSource{
  position:absolute;
  right: 12px;
  bottom: 10px;
  display:flex;
  align-items:center;
  gap: 8px;
  font-size: .82rem;
  opacity: .88;
  z-index: 2;
  pointer-events:none;
}
.gBadge{
  width: 22px;
  height: 22px;
  border-radius: 999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  box-shadow: 0 10px 25px rgba(0,0,0,.25);
}
.gText{color: rgba(185,199,222,.85);}

/* fades */
.tFade{
  position:absolute;
  top:0; bottom:0;
  width: 80px;
  pointer-events:none;
  z-index:5;
}
.tFade--l{
  left:0;
  background: linear-gradient(90deg, rgba(5,8,15,.90), rgba(5,8,15,0));
}
.tFade--r{
  right:0;
  background: linear-gradient(270deg, rgba(5,8,15,.90), rgba(5,8,15,0));
}
.tActions{margin-top: 14px; display:flex; gap: 10px; flex-wrap:wrap; justify-content:center;}

/* contact */
.sectionTop{display:flex; flex-direction:column; gap:8px; margin-bottom: 14px;}
.kickerSmall{
  display:inline-flex;
  align-self:flex-start;
  font-size:.75rem;
  letter-spacing:.14em;
  color: rgba(185,199,222,.82);
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.22);
}
.contactBox{
  border-radius: 24px;
  border:1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(11,20,36,.68), rgba(5,8,15,.35));
  padding: 26px 18px;
  box-shadow: 0 30px 80px rgba(0,0,0,.45);
  position:relative;
  overflow:hidden;
}
.contactBox::before{
  content:"";
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 45% 30%, rgba(90,214,255,.16), transparent 60%);
  opacity:.65;
}
.contactInfo{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
  position:relative;
  z-index:1;
  margin-bottom: 14px;
}
.infoPill{
  display:inline-flex;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.25);
  color: rgba(232,238,248,.84);
}
.form{position:relative; z-index:1;}
.formGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.field{display:flex; flex-direction:column; gap:8px;}
.field span{font-size:.9rem; color: rgba(232,238,248,.82);}
.field--full{grid-column: 1 / -1;}
.field input, .field textarea, .field select{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(5,8,15,.28);
  color: rgba(232,238,248,.92);
  outline:none;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.field input::placeholder, .field textarea::placeholder{color: rgba(185,199,222,.55);}
.field input:focus, .field textarea:focus, .field select:focus{
  border-color: rgba(90,214,255,.22);
  box-shadow: 0 0 0 4px rgba(90,214,255,.10);
}
.field select{
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(232,238,248,.75) 50%),
    linear-gradient(135deg, rgba(232,238,248,.75) 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(50% - 3px), calc(100% - 12px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 42px;
}
.formActions{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin-top: 12px;
}
.formNote{font-size:.9rem}
.toast{
  margin-top: 12px;
  display:inline-flex;
  padding: 8px 12px;
  border-radius: 12px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(5,8,15,.35);
  color: rgba(232,238,248,.86);
  opacity:0;
  transform: translateY(6px);
  transition: opacity .25s ease, transform .25s ease;
  position:relative;
  z-index:1;
}
.toast.show{opacity:1; transform: translateY(0);}

/* footer */
.foot{
  margin-top: 22px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  color: rgba(127,150,187,.9);
  position:relative;
  z-index:1;
}

/* ========== Reveal / Tilt ========== */
.reveal{
  opacity:0;
  transform: translateY(14px);
  filter: blur(6px);
  transition: opacity .8s ease, transform .8s ease, filter .8s ease;
}
.reveal.in{
  opacity:1;
  transform: translateY(0);
  filter: blur(0);
}

/* Tilt */
.tilt{transform-style:preserve-3d; transition: transform .18s ease;}
.tilt:hover{transition: transform .08s ease;}

/* WhatsApp floating */
.waFloat{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 200;
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(11,20,36,.88), rgba(5,8,15,.55));
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  color: rgba(232,238,248,.95);
  transition: transform .22s ease, border-color .22s ease;
  overflow:hidden;
}
.waFloat:hover{transform: translateY(-2px); border-color: rgba(90,214,255,.22);}
.waFloat__icon{width: 22px; height: 22px; display:block;}
.waFloat__text{font-weight: 700; letter-spacing:.2px; font-size:.95rem;}
.waFloat__pulse{
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(90,214,255,.18), transparent 60%);
  opacity:.0;
  transition: opacity .25s ease;
}
.waFloat:hover .waFloat__pulse{opacity:1;}

@media (max-width: 520px){
  .waFloat{
    width: 54px;
    height: 54px;
    padding: 0;
    justify-content:center;
    border-radius: 999px;
  }
  .waFloat__text{display:none;}
  .waFloat__icon{width: 26px; height: 26px;}
}

/* ========== Responsive ========== */
@media (max-width: 980px){
  .hero__inner{grid-template-columns: 1fr; gap: 22px;}
  .nav{display:none;}
  .stats{grid-template-columns: 1fr; }
  .grid4{grid-template-columns: repeat(2, 1fr);}
  .grid3{grid-template-columns: 1fr;}
  .steps{grid-template-columns: 1fr;}
  .portfolioGrid{grid-template-columns: 1fr;}
  .faqGrid{grid-template-columns: 1fr;}
  .modal__grid{grid-template-columns: 1fr;}
  .formGrid{grid-template-columns: 1fr;}
}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important;}
}
