/* ════════════════════════════════════════════
   SHATTERED INDIGO v7 — Final
   Sloane Indigo Studio
   ════════════════════════════════════════════ */

:root {
  --void:    #0A0B10;
  --shadow:  #14141A;
  --panel:   #1C1C24;
  --indigo:  #3F48CC;
  --indigo2: #6366f1;
  --purple:  #2E1065;
  --haunt:   #C4A6E0;
  --copper:  #E8763A;
  --copper-glow: rgba(232, 118, 58, 0.35);
  --cream:   #F8E8D4;
  --text:    #F8FAFC;
  --silver:  #F1F5F9;
  --dim:     #C5CFE0;
  --border:  rgba(63,72,204,0.25);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--void);
  color: var(--text);
  font-family: 'Inter', sans-serif;
  font-weight: 300;
  overflow-x: hidden;
  cursor: none;
  -webkit-font-smoothing: antialiased;
}

/* ── GLOBAL GRAIN ── */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: 9000;
  pointer-events: none; opacity: 0.025;
  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.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px;
}

/* ── CRT SCANLINES ── */
body::after {
  content: '';
  position: fixed; inset: 0; z-index: 8999;
  pointer-events: none;
  background: repeating-linear-gradient(
    0deg, transparent, transparent 2px,
    rgba(0,0,0,0.012) 2px, rgba(0,0,0,0.012) 4px
  );
}

/* ── CURSOR — Shard Style ── */
#cur {
  position: fixed; width: 22px; height: 22px;
  pointer-events: none; z-index: 9999;
  transform: translate(-50%, -50%) rotate(0deg);
  transition: width .25s, height .25s, opacity .25s;
  filter: drop-shadow(0 0 10px rgba(196,166,224,0.8))
          drop-shadow(0 0 22px rgba(196,166,224,0.4));
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpolygon points='12,1 19,9 14,22 6,17 4,6' fill='%23C4A6E0' stroke='%23ffffff' stroke-width='0.6' stroke-linejoin='miter'/%3E%3Cpolygon points='12,1 19,9 14,22' fill='%23A07CC5' opacity='0.6'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}
#cur.big {
  width: 48px; height: 48px;
  filter: drop-shadow(0 0 18px rgba(63,72,204,0.95))
          drop-shadow(0 0 36px rgba(63,72,204,0.5));
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpolygon points='12,1 19,9 14,22 6,17 4,6' fill='%233F48CC' stroke='%23ffffff' stroke-width='0.7' stroke-linejoin='miter'/%3E%3Cpolygon points='12,1 19,9 14,22' fill='%236366f1' opacity='0.7'/%3E%3C/svg%3E");
  animation: shardVibrate 0.6s ease-in-out infinite;
}
@keyframes shardVibrate {
  0%, 100% { transform: translate(-50%, -50%) rotate(var(--rot, 0deg)); }
  25% { transform: translate(-50%, -50%) rotate(calc(var(--rot, 0deg) + 2deg)) scale(1.03); }
  75% { transform: translate(-50%, -50%) rotate(calc(var(--rot, 0deg) - 2deg)) scale(1.03); }
}
#trail {
  position: fixed; width: 38px; height: 38px;
  border: 1px solid rgba(196,166,224,.3); border-radius: 50%;
  pointer-events: none; z-index: 9998;
  transform: translate(-50%, -50%);
}
/* Click burst shards — explode outward from click point */
.click-shard {
  position: fixed; pointer-events: none;
  z-index: 9997;
  width: 18px; height: 18px;
  transform: translate(-50%, -50%);
  filter: drop-shadow(0 0 8px rgba(63,72,204,0.8));
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpolygon points='10,1 16,8 12,18 6,14 4,5' fill='%233F48CC' stroke='%23ffffff' stroke-width='0.6'/%3E%3C/svg%3E");
  background-size: contain; background-repeat: no-repeat;
  animation: shardBurst 0.85s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
@keyframes shardBurst {
  0% {
    opacity: 1;
    transform: translate(-50%, -50%) translate(0, 0) rotate(var(--start-rot, 0deg)) scale(0.4);
  }
  30% {
    opacity: 1;
    transform: translate(-50%, -50%) translate(calc(var(--dx) * 0.6), calc(var(--dy) * 0.6)) rotate(var(--end-rot, 180deg)) scale(1.1);
  }
  100% {
    opacity: 0;
    transform: translate(-50%, -50%) translate(var(--dx), var(--dy)) rotate(var(--end-rot, 360deg)) scale(0.7);
  }
}

/* ── FRACTURE RING ── */
.f-ring {
  position: fixed; border: 1.5px solid var(--indigo);
  pointer-events: none; z-index: 9997;
  transform: translate(-50%,-50%) scale(0) rotate(45deg);
  opacity: .8;
  animation: fracture .6s ease-out forwards;
}
@keyframes fracture {
  0% { transform: translate(-50%,-50%) scale(0) rotate(45deg); opacity: .8; width: 10px; height: 10px; }
  100% { transform: translate(-50%,-50%) scale(1) rotate(45deg); opacity: 0; width: 110px; height: 110px; }
}

/* ── GLITCH FLASH ── */
#gf {
  position: fixed; inset: 0; background: var(--indigo);
  z-index: 8998; opacity: 0; pointer-events: none;
  transition: opacity .04s;
}
#gf.pop { opacity: .055; }

/* ── NAV ── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  padding: 1.2rem 3rem;
  display: flex; justify-content: space-between; align-items: center;
  backdrop-filter: blur(20px) saturate(0.5);
  -webkit-backdrop-filter: blur(20px) saturate(0.5);
  background: rgba(10,11,16,0.7);
  border-bottom: 1px solid var(--border);
}
.nav-logo {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.4rem; letter-spacing: .06em;
  color: var(--text); text-decoration: none;
}
.nav-logo .dot { color: var(--indigo); letter-spacing: 0; }
.nav-links { display: flex; gap: 2.2rem; list-style: none; }
.nav-links a {
  font-size: .82rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--silver); text-decoration: none; font-weight: 500;
  transition: color .3s;
}
.nav-links a:hover { color: var(--indigo); }

/* ════════════════════════════════════════════
   CRACKED LETTERS — Real Crack-Through Effect
   ════════════════════════════════════════════ */
.cracked {
  position: relative;
  display: inline-block;
  filter: url(#cracks);
}
.cracked-stroke {
  -webkit-text-stroke: 2px var(--indigo);
  color: transparent;
  position: relative;
  filter: drop-shadow(0 0 25px rgba(63,72,204,0.6))
          drop-shadow(0 0 50px rgba(63,72,204,0.3));
}
.cracked-stroke::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  -webkit-text-stroke: 2px var(--indigo);
  color: transparent;
  pointer-events: none;
}
/* Hero specific */
.hero-title .cracked-stroke {
  -webkit-text-stroke: 1.5px var(--indigo);
}
/* Contact specific - white stroke */
.c-head .cracked-white {
  -webkit-text-stroke: 2.5px #fff;
  color: transparent;
  display: block;
  filter: url(#cracks-white) drop-shadow(0 0 20px rgba(255,255,255,0.4));
}
/* Manifesto specific - white stroke outline */
.manifesto-words .cracked-manifesto {
  display: inline-block;
  -webkit-text-stroke: 1.8px var(--text);
  color: transparent;
  filter: url(#cracks-white);
}

/* ════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════ */
#hero {
  height: 100vh; min-height: 700px;
  position: relative; overflow: hidden;
  background: var(--void);
  padding-bottom: 4rem;
}
#hero-canvas {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  z-index: 1;
}
.hero-fallback {
  display: none;
  position: absolute; inset: 0; z-index: 1;
  background: radial-gradient(circle at center, rgba(63,72,204,0.4) 0%, rgba(46,16,101,0.3) 30%, var(--void) 75%);
}
.hero-fallback.show { display: block; }

#hero-text {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -58%);
  z-index: 3; text-align: center;
  width: 90%; max-width: 800px;
  opacity: 0;
}
#hero-text.reveal { opacity: 1; }

.hero-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(3rem, 11vw, 10rem);
  line-height: .92;
  letter-spacing: .04em;
  color: var(--indigo);
  text-shadow:
    0 0 30px rgba(63,72,204,.6),
    0 0 60px rgba(63,72,204,.3),
    0 0 90px rgba(46,16,101,.4);
  position: relative;
}
.hero-title .hero-logo-image {
  display: block;
  width: 100%;
  max-width: 720px;
  height: auto;
  margin: 0 auto;
  filter: drop-shadow(0 0 50px rgba(63,72,204,0.7))
          drop-shadow(0 0 100px rgba(63,72,204,0.4));
}

.hero-method {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: clamp(1rem, 2vw, 1.4rem);
  color: var(--haunt);
  letter-spacing: .25em;
  margin-top: 1.25rem;
  text-transform: uppercase;
}

.hero-sub {
  margin-top: 1.5rem;
  font-size: 1rem; line-height: 1.85;
  color: var(--dim); max-width: 460px;
  margin-left: auto; margin-right: auto;
}
.hero-sub strong { color: var(--silver); font-weight: 400; }

.hero-cta {
  margin-top: 2.25rem;
  display: flex; gap: 1.5rem;
  justify-content: center; flex-wrap: wrap;
}

.btn {
  font-size: .75rem; letter-spacing: .18em; text-transform: uppercase;
  font-weight: 500; text-decoration: none;
  font-family: 'Inter', sans-serif;
  padding: .9rem 2.2rem;
  display: inline-block; transition: all .3s;
}
.btn-solid {
  background: var(--indigo); color: #fff;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
}
.btn-solid:hover { background: var(--indigo2); transform: translateY(-2px); }
.btn-outline {
  color: var(--silver); border: 1px solid var(--border);
}
.btn-outline:hover { color: var(--text); border-color: var(--indigo); }

.hero-signature {
  position: absolute; bottom: 2rem; left: 3rem;
  z-index: 4;
  font-family: 'Bebas Neue', sans-serif;
  font-size: .7rem;
  letter-spacing: 0.3em;
  color: var(--silver);
  text-transform: uppercase;
  opacity: 0;
  animation: sigIn 1s ease 3s forwards;
}
.hero-signature .indigo-mark { color: var(--indigo); }

.hero-scroll {
  position: absolute; bottom: 2rem; right: 3rem; z-index: 4;
  font-size: .65rem; letter-spacing: .25em; text-transform: uppercase;
  color: var(--dim);
  display: flex; align-items: center; gap: .7rem;
  opacity: 0;
  animation: sigIn 1s ease 3.3s forwards;
}
.scroll-line {
  width: 40px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--indigo));
  animation: pulse 2s ease infinite;
}
@keyframes sigIn { to { opacity: 1; } }
@keyframes pulse { 50% { opacity: .3; } }

.line {
  position: relative;
  width: 100%; height: 14px;
  overflow: visible;
  opacity: .85;
}
.line::before, .line::after {
  content: '';
  position: absolute;
  left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--indigo) 30%, var(--haunt) 60%, transparent);
}
.line::before { top: 50%; opacity: .35; }
.line::after { display: none; }
/* Crack SVG injected into .line via JS draws on scroll-in */
.line .fault-svg {
  position: absolute;
  left: 0; top: 50%; transform: translateY(-50%);
  width: 100%; height: 12px;
  overflow: visible;
  pointer-events: none;
  opacity: 0;
}
.line.fired .fault-svg { opacity: 1; }
.line .fault-svg path {
  fill: none;
  stroke: var(--haunt);
  stroke-width: 1;
  stroke-linecap: round;
  stroke-dasharray: var(--len, 1000);
  stroke-dashoffset: var(--len, 1000);
  filter: drop-shadow(0 0 3px rgba(196,166,224,0.4));
  transition: stroke-dashoffset 1.2s cubic-bezier(.2,.7,.3,1);
}
.line.fired .fault-svg path {
  stroke-dashoffset: 0;
}

/* ════════════════════════════════════════════
   SHATTER SLIDER
   ════════════════════════════════════════════ */
#inverse {
  background: var(--void);
  padding: 6rem 3rem;
  position: relative;
}
.s-label {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: 1.25rem;
  font-weight: 400;
  color: var(--haunt); letter-spacing: .25em;
  text-transform: uppercase; margin-bottom: 1rem; display: block;
  text-shadow: 0 0 12px rgba(196,166,224,0.3);
}
.s-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  line-height: .95; letter-spacing: .03em;
  color: var(--text); margin-bottom: 1rem;
  text-align: center;
}
.s-title .ghost { -webkit-text-stroke: 1px var(--indigo); color: transparent; }
.s-title .lit { color: var(--indigo); }

/* Big Shoulders for keyword emphasis */
.bigshoulder {
  font-family: 'Big Shoulders Display', sans-serif;
  font-weight: 800;
  letter-spacing: 0;
}

.s-subtitle {
  text-align: center;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: 1.2rem; font-weight: 400;
  color: var(--silver); max-width: 600px;
  margin: 0 auto 3rem;
  line-height: 1.8;
}
.shatter-stage {
  max-width: 900px; margin: 0 auto;
  position: relative;
  border: 1px solid var(--border);
  background: var(--shadow);
  clip-path: polygon(0 0, calc(100% - 24px) 0, 100% 24px, 100% 100%, 24px 100%, 0 calc(100% - 24px));
  overflow: hidden;
}
.shatter-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16/10;
  user-select: none;
  cursor: ew-resize;
  background: var(--shadow);
}
.shatter-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: contain;
  pointer-events: none;
  background: var(--shadow);
}
.shatter-img.hi {
  z-index: 2;
  clip-path: polygon(50% 0, 100% 0, 100% 100%, 50% 100%);
  transition: clip-path .05s linear;
}
.shatter-divider {
  position: absolute; top: 0; bottom: 0;
  left: 50%;
  width: 2px;
  background: var(--indigo);
  z-index: 3;
  box-shadow: 0 0 20px rgba(63,72,204,.6);
  pointer-events: none;
}
.shatter-handle {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 56px; height: 56px;
  background: var(--indigo);
  border: 2px solid var(--text);
  z-index: 4;
  display: flex; align-items: center; justify-content: center;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  pointer-events: none;
  box-shadow: 0 0 30px rgba(63,72,204,.7);
}
.shatter-handle::before {
  content: '⇆';
  color: #fff;
  font-size: 1.3rem;
  font-weight: bold;
}
.shatter-labels {
  display: flex; justify-content: space-between;
  padding: 1.2rem 1.8rem;
  font-family: 'Bebas Neue', sans-serif;
  font-size: .9rem; letter-spacing: .18em;
  color: var(--dim);
  background: var(--shadow);
  border-top: 1px solid var(--border);
}
.shatter-labels .left { color: var(--silver); }
.shatter-labels .right { color: var(--indigo); }
.shatter-instruction {
  text-align: center;
  margin-top: 1.5rem;
  font-size: .8rem;
  color: var(--dim);
  letter-spacing: .15em;
  text-transform: uppercase;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
}

/* ════════════════════════════════════════════
   WORK
   ════════════════════════════════════════════ */
#work {
  background: var(--void);
  padding: 6rem 3rem;
}
.proj-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2px;
  background: var(--border);
  border: 1px solid var(--border);
  margin-top: 3rem;
}
.proj-card {
  background: var(--void);
  position: relative; overflow: hidden;
  cursor: none; transition: background .4s;
}
.proj-card:hover { background: var(--shadow); }
.proj-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--indigo), transparent);
  opacity: 0; transition: opacity .4s;
}
.proj-card:hover::before { opacity: 1; }
.proj-card::after {
  content: ''; position: absolute; top: 0; right: 0;
  width: 0; height: 0;
  border-top: 20px solid var(--indigo);
  border-left: 20px solid transparent;
  opacity: 0; transition: opacity .3s;
}
.proj-card:hover::after { opacity: .5; }
.proj-img {
  width: 100%; aspect-ratio: 16/9;
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
  clip-path: polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 0 100%);
}
.proj-img iframe {
  width: 100%; height: 100%; border: none; pointer-events: none;
  filter: saturate(.65) brightness(.78);
  transition: filter .5s, transform .5s;
}
.proj-card:hover .proj-img iframe {
  filter: saturate(.95) brightness(1);
  transform: scale(1.04);
}
.proj-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(10,11,16,.95) 100%);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .3s; z-index: 2;
}
.proj-card:hover .proj-overlay { opacity: 1; }
.view-btn {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1rem; letter-spacing: .2em;
  color: var(--indigo); border: 1px solid var(--border);
  padding: .6rem 1.5rem; backdrop-filter: blur(8px);
}
.proj-placeholder {
  width: 100%; aspect-ratio: 16/9;
  display: flex; align-items: center; justify-content: center;
  background: var(--panel);
  clip-path: polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 0 100%);
  position: relative; overflow: hidden;
}
.proj-placeholder::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(63,72,204,.08) 0%, transparent 60%);
}
.proj-placeholder img {
  max-width: 200px; width: 75%; opacity: .95;
  position: relative; z-index: 1;
}
.proj-body { padding: 2rem 2.5rem 2.5rem; }
.proj-tag {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-size: 1.1rem; font-weight: 400;
  color: var(--haunt); letter-spacing: .12em;
  display: block; margin-bottom: .6rem;
  text-shadow: 0 0 10px rgba(196,166,224,0.25);
}
.proj-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 2.2rem; letter-spacing: .04em;
  color: var(--text); margin-bottom: .8rem;
  transition: color .3s;
}
.proj-card:hover .proj-name { color: #fff; }
.proj-desc {
  font-size: .9rem; line-height: 1.9;
  color: var(--dim); margin-bottom: 1.5rem;
}
.pills { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.pill {
  font-size: .7rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--indigo2); border: 1px solid rgba(99,102,241,.4);
  padding: .25rem .7rem; font-weight: 500;
}
.proj-links { display: flex; gap: 1.2rem; flex-wrap: wrap; }
.plink {
  font-size: .72rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--dim); text-decoration: none; font-weight: 400;
  transition: color .3s; display: flex; align-items: center; gap: .4rem;
}
.plink:hover { color: var(--indigo); }
.wip {
  font-size: .58rem; letter-spacing: .15em; text-transform: uppercase;
  background: rgba(160,124,197,.15); color: var(--haunt);
  border: 1px solid rgba(160,124,197,.3);
  padding: .15rem .5rem; margin-left: .6rem; vertical-align: middle;
}
.proj-card.wide {
  grid-column: 1 / -1;
  display: grid; grid-template-columns: 1fr 1fr;
  align-items: stretch;
}
.proj-card.wide .proj-img {
  aspect-ratio: auto; height: 100%; min-height: 320px;
  clip-path: polygon(0 0, calc(100% - 24px) 0, 100% 24px, 100% 100%, 0 100%);
}
.proj-card.wide .proj-img iframe { height: 100%; }
.proj-card.wide .proj-body { padding: 3rem; }

/* ════════════════════════════════════════════
   SERVICES — THE OFFERINGS
   ════════════════════════════════════════════ */
#offerings {
  background: var(--shadow);
  padding: 6rem 3rem;
  position: relative;
}
/* v15/v16: subtle distress overlay — using screen blend so it shows on dark backgrounds */
#offerings::before, #specialty::before, #currently::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .18;
  z-index: 0;
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='320' height='320' viewBox='0 0 320 320'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.55 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 320px 320px;
  mix-blend-mode: screen;
}
#offerings > *, #specialty > *, #currently > * { position: relative; z-index: 1; }
.offerings-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: var(--border);
  border: 1px solid var(--border);
  margin-top: 3rem;
  max-width: 1300px;
  margin-left: auto;
  margin-right: auto;
}
.offer-card {
  background: var(--void);
  padding: 3rem 2.5rem 3.5rem;
  position: relative; overflow: hidden;
  transition: background .4s;
}
.offer-card::before {
  content: ''; position: absolute; 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.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px; opacity: .04; pointer-events: none;
}
.offer-card:hover {
  background: var(--shadow);
  box-shadow: 0 0 30px rgba(63,72,204,.15);
}
.offer-num {
  font-family: 'Big Shoulders Display', sans-serif;
  font-weight: 900;
  font-size: 4rem;
  color: transparent;
  -webkit-text-stroke: 1px var(--border);
  display: block;
  margin-bottom: 1.5rem;
  line-height: 1;
  transition: -webkit-text-stroke-color .3s;
}
.offer-card:hover .offer-num { -webkit-text-stroke-color: rgba(63,72,204,.5); }
.offer-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.8rem; letter-spacing: .06em;
  color: var(--text); margin-bottom: .4rem;
}
.offer-sub {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: 1.2rem; font-weight: 400;
  color: var(--text); letter-spacing: .08em;
  margin-bottom: 1.5rem; display: block;
  text-shadow: 0 0 12px rgba(248,250,252,0.2);
}
.offer-desc {
  font-size: .88rem; line-height: 1.9;
  color: var(--dim); margin-bottom: 2rem;
}
.offer-btn {
  display: inline-block;
  font-size: .75rem; letter-spacing: .18em; text-transform: uppercase;
  font-family: 'Inter', sans-serif; font-weight: 600;
  color: #fff; text-decoration: none;
  background: var(--indigo);
  padding: 1rem 2.2rem;
  margin-top: .8rem;
  transition: all .3s;
  position: relative; z-index: 1;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
  box-shadow: 0 0 25px rgba(63,72,204,0.4);
}
.offer-btn:hover {
  background: var(--indigo2);
  transform: translateY(-2px);
  box-shadow: 0 4px 30px rgba(63,72,204,0.6);
}

/* ════════════════════════════════════════════
   SPECIALTY SERVICES — Productized À la Carte
   ════════════════════════════════════════════ */
#specialty {
  background: var(--void);
  padding: 5rem 3rem;
  position: relative;
}
.specialty-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  max-width: 1100px;
  margin: 3rem auto 0;
}
.specialty-card {
  background: var(--shadow);
  border: 1px solid var(--border);
  padding: 2rem 2rem 2.4rem;
  position: relative;
  overflow: hidden;
  transition: border-color .35s, background .35s, transform .3s;
}
.specialty-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--indigo), transparent);
  opacity: 0;
  transition: opacity .4s;
}
.specialty-card:hover {
  border-color: rgba(63,72,204,.5);
  background: rgba(28,28,36,0.95);
  transform: translateY(-3px);
}
.specialty-card:hover::before { opacity: 1; }
.specialty-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.6rem; letter-spacing: .06em;
  color: var(--text); margin-bottom: .8rem;
}
.specialty-desc {
  font-size: .9rem; line-height: 1.7;
  color: var(--silver); margin-bottom: 1.5rem;
}
.specialty-btn {
  display: inline-block;
  font-size: .68rem; letter-spacing: .18em; text-transform: uppercase;
  font-family: 'Inter', sans-serif; font-weight: 500;
  color: var(--silver); text-decoration: none;
  border: 1px solid var(--border);
  padding: .7rem 1.6rem;
  margin-top: .6rem;
  transition: all .3s;
}
.specialty-btn:hover {
  background: var(--indigo);
  border-color: var(--indigo);
  color: #fff;
}

@media (max-width: 768px) {
  .specialty-grid { grid-template-columns: 1fr; }
}


#about {
  background: var(--void);
  padding: 6rem 3rem;
  position: relative; overflow: hidden;
}
#about::after {
  content: '';
  position: absolute; width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(160,124,197,.06) 0%, transparent 65%);
  bottom: -150px; right: -150px; pointer-events: none;
}
.about-grid {
  display: grid; grid-template-columns: 1fr 1.5fr;
  gap: 6rem; align-items: start;
  max-width: 1300px; margin: 0 auto;
}
.about-name-block {
  font-family: 'Big Shoulders Display', sans-serif;
  font-weight: 900;
  font-size: clamp(2.5rem, 6vw, 5rem);
  line-height: .95;
  color: var(--text);
  letter-spacing: -0.01em;
}
.about-name-block .lit {
  color: var(--indigo);
  text-shadow: 0 0 25px rgba(63,72,204,.4);
}
.about-name-block .stroke {
  -webkit-text-stroke: 1.5px var(--indigo);
  color: transparent;
  display: block;
}
.about-role {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: 1.4rem; font-weight: 400;
  color: var(--haunt); letter-spacing: .15em;
  margin-top: 1.2rem; display: block;
  text-shadow: 0 0 12px rgba(196,166,224,0.3);
}
.about-quote {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: 1.3rem;
  line-height: 1.85; color: var(--silver);
  border-left: 2px solid var(--indigo);
  padding-left: 1.3rem; margin-top: 2.5rem;
}
.about-p {
  font-size: .95rem; line-height: 2.1;
  color: var(--dim); margin-bottom: 1.3rem;
}
.about-p strong { color: var(--silver); font-weight: 400; }
.about-p em {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: 1.1rem;
  color: var(--text);
  font-weight: 400;
  text-shadow: 0 0 12px rgba(248,250,252,0.25);
}
.skills {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1px; background: var(--border);
  border: 1px solid var(--border); margin-top: 2.5rem;
}
.skill {
  background: var(--shadow); padding: 1.1rem 1.4rem;
  font-size: .8rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--silver); font-weight: 400;
  transition: background .3s, color .3s;
}
.skill:hover { background: rgba(63,72,204,.1); color: #fff; }
.skill::before { content: '/ '; color: var(--indigo); font-weight: 600; }

/* ════════════════════════════════════════════
   MANIFESTO STRIP
   ════════════════════════════════════════════ */
.manifesto-strip {
  /* v15: desaturated — was pure purple, now blends into surrounding dark sections */
  background: linear-gradient(135deg, #2a1f5a 0%, #14122e 100%);
  padding: 4rem 3rem;
  text-align: center;
  position: relative; overflow: hidden;
}
.manifesto-strip::before {
  content: ''; position: absolute; 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.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px; opacity: .07; pointer-events: none;
}
.manifesto-words {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2.5rem, 6vw, 5rem);
  letter-spacing: .1em; color: var(--text);
  line-height: 1.1; position: relative; z-index: 1;
}
.manifesto-words em {
  font-style: normal;
  -webkit-text-stroke: 1.5px var(--text);
  color: transparent;
}
.manifesto-words .breakit {
  display: inline-block;
  position: relative;
  -webkit-text-stroke: 1.8px var(--text);
  color: transparent;
}

/* ════════════════════════════════════════════
   CURRENTLY — In Motion
   ════════════════════════════════════════════ */
#currently {
  background: var(--shadow);
  padding: 6rem 3rem;
  position: relative;
}
.currently-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  max-width: 1100px;
  margin: 3rem auto 0;
}
.currently-card {
  background: var(--void);
  border: 1px solid var(--border);
  padding: 2.2rem 2.2rem 2.6rem;
  position: relative;
  overflow: hidden;
  transition: border-color .35s, transform .3s;
}
.currently-card:hover {
  border-color: rgba(63,72,204,.5);
  transform: translateY(-3px);
}
.currently-status {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: .65rem;
  font-weight: 600;
  letter-spacing: .25em;
  text-transform: uppercase;
  padding: .35rem .8rem;
  margin-bottom: 1.3rem;
  border: 1px solid;
}
.status-live {
  color: #6FE3A8;
  border-color: rgba(111,227,168,.5);
  background: rgba(111,227,168,.08);
}
.status-rebuilding {
  color: var(--haunt);
  border-color: rgba(196,166,224,.5);
  background: rgba(196,166,224,.08);
}
.status-development {
  color: var(--copper);
  border-color: rgba(232,118,58,.5);
  background: rgba(232,118,58,.08);
}
.status-studio {
  color: var(--indigo2);
  border-color: rgba(99,102,241,.5);
  background: rgba(99,102,241,.08);
}
.currently-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.9rem;
  letter-spacing: .04em;
  color: var(--text);
  margin-bottom: .8rem;
}
.currently-desc {
  font-size: .92rem;
  line-height: 1.85;
  color: var(--silver);
  margin-bottom: 1.5rem;
}
.currently-link {
  font-family: 'Inter', sans-serif;
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--haunt);
  text-decoration: none;
  font-weight: 500;
  transition: color .3s;
}
.currently-link:hover { color: var(--indigo2); }

@media (max-width: 768px) {
  .currently-grid { grid-template-columns: 1fr; }
}


#contact {
  background: linear-gradient(135deg, #4D3D9E 0%, #3F48CC 50%, #5238A8 100%);
  padding: 8rem 3rem 6rem;
  position: relative; overflow: hidden;
  text-align: center;
}
/* Animated copper glow — the molten core */
#contact::before {
  content: ''; position: absolute;
  width: 80%; height: 80%;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(
    ellipse at center,
    rgba(232,118,58,0.35) 0%,
    rgba(232,118,58,0.18) 25%,
    rgba(232,118,58,0.05) 50%,
    transparent 75%
  );
  pointer-events: none;
  z-index: 0;
  animation: copperPulse 7s ease-in-out infinite;
  filter: blur(20px);
}
/* Grunge texture overlay on top of glow */
#contact::after {
  content: ''; position: absolute; inset: 0;
  background-image: url("https://i.postimg.cc/d1dkCr0p/Untitled-design-%284%29.png");
  background-size: cover;
  background-position: center;
  opacity: 0.22;
  pointer-events: none;
  filter: invert(1) hue-rotate(220deg) brightness(0.6);
  mix-blend-mode: multiply;
  z-index: 0;
}
@keyframes copperPulse {
  0%, 100% {
    opacity: 0.7;
    transform: translate(-50%, -50%) scale(1);
  }
  50% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.05);
  }
}
.contact-inner { position: relative; z-index: 2; }
.c-label {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  color: rgba(255,255,255,.85); font-size: 1rem;
  letter-spacing: .22em; text-transform: uppercase;
  margin-bottom: 1.5rem; display: block;
}
.c-head {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(4rem, 10vw, 9rem);
  line-height: .88; letter-spacing: .06em;
  color: transparent; -webkit-text-stroke: 2px #fff;
  margin-bottom: 1rem;
  /* v19: slower flicker — 12s/18s/24s for true ember breathing */
  animation:
    emberFlickerA 12s steps(20, end) infinite,
    emberFlickerB 18s ease-out infinite,
    emberFlickerC 24s linear infinite;
}
.c-head .cracked-line {
  display: block;
  position: relative;
  -webkit-text-stroke: 2.5px #fff;
  color: transparent;
  text-shadow:
    0 0 8px rgba(232,118,58,0.6),
    0 0 24px rgba(232,118,58,0.4),
    0 0 48px rgba(255,138,74,0.3);
}
@keyframes emberFlickerA {
  /* Sharp spike-and-decay pattern — flame catching, not heart beating */
  0%   { filter: drop-shadow(0 0 22px rgba(232,118,58,0.42)) brightness(1); }
  4%   { filter: drop-shadow(0 0 70px rgba(255,150,80,1.15)) brightness(1.7); }
  9%   { filter: drop-shadow(0 0 25px rgba(232,118,58,0.45)) brightness(0.95); }
  12%  { filter: drop-shadow(0 0 18px rgba(232,118,58,0.35)) brightness(0.88); }
  14%  { filter: drop-shadow(0 0 55px rgba(255,138,74,0.95)) brightness(1.45); }
  17%  { filter: drop-shadow(0 0 22px rgba(232,118,58,0.4)) brightness(1); }
  31%  { filter: drop-shadow(0 0 24px rgba(232,118,58,0.45)) brightness(1.02); }
  35%  { filter: drop-shadow(0 0 80px rgba(255,160,90,1.25)) brightness(1.8); }
  38%  { filter: drop-shadow(0 0 30px rgba(232,118,58,0.5)) brightness(1.05); }
  41%  { filter: drop-shadow(0 0 16px rgba(232,118,58,0.3)) brightness(0.82); }
  44%  { filter: drop-shadow(0 0 22px rgba(232,118,58,0.4)) brightness(0.98); }
  58%  { filter: drop-shadow(0 0 65px rgba(255,150,80,1.05)) brightness(1.55); }
  62%  { filter: drop-shadow(0 0 28px rgba(232,118,58,0.48)) brightness(1.05); }
  66%  { filter: drop-shadow(0 0 20px rgba(232,118,58,0.38)) brightness(0.92); }
  79%  { filter: drop-shadow(0 0 75px rgba(255,160,85,1.2)) brightness(1.7); }
  83%  { filter: drop-shadow(0 0 26px rgba(232,118,58,0.46)) brightness(1.03); }
  87%  { filter: drop-shadow(0 0 18px rgba(232,118,58,0.34)) brightness(0.88); }
  100% { filter: drop-shadow(0 0 22px rgba(232,118,58,0.42)) brightness(1); }
}
@keyframes emberFlickerB {
  /* Quick micro-stutters in opacity — bulb glitching */
  0%   { opacity: 1; }
  13%  { opacity: 1; }
  14%  { opacity: 0.78; }
  15%  { opacity: 1; }
  37%  { opacity: 1; }
  38%  { opacity: 0.82; }
  39%  { opacity: 1; }
  58%  { opacity: 1; }
  59%  { opacity: 0.74; }
  60%  { opacity: 0.92; }
  61%  { opacity: 1; }
  84%  { opacity: 1; }
  85%  { opacity: 0.8; }
  86%  { opacity: 1; }
  100% { opacity: 1; }
}
@keyframes emberFlickerC {
  /* Asymmetric text-shadow flutter on a third clock */
  0%, 100% { text-shadow: 0 0 8px rgba(232,118,58,0.6), 0 0 24px rgba(232,118,58,0.4); }
  23%      { text-shadow: 0 0 18px rgba(255,160,90,1), 0 0 44px rgba(255,138,74,0.85), 0 0 90px rgba(232,118,58,0.5); }
  29%      { text-shadow: 0 0 8px rgba(232,118,58,0.55), 0 0 22px rgba(232,118,58,0.38); }
  64%      { text-shadow: 0 0 16px rgba(255,150,80,0.95), 0 0 38px rgba(255,138,74,0.7), 0 0 80px rgba(232,118,58,0.42); }
  72%      { text-shadow: 0 0 10px rgba(232,118,58,0.65), 0 0 26px rgba(232,118,58,0.42); }
}

.c-sub {
  font-size: 1rem; color: rgba(255,255,255,.85);
  max-width: 460px; margin: 0 auto 1rem;
  line-height: 1.95;
}
.c-reassurance {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: .95rem;
  color: var(--cream);
  letter-spacing: .12em;
  margin: 0 auto 3rem;
  max-width: 440px;
}
.contact-links {
  display: flex; gap: 2rem; justify-content: center;
  flex-wrap: wrap; margin-bottom: 5rem; margin-top: 1rem;
}
.c-link {
  display: inline-block;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.4rem; letter-spacing: .18em;
  color: #14141A; text-decoration: none;
  background: var(--copper);
  padding: 1.4rem 3.5rem;
  transition: all .4s; position: relative; overflow: hidden;
  box-shadow: 0 0 50px var(--copper-glow),
              0 0 100px rgba(232,118,58,0.25);
  font-weight: 700;
  clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 14px 100%, 0 calc(100% - 14px));
}
.c-link::before {
  content: ''; position: absolute; inset: 0;
  background: #FFB088;
  transform: scaleX(0); transform-origin: left;
  transition: transform .4s ease;
  z-index: -1;
}
.c-link:hover::before { transform: scaleX(1); }
.c-link:hover {
  color: #14141A;
  transform: translateY(-3px);
  box-shadow: 0 8px 60px rgba(232,118,58,0.6),
              0 0 100px rgba(232,118,58,0.4);
}
.contact-sig {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.1rem; letter-spacing: .35em;
  color: rgba(255,255,255,.4);
  display: block; padding-bottom: 2rem;
}

/* ════════════════════════════════════════════
   WORN FOOTER
   ════════════════════════════════════════════ */
.worn-footer {
  background: #050609;
  padding: 3.5rem 3rem 1.5rem;
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--border);
}
.worn-footer::before {
  content: ''; position: absolute; 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='1.2' numOctaves='5' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 220px;
  opacity: 0.06;
  pointer-events: none;
}
.worn-footer::after {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 30%, rgba(63,72,204,0.06), transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(196,166,224,0.04), transparent 50%);
  pointer-events: none;
}
.worn-inner {
  position: relative; z-index: 1;
  max-width: 1200px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 3rem;
  align-items: center;
}
.worn-left {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.1rem; letter-spacing: .12em;
  color: var(--silver);
}
.worn-left .dot { color: var(--indigo); letter-spacing: 0; }
.worn-left .tag {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: .9rem;
  color: var(--haunt); letter-spacing: .15em;
  margin-top: .3rem;
}
.worn-center {
  text-align: center;
}
.worn-email {
  font-family: 'Big Shoulders Display', sans-serif;
  font-weight: 700;
  font-size: 1.2rem;
  letter-spacing: .04em;
  color: var(--text);
  text-decoration: none;
  border-bottom: 1px solid var(--indigo);
  padding-bottom: .3rem;
  transition: color .3s;
}
.worn-email:hover { color: var(--indigo); }
.worn-right {
  text-align: right;
  font-family: 'Inter', sans-serif;
  font-size: .68rem; letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--dim);
}
.worn-right .indigo-dot { color: var(--indigo); }
.worn-fine {
  position: relative; z-index: 1;
  margin-top: 2rem; padding-top: 1.5rem;
  border-top: 1px solid rgba(63,72,204,0.1);
  text-align: center;
  font-size: .65rem; letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(168,180,200,.5);
  font-family: 'Inter', sans-serif;
}

/* ════════════════════════════════════════════
   MODALS
   ════════════════════════════════════════════ */
.modal-bg {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(10,11,16,.85);
  backdrop-filter: blur(18px) saturate(0.6);
  -webkit-backdrop-filter: blur(18px) saturate(0.6);
  opacity: 0; pointer-events: none;
  transition: opacity .4s;
  display: flex; align-items: center; justify-content: center;
  padding: 2rem;
}
.modal-bg.open { opacity: 1; pointer-events: all; }
.modal {
  width: 100%; max-width: 1100px;
  background: rgba(28,28,36,0.85);
  backdrop-filter: blur(20px);
  border: 1px solid var(--indigo);
  box-shadow: 0 0 60px rgba(63,72,204,.3);
  padding: 2.5rem;
  clip-path: polygon(0 0, calc(100% - 24px) 0, 100% 24px, 100% 100%, 0 100%);
  transform: translateY(30px);
  transition: transform .4s;
  position: relative; max-height: 88vh; overflow-y: auto;
}
.modal-bg.open .modal { transform: translateY(0); }
.modal-close {
  position: absolute; top: 1.5rem; right: 1.5rem;
  font-family: 'Bebas Neue', sans-serif; font-size: .9rem;
  letter-spacing: .15em; color: var(--silver);
  background: none; border: 1px solid var(--border);
  padding: .3rem .8rem; cursor: none;
  transition: color .3s, border-color .3s;
}
.modal-close:hover { color: var(--indigo); border-color: var(--indigo); }
.modal-tag {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-size: .95rem; color: var(--haunt); letter-spacing: .15em;
  margin-bottom: .5rem; display: block;
}
.modal-title {
  font-family: 'Bebas Neue', sans-serif; font-size: 2.8rem;
  letter-spacing: .04em; color: var(--text); margin-bottom: 1rem;
}
.modal-desc {
  font-size: .92rem; line-height: 1.9; color: var(--dim);
  margin-bottom: 2rem; max-width: 680px;
}
.modal-frame {
  width: 100%; aspect-ratio: 16/9;
  border: 1px solid var(--border); background: var(--panel);
  margin-bottom: 2rem;
}
.modal-frame iframe { width: 100%; height: 100%; border: none; }
.modal-acts { display: flex; gap: 1rem; flex-wrap: wrap; }

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.on { opacity: 1; transform: translateY(0); }

/* ════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════ */
@media (max-width: 900px) {
  nav { padding: 1rem 1.5rem; }
  .nav-links { display: none; }
  #hero { padding: 0 1.5rem; }
  .hero-signature, .hero-scroll { left: 1.5rem; right: 1.5rem; bottom: 1rem; }
  .hero-scroll { display: none; }
  #inverse, #work, #about, #contact, #offerings { padding-left: 1.5rem; padding-right: 1.5rem; }
  .proj-grid { grid-template-columns: 1fr; }
  .proj-card.wide { grid-template-columns: 1fr; }
  .proj-card.wide .proj-img { height: 220px; }
  .about-grid { grid-template-columns: 1fr; gap: 3rem; }
  .offerings-grid { grid-template-columns: 1fr; }
  .contact-links { flex-direction: column; align-items: center; }
  .worn-inner { grid-template-columns: 1fr; gap: 1.5rem; text-align: center; }
  .worn-left, .worn-right { text-align: center; }
}

/* ════════════════════════════════════════════
   v16 — BUILT. BROKEN. REBUILT. footer animation
   Fires once on scroll-in. Built stays. Broken fractures. Rebuilt assembles.
   ════════════════════════════════════════════ */
.bbr-tagline {
  display: inline-block;
}
.bbr-word {
  display: inline-block;
  position: relative;
  vertical-align: baseline;
}

/* BUILT — stays solid, soft glow pulse only when sequence fires */
.bbr-tagline:not(.bbr-gsap).firing .bbr-built {
  animation: bbrBuiltGlow 1s ease-out forwards;
}
@keyframes bbrBuiltGlow {
  0%   { text-shadow: none; opacity: 1; }
  40%  { text-shadow: 0 0 0.35em rgba(196,166,224,0.7); opacity: 1; }
  100% { text-shadow: 0 0 0.1em rgba(196,166,224,0.25); opacity: 1; }
}

/* BROKEN — fractures: original drops/fades, duplicate (data-text) drifts opposite */
.bbr-broken::before {
  content: attr(data-text);
  position: absolute;
  left: 0; top: 0;
  opacity: 0;
  pointer-events: none;
  color: inherit;
}
.bbr-tagline:not(.bbr-gsap).firing .bbr-broken {
  animation: bbrBrokenSplitTop 1.8s cubic-bezier(.5,.1,.4,1) 0.6s forwards;
}
.bbr-tagline:not(.bbr-gsap).firing .bbr-broken::before {
  animation: bbrBrokenSplitBottom 1.8s cubic-bezier(.5,.1,.4,1) 0.6s forwards;
}
/* v19: em-based translation so break scales with text size */
@keyframes bbrBrokenSplitTop {
  0%   { transform: translate(0, 0) rotate(0); opacity: 1; }
  25%  { transform: translate(0, 0) rotate(0); opacity: 1; filter: drop-shadow(0 0 0.2em rgba(196,166,224,0.8)); }
  60%  { transform: translate(-0.18em, -0.12em) rotate(-2deg); opacity: 0.7; }
  100% { transform: translate(-0.30em, -0.22em) rotate(-3deg); opacity: 0.3; filter: none; }
}
@keyframes bbrBrokenSplitBottom {
  0%   { transform: translate(0, 0) rotate(0); opacity: 0; }
  25%  { transform: translate(0, 0) rotate(0); opacity: 0; }
  26%  { transform: translate(0, 0) rotate(0); opacity: 1; }
  60%  { transform: translate(0.20em, 0.15em) rotate(2.5deg); opacity: 0.7; }
  100% { transform: translate(0.34em, 0.25em) rotate(3.5deg); opacity: 0.4; }
}

/* REBUILT — letters fly in from random offsets and assemble */
.bbr-rebuilt .bbr-letter {
  display: inline-block;
  opacity: 0;
  transform: translate(var(--lx, 0), var(--ly, 0)) rotate(var(--lr, 0deg)) scale(0.7);
}
.bbr-tagline:not(.bbr-gsap).firing .bbr-rebuilt .bbr-letter {
  animation: bbrRebuiltAssemble 0.9s cubic-bezier(.2,.7,.3,1) forwards;
  animation-delay: calc(1.6s + var(--li, 0) * 60ms);
}
@keyframes bbrRebuiltAssemble {
  0%   { opacity: 0; transform: translate(var(--lx, 0), var(--ly, 0)) rotate(var(--lr, 0deg)) scale(0.7); }
  100% { opacity: 1; transform: translate(0, 0) rotate(0) scale(1); }
}

/* ════════════════════════════════════════════
   v20 — GSAP-driven BBR letter physics
   ════════════════════════════════════════════ */
.bbr-gsap-letter {
  display: inline-block;
  position: relative;
  will-change: transform, opacity;
}
/* Initial state for GSAP-managed letters — invisible until JS sets them */
.bbr-gsap .bbr-gsap-rebuilt-letter {
  opacity: 0;
}
