/* Unincorporated Media — v0.3 cinematic institutional refinement
   Palette: cobalt primary · auburn/maroon tracings · ink/paper/graphite ground */
:root{
  --ink:#0A0A0B;
  --paper:#F4F2EC;
  --bone:#E8E4D8;
  --graphite:#101218;
  --graphite-2:#161922;
  --slate-800:#22262E;
  --slate-700:#3A3D44;
  --slate-500:#6B7079;
  --slate-400:#8A8F97;
  --slate-300:#B5B9C1;
  --rule-dark:#1E222B;
  --rule-light:#dad6cb;

  /* Cobalt primary scale */
  --cobalt-50:#E8EDF6;
  --cobalt-200:#9EB1D9;
  --cobalt-400:#4F6FB3;
  --cobalt-500:#2E55A4;
  --cobalt:#1F47A0;       /* primary */
  --cobalt-700:#163887;
  --cobalt-900:#0E2660;
  --cobalt-ink:#091A45;

  /* Auburn / maroon — tracings only */
  --auburn:#9C3D26;
  --auburn-soft:#B65A3F;
  --maroon:#5E1F1A;
  --maroon-deep:#3F1411;

  --serif: "GT Sectra","Tiempos Headline","Source Serif Pro",Georgia,serif;
  --sans: "Söhne",Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;
  --mono: "Söhne Mono","JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --ease: cubic-bezier(0.2,0.0,0.0,1.0);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);font-size:16px;line-height:1.55;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body.graphite{background:var(--graphite);color:var(--paper)}
a{color:inherit;text-decoration:none}

/* ── ATMOSPHERIC HERO BACKGROUND ─────────────────
   Deep cobalt ink wash with hairline lattice — institutional, not gradient-y */
.atmos{
  position:absolute;inset:0;overflow:hidden;pointer-events:none;
  background:
    radial-gradient(1200px 600px at 20% 30%, rgba(31,71,160,0.18), transparent 60%),
    radial-gradient(900px 500px at 85% 70%, rgba(94,31,26,0.10), transparent 65%),
    linear-gradient(180deg, #0B0E16 0%, #101218 60%, #0B0E16 100%);
}
/* v0.3.3 — cinematic texture (heavily blurred abstract media operations).
   v0.3.5 — promoted ABOVE the procedural canvas (z-index:2). Opacity & contrast
   raised one more step. Still institutionally restrained: typography pocket
   preserved via the radial mask. */
.atmos .tex{
  position:absolute;inset:-4%;
  z-index:2;
  background-image: url("/assets/cinematic-texture.svg");
  background-size: cover;
  background-position: 50% 55%;
  background-repeat: no-repeat;
  opacity: 0.48;
  filter: blur(3px) saturate(82%) brightness(1.05) contrast(1.28);
  mix-blend-mode: screen;
  mask-image: radial-gradient(ellipse 96% 90% at 50% 55%, #000 60%, transparent 98%);
  -webkit-mask-image: radial-gradient(ellipse 96% 90% at 50% 55%, #000 60%, transparent 98%);
  animation: tex-drift 60s var(--ease) infinite alternate;
  will-change: transform, opacity;
  pointer-events:none;
}
@keyframes tex-drift{
  0%   { transform: scale(1.07) translate(-1.2%, 0.8%); opacity: 0.44; }
  50%  { transform: scale(1.12) translate(0.8%, -1.1%); opacity: 0.54; }
  100% { transform: scale(1.08) translate(-0.9%, 0.9%); opacity: 0.48; }
}
@media (prefers-reduced-motion: reduce){
  .atmos .tex{ animation: none; opacity: 0.40; }
}
.atmos::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 96px 96px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
}
.atmos::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg, transparent, rgba(31,71,160,0.6), rgba(156,61,38,0.4), transparent);
  opacity:0.7;
}
/* v0.3.2 — Ambient motion canvas. Subtle, slow, no audio.
   v0.3.5 — now sits BENEATH the cinematic texture (z-index:1). Opacity reduced
   modestly so it supports (not competes with) the editorial texture above. */
.atmos canvas.amb{
  position:absolute;inset:0;width:100%;height:100%;
  z-index:1;
  mix-blend-mode:screen;
  opacity:0.55;
  mask-image: radial-gradient(ellipse 92% 82% at 50% 55%, #000 55%, transparent 96%);
  -webkit-mask-image: radial-gradient(ellipse 92% 82% at 50% 55%, #000 55%, transparent 96%);
  pointer-events:none;
}
@media (prefers-reduced-motion: reduce){
  .atmos canvas.amb{opacity:0.38}
}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:16px 40px;
  border-bottom:1px solid var(--rule-dark);
  background:rgba(16,18,24,0.82);backdrop-filter:saturate(160%) blur(14px);
  color:var(--paper);
  font-size:12.5px;letter-spacing:0.02em;
}
.wordmark{font-family:var(--sans);font-weight:600;letter-spacing:0.18em;font-size:12.5px}
.wm-lock{display:inline-flex;align-items:center;gap:14px;color:var(--paper)}
.sysmark{color:var(--cobalt-400);transition:color 280ms var(--ease)}
.wm-lock:hover .sysmark{color:var(--auburn-soft)}
.nav .links{display:flex;gap:24px;justify-content:center}
.nav .links a:first-child{margin-left:14px} /* v0.3.3: breathing room for Mission */
.nav .links a{color:var(--slate-400);transition:color 220ms var(--ease);font-size:12.5px;position:relative}
.nav .links a:hover{color:var(--paper)}
.nav .links a:hover::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--auburn-soft)}
.meta-tag{font-family:var(--mono);font-size:10.5px;color:var(--slate-500);text-align:right;letter-spacing:0.08em}
.meta-tag em{font-style:normal;color:var(--cobalt-400)}

/* ── HERO ── */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-start;padding:160px 96px 100px;overflow:hidden}
.hero-inner{position:relative;max-width:1360px;margin:0 auto;width:100%;z-index:5}
.hero-kicker{display:inline-flex;align-items:center;gap:12px;margin:0 0 32px;color:var(--slate-400);font-family:var(--mono);font-size:11px;letter-spacing:0.22em;text-transform:uppercase}
.hero-kicker::before{content:"";display:inline-block;width:24px;height:1px;background:var(--cobalt-400)}

/* v0.3.11 — Wordmark-dominant hero.
   v0.3.12 — wordmark scale reduced to eliminate collisions with surrounding
   hero elements. Confident, architectural, no longer oversized. */
.hero-brand{
  display:block;
  margin:28px 0 32px;
  color:var(--paper);
  opacity:0;transform:translateY(8px);
  animation: rise 1400ms var(--ease) forwards;
}
.hero-brand-wordmark{
  display:block;
  font-family:var(--sans);font-weight:600;
  font-size:clamp(22px, 3.2vw, 46px);
  letter-spacing:0.20em;
  color:var(--paper);
  line-height:1;
  white-space:nowrap;
}
.display{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(52px,8vw,128px);line-height:0.96;letter-spacing:-0.022em;
  margin:0 0 40px;color:var(--paper);
}
.display .line{display:block;opacity:0;transform:translateY(14px);animation:rise 1300ms var(--ease) forwards}
.display .line:nth-child(2){animation-delay:180ms;font-style:italic;color:var(--cobalt-200)}
@keyframes rise{to{opacity:1;transform:translateY(0)}}
.sub{font-family:var(--sans);font-size:17.5px;line-height:1.6;color:var(--slate-300);max-width:54ch;margin:0 0 44px;opacity:0;animation:rise 1300ms var(--ease) 360ms forwards}
.hero-links{display:flex;gap:40px;opacity:0;animation:rise 1300ms var(--ease) 520ms forwards}
.text-link{font-family:var(--sans);font-size:13.5px;letter-spacing:0.04em;border-bottom:1px solid currentColor;padding-bottom:3px;color:var(--paper);transition:color 280ms var(--ease),border-color 280ms var(--ease)}
.text-link.muted{color:var(--slate-400)}
.text-link.dark{color:var(--ink)}
.text-link:hover{color:var(--auburn-soft);border-color:var(--auburn-soft)}
.hero-rule{position:absolute;left:96px;right:96px;bottom:96px;height:1px;background:var(--rule-dark);transform-origin:left center;transform:scaleX(0);animation:draw 1800ms var(--ease) 500ms forwards;z-index:2}
.hero-rule::after{content:"";position:absolute;left:0;width:64px;height:1px;background:var(--cobalt-400);top:0}
@keyframes draw{to{transform:scaleX(1)}}
.hero-meta{position:absolute;left:96px;right:96px;bottom:44px;display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--slate-500);letter-spacing:0.1em;z-index:2}
.hero-meta strong{color:var(--cobalt-400);font-weight:400}

/* coordinates badge — quiet, institutional, signals operational reality
   v0.3.4 — CODE · CITY · LAT/LONG in three rails.
   v0.3.6 — strict CSS grid alignment, fully right-justified across all rails.
   Removes any drifting/slanted appearance. */
.coord{
  position:absolute;top:96px;right:96px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:0.06em;color:var(--slate-500);
  text-align:right;z-index:6;line-height:1.7;
}
.coord > div{
  display:grid;
  grid-template-columns: 44px 108px 168px;
  column-gap:14px;
  align-items:baseline;
  justify-content:end;
}
.coord .code{color:var(--cobalt-200);font-size:10.5px;letter-spacing:0.18em;text-align:right;font-family:var(--mono)}
.coord .city{color:var(--paper);font-family:var(--sans);font-size:11px;letter-spacing:0.04em;text-align:right;font-weight:400}
.coord .geo{color:var(--slate-500);font-size:10px;letter-spacing:0.04em;text-align:right;font-family:var(--mono)}
.coord .tick-row{display:flex;justify-content:flex-end;grid-template-columns:none;margin-top:8px}
.coord .tick{color:var(--auburn-soft);font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em}

/* ── INDEX STRIP ── */
.indexstrip{padding:0 96px;border-top:1px solid var(--rule-dark);background:#0C0F16}
.indexrows{padding:0;display:grid;grid-template-columns:repeat(3,1fr)!important;gap:0!important;max-width:1360px;margin:0 auto}
.ix{
  position:relative;
  display:flex;flex-direction:column;gap:10px;
  padding:52px 28px 52px 0;border-top:1px solid transparent;
  color:var(--paper);transition:background 360ms var(--ease)
}
.ix::before{content:"";position:absolute;left:0;top:-1px;width:0;height:1px;background:var(--cobalt-400);transition:width 600ms var(--ease)}
.ix:hover::before{width:48px}
.ix:nth-child(3n+1){border-right:1px solid var(--rule-dark);padding-right:32px}
.ix:nth-child(3n+2){border-right:1px solid var(--rule-dark);padding-left:28px;padding-right:32px}
.ix:nth-child(3n){padding-left:28px}
.ix:nth-child(-n+3){padding-top:52px}
.ix:nth-child(n+4){border-top-color:var(--rule-dark)}
.ix-num{font-family:var(--mono);font-size:10.5px;letter-spacing:0.2em;color:var(--cobalt-400)}
.ix-title{font-family:var(--serif);font-size:32px;line-height:1.08;letter-spacing:-0.012em;color:var(--paper)}
.ix-meta{font-family:var(--sans);font-size:13px;color:var(--slate-400);max-width:34ch;line-height:1.55}
.ix:hover{background:#0E1118}
.ix:hover .ix-title{color:var(--cobalt-200)}

/* ── PLATES ── */
.plate{padding:180px 96px;border-top:1px solid var(--rule-dark);position:relative}
.plate.paper{background:var(--paper);color:var(--ink);border-top-color:var(--rule-light)}
.plate.graphite{background:var(--graphite);color:var(--paper)}
.plate.tall{padding:220px 96px}
.plate.has-trace::before{content:"";position:absolute;left:0;top:-1px;width:96px;height:1px;background:var(--auburn-soft)}
.grid-12{display:grid;grid-template-columns:repeat(12,1fr);gap:36px;max-width:1360px;margin:0 auto}
.col-span-5{grid-column:span 5}
.col-span-7{grid-column:span 7}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--slate-700);padding-top:8px}
.eyebrow.light{color:var(--cobalt-400)}
.lede{font-family:var(--serif);font-weight:400;font-size:clamp(28px,2.8vw,42px);line-height:1.18;letter-spacing:-0.014em;max-width:22ch;margin:0 0 32px}
.lede.light{color:var(--paper)}
.lede em{font-style:italic;color:var(--cobalt-500)}
.lede.light em{color:var(--cobalt-200)}
.body-l{font-family:var(--sans);font-size:16.5px;line-height:1.66;color:var(--slate-700);max-width:54ch;margin:0 0 36px}
.body-l.light{color:var(--slate-300)}

.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
.three-col .col{position:relative;padding-left:20px}
.three-col .col::before{content:"";position:absolute;left:0;top:6px;width:1px;height:24px;background:var(--cobalt-500)}
.three-col h3{font-family:var(--serif);font-weight:400;font-size:24px;margin:0 0 12px;letter-spacing:-0.006em}
.three-col p{font-size:14.5px;line-height:1.6;color:var(--slate-700);margin:0;max-width:32ch}

.research-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--rule-light)}
.research-list li{padding:24px 0;border-bottom:1px solid var(--rule-light);display:grid;grid-template-columns:320px 1fr 20px;gap:24px;align-items:baseline;transition:background 240ms var(--ease);position:relative}
.research-list li::before{content:"";position:absolute;left:0;top:24px;width:0;height:1px;background:var(--auburn-soft);transition:width 500ms var(--ease)}
.research-list li:hover::before{width:48px}
.research-list li:hover{background:rgba(31,71,160,0.04)}
.research-list .rmeta{font-family:var(--mono);font-size:11px;letter-spacing:0.1em;color:var(--cobalt-700)}
.research-list a{font-family:var(--serif);font-size:21px;line-height:1.32;border-bottom:1px solid transparent}
.research-list a:hover{border-bottom-color:var(--cobalt)}
.research-list .arrow{color:var(--slate-400);font-family:var(--mono);font-size:14px}

/* ── OPERATING STRIP — global presence ── */
.opstrip{
  background:#0B0E16;color:var(--slate-300);
  padding:48px 96px;border-top:1px solid var(--rule-dark);border-bottom:1px solid var(--rule-dark);
  font-family:var(--mono);font-size:11px;letter-spacing:0.12em;
}
.opstrip-grid{max-width:1360px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:36px;align-items:start}
.opstrip-grid .label{color:var(--cobalt-400);font-size:10.5px;letter-spacing:0.22em;margin-bottom:8px;display:block}
.opstrip-grid .val{color:var(--paper);font-size:12px}
.opstrip-grid .val em{color:var(--auburn-soft);font-style:normal}

/* ── FOOTER ── */
.foot{background:#06080D;color:var(--slate-400);padding:72px 96px 48px;position:relative}
.foot::before{content:"";position:absolute;left:96px;top:0;width:96px;height:1px;background:var(--cobalt)}
.foot-grid{max-width:1360px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;align-items:start}
.wordmark.small{color:var(--paper);font-size:12px;display:flex;gap:12px;align-items:center;margin-bottom:10px}
.foot-tag{font-family:var(--serif);font-style:italic;color:var(--slate-300);font-size:14px;max-width:34ch}
.foot-meta{font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-align:center;padding-top:6px}
.foot-links{text-align:right;display:flex;gap:24px;justify-content:flex-end;font-size:13px;padding-top:4px}
.foot-baseline{max-width:1360px;margin:48px auto 0;padding-top:24px;border-top:1px solid var(--rule-dark);display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;color:var(--slate-500);letter-spacing:0.1em}

/* ── PAGE TEMPLATE ── */
.page{padding:200px 96px 120px;max-width:1360px;margin:0 auto;position:relative}
.page .kicker{font-family:var(--mono);font-size:11px;letter-spacing:0.22em;color:var(--cobalt-400);text-transform:uppercase;margin-bottom:36px;display:inline-flex;align-items:center;gap:12px}
.page .kicker::before{content:"";width:24px;height:1px;background:var(--cobalt-400)}
.page h1{font-family:var(--serif);font-weight:400;font-size:clamp(48px,6vw,92px);line-height:1.0;letter-spacing:-0.022em;margin:0 0 48px;max-width:18ch}
body.graphite .page h1{color:var(--paper)}
.page h1 em{font-style:italic;color:var(--cobalt-200)}
.page .body{max-width:64ch}
.page .body p{font-size:17px;line-height:1.7;margin:0 0 24px}
body.graphite .page .body p{color:var(--slate-300)}
.page .body p:first-child{font-family:var(--serif);font-size:26px;line-height:1.38;color:var(--paper);max-width:30ch;margin-bottom:32px}
body:not(.graphite) .page .body p:first-child{color:var(--ink)}

.layers-list{list-style:none;margin:56px 0 0;padding:0;border-top:1px solid var(--rule-dark)}
body:not(.graphite) .layers-list{border-top-color:var(--rule-light)}
.layers-list li{display:grid;grid-template-columns:80px 1fr 300px;gap:28px;align-items:baseline;padding:24px 0;border-bottom:1px solid var(--rule-dark);transition:background 240ms var(--ease);position:relative}
body:not(.graphite) .layers-list li{border-bottom-color:var(--rule-light)}
.layers-list li::before{content:"";position:absolute;left:0;top:24px;width:0;height:1px;background:var(--auburn-soft);transition:width 600ms var(--ease)}
.layers-list li:hover::before{width:56px}
.layers-list li:hover{background:rgba(31,71,160,0.05)}
.layers-list .ln{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;color:var(--cobalt-400)}
.layers-list .lt{font-family:var(--serif);font-size:24px;letter-spacing:-0.008em}
body.graphite .layers-list .lt{color:var(--paper)}
.layers-list .ld{font-family:var(--sans);font-size:13.5px;color:var(--slate-400);line-height:1.55}

.contact-block{font-family:var(--mono);font-size:15px;letter-spacing:0.04em;color:var(--paper);padding:24px 0;border-top:1px solid var(--cobalt);border-bottom:1px solid var(--rule-dark);margin:32px 0;max-width:560px;position:relative}
.contact-block::before{content:"";position:absolute;left:0;top:-1px;width:48px;height:1px;background:var(--auburn-soft)}

/* ── RESPONSIVE ── */
@media (max-width:1000px){
  .nav{grid-template-columns:1fr auto;padding:14px 20px}
  .nav .links{display:none}
  .hero,.plate,.page,.indexstrip,.foot,.opstrip{padding-left:24px;padding-right:24px}
  .hero-rule,.hero-meta,.coord{left:24px;right:24px}
  .coord{position:static;text-align:left;margin-bottom:24px}
  .grid-12{grid-template-columns:1fr;gap:24px}
  .col-span-5,.col-span-7{grid-column:span 1}
  .three-col{grid-template-columns:1fr;gap:24px}
  .indexrows{grid-template-columns:1fr}
  .ix{border-right:none!important;padding:24px 0!important;border-top:1px solid var(--rule-dark)!important}
  .research-list li{grid-template-columns:1fr}
  .opstrip-grid{grid-template-columns:1fr 1fr;gap:24px}
  .layers-list li{grid-template-columns:48px 1fr;gap:16px}
  .layers-list .ld{grid-column:1/-1;padding-left:64px}
  .foot-grid,.foot-baseline{grid-template-columns:1fr;display:block;text-align:left}
  .foot-links{justify-content:flex-start}
  .foot-meta{text-align:left}
}
