:root{
  --bg:#eef4ff;
  --card:#ffffff;
  --ink:#122033;
  --muted:#5c6d85;
  --line:#d9e4f4;
  --blue:#2563eb;
  --blue-dark:#1949b6;
  --green:#e8f8ee;
  --green-ink:#10693a;
  --yellow:#fff4d6;
  --yellow-ink:#8b5d00;
  --shadow:0 12px 28px rgba(29,49,89,.10);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  background:linear-gradient(140deg,#edf5ff,#f9fbff 60%,#eef2ff);
  color:var(--ink);
}
#app{padding:20px}
.wrap{max-width:1300px;margin:0 auto; transition: all 0.3s;}
.hero{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.card{
  background:var(--card);
  border-radius:22px;
  box-shadow:var(--shadow);
}
.hero-left{
  padding:26px;
  color:white;
  background:linear-gradient(135deg,#0f172a,#17315f 62%,#204887);
  transition: background 0.5s;
}
.hero-left h1{margin:8px 0 10px;font-size:32px;line-height:1.3}
.kicker{font-size:12px;letter-spacing:.18em;font-weight:900;color:#9fc6ff}
.hero-right{display:grid;gap:18px}
.stat{padding:20px}
.stat .label{font-size:13px;letter-spacing:.1em;font-weight:900;color:var(--muted);text-transform:uppercase}
.stat .value{font-size:40px;font-weight:900;margin-top:6px}
.bar{height:14px;border-radius:999px;background:#dbeafe;overflow:hidden;margin-top:14px}
.fill{height:100%;background:linear-gradient(90deg,#2563eb,#0ea5e9); transition: width 0.4s ease;}
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}
.tab{
  border:none;
  background:white;
  padding:12px 16px;
  border-radius:16px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 4px 12px rgba(29,49,89,.06);
  transition: all 0.2s;
}
.tab:hover { background: #f0f5ff; }
.tab.active{background:#dbeafe;color:#1542a9}
.grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.group{padding:18px; transition: outline 0.2s, background 0.2s;}
.group.flash{outline:4px solid rgba(16,105,58,.5); background:#f4fbf7;}
.group-head{display:flex;justify-content:space-between;gap:10px;margin-bottom:12px}
.group-title{font-size:24px;font-weight:900}
.group-sub{font-size:16px;font-weight:700;color:var(--muted);margin-top:4px}
.badges{display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.badge{display:inline-block;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:900;background:#e7f0ff;color:#1949b6}
.badge.help{background:var(--yellow);color:var(--yellow-ink)}
.badge.ok{background:var(--green);color:var(--green-ink)}
.problem{
  padding:18px;
  border-radius:18px;
  background:#eff7ff;
  border:2px solid #d9eaff;
  font-size:17px;
  line-height:1.6;
  font-weight:500;
}
.problem b { color: #1e293b; }
.row{display:grid;grid-template-columns:1fr auto;gap:10px}
input,select{
  width:100%;
  padding:14px 16px;
  border:1px solid #c9d7e8;
  border-radius:14px;
  background:white;
  font-size:16px;
  font-family: inherit;
}
input:focus { outline: 2px solid var(--blue); border-color: transparent;}
button{
  border:none;
  border-radius:14px;
  padding:12px 16px;
  font-weight:900;
  cursor:pointer;
  transition: background 0.2s, transform 0.1s;
}
button:active { transform: scale(0.98); }
button.primary{background:var(--blue);color:white}
button.primary:hover{background:var(--blue-dark)}
button.secondary{background:#e7edf6;color:#1f3048}
button.secondary:hover{background:#d1dceb}
.msg{margin-top:12px;font-weight:800;color:#0ea5e9; background: #eef7ff; padding: 10px; border-radius: 8px;}
.table-card{overflow:hidden}
.table-title{padding:18px 22px;border-bottom:1px solid var(--line);font-size:24px;font-weight:900}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;min-width:1000px}
th,td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}
th{background:#f8fbff;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#60748b}
.panel{padding:22px}
.panel h2{margin:0 0 14px;font-size:24px}

/* Strategy Map & Market Nodes */
.market-map-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; margin-top: 10px;}
.map-node { background: #f8fbff; padding: 16px; border-radius: 12px; border: 1px solid var(--line); font-size: 18px; font-weight: 700; display:flex; justify-content: space-between; align-items: center;}
.map-node span { font-size: 14px; color: var(--muted); font-weight: normal; }
.map-node.markup { background: #fff4f4; border-color: #ffd1d1; color: #991b1b; }
.map-node.markdown { background: #f0fdf4; border-color: #bbf7d0; color: #166534; }

/* SHOCK EVENT STYLES */
.shock-bg { background: linear-gradient(135deg,#7f1d1d,#b91c1c 62%,#ef4444) !important; color: white !important;}
.shock-border { outline: 4px solid #ef4444; background: #fef2f2; }
.shock-alert { color: #b91c1c; font-size: 20px; font-weight: 900; margin-bottom: 10px; text-transform: uppercase; animation: pulse 1s infinite alternate; }

@keyframes pulse {
    0% { transform: scale(1); }
    100% { transform: scale(1.02); }
}

/* === PROJECTOR MODE GLOBAL OVERRIDES === */
.exit-projector-btn { display: none; }

body.projector-active .hide-on-projector { display: none !important; }
body.projector-active .hero { grid-template-columns: 1fr; }
body.projector-active .wrap { max-width: 95%; margin-top: 20px;}
body.projector-active .hero-left h1 { font-size: 48px; text-align: center; }
body.projector-active .group-title { font-size: 32px; }
body.projector-active .problem { font-size: 24px; line-height: 1.8;}
body.projector-active .grid { grid-template-columns: 1fr 1fr; gap: 30px;}
body.projector-active input { font-size: 22px; padding: 18px; }
body.projector-active button.primary { font-size: 20px; padding: 18px 24px; }

/* The Floating Exit Button */
body.projector-active .exit-projector-btn {
    display: block;
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 1000;
    background: #ef4444;
    color: white;
    font-size: 18px;
    padding: 15px 25px;
    box-shadow: 0 10px 25px rgba(239, 68, 68, 0.4);
}
body.projector-active .exit-projector-btn:hover { background: #dc2626; }

@media (max-width:1200px){
  .hero{grid-template-columns:1fr}
  .grid, .market-map-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .hero,.grid,.market-map-grid{grid-template-columns:1fr}
  .group-head{flex-direction:column}
}/* Add these to the bottom of your styles.css */
u { text-decoration-thickness: 3px; text-underline-offset: 4px; background: rgba(251,191,36,.4); font-weight: bold; }
.mini-btn { padding: 2px 8px !important; font-size: 12px !important; border-radius: 6px !important; }
.active-toggle { background: var(--yellow) !important; color: var(--yellow-ink) !important; border: 1px solid var(--yellow-ink); }
