/* whoop-web — minimal, mobile-first, no build step */
:root {
    --bg: #0f0f0f;
    --surface: #1a1a1a;
    --surface2: #222;
    --text: #e8e8e8;
    --text2: #888;
    --green: #4caf50;
    --yellow: #ffeb3b;
    --red: #f44336;
    --blue: #2196f3;
    --orange: #ff9800;
    --radius: 12px;
    --gap: 16px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
    background: var(--bg);
    color: var(--text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 15px;
    line-height: 1.5;
}

/* ── Login ─────────────────────────────────────────────────────────────────── */
.login-wrap {
    max-width: 360px;
    margin: 80px auto;
    padding: var(--gap);
    background: var(--surface);
    border-radius: var(--radius);
}
.login-wrap h1 { margin-bottom: 24px; font-size: 24px; text-align: center; }
.login-wrap label { display: block; margin-bottom: 16px; }
.login-wrap input {
    display: block; width: 100%; margin-top: 4px;
    padding: 10px; border-radius: 8px; border: 1px solid #333;
    background: var(--bg); color: var(--text); font-size: 15px;
}
.login-wrap button {
    width: 100%; padding: 12px; border-radius: 8px;
    background: var(--blue); color: #fff; border: none;
    font-size: 16px; cursor: pointer;
}
.login-wrap button:hover { opacity: 0.9; }
.error { color: var(--red); margin-bottom: 12px; }

/* ── Top bar ──────────────────────────────────────────────────────────────── */
.top-bar {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px var(--gap); background: var(--surface); border-bottom: 1px solid #2a2a2a;
}
.logo { font-weight: 700; font-size: 18px; }
.top-actions { display: flex; gap: 8px; align-items: center; }

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn-sync {
    padding: 8px 16px; border-radius: 8px;
    background: var(--blue); color: #fff; border: none;
    font-size: 14px; cursor: pointer;
}
.btn-sync:hover { opacity: 0.9; }
.btn-sync:disabled { opacity: 0.5; cursor: default; }
.btn-logout {
    padding: 8px 16px; border-radius: 8px;
    background: var(--surface2); color: var(--text2);
    text-decoration: none; font-size: 14px;
}
.inline-form { display: inline; }

/* ── Main layout ──────────────────────────────────────────────────────────── */
main { max-width: 1100px; margin: 0 auto; padding: var(--gap); }
section { margin-bottom: 32px; }
h2 { font-size: 18px; margin-bottom: 12px; color: var(--text2); }
h3 { font-size: 14px; margin-bottom: 8px; color: var(--text2); }

/* ── Cards ────────────────────────────────────────────────────────────────── */
.cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--gap);
}
.card {
    background: var(--surface); border-radius: var(--radius);
    padding: 20px; display: flex; flex-direction: column; gap: 6px;
}
.card-label { font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--text2); }
.card-value { font-size: 48px; font-weight: 700; line-height: 1; }
.card-value.green { color: var(--green); }
.card-value.yellow { color: var(--yellow); }
.card-value.red { color: var(--red); }
.card-value.grey { color: var(--text2); }
.card-meta { font-size: 13px; color: var(--text2); }
.card-date { font-size: 12px; color: #555; margin-top: 4px; }

/* ── Trend tabs ───────────────────────────────────────────────────────────── */
.trend-tabs { display: flex; gap: 8px; margin-bottom: 16px; }
.tab {
    padding: 6px 14px; border-radius: 6px;
    background: var(--surface2); color: var(--text2);
    border: none; cursor: pointer; font-size: 14px;
}
.tab.active { background: var(--blue); color: #fff; }

/* ── Charts ───────────────────────────────────────────────────────────────── */
.charts { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--gap); }
.chart-wrap { background: var(--surface); border-radius: var(--radius); padding: 16px; }

/* ── Workouts table ───────────────────────────────────────────────────────── */
table { width: 100%; border-collapse: collapse; font-size: 14px; }
th { text-align: left; padding: 8px; border-bottom: 1px solid #2a2a2a; color: var(--text2); font-weight: 500; }
td { padding: 8px; border-bottom: 1px solid #1e1e1e; }
tr:last-child td { border-bottom: none; }

/* ── Status grid ──────────────────────────────────────────────────────────── */
.status-grid {
    display: grid; grid-template-columns: auto 1fr; gap: 8px 16px;
    background: var(--surface); border-radius: var(--radius); padding: 16px;
    font-size: 14px;
}
.status-grid > div:nth-child(odd) { color: var(--text2); }

/* ── Misc ─────────────────────────────────────────────────────────────────── */
.empty { color: var(--text2); font-size: 14px; padding: 16px; }
