/* ===== Formory Group — "Form Foundry" (arctic engineering / frost premium) ===== */
/* Built with frontend-design + ui-ux-pro-max: distinctive type-forward direction,
   Bricolage Grotesque display + JetBrains Mono spec system + Inter body.
   Signature: frost-shimmer wordmark, engineered hairline grid, mono index. */
:root {
  /* Arctic ink & cool neutrals */
  --ink: #07131C;          /* arctic near-black */
  --ink-2: #0C2030;        /* elevated dark */
  --bg: #E9EEF2;           /* frost base */
  --bg-2: #DFE7ED;         /* alt section */
  --surface: #FBFDFE;      /* card surface */

  /* Cryo brand (signature electric ice) */
  --cryo: #2F7BEC;
  --cryo-deep: #1A5FC8;
  --cryo-press: #134EA8;
  --ice: #9FC6EE;
  --ice-soft: #D6E7F8;

  /* Lines & muted */
  --hair: #CCD9E5;         /* hairline rules */
  --hair-strong: #B7C8D8;
  --muted: #50637A;        /* cool slate body-muted */
  --mist: #8EA4B8;         /* on dark muted */

  --shadow: 0 34px 80px rgba(7, 25, 45, 0.18);
  --shadow-sm: 0 14px 34px rgba(7, 25, 45, 0.10);
  --shadow-cryo: 0 16px 38px rgba(47, 123, 236, 0.30);

  --max: 1240px;
  --radius: 16px;
  --radius-lg: 22px;
  --font-display: 'Bricolage Grotesque', 'Sora', -apple-system, BlinkMacSystemFont, sans-serif;
  --sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--sans);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.65;
  font-size: 16px;
  letter-spacing: -0.006em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
h1, h2, h3, h4 { margin: 0 0 .4em; color: var(--ink); font-family: var(--font-display); }
.display, .hero-title { font-family: var(--font-display); font-weight: 800; letter-spacing: -0.035em; line-height: 1.02; }
.display { font-size: clamp(2.1rem, 4.6vw, 3.7rem); }

/* Frost-shimmer accent (the signature) */
.display em, .hero-title em, .grad {
  font-style: normal;
  background: linear-gradient(110deg, var(--cryo) 18%, #8fbef0 38%, #ffffff 50%, #8fbef0 62%, var(--cryo) 82%);
  background-size: 240% 100%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: shimmer 5.5s var(--ease) infinite;
}
@keyframes shimmer { 0% { background-position: 150% 0; } 100% { background-position: -50% 0; } }

p { margin: 0 0 1em; }
a { color: inherit; text-decoration: none; }
img, svg { max-width: 100%; display: block; }
.container { width: 100%; max-width: var(--max); margin: 0 auto; padding: 0 30px; }
::selection { background: var(--cryo); color: #fff; }

/* ===== Site-wide 3D world ===== */
.site-3d { position: fixed; inset: 0; width: 100vw; height: 100vh; height: 100dvh; z-index: 0; pointer-events: none; }
.topbar, .site-header, .hero, .marquee, .section, .stats-band, .cta-band, .site-footer { position: relative; z-index: 1; }
/* let the 3D world show through light areas */
.has3d .hero-bg { display: none; }
.has3d .hero { background: transparent; }
.has3d .section:not(.section-dark) { background: rgba(233,239,246,0.6); backdrop-filter: blur(7px); -webkit-backdrop-filter: blur(7px); }
.has3d .section-cream { background: rgba(223,231,239,0.62); backdrop-filter: blur(7px); -webkit-backdrop-filter: blur(7px); }
/* glass cards float over the 3D world */
.has3d .studio-card:not(.studio-card-alt),
.has3d .case,
.has3d .steps li,
.has3d .contact-form {
  background: rgba(251,253,254,0.62);
  backdrop-filter: blur(13px) saturate(1.15);
  -webkit-backdrop-filter: blur(13px) saturate(1.15);
  border-color: rgba(255,255,255,0.6);
}
/* every section floats over the 3D world */
.has3d .section-dark { background: linear-gradient(180deg, rgba(7,19,28,0.62), rgba(12,34,51,0.68)); backdrop-filter: blur(13px); -webkit-backdrop-filter: blur(13px); }
.has3d .cta-band { background: linear-gradient(150deg, rgba(7,19,28,0.6), rgba(13,42,68,0.68)); backdrop-filter: blur(13px); -webkit-backdrop-filter: blur(13px); }
.has3d .marquee { background: rgba(7,19,28,0.66); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.has3d .stats-band { background: linear-gradient(135deg, rgba(47,123,236,0.8), rgba(26,95,200,0.82)); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.has3d .site-footer { background: rgba(7,19,28,0.82); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
/* 3D tilt interaction */
.tilt { transform-style: preserve-3d; transition: transform .25s var(--ease); will-change: transform; }
:focus-visible { outline: 2px solid var(--cryo); outline-offset: 3px; border-radius: 3px; }

/* ===== Mono spec label system (signature) ===== */
.kicker, .hero-spec, .studio-tag, .case-tag, .svc-deliver span {
  font-family: var(--mono); text-transform: uppercase; letter-spacing: .12em;
  font-weight: 500;
}
.kicker { display: inline-flex; align-items: center; gap: .55rem; font-size: .72rem; color: var(--cryo-deep); margin: 0 0 1.1rem; }
.kicker::before { content: ""; width: 7px; height: 7px; background: var(--cryo); display: inline-block; }
.kicker-light { color: var(--ice); }
.kicker-light::before { background: var(--ice); }

/* ===== Buttons ===== */
.btn {
  position: relative; overflow: hidden;
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  background: var(--ink); color: #fff;
  padding: .95rem 1.7rem; border-radius: 100px;
  font-family: var(--sans); font-weight: 600; font-size: .95rem; border: 0; cursor: pointer;
  min-height: 48px;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), background .2s;
  white-space: nowrap;
}
.btn::after { content: ""; position: absolute; top: 0; left: -120%; width: 60%; height: 100%; background: linear-gradient(100deg, transparent, rgba(255,255,255,0.28), transparent); transform: skewX(-18deg); transition: left .6s var(--ease); }
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-cryo); background: var(--cryo); }
.btn:hover::after { left: 130%; }
.btn:active { transform: translateY(0); }
.btn-lg { padding: 1.1rem 2.1rem; font-size: 1rem; }
.btn-sm { padding: .6rem 1.2rem; font-size: .9rem; min-height: 40px; }
.btn-block { width: 100%; }
.btn-ghost { background: transparent; color: var(--ink); border: 1.5px solid var(--hair-strong); }
.btn-ghost:hover { background: var(--surface); color: var(--cryo-deep); border-color: var(--cryo); box-shadow: var(--shadow-sm); }
.btn-light { background: #fff; color: var(--ink); }
.btn-light:hover { background: var(--ice-soft); color: var(--cryo-press); }

/* ===== Topbar ===== */
.topbar { background: var(--ink); color: #fff; font-family: var(--mono); font-size: .74rem; letter-spacing: .04em; }
.topbar-row { display: flex; align-items: center; justify-content: center; gap: 1.5rem; padding: .55rem 30px; flex-wrap: wrap; }
.topbar-row span { color: var(--mist); }
.topbar-row a { color: #fff; font-weight: 500; border-bottom: 1px solid transparent; transition: border-color .2s; }
.topbar-row a:hover { border-color: var(--ice); }

/* ===== Header (frosted glass) ===== */
.site-header {
  position: sticky; top: 0; z-index: 60;
  background: rgba(233, 238, 242, 0.7);
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-bottom: 1px solid transparent;
  transition: border-color .3s, box-shadow .3s;
}
.site-header.scrolled { border-color: var(--hair); box-shadow: 0 6px 24px rgba(7,25,45,0.06); }
.nav { display: flex; align-items: center; justify-content: space-between; height: 78px; }
.brand { display: inline-flex; align-items: center; gap: .6rem; }
.brand-mark { width: 36px; height: 36px; flex: none; }
.brand-name { font-family: var(--font-display); font-weight: 800; font-size: 1.34rem; letter-spacing: -0.04em; color: var(--ink); display: inline-flex; align-items: baseline; gap: .42rem; }
.brand-mark-sub { font-family: var(--mono); font-size: .58rem; font-weight: 500; letter-spacing: .2em; text-transform: uppercase; color: var(--cryo); }
.site-footer .brand-name { color: #fff; }
.nav-links { display: flex; align-items: center; gap: 2rem; }
.nav-links a { font-weight: 500; font-size: .95rem; color: var(--ink); position: relative; }
.nav-links a:not(.btn)::after { content: ""; position: absolute; left: 0; bottom: -5px; width: 0; height: 2px; background: var(--cryo); transition: width .3s var(--ease); }
.nav-links a:not(.btn):hover::after { width: 100%; }
.nav-links .btn { color: #fff; }
.menu-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 8px; }
.menu-toggle span { width: 26px; height: 2px; background: var(--ink); border-radius: 2px; transition: .3s; }
.menu-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-toggle.open span:nth-child(2) { opacity: 0; }
.menu-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ===== Hero ===== */
.hero { position: relative; padding: clamp(3.5rem, 8vw, 7rem) 0 clamp(4rem, 8vw, 7rem); overflow: hidden; }
.hero-bg { position: absolute; inset: 0; z-index: 0; background:
  radial-gradient(1100px 640px at 82% -14%, rgba(47,123,236,0.18), transparent 58%),
  radial-gradient(900px 600px at -8% 112%, rgba(159,198,238,0.30), transparent 56%),
  linear-gradient(180deg, #EFF4F8 0%, var(--bg) 64%); }
/* Engineered hairline grid */
.hero-grid-lines { position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(12,32,48,0.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(12,32,48,0.045) 1px, transparent 1px);
  background-size: 80px 80px;
  -webkit-mask-image: radial-gradient(120% 90% at 60% 30%, #000 30%, transparent 78%);
  mask-image: radial-gradient(120% 90% at 60% 30%, #000 30%, transparent 78%); }
.hero-layout { position: relative; z-index: 1; display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 3.5rem; align-items: center; }
.hero-inner { position: relative; z-index: 1; }
.hero-figure { position: relative; margin: 0; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--hair); box-shadow: var(--shadow); aspect-ratio: 4/5; }
.hero-figure img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 20%; filter: saturate(0.5) contrast(1.05) brightness(1.06); transition: transform .8s var(--ease); }
.hero-figure:hover img { transform: scale(1.04); }
/* Light frost wash: subtle cool tint + faint icy highlight (image is already wintry) */
.hero-figure::after { content: ""; position: absolute; inset: 0; background:
  linear-gradient(160deg, rgba(10,27,46,0.12), rgba(47,123,236,0.22) 70%);
  mix-blend-mode: multiply; pointer-events: none; }
.hero-figure::before { content: ""; position: absolute; inset: 0; z-index: 1; background:
  linear-gradient(160deg, rgba(206,228,247,0) 45%, rgba(206,228,247,0.32) 100%);
  mix-blend-mode: screen; pointer-events: none; }
.hero-figure figcaption { position: absolute; left: 14px; bottom: 14px; z-index: 2; display: inline-flex; align-items: center; gap: .5rem; font-family: var(--mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; color: #fff; background: rgba(7,19,28,0.4); border: 1px solid rgba(255,255,255,0.18); padding: .4rem .7rem; border-radius: 100px; backdrop-filter: blur(6px); }
.hero-figure figcaption .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--ice); }
/* 3D hero canvas */
.hero-3d { position: absolute; inset: 0; width: 100%; height: 100%; display: block; z-index: 0; }
.hero-figure:not(.on) .hero-3d { display: none; }
.hero-figure.on .hero-3d-fallback { display: none; }
.hero-figure.on::after { background: linear-gradient(160deg, rgba(10,27,46,0.06), rgba(47,123,236,0.12) 75%); }
.hero-figure.on::before { background: linear-gradient(160deg, rgba(206,228,247,0) 55%, rgba(206,228,247,0.22) 100%); }
.hero-spec { display: inline-flex; align-items: center; gap: .8rem; font-size: .74rem; color: var(--cryo-deep); margin: 0 0 1.6rem; padding: .45rem .9rem; background: rgba(255,255,255,0.6); border: 1px solid var(--hair); border-radius: 100px; backdrop-filter: blur(6px); }
.hero-spec .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--cryo); }
.hero-title { font-size: clamp(2.7rem, 7.4vw, 5.8rem); margin: 0 0 1.7rem; }
.hero-lede { font-size: clamp(1.08rem, 1.55vw, 1.3rem); color: var(--muted); max-width: 41rem; line-height: 1.62; }
.hero-lede strong { color: var(--ink); font-weight: 600; }
.hero-cta { display: flex; gap: .9rem; flex-wrap: wrap; margin: 2.3rem 0 3.4rem; }
.hero-meta { display: flex; gap: 0; flex-wrap: wrap; border-top: 1px solid var(--hair); max-width: 46rem; }
.hero-meta div { display: flex; flex-direction: column; padding: 1.6rem 2.4rem 0 0; margin-right: 2.4rem; border-right: 1px solid var(--hair); }
.hero-meta div:last-child { border-right: 0; margin-right: 0; }
.num { font-family: var(--font-display); font-size: clamp(2rem, 3.2vw, 2.7rem); font-weight: 800; color: var(--ink); line-height: 1; letter-spacing: -0.04em; font-variant-numeric: tabular-nums; }
.hero-meta label, .stat label { font-family: var(--mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); margin-top: .55rem; }

/* ===== Marquee ===== */
.marquee { background: var(--ink); color: #fff; overflow: hidden; padding: 1.1rem 0; border-block: 1px solid rgba(255,255,255,0.08); }
.marquee-track { display: inline-flex; align-items: center; gap: 1.6rem; white-space: nowrap; animation: marquee 32s linear infinite; }
.marquee-track span { font-family: var(--font-display); font-size: 1.35rem; font-weight: 700; letter-spacing: -0.03em; }
.marquee-track i { color: var(--cryo); font-style: normal; font-size: .8rem; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ===== Sections ===== */
.section { padding: clamp(4rem, 8vw, 7.5rem) 0; }
.section-cream { background: var(--bg-2); }
.section-dark { background: linear-gradient(180deg, #07131C 0%, #0C2233 100%); color: #fff; position: relative; }
.section-dark::before { content: ""; position: absolute; inset: 0; background: radial-gradient(760px 400px at 86% 0%, rgba(47,123,236,0.22), transparent 60%); pointer-events: none; }
.section-dark > .container { position: relative; z-index: 1; }
.section-dark .display, .section-dark h3, .section-dark h4 { color: #fff; }
.section-head { max-width: 52rem; margin: 0 0 3.5rem; }
.section-sub { color: var(--muted); font-size: 1.1rem; max-width: 40rem; margin-top: 1rem; line-height: 1.6; }
.section-sub-light { color: var(--mist); font-size: 1.1rem; max-width: 42rem; margin-top: 1rem; line-height: 1.6; }

/* ===== Approach intro ===== */
.lead-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem 4rem; align-items: start; margin-bottom: 4rem; }
.lead-text { color: var(--muted); font-size: 1.1rem; }
.studio-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1.6rem; }
.studio-card { position: relative; overflow: hidden; background: var(--surface); border: 1px solid var(--hair); border-radius: var(--radius-lg); padding: 2.6rem; color: var(--cryo); transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .3s; }
.studio-card-alt { background: linear-gradient(155deg, #0C2233, #07131C); border-color: transparent; color: #fff; }
.studio-card-alt h3, .studio-card-alt p { color: #fff; }
.studio-card-alt .studio-tag { color: var(--ice); border-color: rgba(159,198,238,0.3); }
.studio-card-alt .link-arrow { color: var(--ice); }
.studio-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: var(--cryo); }
.studio-card-alt:hover { border-color: rgba(159,198,238,0.4); }
.studio-tag { display: inline-block; font-size: .68rem; color: var(--cryo-deep); border: 1px solid var(--hair-strong); padding: .32rem .7rem; border-radius: 100px; margin-bottom: 1.4rem; }
.studio-card h3 { font-family: var(--font-display); font-weight: 800; font-size: 1.95rem; letter-spacing: -0.03em; color: var(--ink); margin-bottom: .6rem; }
.studio-card-alt h3 { color: #fff; }
.studio-card p { color: var(--muted); max-width: 26rem; }
.studio-card-alt p { color: rgba(255,255,255,0.78); }
.link-arrow { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--mono); font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; font-weight: 500; color: var(--cryo-deep); margin-top: .5rem; }
.link-arrow span { transition: transform .3s var(--ease); }
.link-arrow:hover span { transform: translateX(5px); }
.studio-illo { position: absolute; right: -8px; bottom: -8px; width: 200px; opacity: .4; pointer-events: none; }

/* ===== Services list ===== */
.svc-list { display: grid; gap: 0; }
.svc { display: grid; grid-template-columns: 64px 1fr 280px; gap: 2.5rem; padding: 2.8rem 0; border-top: 1px solid rgba(255,255,255,0.13); align-items: start; transition: background .3s; }
.svc:last-child { border-bottom: 1px solid rgba(255,255,255,0.13); }
.svc:hover { background: rgba(159,198,238,0.04); }
.svc-no { font-family: var(--mono); font-size: 1rem; font-weight: 600; color: var(--ice); padding-top: .4rem; }
.svc-main h3 { font-family: var(--font-display); font-weight: 800; font-size: 1.8rem; letter-spacing: -0.03em; color: #fff; margin-bottom: .6rem; }
.svc-main > p { color: var(--mist); max-width: 42rem; margin-bottom: 1.4rem; }
.svc-tags { list-style: none; display: flex; flex-wrap: wrap; gap: .5rem .6rem; padding: 0; margin: 0; }
.svc-tags li { font-family: var(--mono); font-size: .76rem; letter-spacing: .02em; color: #fff; background: rgba(159,198,238,0.09); border: 1px solid rgba(159,198,238,0.2); padding: .42rem .85rem; border-radius: 6px; }
.svc-deliver { border-left: 2px solid var(--cryo); padding-left: 1.3rem; }
.svc-deliver span { display: block; font-size: .68rem; color: var(--ice); margin-bottom: .5rem; }
.svc-deliver p { font-size: .92rem; color: var(--mist); margin: 0; line-height: 1.7; }

/* ===== Stats band ===== */
.stats-band { background: linear-gradient(135deg, var(--cryo) 0%, var(--cryo-deep) 100%); color: #fff; padding: clamp(3rem, 6vw, 5rem) 0; position: relative; overflow: hidden; }
.stats-band::before { content: ""; position: absolute; inset: 0; background:
  radial-gradient(600px 300px at 92% 130%, rgba(255,255,255,0.18), transparent 60%),
  linear-gradient(to right, rgba(255,255,255,0.07) 1px, transparent 1px); background-size: auto, 25% 100%; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; position: relative; z-index: 1; }
.stat { display: flex; flex-direction: column; align-items: flex-start; }
.stat .num { color: #fff; display: block; }
.stat label { display: block; margin-top: .7rem; }
.stats-band label { color: rgba(255,255,255,0.85); }

/* ===== Cases ===== */
.cases { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.case { background: var(--surface); border: 1px solid var(--hair); border-radius: var(--radius-lg); overflow: hidden; transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .3s; }
.case:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: var(--cryo); }
.case-thumb { aspect-ratio: 4/3; position: relative; overflow: hidden; }
.case-thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.25) saturate(0.7) contrast(1.05); transition: transform .7s var(--ease); }
.case:hover .case-thumb img { transform: scale(1.06); }
.case-thumb::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(160deg, rgba(7,19,28,0.22), rgba(47,123,236,0.40) 60%, rgba(159,198,238,0.26)); mix-blend-mode: multiply; pointer-events: none; }
.case-1 { background: linear-gradient(150deg, #0C2233, #1A5FC8); }
.case-2 { background: linear-gradient(150deg, #2F7BEC, #9FC6EE); }
.case-3 { background: linear-gradient(150deg, #07131C, #355F86); }
.case-body { padding: 1.6rem 1.7rem 1.9rem; }
.case-tag { display: inline-block; font-size: .68rem; color: var(--cryo-deep); margin-bottom: .7rem; }
.case-body h3 { font-family: var(--font-display); font-weight: 800; font-size: 1.3rem; letter-spacing: -0.03em; margin-bottom: .5rem; }
.case-body p { color: var(--muted); font-size: .96rem; }
.case-result { display: block; font-family: var(--mono); font-weight: 500; font-size: .82rem; color: var(--cryo-deep); margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--hair); font-variant-numeric: tabular-nums; }

/* ===== Steps ===== */
.steps { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.6rem; }
.steps li { background: var(--surface); border: 1px solid var(--hair); border-radius: var(--radius); padding: 2rem 1.7rem; transition: transform .3s var(--ease), box-shadow .3s var(--ease); }
.steps li:hover { transform: translateY(-4px); box-shadow: var(--shadow-sm); }
.step-no { font-family: var(--mono); font-size: 1rem; font-weight: 600; color: var(--cryo); display: block; margin-bottom: .8rem; }
.steps h3 { font-size: 1.2rem; font-weight: 700; }
.steps p { color: var(--muted); font-size: .95rem; margin: 0; }

/* ===== Testimonials ===== */
.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.quote-card { background: rgba(159,198,238,0.06); border: 1px solid rgba(159,198,238,0.18); border-radius: var(--radius-lg); padding: 2.2rem; margin: 0; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.quote-card blockquote { font-family: var(--font-display); font-size: 1.2rem; font-weight: 600; line-height: 1.45; letter-spacing: -0.02em; color: #fff; margin: 0 0 1.6rem; }
.quote-card figcaption { display: flex; align-items: center; gap: .9rem; }
.avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--cryo); color: #fff; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; flex: none; }
.quote-card figcaption strong { display: block; color: #fff; }
.quote-card figcaption span { font-family: var(--mono); font-size: .76rem; color: var(--mist); }

/* ===== FAQ ===== */
.faq-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 4rem; align-items: start; }
.inline-link { color: var(--cryo-deep); border-bottom: 1px solid var(--cryo); }
.faq-list { display: flex; flex-direction: column; }
.faq-item { border-top: 1px solid var(--hair); }
.faq-item:last-child { border-bottom: 1px solid var(--hair); }
.faq-item summary { list-style: none; cursor: pointer; padding: 1.4rem 2.5rem 1.4rem 0; font-size: 1.12rem; font-weight: 700; font-family: var(--font-display); letter-spacing: -0.02em; position: relative; color: var(--ink); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; position: absolute; right: 0; top: 50%; transform: translateY(-50%); font-size: 1.5rem; color: var(--cryo); transition: transform .3s var(--ease); font-weight: 400; }
.faq-item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.faq-item p { color: var(--muted); margin: 0 0 1.4rem; max-width: 44rem; }

/* ===== CTA band ===== */
.cta-band { background: linear-gradient(150deg, #07131C 0%, #0D2A44 100%); color: #fff; padding: clamp(4rem, 8vw, 7rem) 0; position: relative; overflow: hidden; }
.cta-band::before { content: ""; position: absolute; inset: 0; background: radial-gradient(640px 360px at 80% -12%, rgba(47,123,236,0.34), transparent 60%); }
.cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 2.5rem; flex-wrap: wrap; position: relative; z-index: 1; }
.cta-inner .display { color: #fff; }

/* ===== Contact ===== */
.contact-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 4rem; align-items: start; }
.contact-info { list-style: none; padding: 0; margin: 2.2rem 0 0; display: grid; gap: 1rem; }
.contact-info li { display: flex; align-items: center; gap: .9rem; color: var(--ink); font-weight: 500; }
.contact-info a:hover { color: var(--cryo); }
.contact-info svg { width: 22px; height: 22px; fill: none; stroke: var(--cryo); stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; flex: none; }
.contact-form { background: var(--surface); border: 1px solid var(--hair); border-radius: var(--radius-lg); padding: 2.4rem; box-shadow: var(--shadow-sm); }
.field { margin-bottom: 1.2rem; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.field label { display: block; font-family: var(--mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; font-weight: 500; color: var(--muted); margin-bottom: .45rem; }
.field input, .field select, .field textarea {
  width: 100%; padding: .85rem 1rem; border: 1.5px solid var(--hair-strong); border-radius: 11px;
  font: inherit; color: var(--ink); background: #fff; min-height: 48px; transition: border-color .2s, box-shadow .2s;
}
.field input:focus, .field select:focus, .field textarea:focus { outline: 0; border-color: var(--cryo); box-shadow: 0 0 0 3px rgba(47,123,236,0.16); }
.field textarea { resize: vertical; min-height: auto; }
.form-note { margin: 1rem 0 0; padding: .85rem 1rem; background: var(--ice-soft); color: var(--cryo-press); border-radius: 11px; font-weight: 600; font-size: .92rem; }
.form-note.is-error { background: #fdecec; color: #b3261e; }

/* ===== Footer ===== */
.site-footer { background: var(--ink); color: var(--mist); padding: clamp(3.5rem, 6vw, 5rem) 0 1.8rem; }
.site-footer .brand { margin-bottom: 1.2rem; }
.footer-tag { color: var(--mist); max-width: 24rem; margin-bottom: 1.6rem; }
.footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1.2fr; gap: 2.5rem; padding-bottom: 3rem; border-bottom: 1px solid rgba(255,255,255,0.1); }
.footer-col { display: flex; flex-direction: column; gap: .7rem; }
.footer-col h4 { color: #fff; font-family: var(--mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; margin-bottom: .5rem; font-weight: 500; }
.footer-col a { color: var(--mist); font-size: .95rem; transition: color .2s; }
.footer-col a:hover { color: var(--ice); }
.footer-area { color: #6a7e93; font-size: .9rem; }
.footer-bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: .6rem; padding-top: 1.8rem; font-family: var(--mono); font-size: .76rem; color: #6a7e93; }

/* ===== Reveal animation ===== */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ===== Responsive ===== */
@media (max-width: 1000px) {
  .svc { grid-template-columns: 44px 1fr; }
  .svc-deliver { grid-column: 2; border-left: 0; border-top: 1px solid rgba(255,255,255,0.14); padding-left: 0; padding-top: 1.2rem; margin-top: .4rem; }
  .stats-grid, .cases, .steps, .quotes { grid-template-columns: 1fr 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
  .nav-links { position: fixed; top: 0; right: 0; bottom: 0; left: auto; height: 100vh; height: 100dvh; width: min(82vw, 340px); flex-direction: column; justify-content: flex-start; background: var(--surface); padding: 6.5rem 2rem 2rem; gap: 1.8rem; align-items: flex-start; transform: translateX(110%); transition: transform .4s var(--ease); box-shadow: var(--shadow); z-index: 55; overflow-y: auto; }
  .nav-links a { font-size: 1.3rem; }
  .nav-links .btn { margin-top: .6rem; font-size: 1rem; }
  .nav-links.open { transform: translateX(0); }
  .menu-toggle { display: flex; z-index: 56; }
  .lead-grid, .studio-cards, .contact-grid, .faq-grid { grid-template-columns: 1fr; }
  .faq-grid { gap: 2rem; }
  .hero-meta div { padding-right: 1.5rem; margin-right: 1.5rem; }
  .hero-layout { grid-template-columns: 1fr; gap: 2.4rem; }
  .hero-figure { aspect-ratio: 1/1; max-height: 440px; }
  .hero-figure img { object-position: 50% 12%; }
}
@media (max-width: 600px) {
  .stats-grid, .cases, .steps, .quotes, .footer-top { grid-template-columns: 1fr; }
  .field-row { grid-template-columns: 1fr; }
  .svc { grid-template-columns: 1fr; gap: 1rem; }
  .svc-deliver { grid-column: 1; }
  .marquee-track span { font-size: 1.15rem; }
  .hero-meta { gap: 0; }
  .hero-meta div { border-right: 0; border-bottom: 1px solid var(--hair); padding: 1rem 0; margin: 0; width: 100%; }
  .hero-spec span:first-child, .hero-spec .dot { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .display em, .hero-title em, .grad { background-position: 0 0; }
}
