:root {
  --bg: #04070d;
  --surface: #0c1424;
  --text: #e6edf7;
  --cyan: #12d7f3;
  --gold: #f5b942;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--text);
  background:
    radial-gradient(circle at 15% 10%, rgba(0, 229, 255, 0.22), transparent 35%),
    radial-gradient(circle at 85% 18%, rgba(245, 185, 66, 0.16), transparent 30%),
    linear-gradient(125deg, #04070d 0%, #081122 54%, #060a14 100%);
  font-family: "Manrope", sans-serif;
}
body.page-enter {
  opacity: 0;
}
body.page-enter.page-enter-active {
  opacity: 1;
  transition: opacity 260ms ease;
}
body.page-exit {
  opacity: 0;
  transition: opacity 220ms ease;
}
h1,h2,h3 { font-family: "Sora", sans-serif; margin: 0 0 0.6rem; }
a { color: inherit; text-decoration: none; }

.container { width: min(1120px, 92vw); margin: 0 auto; }
.section { padding: 5rem 0; }

.site-header {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(8px);
  background: rgba(4, 7, 13, 0.8);
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.nav-shell { display: flex; align-items: center; justify-content: space-between; gap: .85rem; padding: .55rem 0; }
.brand { font-weight: 800; font-size: 1.2rem; }
.brand span { color: var(--cyan); }
.brand-logo-wrap { max-width: 320px; overflow: hidden; flex: 0 0 auto; }
.brand-logo-wrap img,
.brand-logo-wrap .custom-logo {
  height: 56px !important;
  width: auto !important;
  max-height: 56px !important;
  max-width: 320px !important;
  object-fit: contain;
}
.brand-logo-wrap .custom-logo-link { display: inline-flex; }
.nav-links { display: flex; list-style: none; gap: 1rem; margin: 0; padding: 0; }
.nav-links li { white-space: nowrap; }
.nav-links a { font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; opacity: .9; }

.btn {
  appearance: none;
  -webkit-appearance: none;
  font-family: "Manrope", sans-serif;
  line-height: 1;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: .68rem 1.15rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  cursor: pointer;
}
.btn-gold { background: var(--gold); color: #181818; }
.btn-cyan { border-color: rgba(0,229,255,.7); color: var(--cyan); }

.hero-grid {
  position: relative;
  background-image:
    linear-gradient(rgba(0, 229, 255, 0.11) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 229, 255, 0.11) 1px, transparent 1px);
  background-size: 48px 48px;
}
.hero-layout { display: grid; gap: 2rem; grid-template-columns: 1.1fr 1fr; align-items: center; }
.hero h1 { font-size: clamp(2.4rem, 7vw, 6rem); line-height: .95; }
.hero h1 span { color: var(--cyan); text-shadow: 0 0 20px rgba(0,229,255,.8); }
.eyebrow { text-transform: uppercase; letter-spacing: .22em; color: var(--cyan); font-size: .75rem; }
.hero-sub { font-size: clamp(1rem, 2vw, 1.2rem); }
.hero-actions { display: flex; gap: .8rem; flex-wrap: wrap; margin-top: 1.5rem; }
.hero-brand-image {
  display: block;
  max-width: min(360px, 92%);
  width: auto;
  height: auto;
  margin: 0 0 1rem;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: .75rem;
  box-shadow: 0 0 24px rgba(0,229,255,.22);
}

.hero-visual { position: relative; height: 420px; transition: transform .25s ease; }
.hero-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 1.25rem;
  opacity: .24;
  border: 1px solid rgba(255,255,255,.2);
}
.wireframe {
  position: absolute; left: 50%; top: 36%; width: 260px; height: 260px;
  transform: translate(-50%,-50%) rotate(45deg);
  border: 1px solid rgba(0,229,255,.6);
  animation: float 8s ease-in-out infinite;
}
.hero-panel {
  position: absolute; padding: .8rem; width: 180px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 1rem;
  background: rgba(10, 18, 34, .82);
  animation: panelDrift 7s ease-in-out infinite;
}
.hero-panel strong { font-size: 1.7rem; }
.hero-panel:nth-of-type(1) { left: 0; top: 80px; }
.hero-panel:nth-of-type(2) { right: 0; top: 50px; animation-delay: .8s; }
.hero-panel:nth-of-type(3) { bottom: 20px; left: 50%; transform: translateX(-50%); animation-delay: 1.4s; }
.hero-link { position: absolute; height: 1px; background: linear-gradient(90deg, transparent, rgba(0,229,255,.9), transparent); }
.hero-link-a { left: 14%; top: 38%; width: 42%; transform: rotate(-14deg); }
.hero-link-b { left: 44%; top: 30%; width: 38%; transform: rotate(24deg); }
.hero-link-c { left: 36%; top: 70%; width: 40%; transform: rotate(-10deg); }
.hero-node { position: absolute; width: 10px; height: 10px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 14px rgba(0,229,255,.9); animation: nodePulse 5s ease-in-out infinite; }
.hero-node-a { left: 8%; top: 24%; }
.hero-node-b { right: 12%; top: 14%; animation-delay: 1.2s; }
.hero-node-c { right: 18%; bottom: 16%; animation-delay: 2s; }

.section-title { position: relative; display: inline-block; padding-bottom: .55rem; }
.section-title::after { content: ""; position: absolute; left: 0; bottom: 0; width: 64%; height: 3px; background: linear-gradient(90deg, var(--cyan), transparent); }
.grid-2 { margin-top: 1.5rem; display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
.grid-3 { margin-top: 1.5rem; display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem; }
.horizontal-cards { margin-top: 1.5rem; display: flex; gap: 1rem; overflow-x: auto; }
.portfolio-grid { margin-top: 1rem; display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem; }
.card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 1.25rem;
  padding: 1.2rem;
  min-width: 280px;
  backdrop-filter: blur(6px);
}
.card ul { margin: .5rem 0 0; padding-left: 1.15rem; line-height: 1.6; }
.card li { margin-bottom: .3rem; }
.card-cyan { background: rgba(0,229,255,.11); border-color: rgba(0,229,255,.5); }
.card-icon-wrap { margin-bottom: .5rem; }
.card-icon-text { font-size: 1.55rem; display: inline-block; }
.card-icon-image {
  width: 40px;
  height: 40px;
  object-fit: cover;
  border-radius: .5rem;
  border: 1px solid rgba(255,255,255,.25);
}
.card-thumb {
  width: 100%;
  height: 150px;
  object-fit: cover;
  border-radius: .8rem;
  margin-bottom: .8rem;
  border: 1px solid rgba(255,255,255,.2);
}
.metric { color: var(--gold); font-weight: 700; }
.card-link { color: var(--cyan); font-weight: 700; }
.teaser-link { margin-top: 1rem; }

.filter-row {
  margin-top: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}
.filter-btn {
  appearance: none;
  -webkit-appearance: none;
  font-family: "Manrope", sans-serif;
  line-height: 1;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.2);
  color: var(--text);
  padding: .45rem .8rem;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 600;
}
.filter-row .filter-btn {
  background: rgba(255,255,255,.05) !important;
  border: 1px solid rgba(255,255,255,.2) !important;
  color: var(--text) !important;
}
.filter-btn.is-active {
  border-color: rgba(0,229,255,.8);
  color: var(--cyan);
  background: rgba(0,229,255,.1);
}
.filter-row .filter-btn.is-active {
  border-color: rgba(0,229,255,.8) !important;
  color: var(--cyan) !important;
  background: rgba(0,229,255,.1) !important;
}
.cat-pill-wrap { margin: .8rem 0 .2rem; display: flex; flex-wrap: wrap; gap: .4rem; }
.cat-pill {
  font-size: .75rem;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 999px;
  padding: .2rem .55rem;
  opacity: .9;
}
.filter-empty { margin-top: .8rem; opacity: .8; }
.portfolio-intro-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; margin-top: 1rem; }
.gallery-grid { grid-template-columns: repeat(12, minmax(0, 1fr)); gap: .9rem; }
.photo-grid-card {
  position: relative;
  min-width: 0;
  min-height: 240px;
  padding: 0;
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(7, 14, 30, .7);
  transform: translateZ(0);
}
.photo-grid-card:nth-child(6n + 1),
.photo-grid-card:nth-child(6n + 4) { grid-column: span 6; }
.photo-grid-card:nth-child(6n + 2),
.photo-grid-card:nth-child(6n + 3),
.photo-grid-card:nth-child(6n + 5),
.photo-grid-card:nth-child(6n + 6) { grid-column: span 3; }
.photo-grid-card__img {
  width: 100%;
  height: 100%;
  min-height: 240px;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
  transition: transform .55s cubic-bezier(.2,.6,.2,1), filter .55s ease;
}
.photo-grid-card__overlay {
  position: absolute;
  inset: 0;
  border: 0;
  width: 100%;
  background:
    linear-gradient(180deg, rgba(4,7,13,.06) 20%, rgba(4,7,13,.86) 84%),
    linear-gradient(120deg, rgba(0,229,255,.0), rgba(0,229,255,.17));
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  gap: .35rem;
  padding: 1rem;
  cursor: pointer;
  text-align: left;
}
.photo-grid-card__overlay::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(130deg, rgba(0,229,255,.0), rgba(0,229,255,.22));
  opacity: 0;
  transition: opacity .35s ease;
}
.photo-grid-card__title {
  position: relative;
  font-size: 1.08rem;
  font-weight: 800;
  letter-spacing: .01em;
  transform: translateY(8px);
  opacity: .95;
  transition: transform .35s ease;
}
.photo-grid-card__meta {
  position: relative;
  display: flex;
  gap: .35rem;
  flex-wrap: wrap;
  transform: translateY(12px);
  opacity: 0;
  transition: transform .35s ease, opacity .35s ease;
}
.photo-grid-card:hover .photo-grid-card__img {
  transform: scale(1.09);
  filter: saturate(1.1);
}
.photo-grid-card:hover .photo-grid-card__overlay::before { opacity: 1; }
.photo-grid-card:hover .photo-grid-card__title { transform: translateY(0); }
.photo-grid-card:hover .photo-grid-card__meta {
  transform: translateY(0);
  opacity: 1;
}
.photo-grid-card:hover { box-shadow: 0 14px 30px rgba(0,0,0,.35), 0 0 0 1px rgba(0,229,255,.35) inset; }
.thumb-placeholder {
  background: linear-gradient(135deg, rgba(0,229,255,.14), rgba(245,185,66,.12));
}
.gallery-excerpt { opacity: .92; }

.stepper { display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); gap: .75rem; margin-top: 1.5rem; }
.step {
  text-align: left;
  border: 1px solid rgba(255,255,255,.2);
  background: rgba(255,255,255,.04);
  color: var(--text);
  border-radius: .9rem;
  padding: .8rem;
  cursor: pointer;
}
.step.is-active { border-color: var(--cyan); background: rgba(0,229,255,.1); }
.process-detail { margin-top: 1rem; }

.proof-bar { border-top: 1px solid rgba(0,229,255,.3); border-bottom: 1px solid rgba(0,229,255,.3); background: #081220; padding: 1rem 0; }
.proof-grid { display: grid; gap: .5rem; grid-template-columns: 1.2fr 1fr 1fr 1fr; font-weight: 700; }

.contact-cta { text-align: center; }
.video-section p { max-width: 760px; }
.video-shell {
  margin-top: 1rem;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 1rem;
  overflow: hidden;
  background: rgba(6, 16, 30, .9);
}
.video-shell iframe {
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 0;
  display: block;
}
.video-placeholder {
  aspect-ratio: 16 / 9;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 1rem;
  color: rgba(230, 237, 247, .85);
}
.video-cta-wrap { margin-top: 1rem; }
.founder-photo {
  width: 100%;
  height: 210px;
  object-fit: cover;
  border-radius: .9rem;
  margin-bottom: .8rem;
  border: 1px solid rgba(255,255,255,.2);
}
.quote { color: var(--cyan); font-style: italic; }

.site-footer { border-top: 1px solid rgba(255,255,255,.1); background: rgba(4,7,13,.7); }
.footer-grid { display: grid; gap: 1rem; grid-template-columns: repeat(3,minmax(0,1fr)); padding: 2.5rem 0; }
.footer-brand { font-weight: 800; }
.footer-label { color: var(--cyan); text-transform: uppercase; letter-spacing: .06em; font-size: .85rem; }
.copyright { text-align: center; border-top: 1px solid rgba(255,255,255,.1); padding: .85rem 0; font-size: .75rem; opacity: .8; }

.mesh-overlay {
  position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    linear-gradient(rgba(0, 229, 255, 0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 229, 255, 0.07) 1px, transparent 1px);
  background-size: 52px 52px;
  animation: meshShift 16s linear infinite;
}

.contact-modal { position: fixed; inset: 0; background: rgba(2,6,17,.85); display: none; align-items: center; justify-content: center; padding: 1rem; z-index: 90; }
.contact-modal.is-open { display: flex; }
.contact-modal__panel { width: min(720px, 95vw); background: rgba(3,10,22,.95); border: 1px solid rgba(255,255,255,.2); border-radius: 1.5rem; padding: 1.25rem; }
.contact-modal__close { float: right; border: 1px solid rgba(255,255,255,.3); background: transparent; color: #fff; border-radius: 999px; padding: .3rem .7rem; cursor: pointer; }
.contact-form { display: grid; gap: .8rem; }
.form-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: .8rem; }
input,select,textarea { width: 100%; border-radius: .75rem; border: 1px solid rgba(255,255,255,.15); background: rgba(0,0,0,.3); color: #fff; padding: .75rem .9rem; }
.form-status {
  border-radius: .75rem;
  padding: .75rem .85rem;
  margin: 0 0 .75rem;
  font-weight: 600;
}
.form-status.is-success { background: rgba(0, 229, 255, .14); border: 1px solid rgba(0, 229, 255, .45); }
.form-status.is-error { background: rgba(255, 95, 95, .15); border: 1px solid rgba(255, 95, 95, .45); }
.content-block {
  min-height: 120px;
  margin-top: 1rem;
}
.gallery-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  z-index: 95;
  background: rgba(1, 4, 12, .86);
  backdrop-filter: blur(5px);
}
.gallery-modal.is-open { display: flex; }
.gallery-modal__panel {
  position: relative;
  width: min(1080px, 96vw);
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,.2);
  background: rgba(7, 14, 28, .96);
  overflow: hidden;
}
.gallery-modal__panel img {
  width: 100%;
  max-height: min(70vh, 760px);
  object-fit: contain;
  display: block;
  background: rgba(0,0,0,.4);
}
.gallery-modal__meta { padding: .9rem 1rem 1.1rem; }
.gallery-modal__title { margin: 0 0 .35rem; font-weight: 800; font-size: 1.08rem; }
.gallery-modal__caption { margin: 0 0 .65rem; color: rgba(230,237,247,.9); }
.gallery-modal__close {
  position: absolute;
  margin: .75rem;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(3,9,20,.7);
  color: #fff;
  border-radius: 999px;
  padding: .35rem .72rem;
  cursor: pointer;
}
.service-extras,
.process-support,
.contact-grid { margin-top: 1rem; }
.section .grid-2 + .content-block,
.section .grid-3 + .content-block,
.section .stepper + .content-block,
.section .portfolio-grid + .content-block {
  margin-top: 1.25rem;
}
.work-content { line-height: 1.65; }
.work-single { max-width: 920px; margin: 0 auto; }
.project-gallery-grid {
  margin: 1rem 0 1.2rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .7rem;
}
.project-gallery-item {
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: .85rem;
  overflow: hidden;
  padding: 0;
  background: rgba(8, 16, 30, .8);
  cursor: pointer;
}
.project-gallery-item img,
.project-gallery-item .thumb-placeholder {
  display: block;
  width: 100%;
  height: 170px;
  object-fit: cover;
}
.project-gallery-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(0,0,0,.35), 0 0 0 1px rgba(0,229,255,.35) inset;
  transition: transform .24s ease, box-shadow .24s ease;
}
.blog-page-intro { max-width: 720px; margin-bottom: 1rem; }
.blog-kicker {
  margin: 0 0 .45rem;
  font-size: .72rem;
  letter-spacing: .11em;
  text-transform: uppercase;
  color: var(--cyan);
  font-weight: 700;
}
.blog-hero-card {
  margin-top: 1rem;
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.2);
  background: rgba(8, 16, 30, .9);
}
.blog-hero-link { display: block; position: relative; min-height: 420px; }
.blog-hero-image {
  width: 100%;
  height: 420px;
  object-fit: cover;
  display: block;
  filter: saturate(1.08);
}
.blog-hero-overlay {
  position: absolute;
  inset: auto 0 0;
  padding: 1.2rem 1.2rem 1.35rem;
  background: linear-gradient(180deg, rgba(4,7,13,.08) 0%, rgba(4,7,13,.92) 88%);
}
.blog-hero-overlay h2 { margin: 0 0 .35rem; font-size: clamp(1.4rem, 2.8vw, 2.1rem); }
.blog-hero-overlay p { margin: 0; max-width: 88%; color: rgba(230,237,247,.95); }
.news-grid {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(12, minmax(0,1fr));
  gap: .9rem;
}
.news-card {
  grid-column: span 4;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 1rem;
  overflow: hidden;
  background: rgba(9, 18, 34, .8);
  min-width: 0;
}
.news-card-large { grid-column: span 8; }
.news-card-link { display: block; height: 100%; }
.news-card-thumb {
  width: 100%;
  height: 210px;
  object-fit: cover;
  display: block;
}
.news-card-large .news-card-thumb { height: 280px; }
.news-card-content { padding: .95rem .95rem 1rem; }
.news-card-content h3 { margin: 0 0 .35rem; font-size: 1.1rem; line-height: 1.25; }
.news-card-content p { margin: 0; color: rgba(230,237,247,.92); }
.news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 30px rgba(0,0,0,.35), 0 0 0 1px rgba(0,229,255,.28) inset;
  transition: transform .28s ease, box-shadow .28s ease;
}

.motion-reveal { opacity: 0; transform: translateY(24px) scale(.985); transition: opacity .62s ease, transform .62s cubic-bezier(.21,1,.22,1); }
.motion-reveal.is-visible { opacity: 1; transform: translateY(0) scale(1); }

@keyframes float { 0%,100% { transform: translate(-50%,-50%) rotate(45deg); } 50% { transform: translate(-50%,-58%) rotate(45deg); } }
@keyframes panelDrift { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
@keyframes nodePulse { 0%,100% { opacity:.35; transform:scale(1); } 50% { opacity:1; transform:scale(1.22); } }
@keyframes meshShift { 0% { transform: translate3d(0,0,0);} 50% { transform: translate3d(-1.2%,1.1%,0);} 100% { transform: translate3d(1%,-1%,0);} }

@media (max-width: 960px) {
  .nav-links { display: none; }
  .hero-layout, .grid-2, .grid-3, .footer-grid, .proof-grid, .stepper, .form-grid, .portfolio-grid, .portfolio-intro-grid { grid-template-columns: 1fr; }
  .hero-visual { height: 350px; }
  .news-grid { grid-template-columns: 1fr; }
  .news-card, .news-card-large { grid-column: span 1; }
  .blog-hero-image, .blog-hero-link { min-height: 280px; height: 280px; }
  .blog-hero-overlay p { max-width: 100%; }
  .project-gallery-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gallery-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .photo-grid-card:nth-child(6n + 1),
  .photo-grid-card:nth-child(6n + 2),
  .photo-grid-card:nth-child(6n + 3),
  .photo-grid-card:nth-child(6n + 4),
  .photo-grid-card:nth-child(6n + 5),
  .photo-grid-card:nth-child(6n + 6) { grid-column: span 1; }
}
