:root {
  --bg: #0B0F1A;
  --panel: #121827;
  --panel-2: #1C2230;
  --blue: #3A6DF0;
  --cyan: #00C2FF;
  --violet: #7A5CFF;
  --ice: #E8ECF4;
  --steel: #A2A9B9;
  --max: 1180px;
  --radius: 24px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background:
    radial-gradient(circle at 15% 10%, rgba(58,109,240,0.18), transparent 24%),
    radial-gradient(circle at 80% 0%, rgba(0,194,255,0.10), transparent 24%),
    radial-gradient(circle at 50% 35%, rgba(122,92,255,0.08), transparent 26%),
    linear-gradient(180deg, #0a0f19 0%, #0b0f1a 48%, #0c111d 100%);
  color: var(--ice);
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(var(--max), calc(100% - 64px)); margin: 0 auto; }
.narrow { max-width: 860px; }
.nav {
  position: sticky;
  top: 0;
  z-index: 20;
  backdrop-filter: blur(18px);
  background: linear-gradient(180deg, rgba(11,15,26,0.84), rgba(11,15,26,0.68));
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.nav-inner { display:flex; align-items:center; justify-content:space-between; padding: 18px 0; }
.logo { display:flex; align-items:center; gap:14px; font-weight:700; letter-spacing: -0.01em; }
.logo img { width:40px; height:40px; border-radius:12px; }
.nav-links { display:flex; gap:26px; font-size:14px; color: rgba(232,236,244,0.8); }
.nav-links a { position: relative; }
.nav-links a::after { content: ''; position: absolute; left: 0; right: 0; bottom: -8px; height: 1px; background: rgba(0,194,255,0.7); transform: scaleX(0); transform-origin: left; transition: transform 180ms ease; }
.nav-links a:hover::after { transform: scaleX(1); }
.hero { padding: 76px 0 72px; }
.scroll-start { padding-top: 88px; }
.hero-grid { display:grid; grid-template-columns: 1.02fr 0.98fr; gap: 42px; align-items: stretch; }
.hero-copy { padding: 32px 0 18px; }
.eyebrow { display:inline-flex; gap:8px; align-items:center; padding:8px 12px; border:1px solid rgba(255,255,255,0.10); border-radius:999px; font-size:13px; color: rgba(232,236,244,0.84); background: rgba(255,255,255,0.02); }
.eyebrow::before { content:''; width:8px; height:8px; border-radius:50%; background: linear-gradient(135deg,var(--cyan),var(--blue)); box-shadow: 0 0 20px rgba(0,194,255,0.6); }
h1 { font-size: clamp(50px, 7vw, 84px); line-height: 0.94; letter-spacing: -0.05em; margin: 20px 0 20px; max-width: 11ch; }
h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.02; letter-spacing: -0.04em; margin: 0 0 18px; }
.hero p.lead, .intro-flow p, .band p, .footer-copy {
  font-size: 20px;
  line-height: 1.8;
  color: rgba(232,236,244,0.78);
}
.hero p.lead { max-width: 60ch; margin: 0 0 34px; }
.hero-note { margin-top: 28px; color: rgba(232,236,244,0.54); font-size: 13px; letter-spacing: 0.06em;  }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; }
.button { display:inline-flex; align-items:center; justify-content:center; padding: 15px 20px; border-radius: 14px; font-weight: 600; border: 1px solid rgba(255,255,255,0.10); }
.button.primary { background: linear-gradient(135deg, var(--blue), var(--cyan)); color: white; box-shadow: 0 18px 36px rgba(58,109,240,0.25); }
.button.secondary { background: rgba(255,255,255,0.02); color: var(--ice); }
.hero-card { position: relative; min-height: 700px; border-radius: 32px; overflow: hidden; background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01)); border:1px solid rgba(255,255,255,0.08); box-shadow: 0 30px 60px rgba(0,0,0,0.30); }
.hero-card .bg { position:absolute; inset:0; background: linear-gradient(180deg, rgba(9,11,19,0.18), rgba(9,11,19,0.72)), url('assets/hero-generated.png') center/cover no-repeat; }
.hero-card .overlay { position:absolute; inset:0; background: radial-gradient(circle at 70% 20%, rgba(0,194,255,0.2), transparent 24%), linear-gradient(180deg, transparent 0, rgba(10,15,25,0.86) 76%); }
.hero-card .content { position:absolute; inset:auto 28px 28px 28px; display:grid; gap:18px; }
.metric-row { display:grid; grid-template-columns: repeat(3,1fr); gap:12px; }
.metric { padding:18px; background: rgba(9,11,19,0.55); border:1px solid rgba(255,255,255,0.08); border-radius:18px; backdrop-filter: blur(10px); }
.metric strong { display:block; font-size: 28px; letter-spacing:-0.03em; margin-bottom:6px; }
.metric span { display:block; font-size: 13px; line-height:1.55; color: rgba(232,236,244,0.7); }
section { padding: 66px 0; }
.story-block { position: relative; }
.story-block::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.012), rgba(255,255,255,0));
  pointer-events: none;
}
.intro-flow { display: grid; gap: 12px; }
.intro-flow p { margin: 0; max-width: 44em; }
.section-head { display:flex; justify-content:space-between; align-items:end; gap:20px; margin-bottom: 34px; }
.section-head-stack { display:grid; justify-content:start; align-items:start; gap: 0; }
.section-head-stack p { margin: 0; max-width: 54em; color: rgba(232,236,244,0.68); line-height: 1.8; font-size: 18px; }
.wide-gap { margin-bottom: 42px; }
.grid-3 { display:grid; grid-template-columns: repeat(3,1fr); gap:24px; }
.grid-2 { display:grid; grid-template-columns: repeat(2,1fr); gap:24px; }
.roomy-grid { gap: 26px; }
.card {
  background: linear-gradient(180deg, rgba(28,34,48,0.76), rgba(18,24,39,0.62));
  border:1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius);
  padding: 28px;
  box-shadow: 0 18px 42px rgba(0,0,0,0.18);
}
.glass { box-shadow: none; }
.soft-card { backdrop-filter: blur(12px); }
.card h3 { margin:0 0 14px; font-size:26px; letter-spacing:-0.03em; }
.card p, .card li { color: rgba(232,236,244,0.72); line-height: 1.72; font-size: 16px; }
.card ul { margin: 16px 0 0 20px; padding:0; display: grid; gap: 8px; }
.kicker { font-family: 'IBM Plex Mono', Menlo, monospace; letter-spacing:0.14em;  font-size:12px; color: var(--cyan); margin-bottom:12px; display:block; }
.work-card { min-height: 260px; position:relative; overflow:hidden; }
.work-card::after { content:''; position:absolute; inset:auto -30px -80px auto; width:180px; height:180px; background: radial-gradient(circle, rgba(0,194,255,0.18), transparent 68%); }
.emphasis-band { background: linear-gradient(180deg, rgba(58,109,240,0.06), rgba(122,92,255,0.04)); }
.band {
  padding: 40px;
  border-radius: 32px;
  background: linear-gradient(135deg, rgba(58,109,240,0.16), rgba(122,92,255,0.10));
  border:1px solid rgba(255,255,255,0.08);
  display:grid;
  grid-template-columns: 1.16fr 0.84fr;
  gap:30px;
  align-items:stretch;
}
.airy-band { padding-top: 46px; padding-bottom: 46px; }
blockquote { margin:0; font-size: 24px; line-height:1.5; letter-spacing:-0.02em; }
.persona { display:flex; gap:18px; align-items:center; }
.persona img { width:64px; height:64px; border-radius:18px; }
.founder-card { display: flex; flex-direction: column; justify-content: center; }
.small { font-size:14px; color: rgba(232,236,244,0.62); line-height: 1.7; }
.subtle-section { background: linear-gradient(180deg, rgba(255,255,255,0.015), rgba(255,255,255,0)); }
.logo-strip-section { padding: 40px 0 54px; overflow: hidden; }


@media (max-width: 980px) {
  
  
  
}



  

  
}










/* Ensure long logo names don't shrink weirdly */
.logo-pill-image img[alt*="Bramley"],
.logo-pill-image img[alt*="Adel"] {
  max-width: 148px !important;
  max-height: 18px !important;
}

@media (max-width: 980px) {
  

  

  
}


@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}


/* --- client logo row --- */
.logo-marquee{
  position: relative;
  overflow: hidden;
  width: 100%;
  padding: 6px 0 2px;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 7%, #000 93%, transparent);
  mask-image: linear-gradient(to right, transparent, #000 7%, #000 93%, transparent);
}

.logo-track{
  display:flex;
  align-items:center;
  gap:14px;
  width:max-content;
  animation: marquee 38s linear infinite;
  will-change: transform;
}

.logo-pill-image{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  height:100px;
  min-height:100px;
  padding:0 30px;
  border-radius:999px;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  box-sizing:border-box;
}

.logo-pill-image img{
  display:block;
  width:auto;
  height:42px;
  max-width:180px;
  object-fit:contain;
  filter: grayscale(1) brightness(1.08) contrast(1.02);
  opacity:0.96;
}

.logo-pill-image img[alt*="Bramley"],
.logo-pill-image img[alt*="Adel"],
.logo-pill-image img[alt*="Morgan Stanley"]{
  max-width:200px;
  height:38px;
}

@media (max-width: 980px){
  .logo-track{
    gap:10px;
    animation: marquee 32s linear infinite;
  }
  .logo-pill-image{
    height:88px;
    min-height:88px;
    padding:0 24px;
  }
  .logo-pill-image img{
    height:36px;
    max-width:160px;
  }
  .logo-pill-image img[alt*="Bramley"],
  .logo-pill-image img[alt*="Adel"],
  .logo-pill-image img[alt*="Morgan Stanley"]{
    max-width:176px;
    height:32px;
  }
}






/* contact two-column restore */
.contact-grid,
.contact-columns,
.contact-wrap,
.contact-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr) !important;
  gap: 2.25rem !important;
  align-items: start !important;
}

.contact-grid > *,
.contact-columns > *,
.contact-wrap > *,
.contact-layout > * {
  min-width: 0;
}

@media (max-width: 900px) {
  .contact-grid,
  .contact-columns,
  .contact-wrap,
  .contact-layout {
    grid-template-columns: 1fr !important;
  }
}


section[id*="contact"] .inner,
section.contact .inner,
.contact-section .inner {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
  gap: 2.25rem;
  align-items: start;
}

@media (max-width: 900px) {
  section[id*="contact"] .inner,
  section.contact .inner,
  .contact-section .inner {
    grid-template-columns: 1fr;
  }
}


/* menu and subtitle case */
nav a,
.site-nav a,
header nav a {
  text-transform: none !important;
}

.kicker,
.eyebrow,
.section-label,
.overline {
  text-transform: uppercase !important;
  letter-spacing: 0.14em;
}
