/* ===== TOKENS ===== */
:root{
  --bg: #08080d;
  --bg-panel: #121219;
  --bg-panel-2: #171722;
  --line: #26263a;
  --line-soft: #1c1c29;

  --brass: #7c5cff;
  --brass-bright: #a48bff;
  --red: #ef4a5f;
  --green: #2fd688;

  --text: #edeef7;
  --text-dim: #a3a3bd;
  --text-faint: #63637f;

  --font-display: 'Inter', sans-serif;
  --font-mono: 'IBM Plex Mono', monospace;
  --font-body: 'Inter', sans-serif;

  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-pill: 999px;
  --glow-brass: 0 0 0 1px rgba(124,92,255,0.3), 0 20px 44px rgba(124,92,255,0.18);
  --shadow-lift: 0 24px 50px rgba(0,0,0,0.55);
}

*{ margin:0; padding:0; box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  line-height:1.5;
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important; }
}

/* ===== GRAIN OVERLAY ===== */
.grain{
  position:fixed; inset:0; pointer-events:none; z-index:200;
  opacity:0.045; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ===== REPEATED PADLOCK BACKGROUND PATTERN ===== */
.hero__pattern, .access__panel-pattern{
  position:absolute; inset:0; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cg transform='translate(70,70) rotate(-18) translate(-12,-12)' fill='none' stroke='%237c5cff' stroke-width='1.4' opacity='0.5'%3E%3Cpath d='M12 1a5 5 0 0 0-5 5v3H6a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-9a2 2 0 0 0-2-2h-1V6a5 5 0 0 0-5-5Zm-3 8V6a3 3 0 0 1 6 0v3H9Z'/%3E%3C/g%3E%3C/svg%3E");
  background-size:140px 140px;
  opacity:0.06;
}

/* ===== SHARED TYPE ===== */
.eyebrow{
  font-family:var(--font-mono);
  font-size:0.72rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:14px;
}

.section__title{
  font-family:var(--font-display);
  font-size:clamp(2rem, 4vw, 2.8rem);
  font-weight:800;
  letter-spacing:-0.01em;
  line-height:1.08;
  margin-bottom:10px;
}

.section__note{
  color:var(--text-dim);
  max-width:520px;
  font-size:0.95rem;
}

/* ===== 3D HERO ICON ===== */
.icon3d{
  width:104px; height:90px;
  margin:0 auto 28px;
  perspective:700px;
  position:relative; z-index:2;
}
.icon3d__stage{
  width:100%; height:100%;
  position:relative;
  transform-style:preserve-3d;
  transform:rotateX(0) rotateY(0);
  animation:icon3d-spin-in 1.1s cubic-bezier(.2,.8,.3,1) both;
  transition:transform 0.25s ease-out;
  cursor:pointer;
}
.icon3d__face{
  position:absolute; inset:0;
  width:100%; height:100%;
}
.icon3d__face path{ fill:var(--brass); }
.icon3d__face--back{ transform:translateZ(-14px) scale(0.94); opacity:0.35; }
.icon3d__face--back path{ fill:#3a2f6e; }
.icon3d__face--mid{ transform:translateZ(-7px) scale(0.97); opacity:0.6; }
.icon3d__face--mid path{ fill:var(--brass); opacity:0.7; }
.icon3d__face--front{ transform:translateZ(0); }
.icon3d__face--front path{ fill:var(--brass-bright); filter:drop-shadow(0 8px 18px rgba(124,92,255,0.45)); }
@keyframes icon3d-spin-in{
  0%{ transform:rotateY(0deg) rotateX(8deg) scale(0.6); opacity:0; }
  60%{ opacity:1; }
  100%{ transform:rotateY(720deg) rotateX(0deg) scale(1); opacity:1; }
}
.icon3d.is-replaying .icon3d__stage{ animation:icon3d-spin-in 0.9s cubic-bezier(.2,.8,.3,1) both; }

/* ===== NAV ===== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; justify-content:center;
  padding:18px clamp(16px, 5vw, 40px) 0;
}
.nav__pill{
  width:100%; max-width:1180px;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
  padding:10px 12px 10px 20px;
  background:rgba(19,18,23,0.72);
  border:1px solid var(--line);
  border-radius:var(--r-pill);
  backdrop-filter:blur(14px) saturate(140%);
  box-shadow:0 10px 30px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.03);
  transition:border-color 0.3s, box-shadow 0.3s, background 0.3s;
}
.nav__brand{
  display:flex; align-items:center; gap:8px;
  font-family:var(--font-display);
  font-size:1.05rem;
  font-weight:800;
  letter-spacing:-0.01em;
  color:var(--text);
  flex-shrink:0;
}
.nav__logo{ width:21px; height:18px; fill:var(--brass); }
.nav__dot{ color:var(--brass); margin-left:2px; }
.nav__links{ display:flex; gap:30px; }
.nav__links a{
  font-family:var(--font-mono);
  font-size:0.76rem;
  letter-spacing:0.07em;
  text-transform:uppercase;
  color:var(--text-dim);
  transition:color 0.2s;
}
.nav__links a:hover{ color:var(--brass-bright); }
.nav__cta{
  font-family:var(--font-mono);
  font-size:0.74rem;
  letter-spacing:0.05em;
  text-transform:uppercase;
  color:#141208;
  background:linear-gradient(180deg, var(--brass-bright), var(--brass));
  padding:11px 20px;
  border-radius:var(--r-pill);
  font-weight:600;
  box-shadow:0 6px 16px rgba(124,92,255,0.28), inset 0 1px 0 rgba(255,255,255,0.35);
  transition:transform 0.2s, box-shadow 0.2s;
  flex-shrink:0;
}
.nav__cta:hover{ transform:translateY(-1px); box-shadow:0 10px 22px rgba(124,92,255,0.38), inset 0 1px 0 rgba(255,255,255,0.4); }
@media (max-width:720px){
  .nav__links{ display:none; }
  .nav__pill{ padding:8px 8px 8px 16px; }
}

/* ===== HERO ===== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:150px 24px 90px;
  overflow:hidden;
  background:
    radial-gradient(ellipse at 50% 15%, rgba(124,92,255,0.09), transparent 55%),
    var(--bg);
}

.dial{
  position:absolute;
  width:min(80vw, 620px);
  height:min(80vw, 620px);
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  opacity:0.4;
  animation:dial-spin 180s linear infinite;
}
@keyframes dial-spin{ to{ transform:translate(-50%,-50%) rotate(360deg); } }

.dial__ring{ fill:none; stroke:var(--line); stroke-width:1; }
.dial__ring--inner{ stroke:var(--line-soft); }
.dial__ticks line{ stroke:var(--line); stroke-width:1; }
.dial__needle{ stroke:var(--brass); stroke-width:2; opacity:0.6; }
.dial__hub{ fill:var(--brass); opacity:0.6; }

/* floating tilted file previews */
.floaters{ position:absolute; inset:0; z-index:1; }
.floater{
  position:absolute;
  width:180px;
  background:linear-gradient(180deg, var(--bg-panel-2), var(--bg-panel));
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:16px 16px 14px;
  box-shadow:var(--shadow-lift);
  opacity:0.85;
}
.floater--a{ top:14%; left:6%; transform:rotate(-9deg); animation:float-a 9s ease-in-out infinite; }
.floater--b{ top:60%; left:3%; transform:rotate(6deg) scale(0.9); opacity:0.6; animation:float-b 11s ease-in-out infinite; }
.floater--c{ top:20%; right:6%; transform:rotate(8deg); animation:float-c 10s ease-in-out infinite; }
@keyframes float-a{ 0%,100%{ transform:rotate(-9deg) translateY(0); } 50%{ transform:rotate(-9deg) translateY(-14px); } }
@keyframes float-b{ 0%,100%{ transform:rotate(6deg) scale(0.9) translateY(0); } 50%{ transform:rotate(6deg) scale(0.9) translateY(12px); } }
@keyframes float-c{ 0%,100%{ transform:rotate(8deg) translateY(0); } 50%{ transform:rotate(8deg) translateY(-10px); } }
.floater__tab{
  font-family:var(--font-mono); font-size:0.6rem; letter-spacing:0.08em;
  color:var(--text-faint); margin-bottom:10px;
}
.floater__wave{ display:flex; align-items:flex-end; gap:3px; height:18px; margin-bottom:12px; }
.floater__wave span{ width:3px; background:var(--brass); opacity:0.5; }
.floater__wave span:nth-child(1){ height:40%; } .floater__wave span:nth-child(2){ height:80%; }
.floater__wave span:nth-child(3){ height:55%; } .floater__wave span:nth-child(4){ height:100%; }
.floater__wave span:nth-child(5){ height:65%; } .floater__wave span:nth-child(6){ height:35%; }
.floater__title{ font-size:0.78rem; margin-bottom:10px; }
.floater__title em{ font-style:italic; color:var(--brass-bright); }
@media (max-width:1000px){ .floaters{ display:none; } }

.hero__content{
  position:relative; z-index:2;
  max-width:720px;
  text-align:center;
}

.hero__title{
  font-family:var(--font-display);
  font-size:clamp(2.6rem, 6vw, 4.4rem);
  font-weight:800;
  letter-spacing:-0.02em;
  line-height:1.04;
  color:var(--text);
  margin-bottom:20px;
}

.hero__sub{
  color:var(--text-dim);
  font-size:1.02rem;
  max-width:520px;
  margin:0 auto 36px;
}

.hero__actions{
  display:flex; gap:16px; justify-content:center; flex-wrap:wrap;
  margin-bottom:56px;
}

.btn{
  font-family:var(--font-mono);
  font-size:0.82rem;
  letter-spacing:0.06em;
  text-transform:uppercase;
  padding:15px 30px;
  border:1px solid var(--line);
  border-radius:var(--r-pill);
  transition:transform 0.25s, box-shadow 0.25s, border-color 0.25s, background 0.25s;
}
.btn--brass{
  background:linear-gradient(180deg, var(--brass-bright), var(--brass));
  color:#141208;
  border-color:transparent;
  font-weight:600;
  box-shadow:0 8px 20px rgba(124,92,255,0.3), inset 0 1px 0 rgba(255,255,255,0.35);
}
.btn--brass:hover{ transform:translateY(-2px); box-shadow:0 14px 30px rgba(124,92,255,0.4), inset 0 1px 0 rgba(255,255,255,0.4); }
.btn--ghost{ color:var(--text-dim); background:rgba(255,255,255,0.02); }
.btn--ghost:hover{ color:var(--text); border-color:var(--text-dim); transform:translateY(-2px); }

.hero__stats{
  display:flex; gap:16px; justify-content:center; flex-wrap:wrap;
}
.stat{
  display:flex; flex-direction:column; align-items:center;
  gap:6px;
  padding:20px 30px;
  min-width:140px;
  background:var(--bg-panel);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 10px 24px rgba(0,0,0,0.3);
  transition:border-color 0.25s, transform 0.25s;
}
.stat:hover{ border-color:rgba(124,92,255,0.4); transform:translateY(-3px); }
.stat__icon{ width:20px; height:20px; fill:var(--brass); opacity:0.85; margin-bottom:2px; }
.stat__num{
  font-family:var(--font-mono);
  font-size:1.7rem;
  color:var(--brass-bright);
  letter-spacing:0.04em;
}
.stat__label{
  font-family:var(--font-mono);
  font-size:0.66rem;
  letter-spacing:0.09em;
  text-transform:uppercase;
  color:var(--text-faint);
}

.scroll-cue{
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
  z-index:2;
  font-family:var(--font-mono);
  font-size:0.68rem;
  letter-spacing:0.2em;
  color:var(--text-faint);
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.scroll-cue span{
  width:1px; height:28px; background:linear-gradient(var(--brass), transparent);
  animation:scroll-drop 1.8s ease-in-out infinite;
}
@keyframes scroll-drop{ 0%{ opacity:0; } 30%{ opacity:1; } 100%{ opacity:0; transform:translateY(8px); } }

/* ===== SECTIONS ===== */
.section{
  padding:110px clamp(20px, 6vw, 64px);
  border-top:1px solid var(--line-soft);
}
.section__head{ max-width:720px; margin-bottom:48px; }

.reveal{
  opacity:0; transform:translateY(28px);
  transition:opacity 0.8s cubic-bezier(.2,.7,.2,1), transform 0.8s cubic-bezier(.2,.7,.2,1);
  transition-delay:calc(var(--reveal-i, 0) * 70ms);
}
.reveal.is-visible{ opacity:1; transform:translateY(0); }

/* ===== FILTERS ===== */
.filters{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:36px; }
.filter{
  font-family:var(--font-mono);
  font-size:0.72rem;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--text-dim);
  background:var(--bg-panel);
  border:1px solid var(--line);
  border-radius:var(--r-pill);
  padding:10px 18px;
  cursor:pointer;
  transition:all 0.2s;
}
.filter:hover{ color:var(--text); border-color:var(--text-dim); transform:translateY(-1px); }
.filter.is-active{
  color:#141208;
  background:linear-gradient(180deg, var(--brass-bright), var(--brass));
  border-color:transparent;
  box-shadow:0 6px 16px rgba(124,92,255,0.3);
}

/* ===== CATALOG GRID / PRICING-STYLE CARDS ===== */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:20px;
  align-items:start;
}

.card{
  position:relative;
  display:flex;
  flex-direction:column;
  background:linear-gradient(180deg, var(--bg-panel-2), var(--bg-panel));
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:30px 24px 24px;
  overflow:hidden;
  transition:transform 0.25s, border-color 0.25s, box-shadow 0.25s;
}
.card::before{
  content:"";
  position:absolute; inset:0 0 auto 0; height:2px;
  background:linear-gradient(90deg, transparent, var(--brass), transparent);
  opacity:0; transition:opacity 0.25s;
}
.card:hover{
  transform:translateY(-6px);
  border-color:rgba(124,92,255,0.45);
  box-shadow:var(--shadow-lift), var(--glow-brass);
}
.card:hover::before{ opacity:1; }
.card[data-hidden="true"]{ display:none; }

.card--featured{
  border-color:rgba(124,92,255,0.5);
  box-shadow:var(--glow-brass);
}
.card--featured::before{ opacity:1; }

.card__ribbon{
  position:absolute; top:16px; right:-32px;
  background:linear-gradient(180deg, var(--brass-bright), var(--brass));
  color:#141208;
  font-family:var(--font-mono);
  font-size:0.6rem;
  font-weight:700;
  letter-spacing:0.08em;
  padding:5px 40px;
  transform:rotate(38deg);
  box-shadow:0 4px 10px rgba(0,0,0,0.35);
}

.card__tab{
  align-self:flex-start;
  background:rgba(0,0,0,0.3);
  border:1px solid var(--line);
  border-radius:var(--r-pill);
  font-family:var(--font-mono);
  font-size:0.63rem;
  letter-spacing:0.08em;
  color:var(--text-faint);
  padding:4px 12px;
  margin-bottom:18px;
}

.card__waveform{
  display:flex; align-items:flex-end; gap:3px;
  height:24px; margin-bottom:18px;
}
.card__waveform span{
  width:3px; background:var(--line);
  animation:wave 1.6s ease-in-out infinite;
}
.card__waveform span:nth-child(1){ height:40%; animation-delay:0s; }
.card__waveform span:nth-child(2){ height:80%; animation-delay:0.1s; }
.card__waveform span:nth-child(3){ height:55%; animation-delay:0.2s; }
.card__waveform span:nth-child(4){ height:100%; animation-delay:0.3s; }
.card__waveform span:nth-child(5){ height:65%; animation-delay:0.4s; }
.card__waveform span:nth-child(6){ height:35%; animation-delay:0.5s; }
.card__waveform span:nth-child(7){ height:75%; animation-delay:0.6s; }
.card__waveform span:nth-child(8){ height:45%; animation-delay:0.7s; }
@keyframes wave{ 0%,100%{ opacity:0.5; transform:scaleY(0.6); } 50%{ opacity:1; transform:scaleY(1); } }
.card:hover .card__waveform span{ background:var(--brass); }

.card__title{
  font-family:var(--font-body);
  font-weight:700;
  font-size:1.08rem;
  margin-bottom:14px;
}
.card__title em{ font-style:italic; color:var(--brass-bright); font-weight:600; }

.card__specs{
  list-style:none;
  display:flex; flex-wrap:wrap; gap:8px;
  margin-bottom:14px;
}
.card__specs li{
  font-family:var(--font-mono);
  font-size:0.68rem;
  letter-spacing:0.03em;
  color:var(--text-dim);
  background:rgba(255,255,255,0.03);
  border:1px solid var(--line-soft);
  border-radius:var(--r-pill);
  padding:4px 10px;
}

.card__desc{
  color:var(--text-dim);
  font-size:0.88rem;
  margin-bottom:20px;
  min-height:40px;
}

.card__foot{
  display:flex; align-items:center; justify-content:space-between;
  border-top:1px solid var(--line-soft);
  padding-top:16px;
  margin-bottom:18px;
}

.card__price{
  font-family:var(--font-mono);
  font-weight:700;
  font-size:1.15rem;
  color:var(--text);
}

.card__cta{
  display:block;
  text-align:center;
  font-family:var(--font-mono);
  font-size:0.74rem;
  letter-spacing:0.05em;
  text-transform:uppercase;
  color:var(--text-dim);
  border:1px solid var(--line);
  border-radius:var(--r-pill);
  padding:11px;
  margin-top:auto;
  transition:all 0.2s;
}
.card__cta:hover{ color:var(--text); border-color:var(--text-dim); }
.card__cta--brass{
  color:#141208;
  background:linear-gradient(180deg, var(--brass-bright), var(--brass));
  border-color:transparent;
  font-weight:600;
  box-shadow:0 6px 16px rgba(124,92,255,0.3);
}
.card__cta--brass:hover{ transform:translateY(-1px); box-shadow:0 10px 22px rgba(124,92,255,0.4); }

/* ===== STAMPS ===== */
.stamp{
  font-family:var(--font-mono);
  font-size:0.66rem;
  letter-spacing:0.1em;
  padding:5px 12px;
  border:1.5px solid currentColor;
  border-radius:var(--r-pill);
  display:inline-block;
}
.stamp--sm{ font-size:0.6rem; padding:3px 10px; }
.stamp--green{ color:var(--green); }
.stamp--brass{ color:var(--brass-bright); }
.stamp--red{ color:var(--red); }

/* ===== VOUCHES MARQUEE ===== */
.section--vouches{ background:var(--bg-panel); overflow:hidden; }

.marquee{
  position:relative;
  width:100%;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent, black 6%, black 94%, transparent);
  mask-image:linear-gradient(90deg, transparent, black 6%, black 94%, transparent);
}
.marquee__track{
  display:flex;
  gap:16px;
  width:max-content;
  animation:marquee-scroll 34s linear infinite;
}
.marquee:hover .marquee__track{ animation-play-state:paused; }
@keyframes marquee-scroll{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}

.entry{
  flex:0 0 auto;
  width:300px;
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:26px 24px;
  transition:border-color 0.25s, transform 0.25s;
}
.entry:hover{ border-color:rgba(124,92,255,0.4); transform:translateY(-3px); }

.entry__top{
  display:flex; align-items:center; gap:12px;
  margin-bottom:14px;
}
.entry__avatar{
  width:34px; height:34px; flex-shrink:0;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(140deg, var(--bg-panel-2), var(--bg-panel));
  border:1px solid var(--line);
  font-family:var(--font-mono);
  font-size:0.66rem;
  color:var(--brass-bright);
}
.entry__who{ display:flex; flex-direction:column; gap:5px; }
.entry__handle{
  font-family:var(--font-mono);
  font-size:0.82rem;
  color:var(--text);
}
.entry__stars{ display:flex; gap:3px; margin-bottom:12px; }
.entry__stars svg{ width:14px; height:14px; fill:var(--brass-bright); }
.entry__stars svg.star--empty{ fill:var(--line); }
.entry__quote{
  color:var(--text-dim);
  font-size:0.92rem;
  margin-bottom:16px;
}
.entry__date{
  font-family:var(--font-mono);
  font-size:0.68rem;
  color:var(--text-faint);
  letter-spacing:0.06em;
}

/* ===== ACCESS ===== */
.section--access{ padding-left:clamp(20px, 4vw, 40px); padding-right:clamp(20px, 4vw, 40px); }

.access__panel{
  position:relative;
  max-width:1040px;
  margin:0 auto;
  padding:64px 32px;
  background:var(--bg-panel);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lift);
  text-align:center;
}
.access__panel-glow{
  position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 90% at 50% 0%, rgba(124,92,255,0.16), transparent 70%);
  pointer-events:none;
}
.access__panel-content{ position:relative; z-index:1; }
.access__panel .section__title{ margin-left:auto; margin-right:auto; }
.access__note-top{ margin:0 auto 8px; }

.plaques{
  display:flex; gap:18px; justify-content:center; flex-wrap:wrap;
  margin:36px 0 32px;
}
.plaque{
  display:flex; flex-direction:column; align-items:center; gap:10px;
  width:180px; padding:28px 18px;
  background:var(--bg-panel-2);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  transition:border-color 0.25s, transform 0.25s, box-shadow 0.25s;
}
.plaque:hover{ border-color:var(--brass); transform:translateY(-4px); box-shadow:var(--glow-brass); }
.plaque__icon{ width:26px; height:26px; fill:var(--brass); }
.plaque__label{ font-family:var(--font-mono); font-size:0.85rem; letter-spacing:0.04em; }
.plaque__sub{ font-size:0.75rem; color:var(--text-faint); }

.access__note{
  font-family:var(--font-mono);
  font-size:0.75rem;
  color:var(--text-faint);
  letter-spacing:0.03em;
}

/* ===== FOOTER ===== */
.footer{ padding:60px clamp(20px, 6vw, 64px) 32px; border-top:1px solid var(--line-soft); }
.footer__top{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:32px;
  margin-bottom:40px;
}
.footer__col{ display:flex; flex-direction:column; gap:12px; }
.footer__col a{
  font-family:var(--font-mono);
  font-size:0.78rem;
  color:var(--text-dim);
  letter-spacing:0.02em;
  transition:color 0.2s;
}
.footer__col a:hover{ color:var(--brass-bright); }
.footer__heading{
  font-family:var(--font-mono);
  font-size:0.66rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--text-faint);
  margin-bottom:4px;
}
.footer__brand{
  font-family:var(--font-display);
  font-weight:800;
  font-size:1.1rem;
}
.footer__tagline{ color:var(--text-dim); font-size:0.85rem; max-width:280px; }
.footer__status{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono);
  font-size:0.68rem;
  letter-spacing:0.05em;
  text-transform:uppercase;
  color:var(--green);
  margin-top:4px;
}
.footer__status i{
  width:6px; height:6px; border-radius:50%;
  background:var(--green);
  box-shadow:0 0 8px var(--green);
}
.footer__bottom{
  padding-top:24px;
  border-top:1px solid var(--line-soft);
}
.footer__legal{
  font-family:var(--font-mono);
  font-size:0.68rem;
  color:var(--text-faint);
  text-align:center;
}
@media (max-width:720px){
  .footer__top{ grid-template-columns:1fr 1fr; }
  .footer__col--brand{ grid-column:1 / -1; margin-bottom:8px; }
}

/* Focus visibility */
a:focus-visible, button:focus-visible{
  outline:1.5px solid var(--brass-bright);
  outline-offset:3px;
}
