/* the-forum-is-live.css — extracted from inline <style> blocks. Generated by scripts/h1-extract.mjs */
/* ============================================================
         FORUM POST animations — .frm-* namespace
         All rules use existing /style.css CSS variables.
         ============================================================ */
      .frm-section { border: 1px solid var(--border); background: var(--bg-card); padding: 20px; margin: 28px 0; position: relative; }
      .frm-h { font-size: 11px; color: var(--green); text-transform: uppercase; letter-spacing: 2px; margin: 0 0 16px; font-weight: 700; text-align: center; }
      .frm-cap { text-align: center; font-size: 11px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 2px; margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--border); }

      /* ── A. tier ladder ──────────────────────────────── */
      .frm-ladder-grid { display: grid; grid-template-columns: 1.05fr 1.4fr; gap: 22px; align-items: stretch; }
      .frm-ladder-graphic { position: relative; }
      .frm-ladder-svg { width: 100%; height: 480px; display: block; }
      .frm-rail { stroke: #00aa33; stroke-width: 2.5; opacity: 0.55; }
      .frm-rung-line { stroke: #007a22; stroke-width: 4; transition: stroke 0.4s ease, filter 0.4s ease; }
      .frm-rung-label { fill: var(--text-muted); font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 700; transition: fill 0.4s ease; letter-spacing: 1px; }
      .frm-rung.frm-rung-on .frm-rung-line { stroke: var(--green); filter: drop-shadow(0 0 6px rgba(0,255,65,0.6)); }
      .frm-rung.frm-rung-on .frm-rung-label { fill: var(--green); }
      .frm-avatar-dot { fill: var(--green); stroke: #001a08; stroke-width: 2; filter: drop-shadow(0 0 10px var(--green)); transition: cy 0.6s cubic-bezier(.4,.05,.2,1); }
      .frm-rooms-side { display: flex; flex-direction: column; gap: 6px; }
      .frm-rooms-side .frm-room { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border: 1px solid var(--border); background: var(--bg-terminal); font-family: 'JetBrains Mono', monospace; font-size: 11.5px; color: var(--text-muted); transition: color 0.35s, border-color 0.35s, background 0.35s; line-height: 1.3; }
      .frm-rooms-side .frm-room .frm-rk-icon { font-size: 11px; opacity: 0.7; min-width: 12px; text-align: center; }
      .frm-rooms-side .frm-room .frm-rk-meta { margin-left: auto; font-size: 9.5px; color: var(--text-muted); letter-spacing: 1px; text-transform: uppercase; }
      .frm-rooms-side .frm-room.frm-on { color: var(--white); border-color: var(--green); background: rgba(0,255,65,0.06); }
      .frm-rooms-side .frm-room.frm-on .frm-rk-icon { color: var(--green); opacity: 1; }
      .frm-rooms-side .frm-room.frm-on .frm-rk-meta { color: var(--green-dim); }
      .frm-rank-input { margin-top: 14px; padding: 12px 14px; border: 1px solid var(--border); background: var(--bg-terminal); }
      .frm-rank-input label { display: block; font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 6px; }
      .frm-rank-slider { -webkit-appearance: none; appearance: none; width: 100%; height: 28px; background: transparent; accent-color: var(--green); margin: 0; cursor: pointer; }
      .frm-rank-slider:focus { outline: 1px solid var(--green); }
      .frm-rank-out { color: var(--green); font-size: 16px; font-weight: 700; font-family: 'JetBrains Mono', monospace; margin-left: 8px; }
      .frm-cohort-out { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-dim); margin-top: 8px; line-height: 1.6; }
      .frm-cohort-out strong { color: var(--green); }

      /* ── B. cohort doubling waves ────────────────────── */
      .frm-waves-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: stretch; }
      .frm-waves-svg { width: 100%; height: 340px; display: block; }
      .frm-wave-ring { fill: none; stroke: #00aa33; stroke-width: 1.6; opacity: 0.45; transition: opacity 0.25s ease, stroke 0.25s ease, stroke-width 0.25s ease, filter 0.25s ease; cursor: pointer; pointer-events: stroke; }
      .frm-wave-ring.frm-active { opacity: 1; stroke: var(--green); stroke-width: 2.6; filter: drop-shadow(0 0 8px rgba(0,255,65,0.6)); }
      .frm-wave-label { fill: var(--green-dim); font-family: 'JetBrains Mono', monospace; font-size: 10px; pointer-events: none; transition: fill 0.25s ease; }
      .frm-wave-label.frm-active { fill: var(--green); font-weight: 700; }
      .frm-wave-pointer { fill: var(--green); filter: drop-shadow(0 0 6px rgba(0,255,65,0.7)); transition: cx 0.3s ease, cy 0.3s ease; }
      .frm-wave-info { padding: 14px 16px; border: 1px solid var(--border); background: var(--bg-terminal); font-family: 'JetBrains Mono', monospace; font-size: 12px; line-height: 1.6; display: flex; flex-direction: column; }
      .frm-wave-info h5 { margin: 0 0 8px; font-size: 12px; color: var(--green); letter-spacing: 1.5px; text-transform: uppercase; }
      .frm-wave-info .frm-wv-row { display: flex; justify-content: space-between; padding: 5px 0; border-bottom: 1px dashed rgba(0,255,65,0.12); }
      .frm-wave-info .frm-wv-row span:last-child { color: var(--green); }
      .frm-wave-rooms { margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--border); font-size: 11px; color: var(--text-dim); line-height: 1.55; }
      .frm-wave-rooms strong { color: var(--green-dim); }

      /* ── C. founders 10k ─────────────────────────────── */
      .frm-fnd-stage { display: grid; grid-template-columns: 1fr 0.8fr; gap: 18px; align-items: stretch; }
      .frm-fnd-grid { position: relative; border: 1px solid var(--border); background: #000; aspect-ratio: 1; box-shadow: inset 0 0 24px rgba(0,255,65,0.08); overflow: hidden; }
      .frm-fnd-canvas { display: block; width: 100%; height: 100%; }
      .frm-fnd-gate { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 6px; background: linear-gradient(180deg, rgba(255,51,51,0.18), rgba(0,0,0,0.92)); border: 2px solid #ff3333; color: #ff5555; font-family: 'JetBrains Mono', monospace; font-size: 16px; font-weight: 800; letter-spacing: 4px; opacity: 0; transform: scaleY(0); transform-origin: top; transition: opacity 0.45s ease, transform 0.55s cubic-bezier(.6,.05,.3,1); pointer-events: none; }
      .frm-fnd-gate.frm-shut { opacity: 1; transform: scaleY(1); }
      .frm-fnd-gate small { display: block; font-size: 10px; color: #ffb0b0; letter-spacing: 1.5px; margin-top: 6px; font-weight: 600; max-width: 80%; text-align: center; line-height: 1.4; }
      .frm-fnd-side { display: flex; flex-direction: column; justify-content: space-between; gap: 14px; padding: 18px; border: 1px solid var(--border); background: var(--bg-terminal); }
      .frm-fnd-counter { font-family: 'JetBrains Mono', monospace; font-size: 36px; font-weight: 800; color: var(--green); line-height: 1; letter-spacing: 1px; }
      .frm-fnd-counter .frm-fnd-of { font-size: 13px; color: var(--text-muted); margin-left: 6px; letter-spacing: 1px; font-weight: 600; }
      .frm-fnd-label { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 2px; margin-top: 6px; }
      .frm-fnd-bar { height: 12px; background: #0a0a0a; border: 1px solid var(--border); position: relative; overflow: hidden; }
      .frm-fnd-bar-fill { height: 100%; width: 0%; background: linear-gradient(90deg, #003311, var(--green)); box-shadow: inset 0 0 8px rgba(0,255,65,0.6); transition: width 0.05s linear; }
      .frm-fnd-badge { display: inline-block; padding: 5px 10px; border: 1px dashed var(--green); color: var(--green); font-family: 'JetBrains Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 1.5px; align-self: flex-start; }
      .frm-fnd-replay { display: inline-flex; align-items: center; gap: 6px; padding: 9px 16px; min-height: 36px; background: transparent; border: 1px solid var(--green-dark); color: var(--green); font-family: 'JetBrains Mono', monospace; font-size: 11px; text-transform: uppercase; letter-spacing: 2px; cursor: pointer; align-self: flex-start; transition: background 0.2s, color 0.2s; font-weight: 700; }
      .frm-fnd-replay:hover:not(:disabled) { background: var(--green); color: #000; }
      .frm-fnd-replay:disabled { opacity: 0.4; cursor: not-allowed; }

      /* ── D. room sorter ──────────────────────────────── */
      .frm-sort-stage { display: flex; flex-direction: column; gap: 14px; }
      .frm-sort-pool { border: 1px dashed var(--border); background: var(--bg-terminal); padding: 12px; min-height: 70px; display: flex; flex-wrap: wrap; gap: 8px; align-items: flex-start; }
      .frm-sort-pool h6 { width: 100%; margin: 0 0 4px; font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 2px; font-weight: 700; }
      .frm-chip { display: inline-flex; align-items: center; padding: 8px 12px; min-height: 36px; background: #001a08; border: 1px solid var(--green-dark); color: var(--white); font-family: 'JetBrains Mono', monospace; font-size: 11px; cursor: grab; user-select: none; touch-action: none; transition: transform 0.18s ease, border-color 0.2s, box-shadow 0.2s, background 0.2s, color 0.2s; line-height: 1.2; text-align: left; }
      .frm-chip:hover { border-color: var(--green); box-shadow: 0 0 10px rgba(0,255,65,0.18); }
      .frm-chip.frm-drag { cursor: grabbing; opacity: 0.95; box-shadow: 0 0 22px rgba(0,255,65,0.45); border-color: var(--green); z-index: 100; }
      .frm-chip.frm-floating { position: fixed; pointer-events: none; }
      .frm-chip.frm-bounce { animation: frmBounce 0.5s ease; border-color: #ff3333; box-shadow: 0 0 14px rgba(255,51,51,0.45); }
      .frm-chip.frm-correct { border-color: var(--green); background: rgba(0,255,65,0.16); color: var(--green); cursor: default; }
      .frm-chip.frm-correct::after { content: ' ✓'; color: var(--green); font-weight: 700; margin-left: 6px; }
      @keyframes frmBounce { 0%   { transform: translate(0,0); } 25%  { transform: translate(-7px, 4px); } 55%  { transform: translate(6px, -3px); } 85%  { transform: translate(-3px, 1px); } 100% { transform: translate(0,0); } }
      .frm-sort-rooms { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
      .frm-sort-room { border: 1px solid var(--border); background: var(--bg-card); padding: 10px 10px 12px; min-height: 130px; display: flex; flex-direction: column; gap: 6px; transition: border-color 0.2s, background 0.2s; }
      .frm-sort-room.frm-hover { border-color: var(--green); background: rgba(0,255,65,0.08); }
      .frm-sort-room.frm-flash-ok { border-color: var(--green); background: rgba(0,255,65,0.18); }
      .frm-sort-room.frm-flash-bad { border-color: #ff3333; background: rgba(255,51,51,0.12); }
      .frm-sort-room h5 { margin: 0; font-size: 10.5px; color: var(--green); letter-spacing: 1px; text-transform: uppercase; font-weight: 700; line-height: 1.2; }
      .frm-sort-room small { font-size: 9px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; }
      .frm-sort-room small.frm-private::before { content: '🔒 '; }
      .frm-sort-room small.frm-public::before { content: '🔓 '; }
      .frm-sort-bin { flex: 1; display: flex; flex-wrap: wrap; gap: 4px; align-content: flex-start; min-height: 30px; }
      .frm-sort-bin .frm-chip { font-size: 10px; padding: 4px 7px; min-height: 24px; }
      .frm-sort-status { display: flex; justify-content: space-between; align-items: center; padding: 10px 14px; border: 1px solid var(--border); background: var(--bg-terminal); font-family: 'JetBrains Mono', monospace; font-size: 11px; gap: 12px; flex-wrap: wrap; }
      .frm-sort-status .frm-sort-score { color: var(--green); font-weight: 700; flex-shrink: 0; }
      .frm-sort-status .frm-sort-tip { color: #ff8c8c; font-size: 11px; flex: 1; min-width: 180px; }
      .frm-sort-status .frm-sort-tip.frm-ok { color: var(--green-dim); }
      .frm-sort-reset { background: transparent; border: 1px solid var(--green-dark); color: var(--green); padding: 6px 14px; min-height: 32px; font-family: 'JetBrains Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 2px; cursor: pointer; font-weight: 700; flex-shrink: 0; }
      .frm-sort-reset:hover { background: var(--green); color: #000; }

      /* ── responsive ──────────────────────────────────── */
      @media (max-width: 720px) {
        .frm-ladder-grid { grid-template-columns: 1fr; gap: 14px; }
        .frm-ladder-svg  { height: 380px; }
        .frm-waves-grid  { grid-template-columns: 1fr; }
        .frm-waves-svg   { height: 280px; }
        .frm-fnd-stage   { grid-template-columns: 1fr; }
        .frm-sort-rooms  { grid-template-columns: repeat(2, 1fr); }
        .frm-sort-room   { min-height: 110px; }
        .frm-fnd-counter { font-size: 30px; }
      }

      /* ── reduced-motion overrides ───────────────────── */
      @media (prefers-reduced-motion: reduce) {
        .frm-chip.frm-bounce          { animation: none !important; }
        .frm-fnd-bar-fill, .frm-fnd-gate { transition: none !important; }
        .frm-wave-ring, .frm-wave-label, .frm-wave-pointer { transition: none !important; }
        .frm-rooms-side .frm-room      { transition: none !important; }
        .frm-rung-line, .frm-rung-label, .frm-avatar-dot { transition: none !important; }
      }
