/* ============== Nav ============== */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-nav);
  height: var(--nav-height);
  display: flex;
  align-items: center;
  background: rgba(10, 9, 8, 0.55);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid transparent;
  transition: height var(--t-base) var(--ease), background var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.nav.is-scrolled {
  height: var(--nav-height-shrunk);
  background: rgba(10, 9, 8, 0.85);
  border-bottom-color: var(--border);
}
.nav-inner {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-5);
}
.nav-logo {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--text-1);
}
.nav-logo .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  margin-bottom: -2px;
  box-shadow: 0 0 12px var(--accent-glow);
}
.nav-links {
  display: none;
  gap: var(--s-6);
  align-items: center;
}
@media (min-width: 768px) {
  .nav-links { display: flex; }
}
.nav-links a {
  font-family: var(--font-mono);
  font-size: var(--text-small);
  letter-spacing: 0.04em;
  color: var(--text-2);
  position: relative;
  padding: 4px 0;
  transition: color var(--t-fast) var(--ease);
}
.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 1px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: 0 50%;
  transition: transform var(--t-base) var(--ease);
}
.nav-links a:hover, .nav-links a.is-active { color: var(--text-1); }
.nav-links a.is-active::after, .nav-links a:hover::after { transform: scaleX(1); }
.nav-cta {
  display: none;
}
@media (min-width: 768px) {
  .nav-cta { display: inline-flex; }
}

/* Mobile burger */
.burger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: transparent;
  border-radius: var(--r-2);
  cursor: pointer;
  position: relative;
}
@media (min-width: 768px) { .burger { display: none; } }
.burger span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--text-1);
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  transition: transform var(--t-base) var(--ease), opacity var(--t-fast) var(--ease), top var(--t-base) var(--ease);
}
.burger span:nth-child(1) { top: 17px; }
.burger span:nth-child(2) { top: 50%; margin-top: -0.75px; }
.burger span:nth-child(3) { bottom: 17px; }
.burger.is-open span:nth-child(1) { top: 50%; margin-top: -0.75px; transform: translateX(-50%) rotate(45deg); }
.burger.is-open span:nth-child(2) { opacity: 0; }
.burger.is-open span:nth-child(3) { bottom: auto; top: 50%; margin-top: -0.75px; transform: translateX(-50%) rotate(-45deg); }

/* Mobile overlay */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  background: var(--bg-0);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: var(--s-6);
  padding: var(--s-9) var(--s-5) var(--s-7);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t-base) var(--ease);
}
.mobile-menu.is-open { opacity: 1; pointer-events: auto; }
.mobile-menu::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at top, var(--accent-soft) 0%, transparent 60%);
  pointer-events: none;
}
.mobile-menu a {
  position: relative;
  font-family: var(--font-display);
  font-size: clamp(36px, 9vw, 56px);
  font-weight: 600;
  letter-spacing: -0.03em;
  color: var(--text-1);
  opacity: 0;
  transform: translateY(20px);
  transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease);
}
.mobile-menu.is-open a {
  opacity: 1;
  transform: translateY(0);
}
.mobile-menu.is-open a:nth-child(1) { transition-delay: 60ms; }
.mobile-menu.is-open a:nth-child(2) { transition-delay: 120ms; }
.mobile-menu.is-open a:nth-child(3) { transition-delay: 180ms; }
.mobile-menu.is-open a:nth-child(4) { transition-delay: 240ms; }
@media (min-width: 768px) { .mobile-menu { display: none; } }

/* ============== Hero ============== */
.hero {
  position: relative;
  min-height: 100dvh;
  padding-top: calc(var(--nav-height) + var(--s-8));
  padding-bottom: var(--s-8);
  display: flex;
  align-items: center;
  overflow: hidden;
  isolation: isolate;
}
.hero-bg-fallback {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse 80% 60% at 30% 30%, rgba(255, 181, 71, 0.18) 0%, transparent 50%),
    radial-gradient(ellipse 60% 80% at 70% 70%, rgba(232, 153, 56, 0.14) 0%, transparent 60%),
    conic-gradient(from 220deg at 50% 50%, var(--bg-0), #1A1410, var(--bg-0), #221912, var(--bg-0));
}
.hero-canvas {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
}
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: radial-gradient(ellipse at center, transparent 0%, transparent 50%, var(--bg-0) 100%);
  pointer-events: none;
}
.hero-grain {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  opacity: 0.06;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero-content {
  position: relative;
  z-index: 4;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
  max-width: 920px;
}
.hero-eyebrow { color: var(--text-2); }
.hero h1 {
  font-size: var(--text-xl);
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 0.96;
}
.hero h1 .word {
  display: inline-block;
  vertical-align: top;
  opacity: 0;
  transform: translateY(28px);
}
.hero h1 .word.is-revealed {
  opacity: 1;
  transform: none;
  transition: opacity var(--t-slow) var(--ease), transform var(--t-slow) var(--ease);
}
.hero-headline-accent {
  display: inline;
  background: linear-gradient(120deg, var(--accent) 0%, var(--accent-deep) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero-sub {
  color: var(--text-2);
  font-size: clamp(18px, 1.6vw, 22px);
  max-width: 56ch;
  line-height: 1.5;
}
.hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-top: var(--s-3);
}
.hero-scroll {
  position: absolute;
  bottom: var(--s-7);
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-3);
}
.hero-scroll-line {
  width: 1px;
  height: 32px;
  background: linear-gradient(to bottom, transparent, var(--text-3));
  animation: scroll-bob 2.4s var(--ease) infinite;
}
@keyframes scroll-bob {
  0%, 100% { transform: translateY(0); opacity: 0.6; }
  50%      { transform: translateY(8px); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-scroll-line { animation: none; }
}

/* ============== Work ============== */
.work-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-7);
}
@media (min-width: 1024px) {
  .work-grid { grid-template-columns: repeat(3, 1fr); gap: var(--s-6); }
}
.work-card {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  color: inherit;
  transition: transform var(--t-base) var(--ease);
}
.work-card:hover .browser {
  border-color: var(--border-amber);
  box-shadow: 0 24px 64px -16px var(--accent-glow), 0 0 0 1px var(--accent-glow);
  transform: translateY(-4px);
}
.work-meta {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.work-meta-row {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  flex-wrap: wrap;
}
.work-name {
  font-family: var(--font-display);
  font-size: var(--text-m);
  font-weight: 600;
  letter-spacing: -0.02em;
}
.work-location {
  font-family: var(--font-mono);
  font-size: var(--text-small);
  color: var(--text-3);
}
.work-tagline {
  color: var(--text-2);
  font-size: var(--text-body);
}

/* ============== Services ============== */
.services-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
}
@media (min-width: 768px) {
  .services-grid { grid-template-columns: repeat(3, 1fr); gap: var(--s-7); }
}
.service-item {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding-top: var(--s-5);
  border-top: 1px solid var(--border);
}
.service-num {
  font-family: var(--font-mono);
  font-size: var(--text-small);
  font-weight: 500;
  letter-spacing: 0.16em;
  color: var(--accent);
}
.service-title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 600;
  letter-spacing: -0.02em;
}
.service-desc { color: var(--text-2); font-size: var(--text-body); }

/* ============== Pricing ============== */
.price-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
  max-width: var(--container-narrow);
  margin-inline: auto;
}
@media (min-width: 768px) {
  .price-grid { grid-template-columns: 1fr 1fr; gap: var(--s-6); }
}
.addons {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
  max-width: var(--container-narrow);
  margin: 0 auto;
}
@media (min-width: 768px) {
  .addons { grid-template-columns: repeat(3, 1fr); }
}
.addons-label {
  text-align: center;
  margin-top: var(--s-9);
  margin-bottom: var(--s-5);
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
@media (min-width: 1024px) {
  .addons-label { margin-top: var(--s-10); }
}

/* ============== Process ============== */
.process-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-7);
  position: relative;
}
@media (min-width: 1024px) {
  .process-grid { grid-template-columns: repeat(3, 1fr); gap: var(--s-7); }
  .process-grid::before {
    content: "";
    position: absolute;
    top: clamp(40px, 7vw, 100px);
    left: 16%;
    right: 16%;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--border-strong) 20%, var(--border-strong) 80%, transparent);
    pointer-events: none;
  }
}
.process-item {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  position: relative;
}
.process-num {
  font-family: var(--font-display);
  font-size: clamp(80px, 14vw, 200px);
  font-weight: 600;
  line-height: 0.9;
  letter-spacing: -0.05em;
  color: var(--text-3);
  background: linear-gradient(135deg, var(--text-3) 0%, var(--text-3) 50%, transparent 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.process-item.is-revealed .process-num {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-deep) 50%, var(--text-3) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  transition: background 800ms var(--ease);
}
.process-title {
  font-family: var(--font-display);
  font-size: var(--text-m);
  font-weight: 600;
  letter-spacing: -0.02em;
}
.process-desc { color: var(--text-2); font-size: var(--text-body-l); max-width: 32ch; }

/* ============== Why ============== */
.why-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-4);
}
@media (min-width: 640px) {
  .why-grid { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1024px) {
  .why-grid { grid-template-columns: repeat(2, 1fr); }
}
.why-card {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-7);
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--r-3);
  transition: border-color var(--t-base) var(--ease), background var(--t-base) var(--ease);
}
.why-card:hover {
  border-color: var(--border-amber);
  background: var(--bg-2);
}
.why-stat {
  font-family: var(--font-display);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 600;
  letter-spacing: -0.03em;
  color: var(--accent);
  line-height: 1;
}
.why-desc {
  color: var(--text-2);
  font-size: var(--text-body);
  max-width: 32ch;
}

/* ============== Contact / Form ============== */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-7);
  align-items: start;
}
@media (min-width: 1024px) {
  .contact-grid { grid-template-columns: 1fr 1.4fr; gap: var(--s-8); }
}
.contact-aside h2 { font-size: var(--text-l); margin-top: var(--s-3); }
.contact-aside .lede { color: var(--text-2); margin-top: var(--s-4); font-size: var(--text-body-l); max-width: 40ch; }
.contact-aside .meta {
  margin-top: var(--s-7);
  padding-top: var(--s-5);
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  color: var(--text-2);
  font-family: var(--font-mono);
  font-size: var(--text-small);
}
.contact-aside .meta strong { color: var(--text-1); font-weight: 500; }

.quote-form {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-4);
  background: var(--bg-1);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-3);
  padding: var(--s-6);
}
@media (min-width: 640px) {
  .quote-form { padding: var(--s-7); grid-template-columns: 1fr 1fr; }
  .quote-form .span-2 { grid-column: span 2; }
}

/* ============== Footer ============== */
.footer {
  border-top: 1px solid var(--border);
  background: var(--bg-1);
  padding-block: var(--s-7) var(--s-5);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
  align-items: start;
  margin-bottom: var(--s-6);
}
@media (min-width: 768px) {
  .footer-grid { grid-template-columns: 1fr 1fr 1fr; }
}
.footer-meta {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-small);
  color: var(--text-2);
}
.footer-meta a:hover { color: var(--accent); }
.footer-links {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
@media (min-width: 768px) { .footer-links { align-items: flex-end; } }
.footer-links a {
  font-family: var(--font-mono);
  font-size: var(--text-small);
  color: var(--text-2);
  transition: color var(--t-fast) var(--ease);
}
.footer-links a:hover { color: var(--accent); }
.footer-bottom {
  border-top: 1px solid var(--border);
  padding-top: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-3);
}
@media (min-width: 768px) {
  .footer-bottom { flex-direction: row; justify-content: space-between; }
}
