/* =============================================================================
   BAYANIHAN — Core Design System (Philippines — sun palette, Taglish typography)
   ============================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;700;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
  /* Base palette — Philippine sun */
  --forge-bg-deep:        #0E1A2E;
  --forge-bg-surface:     #14223A;
  --forge-bg-card:        rgba(22, 34, 58, 0.65);
  --forge-bg-card-hover:  rgba(30, 46, 75, 0.75);
  --forge-border-glass:   rgba(255, 255, 255, 0.06);
  --forge-border-glow:    rgba(252, 209, 22, 0.18);
  --forge-text-primary:   #E8ECF4;
  --forge-text-secondary: #8B95A8;
  --forge-text-muted:     #525D72;

  --forge-gold:           #FCD116;
  --forge-gold-glow:      rgba(252, 209, 22, 0.28);
  --forge-gold-dim:       #B8961A;
  --forge-blue:           #0038A8;
  --forge-red:            #CE1126;

  --forge-status-live:    #34D399;
  --forge-status-dev:     #60A5FA;
  --forge-status-issue:   #FBBF24;
  --forge-status-offline: #F87171;

  --forge-glass-blur:     16px;
  --forge-glass-bg:       rgba(22, 34, 58, 0.55);
  --forge-glass-border:   1px solid rgba(252, 209, 22, 0.08);

  /* Per-app accent default */
  --app-accent: var(--forge-gold);
  --app-glow: var(--forge-gold-glow);

  /* Rank colors — Kaibigan, Kasama, Bayani, Datu */
  --rank-kaibigan:    #8B95A8;
  --rank-kasama:      #60A5FA;
  --rank-bayani:      #FCD116;
  --rank-datu:        #E879F9;
  /* Legacy aliases (do not remove — forge-app.js may still reference) */
  --rank-apprentice:  var(--rank-kaibigan);
  --rank-smith:       var(--rank-kasama);
  --rank-master:      var(--rank-bayani);
  --rank-architect:   var(--rank-datu);

  /* Typography */
  --font-display: 'Orbitron', sans-serif;
  --font-body:    'Outfit', sans-serif;
  --font-mono:    'JetBrains Mono', monospace;

  /* Motion */
  --ease-out:   cubic-bezier(0.22, 1, 0.36, 1);
  --ease-inout: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Spacing (4px grid) */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px; --sp-5: 20px;
  --sp-6: 24px; --sp-8: 32px; --sp-10: 40px; --sp-12: 48px; --sp-16: 64px;

  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 16px;
  --radius-xl: 24px;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.2);
  --shadow:    0 8px 28px rgba(0,0,0,.35);
  --shadow-lg: 0 24px 64px rgba(0,0,0,.55);
  --shadow-glow: 0 0 40px var(--app-glow);
}

/* Per-app accent assignment */
[data-app="health"]       { --app-accent:#34D399; --app-glow:rgba(52,211,153,.2); }
[data-app="gigapp"]       { --app-accent:#FBBF24; --app-glow:rgba(251,191,36,.2); }
[data-app="echoforge"]    { --app-accent:#A78BFA; --app-glow:rgba(167,139,250,.2); }
[data-app="opsflow"]      { --app-accent:#60A5FA; --app-glow:rgba(96,165,250,.2); }
[data-app="mechanic"]     { --app-accent:#64B5C6; --app-glow:rgba(100,181,198,.2); }
[data-app="guardian"]     { --app-accent:#F9A8D4; --app-glow:rgba(249,168,212,.2); }
[data-app="sentinel"]     { --app-accent:#F87171; --app-glow:rgba(248,113,113,.2); }
[data-app="brainforge"]   { --app-accent:#6EE7B7; --app-glow:rgba(110,231,183,.2); }
[data-app="culina"]       { --app-accent:#FB923C; --app-glow:rgba(251,146,60,.2); }
[data-app="kurostudio"]   { --app-accent:#E879F9; --app-glow:rgba(232,121,249,.2); }
[data-app="sonara"]       { --app-accent:#22D3EE; --app-glow:rgba(34,211,238,.2); }
[data-app="adapterforge"] { --app-accent:#A3E635; --app-glow:rgba(163,230,53,.2); }
[data-app="conduit"]      { --app-accent:#818CF8; --app-glow:rgba(129,140,248,.2); }
[data-app="crucible"]     { --app-accent:#FB7185; --app-glow:rgba(251,113,133,.2); }
[data-app="pillar"]       { --app-accent:#FCD34D; --app-glow:rgba(252,211,77,.2); }
[data-app="gigapp-ph"]    { --app-accent:#FCD116; --app-glow:rgba(252,209,22,.28); }
[data-app="visakapatid"]  { --app-accent:#0038A8; --app-glow:rgba(0,56,168,.28); }

/* Reset */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html {
  background: var(--forge-bg-deep);
  color: var(--forge-text-primary);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100%;
}
body {
  background:
    radial-gradient(ellipse at 30% -10%, rgba(252, 209, 22, 0.10) 0%, transparent 60%),
    radial-gradient(ellipse at 85% 0%, rgba(0, 56, 168, 0.08) 0%, transparent 55%),
    var(--forge-bg-deep);
  background-attachment: fixed;
  min-height: 100vh;
}

a { color: inherit; text-decoration: none; }
img, svg, video { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; padding: 0; }
input, textarea, select { font: inherit; color: inherit; }

/* Typography */
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 700; letter-spacing: 0.02em; margin: 0 0 var(--sp-4); }
h1 { font-size: clamp(2.2rem, 4vw, 3.4rem); }
h2 { font-size: clamp(1.6rem, 2.5vw, 2.2rem); }
h3 { font-size: 1.25rem; }
p  { margin: 0 0 var(--sp-4); }
code, pre { font-family: var(--font-mono); }
small { color: var(--forge-text-muted); }

/* Layout */
.forge-shell { min-height: 100vh; display: flex; flex-direction: column; }
.forge-container { max-width: 1280px; margin: 0 auto; padding: 0 var(--sp-6); width: 100%; }
.forge-container-narrow { max-width: 840px; margin: 0 auto; padding: 0 var(--sp-6); width: 100%; }

/* Top nav bar */
.forge-topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: var(--sp-6);
  padding: var(--sp-3) var(--sp-6);
  background: rgba(10, 12, 16, 0.75);
  backdrop-filter: blur(var(--forge-glass-blur)) saturate(1.4);
  -webkit-backdrop-filter: blur(var(--forge-glass-blur)) saturate(1.4);
  border-bottom: 1px solid var(--forge-border-glass);
}
.forge-topbar .brand {
  display: flex; align-items: center; gap: var(--sp-3);
  font-family: var(--font-display); font-weight: 700;
  font-size: 1.1rem; letter-spacing: 0.14em;
  color: var(--forge-gold);
  text-transform: uppercase;
}
.forge-topbar .brand::before {
  content: ''; width: 22px; height: 22px; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #FFF4A3 0%, #FCD116 45%, #B8961A 100%);
  box-shadow: 0 0 18px var(--forge-gold-glow);
}
.forge-topbar nav {
  display: flex; gap: var(--sp-5); align-items: center;
  font-size: 0.9rem; color: var(--forge-text-secondary);
}
.forge-topbar nav a { transition: color .2s var(--ease-out); }
.forge-topbar nav a:hover, .forge-topbar nav a.active { color: var(--forge-text-primary); }
.forge-topbar .spacer { flex: 1; }
.forge-topbar .user-chip {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--radius);
  border: 1px solid var(--forge-border-glass);
  background: var(--forge-bg-card);
  font-size: 0.85rem;
}

/* Hero */
.forge-hero {
  padding: var(--sp-16) 0;
  text-align: center;
  position: relative;
}
.forge-hero h1 {
  background: linear-gradient(135deg, #fff 0%, var(--forge-gold) 55%, var(--forge-blue) 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.forge-hero p.lede { font-size: 1.15rem; color: var(--forge-text-secondary); max-width: 620px; margin: 0 auto; }

/* Grid */
.forge-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--sp-4);
}
.forge-grid-2 { grid-template-columns: 1fr 1fr; }
.forge-grid-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 860px) {
  .forge-grid-2, .forge-grid-3 { grid-template-columns: 1fr; }
}

/* Utility */
.mono { font-family: var(--font-mono); }
.text-muted { color: var(--forge-text-muted); }
.text-secondary { color: var(--forge-text-secondary); }
.text-gold { color: var(--forge-gold); }
.text-center { text-align: center; }
.row { display: flex; gap: var(--sp-3); align-items: center; }
.row-wrap { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.col { display: flex; flex-direction: column; gap: var(--sp-3); }
.gap-2 { gap: var(--sp-2); } .gap-4 { gap: var(--sp-4); } .gap-6 { gap: var(--sp-6); }
.mt-4 { margin-top: var(--sp-4); } .mt-6 { margin-top: var(--sp-6); } .mt-8 { margin-top: var(--sp-8); }
.mb-4 { margin-bottom: var(--sp-4); } .mb-6 { margin-bottom: var(--sp-6); } .mb-8 { margin-bottom: var(--sp-8); }
.flex-1 { flex: 1; }

/* Scrollbars */
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-track { background: var(--forge-bg-surface); }
*::-webkit-scrollbar-thumb { background: rgba(255,255,255,.08); border-radius: 8px; }
*::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.15); }

/* Focus */
:focus-visible { outline: 2px solid var(--forge-gold); outline-offset: 2px; border-radius: 4px; }

/* Motion-reduce */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
