/* Two Dreams Recovery Network — business plan site
   Shared design system. Do not fork per-page; use these classes. */

:root{
  --bg:#ffffff;
  --surface:#f5f8f8;
  --surface-2:#eef3f3;
  --ink:#13212b;
  --muted:#5a6b76;
  --line:#e1e8ec;
  --primary:#0f5e63;
  --primary-d:#0a4448;
  --primary-l:#e6f1f1;
  --accent:#cf7a33;
  --accent-l:#fbeede;
  --good:#2f7d52;
  --good-l:#e6f3ec;
  --warn:#b4631a;
  --warn-l:#fbeede;
  --bad:#b3261e;
  --bad-l:#fae9e8;
  --nav-bg:#0d2a31;
  --nav-ink:#cfe0e1;
  --nav-ink-dim:#7fa0a3;
  --radius:10px;
  --shadow:0 1px 3px rgba(16,40,48,.08),0 6px 20px rgba(16,40,48,.06);
  --maxw:960px;
  --sidebar-w:264px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  line-height:1.62;font-size:16px;-webkit-font-smoothing:antialiased;
}

/* ---------- Layout ---------- */
.layout{display:flex;min-height:100vh}
.sidebar{
  width:var(--sidebar-w);flex:0 0 var(--sidebar-w);background:var(--nav-bg);
  color:var(--nav-ink);position:sticky;top:0;height:100vh;overflow-y:auto;padding:22px 0;
}
.content{flex:1;min-width:0}
.container{max-width:var(--maxw);margin:0 auto;padding:48px 40px 80px}

/* ---------- Brand + nav ---------- */
.brand{padding:0 22px 18px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:14px}
.brand a{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none;font-weight:700;font-size:18px}
.brand small{display:block;color:var(--nav-ink-dim);font-weight:500;font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.brand-mark{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:8px;background:var(--accent);color:#fff;font-weight:800;font-size:14px;flex:none}
.sidebar nav{display:flex;flex-direction:column}
.nav-group{padding:16px 22px 6px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--nav-ink-dim);font-weight:700}
.sidebar nav a{
  color:var(--nav-ink);text-decoration:none;padding:8px 22px;font-size:14px;border-left:3px solid transparent;
}
.sidebar nav a:hover{background:rgba(255,255,255,.05);color:#fff}
.sidebar nav a.active{background:rgba(207,122,51,.14);border-left-color:var(--accent);color:#fff;font-weight:600}
.nav-toggle{display:none;position:fixed;top:14px;left:14px;z-index:50;background:var(--nav-bg);color:#fff;border:none;border-radius:8px;width:42px;height:42px;font-size:20px;cursor:pointer;box-shadow:var(--shadow)}

/* ---------- Typography ---------- */
h1,h2,h3,h4{line-height:1.25;color:var(--ink);font-weight:700}
h1{font-size:2.1rem;margin:0 0 .3em;letter-spacing:-.01em}
h2{font-size:1.5rem;margin:2.2em 0 .6em;padding-top:.3em}
h3{font-size:1.18rem;margin:1.8em 0 .5em}
h4{font-size:1rem;margin:1.4em 0 .4em;color:var(--primary-d)}
p{margin:0 0 1em}
a{color:var(--primary)}
ul,ol{margin:0 0 1em;padding-left:1.3em}
li{margin:.3em 0}
strong{color:var(--ink)}
small{font-size:.85em}
hr{border:none;border-top:1px solid var(--line);margin:2.4em 0}
.eyebrow{text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;font-weight:700;color:var(--accent)}
.lede{font-size:1.18rem;color:var(--muted);max-width:62ch;margin-bottom:1.4em}
.muted{color:var(--muted)}

/* ---------- Hero ---------- */
.hero{padding:14px 0 22px;border-bottom:1px solid var(--line);margin-bottom:8px}

/* ---------- Cards ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow)}
.card h3{margin-top:0}
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;margin:1.2em 0}
.card a.card-link{text-decoration:none;color:inherit;display:block}
a.card-link:hover{border-color:var(--primary);transform:translateY(-2px);transition:.15s}
.card .tag{margin-bottom:8px}

/* ---------- Stat grid ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin:1.4em 0}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}
.stat .num{font-size:1.9rem;font-weight:800;color:var(--primary-d);line-height:1.1;letter-spacing:-.02em}
.stat .label{font-size:.85rem;color:var(--muted);margin-top:4px}

/* ---------- Callouts ---------- */
.callout{border:1px solid var(--line);border-left:4px solid var(--muted);background:var(--surface);border-radius:8px;padding:14px 18px;margin:1.2em 0}
.callout p:last-child{margin-bottom:0}
.callout .callout-title{font-weight:700;display:block;margin-bottom:4px}
.callout.info{border-left-color:var(--primary);background:var(--primary-l)}
.callout.key{border-left-color:var(--accent);background:var(--accent-l)}
.callout.success{border-left-color:var(--good);background:var(--good-l)}
.callout.warn{border-left-color:var(--warn);background:var(--warn-l)}
.callout.danger{border-left-color:var(--bad);background:var(--bad-l)}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;margin:1.2em 0;border:1px solid var(--line);border-radius:var(--radius)}
table{border-collapse:collapse;width:100%;font-size:.93rem}
th,td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--line);vertical-align:top}
thead th{background:var(--surface-2);font-weight:700;color:var(--ink);white-space:nowrap;cursor:default}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--surface)}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
table.sortable thead th{cursor:pointer}
table.sortable thead th:hover{color:var(--primary)}
.total-row td{font-weight:700;background:var(--surface);border-top:2px solid var(--line)}

/* ---------- Tags / badges ---------- */
.tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 9px;border-radius:999px;background:var(--surface-2);color:var(--muted)}
.tag.primary{background:var(--primary-l);color:var(--primary-d)}
.tag.accent{background:var(--accent-l);color:var(--warn)}
.tag.good{background:var(--good-l);color:var(--good)}
.tag.warn{background:var(--warn-l);color:var(--warn)}
.tag.verify{background:#fff5e6;color:#9a6212;border:1px dashed #d9a441}

/* ---------- Timeline / phases ---------- */
.timeline{position:relative;margin:1.4em 0;padding-left:28px}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--line)}
.timeline-item{position:relative;margin-bottom:24px}
.timeline-item::before{content:"";position:absolute;left:-24px;top:5px;width:12px;height:12px;border-radius:50%;background:var(--primary);border:2px solid #fff;box-shadow:0 0 0 2px var(--primary-l)}
.timeline-item h4{margin:0 0 .2em}
.phase-label{font-size:.78rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}

/* ---------- Diagram (flow) ---------- */
.flow{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:1.2em 0}
.flow .node{background:var(--primary-l);border:1px solid var(--primary);color:var(--primary-d);border-radius:8px;padding:10px 14px;font-size:.9rem;font-weight:600}
.flow .arrow{color:var(--accent);font-weight:800;font-size:1.2rem}

/* ---------- Layout helpers ---------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:1.2em 0}
.section{margin:2.4em 0}
.btn{display:inline-block;background:var(--primary);color:#fff;text-decoration:none;padding:11px 20px;border-radius:8px;font-weight:600;font-size:.95rem}
.btn:hover{background:var(--primary-d)}
.btn.ghost{background:transparent;color:var(--primary);border:1px solid var(--primary)}
.pill-row{display:flex;flex-wrap:wrap;gap:8px;margin:1em 0}

/* ---------- Chart wrapper ---------- */
.chart-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin:1.2em 0;box-shadow:var(--shadow)}
.chart-box h4{margin-top:0}
.chart-box canvas{max-height:340px}

/* ---------- Footer ---------- */
.page-foot{margin-top:64px;padding-top:20px;border-top:1px solid var(--line);font-size:.8rem;color:var(--muted)}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .nav-toggle{display:block}
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:transform .22s ease;z-index:40;box-shadow:var(--shadow)}
  .sidebar.open{transform:translateX(0)}
  .container{padding:64px 22px 64px}
  .two-col{grid-template-columns:1fr}
}

/* ---------- Print ---------- */
@media print{
  .sidebar,.nav-toggle{display:none}
  .container{max-width:100%;padding:0}
  .card,.stat,.chart-box{box-shadow:none}
  a{color:var(--ink);text-decoration:none}
}
