:root {
  --cream: #faf7f0;
  --cream-deep: #efe7da;
  --navy: #11182b;
  --navy-soft: #1d263b;
  --taupe: #746c62;
  --taupe-soft: #9b9286;
  --brown: #7d6551;
  --gold: #c5a77d;
  --gold-deep: #a98252;
  --line: rgba(28, 35, 54, 0.12);
  --line-warm: rgba(165, 132, 83, 0.22);
  --white: #fff;
  --shadow: 0 26px 70px rgba(42, 34, 23, 0.12);
  --shadow-soft: 0 14px 36px rgba(42, 34, 23, 0.09);
  --radius: 8px;
  --max: 1180px;
  --header: 92px;
  --sidebar: 68px;
}

* { box-sizing: border-box; }
html { background: #080a0e; scroll-behavior: smooth; overflow-x: hidden; }
body {
  min-height: 100vh;
  margin: 0;
  color: var(--navy);
  background:
    radial-gradient(circle at 82% 8%, rgba(67,75,90,.34), transparent 34%),
    radial-gradient(circle at 16% 82%, rgba(197,167,125,.12), transparent 30%),
    linear-gradient(135deg, #080a0e 0%, #151920 42%, #0b0d12 100%);
  font-family: "Inter", system-ui, sans-serif;
  overflow-x: hidden;
}
main { position: relative; z-index: 4; margin-left: calc(var(--sidebar) + 28px); overflow-x: hidden; }
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px),
    radial-gradient(circle at 50% 20%, rgba(255,255,255,.07), transparent 38%);
  background-size: 72px 72px, 72px 72px, auto;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.88), rgba(0,0,0,.3));
}
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; letter-spacing: 0; }
button { cursor: pointer; }
#background-canvas { position: fixed; inset: 0; width: 100%; height: 100%; z-index: 0; opacity: .92; pointer-events: none; }
.depth-scene { position: fixed; inset: 0; z-index: 1; pointer-events: none; perspective: 1000px; overflow: hidden; }
.depth-grid {
  position: absolute;
  width: 840px;
  height: 520px;
  --grid-transform: rotateX(62deg) rotateZ(-18deg) translateZ(-120px);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(197,167,125,.035) 1px, transparent 1px);
  background-size: 42px 42px;
  transform: var(--grid-transform);
  animation: gridFloat 18s ease-in-out infinite;
}
.depth-grid-a { left: -240px; top: 150px; }
.depth-grid-b { right: -330px; bottom: -80px; opacity: .58; --grid-transform: rotateX(64deg) rotateZ(22deg) translateZ(-210px); animation-duration: 22s; }
.depth-slab { position: absolute; border: 1px solid rgba(255,255,255,.08); border-radius: 26px; background: rgba(10,12,17,.34); box-shadow: 0 24px 64px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.08); backdrop-filter: blur(8px); animation: slabDrift 18s ease-in-out infinite; }
.slab-one { width: 310px; height: 430px; right: 8%; top: 16%; transform: rotateX(10deg) rotateZ(12deg); }
.slab-two { width: 120px; height: 120px; left: 54%; bottom: 10%; animation-delay: 1.8s; transform: rotateZ(18deg); background: rgba(255,255,255,.05); }
.slab-three { width: 82px; height: 82px; right: 5%; top: 2%; animation-delay: 3s; background: rgba(255,255,255,.06); }

.site-header { position: fixed; inset: 0 0 auto; z-index: 30; background: rgba(250,247,240,.78); border-bottom: 1px solid rgba(255,255,255,.72); backdrop-filter: blur(12px); transition: background .18s ease, box-shadow .18s ease; }
.site-header.scrolled { background: rgba(250,247,240,.9); box-shadow: 0 16px 42px rgba(61,49,34,.12); }
.nav-wrap { width: calc(100% - 44px); max-width: none; min-height: var(--header); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: inline-flex; align-items: center; gap: 16px; min-width: 0; }
.brand-mark {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}
.brand-mark img { display: block; width: 218px; height: auto; object-fit: contain; object-position: center; padding: 0; overflow: visible; }
.brand-copy { display: none; flex-direction: column; justify-content: center; line-height: 1; }
.brand-copy strong {
  font-family: "Cinzel", "Playfair Display", Georgia, serif;
  font-size: 2.02rem;
  color: var(--navy);
  font-weight: 900;
  font-style: normal;
  letter-spacing: 0;
  line-height: .94;
  text-shadow: 0 1px 0 rgba(255,255,255,.72), 0 14px 28px rgba(17,24,43,.12);
}
.brand-copy small {
  margin-top: 8px;
  color: rgba(17,24,43,.72);
  font-family: "Manrope", "Montserrat", Inter, Arial, sans-serif;
  font-size: .66rem;
  font-weight: 900;
  letter-spacing: .12em;
  line-height: 1.12;
  text-transform: uppercase;
}
.site-footer a, .side-menu a, .dock-menu a { transition: color .2s ease, transform .22s ease, background .22s ease, box-shadow .22s ease, border-color .22s ease; }
.site-footer a:hover { color: var(--navy); transform: translateY(-2px); }
.nav-cta, .btn, .mobile-cta, .side-menu-cta { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; border: 1px solid transparent; border-radius: 8px; padding: 0 22px; font-weight: 800; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease; }
.nav-cta, .btn.primary, .mobile-cta, .side-menu-cta { color: var(--white); background: var(--navy); box-shadow: 0 18px 38px rgba(17,24,43,.18); }
.btn.secondary { color: var(--navy); background: rgba(255,255,255,.5); border-color: rgba(17,24,43,.12); backdrop-filter: blur(12px); }
.nav-cta:hover, .btn:hover, .mobile-cta:hover, .side-menu-cta:hover { transform: translateY(-4px) scale(1.02); box-shadow: 0 24px 54px rgba(17,24,43,.2); }
.btn.primary:hover, .nav-cta:hover, .mobile-cta:hover, .side-menu-cta:hover { background: #080d1d; }
.nav-cta:active, .btn:active, .mobile-cta:active, .side-menu-cta:active,
.card:active, .project-preview:active, .bug-report-link:active {
  transform: translateY(-1px) scale(.995);
}
.menu-toggle, .mobile-menu, .mobile-break { display: none; }

.side-menu {
  position: fixed;
  top: calc(var(--header) + 18px);
  bottom: 18px;
  left: 16px;
  z-index: 24;
  width: var(--sidebar);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 10px 8px;
  border: 1px solid rgba(250,247,240,.12);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(250,247,240,.08), rgba(250,247,240,.03)),
    rgba(8,10,14,.86);
  box-shadow: 0 22px 56px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.12);
  backdrop-filter: blur(12px);
}
.side-menu::before {
  content: "";
  position: absolute;
  inset: 10px auto 10px 0;
  width: 1px;
  border-radius: 999px;
  background: linear-gradient(180deg, transparent, rgba(197,167,125,.52), transparent);
}
.side-menu-stack {
  display: grid;
  gap: 8px;
  width: 100%;
  justify-items: center;
}
.side-menu a {
  position: relative;
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border: 1px solid transparent;
  border-radius: 16px;
  color: rgba(250,247,240,.72);
  background: transparent;
  font-weight: 900;
}
.side-menu svg {
  display: block;
  width: 19px;
  height: 19px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.side-menu-orb {
  overflow: hidden;
  color: var(--navy);
  background: rgba(250,247,240,.94) !important;
  border-color: rgba(250,247,240,.24) !important;
  box-shadow: 0 16px 34px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.86);
}
.side-menu-orb img {
  display: block;
  width: 28px;
  height: auto;
  object-fit: contain;
}
.side-label {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}
.side-menu a::after {
  content: attr(data-tooltip);
  position: absolute;
  left: calc(100% + 12px);
  top: 50%;
  z-index: 2;
  min-width: max-content;
  padding: 8px 11px;
  border: 1px solid rgba(197,167,125,.26);
  border-radius: 999px;
  color: var(--navy);
  background: rgba(250,247,240,.92);
  box-shadow: 0 18px 38px rgba(0,0,0,.16);
  opacity: 0;
  pointer-events: none;
  transform: translate(-6px, -50%);
  transition: opacity .18s ease, transform .18s ease;
  font-size: .76rem;
  font-weight: 900;
}
.side-menu a:hover::after,
.side-menu a:focus-visible::after {
  opacity: 1;
  transform: translate(0, -50%);
}
.side-menu a:not(.side-menu-orb):not(.side-menu-cta)::before,
.side-menu-cta::before {
  content: "";
  position: absolute;
  left: -8px;
  top: 50%;
  width: 3px;
  height: 18px;
  border-radius: 999px;
  background: var(--gold);
  opacity: 0;
  transform: translateY(-50%) scaleY(.62);
  transition: opacity .2s ease, transform .2s ease;
}
.side-menu a:hover,
.side-menu a:focus-visible,
.side-menu a.active {
  color: rgba(250,247,240,.98);
  border-color: rgba(197,167,125,.34);
  background: rgba(250,247,240,.12);
  box-shadow: 0 16px 34px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.12);
  transform: translateY(-2px);
}
.side-menu a.active::before,
.side-menu a:hover::before,
.side-menu a:focus-visible::before {
  opacity: 1;
  transform: translateY(-50%) scaleY(1);
}
.side-menu-cta {
  width: 46px;
  height: 46px;
  min-height: 46px;
  margin-top: auto;
  padding: 0;
  border-radius: 16px;
  color: var(--navy);
  background: linear-gradient(145deg, #f8e7bb, var(--gold));
  box-shadow: 0 18px 44px rgba(197,167,125,.22);
}
.side-menu-cta:hover,
.side-menu-cta:focus-visible {
  color: var(--navy);
  background: linear-gradient(145deg, #ffecc1, #d1b279);
}
.dock-menu {
  position: fixed;
  top: 22px;
  left: 50%;
  z-index: 35;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px;
  border: 1px solid rgba(250,247,240,.78);
  border-radius: 999px;
  background: rgba(250,247,240,.76);
  box-shadow: 0 16px 36px rgba(42,34,23,.1);
  backdrop-filter: blur(12px);
  transform: translateX(-50%);
}
.dock-menu a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 16px;
  border: 1px solid transparent;
  border-radius: 999px;
  color: var(--taupe);
  font-size: .88rem;
  font-weight: 900;
  white-space: nowrap;
}
.dock-menu a:hover,
.dock-menu a:focus-visible,
.dock-menu a.active {
  color: rgba(250,247,240,.96);
  border-color: rgba(17,24,43,.08);
  background: var(--navy);
  box-shadow: 0 14px 30px rgba(17,24,43,.18);
  transform: translateY(-1px);
}

.section { position: relative; z-index: 1; width: calc(100% - 36px); max-width: var(--max); margin: 0 auto; padding: 86px 0 64px; }
.tab-panel { min-height: calc(100vh - var(--header)); }
.tab-panel[hidden], .page-extra[hidden] { display: none !important; }
.tab-panel.tab-revealing { animation: tabReveal .64s cubic-bezier(.2,.72,.2,1) both; }
.tab-panel.tab-revealing .card,
.tab-panel.tab-revealing .project-preview,
.tab-panel.tab-revealing .mini-card,
.tab-panel.tab-revealing .contact-list div,
.tab-panel.tab-revealing .price,
.tab-panel.tab-revealing .hero-actions,
.tab-panel.tab-revealing .hero-service-line,
.tab-panel.tab-revealing .home-utility,
.tab-panel.tab-revealing .proof-row span {
  animation: cardReveal .58s cubic-bezier(.2,.72,.2,1) both;
}
.tab-panel.tab-revealing .card:nth-child(2),
.tab-panel.tab-revealing .mini-card:nth-child(2),
.tab-panel.tab-revealing .proof-row span:nth-child(2) { animation-delay: .08s; }
.tab-panel.tab-revealing .card:nth-child(3),
.tab-panel.tab-revealing .mini-card:nth-child(3),
.tab-panel.tab-revealing .proof-row span:nth-child(3) { animation-delay: .14s; }
.tab-panel.tab-revealing .card:nth-child(4),
.tab-panel.tab-revealing .mini-card:nth-child(4),
.tab-panel.tab-revealing .proof-row span:nth-child(4) { animation-delay: .2s; }
.reveal-pop {
  opacity: 0;
  transform: translateY(14px) scale(.985);
  will-change: opacity, transform;
}
.reveal-pop.is-visible {
  animation: cardReveal .58s cubic-bezier(.2,.72,.2,1) var(--reveal-delay, 0ms) both;
}
.tab-panel[hidden] .reveal-pop {
  animation: none;
}
.hero { min-height: calc(100vh - 22px); display: flex; align-items: center; justify-content: flex-start; padding-top: calc(var(--header) + 28px); padding-bottom: 56px; }
.hero-content { max-width: 1100px; width: 100%; }
.eyebrow { display: inline-flex; align-items: center; gap: 12px; margin: 0 0 28px; padding: 11px 20px; border: 1px solid rgba(255,255,255,.78); border-radius: 999px; background: rgba(255,255,255,.66); color: var(--taupe); box-shadow: var(--shadow-soft); backdrop-filter: blur(8px); font-size: .86rem; font-weight: 800; text-transform: uppercase; }
.eyebrow::before { content: ""; width: 9px; height: 9px; border-radius: 50%; background: var(--navy); }
h1, h2, h3, h4 { margin: 0; letter-spacing: 0; }
h1, h2 { font-family: "Playfair Display", Georgia, serif; color: var(--navy); font-weight: 700; }
h1 {
  max-width: 1120px;
  font-family: "Manrope", Inter, system-ui, sans-serif;
  font-size: 4.5rem;
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: 0;
}
h1 span {
  color: var(--brown);
  font-family: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  font-style: italic;
  font-weight: 700;
  letter-spacing: 0;
}
.hero h1, .section-heading h2, .split-copy h2, .contact-copy h2, .final-cta h2 {
  color: rgba(250,247,240,.96);
  text-shadow: 0 24px 60px rgba(0,0,0,.42);
}
.hero h1 span { color: #d7bb88; }
h3, h4 { color: var(--navy); }
.hero-subtitle { max-width: 880px; margin: 30px 0 0; color: rgba(250,247,240,.76); font-size: 1.22rem; line-height: 1.8; text-shadow: 0 12px 34px rgba(0,0,0,.38); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 18px; align-items: center; margin-top: 42px; }
.hero-actions .btn { min-width: 180px; min-height: 56px; }
.hero-service-line {
  max-width: 1040px;
  margin-top: 32px;
}
.hero-service-line p {
  max-width: 780px;
  margin: 0 0 14px;
  color: rgba(250,247,240,.68);
  font-size: .98rem;
  font-weight: 700;
  line-height: 1.65;
  text-shadow: 0 12px 30px rgba(0,0,0,.34);
}
.hero-service-marquee {
  position: relative;
  overflow: hidden;
  width: 100%;
  border: 1px solid rgba(255,255,255,.78);
  border-radius: 14px;
  background: rgba(255,255,255,.52);
  box-shadow: 0 16px 40px rgba(42,34,23,.09);
  backdrop-filter: blur(8px);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}
.hero-service-marquee:hover {
  border-color: rgba(165,132,83,.3);
  box-shadow: 0 28px 68px rgba(42,34,23,.14);
  transform: translateY(-3px);
}
.hero-service-track {
  display: flex;
  width: max-content;
  animation: heroServiceMarquee 32s linear infinite;
}
.hero-service-marquee:hover .hero-service-track { animation-play-state: paused; }
.hero-service-group {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 15px 9px;
}
.hero-service-group span {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  color: var(--navy);
  font-family: "Montserrat", Inter, Arial, sans-serif;
  font-size: .86rem;
  font-weight: 800;
  letter-spacing: .02em;
  white-space: nowrap;
}
.hero-service-group span::after {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 4px rgba(197,167,125,.12);
}
.proof-row { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); max-width: 960px; margin-top: 56px; color: rgba(250,247,240,.58); }
.proof-row span { display: flex; flex-direction: column; gap: 4px; padding: 0 28px; border-left: 1px solid rgba(255,255,255,.12); }
.proof-row span:first-child { padding-left: 0; border-left: 0; }
.proof-row strong { color: rgba(250,247,240,.95); font-family: "Inter", "Manrope", system-ui, sans-serif; font-size: 2.08rem; font-weight: 800; line-height: 1; letter-spacing: 0; text-shadow: 0 14px 34px rgba(0,0,0,.28); }
.proof-row small { color: rgba(250,247,240,.62); font-size: .78rem; font-weight: 750; letter-spacing: .02em; text-transform: uppercase; }
.home-utility {
  display: flex;
  margin-top: 30px;
}
.bug-report-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 40px;
  padding: 0 14px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  color: rgba(250,247,240,.72);
  background: rgba(250,247,240,.08);
  box-shadow: 0 16px 40px rgba(0,0,0,.18);
  backdrop-filter: blur(8px);
  font-size: .82rem;
  font-weight: 800;
  transition: transform .22s ease, color .22s ease, border-color .22s ease, background .22s ease, box-shadow .22s ease;
}
.bug-report-link svg {
  width: 17px;
  height: 17px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.bug-report-link:hover,
.bug-report-link:focus-visible {
  color: rgba(250,247,240,.96);
  border-color: rgba(197,167,125,.4);
  background: rgba(250,247,240,.13);
  box-shadow: 0 22px 54px rgba(0,0,0,.24);
  transform: translateY(-3px);
}
.site-footer .bug-report-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  margin-top: 18px;
  min-height: 42px;
  padding: 0 15px;
  border-color: rgba(17,24,43,.12);
  color: var(--navy);
  background: rgba(255,255,255,.52);
  box-shadow: 0 14px 30px rgba(42,34,23,.1);
}
.site-footer .bug-report-link:hover,
.site-footer .bug-report-link:focus-visible {
  color: var(--navy);
  border-color: rgba(165,132,83,.42);
  background: rgba(255,255,255,.78);
  box-shadow: 0 20px 44px rgba(42,34,23,.14);
  transform: translateY(-3px);
}
.marquee-band { position: relative; z-index: 1; padding: 18px 0; border-top: 1px solid rgba(255,255,255,.72); border-bottom: 1px solid var(--line); background: rgba(255,255,255,.32); overflow: hidden; }
.marquee-line { display: flex; white-space: nowrap; overflow: hidden; }
.marquee-line + .marquee-line { margin-top: 10px; }
.marquee-track { display: flex; gap: 32px; min-width: max-content; animation: marqueeLeft 30s linear infinite; }
.marquee-track.reverse { animation: marqueeRight 30s linear infinite; }
.marquee-track span { color: var(--navy); font-family: "Playfair Display", Georgia, serif; font-weight: 700; text-transform: uppercase; }
.marquee-line.muted .marquee-track span { color: var(--gold-deep); }
.section-heading { max-width: 760px; margin: 0 auto 44px; text-align: center; }
.section-heading h2, .split-copy h2, .contact-copy h2, .final-cta h2 { font-size: 3.2rem; line-height: 1.1; }
.section-heading p:not(.eyebrow), .split-copy p, .contact-copy p, .final-cta p { color: rgba(250,247,240,.7); font-size: 1.08rem; line-height: 1.75; }
.service-grid, .pricing-grid, .testimonial-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 24px; }
.core-service-grid { grid-template-columns: repeat(2,minmax(0,1fr)); grid-auto-rows: 1fr; gap: 28px; }
.industry-grid, .partner-service-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 22px; }
.card, .contact-form { position: relative; border: 1px solid rgba(255,255,255,.72); border-radius: var(--radius); background: linear-gradient(145deg, rgba(255,255,255,.68), rgba(255,255,255,.34)), rgba(250,247,240,.54); box-shadow: var(--shadow); backdrop-filter: blur(10px); }
.card { min-width: 0; padding: 28px; }
.card:hover { border-color: rgba(165,132,83,.34); box-shadow: 0 34px 86px rgba(42,34,23,.18); transform: translateY(-4px) scale(1.01); }
.service-card, .industry-card, .pricing-card, .testimonial-card, .partner-service-card { display: flex; flex-direction: column; min-height: 100%; transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease; }
.service-card.featured, .pricing-card.featured { border-color: rgba(165,132,83,.35); background: linear-gradient(145deg, rgba(255,255,255,.76), rgba(235,224,209,.44)), rgba(250,247,240,.72); }
.main-service-card { padding: 32px; }
.main-service-card h3 { font-size: 1.72rem; line-height: 1.18; }
.service-card-top { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.edge-left { border-left: 3px solid var(--navy); }
.edge-right { border-right: 3px solid var(--gold); }
.badge { position: absolute; top: -14px; right: 20px; padding: 7px 12px; border-radius: 8px; color: var(--white); background: var(--navy); font-size: .72rem; font-weight: 800; text-transform: uppercase; }
.icon-box { display: inline-flex; width: 54px; height: 54px; align-items: center; justify-content: center; border: 1px solid var(--line-warm); border-radius: 8px; color: var(--navy); background: rgba(255,255,255,.54); font-family: "Playfair Display", Georgia, serif; font-weight: 800; }
.icon-box svg { width: 25px; height: 25px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.service-type, .partner-label, .partner-services-heading span { display: inline-flex; width: fit-content; border: 1px solid rgba(165,132,83,.2); border-radius: 999px; padding: 6px 10px; color: var(--gold-deep); background: rgba(197,167,125,.1); font-size: .68rem; font-weight: 900; text-transform: uppercase; }
.card h3 { font-size: 1.42rem; margin-bottom: 8px; overflow-wrap: break-word; }
.card.main-service-card h3 { font-size: 1.72rem; line-height: 1.18; }
.card-kicker { margin: 0 0 16px; color: var(--gold-deep); font-weight: 800; }
.card p { color: var(--taupe); line-height: 1.65; overflow-wrap: break-word; }
.card ul { list-style: none; padding: 0; margin: 20px 0 26px; }
.main-service-card ul { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); column-gap: 18px; }
.card li { position: relative; padding-left: 22px; margin-top: 12px; color: var(--navy-soft); line-height: 1.45; }
.card li::before { content: ""; position: absolute; left: 0; top: .62em; width: 7px; height: 7px; border-radius: 50%; background: var(--gold); }
.service-cta { width: fit-content; margin-top: auto; }
.premium-service-card { border-color: rgba(197,167,125,.54); box-shadow: 0 34px 92px rgba(0,0,0,.2), 0 0 0 1px rgba(197,167,125,.16); }
.text-link { margin-top: auto; color: var(--navy); font-weight: 900; transition: color .2s ease, transform .22s ease; }
.text-link:hover { color: var(--gold-deep); transform: translateX(4px); }
.text-link::after { content: " ->"; color: var(--gold-deep); }
.partner-services { margin-top: 58px; padding-top: 42px; border-top: 1px solid rgba(17,24,43,.1); }
.partner-services-heading { max-width: 720px; margin-bottom: 30px; }
.partner-services-heading h3 { margin-top: 14px; font-family: "Playfair Display", Georgia, serif; font-size: 2.35rem; line-height: 1.12; }
.partner-services-heading p { color: var(--taupe); font-size: 1.02rem; line-height: 1.72; }
.partner-service-card { padding: 24px; background: linear-gradient(145deg, rgba(255,255,255,.62), rgba(244,235,223,.34)), rgba(250,247,240,.52); }
.partner-service-card h4 { margin: 16px 0 10px; font-size: 1.08rem; line-height: 1.28; overflow-wrap: break-word; }
.partner-service-card p { margin-bottom: 20px; font-size: .95rem; }
.partner-service-card a { margin-top: auto; color: var(--navy); font-size: .9rem; font-weight: 900; transition: color .2s ease, transform .22s ease; }
.partner-service-card a:hover { color: var(--gold-deep); transform: translateX(4px); }

.projects-section { padding-top: 92px; }
.project-showcase + .project-showcase { margin-top: 28px; }
.project-showcase {
  display: grid;
  grid-template-columns: minmax(0,.9fr) minmax(320px,1.1fr);
  align-items: center;
  gap: 42px;
  padding: 34px;
  overflow: hidden;
}
.project-copy h3 {
  margin: 16px 0 14px;
  color: var(--navy);
  font-family: "Playfair Display", Georgia, serif;
  font-size: 2.55rem;
  line-height: 1.08;
}
.project-copy p { color: var(--taupe); line-height: 1.72; }
.project-copy .hero-actions { margin-top: 30px; }
.project-preview {
  display: block;
  min-width: 0;
  border: 1px solid rgba(17,24,43,.1);
  border-radius: 12px;
  background: rgba(255,255,255,.5);
  box-shadow: 0 34px 90px rgba(42,34,23,.14);
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease;
}
.project-preview:hover { transform: translateY(-5px) scale(1.01); box-shadow: 0 42px 104px rgba(42,34,23,.18); }
.browser-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
  background: rgba(250,247,240,.84);
}
.browser-bar span { width: 10px; height: 10px; border-radius: 50%; background: rgba(17,24,43,.22); }
.browser-bar span:nth-child(2) { background: rgba(197,167,125,.5); }
.browser-bar span:nth-child(3) { background: rgba(125,101,81,.38); }
.browser-bar strong { margin-left: 8px; color: var(--taupe); font-size: .82rem; }
.project-screen {
  position: relative;
  min-height: 410px;
  padding: 34px;
  background:
    linear-gradient(135deg, rgba(17,24,43,.9), rgba(17,24,43,.58)),
    linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: auto, 38px 38px, 38px 38px;
}
.project-screen::after {
  content: "";
  position: absolute;
  right: -64px;
  bottom: -72px;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  background: rgba(197,167,125,.22);
  filter: blur(4px);
}
.project-screen-hero {
  position: relative;
  z-index: 1;
  max-width: 410px;
  padding: 26px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--radius);
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
}
.project-screen-hero small { color: rgba(255,255,255,.72); font-weight: 800; text-transform: uppercase; }
.project-screen-hero h4 { margin: 18px 0 10px; color: var(--white); font-family: "Playfair Display", Georgia, serif; font-size: 2.25rem; line-height: 1.05; }
.project-screen-hero p { margin: 0; color: rgba(255,255,255,.76); line-height: 1.58; }
.project-screen-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3,minmax(0,1fr));
  gap: 14px;
  margin-top: 28px;
}
.project-screen-grid span {
  min-height: 92px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--radius);
  background: linear-gradient(145deg, rgba(255,255,255,.18), rgba(255,255,255,.05));
}

.preview-section .section-heading { margin-bottom: 48px; }
.preview-stack { display: grid; gap: 30px; }
.preview-block {
  display: grid;
  grid-template-columns: minmax(280px,.95fr) minmax(0,1.05fr);
  align-items: center;
  gap: 46px;
  padding: 34px;
  overflow: hidden;
}
.preview-block-reverse { grid-template-columns: minmax(0,1.05fr) minmax(280px,.95fr); }
.preview-visual { display: flex; justify-content: center; min-width: 0; }
.preview-copy { min-width: 0; }
.preview-copy h3, .audit-highlight h3 {
  margin: 16px 0 10px;
  color: var(--navy);
  font-family: "Playfair Display", Georgia, serif;
  font-size: 2.35rem;
  line-height: 1.12;
}
.preview-copy h4 { margin-bottom: 18px; color: var(--gold-deep); font-size: 1.02rem; line-height: 1.5; }
.preview-copy p, .audit-highlight p { color: var(--taupe); line-height: 1.72; }
.preview-note {
  padding: 14px 16px;
  border-left: 3px solid var(--gold);
  border-radius: var(--radius);
  background: rgba(255,255,255,.42);
}
.feature-list, .audit-checks ul { list-style: none; padding: 0; margin: 22px 0 0; }
.feature-list li, .audit-checks li {
  position: relative;
  padding-left: 22px;
  margin-top: 11px;
  color: var(--navy-soft);
  line-height: 1.45;
}
.feature-list li::before, .audit-checks li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .62em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold);
}
.preview-stats { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 14px; margin-top: 28px; }
.preview-stats .mini-card { padding: 17px; }
.preview-stats .mini-card strong { font-size: 1.45rem; }
.preview-phone { transform: rotate(-1deg); }
.whatsapp-shell { min-height: 560px; transform: rotate(1deg); }
.whatsapp-header { background: linear-gradient(145deg, var(--navy), #203326); }
.static-chat { justify-content: center; }
.call-preview {
  width: min(100%, 430px);
  border: 1px solid rgba(255,255,255,.8);
  border-radius: var(--radius);
  padding: 28px;
  background: linear-gradient(145deg, rgba(255,255,255,.68), rgba(246,239,229,.42));
  box-shadow: 0 30px 68px rgba(42,34,23,.14);
  backdrop-filter: blur(10px);
}
.call-top { display: flex; align-items: center; gap: 14px; padding-bottom: 18px; border-bottom: 1px solid var(--line); }
.call-top small { display: block; margin-top: 4px; color: var(--taupe); }
.call-dot { width: 42px; height: 42px; border-radius: 50%; background: radial-gradient(circle at 35% 32%, var(--white), var(--gold)); box-shadow: 0 0 0 8px rgba(197,167,125,.14); }
.call-wave { display: flex; align-items: end; justify-content: center; gap: 10px; height: 82px; margin: 22px 0; }
.call-wave span { width: 12px; border-radius: 999px; background: linear-gradient(var(--navy), var(--gold)); opacity: .75; }
.call-wave span:nth-child(1) { height: 34px; }
.call-wave span:nth-child(2) { height: 58px; }
.call-wave span:nth-child(3) { height: 42px; }
.call-wave span:nth-child(4) { height: 68px; }
.call-flow { display: grid; gap: 12px; }
.call-line {
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.48);
}
.call-line.ai { border-color: rgba(165,132,83,.28); background: rgba(246,239,229,.58); }
.call-line span { display: block; margin-bottom: 6px; color: var(--gold-deep); font-size: .74rem; font-weight: 900; text-transform: uppercase; }
.call-line p { margin: 0; color: var(--navy-soft); line-height: 1.45; }
.audit-highlight {
  display: grid;
  grid-template-columns: minmax(0,1.08fr) minmax(280px,.92fr);
  gap: 34px;
  margin-top: 38px;
  padding: 36px;
  border: 1px solid rgba(197,167,125,.42);
  border-radius: var(--radius);
  background: linear-gradient(145deg, rgba(255,255,255,.76), rgba(239,226,207,.5)), rgba(250,247,240,.7);
  box-shadow: 0 30px 72px rgba(42,34,23,.15);
  backdrop-filter: blur(10px);
}
.audit-highlight .eyebrow { margin-bottom: 18px; }
.audit-highlight .btn { margin-top: 24px; }
.audit-checks {
  padding: 24px;
  border: 1px solid rgba(255,255,255,.76);
  border-radius: var(--radius);
  background: rgba(255,255,255,.42);
  box-shadow: var(--shadow-soft);
}
.audit-checks h4 { font-size: 1rem; text-transform: uppercase; letter-spacing: 0; }

.split-section, .contact-section { display: grid; grid-template-columns: minmax(0,.95fr) minmax(0,1.05fr); align-items: center; gap: 72px; }
.phone-wrap { position: relative; display: flex; justify-content: center; }
.phone-shell { position: relative; width: min(100%, 370px); min-height: 620px; border: 1px solid rgba(255,255,255,.8); border-radius: 28px; padding: 16px; background: rgba(255,252,246,.76); box-shadow: 0 32px 72px rgba(42,34,23,.14); backdrop-filter: blur(10px); display: flex; flex-direction: column; }
.phone-header { display: flex; align-items: center; gap: 12px; margin: -16px -16px 18px; padding: 22px; border-radius: 28px 28px 0 0; color: var(--white); background: var(--navy); }
.avatar { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50%; color: var(--navy); background: var(--cream); font-weight: 800; }
.phone-header span { display: block; margin-top: 3px; color: rgba(255,255,255,.72); font-size: .8rem; }
.chat-window { flex: 1; display: flex; flex-direction: column; gap: 12px; overflow: hidden; }
.bubble { max-width: 82%; padding: 13px 14px; border-radius: 8px; line-height: 1.45; font-size: .92rem; animation: bubbleIn .26s ease both; }
.bubble.bot { align-self: flex-start; color: var(--navy); border: 1px solid var(--line); background: rgba(255,255,255,.58); }
.bubble.user { align-self: flex-end; color: var(--white); background: var(--navy); }
.typing { display: inline-flex; gap: 4px; }
.typing span { width: 6px; height: 6px; border-radius: 50%; background: var(--taupe-soft); animation: typing 1s ease-in-out infinite; }
.typing span:nth-child(2) { animation-delay: .14s; }
.typing span:nth-child(3) { animation-delay: .28s; }
.chat-input { margin-top: 18px; padding: 13px 16px; border: 1px solid var(--line); border-radius: 999px; color: var(--taupe-soft); background: rgba(255,255,255,.52); }
.metric-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 16px; margin: 28px 0 30px; }
.mini-card { border: 1px solid rgba(255,255,255,.72); border-radius: var(--radius); padding: 20px; background: rgba(255,255,255,.48); box-shadow: var(--shadow-soft); }
.mini-card strong, .stats-band strong { display: block; color: var(--navy); font-family: "Inter", "Manrope", system-ui, sans-serif; letter-spacing: 0; }
.price span { display: block; color: var(--navy); }
.mini-card strong { font-size: 1.72rem; }
.mini-card span, .stats-band span { display: block; margin-top: 6px; color: var(--taupe); font-size: .82rem; text-transform: uppercase; }
.process-grid { position: relative; display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 22px; }
.process-step { text-align: center; }
.process-step span { display: inline-grid; place-items: center; width: 68px; height: 68px; margin-bottom: 24px; border-radius: 50%; color: var(--white); background: var(--navy); font-weight: 900; box-shadow: var(--shadow-soft); }
.process-step p { color: var(--taupe); line-height: 1.6; }
.stats-band { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); gap: 18px; padding: 48px max(18px, calc((100% - var(--max)) / 2)); border-top: 1px solid rgba(255,255,255,.78); border-bottom: 1px solid var(--line); background: rgba(255,255,255,.34); text-align: center; backdrop-filter: blur(8px); }
.stats-band strong { font-size: 2.7rem; }
.stats-band span { font-weight: 800; }
.pricing-controls { display: flex; justify-content: center; margin: -20px 0 34px; }
.currency-select-wrap {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 8px 10px 8px 14px;
  border: 1px solid rgba(255,255,255,.72);
  border-radius: 999px;
  color: var(--taupe);
  background: rgba(255,255,255,.58);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(10px);
  font-size: .82rem;
  font-weight: 900;
  text-transform: uppercase;
}
.currency-select-wrap select {
  min-height: 36px;
  border: 1px solid rgba(17,24,43,.1);
  border-radius: 999px;
  padding: 0 34px 0 14px;
  color: var(--navy);
  background: rgba(255,255,255,.7);
  outline: 0;
  font-weight: 900;
}
.currency-select-wrap select:focus { border-color: rgba(17,24,43,.34); box-shadow: 0 0 0 3px rgba(197,167,125,.18); }
.pricing-grid-compact { grid-template-columns: repeat(2,minmax(0,1fr)); grid-auto-rows: 1fr; max-width: 1000px; margin: 0 auto; }
.pricing-card .price { display: flex; align-items: baseline; gap: 7px; margin: 20px 0 14px; }
.pricing-card .price span { font-family: "Inter", system-ui, sans-serif; font-size: 1.72rem; line-height: 1.16; overflow-wrap: break-word; }
.pricing-card.featured { border-color: rgba(197,167,125,.56); box-shadow: 0 34px 92px rgba(0,0,0,.22), 0 0 0 1px rgba(197,167,125,.18); }
.price span { font-size: 2.45rem; font-weight: 800; }
.price small, .author small { color: var(--taupe); }
.pricing-card .btn { width: 100%; margin-top: auto; }
.pricing-note { margin: 34px 0 0; color: var(--taupe); text-align: center; }
.testimonial-card p { flex: 1; }
.stars { margin-bottom: 18px; color: var(--gold-deep); font-weight: 900; }
.author { display: flex; align-items: center; gap: 14px; padding-top: 20px; border-top: 1px solid var(--line); }
.author span { display: grid; place-items: center; width: 46px; height: 46px; border-radius: 50%; color: var(--white); background: var(--navy); font-weight: 900; }
.author small { display: block; margin-top: 4px; }
.faq-section { max-width: 900px; }
.faq-list { display: grid; gap: 12px; }
.faq-item { border: 1px solid rgba(255,255,255,.72); border-radius: var(--radius); background: rgba(255,255,255,.5); overflow: hidden; box-shadow: var(--shadow-soft); backdrop-filter: blur(8px); }
.faq-item button { position: relative; width: 100%; border: 0; padding: 22px 54px 22px 22px; color: var(--navy); background: transparent; font-weight: 800; text-align: left; }
.faq-item button::after { content: "+"; position: absolute; right: 22px; top: 50%; transform: translateY(-50%); color: var(--gold-deep); font-size: 1.5rem; }
.faq-item.open button::after { content: "-"; }
.faq-item div { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .2s ease; }
.faq-item.open div { grid-template-rows: 1fr; }
.faq-item p { min-height: 0; margin: 0; padding: 0 22px; color: var(--taupe); line-height: 1.65; overflow: hidden; }
.faq-item.open p { padding-bottom: 22px; }
.final-cta { width: 100%; max-width: none; padding-inline: max(18px, calc((100% - 900px) / 2)); text-align: center; background: rgba(255,255,255,.34); border-top: 1px solid rgba(255,255,255,.78); border-bottom: 1px solid var(--line); backdrop-filter: blur(8px); }
.final-cta p { max-width: 640px; margin: 22px auto 0; }
.final-cta .hero-actions { justify-content: center; }
.contact-list { display: grid; gap: 18px; margin-top: 34px; }
.contact-list div { display: grid; gap: 4px; padding: 18px; border: 1px solid rgba(255,255,255,.74); border-radius: var(--radius); background: rgba(255,255,255,.44); box-shadow: var(--shadow-soft); transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
.contact-list div:hover { border-color: rgba(165,132,83,.32); box-shadow: 0 22px 52px rgba(42,34,23,.13); transform: translateY(-3px); }
.contact-list span { color: var(--gold-deep); font-size: .82rem; font-weight: 800; text-transform: uppercase; }
.global-note { margin-top: 18px; padding: 15px 17px; border-left: 3px solid var(--gold); border-radius: var(--radius); background: rgba(255,255,255,.42); }
.contact-form { padding: 30px; }
.form-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 16px; }
.contact-form label { display: grid; gap: 8px; margin-bottom: 16px; color: var(--taupe); font-size: .82rem; font-weight: 800; text-transform: uppercase; }
.contact-form input, .contact-form select, .contact-form textarea { width: 100%; border: 1px solid rgba(17,24,43,.1); border-radius: 8px; padding: 14px 15px; color: var(--navy); background: rgba(255,255,255,.54); outline: 0; resize: vertical; text-transform: none; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { border-color: rgba(17,24,43,.34); }
.phone-field { display: grid; grid-template-columns: minmax(150px,.72fr) minmax(0,1fr); gap: 10px; }
.phone-field select, .phone-field input { min-width: 0; }
.contact-form .btn { width: 100%; min-height: 54px; }
.form-status { min-height: 24px; margin: 14px 0 0; color: var(--gold-deep); text-align: center; font-weight: 700; }
.form-status.error { color: #9a3f2f; }
.contact-form .btn:disabled { cursor: not-allowed; opacity: .68; transform: none; }
.site-footer { position: relative; z-index: 4; margin-left: calc(var(--sidebar) + 28px); padding: 76px max(18px, calc((100% - var(--max)) / 2)) 28px; border-top: 1px solid rgba(255,255,255,.78); background: rgba(244,238,229,.82); backdrop-filter: blur(8px); }
.footer-grid { display: grid; grid-template-columns: 1.2fr repeat(3,1fr); gap: 54px; }
.site-footer .brand { align-items: flex-start; gap: 12px; }
.site-footer .brand-mark img { width: 214px; }
.site-footer .brand-copy strong { font-size: 1.72rem; }
.site-footer .brand-copy small { font-size: .58rem; letter-spacing: .1em; }
.site-footer h3 { margin-bottom: 20px; color: var(--navy); font-size: .9rem; text-transform: uppercase; }
.site-footer p, .site-footer a { display: block; color: var(--taupe); line-height: 1.65; }
.site-footer a + a { margin-top: 11px; }
.social-link { width: fit-content; margin-top: 14px; color: var(--navy) !important; font-weight: 900; }
.social-link::before { content: ""; display: inline-block; width: 8px; height: 8px; margin-right: 9px; border-radius: 50%; background: var(--gold); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-top: 54px; padding-top: 24px; border-top: 1px solid var(--line); color: var(--taupe-soft); font-size: .86rem; }
.footer-bottom div { display: flex; gap: 22px; }

.legal-page .site-header { background: rgba(250,247,240,.86); }
.legal-main {
  width: calc(100% - 36px);
  max-width: var(--max);
  margin-left: calc(var(--sidebar) + 28px);
  padding: calc(var(--header) + 58px) 0 76px;
}
.legal-hero {
  max-width: 920px;
  padding: 42px;
  border: 1px solid rgba(255,255,255,.72);
  border-radius: var(--radius);
  background: linear-gradient(145deg, rgba(255,255,255,.16), rgba(255,255,255,.06)), rgba(8,10,14,.44);
  box-shadow: 0 34px 92px rgba(0,0,0,.28);
  backdrop-filter: blur(12px);
}
.legal-hero h1 {
  color: rgba(250,247,240,.96);
  font-size: 3.4rem;
  line-height: 1.04;
  text-shadow: 0 24px 60px rgba(0,0,0,.42);
}
.legal-hero p {
  max-width: 760px;
  color: rgba(250,247,240,.72);
  font-size: 1.08rem;
  line-height: 1.75;
}
.legal-content {
  display: grid;
  gap: 18px;
  margin-top: 32px;
}
.legal-card {
  padding: 30px;
  border: 1px solid rgba(255,255,255,.72);
  border-radius: var(--radius);
  background: linear-gradient(145deg, rgba(255,255,255,.7), rgba(255,255,255,.38)), rgba(250,247,240,.56);
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.legal-card h2 {
  color: var(--navy);
  font-size: 1.68rem;
  line-height: 1.18;
}
.legal-card p, .legal-card li {
  color: var(--taupe);
  line-height: 1.7;
}
.legal-card ul {
  margin: 18px 0 0;
  padding-left: 20px;
}
.legal-meta {
  margin-top: 18px;
  color: rgba(250,247,240,.62);
  font-weight: 700;
}

.ai-agent-widget {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 40;
  display: grid;
  justify-items: end;
  gap: 14px;
  font-family: "Inter", system-ui, sans-serif;
}
.ai-agent-launcher {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: 62px;
  border: 1px solid rgba(255,255,255,.5);
  border-radius: 999px;
  padding: 8px 18px 8px 8px;
  color: var(--white);
  background: linear-gradient(145deg, rgba(17,24,43,.96), rgba(26,36,58,.9)), var(--navy);
  box-shadow: 0 26px 70px rgba(0,0,0,.34), 0 0 0 1px rgba(197,167,125,.16);
  overflow: hidden;
  isolation: isolate;
}
.ai-agent-launcher::before {
  content: "";
  position: absolute;
  inset: -38% -18%;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 28%, rgba(124,230,204,.28), transparent 26%),
    radial-gradient(circle at 78% 22%, rgba(255,128,163,.24), transparent 28%),
    radial-gradient(circle at 56% 90%, rgba(197,167,125,.34), transparent 30%);
  animation: agentGlow 4.5s ease-in-out infinite;
}
.ai-agent-pulse {
  position: absolute;
  inset: 8px auto auto 8px;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: rgba(124,230,204,.18);
  animation: agentPulse 1.9s ease-out infinite;
}
.ai-agent-mark,
.ai-agent-avatar {
  position: relative;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  width: 46px;
  height: 46px;
  border-radius: 12px;
  color: var(--navy);
  background: linear-gradient(145deg, rgba(255,255,255,.96), rgba(215,214,207,.94));
  font-weight: 950;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.84), 0 12px 28px rgba(0,0,0,.26), 0 0 0 1px rgba(255,255,255,.46);
  overflow: hidden;
}
.ai-agent-mark img,
.ai-agent-avatar img {
  display: block;
  width: 44px;
  height: 44px;
  object-fit: contain;
}
.ai-agent-avatar {
  width: 48px;
  height: 48px;
}
.ai-agent-avatar img {
  width: 46px;
  height: 46px;
}
.ai-agent-launch-copy { display: grid; gap: 2px; text-align: left; }
.ai-agent-launch-copy strong,
.ai-agent-identity strong { font-size: .92rem; font-weight: 950; letter-spacing: 0; }
.ai-agent-launch-copy small,
.ai-agent-identity small { color: rgba(255,255,255,.68); font-size: .74rem; font-weight: 800; }
.ai-agent-identity div { display: grid; gap: 3px; }
.ai-agent-identity strong,
.ai-agent-identity small { display: block; }
.ai-agent-panel {
  width: min(390px, calc(100vw - 28px));
  max-height: min(650px, calc(100vh - 104px));
  display: grid;
  grid-template-rows: auto minmax(120px,1fr) auto auto;
  border: 1px solid rgba(255,255,255,.56);
  border-radius: 18px;
  color: var(--white);
  background: linear-gradient(145deg, rgba(11,13,18,.96), rgba(23,29,44,.94)), rgba(11,13,18,.94);
  box-shadow: 0 34px 90px rgba(0,0,0,.48), 0 0 0 1px rgba(124,230,204,.12);
  overflow: hidden;
  backdrop-filter: blur(18px);
  transform-origin: right bottom;
  animation: agentPanelIn .24s ease both;
}
.ai-agent-panel[hidden] { display: none; }
.ai-agent-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.ai-agent-identity { display: flex; align-items: center; gap: 12px; }
.ai-agent-close {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 50%;
  color: var(--white);
  background: rgba(255,255,255,.07);
}
.ai-agent-close svg,
.ai-agent-form svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.ai-agent-status {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  color: rgba(255,255,255,.72);
  font-size: .78rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ai-agent-status span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #7ce6cc;
  box-shadow: 0 0 18px rgba(124,230,204,.9);
}
.ai-agent-status strong { color: #7ce6cc; font-weight: 900; }
.ai-agent-messages {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 0;
  padding: 18px;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: rgba(197,167,125,.64) rgba(255,255,255,.06);
}
.ai-message {
  max-width: 88%;
  padding: 12px 13px;
  border-radius: 16px;
  font-size: .9rem;
  line-height: 1.5;
  animation: bubbleIn .24s ease both;
  white-space: pre-line;
  overflow-wrap: break-word;
}
.ai-message.bot {
  align-self: flex-start;
  border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.88);
  background: rgba(255,255,255,.08);
}
.ai-message.user {
  align-self: flex-end;
  color: var(--navy);
  background: linear-gradient(145deg, #fff7e8, #7ce6cc);
  font-weight: 800;
}
.ai-agent-prompts {
  display: flex;
  gap: 8px;
  padding: 0 18px 14px;
  overflow-x: auto;
  scrollbar-width: none;
}
.ai-agent-prompts::-webkit-scrollbar { display: none; }
.ai-agent-prompts button {
  flex: 0 0 auto;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: 8px 11px;
  color: rgba(255,255,255,.82);
  background: rgba(255,255,255,.07);
  font-size: .76rem;
  font-weight: 900;
}
.ai-agent-form {
  display: grid;
  grid-template-columns: minmax(0,1fr) 44px;
  gap: 10px;
  padding: 14px;
  border-top: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.05);
}
.ai-agent-form input {
  min-width: 0;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 13px 14px;
  color: var(--white);
  background: rgba(255,255,255,.08);
  outline: 0;
}
.ai-agent-form input::placeholder { color: rgba(255,255,255,.46); }
.ai-agent-form input:focus { border-color: rgba(124,230,204,.48); box-shadow: 0 0 0 4px rgba(124,230,204,.1); }
.ai-agent-form button {
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 50%;
  color: var(--navy);
  background: linear-gradient(145deg, #7ce6cc, #f1cf9d);
  box-shadow: 0 16px 34px rgba(0,0,0,.24);
}

@keyframes marqueeLeft { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes marqueeRight { from { transform: translateX(-50%); } to { transform: translateX(0); } }
@keyframes heroServiceMarquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes tabReveal { from { opacity: 0; transform: translateY(14px) scale(.99); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes cardReveal { from { opacity: 0; transform: translateY(12px) scale(.99); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes iconPop { 0% { transform: scale(1); } 48% { transform: scale(1.15); } 100% { transform: scale(1); } }
.side-icon, .icon-box, .brand-mark, .bug-report-link svg, .menu-toggle, .ai-agent-mark, .ai-agent-close, .ai-agent-form button { transform-origin: center; will-change: transform; }
.icon-pop-click { animation: iconPop .28s cubic-bezier(.2,.9,.25,1.18) both; }
.side-icon:hover,
.side-menu a:hover .side-icon,
.icon-box:hover,
.brand:hover .brand-mark,
.bug-report-link:hover svg,
.menu-toggle:hover,
.ai-agent-launcher:hover .ai-agent-mark,
.ai-agent-close:hover,
.ai-agent-form button:hover {
  animation: iconPop .32s cubic-bezier(.2,.9,.25,1.18) both;
}
@keyframes bubbleIn { from { opacity: 0; transform: translateY(8px) scale(.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes agentPanelIn { from { opacity: 0; transform: translateY(12px) scale(.96); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes agentPulse { 0% { transform: scale(.88); opacity: .76; } 72%,100% { transform: scale(1.65); opacity: 0; } }
@keyframes agentGlow { 0%,100% { transform: translateX(-2%) rotate(0deg); opacity: .9; } 50% { transform: translateX(4%) rotate(8deg); opacity: 1; } }
@keyframes typing { 0%,100% { opacity: .35; transform: translateY(0); } 50% { opacity: 1; transform: translateY(-4px); } }
@keyframes gridFloat { 0%,100% { transform: var(--grid-transform) translateY(0); } 50% { transform: var(--grid-transform) translateY(24px); } }
@keyframes slabDrift { 0%,100% { translate: 0 0; } 50% { translate: 14px -18px; } }

@media (max-width: 1280px) {
  h1 { font-size: 3.85rem; }
}
@media (max-width: 1040px) {
  .brand-copy strong { font-size: 1.72rem; }
  h1 { font-size: 3.35rem; }
}
@media (max-width: 980px) {
  main, .site-footer, .legal-main { margin-left: 0; }
  .side-menu, .dock-menu, .nav-cta { display: none; }
  .menu-toggle { position: fixed; top: 16px; right: 16px; z-index: 2; display: grid; flex: 0 0 44px; place-items: center; width: 44px; height: 44px; border: 0; border-radius: 8px; background: var(--navy); box-shadow: 0 12px 28px rgba(17,24,43,.18); }
  .menu-toggle span { display: block; width: 20px; height: 2px; margin: 3px auto; background: var(--white); transition: transform .16s ease, opacity .16s ease; }
  .menu-toggle.open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
  .menu-toggle.open span:nth-child(2) { opacity: 0; }
  .menu-toggle.open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
  .mobile-menu { position: fixed; inset: var(--header) 18px auto; display: grid; gap: 14px; max-height: calc(100vh - var(--header) - 24px); overflow: auto; padding: 22px; border: 1px solid rgba(255,255,255,.74); border-radius: var(--radius); background: rgba(250,247,240,.94); box-shadow: var(--shadow); backdrop-filter: blur(8px); transform: translateY(-12px); opacity: 0; pointer-events: none; transition: opacity .18s ease, transform .18s ease; }
  .mobile-menu.open { opacity: 1; transform: translateY(0); pointer-events: auto; }
  .mobile-menu a { padding: 12px; border: 1px solid var(--line); border-radius: 8px; color: var(--navy); background: rgba(255,255,255,.42); font-weight: 800; transition: transform .22s ease, border-color .22s ease, background .22s ease, box-shadow .22s ease; }
  .mobile-menu a:hover, .mobile-menu a.active { border-color: rgba(165,132,83,.34); background: rgba(255,255,255,.72); box-shadow: var(--shadow-soft); transform: translateY(-2px); }
  h1 { font-size: 3.45rem; }
  .section-heading h2, .split-copy h2, .contact-copy h2, .final-cta h2 { font-size: 2.6rem; }
  .preview-copy h3, .audit-highlight h3 { font-size: 2.15rem; }
  .service-grid, .pricing-grid, .testimonial-grid, .industry-grid, .split-section, .contact-section, .project-showcase, .preview-block, .preview-block-reverse, .audit-highlight { grid-template-columns: 1fr; }
  .core-service-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .partner-service-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .split-section, .contact-section, .project-showcase, .preview-block { gap: 48px; }
  .preview-block-reverse .preview-copy { order: 2; }
  .preview-block-reverse .preview-visual { order: 1; }
  .process-grid, .stats-band, .footer-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (min-width: 641px) and (max-width: 980px) {
  .pricing-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 760px) {
  h1 { font-size: 2.9rem; }
}
@media (max-width: 640px) {
  :root { --header: 76px; }
  .nav-wrap, .section { width: calc(100vw - 28px); max-width: var(--max); }
  .brand { gap: 10px; }
  .brand-mark { flex-basis: auto; width: auto; height: auto; }
  .brand-mark img { width: 154px; }
  .brand-copy strong { font-size: 1.3rem; letter-spacing: 0; }
  .brand-copy small { margin-top: 5px; font-size: .52rem; letter-spacing: .055em; }
  .hero { align-items: flex-start; }
  .hero-content { padding-top: 56px; }
  h1 { max-width: 100%; font-size: 2.55rem; line-height: 1.06; letter-spacing: 0; }
  h1 span { letter-spacing: 0; }
  .mobile-break { display: block; }
  .hero-subtitle { max-width: 100%; font-size: 1rem; }
  .hero-actions .btn { width: 100%; }
  .hero-service-line { margin-top: 28px; }
  .hero-service-line p { max-width: 100%; font-size: .92rem; }
  .hero-service-marquee {
    border-radius: 12px;
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
    mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
  }
  .hero-service-track { animation-duration: 34s; }
  .hero-service-group { gap: 14px; padding: 13px 7px; }
  .hero-service-group span { gap: 14px; font-size: .78rem; }
  .hero-service-group span::after {
    width: 6px;
    height: 6px;
    box-shadow: 0 0 0 3px rgba(197,167,125,.12);
  }
  .proof-row { grid-template-columns: 1fr 1fr; gap: 22px 0; margin-top: 50px; }
  .proof-row span:nth-child(odd) { padding-left: 0; border-left: 0; }
  .proof-row strong { font-size: 2rem; }
  .section { padding: 76px 0 54px; }
  .tab-panel { min-height: calc(100vh - var(--header)); }
  .section-heading { text-align: left; }
  .section-heading h2, .split-copy h2, .contact-copy h2, .final-cta h2 { font-size: 2rem; overflow-wrap: break-word; }
  .preview-copy h3, .audit-highlight h3 { font-size: 1.9rem; overflow-wrap: break-word; }
  .section-heading h2,
  .section-heading p:not(.eyebrow) {
    width: 100%;
    max-width: 330px;
  }
  .metric-grid, .form-grid, .core-service-grid, .partner-service-grid, .stats-band, .process-grid, .footer-grid, .preview-stats, .phone-field { grid-template-columns: 1fr; }
  .core-service-grid, .pricing-grid-compact { grid-auto-rows: auto; }
  .project-showcase { padding: 22px; }
  .project-copy h3 { font-size: 2rem; }
  .project-screen { min-height: 360px; padding: 22px; }
  .project-screen-grid { grid-template-columns: 1fr; }
  .project-screen-grid span { min-height: 64px; }
  .preview-block, .audit-highlight { padding: 22px; gap: 28px; }
  .preview-copy p,
  .preview-copy h4,
  .feature-list,
  .audit-highlight p,
  .audit-checks {
    width: 100%;
    max-width: 300px;
  }
  .main-service-card { padding: 24px; }
  .main-service-card h3,
  .main-service-card .card-kicker,
  .main-service-card p,
  .main-service-card ul {
    width: 100%;
    max-width: 300px;
  }
  .badge {
    right: auto;
    left: 32px;
    max-width: calc(100% - 24px);
  }
  .main-service-card ul { grid-template-columns: 1fr; }
  .service-card-top { align-items: flex-start; flex-direction: column; }
  .partner-services { margin-top: 56px; padding-top: 40px; }
  .partner-services-heading h3 { font-size: 1.9rem; }
  .phone-shell { min-height: 560px; }
  .preview-phone, .whatsapp-shell { min-height: 530px; transform: none; }
  .call-preview { padding: 22px; }
  .footer-bottom { align-items: flex-start; flex-direction: column; }
  .footer-bottom div { flex-direction: column; gap: 8px; }
  .pricing-controls { justify-content: flex-start; margin-top: -16px; }
  .currency-select-wrap { width: 100%; max-width: 330px; justify-content: space-between; }
  .pricing-card .price span { font-size: 1.45rem; }
  .legal-main { width: calc(100vw - 28px); padding-top: calc(var(--header) + 34px); }
  .legal-hero { padding: 26px; }
  .legal-hero h1 { font-size: 2.35rem; }
  .legal-hero p { font-size: 1rem; }
  .legal-card { padding: 22px; }
  .legal-card h2 { font-size: 1.38rem; }
  .slab-one { right: -42%; opacity: .55; }
  .ai-agent-widget { right: 14px; bottom: 14px; left: 14px; justify-items: stretch; }
  .ai-agent-launcher { justify-self: end; max-width: calc(100vw - 28px); }
  .ai-agent-panel { width: 100%; max-height: calc(100vh - 96px); border-radius: 16px; }
  .ai-agent-launch-copy strong { font-size: .86rem; }
}
