:root{
  --bg: #070c16;
  --bg2: #0b1220;
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.72);
  --line: rgba(255,255,255,.14);

  --blue: #2563eb;
  --blue2: #3b82f6;

  --radius: 18px;
  --shadow: 0 22px 55px rgba(0,0,0,.35);
  --shadow2: 0 14px 30px rgba(37,99,235,.28);
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  background: var(--bg);
  color: var(--text);
}

.container{ width: min(1200px, 92vw); margin-inline: auto; }

.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left: 16px; top: 12px; width:auto; height:auto; padding: 10px 12px;
  border-radius: 12px; background: #fff; color: #000; z-index: 9999;
}

/* ================= Header/Nav ================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(7,12,22,.72);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 14px 0;
  gap: 14px;
}

.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  color: var(--text);
  text-decoration:none;
  font-weight: 800;
}

.brand-logo{
  width: 44px;
  height: 44px;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.35));
}

.brand-meta{ display:flex; flex-direction: column; line-height: 1.1; }
.brand-name{ font-size: 14px; letter-spacing: .01em; color:#fff; }
.brand-role{ font-size: 12px; color: rgba(255,255,255,.70); font-weight: 700; }

.nav{ display:flex; align-items:center; gap: 18px; }
.nav a{
  color: rgba(255,255,255,.78);
  text-decoration:none;
  font-weight: 700;
  font-size: 14px;
}
.nav a:hover{ color:#fff; }

.nav .nav-cta{
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
}

.nav-toggle{
  display:none;
  background: transparent;
  border: 0;
  padding: 10px;
  border-radius: 12px;
}
.nav-toggle:focus{ outline: 2px solid rgba(59,130,246,.7); outline-offset: 2px; }
.nav-toggle-bar{
  display:block;
  width: 22px;
  height: 2px;
  background: rgba(255,255,255,.85);
  margin: 5px 0;
  border-radius: 2px;
}

/* ================= Hero ================= */
.hero{
  position: relative;
  overflow: hidden;
  padding: 84px 0 64px;
  background: linear-gradient(180deg, var(--bg2) 0%, var(--bg) 100%);
}

.hero-bg{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(1200px 700px at 15% 15%, rgba(37, 99, 235, .20) 0%, rgba(37, 99, 235, 0) 60%),
    radial-gradient(900px 600px at 85% 25%, rgba(59, 130, 246, .16) 0%, rgba(59, 130, 246, 0) 55%),
    linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: auto, auto, 56px 56px, 56px 56px;
  opacity: .95;
}

.hero-grid{
  position: relative;
  z-index: 2;
  display:grid;
  grid-template-columns: 1.35fr .85fr;
  gap: 26px;
  align-items: start;
}

.eyebrow{ margin: 0 0 10px; color: rgba(255,255,255,.74); font-weight: 700; }
.eyebrow strong{ color:#fff; }

.hero h1{
  margin: 0 0 14px;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color:#fff;
}

.accent{
  background: linear-gradient(90deg, var(--blue2), var(--blue));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.subhead{
  margin: 0 0 22px;
  font-size: 18px;
  line-height: 1.6;
  color: var(--muted);
  max-width: 62ch;
}

.hero-actions{ display:flex; flex-wrap: wrap; gap: 12px; margin-bottom: 18px; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  padding: 12px 16px;
  border-radius: 14px;
  font-weight: 900;
  letter-spacing: .01em;
  text-decoration:none;
  border: 1px solid transparent;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
  will-change: transform;
}
.btn:focus{ outline: 2px solid rgba(59,130,246,.8); outline-offset: 2px; }

.btn-primary{
  background: var(--blue);
  border-color: var(--blue);
  color: #fff;
  box-shadow: var(--shadow2);
}
.btn-primary:hover{ transform: translateY(-2px); box-shadow: 0 18px 40px rgba(37, 99, 235, .36); }

.btn-ghost{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.22);
  color: #fff;
}
.btn-ghost:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.35);
}

.btn-soft{
  background: rgba(37,99,235,.14);
  border-color: rgba(37,99,235,.25);
  color: #fff;
}

.hero-badges{
  margin: 0;
  padding: 0;
  list-style: none;
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
}
.hero-badges li{
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  font-size: 13px;
  color: rgba(255,255,255,.78);
}

/* Card */
.hero-card{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius);
  padding: 18px 16px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.card-head{
  display:flex;
  align-items:center;
  gap: 12px;
  margin-bottom: 12px;
}

.card-logo{
  width: 44px;
  height: 44px;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.35));
}

.hero-card h2{ margin: 0; font-size: 18px; color:#fff; letter-spacing: .01em; }
.card-sub{ margin: 4px 0 0; font-size: 13px; color: rgba(255,255,255,.70); }

.pill-row{ display:flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.pill{
  font-size: 12px;
  font-weight: 900;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(37,99,235,.14);
  border: 1px solid rgba(37,99,235,.25);
  color: rgba(255,255,255,.9);
}

.card-list{ display:grid; gap: 12px; }
.card-item{
  padding: 12px 12px;
  border-radius: 14px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.10);
}
.card-item h3{ margin: 0 0 6px; font-size: 14px; color:#fff; }
.card-item p{ margin: 0; font-size: 14px; line-height: 1.5; color: rgba(255,255,255,.72); }

.card-cta{ margin-top: 14px; }

/* Placeholder sections for testing */
.spacer{ height: 40vh; border-top: 1px solid rgba(255,255,255,.06); }

/* ================= Footer ================= */
.site-footer{
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(7,12,22,.85);
  padding: 28px 0;
}

.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr 1fr;
  gap: 18px;
  align-items:center;
}

.footer-brand{
  display:flex;
  align-items:center;
  gap: 12px;
}

.footer-logo{
  width: 44px;
  height: 44px;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.35));
}

.footer-title{ font-weight: 900; color:#fff; }
.footer-muted{ color: rgba(255,255,255,.72); font-weight: 700; }
.footer-muted.small{ font-size: 12px; margin-top: 10px; }

.footer-links{
  display:flex;
  flex-wrap: wrap;
  gap: 12px 16px;
  justify-content: center;
}
.footer-links a{
  color: rgba(255,255,255,.78);
  text-decoration:none;
  font-weight: 800;
  font-size: 13px;
}
.footer-links a:hover{ color:#fff; }

.footer-cta{
  display:flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}

/* ================= Responsive ================= */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }

  .nav-toggle{ display:block; }
  .nav{
    position: fixed;
    top: 64px;
    right: 16px;
    left: 16px;
    background: rgba(7,12,22,.95);
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 16px;
    padding: 14px;
    display:none;
    flex-direction: column;
    gap: 12px;
    box-shadow: 0 30px 80px rgba(0,0,0,.55);
    backdrop-filter: blur(10px);
  }
  .nav.is-open{ display:flex; }
  .nav a{ font-size: 16px; padding: 10px 8px; }

  .footer-grid{
    grid-template-columns: 1fr;
    text-align: left;
  }
  .footer-links{ justify-content: flex-start; }
  .footer-cta{ align-items: flex-start; }
}

/* ================= What I Do ================= */
.what{
  position: relative;
  padding: 76px 0;
  border-top: 1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(11,18,32,.35) 0%, rgba(7,12,22,0) 100%);
}

.section-head{
  max-width: 70ch;
  margin-bottom: 22px;
}

.kicker{
  margin: 0 0 8px;
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,.72);
}
.kicker:before{
  content:"";
  width: 16px;
  height: 2px;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--blue2), var(--blue));
  box-shadow: 0 10px 30px rgba(37,99,235,.20);
}

.what h2{
  margin: 0 0 10px;
  font-size: clamp(26px, 2.6vw, 36px);
  letter-spacing: -0.01em;
  color: #fff;
}

.section-sub{
  margin: 0;
  color: rgba(255,255,255,.72);
  line-height: 1.6;
  font-size: 16px;
}

/* Grid */
.what-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 18px;
}

/* Card */
.what-card{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 18px 16px;
  box-shadow: 0 18px 45px rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
  transform: translateZ(0);
}

.what-card:hover{
  transform: translateY(-4px);
  border-color: rgba(59,130,246,.35);
  background: rgba(255,255,255,.075);
}

.what-top{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  margin-bottom: 12px;
}

.what-icon{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(37,99,235,.14);
  border: 1px solid rgba(37,99,235,.24);
  color: rgba(255,255,255,.92);
  box-shadow: 0 18px 35px rgba(37,99,235,.12);
}
.what-icon svg{ width: 22px; height: 22px; }

.what-card h3{
  margin: 0 0 4px;
  font-size: 18px;
  color:#fff;
  letter-spacing: .01em;
}

.what-muted{
  margin: 0;
  font-size: 13px;
  color: rgba(255,255,255,.68);
  line-height: 1.5;
}

/* List */
.what-list{
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
  display:grid;
  gap: 10px;
}

.what-list li{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  color: rgba(255,255,255,.78);
  font-size: 14px;
  line-height: 1.5;
}

.what-list .dot{
  width: 8px;
  height: 8px;
  margin-top: 6px;
  border-radius: 99px;
  background: linear-gradient(180deg, var(--blue2), var(--blue));
  box-shadow: 0 10px 25px rgba(37,99,235,.25);
  flex: 0 0 8px;
}

/* Meta row */
.what-meta{
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.10);
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.tag{
  font-size: 12px;
  font-weight: 900;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.78);
}

.mini-cta{
  font-weight: 900;
  text-decoration: none;
  color: rgba(255,255,255,.92);
  border-bottom: 1px solid rgba(59,130,246,.35);
  padding-bottom: 2px;
}
.mini-cta:hover{
  color:#fff;
  border-bottom-color: rgba(59,130,246,.75);
}

/* Bottom CTA strip */
.what-strip{
  margin-top: 18px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  padding: 16px;
  border-radius: 18px;
  background:
    radial-gradient(900px 250px at 15% 50%, rgba(37,99,235,.20) 0%, rgba(37,99,235,0) 60%),
    rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 22px 55px rgba(0,0,0,.28);
}

.strip-left{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: min(520px, 100%);
  margin-bottom: 1em;
}

.strip-logo{
  width: 44px;
  height: 44px;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.35));
}

.strip-title{
  margin: 0 0 2px;
  font-weight: 900;
  color:#fff;
}

.strip-sub{
  margin: 0;
  color: rgba(255,255,255,.72);
  font-size: 13px;
}

.strip-right{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 980px){
  .what{ padding: 58px 0; }
  .what-grid{ grid-template-columns: 1fr; }
  .strip-left{ min-width: 100%; }
}

/* ================= Featured Work ================= */
.work{
  padding: 76px 0;
  border-top: 1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

.work-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 18px;
}

.work-card{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 18px 45px rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.work-card:hover{
  transform: translateY(-4px);
  border-color: rgba(59,130,246,.35);
  background: rgba(255,255,255,.075);
}

/* Thumbnail */
.work-thumb{
  position: relative;
  aspect-ratio: 16 / 10;
  background: rgba(0,0,0,.22);
  border-bottom: 1px solid rgba(255,255,255,.10);
  overflow:hidden;
}
.work-thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
  transform: scale(1.02);
}
.work-badge{
  position:absolute;
  top: 12px;
  left: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  background: rgba(7,12,22,.75);
  border: 1px solid rgba(255,255,255,.16);
  color: rgba(255,255,255,.92);
}

/* Body */
.work-body{
  padding: 14px 14px 16px;
}

.work-head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 6px;
}
.work-head h3{
  margin: 0;
  font-size: 16px;
  color:#fff;
  font-weight: 900;
  letter-spacing: .01em;
}
.work-favicon{
  width: 22px;
  height: 22px;
  border-radius: 6px;
  opacity: .95;
}

.work-desc{
  margin: 0 0 12px;
  font-size: 13px;
  line-height: 1.55;
  color: rgba(255,255,255,.72);
}

.work-tags{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.work-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Note */
.work-note{
  margin-top: 14px;
  color: rgba(255,255,255,.62);
  font-size: 13px;
}

/* ================= Modal ================= */
.modal{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 200;
}
.modal.is-open{ display:block; }

.modal__overlay{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.modal__panel{
  position: relative;
  width: min(1100px, 92vw);
  height: min(740px, 86vh);
  margin: 7vh auto 0;
  border-radius: 18px;
  overflow: hidden;
  background: rgba(7,12,22,.92);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 40px 120px rgba(0,0,0,.65);
}

.modal__head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 12px;
  border-bottom: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}

.modal__titlewrap{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 0;
}

.modal__logo{
  width: 34px;
  height: 34px;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.35));
}
.modal__kicker{
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.62);
}
.modal__title{
  margin: 0;
  font-size: 14px;
  font-weight: 900;
  color:#fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 52vw;
}

.modal__actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.modal__body{
  position: relative;
  height: calc(100% - 62px);
  background: rgba(0,0,0,.25);
}

.modal__fallback{
  position:absolute;
  inset: 0;
  display:grid;
  place-items:center;
  text-align:center;
  padding: 24px;
  color: rgba(255,255,255,.85);
}

.modal iframe{
  width: 100%;
  height: 100%;
  border: 0;
  display:block;
  background: #fff;
}

/* Responsive */
@media (max-width: 980px){
  .work{ padding: 58px 0; }
  .work-grid{ grid-template-columns: 1fr; }
  .modal__panel{
    height: 86vh;
    margin-top: 6vh;
  }
  .modal__title{ max-width: 46vw; }
}

/* ================= Process ================= */
.process{
  padding: 76px 0;
  border-top: 1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

.process-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-top: 18px;
}

.step{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 16px 14px;
  box-shadow: 0 18px 45px rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
  position: relative;
  overflow: hidden;
}

.step:before{
  content:"";
  position:absolute;
  inset: -60px -60px auto auto;
  width: 160px;
  height: 160px;
  background: radial-gradient(circle at 30% 30%, rgba(37,99,235,.22), rgba(37,99,235,0) 60%);
  transform: rotate(10deg);
  pointer-events:none;
}

.step:hover{
  transform: translateY(-4px);
  border-color: rgba(59,130,246,.35);
  background: rgba(255,255,255,.075);
}

.step-top{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
  position: relative;
  z-index: 1;
}

.step-num{
  font-weight: 1000;
  letter-spacing: .08em;
  color: rgba(255,255,255,.35);
  font-size: 14px;
}

.step-icon{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(37,99,235,.14);
  border: 1px solid rgba(37,99,235,.24);
  color: rgba(255,255,255,.92);
  box-shadow: 0 18px 35px rgba(37,99,235,.12);
}
.step-icon svg{ width: 22px; height: 22px; }

.step h3{
  margin: 6px 0 6px;
  font-size: 16px;
  font-weight: 950;
  color:#fff;
  position: relative;
  z-index: 1;
}

.step p{
  margin: 0 0 12px;
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255,255,255,.72);
  position: relative;
  z-index: 1;
}

.step-list{
  margin: 0;
  padding: 0;
  list-style: none;
  display:grid;
  gap: 10px;
  position: relative;
  z-index: 1;
}

.step-list li{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  color: rgba(255,255,255,.78);
  font-size: 13px;
  line-height: 1.5;
}

.step-list .dot{
  width: 8px;
  height: 8px;
  margin-top: 6px;
  border-radius: 99px;
  background: linear-gradient(180deg, var(--blue2), var(--blue));
  box-shadow: 0 10px 25px rgba(37,99,235,.25);
  flex: 0 0 8px;
}

/* Reuse existing strip styles, but add spacing */
.process-strip{
  margin-top: 18px;
}

/* Responsive */
@media (max-width: 1100px){
  .process-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 680px){
  .process{ padding: 58px 0; }
  .process-grid{ grid-template-columns: 1fr; }
}

/* Reveal animation */
.reveal{ opacity: 0; transform: translateY(10px); transition: opacity .35s ease, transform .35s ease; }
.reveal--in{ opacity: 1; transform: translateY(0); }

/* ================= Testimonials / Trust ================= */
.trust{
  padding: 76px 0;
  border-top: 1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

/* Stats row */
.trust-stats{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 18px;
  margin-bottom: 16px;
}

.stat{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 16px 14px;
  box-shadow: 0 18px 45px rgba(0,0,0,.22);
  position: relative;
  overflow: hidden;
}

.stat:before{
  content:"";
  position:absolute;
  inset: -80px -80px auto auto;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle at 30% 30%, rgba(37,99,235,.22), rgba(37,99,235,0) 60%);
  pointer-events:none;
}

.stat-num{
  font-weight: 1000;
  font-size: 22px;
  letter-spacing: .02em;
  color: #fff;
  position: relative;
  z-index: 1;
}

.stat-label{
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255,255,255,.72);
  position: relative;
  z-index: 1;
}

/* Quotes */
.trust-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.quote{
  margin: 0;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 16px 14px;
  box-shadow: 0 18px 45px rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.quote:hover{
  transform: translateY(-4px);
  border-color: rgba(59,130,246,.35);
  background: rgba(255,255,255,.075);
}

.quote-top{
  display:flex;
  align-items:center;
  gap: 12px;
  margin-bottom: 10px;
}

.quote-mark{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(37,99,235,.14);
  border: 1px solid rgba(37,99,235,.24);
  color: rgba(255,255,255,.92);
  font-size: 24px;
  font-weight: 1000;
  line-height: 1;
}

.quote-meta{ line-height: 1.15; }
.quote-name{ font-weight: 950; color:#fff; font-size: 14px; }
.quote-role{ color: rgba(255,255,255,.70); font-size: 12px; font-weight: 800; }

.quote blockquote{
  margin: 0;
  color: rgba(255,255,255,.78);
  font-size: 13px;
  line-height: 1.65;
}

.quote-foot{
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.10);
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* Strip spacing */
.trust-strip{
  margin-top: 18px;
}

/* Responsive */
@media (max-width: 1100px){
  .trust-stats{ grid-template-columns: 1fr; }
  .trust-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 680px){
  .trust{ padding: 58px 0; }
}

/* ===== FIX: Ensure sections don't visually collide ===== */
.process{ padding-bottom: 76px; } /* gives space after Process strip */
.trust{
  padding: 76px 0;
  margin-top: 0;
  border-top: 1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

/* ===== Testimonials Slider ===== */
.t-slider{
  margin-top: 16px;
}

.t-slider__head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  margin: 8px 0 10px;
}

.t-slider__hint{
  font-size: 12px;
  font-weight: 800;
  color: rgba(255,255,255,.60);
}

.t-slider__controls{
  display:flex;
  gap: 10px;
}

.t-btn{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: #fff;
  font-weight: 900;
  cursor: pointer;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.t-btn:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.10);
  border-color: rgba(59,130,246,.35);
}
.t-btn:focus{
  outline: 2px solid rgba(59,130,246,.8);
  outline-offset: 2px;
}

.t-slider__viewport{
  overflow: hidden;
  border-radius: 18px;
}

.t-slider__track{
  display:flex;
  gap: 16px;
  will-change: transform;
  transition: transform .35s ease;
  padding: 2px; /* keeps shadows from clipping */
}

/* per-view cards: 3 desktop, 2 tablet, 1 mobile */
.t-slide{
  flex: 0 0 calc((100% - 32px) / 3);
  min-height: 100%;
}

/* make quotes align nicely */
.quote{
  height: 100%;
  display:flex;
  flex-direction: column;
}
.quote blockquote{
  flex: 1;
}

.t-dots{
  display:flex;
  justify-content:center;
  gap: 8px;
  margin-top: 12px;
}

.t-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  cursor: pointer;
}
.t-dot.is-active{
  background: linear-gradient(180deg, var(--blue2), var(--blue));
  border-color: rgba(59,130,246,.55);
  box-shadow: 0 12px 26px rgba(37,99,235,.25);
}

/* Tablet */
@media (max-width: 1100px){
  .t-slide{ flex-basis: calc((100% - 16px) / 2); }
}

/* Mobile */
@media (max-width: 680px){
  .t-slider__head{ align-items:flex-start; }
  .t-slide{ flex-basis: 100%; }
}

/* ================= Contact ================= */
.contact{
  padding: 76px 0;
  border-top: 1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

.contact-grid{
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 16px;
  margin-top: 18px;
  align-items: start;
}

/* Left card */
.contact-card{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 16px 14px;
  box-shadow: 0 18px 45px rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.contact-card__top{
  display:flex;
  align-items:center;
  gap: 12px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.10);
  margin-bottom: 14px;
}

.contact-logo{
  width: 46px;
  height: 46px;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.35));
}

.contact-name{
  font-weight: 1000;
  color:#fff;
  letter-spacing: .01em;
}

.contact-role{
  font-weight: 800;
  font-size: 12px;
  color: rgba(255,255,255,.70);
  margin-top: 2px;
}

.contact-links{
  display:grid;
  gap: 10px;
  margin-bottom: 14px;
}

.c-link{
  display:flex;
  gap: 12px;
  align-items:center;
  text-decoration:none;
  padding: 12px 12px;
  border-radius: 16px;
  background: rgba(0,0,0,.16);
  border: 1px solid rgba(255,255,255,.10);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
  color: rgba(255,255,255,.90);
}
.c-link:hover{
  transform: translateY(-2px);
  border-color: rgba(59,130,246,.35);
  background: rgba(255,255,255,.07);
}

.c-ic{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(37,99,235,.14);
  border: 1px solid rgba(37,99,235,.24);
  font-weight: 1000;
  color:#fff;
}

.c-label{
  display:block;
  font-size: 12px;
  font-weight: 900;
  color: rgba(255,255,255,.70);
}
.c-value{
  display:block;
  font-size: 13px;
  font-weight: 900;
  color: rgba(255,255,255,.92);
  margin-top: 2px;
}

.contact-note p{
  margin: 0 0 6px;
  color: rgba(255,255,255,.78);
  font-size: 13px;
  line-height: 1.6;
}
.contact-note .muted{
  color: rgba(255,255,255,.62);
}

/* Form card */
.form-card{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 16px 14px;
  box-shadow: 0 18px 45px rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.form{
  display:grid;
  gap: 12px;
}

.form-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.field{
  display:grid;
  gap: 6px;
}

.field-label{
  font-size: 12px;
  font-weight: 950;
  color: rgba(255,255,255,.80);
}

.field input,
.field select,
.field textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.92);
  font-weight: 700;
  outline: none;
}

.field input::placeholder,
.field textarea::placeholder{
  color: rgba(255,255,255,.45);
  font-weight: 700;
}

.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color: rgba(59,130,246,.45);
  box-shadow: 0 0 0 3px rgba(59,130,246,.18);
}

.field-error{
  min-height: 16px;
  font-size: 12px;
  font-weight: 800;
  color: rgba(255,120,120,.92);
}

.form-actions{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items:center;
  margin-top: 4px;
}

.form-success{
  margin: 8px 0 0;
  padding: 12px 12px;
  border-radius: 16px;
  background: rgba(37,99,235,.14);
  border: 1px solid rgba(37,99,235,.25);
  color: rgba(255,255,255,.92);
  font-weight: 900;
  font-size: 13px;
}

.form-tip{
  margin-top: 12px;
  padding: 14px;
  border-radius: 18px;
  background:
    radial-gradient(900px 250px at 15% 50%, rgba(37,99,235,.16) 0%, rgba(37,99,235,0) 60%),
    rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
}

.form-tip p{
  margin: 0;
  color: rgba(255,255,255,.78);
  font-size: 13px;
  line-height: 1.6;
}

/* Responsive */
@media (max-width: 1100px){
  .contact-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 680px){
  .contact{ padding: 58px 0; }
  .form-row{ grid-template-columns: 1fr; }
}

/* ================= Premium Section Background ================= */

/* Optional: global section spacing consistency */
.bg-premium{
  position: relative;
  overflow: hidden;
}

/* Layered glow + vignette */
.bg-premium::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index: 0;

  /* glow blobs + vignette */
  background:
    radial-gradient(900px 420px at 18% 18%, rgba(37,99,235,.18) 0%, rgba(37,99,235,0) 60%),
    radial-gradient(780px 380px at 88% 30%, rgba(59,130,246,.14) 0%, rgba(59,130,246,0) 58%),
    radial-gradient(820px 420px at 45% 95%, rgba(37,99,235,.10) 0%, rgba(37,99,235,0) 60%),
    radial-gradient(1200px 700px at 50% 50%, rgba(0,0,0,.22) 0%, rgba(0,0,0,0) 55%),
    linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
  opacity: 1;
}

/* Subtle grain texture (no image, pure CSS) */
.bg-premium::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index: 0;
  opacity: .10;

  background-image:
    repeating-linear-gradient(0deg,
      rgba(255,255,255,.06) 0px,
      rgba(255,255,255,.06) 1px,
      transparent 1px,
      transparent 3px),
    repeating-linear-gradient(90deg,
      rgba(255,255,255,.04) 0px,
      rgba(255,255,255,.04) 1px,
      transparent 1px,
      transparent 4px);
  mix-blend-mode: overlay;
}

/* Ensure section content stays above overlays */
.bg-premium > .container,
.bg-premium .container{
  position: relative;
  z-index: 1;
}

/* Unique glow positions by section (optional) */
#services.bg-premium::before{
  background:
    radial-gradient(900px 420px at 15% 15%, rgba(37,99,235,.20) 0%, rgba(37,99,235,0) 60%),
    radial-gradient(760px 360px at 90% 40%, rgba(59,130,246,.12) 0%, rgba(59,130,246,0) 58%),
    linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

#portfolio.bg-premium::before{
  background:
    radial-gradient(900px 420px at 85% 20%, rgba(37,99,235,.18) 0%, rgba(37,99,235,0) 60%),
    radial-gradient(760px 360px at 18% 55%, rgba(59,130,246,.12) 0%, rgba(59,130,246,0) 58%),
    linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

#process.bg-premium::before{
  background:
    radial-gradient(900px 420px at 20% 30%, rgba(37,99,235,.18) 0%, rgba(37,99,235,0) 60%),
    radial-gradient(760px 360px at 80% 70%, rgba(59,130,246,.12) 0%, rgba(59,130,246,0) 58%),
    linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

#testimonials.bg-premium::before{
  background:
    radial-gradient(900px 420px at 50% 15%, rgba(37,99,235,.18) 0%, rgba(37,99,235,0) 60%),
    radial-gradient(760px 360px at 12% 80%, rgba(59,130,246,.12) 0%, rgba(59,130,246,0) 58%),
    linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

#about.bg-premium::before{
  background:
    radial-gradient(900px 420px at 12% 25%, rgba(37,99,235,.18) 0%, rgba(37,99,235,0) 60%),
    radial-gradient(760px 360px at 92% 80%, rgba(59,130,246,.12) 0%, rgba(59,130,246,0) 58%),
    linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

#contact.bg-premium::before{
  background:
    radial-gradient(900px 420px at 80% 20%, rgba(37,99,235,.18) 0%, rgba(37,99,235,0) 60%),
    radial-gradient(760px 360px at 20% 80%, rgba(59,130,246,.12) 0%, rgba(59,130,246,0) 58%),
    linear-gradient(180deg, rgba(11,18,32,.28) 0%, rgba(7,12,22,0) 100%);
}

/* ================= Seamless Section Transitions ================= */
.what,
.work,
.process,
.trust,
.about,
.contact{
  border-top: none !important;  /* removes the hard lines */
}

/* Soft separator (no harsh lines) */
.bg-premium{
  position: relative;
}

.bg-premium::marker{ content: none; } /* harmless */

.bg-premium + .bg-premium{
  position: relative;
}

.bg-premium + .bg-premium::before{
  /* keep your existing ::before glow - this does not replace it */
}

/* Add a subtle top fade on each bg-premium section */
.bg-premium{
  padding-top: 76px; /* keeps spacing consistent */
}

.bg-premium:before{
  /* if you already have bg-premium::before, keep it.
     This is just to ensure we DON'T create a hard edge. */
}

/* This adds a soft "blend" at the top of every premium section */
.bg-premium .container{
  position: relative;
  z-index: 1;
}

.bg-premium::after{
  /* if you already use ::after for grain, keep it.
     We'll add a new element using box-shadow style instead below. */
}

/* Add a soft fade overlay at top of each section (seamless) */
.bg-premium{
  --section-fade: rgba(7,12,22,1);
}

.bg-premium > .container{
  position: relative;
  z-index: 1;
}

.bg-premium{
  background: transparent; /* let body/hero flow */
}

.bg-premium{
  /* create a blend fade without visible border */
  box-shadow: inset 0 36px 50px rgba(7,12,22,.85);
}

.what-strip,
.process-strip,
.trust-strip{
  border-color: rgba(255,255,255,.10) !important; /* softer */
  box-shadow: 0 22px 55px rgba(0,0,0,.22) !important; /* less harsh */
}

.spacer{
  height: 22vh;
  border: none;
  opacity: 0;
}