:root {
  --cream: #EDE8DF;
  --cream-dark: #D9D2C5;
  --ink: #1A1A18;
  --ink-light: #2E2E2B;
  --ink-muted: #6B6860;
  --accent: #C8B89A;
  --r: 16px;
  --r-sm: 10px;
  --r-lg: 24px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--ink);
  color: var(--cream);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 400;
  font-size: 16px;
  overflow-x: hidden;
}
.cursor, .cursor-ring { display: none; }
@media (pointer: fine) {
  body { cursor: none; }
  .cursor {
    display: block; position: fixed;
    width: 8px; height: 8px;
    background: var(--cream); border-radius: 50%;
    pointer-events: none; z-index: 9999;
    transform: translate(-50%,-50%);
    transition: transform .15s;
  }
  .cursor-ring {
    display: block; position: fixed;
    width: 36px; height: 36px;
    border: 1px solid rgba(237,232,223,.4); border-radius: 50%;
    pointer-events: none; z-index: 9998;
    transform: translate(-50%,-50%);
    transition: width .3s, height .3s, opacity .3s;
  }
}

/* PAGE ROUTER */
.page { display: none; }
.page.active { display: block; }

/* NAV */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 40px;
  transition: background .3s, backdrop-filter .3s, padding .3s;
}
nav.scrolled {
  background: rgba(26,26,24,.92);
  backdrop-filter: blur(20px);
  padding: 12px 40px;
  box-shadow: 0 1px 0 rgba(237,232,223,.06);
}
.nav-logo {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; cursor: pointer; flex-shrink: 0;
}
.logo-mark { display: flex; align-items: center; gap: 5px; }
.logo-dot { width: 5px; height: 5px; background: var(--cream); border-radius: 50%; flex-shrink: 0; }
.logo-n {
  font-weight: 700; font-size: 20px; color: var(--cream);
  line-height: 1; position: relative; flex-shrink: 0;
}
.logo-n::after {
  content: ''; position: absolute;
  right: -7px; top: 2px; bottom: 2px;
  width: 1px; background: var(--cream); opacity: .35;
}
.logo-wordmark {
  font-weight: 600; font-size: 14px;
  letter-spacing: .28em; color: var(--cream);
  padding-left: 8px; text-transform: uppercase; white-space: nowrap;
}
.nav-links {
  display: flex; gap: 32px; list-style: none;
  align-items: center;
}
.nav-links a {
  font-size: 13px; font-weight: 600; letter-spacing: .1em;
  color: var(--cream); opacity: .6;
  text-decoration: none; text-transform: uppercase;
  transition: opacity .2s; cursor: pointer; white-space: nowrap;
}
.nav-links a:hover, .nav-links a.active { opacity: 1; }
.nav-cta {
  font-size: 13px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--ink);
  background: var(--cream); padding: 11px 22px;
  border-radius: var(--r-sm); text-decoration: none;
  transition: background .2s, transform .2s; cursor: pointer;
  white-space: nowrap; flex-shrink: 0;
}
.nav-cta:hover { background: var(--accent); transform: translateY(-1px); }

/* HAMBURGER */
.hamburger {
  display: none; flex-direction: column; justify-content: center; gap: 5px;
  background: none; border: none; cursor: pointer;
  padding: 8px; z-index: 301; width: 40px; height: 40px;
  border-radius: 8px; transition: background .2s;
}
.hamburger:hover { background: rgba(237,232,223,.08); }
.hamburger span {
  display: block; width: 22px; height: 2px;
  background: var(--cream); border-radius: 2px;
  transition: transform .3s cubic-bezier(.16,1,.3,1), opacity .2s, width .3s;
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; width: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* MOBILE MENU */
.mobile-menu {
  display: none; position: fixed; inset: 0;
  background: var(--ink); z-index: 300;
  flex-direction: column; align-items: center; justify-content: center; gap: 8px;
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
}
.mobile-menu.open { display: flex; opacity: 1; pointer-events: all; }
.mobile-menu a {
  font-size: clamp(28px, 8vw, 40px); font-weight: 700; letter-spacing: -.02em;
  color: var(--cream); text-decoration: none; opacity: .35;
  transition: opacity .2s; cursor: pointer; padding: 8px 0;
}
.mobile-menu a:hover { opacity: 1; }
.mobile-menu .mob-cta {
  margin-top: 24px;
  font-size: 14px; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ink);
  background: var(--cream); padding: 15px 40px;
  border-radius: var(--r-sm); opacity: 1;
}
.mobile-menu .mob-cta:hover { background: var(--accent); opacity: 1; }

/* Nav shrink breakpoints */
@media (max-width: 1100px) {
  nav { padding: 20px 36px; }
  nav.scrolled { padding: 14px 36px; }
  .nav-links { gap: 20px; }
  .nav-links a { font-size: 12px; }
  .nav-cta { font-size: 12px; padding: 10px 18px; }
}
@media (max-width: 860px) {
  nav { padding: 18px 28px; }
  nav.scrolled { padding: 14px 28px; }
  .nav-links, .nav-cta { display: none; }
  .hamburger { display: flex; }
}

/* SHARED */
.sp { padding: 80px 40px; }
.section-label {
  font-size: 12px; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 14px;
}
.section-title {
  font-size: clamp(30px, 3.8vw, 52px); font-weight: 700;
  letter-spacing: -.03em; line-height: 1.08; color: var(--cream);
}
.section-title em { font-style: normal; color: var(--accent); }
.sh { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 60px; flex-wrap: wrap; gap: 24px; }
.section-link {
  font-size: 13px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--cream); opacity: .5;
  text-decoration: none; display: flex; align-items: center; gap: 6px;
  transition: opacity .2s; cursor: pointer;
}
.section-link:hover { opacity: 1; }
.section-link::after { content: '→'; }
.btn-p {
  display: inline-block; font-size: 13px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink); background: var(--cream);
  padding: 15px 32px; border-radius: var(--r-sm);
  text-decoration: none; transition: background .2s, transform .2s; cursor: pointer;
}
.btn-p:hover { background: var(--accent); transform: translateY(-2px); }
.btn-g {
  font-size: 13px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--cream); opacity: .6;
  text-decoration: none; display: inline-flex; align-items: center;
  gap: 6px; transition: opacity .2s; cursor: pointer;
}
.btn-g:hover { opacity: 1; }
.btn-g::after { content: '→'; }
.btn-d {
  display: inline-block; font-size: 13px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--cream); background: var(--ink);
  padding: 15px 36px; border-radius: var(--r-sm);
  border: 1px solid rgba(237,232,223,.15);
  text-decoration: none; transition: border-color .2s; cursor: pointer;
}
.btn-d:hover { border-color: rgba(237,232,223,.4); }
.btn-o {
  display: inline-block; font-size: 13px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink); background: transparent;
  padding: 15px 36px; border-radius: var(--r-sm);
  border: 1.5px solid rgba(26,26,24,.35);
  text-decoration: none; transition: background .2s; cursor: pointer;
}
.btn-o:hover { background: rgba(26,26,24,.08); }
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .6s, transform .6s; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ══ HOME ══ */
.hero {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  overflow: hidden;
  position: relative;
}
.hero-left {
  display: flex; flex-direction: column; justify-content: center;
  padding: 120px 40px 60px;
  position: relative; z-index: 2;
}
.h-tag {
  font-size: 12px; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 20px;
  opacity: 0; animation: fadeUp .7s .15s forwards;
}
.h-title {
  font-size: clamp(36px, 5vw, 78px); font-weight: 700;
  letter-spacing: -.04em; line-height: 1.05; color: var(--cream);
  margin-bottom: 24px; opacity: 0; animation: fadeUp .7s .3s forwards;
}
.h-title em { font-style: normal; color: var(--accent); }
.h-desc {
  max-width: 420px; font-size: 16px; line-height: 1.8; color: var(--cream);
  opacity: 0; animation: fadeUp .7s .45s forwards;
}
.h-desc-dim { opacity: .55; }
.h-actions {
  display: flex; align-items: center; gap: 16px; margin-top: 36px;
  flex-wrap: wrap; opacity: 0; animation: fadeUp .7s .6s forwards;
}
.hero-right {
  position: relative;
  margin: 20px 20px 20px 0;
}
.h-visual {
  position: absolute; inset: 0;
  background: #111110;
  border-radius: var(--r-lg);
  overflow: hidden;
  opacity: 0; animation: fadeIn .8s .2s forwards;
}

/* Ambient glow */
.h-visual::before {
  content: '';
  position: absolute;
  width: 70%; height: 70%;
  top: -20%; left: 10%;
  background: radial-gradient(ellipse, rgba(200,184,154,.12) 0%, transparent 70%);
  pointer-events: none; z-index: 0;
}
.h-visual::after {
  content: '';
  position: absolute;
  width: 50%; height: 50%;
  bottom: 0%; right: -10%;
  background: radial-gradient(ellipse, rgba(200,184,154,.07) 0%, transparent 70%);
  pointer-events: none; z-index: 0;
}

/* Subtle dot grid */
.h-grid {
  position: absolute; inset: 0; z-index: 1;
  background-image: radial-gradient(circle, rgba(237,232,223,.08) 1px, transparent 1px);
  background-size: 32px 32px;
}

/* Central dashboard card */
.hv-dashboard {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 78%; z-index: 5;
  opacity: 0; animation: fadeUp .7s .6s forwards;
}
.hv-dash-inner {
  background: rgba(30,29,27,.9);
  border: 1px solid rgba(237,232,223,.1);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 40px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(237,232,223,.05);
}
.hv-dash-bar {
  background: rgba(237,232,223,.04);
  padding: 10px 14px;
  display: flex; align-items: center; gap: 8px;
  border-bottom: 1px solid rgba(237,232,223,.07);
}
.hv-dash-dot { width: 8px; height: 8px; border-radius: 50%; }
.hv-dash-tab {
  margin-left: 10px; display: flex; gap: 4px;
}
.hv-dash-tab span {
  font-size: 10px; font-weight: 600; letter-spacing: .05em;
  color: var(--cream); opacity: .3; padding: 3px 10px;
  border-radius: 6px;
}
.hv-dash-tab span.act {
  opacity: .9; background: rgba(237,232,223,.1);
}
.hv-dash-body { padding: 14px; display: flex; flex-direction: column; gap: 10px; }

/* Metric row */
.hv-metrics { display: flex; gap: 8px; }
.hv-metric {
  flex: 1; background: rgba(237,232,223,.05);
  border-radius: 10px; padding: 10px 12px;
  border: 1px solid rgba(237,232,223,.07);
}
.hv-metric-val {
  font-size: 18px; font-weight: 800;
  color: var(--cream); letter-spacing: -.03em; line-height: 1;
}
.hv-metric-val.accent { color: var(--accent); }
.hv-metric-val.green { color: #4ade80; }
.hv-metric-lbl {
  font-size: 9px; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; color: var(--cream); opacity: .35; margin-top: 3px;
}

/* Chart row */
.hv-chart-row { display: flex; gap: 8px; }
.hv-chart {
  flex: 1; background: rgba(237,232,223,.04);
  border-radius: 10px; padding: 10px 12px;
  border: 1px solid rgba(237,232,223,.07);
}
.hv-chart-label {
  font-size: 9px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--cream); opacity: .35; margin-bottom: 8px;
}
.hv-bars { display: flex; align-items: flex-end; gap: 4px; height: 44px; }
.hv-bar {
  flex: 1; border-radius: 4px 4px 0 0;
  background: rgba(200,184,154,.25);
  animation: barGrow .8s ease forwards;
  transform-origin: bottom;
  transform: scaleY(0);
}
.hv-bar.hi { background: rgba(200,184,154,.7); }
.hv-bar:nth-child(1) { animation-delay: .8s; }
.hv-bar:nth-child(2) { animation-delay: .9s; }
.hv-bar:nth-child(3) { animation-delay: 1s; }
.hv-bar:nth-child(4) { animation-delay: 1.1s; }
.hv-bar:nth-child(5) { animation-delay: 1.2s; }
.hv-bar:nth-child(6) { animation-delay: 1.3s; }
.hv-bar:nth-child(7) { animation-delay: 1.4s; }
@keyframes barGrow { to { transform: scaleY(1); } }

/* Progress list */
.hv-list { flex: 0 0 44%; }
.hv-list-item {
  display: flex; flex-direction: column; gap: 4px; margin-bottom: 8px;
}
.hv-list-item:last-child { margin-bottom: 0; }
.hv-list-label {
  display: flex; justify-content: space-between;
  font-size: 9px; font-weight: 600; color: var(--cream); opacity: .45;
}
.hv-progress {
  height: 4px; background: rgba(237,232,223,.08);
  border-radius: 4px; overflow: hidden;
}
.hv-progress-fill {
  height: 100%; border-radius: 4px;
  background: linear-gradient(90deg, var(--accent), rgba(200,184,154,.5));
  animation: fillBar 1.2s ease forwards;
  width: 0%;
}
@keyframes fillBar { to { width: var(--w); } }

/* Activity feed */
.hv-activity { display: flex; flex-direction: column; gap: 6px; }
.hv-act-item {
  display: flex; align-items: center; gap: 8px;
  background: rgba(237,232,223,.04); border-radius: 8px;
  padding: 7px 10px;
  border: 1px solid rgba(237,232,223,.05);
}
.hv-act-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.hv-act-text { font-size: 9px; font-weight: 600; color: var(--cream); opacity: .5; flex: 1; }
.hv-act-time { font-size: 8px; color: var(--cream); opacity: .25; }
.hv-act-live {
  font-size: 8px; font-weight: 700; letter-spacing: .1em;
  color: #4ade80; display: flex; align-items: center; gap: 3px;
}
.hv-act-live::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: #4ade80; animation: pulse 2s infinite;
}

/* Stat card stays */
.h-stat-card {
  position: absolute; bottom: 20px; left: -20px; right: 20px;
  background: rgba(15,14,13,.88); backdrop-filter: blur(24px);
  border: 1px solid rgba(237,232,223,.1); border-radius: var(--r);
  padding: 16px 22px; opacity: 0; animation: fadeUp .7s 1s forwards;
  z-index: 6;
}
.stat-row { display: flex; gap: 0; }
.stat-item {
  flex: 1; display: flex; flex-direction: column;
  padding: 0 16px; border-right: 1px solid rgba(237,232,223,.08);
}
.stat-item:first-child { padding-left: 0; }
.stat-item:last-child { border-right: none; }
.stat-n { font-size: 26px; font-weight: 800; color: var(--cream); letter-spacing: -.04em; line-height: 1; }
.stat-l { font-size: 11px; color: var(--cream); opacity: .45; margin-top: 3px; font-weight: 500; }

/* ── HERO RESPONSIVE ── */
@media (max-width: 1024px) {
  /* h-visual covers full hero as background; dashboard at bottom; h-grid is section background */
  .hero {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    min-height: 100svh;
    min-height: 100vh;
    background-image: radial-gradient(circle, rgba(237,232,223,.08) 1px, transparent 1px);
    background-size: 32px 32px;
  }
  .h-grid { display: none; }
  /* hero-right becomes a full-bleed background layer */
  .hero-right {
    position: absolute; inset: 0;
    height: auto; margin: 0;
    z-index: 1;
  }
  .h-visual { border-radius: 0; }
  /* text sits on top */
  .hero-left {
    position: relative; z-index: 2;
    padding: 130px 36px 280px;
    justify-content: flex-start;
  }
  /* stat card hidden — dashboard shows same data */
  .h-stat-card { display: none; }
  /* dashboard anchored to bottom of the full-bleed visual */
  .hv-dashboard {
    top: auto; left: 50%;
    transform: translateX(-50%);
    bottom: 28px; width: 86%;
  }
  .h-title { font-size: clamp(36px, 7vw, 58px); }
  .h-desc { max-width: 100%; font-size: 16px; }
}
@media (max-width: 768px) {
  .hero-left { padding: 120px 24px 260px; }
  .hv-dashboard { width: 92%; bottom: 24px; }
  .h-title { font-size: clamp(32px, 8vw, 50px); letter-spacing: -.03em; }
  .h-desc { font-size: 15px; }
  .h-actions { gap: 12px; margin-top: 28px; }
  .stat-row { gap: 16px; }
  .stat-n { font-size: 22px; }
  .stat-l { font-size: 11px; }
}
@media (max-width: 480px) {
  .hero-left { padding: 110px 18px 220px; }
  .hv-dashboard { width: 88%; bottom: 20px; }
  .hv-dash-body { padding: 8px; gap: 6px; }
  .hv-metric-val { font-size: 14px; }
  .hv-metric { padding: 7px 8px; }
  .hv-bars { height: 32px; }
  .hv-act-item { padding: 5px 7px; }
  .hv-act-text { font-size: 8px; }
  .hv-metrics { gap: 5px; }
  .hv-chart-row { gap: 5px; }
  .h-tag { font-size: 11px; margin-bottom: 14px; }
  .h-title {
    font-size: clamp(28px, 9vw, 38px);
    letter-spacing: -.03em;
    margin-bottom: 16px;
  }
  .h-desc { font-size: 14px; line-height: 1.7; }
  .h-desc-dim { display: none; }
  .h-actions {
    flex-direction: column; align-items: stretch;
    gap: 10px; margin-top: 22px;
  }
  .h-actions .btn-p, .h-actions .btn-g {
    text-align: center; justify-content: center; padding: 14px;
  }
  /* Cards: smaller, repositioned for 220px panel */
  .hv-card { min-width: 130px; padding: 8px 11px; gap: 8px; border-radius: 10px; }
  .hv-card-title { font-size: 11px; }
  .hv-card-sub { font-size: 10px; }
  .hv-card-icon { width: 24px; height: 24px; border-radius: 6px; }
  .hv-card-icon svg { width: 12px; height: 12px; }
  .hv-card1 { top: 10%; left: 4%; }
  .hv-card2 { top: 40%; right: 3%; }
  .hv-card3 { bottom: 18%; left: 4%; }
  .h-big-n { font-size: 100px; }
  .stat-row { gap: 14px; }
  .stat-n { font-size: 20px; }
  .stat-l { font-size: 10px; }
  .h-stat-card { padding: 11px 14px; left: 10px; right: 10px; bottom: 10px; }
  .h-big-n { font-size: 100px; }
}

/* MARQUEE */
.mq-wrap { background: var(--cream); padding: 15px 0; overflow: hidden; }
.mq-track { display: flex; animation: marquee 22s linear infinite; white-space: nowrap; }
.mq-item { font-size: 12px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--ink); padding: 0 28px; opacity: .6; }
.mq-sep { color: var(--ink); opacity: .2; font-size: 8px; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* SERVICES GRID */
.svc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.svc-card {
  background: var(--ink-light); border-radius: var(--r);
  padding: 36px 32px; position: relative; overflow: hidden;
  transition: background .3s, transform .3s; cursor: default;
}
.svc-card:hover { background: #252522; transform: translateY(-4px); }
.svc-card::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0;
  height: 2px; background: var(--accent);
  transform: scaleX(0); transform-origin: left;
  transition: transform .4s cubic-bezier(.16,1,.3,1);
  border-radius: 0 0 var(--r) var(--r);
}
.svc-card:hover::after { transform: scaleX(1); }
.svc-n { font-size: 12px; font-weight: 700; color: var(--accent); letter-spacing: .08em; margin-bottom: 24px; }
.svc-name { font-size: 19px; font-weight: 700; letter-spacing: -.01em; color: var(--cream); margin-bottom: 12px; }
.svc-desc { font-size: 15px; line-height: 1.75; color: var(--cream); opacity: .65; }
.svc-arr {
  position: absolute; bottom: 24px; right: 24px;
  font-size: 16px; color: var(--cream); opacity: 0;
  transform: translateX(-6px); transition: opacity .3s, transform .3s;
}
.svc-card:hover .svc-arr { opacity: .4; transform: translateX(0); }

/* PROCESS */
.proc-sec {
  padding: 120px 56px; background: var(--cream); position: relative; overflow: hidden;
}
.proc-sec .section-label { color: var(--ink-muted); }
.proc-sec .section-title { color: var(--ink); }
.proc-sec .section-title em { color: var(--ink-muted); }
.proc-sec .section-link { color: var(--ink); }
.proc-bg {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  font-size: 180px; font-weight: 800;
  color: rgba(26,26,24,.04); white-space: nowrap;
  pointer-events: none; letter-spacing: -.04em;
}
.proc-steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; position: relative; z-index: 2; }
.proc-step {
  background: rgba(26,26,24,.07); border-radius: var(--r);
  padding: 28px 24px;
}
.ps-n { font-size: 36px; font-weight: 800; color: var(--ink); opacity: .1; line-height: 1; margin-bottom: 18px; letter-spacing: -.03em; }
.ps-name { font-size: 17px; font-weight: 700; color: var(--ink); margin-bottom: 10px; }
.ps-desc { font-size: 14px; line-height: 1.75; color: var(--ink); opacity: .65; }

/* WORK GRID */
.work-grid {
  display: grid; grid-template-columns: 2fr 1fr;
  grid-template-rows: 1fr 1fr; gap: 14px; min-height: 520px;
}
.wi {
  background: var(--ink-light); border-radius: var(--r);
  padding: 32px; position: relative; overflow: hidden;
  display: flex; flex-direction: column; justify-content: flex-end;
  transition: background .3s; cursor: pointer;
}
.wi:hover { background: #252522; }
.wi.featured { grid-row: span 2; }
.wi-bg {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(237,232,223,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(237,232,223,.04) 1px,transparent 1px);
  background-size: 30px 30px;
}
.wi-yr { position: absolute; top: 20px; right: 20px; font-size: 10px; font-weight: 600; letter-spacing: .12em; color: var(--cream); opacity: .18; }
.wi-cat { font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); margin-bottom: 10px; }
.wi-name { font-size: 22px; font-weight: 700; letter-spacing: -.02em; color: var(--cream); line-height: 1.25; }

/* ABOUT STRIP */
.about-strip { padding: 80px 40px; display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.at { font-size: clamp(28px,3.5vw,48px); font-weight: 700; letter-spacing: -.03em; line-height: 1.1; color: var(--cream); margin-bottom: 20px; }
.at em { font-style: normal; color: var(--accent); }
.ab { font-size: 15px; line-height: 1.85; color: var(--cream); opacity: .7; margin-bottom: 14px; }
.asc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.asc {
  background: var(--cream); border-radius: var(--r); padding: 28px 24px;
}
.asc.dark { background: var(--accent); }
.asc-num { font-size: 40px; font-weight: 700; letter-spacing: -.04em; color: var(--ink); line-height: 1; margin-bottom: 5px; }
.asc-lbl { font-size: 13px; font-weight: 500; color: var(--ink); opacity: .65; }

/* CTA BAND */
.cta-band {
  padding: 80px 40px; text-align: center;
  background: var(--cream); position: relative; overflow: hidden;
}
.cta-band .section-label { color: var(--ink-muted); }
.cta-t {
  font-size: clamp(32px,5vw,68px); font-weight: 700;
  letter-spacing: -.04em; color: var(--ink); line-height: 1.05; margin-bottom: 44px;
}
.cta-t em { font-style: normal; color: var(--ink-muted); }
.cta-acts { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; }

/* ══ SERVICES PAGE ══ */
.pg-hero { padding: 130px 40px 52px; max-width: 760px; }
.pg-hero .h-tag { opacity: 1; animation: none; margin-bottom: 16px; }
.pg-hero .h-title { opacity: 1; animation: none; font-size: clamp(40px,5vw,72px); margin-bottom: 16px; }
.pg-hero .h-desc { opacity: .45; animation: none; max-width: 100%; }

.svc-full { padding: 0 40px 72px; }
.svc-row {
  display: grid; grid-template-columns: 100px 1fr; gap: 48px;
  align-items: start; padding: 48px 0;
  border-top: 1px solid rgba(237,232,223,.09);
}
.svc-row:last-child { border-bottom: 1px solid rgba(237,232,223,.09); }
.svc-row-n { font-size: 48px; font-weight: 800; color: var(--cream); opacity: .08; letter-spacing: -.04em; line-height: 1; }
.svc-row-name { font-size: 24px; font-weight: 700; letter-spacing: -.02em; color: var(--cream); margin-bottom: 16px; }
.svc-row-desc { font-size: 15px; line-height: 1.85; color: var(--cream); opacity: .7; margin-bottom: 20px; }
.tags { display: flex; flex-wrap: wrap; gap: 8px; }
.tag {
  font-size: 12px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--cream);
  border: 1px solid rgba(237,232,223,.18);
  border-radius: 100px; padding: 5px 13px;
}

/* ══ WORK PAGE ══ */
.wc {
  background: var(--ink-light); border-radius: var(--r-lg);
  overflow: hidden; cursor: pointer; transition: transform .3s;
}
.wc:hover { transform: translateY(-6px); }
.wc-img {
  height: 200px; background: var(--ink); position: relative;
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.wc-img-grid {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(237,232,223,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(237,232,223,.04) 1px,transparent 1px);
  background-size: 24px 24px;
}
.wc-icon { font-size: 56px; font-weight: 800; opacity: .07; letter-spacing: -.04em; }
.wc-body { padding: 24px 28px; }
.wc-cat { font-size: 11px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
.wc-title { font-size: 18px; font-weight: 700; letter-spacing: -.02em; color: var(--cream); margin-bottom: 8px; }
.wc-desc { font-size: 14px; line-height: 1.7; color: var(--cream); opacity: .5; }

/* ══ ABOUT PAGE ══ */
.about-full {
  padding: 130px 40px 60px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center;
}
.af-visual {
  background: var(--ink-light); border-radius: var(--r-lg);
  height: 460px; display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.af-bg {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(237,232,223,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(237,232,223,.04) 1px,transparent 1px);
  background-size: 40px 40px;
}
.af-logo { font-size: 120px; font-weight: 800; color: rgba(237,232,223,.06); letter-spacing: -.05em; }
.val-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.val-card { background: var(--ink-light); border-radius: var(--r); padding: 32px 28px; }
.val-ico { font-size: 24px; margin-bottom: 16px; }
.val-name { font-size: 18px; font-weight: 700; letter-spacing: -.01em; color: var(--cream); margin-bottom: 10px; }
.val-desc { font-size: 14px; line-height: 1.8; color: var(--cream); opacity: .65; }
.team-sec { padding: 0 40px 72px; background: var(--cream); }
.team-sec .section-label { color: var(--ink-muted); }
.team-sec .section-title { color: var(--ink); }
.team-sec .section-title em { color: var(--ink-muted); }
.team-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.tc { background: rgba(26,26,24,.08); border-radius: var(--r); padding: 32px 24px; }
.tc-av {
  width: 52px; height: 52px; background: var(--ink);
  border-radius: 50%; margin-bottom: 16px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 700; color: var(--cream);
}
.tc-name { font-size: 18px; font-weight: 700; color: var(--ink); margin-bottom: 6px; }
.tc-role { font-size: 13px; font-weight: 500; color: var(--ink); opacity: .6; letter-spacing: .03em; }

/* ══ CONTACT PAGE ══ */
.contact-layout {
  padding: 130px 40px 80px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start;
}
.cl { font-size: 12px; font-weight: 700; letter-spacing: .3em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; }
.ct { font-size: clamp(32px,4.5vw,56px); font-weight: 700; letter-spacing: -.03em; line-height: 1.08; color: var(--cream); margin-bottom: 28px; }
.ct em { font-style: normal; color: var(--accent); }
.cd { display: flex; flex-direction: column; gap: 18px; margin-bottom: 36px; }
.ci-l { font-size: 13px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--cream); opacity: .5; margin-bottom: 4px; }
.ci-v { font-size: 16px; font-weight: 500; color: var(--cream); }
.ci-v a { color: var(--cream); text-decoration: none; transition: color .2s; }
.ci-v a:hover { color: var(--accent); }
.cf { display: flex; flex-direction: column; gap: 14px; }
.fr { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.fg { display: flex; flex-direction: column; gap: 7px; }
.fl { font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--cream); opacity: .6; }
.fi, .fs, .ft {
  background: var(--ink-light); border: 1px solid rgba(237,232,223,.1);
  border-radius: var(--r-sm); padding: 13px 15px;
  font-family: 'Plus Jakarta Sans', sans-serif; font-size: 15px;
  color: var(--cream); outline: none; transition: border-color .2s; width: 100%;
}
.fi:focus, .fs:focus, .ft:focus { border-color: rgba(237,232,223,.32); }
.fi::placeholder, .ft::placeholder { opacity: .28; }
.fs { appearance: none; cursor: pointer; }
.ft { resize: vertical; min-height: 110px; }
.fsb {
  margin-top: 6px; font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink); background: var(--cream); border: none;
  padding: 16px 36px; border-radius: var(--r-sm);
  cursor: pointer; transition: background .2s, transform .2s; align-self: flex-start;
}
.fsb:hover { background: var(--accent); transform: translateY(-2px); }

/* FOOTER */
footer { padding: 44px 40px 24px; border-top: 1px solid rgba(237,232,223,.07); }
.ft-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 48px; flex-wrap: wrap; gap: 36px; }
.ft-tag { font-size: 14px; color: var(--cream); opacity: .4; margin-top: 8px; }
.ft-cols { display: flex; gap: 56px; flex-wrap: wrap; }
.fc-t { font-size: 12px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; }
.fl-links { list-style: none; }
.fl-links li { margin-bottom: 9px; }
.fl-links a { font-size: 15px; color: var(--cream); opacity: .55; text-decoration: none; transition: opacity .2s; cursor: pointer; }
.fl-links a:hover { opacity: 1; }
.ft-bot { display: flex; justify-content: space-between; align-items: center; padding-top: 24px; border-top: 1px solid rgba(237,232,223,.05); flex-wrap: wrap; gap: 10px; }
.ft-copy { font-size: 13px; color: var(--cream); opacity: .35; }
.ft-loc { font-size: 12px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--cream); opacity: .18; }

@keyframes fadeUp { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
::-webkit-scrollbar { width: 3px; }
::-webkit-scrollbar-track { background: var(--ink); }
::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 3px; }

/* ══ RESPONSIVE ══ */
@media (max-width: 1024px) {
  .sp, .about-strip, .proc-sec { padding: 60px 24px; }
  .svc-full, .work-full, .team-sec { padding-left: 24px; padding-right: 24px; }
  .contact-layout { padding: 104px 24px 56px; }
  .about-full { padding: 104px 24px 44px; }
  .pg-hero { padding: 104px 24px 44px; }
  .cta-band { padding: 60px 24px; }
  footer { padding: 36px 24px 20px; }

  .svc-grid { grid-template-columns: 1fr 1fr; }
  .proc-steps { grid-template-columns: 1fr 1fr; }
  .work-grid { grid-template-columns: 1fr; grid-template-rows: auto; min-height: auto; }
  .wi.featured { grid-row: auto; }
  .about-strip { grid-template-columns: 1fr; gap: 48px; }
  .about-full { grid-template-columns: 1fr; }
  .af-visual { height: 280px; }
  .val-grid { grid-template-columns: 1fr 1fr; }
  .team-grid { grid-template-columns: 1fr 1fr; }
  .contact-layout { grid-template-columns: 1fr; }
  .fr { grid-template-columns: 1fr; }
  .work-full { grid-template-columns: 1fr; }
  .svc-row { grid-template-columns: 1fr; gap: 10px; }
  .svc-row-n { font-size: 32px; }
  .ft-top { flex-direction: column; }
  .proc-bg { font-size: 120px; }
}

@media (max-width: 640px) {
  nav { padding: 14px 18px; }
  nav.scrolled { padding: 12px 18px; }

  .sp, .about-strip, .proc-sec { padding: 48px 16px; }
  .svc-full, .work-full, .team-sec { padding: 0 16px 56px; }
  .contact-layout { padding: 90px 16px 44px; }
  .about-full { padding: 90px 16px 36px; }
  .pg-hero { padding: 90px 16px 36px; }
  .cta-band { padding: 48px 16px; }
  footer { padding: 28px 16px 18px; }
  .ft-cols { flex-direction: column; gap: 28px; }
  .svc-grid { grid-template-columns: 1fr; }
  .proc-steps { grid-template-columns: 1fr; }
  .asc-grid { grid-template-columns: 1fr; }
  .val-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr; }
  .sh { flex-direction: column; align-items: flex-start; }

  .cta-acts { flex-direction: column; align-items: center; }
  .work-grid { min-height: auto; }
  .proc-bg { display: none; }
  .wi-name { font-size: 17px; }
  .team-sec { padding: 48px 16px; }
}

/* FILE UPLOAD */
.fu-zone {
  border: 1.5px dashed rgba(237,232,223,.2);
  border-radius: var(--r-sm);
  padding: 28px 20px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  position: relative;
}
.fu-zone:hover, .fu-zone.drag { border-color: var(--accent); background: rgba(200,184,154,.06); }
.fu-zone input[type="file"] {
  position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%;
}
.fu-icon { font-size: 22px; margin-bottom: 8px; opacity: .4; }
.fu-label {
  font-size: 14px; font-weight: 600; color: var(--cream); opacity: .7;
  display: block; margin-bottom: 4px;
}
.fu-hint { font-size: 13px; color: var(--cream); opacity: .5; }
.fu-files { display: flex; flex-direction: column; gap: 6px; margin-top: 12px; }
.fu-file {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(237,232,223,.06); border-radius: 8px;
  padding: 9px 14px; font-size: 14px; color: var(--cream); opacity: .8;
}
.fu-file-remove {
  background: none; border: none; color: var(--cream);
  opacity: .4; cursor: pointer; font-size: 14px; padding: 0 0 0 8px;
  transition: opacity .2s;
}
.fu-file-remove:hover { opacity: 1; }
.links-section { display: flex; flex-direction: column; gap: 10px; }
.link-row { display: flex; gap: 8px; align-items: center; }
.link-row .fi { flex: 1; }
.add-link-btn {
  background: none; border: 1px solid rgba(237,232,223,.15);
  border-radius: var(--r-sm); color: var(--cream); opacity: .45;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px; font-weight: 600; letter-spacing: .06em;
  padding: 11px 18px; cursor: pointer; transition: opacity .2s, border-color .2s;
  white-space: nowrap;
}
.add-link-btn:hover { opacity: 1; border-color: rgba(237,232,223,.35); }
.remove-link-btn {
  background: none; border: none; color: var(--cream);
  opacity: .3; cursor: pointer; font-size: 16px; padding: 0 4px;
  transition: opacity .2s; flex-shrink: 0;
}
.remove-link-btn:hover { opacity: .8; }
.form-section-label {
  font-size: 13px; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: 12px; margin-top: 4px; display: block;
}

/* ── VISUALS ── */

.showcase-item .si-bg { background: linear-gradient(to top, rgba(26,26,24,0) 0%, rgba(26,26,24,0) 100%); }
.showcase-item::after {
  content: ''; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(to top, rgba(26,26,24,.85) 0%, rgba(26,26,24,.2) 50%, transparent 100%);
  border-radius: var(--r-lg); pointer-events: none;
}
.si-content { z-index: 3; position: relative; }

/* Floating orbs in hero */
.hero-orb {
  position: absolute; border-radius: 50%;
  filter: blur(60px); pointer-events: none; opacity: 0;
  animation: fadeIn 1.5s 0.5s forwards;
}
.orb1 { width: 300px; height: 300px; background: rgba(200,184,154,.12); top: 10%; right: 10%; animation-duration: 2s; }
.orb2 { width: 200px; height: 200px; background: rgba(200,184,154,.08); bottom: 20%; right: 30%; animation-duration: 2.5s; }
.orb3 { width: 150px; height: 150px; background: rgba(237,232,223,.05); top: 40%; right: 5%; animation-duration: 3s; }

/* Floating dots grid */
.dots-grid {
  position: absolute; inset: 0; border-radius: var(--r-lg);
  background-image: radial-gradient(circle, rgba(237,232,223,.15) 1px, transparent 1px);
  background-size: 28px 28px; pointer-events: none;
}

/* Service icons */
.svc-icon {
  width: 44px; height: 44px; margin-bottom: 20px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 12px; background: rgba(200,184,154,.1);
}
.svc-icon svg { width: 22px; height: 22px; }

/* Showcase strip */
.showcase {
  padding: 0 56px 120px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.showcase-item {
  border-radius: var(--r-lg); overflow: hidden;
  position: relative; min-height: 280px;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 36px;
  transition: transform .4s cubic-bezier(.16,1,.3,1);
}
.showcase-item:hover { transform: translateY(-6px); }
.showcase-item.tall { min-height: 400px; }
.si-bg {
  position: absolute; inset: 0; z-index: 0;
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.si-content { position: relative; z-index: 2; }
.si-label {
  font-size: 12px; font-weight: 700; letter-spacing: .16em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 10px;
}
.si-title {
  font-size: 24px; font-weight: 700; letter-spacing: -.02em;
  color: var(--cream); line-height: 1.25;
}
/* Web mockup */
.mock-browser {
  width: 85%; background: #0d0d0b; border-radius: 12px;
  overflow: hidden; box-shadow: 0 32px 80px rgba(0,0,0,.5);
  border: 1px solid rgba(237,232,223,.08);
}
.mock-bar {
  background: #1a1a18; padding: 10px 14px;
  display: flex; align-items: center; gap: 6px;
}
.mock-dot { width: 8px; height: 8px; border-radius: 50%; }
.mock-url {
  flex: 1; background: rgba(237,232,223,.06); border-radius: 4px;
  height: 18px; margin-left: 8px;
}
.mock-body { padding: 16px; display: flex; flex-direction: column; gap: 8px; }
.mock-line { height: 8px; border-radius: 4px; background: rgba(237,232,223,.08); }
.mock-line.accent { background: rgba(200,184,154,.25); width: 40%; }
.mock-line.short { width: 60%; }
.mock-hero-block {
  height: 80px; border-radius: 8px;
  background: linear-gradient(135deg, rgba(200,184,154,.15), rgba(237,232,223,.05));
  margin-bottom: 4px;
}
/* Mobile mockup */
.mock-phone {
  width: 120px; background: #0d0d0b; border-radius: 24px;
  border: 1px solid rgba(237,232,223,.1);
  overflow: hidden; box-shadow: 0 24px 60px rgba(0,0,0,.5);
  flex-shrink: 0;
}
.mock-phone-bar {
  background: #1a1a18; height: 28px;
  display: flex; align-items: center; justify-content: center;
}
.mock-phone-notch { width: 40px; height: 8px; background: #0d0d0b; border-radius: 4px; }
.mock-phone-body { padding: 12px; display: flex; flex-direction: column; gap: 6px; }
.mock-phone-line { height: 6px; border-radius: 3px; background: rgba(237,232,223,.08); }
.mock-phone-card { height: 48px; border-radius: 8px; background: rgba(200,184,154,.12); margin-bottom: 2px; }
/* Email mockup */
.mock-email {
  width: 88%; background: #0d0d0b; border-radius: 10px;
  border: 1px solid rgba(237,232,223,.08);
  overflow: hidden; box-shadow: 0 20px 60px rgba(0,0,0,.4);
}
.mock-email-header {
  background: #1a1a18; padding: 12px 16px;
  display: flex; align-items: center; gap: 10px;
}
.mock-email-avatar { width: 28px; height: 28px; border-radius: 50%; background: rgba(200,184,154,.3); flex-shrink: 0; }
.mock-email-meta { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.mock-email-meta span { height: 6px; border-radius: 3px; background: rgba(237,232,223,.12); display: block; }
.mock-email-meta span:last-child { width: 60%; }
.mock-email-body { padding: 14px 16px; display: flex; flex-direction: column; gap: 7px; }
.mock-email-line { height: 6px; border-radius: 3px; background: rgba(237,232,223,.07); }
.mock-email-logo {
  height: 32px; border-radius: 6px; margin-bottom: 6px;
  background: linear-gradient(90deg, rgba(200,184,154,.2), rgba(200,184,154,.05));
  width: 60%;
}
/* Automation visual */
.auto-flow {
  display: flex; flex-direction: column; gap: 10px; width: 80%;
}
.auto-node {
  background: rgba(237,232,223,.06); border: 1px solid rgba(237,232,223,.1);
  border-radius: 10px; padding: 12px 16px;
  display: flex; align-items: center; gap: 10px;
  animation: nodePulse 3s ease-in-out infinite;
}
.auto-node:nth-child(2) { animation-delay: .5s; margin-left: 24px; }
.auto-node:nth-child(3) { animation-delay: 1s; margin-left: 48px; }
.auto-node:nth-child(4) { animation-delay: 1.5s; margin-left: 24px; }
.auto-node-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent); flex-shrink: 0;
}
.auto-node-text { font-size: 13px; font-weight: 600; color: var(--cream); opacity: .75; }
.auto-arrow { font-size: 14px; color: var(--accent); opacity: .4; margin-left: 28px; }
@keyframes nodePulse {
  0%, 100% { border-color: rgba(237,232,223,.1); }
  50% { border-color: rgba(200,184,154,.3); }
}

/* Tech stack visual in about */
.tech-orbs {
  position: relative; height: 320px; width: 100%;
}
.t-orb {
  position: absolute; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--cream);
  border: 1px solid rgba(237,232,223,.15);
  animation: floatOrb 6s ease-in-out infinite;
}
.t-orb:nth-child(1) { width: 100px; height: 100px; top: 20px; left: 20px; background: rgba(200,184,154,.12); animation-delay: 0s; }
.t-orb:nth-child(2) { width: 80px; height: 80px; top: 60px; left: 140px; background: rgba(237,232,223,.06); animation-delay: .8s; }
.t-orb:nth-child(3) { width: 120px; height: 120px; top: 10px; right: 20px; background: rgba(200,184,154,.08); animation-delay: 1.2s; }
.t-orb:nth-child(4) { width: 70px; height: 70px; bottom: 60px; left: 60px; background: rgba(237,232,223,.05); animation-delay: .4s; }
.t-orb:nth-child(5) { width: 90px; height: 90px; bottom: 40px; right: 100px; background: rgba(200,184,154,.1); animation-delay: 1.6s; }
.t-orb:nth-child(6) { width: 60px; height: 60px; bottom: 80px; right: 20px; background: rgba(237,232,223,.06); animation-delay: 2s; }
@keyframes floatOrb {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

/* Animated counter */
.counter-strip {
  background: var(--accent); padding: 48px 56px;
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 32px; text-align: center;
}
.ctr-num {
  font-size: clamp(36px, 5vw, 64px); font-weight: 800;
  letter-spacing: -.04em; color: var(--ink); line-height: 1;
}
.ctr-lbl {
  font-size: 15px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ink); opacity: .7; margin-top: 8px;
}

/* Glowing border on hover for service cards */
.svc-card { position: relative; }
.svc-card::before {
  content: ''; position: absolute; inset: 0;
  border-radius: var(--r); opacity: 0;
  box-shadow: inset 0 0 0 1px rgba(200,184,154,.4);
  transition: opacity .3s;
}
.svc-card:hover::before { opacity: 1; }

/* Animated bg pattern */
.animated-bg {
  position: absolute; inset: 0; overflow: hidden; border-radius: inherit;
  pointer-events: none;
}
.animated-bg::before {
  content: ''; position: absolute;
  width: 200%; height: 200%; top: -50%; left: -50%;
  background: conic-gradient(from 0deg at 50% 50%, transparent 0deg, rgba(200,184,154,.03) 60deg, transparent 120deg);
  animation: spin 20s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

@media (max-width: 1024px) {
  .showcase { grid-template-columns: 1fr; padding: 0 28px 80px; }
  .showcase-item.tall { min-height: 280px; }
  .counter-strip { grid-template-columns: repeat(3,1fr); padding: 40px 28px; }
  .tech-orbs { height: 240px; }
}
@media (max-width: 640px) {
  .showcase { padding: 0 18px 64px; }
  .counter-strip { grid-template-columns: 1fr; gap: 24px; padding: 40px 18px; text-align: left; }
  .tech-orbs { height: 200px; }
}

/* Hide cards on very small hero */

/* ══ QUOTE BUILDER ══ */
.qb-wrap {
  max-width: 760px;
  margin: 0 auto;
}
.qb-step {
  display: none;
  animation: qbIn .4s cubic-bezier(.16,1,.3,1) forwards;
}
.qb-step.active { display: block; }
@keyframes qbIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.qb-step-label {
  font-size: 12px; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 12px;
}
.qb-step-title {
  font-size: clamp(24px,3vw,36px); font-weight: 700;
  letter-spacing: -.02em; color: var(--cream); margin-bottom: 32px; line-height: 1.15;
}
.qb-options {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 32px;
}
.qb-options.qb-scale { grid-template-columns: repeat(3,1fr); }
.qb-opt {
  background: var(--ink-light); border: 1.5px solid rgba(237,232,223,.08);
  border-radius: var(--r); padding: 24px 20px; cursor: pointer;
  transition: border-color .2s, background .2s, transform .2s;
  position: relative; overflow: hidden;
}
.qb-opt::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 0%, rgba(200,184,154,.08), transparent 70%);
  opacity: 0; transition: opacity .3s;
}
.qb-opt:hover { border-color: rgba(200,184,154,.3); transform: translateY(-2px); }
.qb-opt:hover::before { opacity: 1; }
.qb-opt.selected {
  border-color: var(--accent);
  background: rgba(200,184,154,.08);
}
.qb-opt.selected::after {
  content: '✓'; position: absolute; top: 10px; right: 12px;
  font-size: 11px; font-weight: 800; color: var(--accent);
}
.qb-opt-icon {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(200,184,154,.1); display: flex;
  align-items: center; justify-content: center;
  color: var(--accent); margin-bottom: 14px;
}
.qb-opt-icon svg { width: 18px; height: 18px; }
.qb-opt-name { font-size: 15px; font-weight: 700; color: var(--cream); margin-bottom: 4px; }
.qb-opt-sub { font-size: 12px; color: var(--cream); opacity: .4; line-height: 1.4; }
.qb-next, .qb-back {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; border: none; cursor: pointer;
  border-radius: var(--r-sm); padding: 14px 28px;
  transition: all .2s;
}
.qb-next {
  background: var(--cream); color: var(--ink);
  position: relative; overflow: hidden;
}
.qb-next::after {
  content: ''; position: absolute; inset: 0;
  background: rgba(0,0,0,.1); opacity: 0; transition: opacity .2s;
}
.qb-next:hover:not(:disabled)::after { opacity: 1; }
.qb-next:disabled { opacity: .3; cursor: not-allowed; }
.qb-back {
  background: transparent; color: var(--cream); opacity: .4;
  border: 1px solid rgba(237,232,223,.15);
}
.qb-back:hover { opacity: .8; }
.qb-nav { display: flex; gap: 12px; align-items: center; }
.qb-result { display: none; }
.qb-result.active { display: block; }
.qb-result-inner {
  background: var(--ink-light); border-radius: var(--r-lg);
  padding: 56px 48px; text-align: center;
  border: 1px solid rgba(200,184,154,.2);
  animation: qbIn .5s cubic-bezier(.16,1,.3,1) forwards;
}
.qb-result-icon {
  width: 56px; height: 56px; border-radius: 50%;
  background: rgba(200,184,154,.15); border: 1.5px solid var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: var(--accent); margin: 0 auto 20px;
}
.qb-result-title {
  font-size: 28px; font-weight: 700; letter-spacing: -.02em;
  color: var(--cream); margin-bottom: 12px;
}
.qb-result-sub {
  font-size: 15px; line-height: 1.7; color: var(--cream);
  opacity: .5; max-width: 460px; margin: 0 auto 28px;
}
.qb-summary {
  display: flex; gap: 10px; justify-content: center;
  flex-wrap: wrap; margin-bottom: 28px;
}
.qb-tag {
  font-size: 12px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ink);
  background: var(--accent); padding: 6px 14px; border-radius: 100px;
}

/* ══ PAGE TRANSITIONS ══ */
.page { animation: none; }
.page.active { animation: pageIn .4s cubic-bezier(.16,1,.3,1) forwards; }
@keyframes pageIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ══ MAGNETIC BUTTONS ══ */
.btn-p, .btn-d, .nav-cta {
  transform-style: preserve-3d;
  will-change: transform;
}

/* ══ SCROLL PROGRESS BAR ══ */
.scroll-bar {
  position: fixed; top: 0; left: 0; height: 2px;
  background: var(--accent); z-index: 9999;
  width: 0%; transition: width .1s linear;
  border-radius: 0 2px 2px 0;
}

/* ══ SECTION REVEAL: staggered children ══ */
.stagger-children > * {
  opacity: 0; transform: translateY(20px);
  transition: opacity .5s ease, transform .5s ease;
}
.stagger-children.visible > *:nth-child(1) { opacity:1; transform:none; transition-delay:.05s; }
.stagger-children.visible > *:nth-child(2) { opacity:1; transform:none; transition-delay:.12s; }
.stagger-children.visible > *:nth-child(3) { opacity:1; transform:none; transition-delay:.19s; }
.stagger-children.visible > *:nth-child(4) { opacity:1; transform:none; transition-delay:.26s; }
.stagger-children.visible > *:nth-child(5) { opacity:1; transform:none; transition-delay:.33s; }
.stagger-children.visible > *:nth-child(6) { opacity:1; transform:none; transition-delay:.40s; }

/* ══ HOVER TILT CARDS ══ */
.tilt-card {
  transform-style: preserve-3d;
  transition: transform .1s ease;
  will-change: transform;
}

/* ══ ANIMATED UNDERLINE LINKS ══ */
.nav-links a {
  position: relative;
}
.nav-links a::after {
  content: ''; position: absolute; bottom: -3px; left: 0;
  width: 0; height: 1.5px; background: var(--cream);
  transition: width .25s ease; border-radius: 2px;
}
.nav-links a:hover::after, .nav-links a.active::after { width: 100%; }

/* ══ COUNTER ANIMATION ══ */
.count-up { display: inline-block; }

/* ══ CURSOR TRAIL ══ */
.cursor-trail {
  position: fixed; width: 4px; height: 4px;
  background: var(--accent); border-radius: 50%;
  pointer-events: none; z-index: 9997; opacity: 0;
  transition: opacity .3s;
}

/* ══ RESPONSIVE QB ══ */
@media (max-width: 768px) {
  .qb-options { grid-template-columns: 1fr 1fr; }
  .qb-options.qb-scale { grid-template-columns: 1fr; }
  .qb-result-inner { padding: 36px 24px; }
}
@media (max-width: 480px) {
  .qb-options { grid-template-columns: 1fr; }
  .qb-step-title { font-size: 22px; }
}

/* ══ PRICING PAGE REDESIGN ══ */
.pricing-hero {
  min-height: 60vh;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 160px 56px 72px;
  position: relative; overflow: hidden;
}
.pricing-hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background: radial-gradient(ellipse 80% 60% at 60% 0%, rgba(200,184,154,.1) 0%, transparent 70%);
}
.pricing-hero-grid {
  position: absolute; inset: 0; z-index: 0;
  background-image: radial-gradient(circle, rgba(237,232,223,.07) 1px, transparent 1px);
  background-size: 36px 36px;
}
.pricing-hero-content { position: relative; z-index: 2; max-width: 700px; }
.pricing-hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  background: rgba(200,184,154,.1); border: 1px solid rgba(200,184,154,.2);
  border-radius: 100px; padding: 6px 16px;
  font-size: 11px; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: 28px;
  opacity: 0; animation: fadeUp .6s .1s forwards;
}
.pricing-hero-eyebrow::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); animation: pulse 2s infinite;
}
.pricing-hero-title {
  font-size: clamp(40px, 6vw, 80px); font-weight: 800;
  letter-spacing: -.04em; line-height: 1.0; color: var(--cream);
  margin-bottom: 24px;
  opacity: 0; animation: fadeUp .6s .25s forwards;
}
.pricing-hero-title em { font-style: normal; color: var(--accent); }
.pricing-hero-sub {
  font-size: 17px; line-height: 1.75; color: var(--cream); opacity: .55;
  max-width: 520px;
  opacity: 0; animation: fadeUp .6s .4s forwards;
}
.pricing-hero-scroll {
  position: absolute; bottom: 32px; right: 56px; z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  opacity: 0; animation: fadeIn 1s .8s forwards;
}
.pricing-scroll-line {
  width: 1px; height: 48px;
  background: linear-gradient(to bottom, var(--accent), transparent);
  animation: scrollLine 2s ease-in-out infinite;
}
.pricing-scroll-label {
  font-size: 10px; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--cream); opacity: .3;
  writing-mode: vertical-rl;
}
@keyframes scrollLine {
  0%, 100% { transform: scaleY(1); opacity: 1; }
  50% { transform: scaleY(.5); opacity: .3; }
}

/* QUOTE BUILDER REDESIGN */
.qb-outer {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 0;
  min-height: 600px;
  margin: 0 56px 80px;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid rgba(237,232,223,.08);
}
.qb-sidebar {
  background: var(--cream); padding: 52px 44px;
  display: flex; flex-direction: column; gap: 0;
}
.qb-sidebar-title {
  font-size: 22px; font-weight: 800; letter-spacing: -.02em;
  color: var(--ink); margin-bottom: 8px;
}
.qb-sidebar-sub {
  font-size: 14px; line-height: 1.7; color: var(--ink); opacity: .5;
  margin-bottom: 44px;
}
.qb-progress {
  display: flex; flex-direction: column; gap: 0;
  position: relative; flex: 1;
}
.qb-progress-line {
  position: absolute; left: 15px; top: 16px; bottom: 16px;
  width: 1px; background: rgba(26,26,24,.1);
}
.qb-progress-fill {
  position: absolute; left: 15px; top: 16px;
  width: 1px; background: var(--ink);
  height: 0%; transition: height .5s cubic-bezier(.16,1,.3,1);
}
.qb-prog-step {
  display: flex; align-items: flex-start; gap: 20px;
  padding: 16px 0; position: relative; z-index: 2;
}
.qb-prog-dot {
  width: 30px; height: 30px; border-radius: 50%;
  background: rgba(26,26,24,.08); border: 1.5px solid rgba(26,26,24,.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800; color: var(--ink); opacity: .4;
  flex-shrink: 0; transition: all .3s;
}
.qb-prog-step.done .qb-prog-dot {
  background: var(--ink); border-color: var(--ink);
  color: var(--cream); opacity: 1;
}
.qb-prog-step.current .qb-prog-dot {
  background: var(--accent); border-color: var(--accent);
  color: var(--ink); opacity: 1;
  box-shadow: 0 0 0 4px rgba(200,184,154,.25);
}
.qb-prog-info { padding-top: 4px; }
.qb-prog-label {
  font-size: 10px; font-weight: 700; letter-spacing: .18em;
  text-transform: uppercase; color: var(--ink); opacity: .35; margin-bottom: 2px;
}
.qb-prog-step.current .qb-prog-label,
.qb-prog-step.done .qb-prog-label { opacity: .6; }
.qb-prog-name {
  font-size: 15px; font-weight: 700; color: var(--ink); opacity: .3;
  transition: opacity .3s;
}
.qb-prog-step.current .qb-prog-name { opacity: 1; }
.qb-prog-step.done .qb-prog-name { opacity: .6; }
.qb-prog-val {
  font-size: 12px; color: var(--ink); opacity: 0;
  margin-top: 2px; transition: opacity .3s;
}
.qb-prog-step.done .qb-prog-val { opacity: .5; }

/* Quote builder main panel */
.qb-main {
  background: var(--ink-light);
  padding: 52px 48px;
  display: flex; flex-direction: column;
}
.qb-step { display: none; flex-direction: column; flex: 1; }
.qb-step.active { display: flex; animation: qbIn .4s cubic-bezier(.16,1,.3,1); }
.qb-step-label {
  font-size: 11px; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 14px;
}
.qb-step-title {
  font-size: clamp(22px, 2.5vw, 30px); font-weight: 700;
  letter-spacing: -.02em; color: var(--cream); margin-bottom: 32px; line-height: 1.2;
}
.qb-options {
  display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; margin-bottom: auto;
}
.qb-options.qb-scale { grid-template-columns: 1fr; gap: 10px; }
.qb-opt {
  background: rgba(237,232,223,.05); border: 1.5px solid rgba(237,232,223,.08);
  border-radius: var(--r); padding: 18px 20px; cursor: pointer;
  transition: all .2s; display: flex; align-items: center; gap: 14px;
  position: relative; overflow: hidden;
}
.qb-opt:hover { border-color: rgba(200,184,154,.35); background: rgba(200,184,154,.06); }
.qb-opt.selected {
  border-color: var(--accent);
  background: rgba(200,184,154,.1);
}
.qb-opt-check {
  width: 18px; height: 18px; border-radius: 50%;
  border: 1.5px solid rgba(237,232,223,.2);
  flex-shrink: 0; margin-left: auto;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.qb-opt.selected .qb-opt-check {
  background: var(--accent); border-color: var(--accent);
}
.qb-opt.selected .qb-opt-check::after {
  content: ''; width: 5px; height: 5px;
  border-radius: 50%; background: var(--ink);
}
.qb-opt-icon {
  width: 38px; height: 38px; border-radius: 10px;
  background: rgba(200,184,154,.1);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent); flex-shrink: 0;
}
.qb-opt-icon svg { width: 18px; height: 18px; }
.qb-opt-text { flex: 1; }
.qb-opt-name { font-size: 15px; font-weight: 700; color: var(--cream); line-height: 1.2; }
.qb-opt-sub { font-size: 12px; color: var(--cream); opacity: .38; margin-top: 2px; }
.qb-nav {
  display: flex; align-items: center; gap: 12px;
  margin-top: 32px; padding-top: 24px;
  border-top: 1px solid rgba(237,232,223,.07);
}
.qb-next {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ink);
  background: var(--cream); border: none;
  padding: 13px 28px; border-radius: var(--r-sm);
  cursor: pointer; transition: all .2s;
}
.qb-next:hover:not(:disabled) { background: var(--accent); }
.qb-next:disabled { opacity: .25; cursor: not-allowed; }
.qb-back {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px; font-weight: 600; letter-spacing: .08em;
  background: none; border: 1px solid rgba(237,232,223,.15);
  color: var(--cream); opacity: .45;
  padding: 12px 20px; border-radius: var(--r-sm);
  cursor: pointer; transition: opacity .2s;
}
.qb-back:hover { opacity: .9; }

/* Result state */
.qb-result-inner {
  display: flex; flex-direction: column; align-items: flex-start;
  justify-content: center; height: 100%;
  animation: qbIn .5s cubic-bezier(.16,1,.3,1);
}
.qb-result-check {
  width: 64px; height: 64px; border-radius: 50%;
  background: rgba(200,184,154,.12); border: 1.5px solid var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px; color: var(--accent); margin-bottom: 24px;
}
.qb-result-title {
  font-size: 28px; font-weight: 800; letter-spacing: -.02em;
  color: var(--cream); margin-bottom: 12px; line-height: 1.15;
}
.qb-result-sub {
  font-size: 15px; line-height: 1.75; color: var(--cream);
  opacity: .5; margin-bottom: 28px; max-width: 380px;
}
.qb-summary {
  display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px;
}
.qb-tag {
  font-size: 11px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; background: rgba(200,184,154,.15);
  color: var(--accent); border: 1px solid rgba(200,184,154,.25);
  padding: 5px 14px; border-radius: 100px;
}

/* PAYMENT TIMELINE */
.payment-timeline {
  padding: 100px 56px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center;
}
.pt-left .section-label { color: var(--accent); }
.pt-title {
  font-size: clamp(28px, 3.5vw, 48px); font-weight: 800;
  letter-spacing: -.03em; color: var(--cream); line-height: 1.1;
  margin-bottom: 16px;
}
.pt-title em { font-style: normal; color: var(--accent); }
.pt-desc {
  font-size: 15px; line-height: 1.8; color: var(--cream); opacity: .5;
  margin-bottom: 32px;
}
.pt-right { display: flex; flex-direction: column; gap: 0; }
.pt-step {
  display: flex; gap: 24px; align-items: flex-start;
  padding: 24px 0;
  border-bottom: 1px solid rgba(237,232,223,.07);
  opacity: 0; transform: translateX(20px);
  transition: opacity .5s ease, transform .5s ease;
}
.pt-step:first-child { padding-top: 0; }
.pt-step:last-child { border-bottom: none; }
.pt-step.visible { opacity: 1; transform: translateX(0); }
.pt-step-num {
  width: 40px; height: 40px; border-radius: 12px;
  background: rgba(200,184,154,.1); border: 1px solid rgba(200,184,154,.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800; color: var(--accent);
  flex-shrink: 0;
}
.pt-step-name {
  font-size: 16px; font-weight: 700; letter-spacing: -.01em;
  color: var(--cream); margin-bottom: 4px;
}
.pt-step-desc {
  font-size: 13px; line-height: 1.7; color: var(--cream); opacity: .45;
}

/* FAQ strip */
.faq-strip {
  padding: 0 56px 100px;
}
.faq-title {
  font-size: clamp(24px,3vw,40px); font-weight: 800;
  letter-spacing: -.03em; color: var(--cream);
  margin-bottom: 36px;
}
.faq-title em { font-style: normal; color: var(--accent); }
.faq-list { display: flex; flex-direction: column; gap: 0; max-width: 700px; }
.faq-item {
  border-top: 1px solid rgba(237,232,223,.08);
  overflow: hidden;
}
.faq-item:last-child { border-bottom: 1px solid rgba(237,232,223,.08); }
.faq-q {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 0; cursor: pointer; gap: 24px;
  font-size: 16px; font-weight: 700; color: var(--cream);
  transition: color .2s; user-select: none;
}
.faq-q:hover { color: var(--accent); }
.faq-icon {
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(237,232,223,.06); border: 1px solid rgba(237,232,223,.1);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; color: var(--cream); flex-shrink: 0;
  transition: transform .3s, background .2s;
}
.faq-item.open .faq-icon { transform: rotate(45deg); background: rgba(200,184,154,.15); }
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height .4s cubic-bezier(.16,1,.3,1), padding .3s;
  font-size: 14px; line-height: 1.8; color: var(--cream); opacity: .5;
}
.faq-item.open .faq-a { max-height: 200px; padding-bottom: 22px; }

/* Responsive */
@media (max-width: 1024px) {
  .qb-outer { grid-template-columns: 1fr; margin: 0 28px 64px; }
  .qb-sidebar { padding: 36px 32px; }
  .qb-progress { flex-direction: row; gap: 0; }
  .qb-progress-line, .qb-progress-fill { display: none; }
  .qb-prog-step { flex-direction: column; align-items: center; flex: 1; text-align: center; padding: 0; }
  .qb-prog-info { padding-top: 8px; }
  .qb-prog-label { font-size: 9px; }
  .qb-prog-name { font-size: 12px; }
  .qb-main { padding: 36px 32px; }
  .pricing-hero { padding: 140px 28px 60px; }
  .pricing-hero-scroll { display: none; }
  .payment-timeline { grid-template-columns: 1fr; gap: 48px; padding: 72px 28px; }
  .faq-strip { padding: 0 28px 72px; }
}
@media (max-width: 640px) {
  .qb-outer { margin: 0 18px 48px; }
  .qb-sidebar { padding: 28px 22px; }
  .qb-main { padding: 28px 22px; }
  .qb-options { grid-template-columns: 1fr; }
  .pricing-hero { padding: 120px 18px 48px; }
  .payment-timeline { padding: 56px 18px; }
  .faq-strip { padding: 0 18px 56px; }
  .qb-sidebar-title { font-size: 18px; }
}

/* ══ PRICING PAGE v2 ══ */
.pr-hero { min-height:55vh;display:flex;flex-direction:column;justify-content:flex-end;padding:160px 56px 64px;position:relative;overflow:hidden; }
.pr-hero-bg { position:absolute;inset:0;background:radial-gradient(ellipse 100% 80% at 70% -10%,rgba(200,184,154,.12) 0%,transparent 65%),radial-gradient(ellipse 60% 50% at 10% 100%,rgba(200,184,154,.06) 0%,transparent 60%); }
.pr-hero-dots { position:absolute;inset:0;background-image:radial-gradient(circle,rgba(237,232,223,.07) 1px,transparent 1px);background-size:32px 32px; }
.pr-hero-inner { position:relative;z-index:2; }
.pr-hero-pill { display:inline-flex;align-items:center;gap:8px;background:rgba(200,184,154,.1);border:1px solid rgba(200,184,154,.2);border-radius:100px;padding:6px 16px;margin-bottom:24px;font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);opacity:0;animation:fadeUp .5s .1s forwards; }
.pr-hero-pill span { width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite; }
.pr-hero-h1 { font-size:clamp(42px,6vw,84px);font-weight:800;letter-spacing:-.04em;line-height:1.0;color:var(--cream);margin-bottom:20px;opacity:0;animation:fadeUp .5s .2s forwards; }
.pr-hero-h1 em { font-style:normal;color:var(--accent); }
.pr-hero-sub { font-size:17px;line-height:1.75;color:var(--cream);opacity:0;animation:fadeUp .5s .35s forwards;max-width:560px; }
.pr-hero-sub span { opacity:.5; }

/* SERVICE PICKER */
.svc-picker-wrap { padding:0 56px; }
.svc-picker-hd { display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:16px; }
.svc-picker-title { font-size:clamp(22px,2.8vw,36px);font-weight:800;letter-spacing:-.03em;color:var(--cream);line-height:1.1; }
.svc-picker-title em { font-style:normal;color:var(--accent); }
.svc-picker-hint { font-size:13px;color:var(--cream);opacity:.4;font-weight:500; }
.svc-picker-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px; }
.sp-card { background:var(--ink-light);border:1.5px solid rgba(237,232,223,.07);border-radius:var(--r);padding:24px 22px;cursor:pointer;transition:border-color .2s,background .2s,transform .2s;position:relative;user-select:none; }
.sp-card:hover { border-color:rgba(200,184,154,.3);transform:translateY(-3px); }
.sp-card.selected { border-color:var(--accent);background:rgba(200,184,154,.07); }
.sp-card-check { position:absolute;top:14px;right:14px;width:20px;height:20px;border-radius:6px;border:1.5px solid rgba(237,232,223,.2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;transition:all .2s; }
.sp-card.selected .sp-card-check { background:var(--accent);border-color:var(--accent);color:var(--ink); }
.sp-card-icon { width:40px;height:40px;border-radius:11px;background:rgba(200,184,154,.1);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:16px; }
.sp-card-icon svg { width:20px;height:20px; }
.sp-card-name { font-size:15px;font-weight:800;letter-spacing:-.01em;color:var(--cream);margin-bottom:5px; }
.sp-card.selected .sp-card-name { color:var(--accent); }
.sp-card-desc { font-size:12px;line-height:1.6;color:var(--cream);opacity:.4; }
.sp-card-badge { display:inline-block;margin-top:10px;font-size:9px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:var(--accent);border-radius:4px;padding:2px 8px; }
.svc-summary-bar { background:var(--ink-light);border:1px solid rgba(237,232,223,.1);border-radius:var(--r);padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;transition:border-color .3s;margin-bottom:64px;margin-top:4px; }
.svc-summary-bar.has-selection { border-color:rgba(200,184,154,.25); }
.svc-summary-left { display:flex;align-items:center;gap:12px;flex-wrap:wrap;flex:1; }
.svc-summary-label { font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--cream);opacity:.4;white-space:nowrap; }
.svc-selected-tags { display:flex;flex-wrap:wrap;gap:6px; }
.svc-stag { font-size:11px;font-weight:700;color:var(--accent);background:rgba(200,184,154,.1);border:1px solid rgba(200,184,154,.2);border-radius:100px;padding:4px 12px;animation:fadeUp .2s ease; }
.svc-summary-empty { font-size:13px;color:var(--cream);opacity:.3; }
.svc-summary-cta { font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);background:rgba(237,232,223,.3);border:none;padding:11px 22px;border-radius:var(--r-sm);cursor:pointer;transition:background .2s,transform .2s;white-space:nowrap; }
.svc-summary-bar.has-selection .svc-summary-cta { background:var(--accent); }
.svc-summary-cta:hover { background:var(--cream-dark);transform:translateY(-1px); }

/* REDESIGN BANNER */
.redesign-banner { margin:0 56px 72px;background:var(--cream);border-radius:var(--r-lg);padding:52px 56px;display:flex;align-items:center;gap:48px;position:relative;overflow:hidden; }
.redesign-banner::before { content:'REDESIGN';position:absolute;right:-20px;top:50%;transform:translateY(-50%);font-size:130px;font-weight:800;letter-spacing:-.05em;color:rgba(26,26,24,.05);line-height:1;pointer-events:none; }
.redesign-left { flex:1;position:relative;z-index:2; }
.redesign-badge { display:inline-block;font-size:10px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);background:var(--ink);padding:5px 14px;border-radius:100px;margin-bottom:16px; }
.redesign-title { font-size:clamp(22px,3vw,36px);font-weight:800;letter-spacing:-.03em;color:var(--ink);line-height:1.1;margin-bottom:12px; }
.redesign-desc { font-size:14px;color:var(--ink);opacity:.55;line-height:1.7;max-width:420px; }
.redesign-right { flex-shrink:0;position:relative;z-index:2;display:flex;flex-direction:column;gap:14px;align-items:flex-end; }
.redesign-discount { font-size:44px;font-weight:800;letter-spacing:-.04em;color:var(--ink);line-height:1; }
.redesign-discount span { font-size:18px;opacity:.5;font-weight:400; }
.redesign-disc-label { font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--ink);opacity:.4; }
.redesign-btn { font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--cream);background:var(--ink);border:none;padding:13px 24px;border-radius:var(--r-sm);cursor:pointer;transition:all .2s; }
.redesign-btn:hover { background:var(--ink-light);transform:translateY(-2px); }

/* HOSTING */
.hosting-section { padding:80px 56px;background:linear-gradient(160deg,#0d0d0c 0%,var(--ink-light) 100%);position:relative;overflow:hidden; }
.hosting-section::before { content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(200,184,154,.05) 1px,transparent 1px);background-size:28px 28px; }
.hosting-inner { position:relative;z-index:2; }
.hosting-hd { margin-bottom:44px; }
.hosting-title { font-size:clamp(28px,3.5vw,48px);font-weight:800;letter-spacing:-.03em;color:var(--cream);line-height:1.1;margin-bottom:12px; }
.hosting-title em { font-style:normal;color:var(--accent); }
.hosting-sub { font-size:15px;color:var(--cream);opacity:.45;line-height:1.7;max-width:520px; }
.hosting-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:16px; }
.host-card { background:rgba(237,232,223,.04);border:1px solid rgba(237,232,223,.08);border-radius:var(--r-lg);padding:32px 28px;display:flex;flex-direction:column;transition:border-color .3s,transform .3s;position:relative;overflow:hidden; }
.host-card:hover { border-color:rgba(200,184,154,.25);transform:translateY(-4px); }
.host-card.featured { border-color:rgba(200,184,154,.3);background:rgba(200,184,154,.06); }
.host-card-top-badge { position:absolute;top:0;left:50%;transform:translateX(-50%);background:var(--accent);color:var(--ink);font-size:9px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;padding:4px 16px;border-radius:0 0 10px 10px; }
.host-icon { width:44px;height:44px;border-radius:12px;background:rgba(200,184,154,.1);border:1px solid rgba(200,184,154,.15);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:20px; }
.host-icon svg { width:22px;height:22px; }
.host-name { font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--cream);margin-bottom:6px; }
.host-tagline { font-size:13px;color:var(--cream);opacity:.45;margin-bottom:22px;line-height:1.5; }
.host-features { list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:24px;flex:1; }
.host-features li { display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--cream);opacity:.65;line-height:1.5; }
.host-features li::before { content:'✓';font-size:11px;font-weight:900;color:var(--accent);flex-shrink:0;margin-top:1px; }
.host-cta { font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-align:center;color:var(--cream);border:1px solid rgba(237,232,223,.2);background:none;padding:12px;border-radius:var(--r-sm);cursor:pointer;transition:all .2s;width:100%; }
.host-card.featured .host-cta { background:var(--accent);color:var(--ink);border-color:var(--accent); }
.host-cta:hover { border-color:rgba(237,232,223,.6); }
.host-card.featured .host-cta:hover { background:var(--cream); }

/* INSTALLMENTS */
.install-section { padding:80px 56px;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center; }
.install-title { font-size:clamp(28px,3.5vw,48px);font-weight:800;letter-spacing:-.03em;color:var(--cream);line-height:1.1;margin-bottom:16px; }
.install-title em { font-style:normal;color:var(--accent); }
.install-desc { font-size:15px;line-height:1.8;color:var(--cream);opacity:.5;margin-bottom:28px; }
.install-right { display:flex;flex-direction:column;gap:10px; }
.install-card { background:var(--ink-light);border:1px solid rgba(237,232,223,.07);border-radius:var(--r);padding:20px 22px;display:flex;align-items:center;gap:18px;transition:border-color .2s,transform .2s;cursor:default; }
.install-card:hover { border-color:rgba(200,184,154,.25);transform:translateX(4px); }
.install-card.highlight { border-color:rgba(200,184,154,.25);background:rgba(200,184,154,.06); }
.install-num { font-size:26px;font-weight:800;letter-spacing:-.04em;color:var(--accent);line-height:1;flex-shrink:0;width:40px; }
.install-name { font-size:15px;font-weight:700;color:var(--cream);margin-bottom:3px; }
.install-desc2 { font-size:12px;color:var(--cream);opacity:.4;line-height:1.5; }
.install-arrow { margin-left:auto;color:var(--cream);opacity:.2;font-size:18px;transition:opacity .2s,transform .2s; }
.install-card:hover .install-arrow { opacity:.6;transform:translateX(4px); }

/* PAYMENT PROCESS */
.payment-timeline { padding:80px 56px;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;background:var(--cream); }
.pt-left .section-label { color:var(--ink-muted); }
.pt-title { font-size:clamp(28px,3.5vw,48px);font-weight:800;letter-spacing:-.03em;color:var(--ink);line-height:1.1;margin-bottom:16px; }
.pt-title em { font-style:normal;color:var(--ink-muted); }
.pt-desc { font-size:15px;color:var(--ink);opacity:.5;line-height:1.8;margin-bottom:28px; }
.pt-right { display:flex;flex-direction:column; }
.pt-step { display:flex;align-items:flex-start;gap:20px;padding:22px 0;border-bottom:1px solid rgba(26,26,24,.08); }
.pt-step:last-child { border-bottom:none; }
.pt-step-num { width:38px;height:38px;border-radius:10px;background:rgba(26,26,24,.08);border:1px solid rgba(26,26,24,.12);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:var(--ink);flex-shrink:0; }
.pt-step-name { font-size:15px;font-weight:700;color:var(--ink);margin-bottom:4px; }
.pt-step-desc { font-size:13px;color:var(--ink);opacity:.5;line-height:1.6; }

/* FAQ v2 */
.faq-strip { padding:80px 56px; }
.faq-main-title { font-size:clamp(28px,3.5vw,48px);font-weight:800;letter-spacing:-.03em;color:var(--cream);margin-bottom:36px;line-height:1.1; }
.faq-main-title em { font-style:normal;color:var(--accent); }
.faq-list { display:flex;flex-direction:column;max-width:720px; }

/* Responsive */
@media(max-width:1024px){
  .pr-hero{padding:140px 28px 56px;}
  .svc-picker-wrap{padding:0 28px;}
  .svc-picker-grid{grid-template-columns:repeat(2,1fr);}
  .hosting-section{padding:60px 28px;}
  .hosting-grid{grid-template-columns:1fr;}
  .install-section{grid-template-columns:1fr;gap:40px;padding:60px 28px;}
  .redesign-banner{margin:0 28px 60px;padding:36px 32px;flex-direction:column;gap:28px;align-items:flex-start;}
  .redesign-banner::before{display:none;}
  .redesign-right{align-items:flex-start;}
  .payment-timeline{grid-template-columns:1fr;gap:40px;padding:60px 28px;}
  .faq-strip{padding:60px 28px;}
  .svc-summary-bar{margin-bottom:48px;}
}
@media(max-width:640px){
  .pr-hero{padding:120px 18px 48px;}
  .svc-picker-wrap{padding:0 18px;}
  .svc-picker-grid{grid-template-columns:1fr;}
  .hosting-section{padding:48px 18px;}
  .install-section{padding:48px 18px;}
  .redesign-banner{margin:0 18px 48px;padding:28px 22px;}
  .payment-timeline{padding:48px 18px;}
  .faq-strip{padding:48px 18px;}
  .redesign-discount{font-size:36px;}
}

/* ══ AUTOMATION DEEP-DIVE ══ */
.auto-section {
  padding: 100px 56px;
  border-top: 1px solid rgba(237,232,223,.07);
}
.auto-section-top {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: start; margin-bottom: 72px;
}
.auto-eyebrow {
  font-size: 11px; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: var(--accent); margin-bottom: 14px;
}
.auto-title {
  font-size: clamp(28px,3.5vw,48px); font-weight: 800;
  letter-spacing: -.03em; color: var(--cream); line-height: 1.1; margin-bottom: 16px;
}
.auto-title em { font-style: normal; color: var(--accent); }
.auto-desc { font-size: 15px; line-height: 1.8; color: var(--cream); opacity: .55; margin-bottom: 24px; }

/* Animated workflow canvas */
.auto-visual {
  background: #0d0d0c; border-radius: var(--r-lg);
  border: 1px solid rgba(237,232,223,.07);
  padding: 32px; position: relative; overflow: hidden;
  min-height: 320px;
}
.auto-visual-grid {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(237,232,223,.06) 1px, transparent 1px);
  background-size: 24px 24px; border-radius: var(--r-lg);
}
.auto-visual-glow {
  position: absolute; top: -40%; left: 20%;
  width: 60%; height: 80%;
  background: radial-gradient(ellipse, rgba(200,184,154,.08) 0%, transparent 70%);
  pointer-events: none;
}
.auto-nodes-wrap {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; gap: 0; align-items: flex-start;
}
.auto-flow-node {
  display: flex; align-items: center; gap: 12px;
  background: rgba(30,29,27,.92); border: 1px solid rgba(237,232,223,.1);
  border-radius: 12px; padding: 12px 18px;
  width: 100%;
  animation: nodeSlideIn .5s cubic-bezier(.16,1,.3,1) both;
}
.auto-flow-node:nth-child(1) { animation-delay: .1s; }
.auto-flow-node:nth-child(3) { animation-delay: .3s; margin-left: 24px; width: calc(100% - 24px); }
.auto-flow-node:nth-child(5) { animation-delay: .5s; margin-left: 48px; width: calc(100% - 48px); }
.auto-flow-node:nth-child(7) { animation-delay: .7s; margin-left: 24px; width: calc(100% - 24px); }
.auto-flow-node:nth-child(9) { animation-delay: .9s; }
@keyframes nodeSlideIn {
  from { opacity: 0; transform: translateX(-12px); }
  to   { opacity: 1; transform: translateX(0); }
}
.auto-node-dot {
  width: 8px; height: 8px; border-radius: 50%;
  flex-shrink: 0; animation: nodeBlink 2s ease-in-out infinite;
}
.auto-flow-node:nth-child(1) .auto-node-dot { background: #60a5fa; animation-delay: 0s; }
.auto-flow-node:nth-child(3) .auto-node-dot { background: var(--accent); animation-delay: .3s; }
.auto-flow-node:nth-child(5) .auto-node-dot { background: #a78bfa; animation-delay: .6s; }
.auto-flow-node:nth-child(7) .auto-node-dot { background: var(--accent); animation-delay: .9s; }
.auto-flow-node:nth-child(9) .auto-node-dot { background: #4ade80; animation-delay: 1.2s; }
@keyframes nodeBlink {
  0%, 100% { opacity: 1; }
  50% { opacity: .3; }
}
.auto-node-label {
  font-size: 12px; font-weight: 600; color: var(--cream); opacity: .75; flex: 1;
}
.auto-node-badge {
  font-size: 9px; font-weight: 800; letter-spacing: .1em;
  text-transform: uppercase; padding: 3px 8px; border-radius: 4px;
}
.badge-trigger { background: rgba(96,165,250,.15); color: #60a5fa; }
.badge-ai     { background: rgba(167,139,250,.15); color: #a78bfa; }
.badge-action { background: rgba(200,184,154,.15); color: var(--accent); }
.badge-done   { background: rgba(74,222,128,.15); color: #4ade80; }

/* Connector lines between nodes */
.auto-connector {
  display: flex; align-items: center; padding: 4px 0 4px 18px;
}
.auto-connector-line {
  width: 1px; height: 18px; background: rgba(237,232,223,.12);
  margin-left: 15px;
  position: relative; overflow: hidden;
}
.auto-connector-line::after {
  content: ''; position: absolute; top: -100%; left: 0; right: 0;
  height: 100%; background: var(--accent);
  animation: flowDown 2s ease-in-out infinite;
}
.auto-flow-node:nth-child(1) ~ .auto-connector:nth-child(2) .auto-connector-line::after { animation-delay: 0s; }
.auto-flow-node:nth-child(3) ~ .auto-connector:nth-child(4) .auto-connector-line::after { animation-delay: .4s; }
.auto-flow-node:nth-child(5) ~ .auto-connector:nth-child(6) .auto-connector-line::after { animation-delay: .8s; }
.auto-flow-node:nth-child(7) ~ .auto-connector:nth-child(8) .auto-connector-line::after { animation-delay: 1.2s; }
@keyframes flowDown {
  0% { top: -100%; }
  100% { top: 100%; }
}

/* What we automate grid */
.auto-what-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 12px;
  margin-bottom: 64px;
}
.auto-what-card {
  background: var(--ink-light); border: 1px solid rgba(237,232,223,.07);
  border-radius: var(--r); padding: 24px 22px;
  transition: border-color .2s, transform .2s;
}
.auto-what-card:hover { border-color: rgba(200,184,154,.25); transform: translateY(-3px); }
.auto-what-icon {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(200,184,154,.1); display: flex;
  align-items: center; justify-content: center;
  color: var(--accent); margin-bottom: 14px;
}
.auto-what-icon svg { width: 18px; height: 18px; }
.auto-what-name { font-size: 15px; font-weight: 700; color: var(--cream); margin-bottom: 6px; }
.auto-what-desc { font-size: 13px; line-height: 1.65; color: var(--cream); opacity: .45; }

/* Benefits strip */
.auto-benefits {
  display: grid; grid-template-columns: repeat(5,1fr);
  gap: 0; background: rgba(200,184,154,.06);
  border: 1px solid rgba(200,184,154,.15);
  border-radius: var(--r-lg); overflow: hidden;
  margin-bottom: 64px;
}
.auto-benefit {
  padding: 28px 24px; border-right: 1px solid rgba(200,184,154,.12);
  text-align: center;
}
.auto-benefit:last-child { border-right: none; }
.auto-benefit-num {
  font-size: 28px; font-weight: 800; letter-spacing: -.03em;
  color: var(--accent); line-height: 1; margin-bottom: 6px;
}
.auto-benefit-label {
  font-size: 12px; font-weight: 600; color: var(--cream); opacity: .5; line-height: 1.4;
}

/* How we automate - 4 steps */
.auto-steps {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 14px;
}
.auto-step {
  background: var(--ink-light); border-radius: var(--r);
  padding: 28px 22px; position: relative;
}
.auto-step-num {
  font-size: 40px; font-weight: 800; color: var(--cream);
  opacity: .07; line-height: 1; margin-bottom: 16px; letter-spacing: -.03em;
}
.auto-step-name { font-size: 15px; font-weight: 700; color: var(--cream); margin-bottom: 8px; }
.auto-step-desc { font-size: 13px; line-height: 1.7; color: var(--cream); opacity: .45; }
.auto-step-arrow {
  position: absolute; top: 32px; right: -8px;
  font-size: 16px; color: var(--accent); opacity: .4; z-index: 2;
}
.auto-step:last-child .auto-step-arrow { display: none; }

/* Free audit banner */
.auto-audit-banner {
  margin-top: 48px; background: var(--accent);
  border-radius: var(--r-lg); padding: 36px 44px;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  flex-wrap: wrap;
}
.auto-audit-text .section-label { color: var(--ink); opacity: .6; }
.auto-audit-title {
  font-size: clamp(20px,2.5vw,30px); font-weight: 800;
  letter-spacing: -.02em; color: var(--ink); line-height: 1.2;
}
.auto-audit-sub { font-size: 14px; color: var(--ink); opacity: .55; margin-top: 6px; }
.auto-audit-btn {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--cream);
  background: var(--ink); border: none;
  padding: 15px 32px; border-radius: var(--r-sm);
  cursor: pointer; transition: all .2s; white-space: nowrap;
}
.auto-audit-btn:hover { background: var(--ink-light); transform: translateY(-2px); }

@media (max-width: 1024px) {
  .auto-section { padding: 72px 28px; }
  .auto-section-top { grid-template-columns: 1fr; gap: 40px; }
  .auto-what-grid { grid-template-columns: 1fr 1fr; }
  .auto-benefits { grid-template-columns: 1fr 1fr 1fr; }
  .auto-benefit:nth-child(3) { border-right: none; }
  .auto-benefit:nth-child(4),
  .auto-benefit:nth-child(5) { border-top: 1px solid rgba(200,184,154,.12); }
  .auto-steps { grid-template-columns: 1fr 1fr; }
  .auto-step-arrow { display: none; }
  .auto-audit-banner { padding: 28px 32px; }
}
@media (max-width: 640px) {
  .auto-section { padding: 56px 18px; }
  .auto-what-grid { grid-template-columns: 1fr; }
  .auto-benefits { grid-template-columns: 1fr 1fr; }
  .auto-benefit:nth-child(2) { border-right: none; }
  .auto-benefit:nth-child(3),
  .auto-benefit:nth-child(4),
  .auto-benefit:nth-child(5) { border-top: 1px solid rgba(200,184,154,.12); }
  .auto-steps { grid-template-columns: 1fr; }
  .auto-audit-banner { flex-direction: column; padding: 24px 22px; }
}

/* ══ WORKFLOW ANIMATION (HOME) ══ */
.wf-section {
  padding: 100px 56px;
  background: #080807;
  position: relative; overflow: hidden;
}
.wf-bg-glow {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 60% 50% at 80% 20%, rgba(200,184,154,.09) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 20% 80%, rgba(200,184,154,.06) 0%, transparent 60%);
}
.wf-inner { position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.2fr;gap:72px;align-items:center; }
.wf-eyebrow { font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:14px; }
.wf-title { font-size:clamp(28px,3.5vw,48px);font-weight:800;letter-spacing:-.03em;color:var(--cream);line-height:1.08;margin-bottom:16px; }
.wf-title em { font-style:normal;color:var(--accent); }
.wf-desc { font-size:15px;line-height:1.8;color:var(--cream);opacity:.5;margin-bottom:28px; }
.wf-stats { display:flex;gap:28px;margin-bottom:32px;flex-wrap:wrap; }
.wf-stat-num { font-size:30px;font-weight:800;letter-spacing:-.04em;color:var(--cream);line-height:1; }
.wf-stat-num em { font-style:normal;color:var(--accent); }
.wf-stat-label { font-size:11px;color:var(--cream);opacity:.4;margin-top:3px; }
.wf-flow-wrap { background:#0e0e0c;border:1px solid rgba(237,232,223,.07);border-radius:var(--r-lg);padding:28px 24px;position:relative;overflow:hidden; }
.wf-canvas-bg { position:absolute;inset:0;background-image:radial-gradient(circle,rgba(237,232,223,.05) 1px,transparent 1px);background-size:24px 24px;border-radius:var(--r-lg);pointer-events:none; }
.wf-flow { position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:0; }
.wf-row { display:flex;justify-content:center;width:100%; }
.wf-row-split { display:flex;justify-content:space-between;gap:12px; }
.wf-row-split .wf-node { flex:1; }
.wf-node { display:flex;align-items:center;gap:10px;background:rgba(26,25,22,.95);border:1px solid rgba(237,232,223,.09);border-radius:12px;padding:11px 14px;opacity:0;animation:wfIn .5s cubic-bezier(.16,1,.3,1) both;transition:border-color .3s; }
.wf-node:hover { border-color:rgba(200,184,154,.3); }
.wf-node-trigger { border-color:rgba(96,165,250,.2); }
.wf-node-done { border-color:rgba(74,222,128,.2); }
@keyframes wfIn { from{opacity:0;transform:translateY(8px) scale(.97)} to{opacity:1;transform:none} }
.wf-node-ico { width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.wf-node-title { font-size:12px;font-weight:700;color:var(--cream);line-height:1.3; }
.wf-node-sub { font-size:10px;color:var(--cream);opacity:.38;margin-top:2px; }
.wf-pulse { width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-left:auto;animation:wfPulse 2s ease-in-out infinite; }
@keyframes wfPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.25;transform:scale(.7)} }
.wf-conn-v { display:flex;justify-content:center;width:100%;height:24px; }
.wf-conn-line { width:2px;height:100%;background:linear-gradient(to bottom,var(--clr,rgba(200,184,154,.6)) 0%,transparent 100%);border-radius:2px;position:relative;overflow:hidden; }
.wf-conn-anim::after { content:'';position:absolute;top:-50%;left:0;right:0;height:50%;background:rgba(255,255,255,.7);border-radius:2px;animation:connFlow 1.8s ease-in-out infinite;animation-delay:var(--d,0s); }
@keyframes connFlow { 0%{top:-50%;opacity:.8} 100%{top:150%;opacity:0} }
.wf-conn-h { width:100%;height:1px;position:relative;margin:0; }
.wf-conn-branch { position:absolute;left:15%;right:15%;top:0;height:1px;background:rgba(237,232,223,.12); }

/* GROWTH */
/* Revenue / visibility growth section */
.growth-section {
  padding: 100px 56px;
  background: var(--ink);
  position: relative; overflow: hidden;
}
.growth-bg-text {
  position: absolute; top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-size:200px;font-weight:800;
  color:rgba(237,232,223,.03);white-space:nowrap;pointer-events:none;
  letter-spacing:-.05em;
}
.growth-inner { position:relative;z-index:2; }
.growth-hd { text-align:center;margin-bottom:64px; }
.growth-hd .section-label { color:var(--accent); }
.growth-title { font-size:clamp(28px,4vw,54px);font-weight:800;letter-spacing:-.03em;color:var(--cream);line-height:1.08; }
.growth-title em { font-style:normal;color:var(--accent); }
.growth-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:16px; }
.growth-card {
  background:var(--ink-light);border-radius:var(--r-lg);
  padding:36px 32px;position:relative;overflow:hidden;
  border:1px solid rgba(237,232,223,.07);
  transition:transform .3s, border-color .3s;
}
.growth-card:hover { transform:translateY(-5px); border-color:rgba(200,184,154,.2); }
.growth-card-glow {
  position:absolute;top:-30%;right:-20%;
  width:200px;height:200px;border-radius:50%;
  filter:blur(60px);opacity:.1;pointer-events:none;
}
.growth-card-icon {
  width:48px;height:48px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;position:relative;z-index:2;
}
.growth-card-icon svg { width:24px;height:24px; }
.growth-card-num {
  font-size:52px;font-weight:800;letter-spacing:-.04em;
  color:var(--cream);line-height:1;margin-bottom:6px;
  position:relative;z-index:2;
}
.growth-card-num span { font-size:24px;opacity:.5;font-weight:400; }
.growth-card-title { font-size:17px;font-weight:700;color:var(--cream);margin-bottom:8px;position:relative;z-index:2; }
.growth-card-desc { font-size:13px;line-height:1.75;color:var(--cream);opacity:.45;position:relative;z-index:2; }

/* Chart bar inside growth card */
.growth-chart { display:flex;align-items:flex-end;gap:4px;height:48px;margin-top:20px;position:relative;z-index:2; }
.growth-bar {
  flex:1;border-radius:3px 3px 0 0;
  animation:growBar .8s ease both;transform-origin:bottom;
}
@keyframes growBar { from{transform:scaleY(0)} to{transform:scaleY(1)} }
.growth-bar:nth-child(1){animation-delay:.1s}
.growth-bar:nth-child(2){animation-delay:.15s}
.growth-bar:nth-child(3){animation-delay:.2s}
.growth-bar:nth-child(4){animation-delay:.25s}
.growth-bar:nth-child(5){animation-delay:.3s}
.growth-bar:nth-child(6){animation-delay:.35s}
.growth-bar:nth-child(7){animation-delay:.4s}

/* Visibility ring animation */
.visibility-ring {
  width:80px;height:80px;position:relative;margin-top:20px;
}
.vring-svg { width:100%;height:100%; }
.vring-bg { fill:none;stroke:rgba(237,232,223,.1);stroke-width:4; }
.vring-fill {
  fill:none;stroke-width:4;stroke-linecap:round;
  stroke-dasharray:188;stroke-dashoffset:188;
  animation:ringFill 2s 1s cubic-bezier(.16,1,.3,1) forwards;
}
@keyframes ringFill { to{stroke-dashoffset:0} }

@media(max-width:1024px){
  .wf-section{padding:72px 28px;}
  .wf-inner{grid-template-columns:1fr;gap:48px;}
  .wf-canvas{min-height:420px;}
  .growth-section{padding:72px 28px;}
  .growth-grid{grid-template-columns:1fr;}
}
@media(max-width:640px){
  .wf-section{padding:56px 18px;}
  .wf-canvas{min-height:360px;}
  .growth-section{padding:56px 18px;}
  .wf-stats{gap:20px;}
}

.svc-row-tags { display:flex;flex-wrap:wrap;gap:7px;margin-top:16px; }
.svc-row-tags span {
  font-size:11px;font-weight:700;letter-spacing:.08em;
  color:var(--cream);opacity:.5;
  border:1px solid rgba(237,232,223,.15);
  border-radius:100px;padding:4px 12px;
}

/* ══ ABOUT VISUAL ══ */
.af-visual {
  position: relative;
  height: 480px;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: #0e0e0c;
  border: 1px solid rgba(237,232,223,.07);
}
.af-bg {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(237,232,223,.06) 1px, transparent 1px);
  background-size: 28px 28px;
}
.af-watermark {
  position: absolute; bottom: -40px; right: -20px;
  font-size: 260px; font-weight: 800; letter-spacing: -.05em;
  color: rgba(237,232,223,.04); line-height: 1;
  pointer-events: none; user-select: none;
}
.af-cards {
  position: relative; z-index: 2;
  padding: 28px; display: flex; flex-direction: column; gap: 12px;
}
.af-card {
  display: flex; align-items: center; gap: 14px;
  background: rgba(26,25,22,.9);
  border: 1px solid rgba(237,232,223,.08);
  border-radius: 14px; padding: 14px 18px;
  opacity: 0; animation: wfIn .5s cubic-bezier(.16,1,.3,1) both;
  transition: border-color .25s;
}
.af-card:hover { border-color: rgba(200,184,154,.25); }
.af-card-1 { animation-delay: .15s; }
.af-card-2 { animation-delay: .3s; margin-left: 16px; }
.af-card-3 { animation-delay: .45s; margin-left: 32px; }
.af-card-4 { animation-delay: .6s; margin-left: 16px; }
.af-card-icon {
  width: 36px; height: 36px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.af-card-num {
  font-size: 20px; font-weight: 800; letter-spacing: -.03em;
  color: var(--cream); line-height: 1;
}
.af-card-lbl {
  font-size: 11px; color: var(--cream); opacity: .4; margin-top: 2px;
}
.af-card-badge {
  margin-left: auto; font-size: 14px; font-weight: 900;
  color: var(--accent); flex-shrink: 0;
}
.af-tag {
  display: inline-block;
  font-size: 10px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--accent);
  background: rgba(200,184,154,.08); border: 1px solid rgba(200,184,154,.18);
  border-radius: 100px; padding: 5px 14px;
  opacity: 0; animation: wfIn .5s cubic-bezier(.16,1,.3,1) both;
}
.af-tag-1 { animation-delay: .75s; }
.af-tag-2 { animation-delay: .88s; margin-left: 8px; }
.af-tag-3 { animation-delay: 1s; margin-left: 8px; }
.af-cards .af-tag { display: inline-block; }
/* Tag row wrapper */
.af-cards > .af-tag { display: inline; }

@media (max-width: 1024px) {
  .af-visual { height: 360px; }
  .af-watermark { font-size: 180px; }
  .af-card-2, .af-card-3, .af-card-4 { margin-left: 0; }
}
@media (max-width: 640px) {
  .af-visual { height: auto; padding-bottom: 16px; }
  .af-watermark { display: none; }
}

/* ══ HERO VISUAL — clean ══ */
.hv-brand {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -52%);
  display: flex; flex-direction: column;
  align-items: center; gap: 16px;
  z-index: 3;
  opacity: 0; animation: fadeIn .8s .4s forwards;
}
.hv-brand-logo {
  display: flex; align-items: center; gap: 10px;
}
.hv-logo-mark {
  display: flex; align-items: center; gap: 4px;
}
.hv-logo-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--cream); margin-bottom: 2px;
}
.hv-logo-n {
  font-size: 32px; font-weight: 800;
  color: var(--cream); letter-spacing: -.03em;
  line-height: 1; position: relative;
}
.hv-logo-n::after {
  content: ''; position: absolute;
  right: -9px; top: 3px; bottom: 3px;
  width: 1px; background: var(--cream); opacity: .3;
}
.hv-logo-word {
  font-size: 18px; font-weight: 700;
  letter-spacing: .3em; color: var(--cream);
  padding-left: 10px; text-transform: uppercase; opacity: .9;
}
.hv-brand-line {
  width: 40px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.hv-brand-tag {
  font-size: 10px; font-weight: 700; letter-spacing: .28em;
  text-transform: uppercase; color: var(--cream); opacity: .35;
}
.hv-glow {
  position: absolute; top: 30%; left: 50%;
  transform: translate(-50%, -50%);
  width: 280px; height: 280px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(200,184,154,.1) 0%, transparent 70%);
  pointer-events: none; z-index: 1;
}

/* Service pills */
.hv-pill {
  position: absolute; z-index: 4;
  display: flex; align-items: center; gap: 8px;
  background: rgba(20,19,17,.85);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(237,232,223,.1);
  border-radius: 100px;
  padding: 8px 16px 8px 12px;
  font-size: 12px; font-weight: 600;
  color: var(--cream); white-space: nowrap;
  opacity: 0;
}
.hv-pill-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
  animation: wfPulse 2.5s ease-in-out infinite;
}
.hv-pill-1 {
  top: 14%; left: 8%;
  animation: pillIn .5s .7s cubic-bezier(.16,1,.3,1) forwards, floatA 6s 1.2s ease-in-out infinite;
}
.hv-pill-2 {
  top: 32%; right: 6%;
  animation: pillIn .5s .95s cubic-bezier(.16,1,.3,1) forwards, floatB 7s 1.45s ease-in-out infinite;
}
.hv-pill-3 {
  bottom: 32%; left: 6%;
  animation: pillIn .5s 1.2s cubic-bezier(.16,1,.3,1) forwards, floatC 5.5s 1.7s ease-in-out infinite;
}
.hv-pill-4 {
  bottom: 14%; right: 8%;
  animation: pillIn .5s 1.45s cubic-bezier(.16,1,.3,1) forwards, floatA 6.5s 1.95s ease-in-out infinite;
}
@keyframes pillIn {
  from { opacity:0; transform:translateY(8px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes floatA { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes floatB { 0%,100%{transform:translateY(0)} 50%{transform:translateY(6px)} }
@keyframes floatC { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }

/* Responsive pills */
@media (max-width: 480px) {
  .hv-pill { font-size: 10px; padding: 6px 12px 6px 10px; }
  .hv-logo-n { font-size: 24px; }
  .hv-logo-word { font-size: 14px; letter-spacing: .22em; }
}

/* ══ GROWTH CARD ANIMATIONS ══ */

/* Card entrance — staggered slide up */
.growth-card {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity .6s ease, transform .6s cubic-bezier(.16,1,.3,1), border-color .3s;
}
.growth-card.in-view {
  opacity: 1;
  transform: translateY(0);
}
.growth-card:nth-child(1) { transition-delay: 0s; }
.growth-card:nth-child(2) { transition-delay: .12s; }
.growth-card:nth-child(3) { transition-delay: .24s; }

/* Animated number count */
.growth-card-num {
  position: relative; z-index: 2;
  display: inline-block;
  clip-path: inset(0);
}
.growth-card-num.counting {
  animation: numPop .4s cubic-bezier(.16,1,.3,1);
}
@keyframes numPop {
  0%  { transform: scale(.85); opacity: .4; }
  60% { transform: scale(1.08); }
  100%{ transform: scale(1);   opacity: 1; }
}

/* Bars — grow from bottom on scroll */
.growth-bar {
  transform: scaleY(0);
  transform-origin: bottom;
  transition: transform .6s cubic-bezier(.16,1,.3,1);
}
.growth-card.in-view .growth-bar:nth-child(1) { transform:scaleY(1); transition-delay:.05s; }
.growth-card.in-view .growth-bar:nth-child(2) { transform:scaleY(1); transition-delay:.12s; }
.growth-card.in-view .growth-bar:nth-child(3) { transform:scaleY(1); transition-delay:.19s; }
.growth-card.in-view .growth-bar:nth-child(4) { transform:scaleY(1); transition-delay:.26s; }
.growth-card.in-view .growth-bar:nth-child(5) { transform:scaleY(1); transition-delay:.33s; }
.growth-card.in-view .growth-bar:nth-child(6) { transform:scaleY(1); transition-delay:.40s; }
.growth-card.in-view .growth-bar:nth-child(7) { transform:scaleY(1); transition-delay:.47s; }

/* Icon bounce on enter */
.growth-card-icon {
  transition: transform .5s cubic-bezier(.16,1,.3,1);
  transform: scale(.7);
  opacity: 0;
}
.growth-card.in-view .growth-card-icon {
  transform: scale(1);
  opacity: 1;
  transition-delay: .1s;
}

/* Ring — draw on scroll */
.growth-card.in-view .vring-fill,
.growth-card.in-view circle[style*="ringFill"] {
  animation: ringFill 1.8s .3s cubic-bezier(.16,1,.3,1) forwards !important;
}

/* Hover shimmer on card */
.growth-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(237,232,223,.03) 0%, transparent 60%);
  opacity: 0; transition: opacity .3s; border-radius: var(--r-lg);
}
.growth-card:hover::before { opacity: 1; }

/* Glow pulse on hover */
.growth-card-glow {
  transition: opacity .4s;
}
.growth-card:hover .growth-card-glow { opacity: .18; }

/* Live pulse on revenue bar last item */
.growth-bar:last-child {
  position: relative;
}
.growth-bar:last-child::after {
  content: '';
  position: absolute;
  top: -4px; left: 0; right: 0;
  height: 3px;
  background: inherit;
  border-radius: 2px;
  animation: barPulse 2s ease-in-out infinite;
}
@keyframes barPulse {
  0%,100% { opacity: 1; transform: scaleX(1); }
  50%      { opacity: .4; transform: scaleX(.6); }
}

/* Visibility ring label fade */
.growth-card .growth-ring-label {
  opacity: 0; transition: opacity .5s .8s;
}
.growth-card.in-view .growth-ring-label { opacity: .7; }



/* ══ CURSOR ADAPTIVE ══ */
.cursor {
  mix-blend-mode: difference;
  background: white !important;
}
.cursor-ring {
  mix-blend-mode: difference;
  border-color: rgba(255,255,255,.6) !important;
}

/* ══ REVIEWS PAGE ══ */
.rv-hero {
  padding: 120px 40px 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.rv-hero-bg {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(237,232,223,.05) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
}
.rv-score-wrap {
  display: flex; align-items: flex-start; justify-content: center;
  gap: 10px; margin-bottom: 24px;
}
.rv-score {
  font-size: clamp(72px, 14vw, 128px);
  font-weight: 800;
  line-height: 1;
  color: var(--cream);
  letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
}
.rv-score-denom {
  font-size: clamp(22px, 3.5vw, 36px);
  font-weight: 300;
  color: var(--ink-muted);
  padding-top: 14px;
  letter-spacing: -0.02em;
}
.rv-stars {
  display: flex; gap: 10px; justify-content: center;
  margin-bottom: 16px;
}
.rv-star {
  display: inline-flex;
  opacity: 0;
  transform: scale(0.3) rotate(-20deg);
  transition: opacity .5s cubic-bezier(.34,1.56,.64,1), transform .5s cubic-bezier(.34,1.56,.64,1);
}
.rv-star.lit {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}
.rv-hero-sub {
  color: var(--ink-muted);
  font-size: 14px;
}
.rv-hero-sub strong { color: var(--cream-dark); font-weight: 500; }

/* Ticker belt */
.rv-ticker-wrap {
  overflow: hidden;
  padding: 28px 0;
  border-top: 1px solid rgba(237,232,223,.06);
  border-bottom: 1px solid rgba(237,232,223,.06);
  margin-bottom: 36px;
}
.rv-ticker-track {
  display: flex;
  white-space: nowrap;
  width: max-content;
  animation: rvTicker 38s linear infinite;
}
.rv-ticker-item {
  font-size: 13px;
  color: var(--ink-muted);
  flex-shrink: 0;
  padding: 0 28px;
}
.rv-ticker-item em { font-style: normal; color: var(--cream-dark); }
.rv-ticker-sep {
  color: var(--accent);
  opacity: .35;
  flex-shrink: 0;
  align-self: center;
}
@keyframes rvTicker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Filters */
.rv-filters {
  display: flex; gap: 8px; justify-content: center;
  padding: 0 40px 32px;
  flex-wrap: wrap;
}
.rv-filter {
  background: transparent;
  border: 1px solid rgba(237,232,223,.12);
  color: var(--ink-muted);
  padding: 9px 22px;
  border-radius: var(--r-sm);
  font-family: inherit;
  font-size: 13px;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s, transform .2s;
}
.rv-filter:hover {
  border-color: rgba(237,232,223,.28);
  color: var(--cream);
  transform: translateY(-1px);
}
.rv-filter.active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--ink);
  font-weight: 600;
}

/* Card masonry grid */
.rv-grid {
  column-count: 3;
  column-gap: 18px;
  padding: 0 40px 60px;
}
.rv-card {
  break-inside: avoid;
  margin-bottom: 18px;
  background: var(--ink-light);
  border-radius: var(--r);
  padding: 28px;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  --mx: 50%;
  --my: 50%;
  transition: box-shadow .3s, border-color .3s;
  border: 1px solid rgba(237,232,223,.0);
  will-change: transform;
}
.rv-card:hover {
  border-color: rgba(237,232,223,.07);
  box-shadow: 0 24px 64px rgba(0,0,0,.35);
}

/* Cursor-following spotlight */
.rv-card::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle 210px at var(--mx) var(--my), rgba(200,184,154,.1), transparent 70%);
  opacity: 0;
  transition: opacity .35s;
  pointer-events: none;
  border-radius: inherit;
  z-index: 0;
}
.rv-card:hover::before { opacity: 1; }

/* Scan-line sweep */
.rv-card::after {
  content: '';
  position: absolute;
  left: 0; right: 0;
  height: 60px;
  background: linear-gradient(to bottom, transparent, rgba(200,184,154,.05), transparent);
  pointer-events: none;
  z-index: 0;
  top: -60px;
}
.rv-card:hover::after {
  animation: rvScan .75s ease-out forwards;
}
@keyframes rvScan {
  from { top: -60px; }
  to   { top: 110%;  }
}

.rv-card > * { position: relative; z-index: 1; }

.rv-card-header {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 16px;
}
.rv-avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 12px;
  flex-shrink: 0;
  color: var(--ink);
  letter-spacing: .01em;
}
.rv-author { flex: 1; min-width: 0; }
.rv-author-name {
  font-size: 14px; font-weight: 600; color: var(--cream);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rv-author-sub {
  font-size: 11px; color: var(--ink-muted); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rv-rating { display: flex; gap: 4px; flex-shrink: 0; }
.rv-rating-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent);
}
.rv-rating-dot.empty { background: rgba(237,232,223,.1); }

.rv-quote {
  font-size: 14px;
  line-height: 1.72;
  color: var(--cream-dark);
  margin-bottom: 20px;
}
.rv-quote::before {
  content: '\201C';
  font-size: 42px;
  line-height: 0.5;
  vertical-align: -11px;
  color: var(--accent);
  font-weight: 800;
  margin-right: 2px;
  font-family: Georgia, serif;
  opacity: .75;
}
.rv-card-footer {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.rv-cat-tag {
  font-size: 11px; padding: 4px 10px; border-radius: 100px;
  background: rgba(200,184,154,.1); color: var(--accent);
  letter-spacing: .04em; font-weight: 500; white-space: nowrap;
}
.rv-date { font-size: 11px; color: rgba(107,104,96,.55); white-space: nowrap; }

/* Modal */
.rv-modal {
  position: fixed; inset: 0; z-index: 500;
  display: none; align-items: flex-end; justify-content: center;
  padding: 0 20px 20px;
}
.rv-modal.open { display: flex; }
.rv-modal-bg {
  position: absolute; inset: 0;
  background: rgba(26,26,24,.88);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  animation: rvFadeIn .28s ease;
}
.rv-modal-content {
  position: relative; z-index: 1;
  background: #222220;
  border-radius: var(--r-lg);
  padding: 44px;
  width: 100%; max-width: 640px;
  animation: rvSlideUp .42s cubic-bezier(.16,1,.3,1);
  border: 1px solid rgba(237,232,223,.08);
  max-height: 88vh; overflow-y: auto;
}
@keyframes rvFadeIn  { from { opacity: 0; } to { opacity: 1; } }
@keyframes rvSlideUp { from { opacity: 0; transform: translateY(60px) scale(.96); } to { opacity: 1; transform: none; } }

.rv-modal-close {
  position: absolute; top: 20px; right: 20px;
  background: rgba(237,232,223,.06);
  border: 1px solid rgba(237,232,223,.08);
  color: var(--ink-muted);
  width: 36px; height: 36px; border-radius: 50%;
  font-size: 14px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s;
  font-family: inherit;
}
.rv-modal-close:hover { background: rgba(237,232,223,.12); color: var(--cream); }

.rv-modal-stars { display: flex; gap: 6px; margin-bottom: 20px; }
.rv-modal-quote {
  font-size: clamp(17px, 2.8vw, 22px);
  line-height: 1.65; color: var(--cream);
  margin-bottom: 32px; font-weight: 400;
}
.rv-modal-quote::before {
  content: '\201C';
  font-size: 68px; line-height: 0.4; vertical-align: -20px;
  color: var(--accent); font-weight: 800;
  margin-right: 4px; font-family: Georgia, serif; opacity: .7;
}
.rv-modal-divider { height: 1px; background: rgba(237,232,223,.06); margin-bottom: 28px; }
.rv-modal-author { display: flex; align-items: center; gap: 16px; }
.rv-modal-avatar {
  width: 52px; height: 52px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 15px;
  color: var(--ink); flex-shrink: 0;
}
.rv-modal-name { font-size: 16px; font-weight: 600; color: var(--cream); }
.rv-modal-role { font-size: 13px; color: var(--ink-muted); margin-top: 3px; }
.rv-modal-footer-row { display: flex; gap: 8px; align-items: center; margin-top: 10px; }

/* Featured pull quote */
.rv-pull {
  padding: 72px 40px;
  border-top: 1px solid rgba(237,232,223,.06);
  text-align: center;
}
.rv-pull-label {
  font-size: 11px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 48px; opacity: .8;
}
.rv-pull-quote {
  font-size: clamp(21px, 3.2vw, 36px);
  font-weight: 300; line-height: 1.55; color: var(--cream);
  max-width: 840px; margin: 0 auto 32px;
  letter-spacing: -0.02em;
}
.rv-pull-quote em { font-style: normal; color: var(--accent); font-weight: 600; }
.rv-pull-word {
  display: inline-block;
  opacity: 0; transform: translateY(10px);
  transition: opacity .45s, transform .45s;
}
.rv-pull-word.visible { opacity: 1; transform: none; }
.rv-pull-source { font-size: 14px; color: var(--ink-muted); }
.rv-pull-source strong { color: var(--cream); font-weight: 500; }

/* ── REVIEW SUBMIT FORM ── */
.rv-submit {
  padding: 64px 40px;
  border-top: 1px solid rgba(237,232,223,.06);
}
.rv-submit-inner {
  max-width: 720px;
  margin: 0 auto;
}
.rv-submit-hd { margin-bottom: 48px; }
.rv-submit-title {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.03em;
  margin: 12px 0 10px;
}
.rv-submit-title em { font-style: normal; color: var(--accent); }
.rv-submit-sub { color: var(--ink-muted); font-size: 15px; line-height: 1.6; }

/* Star picker */
.rv-star-picker {
  display: flex; gap: 4px;
  margin-bottom: 10px;
}
.rv-star-btn {
  background: none; border: none; cursor: pointer;
  padding: 4px;
  color: rgba(237,232,223,.12);
  transition: color .15s, transform .15s;
  line-height: 0;
}
.rv-star-btn.hov { color: rgba(200,184,154,.6); }
.rv-star-btn.sel { color: var(--accent); }
.rv-star-btn.pop {
  animation: rvStarPop .4s cubic-bezier(.34,1.56,.64,1);
}
@keyframes rvStarPop {
  0%   { transform: scale(1); }
  45%  { transform: scale(1.45); }
  100% { transform: scale(1); }
}
.rv-star-hint {
  font-size: 13px;
  color: var(--ink-muted);
  height: 18px;
  transition: color .2s;
  margin-bottom: 28px;
}
.rv-star-hint.rated { color: var(--accent); }

/* Form */
.rv-form { display: flex; flex-direction: column; gap: 14px; }
.rv-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.rv-fg { display: flex; flex-direction: column; }

/* Floating label inputs */
.rv-field { position: relative; }
.rv-input {
  width: 100%;
  padding: 22px 18px 8px;
  background: var(--ink-light);
  border: 1px solid rgba(237,232,223,.09);
  border-radius: var(--r-sm);
  color: var(--cream);
  font-size: 15px;
  font-family: inherit;
  outline: none;
  transition: border-color .25s, background .25s, box-shadow .25s;
  -webkit-appearance: none;
  appearance: none;
}
.rv-input::placeholder { color: transparent; }
.rv-input:focus {
  border-color: rgba(200,184,154,.35);
  background: #242421;
  box-shadow: 0 0 0 3px rgba(200,184,154,.06);
}
.rv-input.err {
  border-color: rgba(248,113,113,.45) !important;
  animation: rvShake .35s ease;
}
@keyframes rvShake {
  0%,100% { transform: none; }
  20%      { transform: translateX(-6px); }
  40%      { transform: translateX(6px); }
  60%      { transform: translateX(-4px); }
  80%      { transform: translateX(3px); }
}
.rv-label {
  position: absolute;
  left: 18px; top: 50%;
  transform: translateY(-50%);
  color: var(--ink-muted);
  font-size: 15px;
  pointer-events: none;
  transition: top .2s, transform .2s, font-size .2s, letter-spacing .2s, color .2s;
}
.rv-input:not(:placeholder-shown) ~ .rv-label,
.rv-input:focus ~ .rv-label {
  top: 10px;
  transform: none;
  font-size: 10px;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--accent);
}
.rv-textarea {
  height: 136px;
  resize: none;
  padding-top: 28px;
  line-height: 1.65;
  display: block;
}
.rv-label-ta {
  top: 20px;
  transform: none;
}
.rv-textarea:not(:placeholder-shown) ~ .rv-label-ta,
.rv-textarea:focus ~ .rv-label-ta {
  top: 10px;
  transform: none;
}
.rv-char-count {
  text-align: right;
  font-size: 11px;
  color: var(--ink-muted);
  margin-top: 5px;
  transition: color .25s;
}
.rv-char-count.warn  { color: #fb923c; }
.rv-char-count.limit { color: #f87171; }
.rv-opt { opacity: .38; font-weight: 400; font-size: .9em; }

/* Service picker */
.rv-svc-lbl {
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 10px;
}
.rv-svc-picks {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 2px;
}
.rv-svc-pick {
  background: transparent;
  border: 1px solid rgba(237,232,223,.1);
  color: var(--ink-muted);
  padding: 8px 18px;
  border-radius: var(--r-sm);
  font-family: inherit;
  font-size: 13px;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s, transform .15s;
}
.rv-svc-pick:hover {
  border-color: rgba(237,232,223,.24);
  color: var(--cream);
  transform: translateY(-1px);
}
.rv-svc-pick.sel {
  background: rgba(200,184,154,.1);
  border-color: var(--accent);
  color: var(--accent);
  font-weight: 500;
}

/* Submit button */
.rv-submit-btn {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--cream);
  color: var(--ink);
  border: none;
  padding: 16px 34px;
  border-radius: var(--r-sm);
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s, transform .2s, box-shadow .2s, opacity .2s;
  margin-top: 10px;
  position: relative;
  overflow: hidden;
}
.rv-submit-btn::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.15), transparent);
  opacity: 0; transition: opacity .2s;
}
.rv-submit-btn:hover { background: var(--cream-dark); transform: translateY(-2px); box-shadow: 0 16px 40px rgba(237,232,223,.1); }
.rv-submit-btn:hover::before { opacity: 1; }
.rv-submit-btn:active { transform: none; }
.rv-btn-arr { transition: transform .2s; display: inline-block; }
.rv-submit-btn:hover .rv-btn-arr { transform: translateX(4px); }
.rv-submit-btn.loading {
  pointer-events: none;
  opacity: .65;
}
.rv-submit-btn.loading .rv-btn-arr { display: none; }

/* Success state */
.rv-success {
  display: none;
  text-align: center;
  padding: 56px 0 16px;
}
.rv-success.show { display: block; }
.rv-success-ring {
  margin: 0 auto 28px;
  width: 72px; height: 72px;
}
.rv-success-arc {
  animation: rvArcDraw .6s .1s cubic-bezier(.16,1,.3,1) forwards;
  transform-origin: center;
  transform: rotate(-90deg);
}
.rv-success-tick {
  animation: rvTickDraw .4s .65s ease forwards;
}
@keyframes rvArcDraw  { to { stroke-dashoffset: 0; } }
@keyframes rvTickDraw { to { stroke-dashoffset: 0; } }
.rv-success-title {
  font-size: 28px; font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--cream);
  margin-bottom: 8px;
  animation: rvSuccessUp .5s .3s cubic-bezier(.16,1,.3,1) both;
}
.rv-success-sub {
  font-size: 15px; color: var(--ink-muted);
  animation: rvSuccessUp .5s .45s cubic-bezier(.16,1,.3,1) both;
}
@keyframes rvSuccessUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: none; }
}

/* Responsive */
@media (max-width: 1100px) {
  .rv-grid { column-count: 2; padding: 0 24px 44px; }
  .rv-hero { padding: 104px 24px 40px; }
  .rv-filters { padding: 0 24px 28px; }
  .rv-pull { padding: 56px 24px; }
  .rv-submit { padding: 52px 24px; }
}
@media (max-width: 640px) {
  .rv-grid { column-count: 1; padding: 0 16px 36px; }
  .rv-hero { padding: 90px 16px 36px; }
  .rv-filters { padding: 0 16px 24px; gap: 6px; }
  .rv-filter { padding: 8px 16px; font-size: 12px; }
  .rv-pull { padding: 44px 16px; }
  .rv-modal-content { padding: 32px 22px; border-radius: var(--r); }
  .rv-ticker-item { padding: 0 16px; font-size: 12px; }
  .rv-submit { padding: 40px 16px; }
  .rv-form-row { grid-template-columns: 1fr; }
  .rv-submit-btn { width: 100%; justify-content: center; }
}
