/* ============================================================
   Routines (Phase R) — token-driven Brand OS, light-mode-clean.
   ============================================================ */
.rt-hero { padding:28px 30px; border-radius:var(--radius-lg); border:1px solid var(--line);
  background:linear-gradient(180deg, var(--surface), var(--surface-grad-2)); margin-bottom:18px; }
.rt-hero .kicker { font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); }
.rt-hero h1 { margin:8px 0 0; font-family:var(--serif); font-size:28px; letter-spacing:-.02em; }
.rt-hero .sub { margin:9px 0 0; color:var(--muted); font-size:14px; max-width:62ch; }
.rt-sub { color:var(--muted); font-size:12.5px; margin:3px 0 0; max-width:64ch; }

.rt-tabs { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.rt-tab { padding:9px 16px; border-radius:999px; border:1px solid var(--line-2); background:var(--surface);
  color:var(--muted); font-size:13px; font-weight:600; cursor:pointer; transition:all .15s; }
.rt-tab:hover { border-color:var(--gold-line); }
.rt-tab.on { background:var(--gold-soft); border-color:var(--gold-line); color:var(--gold); }

/* shared bits */
.rt-in { width:100%; padding:9px 11px; border-radius:9px; border:1px solid var(--line-2);
  background:var(--surface); color:var(--ivory); font-size:13.5px; font-family:inherit; }
.rt-in:focus { outline:none; border-color:var(--gold-2); box-shadow:0 0 0 2px var(--gold-soft); }
.rt-ta { resize:vertical; min-height:44px; line-height:1.5; }
.rt-in-sm { width:120px; }
.rt-btn { padding:9px 15px; border-radius:9px; border:1px solid var(--line-2); background:var(--surface); color:var(--ivory);
  font-size:13px; font-weight:600; cursor:pointer; transition:transform .15s, border-color .15s; }
.rt-btn:hover { transform:translateY(-1px); border-color:var(--gold-line); }
.rt-btn.ghost { background:transparent; } .rt-btn.sm { padding:7px 12px; font-size:12.5px; }
.rt-btn.primary { background:var(--gold-soft); border-color:var(--gold-line); color:var(--gold); }
.rt-btn.danger { color:var(--red); border-color:var(--red); background:transparent; }
.rt-x { flex:0 0 auto; width:28px; height:28px; border-radius:7px; border:1px solid transparent; background:transparent; color:var(--muted); cursor:pointer; font-size:15px; }
.rt-x:hover { color:var(--red); border-color:var(--red); }
.rt-empty { text-align:center; padding:34px 20px; color:var(--muted); border:1px dashed var(--line-2); border-radius:var(--radius-lg); }
.rt-empty-ic { font-size:26px; margin-bottom:8px; } .rt-empty-sm { color:var(--muted); font-size:12px; font-style:italic; }
.rt-hint { color:var(--muted); font-size:12px; margin-top:8px; }

/* builder */
.rt-routines { display:grid; grid-template-columns:repeat(auto-fill, minmax(300px, 1fr)); gap:14px; }
.rt-card { padding:16px; border-radius:var(--radius-lg); border:1px solid var(--line); background:linear-gradient(180deg, var(--surface), var(--surface-grad-2)); }
.rt-card-head { display:flex; align-items:center; gap:8px; margin-bottom:12px; }
.rt-routine-name { font-weight:700; font-size:15px; }
.rt-steps { display:flex; flex-direction:column; gap:7px; margin-bottom:10px; }
.rt-step { display:flex; align-items:center; gap:7px; }
.rt-step-time { flex:0 0 88px; width:88px; }
.rt-step-act { flex:1 1 auto; }

/* monk mode */
.rt-monk { display:flex; flex-direction:column; gap:18px; }
.rt-monk-top { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; flex-wrap:wrap;
  padding:18px 20px; border-radius:var(--radius-lg); border:1px solid var(--line); background:linear-gradient(180deg, var(--surface), var(--surface-grad-2)); }
.rt-monk-top h3 { margin:0; font-size:18px; }
.rt-monk-day { font-family:var(--mono); font-size:13px; color:var(--gold); }
.rt-monk-streak { font-family:var(--mono); font-size:13px; color:var(--green); margin-left:10px; }
.rt-monk-off { font-size:13px; color:var(--muted); }
.rt-monk-rules h4, .rt-monk-projects h4 { margin:0 0 10px; font-size:14px; }
.rt-rules { display:flex; flex-wrap:wrap; gap:10px; }
.rt-rule { display:flex; align-items:center; gap:8px; padding:10px 14px; border-radius:10px; border:1px solid var(--line-2); background:var(--surface); font-size:13.5px; cursor:pointer; }
.rt-rule input { width:16px; height:16px; accent-color:var(--gold); }
.rt-rule input:disabled { opacity:.5; cursor:not-allowed; }
.rt-proj-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(220px, 1fr)); gap:8px; }
.rt-field label { display:block; font-size:12.5px; color:var(--muted); margin-bottom:5px; }
.rt-monk-grid { display:flex; gap:16px; flex-wrap:wrap; }

/* testing lab */
.rt-lab-head { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-bottom:14px; flex-wrap:wrap; }
.rt-tests { display:flex; flex-direction:column; gap:12px; }
.rt-test { padding:14px 16px; border-radius:var(--radius-lg); border:1px solid var(--line); background:linear-gradient(180deg, var(--surface), var(--surface-grad-2)); }
.rt-test-head { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.rt-test-name { font-weight:600; flex:1; }
.rt-test-date { font-family:var(--mono); font-size:11.5px; color:var(--muted); }
.rt-test-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:10px; }
.rt-test-grid label { display:block; font-size:11.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); }
.rt-test-grid textarea { margin-top:5px; }

@media (max-width:760px) {
  .rt-hero { padding:22px 18px; }
  .rt-test-grid { grid-template-columns:1fr; }
  .rt-routines { grid-template-columns:1fr; }
}
