/* /phase5/phase5.css */
/* =========================================================
   Phase V: The.Reveal:
   Global CSS
   Topbar/Footer aligned to Phase2-index.html styling
   ========================================================= */

:root{
  --bg-0: #050607;
  --bg-1: #07090a;

  --ink: rgba(212,219,223,.92);
  --muted: rgba(212,219,223,.62);
  --line: rgba(212,219,223,.14);

  --gold: #C9A227;

  --p1: #638372;
  --p2: #9C2D12;
  --p3: #3D5677;
  --p4: #A43C9A;
  --p5: #C9A227;

  /* Phase II uses 1160px; your Phase V used 1100px.
     To match Phase II bar/footer proportions more closely, use 1160px. */
  --max: 1160px;

  --panel-pad: clamp(22px, 4vw, 52px);

  --font-sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;

  --ease: cubic-bezier(.2,.9,.2,1);
  --fade: 600ms;

  --phase5-gold: var(--gold);
  --shadow: 0 18px 55px rgba(0,0,0,.55);
  --glow: 0 0 0 2px rgba(201,162,39,.25), 0 0 28px rgba(201,162,39,.20);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  color: var(--ink);
  font-family: var(--font-sans);
  background:
    radial-gradient(1200px 800px at 50% 35%, rgba(255,255,255,.04), transparent 55%),
    radial-gradient(900px 600px at 52% 60%, rgba(201,162,39,.045), transparent 62%),
    linear-gradient(180deg, var(--bg-1) 0%, var(--bg-0) 100%);
  overflow:hidden;
}

a{ color: inherit; text-decoration: none; }
img{ max-width:100%; display:block; }

/* ---------------------------------------------------------
   Panel system
--------------------------------------------------------- */

.phase5-panels{
  height: 100vh;
  width: 100%;
  position: relative;
}

.phase5-panel{
  height: 100vh;
  width: 100%;
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  padding: var(--panel-pad);
  opacity:0;
  transform: translateY(8px);
  pointer-events:none;
  transition: opacity var(--fade) var(--ease), transform var(--fade) var(--ease);
}

.phase5-panel.is-active{
  opacity:1;
  transform: translateY(0);
  pointer-events:auto;
}

.phase5-panel .wrap{
  width: 100%;
  max-width: var(--max);
  margin: 0 auto;
}

/* ---------------------------------------------------------
   Typography
--------------------------------------------------------- */

.kicker{
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 12px;
}

.title{
  margin:0;
  font-size: clamp(42px, 6.2vw, 82px);
  letter-spacing: -0.02em;
  line-height: 1.02;
  font-weight: 750;
}

.subline{
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.6;
  max-width: 72ch;
}

.center{ text-align:center; }

.rule{
  width: min(360px, 56vw);
  height: 1px;
  margin: 18px auto 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(201,162,39,.85) 20%,
    rgba(201,162,39,.85) 80%,
    transparent 100%
  );
  opacity: .9;
}

.text-gold{ color: var(--gold); }

.text-terminal{
  color: rgba(201,162,39,1);
  text-shadow: 0 0 12px rgba(201,162,39,.22);
  font-family: var(--font-mono);
  letter-spacing: .06em;
}

/* =========================================================
   Topbar (Phase II match, Phase V colors)
========================================================= */

.topbar{
  position:fixed;
  inset:0 0 auto 0;
  z-index:60;

  /* Phase II: background/blur handled by the pill */
  background: transparent;
  border: 0;
  backdrop-filter: none;

  padding: 10px 0;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity var(--fade) var(--ease), transform var(--fade) var(--ease);
}

.topbar-inner{
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 16px;
}

.topbar-pill{
  width: 100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;

  padding: 8px 10px;
  border-radius: 999px;

  backdrop-filter: blur(10px);
  background: rgba(8,10,11,.72);
  border: 1px solid var(--line);
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
}

.pillrow{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

/* Button pill (Phase II style) */
.btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:10px;

  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(212,219,223,.22);
  background: rgba(15,18,20,.55);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);

  line-height: 1;
  user-select:none;
  white-space:nowrap;

  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease, background .12s ease;
}

.btn:hover{
  transform: translateY(-1px);
  border-color: rgba(201,162,39,.55);
  box-shadow: var(--shadow), var(--glow);
  background: rgba(15,18,20,.72);
}
.btn:active{ transform: translateY(0px) scale(.99); }

.mini-dot{
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--phase5-gold);
  box-shadow: 0 0 0 2px rgba(201,162,39,.22);
  flex:0 0 auto;
}

/* Hover label swap (Phase II behavior) */
.label-sizer{ visibility:hidden; height:0; position:absolute; }
.label-default,.label-hover{ font-size: 13px; letter-spacing:.02em; }
.label-hover{ display:none; }
.btn.swap:hover .label-default{ display:none; }
.btn.swap:hover .label-hover{ display:inline; }

/* Status pill (Phase II style, Phase V colors) */
.status{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 10px 14px;
  border-radius: 999px;

  border: 1px solid rgba(201,162,39,.40);
  background: rgba(201,162,39,.08);

  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing:.08em;
  text-transform: uppercase;
  white-space:nowrap;
}

.status .tag{
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(212,219,223,.18);
  background: rgba(15,18,20,.55);

  font-family: var(--font-sans);
  font-size: 12px;
  letter-spacing:.03em;
  text-transform:none;
}

/* Phase II: tighten ONLY topbar pill sizing */
.topbar .btn{
  padding: 8px 12px;
  gap: 8px;
}
.topbar .status{
  padding: 8px 12px;
  gap: 8px;
  font-size: 11px;
}
.topbar .status .tag{
  padding: 3px 7px;
  font-size: 11px;
}
.topbar .mini-dot{
  width: 9px;
  height: 9px;
}

/* Phase II: lock topbar font sizing consistency */
.topbar .btn,
.topbar .status{
  font-size: 12px;
  line-height: 1;
}
.topbar .label-default,
.topbar .label-hover{
  font-size: 12px;
}

/* Phase II: right-side pills use mono w/ spacing */
.topbar nav .btn{
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .08em;
}
.topbar nav .label-default,
.topbar nav .label-hover{
  font-size: inherit;
  letter-spacing: inherit;
}

/* =========================================================
   Footer (Phase II match, Phase V colors)
========================================================= */

.footer-wrap{
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 60;
  padding: 0 0 18px;

  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  transition: opacity var(--fade) var(--ease), transform var(--fade) var(--ease);
}

/* Footer container matches Phase II grid + panel look */
.footer{
  max-width: var(--max);
  margin: 0 auto;
  padding: 12px 14px;

  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 12px;

  border: 1px solid var(--line);
  background: rgba(0,0,0,.18);
  border-radius: 22px;

  color: rgba(207,214,212,.72);
  font-size: 12px;
}

.footer-left{ text-align:left; }
.footer-center{ text-align:center; display:flex; justify-content:center; }
.footer-right{ text-align:right; }

.footer b{
  color: var(--ink);
  font-weight:650;
}

/* Roxie Approval Pill (Phase V gold styling, Phase II shape) */
.roxie-approved-pill{
  display:inline-block;
  padding: 6px 14px;
  border-radius: 999px;

  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;

  color: rgba(255,236,180,.95);
  border: 1px solid rgba(201,162,39,.65);
  background: rgba(201,162,39,.10);

  white-space: nowrap;
  pointer-events:none;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}

@media (max-width: 680px){
  .footer{
    grid-template-columns: 1fr;
    text-align:center;
    gap:10px;
    border-radius: 18px;
  }
  .footer-left,
  .footer-right{ text-align:center; }
}

/* =========================================================
   Nav visibility behavior (your Phase5.js toggles this)
========================================================= */

body.show-nav .topbar,
body.show-nav .footer-wrap{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}