/* Advengers · Obsidian login — page stylesheet (ported from the design handoff,
   "video background" revision). Scoped under .obsidian-login so the global class
   names cannot leak into the rest of the app. --accent lives on :root because
   /login/hero-rotator.js animates it (and --accent-ink) on document.documentElement.
   Brand tokens (--lime, --blue, --font) come from /login/brand.css. */

:root { --accent: var(--portal-accent, #c4f400); }

.obsidian-login {
  /* governed by the portal design tokens (brand.css); fallbacks keep the page
     intact even if that sheet hasn't loaded yet. */
  --bg: var(--portal-bg, #19191a);
  --bg-2: var(--portal-bg-2, #222221);
  --ink: var(--portal-ink, #f3f2ec);
  --ink-soft: var(--portal-ink-soft, #b5b3aa);
  --ink-mute: var(--portal-ink-mute, #74726b);
  --line: var(--portal-line, rgba(243, 242, 236, .10));
  --line-2: var(--portal-line-2, rgba(243, 242, 236, .05));
  position: relative;
  height: 100vh;
  overflow: hidden;
  background: #000;
  color: var(--ink);
  font-family: var(--font);
  -webkit-font-smoothing: antialiased;
}
.obsidian-login * { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Background layer ─────────────────────────────────────────────────────── */
.obsidian-login .bg { position: fixed; inset: 0; z-index: 0; overflow: hidden; background: #000; }
.obsidian-login #gl { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.obsidian-login .bg-mesh {
  position: absolute; inset: -20%;
  background:
    radial-gradient(38% 50% at 18% 28%, rgba(196, 244, 0, .08), transparent 70%),
    radial-gradient(48% 55% at 86% 22%, rgba(88, 88, 249, .16), transparent 70%),
    radial-gradient(55% 60% at 72% 92%, rgba(196, 244, 0, .05), transparent 70%);
  filter: blur(20px); opacity: .6;
}
.obsidian-login .bg-grain {
  position: absolute; inset: 0; opacity: .05; mix-blend-mode: screen; z-index: 2;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.obsidian-login .bg-vignette { position: absolute; inset: 0; z-index: 2; background: radial-gradient(120% 120% at 50% 0%, transparent 42%, rgba(0, 0, 0, .5) 100%); }

/* video background (replaces the WebGL plasma) */
.obsidian-login .bg-video { position: absolute; inset: 0; z-index: 1; overflow: hidden; pointer-events: none; opacity: 0; transition: opacity 1.1s ease; background: #08090f center/cover no-repeat; }
.obsidian-login .bg-video.ready { opacity: 1; }
.obsidian-login .bg-video video { position: absolute; top: 50%; left: 50%; width: 100vw; height: 56.25vw; min-height: 100vh; min-width: 177.78vh; transform: translate(-50%, -50%); border: 0; object-fit: cover; }
.obsidian-login .bg-video::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8, 9, 16, .28), rgba(8, 9, 16, .55)); }
.obsidian-login[data-bg-video] .bg-mesh,
.obsidian-login[data-bg-video] #gl { display: none; }

.obsidian-login #loadCurtain { position: fixed; inset: 0; z-index: 200; background: transparent; display: flex; align-items: center; justify-content: center; transition: opacity .8s ease; pointer-events: none; }
.obsidian-login #loadCurtain.gone { opacity: 0; }
.obsidian-login #loadCurtain .lc-sp { width: 30px; height: 30px; border: 2px solid rgba(243, 242, 236, .12); border-top-color: var(--accent, #c4f400); border-radius: 50%; animation: bgspin .8s linear infinite; }
@keyframes bgspin { to { transform: rotate(360deg); } }

.obsidian-login .type-mark { position: absolute; left: -6vw; bottom: -13vh; z-index: 1; width: 52vw; opacity: .035; pointer-events: none; filter: brightness(0) invert(1); }
.obsidian-login .brand-logo { height: 19px; width: auto; display: block; transition: opacity .7s cubic-bezier(.4, 0, .2, 1); }
.obsidian-login .brand-sep { font-size: 13px; color: var(--ink-mute); letter-spacing: .02em; position: relative; top: 1px; left: -6px; }

/* ── Shell / editorial ────────────────────────────────────────────────────── */
.obsidian-login .shell { position: relative; z-index: 2; min-height: 100vh; display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(0, .85fr); }
.obsidian-login .editorial { padding: 46px 56px; display: flex; flex-direction: column; justify-content: space-between; border-right: 1px solid var(--line); min-width: 0; overflow: hidden; background: linear-gradient(90deg, rgba(14, 14, 15, .55), rgba(14, 14, 15, .12) 60%, transparent); }
.obsidian-login .brandrow { display: flex; align-items: flex-end; gap: 12px; }
.obsidian-login .editorial-mid { max-width: 780px; min-width: 0; }
.obsidian-login .display { font-weight: 800; font-size: clamp(56px, 6.6vw, 112px); line-height: .96; letter-spacing: -.04em; color: var(--ink); text-transform: uppercase; }
.obsidian-login .display .ac { color: var(--lime); }
.obsidian-login .display .ln { display: block; overflow: hidden; }
.obsidian-login .display .ln > span { display: block; }
.obsidian-login .lede { margin-top: 30px; font-size: clamp(19px, 1.55vw, 25px); line-height: 1.55; color: var(--ink-soft); max-width: 600px; font-weight: 400; }

.obsidian-login .editorial-foot { display: flex; gap: 40px; align-items: flex-end; justify-content: space-between; }
.obsidian-login .foot-note { font-size: 12px; color: var(--ink-mute); letter-spacing: .02em; display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.obsidian-login .foot-note a { color: var(--ink-mute); text-decoration: none; transition: color .2s; }
.obsidian-login .foot-note a:hover { color: var(--ink-soft); }
.obsidian-login .foot-dot { opacity: .5; }
/* Heart credit — JS toggles .ops-active on the footer line. Sequence on enter:
   (1) the privacy/terms/© meta fades + collapses out FIRST, then (2) the credit
   text slides in (delayed) and (3) footer-credit.js starts the word rotation.
   On leave it reverses: text collapses, then the meta fades back in. */
.obsidian-login .ops-credit { position: relative; display: inline-flex; align-items: center; cursor: default; }
.obsidian-login .ops-credit .ops-text { display: inline-block; max-width: 0; overflow: hidden; white-space: nowrap; opacity: 0; transform: translateX(8px); transition: max-width .5s cubic-bezier(.2, .7, .2, 1), opacity .3s ease, transform .5s cubic-bezier(.2, .7, .2, 1); }
.obsidian-login .ops-credit svg { flex: none; margin-left: 3px; color: var(--ink-mute); transition: color .4s ease; }
/* meta fades back IN with a delay (after the text has collapsed) */
.obsidian-login .foot-meta { display: inline-flex; align-items: center; gap: 9px; overflow: hidden; white-space: nowrap; max-width: 900px; opacity: 1; transition: opacity .3s ease .35s, max-width .4s cubic-bezier(.2, .7, .2, 1) .35s; }
.obsidian-login .foot-note.ops-active .foot-meta { opacity: 0; max-width: 0; transition: opacity .3s ease, max-width .35s cubic-bezier(.2, .7, .2, 1); }
.obsidian-login .foot-note.ops-active .ops-text { max-width: 640px; opacity: 1; transform: translateX(0); transition: max-width .5s cubic-bezier(.2, .7, .2, 1) .32s, opacity .35s ease .32s, transform .5s cubic-bezier(.2, .7, .2, 1) .32s; }
.obsidian-login .foot-note.ops-active .ops-credit svg { color: #ff4d4d; }
.obsidian-login .ops-rot-wrap { display: inline-block; overflow: hidden; vertical-align: bottom; }
.obsidian-login .ops-rot { display: inline-block; font-weight: 700; will-change: transform; }
.obsidian-login .foot-tag { font-size: 13px; color: var(--ink-soft); letter-spacing: .04em; font-weight: 500; }

/* ── Status pill (top-right) — links to the public status page ────────────── */
.obsidian-login .sys-status { position: fixed; top: 40px; right: 56px; z-index: 40; display: inline-flex; align-items: center; gap: 8px; font-size: 12.5px; font-weight: 500; color: var(--ink); letter-spacing: .01em; text-decoration: none; border: 1px solid var(--line); padding: 7px 14px; border-radius: 999px; transition: background .18s ease, border-color .18s ease, transform .18s ease; }
.obsidian-login .sys-status:hover { background: rgba(243, 242, 236, .06); border-color: var(--accent); color: var(--ink); transform: translateY(-1px); }
.obsidian-login .sys-status .dot { width: 7px; height: 7px; border-radius: 50%; background: #9a988f; }
.obsidian-login .sys-status .dot--online { background: #5bd07a; }
.obsidian-login .sys-status .dot--offline { background: #f85149; }
.obsidian-login .sys-status .dot--checking { background: #9a988f; }
.obsidian-login .sys-status .dot.up { box-shadow: 0 0 0 0 rgba(91, 208, 122, .5); animation: sysPulse 2.6s ease-out infinite; }
@keyframes sysPulse { 0% { box-shadow: 0 0 0 0 rgba(91, 208, 122, .5); } 70% { box-shadow: 0 0 0 6px rgba(91, 208, 122, 0); } 100% { box-shadow: 0 0 0 0 rgba(91, 208, 122, 0); } }
@media (max-width: 1080px) { .obsidian-login .sys-status { top: 42px; right: 48px; } }
@media (max-width: 680px) { .obsidian-login .sys-status { top: 31px; right: 22px; font-size: 11px; } }

/* Background-video sound toggle (mirrors the Partner login's #vidSound) */
.obsidian-login .vid-sound { position: fixed; top: 40px; right: calc(42.5% + 56px); z-index: 45; display: inline-flex; align-items: center; gap: 8px; background: rgba(20, 20, 26, .5); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); border: 1px solid var(--line); color: var(--ink-soft); font-family: var(--font); font-size: 12.5px; font-weight: 500; padding: 7px 14px; border-radius: 999px; cursor: pointer; transition: background .2s, border-color .2s, color .2s, transform .15s; }
.obsidian-login .vid-sound:hover { background: rgba(20, 20, 26, .7); border-color: var(--accent); color: var(--ink); transform: translateY(-1px); }
.obsidian-login .vid-sound svg { flex: none; }
.obsidian-login .ops-em { font-style: italic; }
.obsidian-login .ops-heart { vertical-align: -2px; }
@media (max-width: 1080px) { .obsidian-login .vid-sound { top: auto; bottom: 22px; right: 24px; } }
@media (max-width: 680px) { .obsidian-login .vid-sound { bottom: 18px; right: 20px; font-size: 11px; padding: 7px 12px; } }
@media (prefers-reduced-motion: no-preference) { .obsidian-login .display { transition: opacity .3s; } }

/* ── Auth column ──────────────────────────────────────────────────────────── */
.obsidian-login .auth { display: flex; align-items: center; justify-content: center; padding: 48px; background: linear-gradient(180deg, rgba(20, 20, 26, .62), rgba(12, 12, 18, .82)); }
.obsidian-login .card { width: 100%; max-width: 382px; }
.obsidian-login .card-eyebrow { font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 14px; font-weight: 600; }
.obsidian-login .card-title { font-weight: 800; font-size: 40px; line-height: 1.02; letter-spacing: -.03em; margin-bottom: 10px; text-transform: uppercase; }
.obsidian-login .card-sub { font-size: 14px; color: var(--ink-soft); margin-bottom: 34px; }
.obsidian-login .card-sub b { color: var(--ink); font-weight: 600; }

.obsidian-login .btn { width: 100%; padding: 14px; border-radius: 5px; border: none; background: var(--accent); color: var(--accent-ink, #161616); font-family: var(--font); font-weight: 500; font-size: 15px; letter-spacing: 0; cursor: pointer; transition: filter .18s, transform .05s, background 1.3s cubic-bezier(.4, 0, .2, 1); position: relative; display: flex; align-items: center; justify-content: center; gap: 10px; }
.obsidian-login .btn:hover { filter: brightness(.94); }
.obsidian-login .btn:active { transform: scale(.99); }
.obsidian-login .ms-inner { display: inline-flex; align-items: center; gap: 10px; }

/* No-access / error panel */
.obsidian-login .no-access { margin-top: 16px; border: 1px solid rgba(255, 120, 120, .32); background: rgba(255, 90, 90, .07); border-radius: 8px; padding: 14px 16px; animation: advViewIn .42s cubic-bezier(.2, .7, .2, 1); }
.obsidian-login .no-access .na-row { display: flex; gap: 12px; align-items: flex-start; }
.obsidian-login .no-access .na-ic { flex: none; width: 30px; height: 30px; border-radius: 6px; background: rgba(255, 90, 90, .14); display: grid; place-items: center; }
.obsidian-login .no-access .na-title { font-weight: 600; color: #f3f2ec; font-size: 14px; margin-bottom: 4px; }
.obsidian-login .no-access .na-body { font-size: 13px; color: #b5b3aa; line-height: 1.5; }
@keyframes advViewIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* Local-dev badge in the card */
.obsidian-login .local-pill { display: inline-flex; align-items: center; gap: 7px; margin-bottom: 14px; padding: 5px 11px; border-radius: 999px; font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; background: rgba(196, 244, 0, .12); border: 1px solid rgba(196, 244, 0, .3); color: var(--accent); }

/* Help / contact reveal */
.obsidian-login .auth-foot { margin-top: 34px; font-size: 13px; color: var(--ink-mute); text-align: center; line-height: 1.7; }
.obsidian-login .auth-foot a { display: inline-block; margin-top: 4px; color: var(--ink-soft); text-decoration: none; border-bottom: 1px solid var(--line); transition: color .3s ease, border-color .3s ease; cursor: pointer; }
.obsidian-login .auth-foot a:hover { color: var(--accent); border-color: var(--accent); }
.obsidian-login .contact-block { margin-top: 30px; padding-top: 24px; border-top: 1px solid var(--line); overflow: hidden; animation: advContactIn .54s cubic-bezier(.2, .7, .2, 1); }
@keyframes advContactIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.obsidian-login .contact-lead { font-size: 14.5px; color: var(--ink-soft); line-height: 1.55; margin-bottom: 18px; min-height: 2.9em; animation: advLeadIn .42s ease; }
@keyframes advLeadIn { from { opacity: 0; } to { opacity: 1; } }
.obsidian-login .contact-lead b { color: var(--ink); font-weight: 600; }
.obsidian-login .contact-rows { display: flex; align-items: stretch; }
.obsidian-login .contact-row { flex: 1; display: flex; flex-direction: column; gap: 7px; text-decoration: none; }
.obsidian-login .contact-row:first-child { padding-right: 24px; }
.obsidian-login .contact-row:last-child { padding-left: 24px; }
.obsidian-login .contact-sep { width: 1px; align-self: stretch; background: var(--line); flex: none; }
.obsidian-login .contact-row .k { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-mute); font-weight: 600; }
.obsidian-login .contact-row .v { font-size: 16px; color: var(--ink); font-weight: 500; letter-spacing: -.015em; transition: color .25s; }
.obsidian-login .contact-row:hover .v { color: var(--accent); }

/* Partner wrong-turn CTA */
.obsidian-login .partner { margin-top: 38px; padding-top: 32px; border-top: 1px solid var(--line); text-align: center; }
.obsidian-login .partner p { font-size: 14px; color: var(--ink-soft); line-height: 1.6; margin-bottom: 18px; }
.obsidian-login .partner b { color: var(--ink); font-weight: 600; }
.obsidian-login .hero-cta { display: inline-flex; align-items: center; gap: 10px; font-size: 15px; font-weight: 500; color: var(--ink); text-decoration: none; border: 1px solid var(--line); padding: 13px 22px; border-radius: 999px; white-space: nowrap; transition: background .25s, border-color 1.3s cubic-bezier(.4, 0, .2, 1), transform .15s; }
.obsidian-login .hero-cta:hover { background: rgba(243, 242, 236, .06); border-color: var(--accent); transform: translateY(-1px); }
.obsidian-login .hero-cta .arw { display: inline-flex; color: var(--accent); transition: transform .25s, color 1.3s cubic-bezier(.4, 0, .2, 1); }
.obsidian-login .hero-cta:hover .arw { transform: translateX(4px); }

/* ── Responsive ───────────────────────────────────────────────────────────── */
/* Desktop on a short viewport: let the window scroll instead of clipping. */
@media (min-width: 1081px) and (max-height: 720px) {
  /* keep the base space-between so the footer stays pinned to the bottom and the
     hero stays vertically distributed; just allow the page to scroll if tall. */
  .obsidian-login { height: auto; min-height: 100vh; overflow: visible; }
}
@media (max-width: 1080px) {
  .obsidian-login { height: auto; min-height: 100vh; overflow: visible; }
  .obsidian-login .shell { grid-template-columns: 1fr; }
  .obsidian-login .editorial { border-right: none; border-bottom: 1px solid var(--line); padding: 40px 48px; gap: 36px; justify-content: flex-start; background: linear-gradient(180deg, rgba(14, 14, 15, .62), rgba(14, 14, 15, .18)); }
  .obsidian-login .editorial-mid { margin-top: 8px; }
  .obsidian-login .editorial-foot { display: none; }
  .obsidian-login .auth { padding: 48px 44px 56px; }
  .obsidian-login .display { font-size: clamp(52px, 8.4vw, 92px); }
}
@media (max-width: 680px) {
  .obsidian-login .editorial { padding: 30px 22px; gap: 24px; min-height: 84vh; }
  /* phone: logo pinned top, hero centred (flex:1), footer back at the bottom. */
  .obsidian-login .editorial-mid { margin-top: 0; flex: 1 1 auto; display: flex; flex-direction: column; justify-content: center; }
  .obsidian-login .editorial-foot { display: flex; flex-direction: column; align-items: flex-start; gap: 14px; }
  .obsidian-login .brand-logo { height: 17px; }
  .obsidian-login .display { font-size: clamp(38px, 12.4vw, 68px); }
  .obsidian-login .lede { font-size: 17px; margin-top: 20px; }
  .obsidian-login .auth { padding: 32px 22px 46px; }
  .obsidian-login .card { max-width: none; }
  .obsidian-login .card-title { font-size: 32px; }
  .obsidian-login .card-sub { margin-bottom: 28px; }
}
@media (max-width: 380px) {
  .obsidian-login .display { font-size: clamp(32px, 13.5vw, 52px); }
  .obsidian-login .card-title { font-size: 28px; }
}
