/* ════════════════════════════════════════════════
   AB WAR ROOM — styles.css (Monochrome)
   ════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Share+Tech+Mono&family=Bebas+Neue&display=swap');

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

:root {
  /* DARK MODE (Default) */
  --bg:      #050505;
  --s1:      #0a0a0a;
  --s2:      #111111;
  --s3:      #1a1a1a;
  --border:  #222222;
  --border2: #333333;
  --text:    #e0e0e0;
  --text2:   #888888;
  --text3:   #555555;
  --accent:  #ffffff;
  --accent-f:#1a1a1a;
  --danger:  #555555; /* Muted danger */
  
  /* Monochrome variations for layout components */
  --mint:     #ffffff;
  --mint-d:   #1a1a1a;
  --gold:     #cccccc;
  --gold-f:   #111111;
  --purple:   #dddddd;
  --purpled:  #181818;
  --blue:     #eeeeee;
  --blue-d:   #1a1a1a;
  --red:      #cccccc;
  --redd:     #111111;
  --cyan:     #ffffff;
  --cyand:    #151515;
  --warn:     #dddddd;
  --warnd:    #1c1c1c;

  --fd: 'Bebas Neue', sans-serif;
  --fu: 'Rajdhani', sans-serif;
  --fm: 'Share Tech Mono', monospace;
  --radius:  2px;
}

[data-theme="light"] {
  --bg:      #fafafa;
  --s1:      #ffffff;
  --s2:      #f0f0f0;
  --s3:      #e5e5e5;
  --border:  #dddddd;
  --border2: #cccccc;
  --text:    #111111;
  --text2:   #666666;
  --text3:   #999999;
  --accent:  #000000;
  --accent-f:#f5f5f5;

  --mint:     #000000;
  --mint-d:   #f5f5f5;
  --gold:     #333333;
  --gold-f:   #eeeeee;
  --purple:   #222222;
  --purpled:  #f0f0f0;
  --blue:     #111111;
  --blue-d:   #f5f5f5;
  --red:      #333333;
  --redd:     #eeeeee;
  --cyan:     #000000;
  --cyand:    #eaeaea;
  --warn:     #222222;
  --warnd:    #f0f0f0;
}

html { scroll-behavior: smooth }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--fu);
  min-height: 100vh;
  overflow-x: hidden;
  transition: background 0.3s, color 0.3s;
}

/* Subtle grid texture */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 40px 40px;
  opacity: 0.2;
  pointer-events: none;
  z-index: 0;
}

main, header, nav { position: relative; z-index: 1; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 3px; height: 3px }
::-webkit-scrollbar-track { background: transparent }
::-webkit-scrollbar-thumb { background: var(--border2); }

/* ════════════════════════════════
   HEADER
   ════════════════════════════════ */
.hdr {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px 28px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  position: sticky;
  top: 0;
  z-index: 100;
}

.logo {
  font-family: var(--fd);
  font-size: 32px;
  color: var(--accent);
  letter-spacing: .12em;
}

.hdr-r { position: absolute; right: 28px; top: 50%; transform: translateY(-50%); }

.theme-toggle {
  background: none;
  border: none;
  color: var(--text2);
  font-size: 18px;
  cursor: pointer;
  transition: color .2s;
}
.theme-toggle:hover { color: var(--accent); }

/* ════════════════════════════════
   NAV TABS
   ════════════════════════════════ */
.nav {
  display: flex;
  justify-content: flex-start;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  overflow-x: auto;
  padding: 0 20px;
  scrollbar-width: none;
}
.nav::-webkit-scrollbar { display: none }

@media(min-width: 601px) {
  .nav {
    justify-content: center;
  }
}

.ntab {
  font-family: var(--fu);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text2);
  padding: 16px 22px;
  cursor: pointer;
  border: none;
  background: transparent;
  border-bottom: 2px solid transparent;
  transition: all .2s;
  white-space: nowrap;
}
.ntab:hover { color: var(--text) }
.ntab.active { color: var(--accent); border-bottom-color: var(--accent); }

/* ════════════════════════════════
   MAIN CONTENT
   ════════════════════════════════ */
main {
  max-width: 900px;
  margin: 0 auto;
  padding: 40px 20px 100px;
}

.section { display: none }
.section.active { display: block; animation: fadeUp .22s ease; }

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(6px) }
  to   { opacity: 1; transform: none }
}

/* ── Section header ── */
.sh {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 28px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
  gap: 8px;
}

.st {
  font-family: var(--fd);
  font-size: 38px;
  color: var(--accent);
  letter-spacing: .06em;
  line-height: 1;
}

/* ════════════════════════════════
   CARDS
   ════════════════════════════════ */
.card {
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px 26px;
  margin-bottom: 14px;
  transition: border-color .25s, transform .2s;
}
.card:hover {
  border-color: var(--border2);
}

.clabel {
  font-family: var(--fm);
  font-size: 10px;
  color: var(--text2);
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-bottom: 10px;
  margin-top: 24px;
}

.ctitle { font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 6px }
.cbody  { font-size: 13px; color: var(--text2); line-height: 1.78 }

/* ════════════════════════════════
   GRIDS
   ════════════════════════════════ */
.g2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px }
.g3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px }
.g4 { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 14px }

@media(max-width:900px) { .g3,.g4 { grid-template-columns: 1fr 1fr } }
@media(max-width:680px) { .g2, .g3, .g4 { grid-template-columns: 1fr } }

/* ════════════════════════════════
   BUTTONS
   ════════════════════════════════ */
.btn {
  font-family: var(--fu);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 10px 20px;
  border-radius: var(--radius);
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--s1);
  color: var(--text);
  transition: all .2s;
}
.btn:hover { border-color: var(--text); color: var(--accent) }
.bg { background: var(--accent); color: var(--bg); border: none }
.bg:hover { background: var(--text); opacity: 0.9; color: var(--bg) }
.bo { background: transparent; border: 1px solid var(--border2); }
.bo:hover { border-color: var(--accent); color: var(--accent) }

/* ════════════════════════════════
   ROADMAP (civilization)
   ════════════════════════════════ */
.roadmap-subnav {
  display: flex;
  overflow-x: auto;
  gap: 0;
  margin-bottom: 32px;
  border-bottom: 1px solid var(--border);
  scrollbar-width: none;
}
.roadmap-subnav::-webkit-scrollbar { display: none }

.rtab {
  font-family: var(--fu);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text3);
  padding: 14px 18px;
  cursor: pointer;
  border: none;
  background: transparent;
  border-bottom: 2px solid transparent;
  transition: all .2s;
  white-space: nowrap;
}
.rtab:hover { color: var(--text2) }
.rtab.active { color: var(--accent); border-bottom-color: var(--accent) }

.rpanel { display: none }
.rpanel.active { display: block; animation: fadeUp .22s ease }

.rm-hero { padding: 32px 36px; margin-bottom: 32px; border: 1px solid var(--border); background: var(--s1) }
.rm-hero-title { font-family: var(--fd); font-size: 42px; letter-spacing: .04em; line-height: 1; margin-bottom: 12px; color: var(--accent) }
.rm-hero-sub   { font-size: 14px; line-height: 1.78; max-width: 800px; color: var(--text2) }

.rm-sec { margin-bottom: 40px }
.rm-sec-label {
  font-family: var(--fm);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  margin-bottom: 16px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
}

.person-card {
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  transition: border-color .15s;
}
.person-card:hover { border-color: var(--border2); }
.pc-name   { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 4px }
.pc-contrib { font-family: var(--fm); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 8px; color: var(--text2) }
.pc-book   { font-size: 12px; color: var(--text2); line-height: 1.5; font-style: italic }

.tech-card { background: var(--s1); border: 1px solid var(--border); padding: 22px 24px; margin-bottom: 16px }
.tech-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; margin-bottom: 12px }
.tech-title  { font-size: 18px; font-weight: 700; color: var(--text) }
.tech-body   { font-size: 13px; color: var(--text2); line-height: 1.78; margin-bottom: 12px }

.stage-block { background: var(--s1); border: 1px solid var(--border); padding: 24px 28px; margin-bottom: 16px; position: relative; }
.stage-title { font-size: 20px; font-weight: 700; color: var(--accent); margin-bottom: 8px }
.stage-years { font-family: var(--fm); font-size: 11px; color: var(--text2); margin-bottom: 14px }
.stage-body  { font-size: 13px; color: var(--text2); line-height: 1.78 }

.chain { display: flex; flex-direction: column; gap: 0 }
.chain-item { display: flex; gap: 14px; padding-bottom: 0 }
.chain-dot-wrap { display: flex; flex-direction: column; align-items: center; flex-shrink: 0 }
.chain-dot  { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; background: var(--border2) }
.chain-line { width: 1px; flex: 1; min-height: 20px; margin: 4px 0; background: var(--border) }
.chain-body { flex: 1; padding-bottom: 20px }
.chain-name { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 4px }
.chain-sub  { font-size: 13px; color: var(--text2); line-height: 1.62 }

/* MISC */
.alert { padding: 14px 18px; border-left: 3px solid var(--text); background: var(--s2); font-size: 13px; line-height: 1.7 }
.flow { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin: 16px 0 }
.flow-node { font-size: 13px; font-weight: 600; color: var(--text); background: var(--s2); border: 1px solid var(--border); padding: 8px 16px; border-radius: 2px }
.flow-arrow { color: var(--text3); font-family: var(--fm); font-size: 14px }
.flow-node.highlight { background: var(--accent-f); border-color: var(--accent); color: var(--accent) }

.stabs { display: flex; gap: 8px; margin-bottom: 24px }
.stab {
  font-family: var(--fu); font-size: 12px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  padding: 10px 18px; border-radius: 2px; cursor: pointer;
  border: 1px solid var(--border); background: var(--s1); color: var(--text2); transition: all .2s;
}
.stab.active, .stab.aa, .stab.bb { background: var(--accent-f); border-color: var(--accent); color: var(--accent) }

.ss-sec { display: none }
.ss-sec.active { display: block }

.pi { display: flex; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--border) }
.pi:last-child { border: none }
.pn { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; font-family: var(--fd); font-size: 18px; flex-shrink: 0; border: 1px solid var(--border2); background: var(--s2) }
.pc { flex: 1 }
.ptitle { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 4px }
.pwhen  { font-family: var(--fm); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 6px; color: var(--text3) }
.pdesc  { font-size: 13px; color: var(--text2); line-height: 1.6 }

.qbox { background: var(--s2); border-left: 3px solid var(--border2); padding: 16px 20px; margin-bottom: 24px }
.qt { font-family: var(--fm); font-size: 12px; color: var(--text); line-height: 1.72; font-style: italic }

.co-card { background: var(--s1); border: 1px solid var(--border); padding: 18px 20px; transition: border-color .2s; }
.co-card:hover { border-color: var(--border2); }
.co-name  { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 4px }
.co-title { font-family: var(--fm); font-size: 10px; color: var(--text2); margin-bottom: 8px }

.idea-hero { border: 1px solid var(--border); padding: 36px 40px; margin-bottom: 24px; background: var(--s1) }
.idea-title { font-family: var(--fd); font-size: 46px; color: var(--accent); letter-spacing: .04em; margin-bottom: 12px }
.idea-sub   { font-size: 14px; color: var(--text2); line-height: 1.78; max-width: 680px }

/* MODALS */
.overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.85); z-index: 200;
  display: flex; align-items: center; justify-content: center; padding: 20px;
  opacity: 0; pointer-events: none; transition: opacity .2s;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.overlay.open { opacity: 1; pointer-events: all }
.mbox {
  background: var(--bg); border: 1px solid var(--border2); padding: 32px;
  width: 100%; max-width: 460px;
}
.mtitle { font-family: var(--fd); font-size: 32px; color: var(--accent); margin-bottom: 24px; letter-spacing: .05em }
.field { margin-bottom: 16px }
.field label { display: block; font-family: var(--fm); font-size: 10px; color: var(--text2); letter-spacing: .15em; text-transform: uppercase; margin-bottom: 8px }
.field input, .field textarea { width: 100%; font-family: var(--fu); font-size: 15px; background: var(--s1); border: 1px solid var(--border); color: var(--text); padding: 12px 16px; outline: none; }
.field input:focus, .field textarea:focus { border-color: var(--accent) }
.mact { display: flex; gap: 12px; justify-content: flex-end; margin-top: 24px }

/* ═══════════════════════════════════════════
   AITAMIN ROADMAP SCOPED STYLES
   ════════════════════════════════════════════ */
#tab-aitamin {
  --bg: var(--s1);
  --s1: var(--s2);
  --s2: var(--s3);
  --s3: var(--border);
  --border: var(--border);
  --border2: var(--border2);
  --border3: var(--text3);
  --black: var(--text);
  --gray1: var(--text);
  --gray2: var(--text2);
  --gray3: var(--text3);
  --gray4: var(--text3);
  --gray5: var(--border);
  --fu: 'Inter', sans-serif;
  --fm: 'JetBrains Mono', monospace;
  font-family: var(--fu);
}

#tab-aitamin .aitamin-nav { border-bottom: 1px solid var(--border2); background: var(--bg); overflow-x: auto; margin-bottom: 28px; }
#tab-aitamin .aitamin-nav-inner { display: flex; }
#tab-aitamin .aitamin-ntab { font-family: var(--fm); font-size: 11px; font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase; color: var(--gray4); padding: 14px 18px; cursor: pointer; border: none; background: transparent; border-bottom: 2px solid transparent; white-space: nowrap; transition: all .15s; }
#tab-aitamin .aitamin-ntab:hover { color: var(--gray2); }
#tab-aitamin .aitamin-ntab.active { color: var(--black); border-bottom-color: var(--black); }

#tab-aitamin .panel { display: none }
#tab-aitamin .panel.active { display: block; animation: aitaminFade .2s ease }
@keyframes aitaminFade { from { opacity: 0 } to { opacity: 1 } }

#tab-aitamin .pn { font-family: var(--fm); font-size: 11px; color: var(--gray4); letter-spacing: 0.1em; margin-bottom: 8px }
#tab-aitamin .pt { font-size: 36px; font-weight: 800; letter-spacing: -0.02em; line-height: 1.1; margin-bottom: 16px }
#tab-aitamin .pl { font-size: 16px; color: var(--gray2); line-height: 1.7; max-width: 680px; margin-bottom: 36px }

#tab-aitamin .sn { font-family: var(--fm); font-size: 10px; color: var(--gray4); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--border2) }
#tab-aitamin .sec { margin-bottom: 44px }

#tab-aitamin .g2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px }
#tab-aitamin .g3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px }

#tab-aitamin .card { border: 1px solid var(--border2); padding: 22px 24px; margin-bottom: 14px; background: var(--bg); }
#tab-aitamin .card-h { font-size: 16px; font-weight: 700; margin-bottom: 8px; letter-spacing: -0.01em }
#tab-aitamin .card-b { font-size: 13.5px; color: var(--gray2); line-height: 1.75 }

#tab-aitamin .step { display: flex; gap: 18px; padding: 20px 0; border-bottom: 1px solid var(--border) }
#tab-aitamin .step:last-child { border: none }
#tab-aitamin .step-n { font-family: var(--fm); font-size: 13px; font-weight: 700; width: 32px; flex-shrink: 0; padding-top: 2px; color: var(--gray3) }
#tab-aitamin .step-b { flex: 1 }
#tab-aitamin .step-t { font-size: 16px; font-weight: 700; margin-bottom: 6px; letter-spacing: -0.01em }
#tab-aitamin .step-d { font-size: 13.5px; color: var(--gray2); line-height: 1.75 }
#tab-aitamin .step-tag { display: inline-block; font-family: var(--fm); font-size: 10px; color: var(--gray3); border: 1px solid var(--border2); padding: 2px 8px; margin-top: 8px; letter-spacing: 0.03em }

#tab-aitamin .script { border-left: 3px solid var(--black); padding: 16px 20px; margin: 16px 0; background: var(--s1) }
#tab-aitamin .script-l { font-family: var(--fm); font-size: 9px; color: var(--gray4); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 8px }
#tab-aitamin .script-t { font-size: 13.5px; line-height: 1.8; font-style: italic; color: var(--gray1) }

#tab-aitamin .tbl { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 13px }
#tab-aitamin .tbl th { text-align: left; font-family: var(--fm); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--gray4); padding: 10px 14px; border-bottom: 2px solid var(--black) }
#tab-aitamin .tbl td { padding: 12px 14px; border-bottom: 1px solid var(--border); color: var(--gray2); vertical-align: top }
#tab-aitamin .tbl tr:last-child td { border-bottom: 1px solid var(--border2) }

#tab-aitamin .cl { display: flex; align-items: flex-start; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border) }
#tab-aitamin .cl:last-child { border: none }
#tab-aitamin .cl-box { width: 14px; height: 14px; border: 1.5px solid var(--gray3); flex-shrink: 0; margin-top: 3px }
#tab-aitamin .cl-t { font-size: 13.5px; color: var(--gray1); line-height: 1.6 }
#tab-aitamin .cl-t strong { font-weight: 700 }

#tab-aitamin .flow { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin: 18px 0 }
#tab-aitamin .fn { font-family: var(--fm); font-size: 12px; border: 1px solid var(--border3); padding: 8px 14px; font-weight: 500 }
#tab-aitamin .fn.solid { background: var(--black); color: var(--bg); border-color: var(--black) }
#tab-aitamin .fa { color: var(--gray4); font-size: 14px }

#tab-aitamin .warn { border: 1px solid var(--black); padding: 16px 20px; margin: 16px 0 }
#tab-aitamin .warn-h { font-family: var(--fm); font-size: 10px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px }
#tab-aitamin .warn-b { font-size: 13px; color: var(--gray2); line-height: 1.75 }

#tab-aitamin .tlb { border: 1px solid var(--border2); margin-bottom: 0; border-top: none; background: var(--bg); }
#tab-aitamin .tlb:first-child { border-top: 1px solid var(--border2) }
#tab-aitamin .tlb-h { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--border) }
#tab-aitamin .tlb-week { font-family: var(--fm); font-size: 11px; font-weight: 700; letter-spacing: 0.04em }
#tab-aitamin .tlb-focus { font-size: 11px; color: var(--gray3); font-family: var(--fm) }
#tab-aitamin .tlb-body { padding: 18px 22px }
#tab-aitamin .tlb-item { font-size: 13.5px; color: var(--gray2); line-height: 1.9 }
#tab-aitamin .tlb-item::before { content: '— '; color: var(--gray4) }

#tab-aitamin .price-card { border: 1px solid var(--border2); padding: 20px 22px; text-align: center; background: var(--bg); }
#tab-aitamin .price-card.featured { border: 2px solid var(--black) }
#tab-aitamin .price-name { font-family: var(--fm); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--gray3); margin-bottom: 10px }
#tab-aitamin .price-amt { font-size: 32px; font-weight: 800; letter-spacing: -0.02em; margin-bottom: 4px }
#tab-aitamin .price-sub { font-size: 11px; color: var(--gray4); margin-bottom: 16px }
#tab-aitamin .price-list { text-align: left; font-size: 12.5px; color: var(--gray2); line-height: 2; list-style: none }
#tab-aitamin .price-list li::before { content: '+ '; color: var(--gray4) }

@media(max-width:760px){
  #tab-aitamin .g2, #tab-aitamin .g3 { grid-template-columns: 1fr }
}
@media(max-width:680px){
  #tab-aitamin .pt { font-size: 26px }
}

/* ═══════════════════════════════════════════
   LOCAL AI MAP SCOPED STYLES
   ════════════════════════════════════════════ */
#tab-localai {
  --black: var(--text);
  --white: var(--bg);
  --grey: var(--text2);
  --mid: var(--border);
  --light: var(--s2);
  --mono: 'Space Mono', monospace;
  --sans: 'Inter', sans-serif;
  
  font-family: var(--sans);
  background: var(--white);
  color: var(--black);
  line-height: 1.6;
  border-radius: var(--radius);
  border: 1px solid var(--mid);
  overflow: hidden;
  margin-top: 14px;
}

#tab-localai h1 { font-family: var(--mono); font-size: clamp(2.2rem, 5.5vw, 4.5rem); font-weight: 700; line-height: 1.05; letter-spacing: -0.02em; }
#tab-localai h2 { font-family: var(--mono); font-size: clamp(1.2rem, 2.8vw, 2rem); font-weight: 700; }
#tab-localai .eyebrow { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--grey); }

#tab-localai .wrap { max-width: 1140px; margin: 0 auto; padding: 0 2rem; }
#tab-localai section { padding: 5rem 0; }
#tab-localai .dark { background: var(--black); color: var(--white); }
#tab-localai .lite { background: var(--light); }

/* LOCALAI NAV */
#tab-localai .localai-nav {
  padding: 1.2rem 2rem;
  border-bottom: 1px solid var(--black);
  display: flex; justify-content: space-between; align-items: center;
}
#tab-localai .nav-brand { font-family: var(--mono); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.08em; }
#tab-localai .nav-meta { font-family: var(--mono); font-size: 0.62rem; color: var(--grey); letter-spacing: 0.12em; text-transform: uppercase; }

/* HERO */
#tab-localai .hero { padding: 7rem 0 5rem; border-bottom: 1px solid var(--black); }
#tab-localai .hero-tag {
  display: inline-block; border: 1px solid var(--black);
  font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.15em;
  text-transform: uppercase; padding: 0.35rem 0.75rem; margin-bottom: 2.5rem;
}
#tab-localai .hero h1 { margin-bottom: 1.25rem; max-width: 920px; }
#tab-localai .hero-sub { font-size: 1.05rem; color: var(--grey); font-weight: 300; max-width: 560px; margin-bottom: 4rem; }

/* 5 PROPERTIES */
#tab-localai .props {
  display: grid; grid-template-columns: repeat(5, 1fr);
  border-top: 1px solid var(--black); border-left: 1px solid var(--black);
}
#tab-localai .prop { padding: 1.5rem; border-right: 1px solid var(--black); border-bottom: 1px solid var(--black); }
#tab-localai .prop-sym { font-family: var(--mono); font-size: 1.3rem; margin-bottom: 0.75rem; }
#tab-localai .prop-name { font-family: var(--mono); font-size: 0.72rem; font-weight: 700; margin-bottom: 0.4rem; }
#tab-localai .prop-desc { font-size: 0.76rem; color: var(--grey); line-height: 1.5; }

/* MENTAL MODEL */
#tab-localai .mental-grid {
  display: grid; grid-template-columns: 1fr 56px 1fr;
  margin-top: 3rem;
}
#tab-localai .m-col { border: 1px solid var(--black); padding: 2.5rem; }
#tab-localai .m-col.m-new { background: var(--black); color: var(--white); }
#tab-localai .m-vs {
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono); font-size: 0.72rem; font-weight: 700; color: var(--grey);
}
#tab-localai .flow-box {
  border: 1px solid currentColor; padding: 0.55rem 1rem;
  font-family: var(--mono); font-size: 0.78rem; font-weight: 700;
}
#tab-localai .flow-down { font-family: var(--mono); padding: 0.18rem 1rem; color: var(--grey); font-size: 0.85rem; }
#tab-localai .m-new .flow-down { color: #444; }
#tab-localai .flow-note { font-size: 0.74rem; color: var(--grey); margin-top: 1.5rem; line-height: 1.6; font-style: italic; }
#tab-localai .m-new .flow-note { color: #555; }

/* ANALOGY */
#tab-localai .analogy-cols {
  display: grid; grid-template-columns: 1fr 1fr;
  margin-top: 3rem; border-top: 1px solid rgba(255,255,255,0.15); border-left: 1px solid rgba(255,255,255,0.15);
}
#tab-localai .a-col { padding: 3rem 2.5rem; border-right: 1px solid rgba(255,255,255,0.15); border-bottom: 1px solid rgba(255,255,255,0.15); }
#tab-localai .a-label { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: #444; margin-bottom: 2rem; }
#tab-localai .a-box { border: 1px solid rgba(255,255,255,0.25); padding: 0.7rem 1.5rem; font-family: var(--mono); font-size: 0.88rem; font-weight: 700; }
#tab-localai .a-sub { font-size: 0.74rem; color: #555; padding: 0.2rem 1.5rem; font-style: italic; }
#tab-localai .a-down { font-family: var(--mono); padding: 0.2rem 1.5rem; color: #444; }
#tab-localai .analogy-quote {
  margin-top: 2.5rem; padding: 2rem;
  border: 1px solid #222; font-family: var(--mono); font-size: 0.82rem; line-height: 1.9;
}
#tab-localai .analogy-quote .hl { color: var(--white); font-weight: 700; }
#tab-localai .analogy-quote .dim { color: #555; }

/* CATEGORY BLOCKS */
#tab-localai .cat-block { margin-top: 3rem; }
#tab-localai .cat-header {
  display: flex; align-items: center; gap: 1.5rem;
  padding: 1.2rem 0 0.8rem; border-top: 1px solid var(--mid);
}
#tab-localai .cat-name { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--grey); }
#tab-localai .cat-count { font-family: var(--mono); font-size: 0.6rem; color: var(--mid); }

#tab-localai .app-grid {
  display: grid;
  border-top: 1px solid var(--black); border-left: 1px solid var(--black);
}
#tab-localai .g4 { grid-template-columns: repeat(4, 1fr); }
#tab-localai .g5 { grid-template-columns: repeat(5, 1fr); }
#tab-localai .g3 { grid-template-columns: repeat(3, 1fr); }
#tab-localai .g2 { grid-template-columns: repeat(2, 1fr); }
#tab-localai .g1 { grid-template-columns: 1fr; }

#tab-localai .app-card { padding: 1.5rem; border-right: 1px solid var(--black); border-bottom: 1px solid var(--black); }
#tab-localai .app-title { font-family: var(--mono); font-size: 0.78rem; font-weight: 700; margin-bottom: 0.7rem; }
#tab-localai .app-sub { font-size: 0.74rem; color: var(--grey); margin-bottom: 0.7rem; line-height: 1.5; }
#tab-localai .app-pts { list-style: none; font-size: 0.76rem; color: var(--grey); }
#tab-localai .app-pts li { margin-bottom: 0.22rem; }
#tab-localai .app-pts li::before { content: '→ '; font-family: var(--mono); color: var(--black); }

/* AGENT DIAGRAM */
#tab-localai .agent-wrap {
  display: grid; grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--black); border-left: 1px solid var(--black);
}
#tab-localai .agent-panel { border-right: 1px solid var(--black); border-bottom: 1px solid var(--black); }
#tab-localai .panel-head { padding: 1.5rem; border-bottom: 1px solid var(--black); }
#tab-localai .panel-body { padding: 1.5rem; }
#tab-localai .goal-bar {
  font-family: var(--mono); font-size: 0.72rem;
  background: var(--black); color: var(--white);
  padding: 0.75rem 1rem; margin-bottom: 0;
}
#tab-localai .step-track { display: flex; }
#tab-localai .track-line { width: 1px; background: var(--black); margin: 0 1.5rem 0 1rem; flex-shrink: 0; }
#tab-localai .steps { flex: 1; padding: 0.25rem 0; }
#tab-localai .step {
  border: 1px solid var(--black); padding: 0.7rem 1rem;
  margin: 0.45rem 0; display: flex; gap: 0.75rem; align-items: flex-start;
}
#tab-localai .step-n { font-family: var(--mono); font-size: 0.6rem; color: var(--grey); min-width: 1.2rem; margin-top: 0.15rem; }
#tab-localai .step-name { font-family: var(--mono); font-size: 0.74rem; font-weight: 700; margin-bottom: 0.2rem; }
#tab-localai .step-desc { font-size: 0.71rem; color: var(--grey); }

#tab-localai .swarm-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--black); border-left: 1px solid var(--black);
}
#tab-localai .swarm-cell { padding: 1rem; border-right: 1px solid var(--black); border-bottom: 1px solid var(--black); }
#tab-localai .swarm-name { font-family: var(--mono); font-size: 0.7rem; font-weight: 700; margin-bottom: 0.3rem; }
#tab-localai .swarm-desc { font-size: 0.7rem; color: var(--grey); }
#tab-localai .swarm-note {
  margin-top: 1.25rem; padding: 1rem; border: 1px solid var(--mid);
  font-family: var(--mono); font-size: 0.7rem; color: var(--grey); line-height: 1.7;
}

/* SKILLS */
#tab-localai .skills-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid rgba(255,255,255,0.15); border-left: 1px solid rgba(255,255,255,0.15);
  margin-top: 3rem;
}
#tab-localai .sk-card { padding: 2.5rem; border-right: 1px solid rgba(255,255,255,0.15); border-bottom: 1px solid rgba(255,255,255,0.15); }
#tab-localai .sk-num { font-family: var(--mono); font-size: 0.6rem; color: #444; margin-bottom: 1rem; letter-spacing: 0.1em; text-transform: uppercase; }
#tab-localai .sk-name { font-family: var(--mono); font-size: 1.05rem; font-weight: 700; margin-bottom: 1rem; }
#tab-localai .sk-desc { font-size: 0.8rem; color: #888; line-height: 1.7; }
#tab-localai .sk-code {
  margin-top: 1.5rem; padding: 1rem; border: 1px solid #222;
  font-family: var(--mono); font-size: 0.7rem; color: #555; line-height: 1.8;
}
#tab-localai .skills-meta {
  margin-top: 2rem; padding: 2rem; border: 1px solid #1a1a1a;
  display: flex; gap: 3rem; flex-wrap: wrap;
}
#tab-localai .meta-item { }
#tab-localai .meta-label { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; color: #444; margin-bottom: 0.4rem; }
#tab-localai .meta-val { font-family: var(--mono); font-size: 0.78rem; color: #888; }

/* ENTRY POINT */
#tab-localai .entry-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--black); border-left: 1px solid var(--black);
  margin-top: 3rem;
}
#tab-localai .entry-col { padding: 2.5rem; border-right: 1px solid var(--black); border-bottom: 1px solid var(--black); }
#tab-localai .entry-col.inv { background: var(--black); color: var(--white); }
#tab-localai .pitch-headline { font-family: var(--mono); font-size: 1.15rem; font-weight: 700; line-height: 1.5; margin-bottom: 1.25rem; }
#tab-localai .pitch-body { font-size: 0.82rem; color: #888; line-height: 1.8; }
#tab-localai .pitch-box {
  margin-top: 1.75rem; padding: 1.25rem; border: 1px solid #222;
  font-family: var(--mono); font-size: 0.74rem; color: #666; line-height: 1.9;
}
#tab-localai .pitch-box .w { color: var(--white); }
#tab-localai .entry-label { font-family: var(--mono); font-size: 0.62rem; color: var(--grey); letter-spacing: 0.15em; text-transform: uppercase; margin-bottom: 1.5rem; }
#tab-localai .stack { display: flex; flex-direction: column; }
#tab-localai .stack-row {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.65rem 0; border-bottom: 1px solid var(--mid);
  font-family: var(--mono); font-size: 0.76rem;
}
#tab-localai .stack-arrow { color: var(--grey); }
#tab-localai .stack-status { margin-left: auto; font-size: 0.62rem; color: var(--grey); letter-spacing: 0.08em; text-transform: uppercase; }
#tab-localai .entry-note {
  margin-top: 1.75rem; padding: 1.25rem; border: 1px solid var(--mid);
  font-family: var(--mono); font-size: 0.72rem; color: var(--grey); line-height: 1.8;
}

/* CLOSING */
#tab-localai .closing { padding: 8rem 0; border-top: 2px solid var(--black); text-align: center; background: var(--black); color: var(--white); }
#tab-localai .closing-q {
  font-family: var(--mono); font-size: clamp(1.1rem, 2.5vw, 1.85rem);
  font-weight: 700; max-width: 750px; margin: 0 auto 2rem; line-height: 1.5;
}
#tab-localai .closing-sub { color: #555; font-size: 0.88rem; max-width: 480px; margin: 0 auto 3rem; line-height: 1.7; }
#tab-localai .closing-mark { font-family: var(--mono); font-size: 0.62rem; color: #333; letter-spacing: 0.18em; text-transform: uppercase; }

/* RESPONSIVE */
@media (max-width: 860px) {
  #tab-localai .props { grid-template-columns: repeat(2, 1fr); }
  #tab-localai .mental-grid { grid-template-columns: 1fr; }
  #tab-localai .m-vs { padding: 0.75rem; border: none; }
  #tab-localai .analogy-cols { grid-template-columns: 1fr; }
  #tab-localai .g4, #tab-localai .g5 { grid-template-columns: repeat(2, 1fr); }
  #tab-localai .g3 { grid-template-columns: repeat(2, 1fr); }
  #tab-localai .agent-wrap { grid-template-columns: 1fr; }
  #tab-localai .skills-grid { grid-template-columns: 1fr; }
  #tab-localai .entry-grid { grid-template-columns: 1fr; }
  #tab-localai .skills-meta { flex-direction: column; gap: 1.5rem; }
}
@media (max-width: 520px) {
  #tab-localai .g2, #tab-localai .g3, #tab-localai .g4, #tab-localai .g5 { grid-template-columns: 1fr; }
  #tab-localai .swarm-grid { grid-template-columns: 1fr; }
}
