:root { --dark-blue: #003366; --red-accent: #c0392b; --paper: #fdfaf6; }

body { font-family: 'Inter', sans-serif; background: var(--paper); color: var(--dark-blue); margin: 0; }
.main-container { max-width: 1000px; margin: 0 auto; padding: 4rem 2rem; background: #fff; box-shadow: 0 0 20px rgba(0,0,0,0.05); }

.stately-blue { color: var(--dark-blue); font-weight: 800; text-transform: uppercase; letter-spacing: 0.5px; }
.body-blue { color: var(--dark-blue); line-height: 1.6; }
.manifesto-text { font-style: italic; border-left: 4px solid var(--dark-blue); padding-left: 1.5rem; font-size: 1.1rem; margin-bottom: 3rem; }

/* TICKER TAPE */
.ticker-container { background: #000; color: #00ff00; overflow: hidden; white-space: nowrap; padding: 10px 0; position: sticky; top: 0; z-index: 1000; }
.ticker-text { display: inline-block; padding-left: 100%; animation: ticker-move 30s linear infinite; font-family: monospace; }
.ticker-text span { padding-right: 50px; }
@keyframes ticker-move { 0% { transform: translate(0, 0); } 100% { transform: translate(-100%, 0); } }

/* UNIFIED INPUT MATRIX STYLE */
.update-box { background: #fff; border: 1px solid #ddd; border-radius: 8px; padding: 30px; margin-bottom: 3rem; box-shadow: 0 4px 12px rgba(0,0,0,0.05); }
.input-row { display: flex; gap: 20px; margin-bottom: 15px; }
.input-item { flex: 1; }
.input-item label { display: block; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; color: #666; font-weight: 700; margin-bottom: 8px; }
.input-item label a { text-transform: none; color: var(--red-accent); text-decoration: none; }
.input-item input { width: 100%; padding: 12px; font-family: 'Inter', sans-serif; font-size: 1rem; font-weight: 600; color: var(--dark-blue); border: 1px solid #ccc; border-radius: 4px; background-color: #fcfcfc; }

/* DIVERGENCE METRIC */
.divergence-row { margin-top: 30px; border-top: 1px solid #eee; padding-top: 20px; }
.divergence-value { font-size: 1.4rem; font-weight: 800; color: var(--red-accent); }
.metric-label { font-size: 0.85rem; font-weight: 400; color: #666; text-transform: none; }

/* TABLES */
.red-bar { border-left: 5px solid var(--red-accent); padding-left: 15px; margin-top: 3rem; }
table { width: 100%; border-collapse: collapse; background: #fff; }
th { background: #f8f8f8; padding: 12px; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; color: #666; border: 1px solid #eee; }
td { padding: 12px; text-align: center; border: 1px solid #eee; font-size: 1rem; font-weight: 600; }
.active-row { background: #fff9db !important; }
.current-row { border: 2px solid #2980b9; color: #2980b9; font-weight: 800; }

/* DEBT REPORT CHART STYLES */
.chart-box { background: #fff; border: 1px solid #ddd; padding: 30px; border-radius: 8px; margin-top: 20px; box-shadow: 0 4px 10px rgba(0,0,0,0.03); }
.chart-footer-metrics { display: flex; justify-content: space-around; margin-top: 20px; text-align: center; }
.metric-block { flex: 1; padding: 10px; }
.metric-label { display: block; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; color: #666; font-weight: 700; }
.metric-value { display: block; font-size: 2rem; font-weight: 800; color: var(--dark-blue); margin: 5px 0; }
.metric-sub { display: block; font-size: 0.85rem; font-weight: 600; color: #c0392b; }

/* RISK ALERT BUTTON */
.risk-alert-btn { background: #c0392b; color: white !important; padding: 10px 20px; border-radius: 4px; font-weight: bold; text-decoration: none; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.5px; }

/* FOOTNOTE */
.footnote-authorship { font-size: 0.7rem; line-height: 1.5; color: #555; }
.stately-footer { background: #111; padding: 3rem 10%; border-top: 4px solid var(--dark-blue); margin-top: 5rem; }

.info-popup { display: none; position: fixed; top: 20%; left: 50%; transform: translateX(-50%); width: 80%; max-width: 500px; background: #fff; border: 2px solid var(--dark-blue); padding: 30px; z-index: 1000; box-shadow: 0 10px 40px rgba(0,0,0,0.2); }
.info-icon { cursor: pointer; color: var(--red-accent); font-weight: bold; margin-left: 8px; font-size: 1rem; }

@media print { .no-print { display: none !important; } .info-popup { display: none !important; } }