/* ══════════════════════════════════════════════════════════════════════════════
   MONOLITH — Brand Architecture & Strategy Studio
   Main Stylesheet v2.0 — Liquid Chrome Edition
   ══════════════════════════════════════════════════════════════════════════════ */

:root {
    --void:      #060608;
    --obsidian:  #0B0B0C;
    --carbon:    #0E0F11;
    --charcoal:  #151618;
    --iron:      #1E1F22;
    --smoke:     #2E3035;
    --ash:       #6F737A;
    --chrome:    var(--color-chrome, #B6BCC4);
    --pearl:     #E2E5E9;
    --white:     #F2F3F5;
    --prism:     var(--color-prism, #7B8CDE);
    --prism2:    #A78BFA;
    --electric:  var(--color-electric, #4FC3F7);
    --cold:      #3A4658;

    --font-serif: 'Playfair Display', Georgia, serif;
    --font-sans:  'Inter', system-ui, sans-serif;

    --ease-silk:  cubic-bezier(.25, .46, .45, .94);
    --ease-out:   cubic-bezier(.16, 1, .3, 1);
    --ease-snap:  cubic-bezier(.77, 0, .18, 1);
    --ease-mag:   cubic-bezier(.23, 1, .32, 1);
    --ease-expo:  cubic-bezier(.19, 1, .22, 1);

    --container: 1240px;
    --pad:       clamp(24px, 5vw, 88px);
    --section-v: clamp(100px, 12vw, 180px);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
    background: var(--obsidian);
    color: var(--chrome);
    font-family: var(--font-sans);
    font-weight: 300;
    line-height: 1.65;
    overflow-x: hidden;
    cursor: none;
    -webkit-font-smoothing: antialiased;
}
img, video, canvas { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; border: none; background: none; cursor: none; }
ul, ol { list-style: none; }
input, textarea, select { font: inherit; color: inherit; background: transparent; border: none; outline: none; -webkit-appearance: none; appearance: none; }
select option { background: var(--carbon); color: var(--white); }

body::after {
    content: '';
    position: fixed; inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
    opacity: .024;
    pointer-events: none;
    z-index: 9000;
    mix-blend-mode: overlay;
}

/* ── CURSOR ── */
#cur { width: 5px; height: 5px; background: var(--white); border-radius: 50%; position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9999; transform: translate(-50%,-50%); mix-blend-mode: difference; }
#cur-ring { width: 32px; height: 32px; border: 1px solid rgba(182,188,196,.18); border-radius: 50%; position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9998; transform: translate(-50%,-50%); transition: width .5s var(--ease-mag), height .5s var(--ease-mag), border-color .4s, background .4s; }
#cur-ring.expand { width: 52px; height: 52px; border-color: rgba(123,140,222,.38); background: rgba(123,140,222,.025); }
@media (hover: none) { #cur, #cur-ring { display: none; } body { cursor: auto; } button, a { cursor: pointer; } }

/* ── CONTAINER ── */
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--pad); }

/* ── HEADER ── */
#site-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 500;
    padding: 0 var(--pad);
    border-bottom: 1px solid transparent;
    transition: background .8s var(--ease-silk), backdrop-filter .8s var(--ease-silk), border-color .6s;
}
#site-header.scrolled { background: rgba(6,6,8,.93); backdrop-filter: blur(36px) saturate(1.7); border-color: rgba(255,255,255,.03); }
/* Prism line under header */
#site-header::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 1px; background: linear-gradient(to right, transparent, rgba(123,140,222,.12), rgba(79,195,247,.07), rgba(123,140,222,.12), transparent); opacity: 0; transition: opacity .8s var(--ease-silk); }
#site-header.scrolled::after { opacity: 1; }

.header-inner { display: flex; align-items: center; justify-content: space-between; height: 72px; gap: 20px; }

.site-logo { display: flex; align-items: center; flex-shrink: 0; }
.logo-wordmark { font-family: var(--font-serif); font-size: 17px; font-weight: 400; letter-spacing: .32em; text-transform: uppercase; color: var(--white); position: relative; }
.logo-wordmark::after { content: ''; position: absolute; bottom: -2px; left: 0; right: 0; height: 1px; background: linear-gradient(to right, transparent, rgba(123,140,222,.5), transparent); transform: scaleX(0); transition: transform .6s var(--ease-expo); }
.site-logo:hover .logo-wordmark::after { transform: scaleX(1); }
.custom-logo { height: 30px; width: auto; }

.primary-nav { flex: 1; display: flex; justify-content: center; }
.nav-menu { display: flex; align-items: center; gap: 34px; }
.nav-menu li a { font-size: 10px; font-weight: 500; letter-spacing: .3em; text-transform: uppercase; color: var(--ash); position: relative; padding: 4px 0; transition: color .4s var(--ease-silk); }
.nav-menu li a::before { content: ''; position: absolute; bottom: -1px; left: 0; right: 0; height: 1px; background: linear-gradient(to right, var(--prism), var(--electric), var(--prism)); transform: scaleX(0); transition: transform .45s var(--ease-expo); transform-origin: left; }
.nav-menu li a:hover { color: var(--white); }
.nav-menu li a:hover::before,
.nav-menu li.current-menu-item a::before { transform: scaleX(1); }
.nav-menu li.current-menu-item a { color: var(--chrome); }

.header-actions { display: flex; align-items: center; gap: 18px; flex-shrink: 0; }
.header-phone { font-size: 10px; letter-spacing: .16em; color: var(--ash); transition: color .4s var(--ease-silk); display: none; }
@media (min-width: 1200px) { .header-phone { display: block; } }
.header-phone:hover { color: var(--chrome); }
.header-cta { font-size: 10px; font-weight: 500; letter-spacing: .22em; text-transform: uppercase; color: var(--ash); transition: color .4s var(--ease-silk); display: none; }
@media (min-width: 1024px) { .header-cta { display: block; } }
.header-cta:hover { color: var(--white); }

.menu-toggle { display: flex; flex-direction: column; justify-content: center; gap: 5px; width: 36px; height: 36px; padding: 6px; position: relative; z-index: 600; }
.burger-line { display: block; height: 1px; background: var(--chrome); transition: transform .5s var(--ease-expo), opacity .4s, width .4s var(--ease-expo), background .3s; transform-origin: center; }
.burger-line:nth-child(1) { width: 22px; }
.burger-line:nth-child(2) { width: 15px; }
.burger-line:nth-child(3) { width: 22px; }
.menu-toggle[aria-expanded="true"] .burger-line:nth-child(1) { width: 20px; transform: translateY(6px) rotate(45deg); background: var(--white); }
.menu-toggle[aria-expanded="true"] .burger-line:nth-child(2) { opacity: 0; transform: scaleX(0); }
.menu-toggle[aria-expanded="true"] .burger-line:nth-child(3) { width: 20px; transform: translateY(-6px) rotate(-45deg); background: var(--white); }
@media (min-width: 1024px) { .menu-toggle { display: none; } }

/* ── MOBILE NAV ── */
.mobile-nav-overlay {
    position: fixed; inset: 0; z-index: 490;
    background: rgba(5,5,7,.97);
    backdrop-filter: blur(52px) saturate(1.5);
    display: flex; flex-direction: column;
    justify-content: center; align-items: flex-start;
    padding: 80px var(--pad) 48px;
    pointer-events: none;
    opacity: 0;
    transition: opacity .55s var(--ease-silk);
}
.mobile-nav-overlay::before {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(ellipse 55% 45% at 80% 50%, rgba(123,140,222,.035), transparent);
    pointer-events: none;
}
.mobile-nav-overlay.is-open { opacity: 1; pointer-events: all; }

.mobile-nav-close { position: absolute; top: 22px; right: var(--pad); width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; font-size: 15px; color: var(--ash); border: 1px solid rgba(255,255,255,.07); border-radius: 50%; transition: color .3s, border-color .3s, background .3s; z-index: 10; }
.mobile-nav-close:hover { color: var(--white); border-color: rgba(255,255,255,.18); background: rgba(255,255,255,.03); }

.mobile-menu { display: flex; flex-direction: column; width: 100%; }
.mobile-menu li { border-bottom: 1px solid rgba(255,255,255,.04); overflow: hidden; }
.mobile-menu li a {
    display: flex; align-items: center; justify-content: space-between;
    font-family: var(--font-serif);
    font-size: clamp(24px, 5.5vw, 46px);
    font-weight: 400; color: rgba(182,188,196,.35);
    padding: 14px 0;
    opacity: 0;
    transform: translateY(18px);
    transition: color .45s var(--ease-silk), opacity .5s var(--ease-out), transform .5s var(--ease-out);
}
.mobile-menu li a::after { content: '↗'; font-family: var(--font-sans); font-size: 13px; opacity: 0; transition: opacity .3s, transform .4s var(--ease-mag); transform: translateX(-6px) translateY(4px); }
.mobile-menu li a:hover { color: var(--white); }
.mobile-menu li a:hover::after { opacity: .5; transform: translateX(0) translateY(0); }
.mobile-nav-overlay.is-open .mobile-menu li a { opacity: 1; transform: translateY(0); }
.mobile-menu li:nth-child(1) a { transition-delay: .04s; }
.mobile-menu li:nth-child(2) a { transition-delay: .09s; }
.mobile-menu li:nth-child(3) a { transition-delay: .14s; }
.mobile-menu li:nth-child(4) a { transition-delay: .19s; }
.mobile-menu li:nth-child(5) a { transition-delay: .24s; }
.mobile-menu li:nth-child(6) a { transition-delay: .29s; }
.mobile-menu li:nth-child(7) a { transition-delay: .34s; }

.mobile-nav-footer { margin-top: 36px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.04); display: flex; flex-direction: column; gap: 8px; opacity: 0; transform: translateY(10px); transition: opacity .5s var(--ease-out) .38s, transform .5s var(--ease-out) .38s; }
.mobile-nav-overlay.is-open .mobile-nav-footer { opacity: 1; transform: translateY(0); }
.mobile-nav-email, .mobile-nav-phone { font-size: 13px; color: var(--chrome); letter-spacing: .03em; }
.mobile-nav-loc { font-size: 10px; letter-spacing: .12em; color: var(--smoke); margin-top: 4px; }

/* ── BUTTONS ── */
.btn {
    display: inline-flex; align-items: center; gap: 12px;
    padding: 15px 36px;
    font-family: var(--font-sans); font-size: 10px; font-weight: 500;
    letter-spacing: .26em; text-transform: uppercase;
    position: relative; overflow: hidden;
    transition: color .45s var(--ease-silk), border-color .45s var(--ease-silk);
    white-space: nowrap;
}
/* Shimmer sweep */
.btn::after { content: ''; position: absolute; top: 0; left: -120%; bottom: 0; width: 100%; background: linear-gradient(90deg, transparent, rgba(182,188,196,.07), rgba(123,140,222,.05), transparent); transition: left .75s var(--ease-mag); pointer-events: none; }
.btn:hover::after { left: 120%; }
.btn svg { transition: transform .5s var(--ease-mag); flex-shrink: 0; position: relative; z-index: 1; }
.btn:hover svg { transform: translateX(5px); }
.btn span { position: relative; z-index: 1; }

.btn-primary { border: 1px solid rgba(255,255,255,.11); color: var(--white); }
.btn-primary::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(123,140,222,.14), rgba(79,195,247,.07)); opacity: 0; transition: opacity .5s var(--ease-silk); }
.btn-primary:hover { border-color: rgba(123,140,222,.32); }
.btn-primary:hover::before { opacity: 1; }

.btn-ghost { border: 1px solid rgba(255,255,255,.06); color: var(--ash); }
.btn-ghost:hover { border-color: rgba(255,255,255,.13); color: var(--chrome); }

/* ── OVERLINE ── */
.overline { font-size: 9px; font-weight: 500; letter-spacing: .48em; text-transform: uppercase; color: var(--prism); display: flex; align-items: center; gap: 14px; margin-bottom: 20px; }
.overline::before { content: ''; display: block; width: 22px; height: 1px; background: linear-gradient(to right, transparent, var(--prism)); flex-shrink: 0; }

/* ── SECTION TITLE ── */
.section-title { font-family: var(--font-serif); font-size: clamp(2rem, 4vw, 3.75rem); font-weight: 400; line-height: 1.06; color: var(--white); }
.section-head { margin-bottom: clamp(48px, 6vw, 96px); }
.section-canvas { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 0; opacity: .2; }

/* ── CHROME DIVIDER ── */
.chrome-divider { width: 100%; height: 1px; background: linear-gradient(to right, transparent, rgba(182,188,196,.08), rgba(123,140,222,.18), rgba(79,195,247,.1), rgba(123,140,222,.18), rgba(182,188,196,.08), transparent); position: relative; overflow: hidden; }
.chrome-divider::after { content: ''; position: absolute; top: 0; left: -100%; right: 100%; bottom: 0; background: linear-gradient(to right, transparent, rgba(255,255,255,.08), transparent); animation: divider-shimmer 5s ease-in-out infinite; }
@keyframes divider-shimmer { 0% { left: -100%; right: 100%; } 100% { left: 100%; right: -100%; } }

/* ── REVEAL SYSTEM ── */
.reveal-item { opacity: 0; transform: translateY(30px); transition: opacity 1.1s var(--ease-out), transform 1.1s var(--ease-out); }
.reveal-item.visible { opacity: 1; transform: translateY(0); }
.hero-word { display: inline-block; opacity: 0; transform: translateY(65%) skewY(2.5deg); transition: opacity 1.1s var(--ease-out), transform 1.1s var(--ease-out); will-change: transform, opacity; }
.hero-word.visible { opacity: 1; transform: translateY(0) skewY(0deg); }

/* ── PRISM RAYS ── */
.prism-overlay { position: absolute; inset: 0; pointer-events: none; z-index: 2; overflow: hidden; }
.prism-ray { position: absolute; top: 0; bottom: 0; width: 1px; background: linear-gradient(to bottom, transparent 0%, rgba(123,140,222,.0) 5%, rgba(123,140,222,.22) 25%, rgba(167,139,250,.1) 45%, rgba(79,195,247,.16) 62%, rgba(123,140,222,.07) 80%, transparent 100%); filter: blur(.5px); }
.prism-ray:nth-child(1) { left: 36%; animation: ray-pulse 9s ease-in-out infinite; }
.prism-ray:nth-child(2) { left: 54%; opacity: .5; animation: ray-pulse 13s ease-in-out 3.5s infinite; }
.prism-ray:nth-child(3) { left: 70%; opacity: .3; animation: ray-pulse 7s ease-in-out 6s infinite; }
.prism-ray:nth-child(4) { left: 84%; opacity: .18; animation: ray-pulse 11s ease-in-out 1.5s infinite; }
@keyframes ray-pulse { 0%, 100% { opacity: 0; transform: scaleY(.3); } 15%, 85% { opacity: 1; } 50% { opacity: .65; transform: scaleY(1) translateX(3px); } }

/* ── HERO ── */
.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; padding: 0 var(--pad) clamp(72px, 12vh, 140px); overflow: hidden; }
#hero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.hero-vignette { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to bottom, rgba(6,6,8,.65) 0%, rgba(6,6,8,.0) 28%, rgba(6,6,8,.04) 52%, rgba(6,6,8,.97) 100%), linear-gradient(to right, rgba(6,6,8,.92) 0%, rgba(6,6,8,.28) 48%, rgba(6,6,8,.0) 100%); }
.hero-content { position: relative; z-index: 3; max-width: 860px; }
.hero-label { font-size: 9px; letter-spacing: .48em; text-transform: uppercase; color: var(--ash); margin-bottom: 36px; display: flex; align-items: center; gap: 14px; }
.hero-label::before { content: ''; display: block; width: 32px; height: 1px; background: linear-gradient(to right, transparent, var(--prism)); flex-shrink: 0; }
.hero-heading { font-family: var(--font-serif); font-size: clamp(3rem, 8vw, 8.5rem); font-weight: 400; line-height: .91; letter-spacing: -.022em; color: var(--white); margin-bottom: 40px; overflow: visible; }
.hero-sub { font-size: clamp(14px, 1.4vw, 16px); line-height: 1.9; color: var(--ash); max-width: 360px; border-left: 1px solid rgba(255,255,255,.06); padding-left: 20px; margin-bottom: 48px; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }

.hero-scroll-indicator { position: absolute; right: var(--pad); bottom: clamp(48px, 8vh, 96px); z-index: 3; display: flex; flex-direction: column; align-items: center; gap: 10px; opacity: 0; animation: fade-in .8s var(--ease-out) 2.2s forwards; }
.hero-scroll-indicator span { font-size: 8px; letter-spacing: .4em; text-transform: uppercase; color: var(--smoke); writing-mode: vertical-rl; }
.scroll-line { width: 1px; height: 60px; position: relative; overflow: hidden; background: rgba(46,48,53,.25); }
.scroll-line::after { content: ''; position: absolute; top: -100%; left: 0; width: 100%; height: 100%; background: linear-gradient(to bottom, transparent, var(--prism), transparent); animation: scan-down 2.6s var(--ease-silk) infinite; }
@keyframes scan-down { 0% { top: -100%; } 100% { top: 200%; } }
@keyframes fade-in { to { opacity: 1; } }

/* ── MARQUEE ── */
.marquee-strip { padding: 22px 0; overflow: hidden; border-top: 1px solid rgba(255,255,255,.03); border-bottom: 1px solid rgba(255,255,255,.03); position: relative; }
.marquee-strip::before, .marquee-strip::after { content: ''; position: absolute; top: 0; bottom: 0; width: 100px; z-index: 1; }
.marquee-strip::before { left: 0; background: linear-gradient(to right, var(--obsidian), transparent); }
.marquee-strip::after  { right: 0; background: linear-gradient(to left,  var(--obsidian), transparent); }
.marquee-track { display: flex; gap: 52px; width: max-content; animation: marquee 32s linear infinite; }
.marquee-item { font-size: 10px; letter-spacing: .38em; text-transform: uppercase; color: var(--smoke); white-space: nowrap; }
.marquee-dot { color: var(--prism); font-size: 4px; align-self: center; opacity: .55; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── MANIFESTO ── */
.manifesto-section { padding: var(--section-v) var(--pad); position: relative; overflow: hidden; text-align: center; }
.manifesto-section::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 70% 60% at 50% 50%, rgba(123,140,222,.035), transparent); pointer-events: none; }
.manifesto-inner { max-width: 860px; margin: 0 auto; position: relative; z-index: 1; }
.manifesto-statement { font-family: var(--font-serif); font-size: clamp(1.75rem, 4.5vw, 3.75rem); font-weight: 400; line-height: 1.12; color: var(--white); font-style: normal; margin-bottom: 36px; border: none; padding: 0; }
.manifesto-statement em { font-style: italic; background: linear-gradient(135deg, var(--chrome), var(--prism), var(--electric), var(--chrome)); background-size: 200%; -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; animation: gradient-shift 6s ease infinite; }
@keyframes gradient-shift { 0% { background-position: 0%; } 50% { background-position: 100%; } 100% { background-position: 0%; } }
.manifesto-support { font-size: clamp(14px, 1.5vw, 17px); line-height: 2; color: var(--ash); max-width: 520px; margin: 0 auto; }
.manifesto-chrome-bar { position: absolute; bottom: 0; left: 8%; right: 8%; height: 1px; background: linear-gradient(to right, transparent, rgba(182,188,196,.1), rgba(123,140,222,.2), rgba(79,195,247,.12), rgba(123,140,222,.2), rgba(182,188,196,.1), transparent); overflow: hidden; }
.manifesto-chrome-bar::after { content: ''; position: absolute; top: 0; left: -100%; right: 100%; bottom: 0; background: linear-gradient(to right, transparent, rgba(255,255,255,.08), transparent); animation: divider-shimmer 5s ease-in-out infinite; }

/* ── SERVICE SLABS ── */
.services-preview { padding: var(--section-v) var(--pad); position: relative; overflow: hidden; }
.service-slabs { display: flex; flex-direction: column; gap: 0; margin-bottom: 56px; }
.service-slab {
    background: var(--carbon);
    border-top: 1px solid rgba(255,255,255,.04);
    padding: 28px 40px;
    display: grid; grid-template-columns: 28px 1fr 1fr auto;
    gap: 32px; align-items: center;
    position: relative; overflow: hidden;
    transition: background .55s var(--ease-silk), padding-left .55s var(--ease-expo);
}
.service-slab:last-child { border-bottom: 1px solid rgba(255,255,255,.04); }
.service-slab::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: linear-gradient(to bottom, transparent, var(--prism), var(--electric), transparent); transform: scaleY(0); transform-origin: top; transition: transform .65s var(--ease-expo); }
.service-slab:hover { background: var(--charcoal); padding-left: 52px; }
.service-slab:hover::before { transform: scaleY(1); }
.slab-num { font-size: 9px; letter-spacing: .2em; color: var(--smoke); }
.slab-name { font-family: var(--font-serif); font-size: clamp(17px, 1.8vw, 24px); font-weight: 400; color: var(--white); transition: color .4s var(--ease-silk); }
.service-slab:hover .slab-name { background: linear-gradient(to right, var(--white) 50%, var(--chrome)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.slab-desc { font-size: 12px; color: var(--ash); line-height: 1.7; }
.slab-arrow { width: 32px; height: 32px; border: 1px solid rgba(255,255,255,.07); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; color: var(--ash); flex-shrink: 0; transition: background .4s var(--ease-silk), border-color .4s, color .3s, transform .55s var(--ease-mag); }
.service-slab:hover .slab-arrow { background: var(--prism); border-color: var(--prism); color: var(--white); transform: rotate(45deg); }
.slab-sweep { position: absolute; top: 0; left: -100%; bottom: 0; width: 80%; background: linear-gradient(90deg, transparent, rgba(182,188,196,.04), rgba(123,140,222,.025), transparent); transition: left .75s var(--ease-mag); pointer-events: none; }
.service-slab:hover .slab-sweep { left: 120%; }
.slab-prism { position: absolute; top: 0; right: 0; bottom: 0; width: 1px; background: linear-gradient(to bottom, transparent, rgba(79,195,247,.22), rgba(123,140,222,.12), transparent); opacity: 0; transition: opacity .5s var(--ease-silk); }
.service-slab:hover .slab-prism { opacity: 1; }
.section-cta { display: flex; padding-top: 40px; }

/* ── WORLDS PREVIEW ── */
.worlds-preview { padding: var(--section-v) var(--pad); }
.worlds-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: rgba(255,255,255,.04); margin-bottom: 56px; }
@media (max-width: 600px) { .worlds-grid { grid-template-columns: 1fr; } }
.world-card { background: var(--carbon); padding: 32px 28px; position: relative; overflow: hidden; transition: background .55s var(--ease-silk); min-height: 240px; display: flex; flex-direction: column; justify-content: flex-start; gap: 0; }
.world-card:hover { background: var(--charcoal); }
.world-card-visual { position: relative; height: 60px; margin-bottom: 18px; }
.world-card-orb { width: 48px; height: 48px; border-radius: 50%; background: radial-gradient(circle at 32% 30%, rgba(232,234,237,.18), rgba(182,188,196,.09) 30%, rgba(123,140,222,.05) 55%, rgba(0,0,0,0)); border: 1px solid rgba(182,188,196,.1); position: absolute; transition: transform .7s var(--ease-mag), border-color .4s; animation: orb-breathe 7s ease-in-out infinite; }
.world-card:hover .world-card-orb { transform: scale(1.2); border-color: rgba(123,140,222,.25); }
@keyframes orb-breathe { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.06); } }
.world-num { position: absolute; bottom: 0; right: 0; font-size: 8px; letter-spacing: .2em; color: var(--smoke); }
.world-cat { font-size: 8px; letter-spacing: .32em; text-transform: uppercase; color: var(--prism); margin-bottom: 8px; }
.world-name { font-family: var(--font-serif); font-size: clamp(15px, 1.4vw, 18px); font-weight: 400; color: var(--white); margin-bottom: 10px; line-height: 1.25; }
.world-desc { font-size: 12px; color: var(--ash); line-height: 1.75; margin-bottom: 14px; }
.world-palette { font-size: 9px; color: var(--smoke); font-family: monospace; letter-spacing: .04em; margin-top: auto; padding-top: 10px; }
.world-card-sweep { position: absolute; top: 0; left: -100%; bottom: 0; width: 100%; background: linear-gradient(90deg, transparent, rgba(123,140,222,.05), rgba(79,195,247,.03), transparent); transition: left .8s var(--ease-mag); pointer-events: none; }
.world-card:hover .world-card-sweep { left: 100%; }
.world-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(to right, transparent, var(--prism), var(--electric), transparent); opacity: 0; transition: opacity .5s var(--ease-silk); }
.world-card:hover::before { opacity: 1; }

/* ── EXPERIMENTS PREVIEW ── */
.experiments-preview { padding: var(--section-v) var(--pad); position: relative; overflow: hidden; }
.experiments-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(255,255,255,.04); margin-bottom: 56px; }
@media (max-width: 768px) { .experiments-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .experiments-grid { grid-template-columns: 1fr; } }
.exp-block { background: var(--carbon); padding: 36px 28px; position: relative; overflow: hidden; display: flex; flex-direction: column; gap: 12px; transition: background .5s var(--ease-silk); min-height: 200px; justify-content: flex-end; }
.exp-block:hover { background: var(--charcoal); }
.exp-visual { position: absolute; inset: 0; pointer-events: none; background: radial-gradient(circle at 75% 25%, rgba(123,140,222,.06), transparent 55%); opacity: .5; transition: opacity .5s; }
.exp-block:hover .exp-visual { opacity: 1; }
.exp-chrome-orb { position: absolute; right: 20px; top: 20px; width: 52px; height: 52px; border-radius: 50%; background: radial-gradient(circle at 32% 28%, rgba(238,241,245,.18), rgba(182,188,196,.09) 35%, rgba(123,140,222,.05) 60%, rgba(0,0,0,0)); border: 1px solid rgba(182,188,196,.1); transition: border-color .4s, transform .6s var(--ease-mag); }
.exp-block:hover .exp-chrome-orb { border-color: rgba(123,140,222,.28); transform: scale(1.15); }
.exp-type { font-size: 8px; letter-spacing: .32em; text-transform: uppercase; color: var(--prism); }
.exp-label { font-family: var(--font-serif); font-size: 15px; color: var(--white); font-weight: 400; line-height: 1.3; }

/* ── PROCESS PREVIEW ── */
.process-preview { padding: var(--section-v) var(--pad); }
.process-stages { margin-bottom: 56px; }
.process-stage { display: grid; grid-template-columns: 52px 1fr; gap: 24px; align-items: flex-start; padding: 26px 0; border-top: 1px solid rgba(255,255,255,.04); position: relative; transition: padding-left .45s var(--ease-mag); }
.process-stage:last-child { border-bottom: 1px solid rgba(255,255,255,.04); }
.process-stage:hover { padding-left: 8px; }
.stage-num { font-family: var(--font-serif); font-size: 20px; font-weight: 400; color: rgba(182,188,196,.2); font-style: italic; padding-top: 3px; }
.stage-name { font-family: var(--font-serif); font-size: clamp(16px, 1.8vw, 22px); font-weight: 400; color: var(--white); margin-bottom: 6px; }
.stage-desc { font-size: 13px; color: var(--ash); line-height: 1.75; max-width: 480px; }

/* ── FINAL CTA ── */
.final-cta { padding: var(--section-v) var(--pad); position: relative; overflow: hidden; min-height: 60vh; display: flex; align-items: center; }
#cta-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.final-cta-vignette { position: absolute; inset: 0; z-index: 1; background: radial-gradient(ellipse 80% 70% at 50% 50%, rgba(6,6,8,.22), rgba(6,6,8,.88)); }
.final-cta .container { position: relative; z-index: 2; }
.final-cta-inner { text-align: center; max-width: 720px; margin: 0 auto; }
.final-cta-heading { font-family: var(--font-serif); font-size: clamp(2.5rem, 7vw, 6.5rem); font-weight: 400; color: var(--white); line-height: .95; margin-bottom: 24px; letter-spacing: -.02em; }
.final-cta-sub { font-size: 15px; color: var(--ash); margin-bottom: 52px; letter-spacing: .04em; }

/* ── PAGE HERO ── */
.page-hero { position: relative; overflow: hidden; padding: clamp(130px, 20vh, 220px) var(--pad) clamp(72px, 12vh, 140px); min-height: 52vh; display: flex; align-items: flex-end; }
.page-hero-vignette { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to bottom, rgba(6,6,8,.75) 0%, rgba(6,6,8,.08) 45%, rgba(6,6,8,.92) 100%), linear-gradient(to right, rgba(6,6,8,.88) 0%, transparent 65%); }
.page-hero .container, .page-hero-inner { position: relative; z-index: 2; }
.page-hero-heading { font-family: var(--font-serif); font-size: clamp(2.5rem, 6vw, 5.75rem); font-weight: 400; line-height: 1.04; color: var(--white); margin-bottom: 24px; }
.page-hero-heading em { font-style: italic; color: var(--chrome); }
.page-hero-sub { font-size: clamp(14px, 1.4vw, 16px); line-height: 1.9; color: var(--ash); max-width: 500px; }

/* ── ABOUT ── */
.about-philosophy { padding: var(--section-v) var(--pad); }
.philosophy-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: clamp(48px, 8vw, 120px); align-items: start; }
.philosophy-right p { font-size: 15px; line-height: 1.95; color: var(--ash); margin-bottom: 20px; }
.about-failure { padding: var(--section-v) var(--pad); background: var(--carbon); }
.failure-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: rgba(255,255,255,.04); }
.failure-card { background: var(--carbon); padding: 38px 30px; transition: background .5s var(--ease-silk); position: relative; overflow: hidden; }
.failure-card:hover { background: var(--charcoal); }
.failure-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(to right, transparent, var(--prism), transparent); opacity: 0; transition: opacity .5s; }
.failure-card:hover::before { opacity: 1; }
.failure-num { font-size: 8px; letter-spacing: .3em; color: var(--smoke); display: block; margin-bottom: 16px; }
.failure-title { font-family: var(--font-serif); font-size: 18px; font-weight: 400; color: var(--white); margin-bottom: 10px; }
.failure-body { font-size: 13px; color: var(--ash); line-height: 1.8; }
.about-principles { padding: var(--section-v) var(--pad); position: relative; overflow: hidden; }
.principles-list { display: flex; flex-direction: column; }
.principle-item { display: flex; align-items: flex-start; gap: 18px; padding: 20px 0; border-bottom: 1px solid rgba(255,255,255,.04); transition: padding-left .5s var(--ease-expo); }
.principle-item:hover { padding-left: 14px; }
.principle-marker { color: var(--prism); font-size: 6px; margin-top: 7px; flex-shrink: 0; }
.principle-text { font-size: clamp(14px, 1.4vw, 17px); color: var(--chrome); line-height: 1.7; }
.about-quote { padding: var(--section-v) var(--pad); }
.quote-chamber { max-width: 760px; margin: 0 auto; text-align: center; }
.cinematic-quote { font-family: var(--font-serif); font-size: clamp(1.2rem, 2.4vw, 1.85rem); font-weight: 400; font-style: italic; color: var(--chrome); line-height: 1.6; border: none; padding: 0; }

/* ── SERVICES FULL ── */
.services-full { padding: var(--section-v) var(--pad); }
.service-module { padding: 56px 0; border-top: 1px solid rgba(255,255,255,.05); position: relative; }
.service-module:last-child { border-bottom: 1px solid rgba(255,255,255,.05); }
.service-module-header { display: flex; align-items: flex-start; gap: 28px; margin-bottom: 30px; }
.service-module-num { font-size: 8px; letter-spacing: .25em; color: var(--smoke); padding-top: 8px; flex-shrink: 0; min-width: 24px; }
.service-module-name { font-family: var(--font-serif); font-size: clamp(1.4rem, 2.8vw, 2.4rem); font-weight: 400; color: var(--white); line-height: 1.1; margin-bottom: 6px; }
.service-module-tagline { font-size: 12px; color: var(--prism); letter-spacing: .04em; }
.service-module-body { display: grid; grid-template-columns: 1fr 1fr auto; gap: 40px; align-items: start; padding-left: 52px; }
.service-module-desc p { font-size: 14px; color: var(--ash); line-height: 1.9; }
.deliverables-label { font-size: 8px; letter-spacing: .38em; text-transform: uppercase; color: var(--smoke); margin-bottom: 14px; }
.deliverables-list { display: flex; flex-direction: column; gap: 7px; }
.deliverables-list li { font-size: 12px; color: var(--ash); padding-left: 12px; position: relative; }
.deliverables-list li::before { content: ''; position: absolute; left: 0; top: 50%; width: 5px; height: 1px; background: var(--prism); transform: translateY(-50%); }
.service-module-cta { font-size: 9px; letter-spacing: .22em; text-transform: uppercase; color: var(--ash); display: flex; align-items: center; gap: 8px; transition: color .3s; padding-top: 4px; white-space: nowrap; }
.service-module-cta:hover { color: var(--white); }
.service-module-accent { position: absolute; left: 0; top: 0; bottom: 0; width: 1px; background: linear-gradient(to bottom, transparent, var(--prism), transparent); opacity: 0; transition: opacity .5s; }
.service-module:hover .service-module-accent { opacity: 1; }

/* ── WORLDS FULL ── */
.worlds-full { padding: var(--section-v) var(--pad); }
.world-module { padding: 52px 0; border-top: 1px solid rgba(255,255,255,.05); display: grid; grid-template-columns: 1fr auto; gap: 40px; position: relative; overflow: hidden; }
.world-module:last-child { border-bottom: 1px solid rgba(255,255,255,.05); }
.world-module-header { display: flex; gap: 26px; align-items: flex-start; margin-bottom: 28px; }
.world-module-num { font-size: 8px; letter-spacing: .22em; color: var(--smoke); padding-top: 6px; flex-shrink: 0; }
.world-module-cat { font-size: 8px; letter-spacing: .32em; text-transform: uppercase; color: var(--prism); margin-bottom: 8px; }
.world-module-name { font-family: var(--font-serif); font-size: clamp(1.4rem, 2.8vw, 2.4rem); font-weight: 400; color: var(--white); line-height: 1.1; }
.world-module-body { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px; grid-column: 1; }
.world-body-label { font-size: 8px; letter-spacing: .35em; text-transform: uppercase; color: var(--smoke); margin-bottom: 10px; }
.world-module-body p { font-size: 13px; color: var(--ash); line-height: 1.85; }
.world-palette-string { font-family: monospace; font-size: 10px; color: var(--chrome); letter-spacing: .05em; }
.world-module-visual-panel { width: 170px; height: 170px; border: 1px solid rgba(255,255,255,.05); position: relative; overflow: hidden; flex-shrink: 0; }
.world-panel-orb { position: absolute; inset: 0; background: radial-gradient(circle at 38% 32%, rgba(182,188,196,.14), rgba(123,140,222,.06) 50%, rgba(0,0,0,0)); animation: orb-breathe 6s ease-in-out infinite; }

/* ── EXPERIMENTS FULL ── */
.experiments-full { padding: var(--section-v) var(--pad); }
.exp-group { margin-bottom: 60px; }
.exp-group-header { display: flex; align-items: center; gap: 26px; margin-bottom: 20px; }
.exp-group-title { font-family: var(--font-serif); font-size: clamp(1.2rem, 2vw, 1.6rem); font-weight: 400; color: var(--white); white-space: nowrap; }
.exp-group-line { flex: 1; height: 1px; background: rgba(255,255,255,.05); }
.exp-items { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(255,255,255,.04); }
.exp-item { background: var(--carbon); padding: 28px 22px; display: flex; align-items: center; gap: 16px; transition: background .5s var(--ease-silk); }
.exp-item:hover { background: var(--charcoal); }
.exp-item-visual { width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(182,188,196,.1); background: radial-gradient(circle at 32% 30%, rgba(182,188,196,.14), rgba(0,0,0,0)); position: relative; overflow: hidden; transition: border-color .4s; flex-shrink: 0; }
.exp-item:hover .exp-item-visual { border-color: rgba(123,140,222,.28); }
.exp-item-orb { position: absolute; inset: 0; background: radial-gradient(circle at 35% 30%, rgba(123,140,222,.16), transparent); }
.exp-item-title { font-size: 13px; color: var(--white); margin-bottom: 4px; }
.exp-item-tag { font-size: 8px; letter-spacing: .2em; text-transform: uppercase; color: var(--prism); }

/* ── PROCESS FULL ── */
.process-full { padding: var(--section-v) var(--pad); }
.process-module { display: grid; grid-template-columns: 68px 1fr; gap: 40px; padding: 52px 0; border-top: 1px solid rgba(255,255,255,.05); position: relative; }
.process-module:last-child { border-bottom: 1px solid rgba(255,255,255,.05); }
.process-module-aside { display: flex; flex-direction: column; align-items: center; }
.process-stage-num { font-family: var(--font-serif); font-size: 30px; font-weight: 400; font-style: italic; color: rgba(182,188,196,.2); flex-shrink: 0; }
.process-connector { flex: 1; width: 1px; background: rgba(255,255,255,.04); margin-top: 12px; }
.connector-inner { width: 100%; height: 100%; background: linear-gradient(to bottom, rgba(123,140,222,.16), transparent); }
.process-module-name { font-family: var(--font-serif); font-size: clamp(1.4rem, 2.8vw, 2.2rem); font-weight: 400; color: var(--white); margin-bottom: 6px; }
.process-module-sub { font-size: 11px; letter-spacing: .1em; color: var(--prism); margin-bottom: 20px; }
.process-module-body-text { font-size: 14px; color: var(--ash); line-height: 1.9; margin-bottom: 26px; max-width: 580px; }
.outputs-label { font-size: 8px; letter-spacing: .38em; text-transform: uppercase; color: var(--smoke); margin-bottom: 12px; }
.outputs-list { display: flex; flex-direction: column; gap: 7px; }
.outputs-list li { font-size: 12px; color: var(--ash); padding-left: 12px; position: relative; }
.outputs-list li::before { content: ''; position: absolute; left: 0; top: 50%; width: 5px; height: 1px; background: var(--prism); transform: translateY(-50%); }
.process-module-accent { position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(to right, var(--prism), var(--electric), transparent); opacity: 0; transition: opacity .6s; }
.process-module:hover .process-module-accent { opacity: 1; }

/* ── CONTACT ── */
.contact-hero { position: relative; overflow: hidden; padding: clamp(150px, 22vh, 260px) var(--pad) clamp(80px, 14vh, 180px); min-height: 58vh; display: flex; align-items: flex-end; }
#contact-hero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.contact-hero-vignette { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to bottom, rgba(6,6,8,.82), rgba(6,6,8,.05) 40%, rgba(6,6,8,.97) 100%), linear-gradient(to right, rgba(6,6,8,.9), transparent 65%); }
.contact-hero-inner { position: relative; z-index: 2; }
.contact-hero-heading { font-family: var(--font-serif); font-size: clamp(2.5rem, 7vw, 6.5rem); font-weight: 400; color: var(--white); line-height: .97; margin-bottom: 20px; letter-spacing: -.02em; }
.contact-hero-sub { font-size: 15px; color: var(--ash); letter-spacing: .03em; }
.contact-body { padding: var(--section-v) var(--pad); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.6fr; gap: clamp(48px, 8vw, 130px); }
.contact-info-heading { font-family: var(--font-serif); font-size: clamp(1.4rem, 2.8vw, 2.4rem); font-weight: 400; color: var(--white); margin-bottom: 16px; }
.contact-info-body { font-size: 14px; color: var(--ash); line-height: 1.9; margin-bottom: 40px; max-width: 310px; }
.contact-details { display: flex; flex-direction: column; }
.contact-detail-item { display: flex; flex-direction: column; gap: 3px; padding: 16px 0; border-top: 1px solid rgba(255,255,255,.05); transition: padding-left .45s var(--ease-expo); position: relative; }
.contact-detail-item::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 1px; background: linear-gradient(to bottom, transparent, var(--prism), transparent); transform: scaleY(0); transform-origin: center; transition: transform .45s var(--ease-expo); }
.contact-detail-item:hover { padding-left: 14px; }
.contact-detail-item:hover::before { transform: scaleY(1); }
.detail-label { font-size: 8px; letter-spacing: .38em; text-transform: uppercase; color: var(--smoke); }
.detail-value { font-size: 14px; color: var(--chrome); transition: color .3s; }
.contact-detail-item:hover .detail-value { color: var(--white); }

.inquiry-form { display: flex; flex-direction: column; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.form-field { position: relative; padding-bottom: 2px; border-bottom: 1px solid rgba(255,255,255,.05); margin-bottom: 4px; transition: border-color .3s; }
.form-field--full { grid-column: 1 / -1; }
.form-field label { display: block; font-size: 8px; letter-spacing: .35em; text-transform: uppercase; color: var(--smoke); padding-top: 20px; margin-bottom: 8px; transition: color .3s; }
.form-field label span { color: var(--prism); }
.form-field:focus-within label { color: var(--chrome); }
.form-field input, .form-field textarea, .form-field select { width: 100%; font-size: 14px; font-weight: 300; color: var(--white); padding-bottom: 14px; resize: none; }
.form-field input::placeholder, .form-field textarea::placeholder { color: rgba(255,255,255,.1); }
.form-field select { color: rgba(255,255,255,.32); }
.form-field select.has-value { color: var(--white); }
.field-line { position: absolute; bottom: -1px; left: 0; width: 0; height: 1px; background: linear-gradient(to right, var(--prism), var(--electric), var(--prism2)); transition: width .65s var(--ease-expo); }
.form-field:focus-within .field-line { width: 100%; }
.form-field:focus-within { border-color: rgba(123,140,222,.18); }
.form-field:focus-within::after { content: ''; position: absolute; bottom: -1px; left: 0; right: 0; height: 16px; background: linear-gradient(to top, rgba(123,140,222,.035), transparent); pointer-events: none; }
.form-error { font-size: 12px; color: rgba(255,100,100,.75); padding: 10px 0; letter-spacing: .04em; }
.contact-success { text-align: center; padding: 80px 40px; border: 1px solid rgba(123,140,222,.14); }
.success-icon { font-size: 18px; color: var(--prism); margin-bottom: 18px; }
.success-message { font-family: var(--font-serif); font-size: clamp(1.4rem, 3vw, 2.4rem); font-weight: 400; color: var(--white); margin-bottom: 10px; }
.success-body { font-size: 13px; color: var(--ash); }
.btn-submit { margin-top: 44px; width: fit-content; }
.btn-loading { display: inline-flex; align-items: center; gap: 3px; }
.loading-dot { width: 4px; height: 4px; background: currentColor; border-radius: 50%; animation: dot-pulse 1.2s ease infinite; }
.loading-dot:nth-child(2) { animation-delay: .2s; }
.loading-dot:nth-child(3) { animation-delay: .4s; }
@keyframes dot-pulse { 0%, 80%, 100% { opacity: .3; } 40% { opacity: 1; } }

/* ── 404 ── */
.error-404 { position: relative; overflow: hidden; min-height: 100svh; display: flex; align-items: center; padding: 0 var(--pad); }
#error-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.error-vignette { position: absolute; inset: 0; z-index: 1; background: radial-gradient(ellipse 80% 70% at 50% 50%, rgba(6,6,8,.32), rgba(6,6,8,.92)); }
.error-prism { position: absolute; z-index: 1; width: 1px; height: 65vh; top: 18vh; left: 58%; background: linear-gradient(to bottom, transparent, rgba(123,140,222,.26), rgba(79,195,247,.13), transparent); filter: blur(.8px); animation: prism-float 9s ease-in-out infinite; }
@keyframes prism-float { 0%, 100% { transform: translateX(0) skewX(-1deg); opacity: .5; } 50% { transform: translateX(-14px) skewX(1.5deg); opacity: 1; } }
.error-inner { position: relative; z-index: 2; max-width: 580px; }
.error-heading { font-family: var(--font-serif); font-size: clamp(1.8rem, 4.5vw, 4rem); font-weight: 400; color: var(--white); line-height: 1.1; margin-bottom: 18px; }
.error-sub { font-size: 14px; color: var(--ash); margin-bottom: 44px; }

/* ── PAGE CTA STRIP ── */
.page-cta-strip { padding: clamp(56px, 7vw, 96px) var(--pad); border-top: 1px solid rgba(255,255,255,.04); }
.page-cta-inner { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }

/* ── GENERIC PAGE ── */
.generic-page { padding: clamp(120px, 16vh, 180px) var(--pad) var(--section-v); }
.page-title { font-family: var(--font-serif); font-size: clamp(2rem, 5vw, 4rem); font-weight: 400; color: var(--white); margin-bottom: 40px; }
.page-content { font-size: 15px; color: var(--ash); line-height: 1.95; max-width: 720px; }
.page-content h2, .page-content h3 { font-family: var(--font-serif); color: var(--white); margin: 32px 0 14px; }
.page-content p { margin-bottom: 20px; }
.page-content a { color: var(--prism); text-decoration: underline; text-decoration-color: rgba(123,140,222,.3); }

/* ── FOOTER ── */
#site-footer { background: var(--void); border-top: 1px solid rgba(255,255,255,.035); padding: clamp(64px, 8vw, 110px) var(--pad) 40px; position: relative; overflow: hidden; }
#site-footer::before { content: ''; position: absolute; top: 0; left: 10%; right: 10%; height: 1px; background: linear-gradient(to right, transparent, rgba(182,188,196,.1), rgba(123,140,222,.2), rgba(79,195,247,.1), rgba(123,140,222,.2), rgba(182,188,196,.1), transparent); }
.footer-inner { display: grid; grid-template-columns: 1.5fr 2fr 1fr; gap: 64px; margin-bottom: 60px; }
.footer-logo { font-family: var(--font-serif); font-size: 18px; font-weight: 400; letter-spacing: .3em; text-transform: uppercase; color: var(--white); margin-bottom: 10px; display: block; transition: color .4s; }
.footer-logo:hover { color: var(--chrome); }
.footer-tagline { font-size: 11px; color: var(--smoke); line-height: 1.85; }
.footer-menu { display: flex; flex-wrap: wrap; gap: 6px 22px; }
.footer-menu li a { font-size: 11px; color: var(--ash); letter-spacing: .05em; transition: color .4s var(--ease-silk); }
.footer-menu li a:hover { color: var(--white); }
.footer-contact { display: flex; flex-direction: column; gap: 10px; }
.footer-contact-label { font-size: 8px; letter-spacing: .4em; text-transform: uppercase; color: var(--smoke); margin-bottom: 4px; }
.footer-email, .footer-phone, .footer-inquiry-link { font-size: 12px; color: var(--ash); transition: color .4s var(--ease-silk); letter-spacing: .04em; }
.footer-email:hover, .footer-phone:hover { color: var(--white); }
.footer-inquiry-link { color: var(--prism); margin-top: 2px; font-size: 11px; }
.footer-inquiry-link:hover { color: var(--electric); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.035); flex-wrap: wrap; gap: 10px; }
.footer-copy, .footer-loc { font-size: 9px; color: var(--smoke); letter-spacing: .12em; }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
    /* Nav: hide desktop nav, show hamburger */
    .primary-nav { display: none; }
    /* Services */
    .service-slab { grid-template-columns: 28px 1fr auto; }
    .slab-desc { display: none; }
    .service-module-body { grid-template-columns: 1fr 1fr; padding-left: 0; }
    /* Worlds page module */
    .world-module { grid-template-columns: 1fr; }
    .world-module-visual-panel { display: none; }
    /* Footer */
    .footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
    .philosophy-grid { grid-template-columns: 1fr; gap: 36px; }
    .contact-grid { grid-template-columns: 1fr; gap: 52px; }
    .service-module-body { grid-template-columns: 1fr; padding-left: 0; }
    .process-module { grid-template-columns: 1fr; gap: 20px; }
    .process-module-aside { flex-direction: row; }
    .process-connector { display: none; }
    .world-module-body { grid-template-columns: 1fr; gap: 24px; }
}
@media (max-width: 768px) {
    .hero-sub { max-width: 100%; }
    .hero-actions { flex-direction: column; align-items: flex-start; }
    .footer-inner { grid-template-columns: 1fr; gap: 36px; }
    .form-row { grid-template-columns: 1fr; }
    .service-slab { grid-template-columns: 1fr auto; }
    .slab-num { display: none; }
    /* Grids — stack to 1 col on mobile */
    .worlds-grid { grid-template-columns: 1fr !important; }
    .experiments-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .failure-grid { grid-template-columns: 1fr !important; }
    .exp-items { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 480px) {
    .experiments-grid { grid-template-columns: 1fr !important; }
    .exp-items { grid-template-columns: 1fr !important; }
    .page-cta-inner { flex-direction: column; align-items: stretch; }
    .page-cta-inner .btn { justify-content: center; }
    .footer-bottom { flex-direction: column; text-align: center; }
}
@media (max-width: 360px) {
    :root { --pad: 18px; }
    .hero-heading { font-size: 2.6rem; }
    .btn { padding: 13px 22px; }
}

:focus-visible { outline: 2px solid var(--prism); outline-offset: 3px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; } }
