/* commence — Lume dashboard
   Imported from Claude Design handoff bundle.
   Builds on tokens defined in colors_and_type.css. */

@import url('colors_and_type.css');

* { box-sizing: border-box; }
html, body { margin: 0; background: var(--paper-10); color: var(--ink-90); min-height: 100vh; }

/* ============================================================
   LAYOUT — left nav + main canvas
   ============================================================ */
.app {
    display: grid;
    grid-template-columns: 220px 1fr;
    min-height: 100vh;
}

/* ---------- Left nav ---------- */
.nav {
    background: var(--ink-90);
    color: var(--paper-00);
    padding: 22px 16px 24px;
    display: flex;
    flex-direction: column;
    gap: 28px;
    position: sticky;
    top: 0;
    height: 100vh;
    border-right: 1px solid var(--ink-80);
}
.nav-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 6px 4px;
}
.nav-brand .mark {
    width: 22px; height: 22px;
    filter: invert(1);
}
.nav-brand .name {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 17px;
    letter-spacing: -0.02em;
    color: var(--paper-00);
}
.nav-brand .name em {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 600;
    color: var(--dark-accent);
}
.nav-brand .name-wrap { display: flex; flex-direction: column; }
.nav-brand .version {
    font-family: var(--font-mono);
    font-size: 9px;
    letter-spacing: 0.08em;
    color: rgba(255,255,255,0.35);
    margin-top: 2px;
    text-transform: uppercase;
}
.nav-section {
    display: flex; flex-direction: column; gap: 2px;
}
.nav-section-label {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
    padding: 0 10px 8px;
}
.nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 9px 10px;
    border-radius: 0;
    color: rgba(255,255,255,0.72);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: background 150ms cubic-bezier(0.2,0.8,0.25,1), color 150ms;
    text-decoration: none;
}
.nav-item:hover { background: rgba(255,255,255,0.06); color: var(--paper-00); text-decoration: none; }
.nav-item.active {
    background: rgba(217,160,74,0.10);
    color: var(--paper-00);
    box-shadow: inset 2px 0 0 var(--dark-accent);
    border-radius: 0;
}
.nav-item svg { flex-shrink: 0; }
.nav-item .badge-num {
    margin-left: auto; font-family: var(--font-mono);
    font-size: 11px; color: var(--peacock-50);
}

.nav-foot {
    margin-top: auto;
    padding: 12px 10px;
    border-top: 1px solid rgba(255,255,255,0.08);
    display: flex; align-items: center; justify-content: space-between;
}
.nav-foot .version-foot {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.1em;
    color: rgba(255,255,255,0.4);
    text-transform: uppercase;
}

/* ---------- Main ---------- */
.main { padding: 32px 40px 48px; max-width: 1320px; }

.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 28px;
}
.crumbs { font-size: 12px; color: var(--fg-subtle); display: flex; align-items: center; gap: 8px; }
.crumbs .sep { color: var(--paper-40); }
.crumbs strong { color: var(--ink-90); font-weight: 600; }
.topbar-right { display: flex; align-items: center; gap: 16px; font-family: var(--font-mono); font-size: 12px; color: var(--fg-subtle); }
.topbar-right .dot { width: 6px; height: 6px; border-radius: 999px; background: var(--signal-positive); }
.topbar-right .stamp { display: flex; align-items: center; gap: 6px; }

/* ---------- Hero ---------- */
.hero {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: end;
    gap: 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 24px;
}
.hero-lead {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--peacock-80);
    margin-bottom: 14px;
    display: flex; align-items: center; gap: 8px;
}
.hero-lead img { width: 11px; height: 11px; }
.hero-title {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 56px;
    line-height: 1.02;
    letter-spacing: -0.025em;
    color: var(--ink-90);
    margin: 0;
    text-wrap: balance;
}
.hero-title .num {
    font-feature-settings: "tnum" 1, "lnum" 1;
}
.hero-title em {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 600;
    background: var(--grad-spectrum);
    -webkit-background-clip: text;
            background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.hero-sub {
    font-size: 16px;
    color: var(--fg-muted);
    margin: 12px 0 0;
    max-width: 560px;
    line-height: 1.5;
}
.hero-meta {
    display: grid;
    grid-template-columns: repeat(3, auto);
    gap: 32px;
    text-align: right;
    padding-bottom: 6px;
}
.hero-meta-item {
    display: flex; flex-direction: column; gap: 4px;
}
.hero-meta-label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--fg-subtle);
}
.hero-meta-value {
    font-family: var(--font-mono);
    font-size: 15px;
    color: var(--ink-90);
    font-variant-numeric: tabular-nums;
}
.hero-meta-value.tabular {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 600;
    letter-spacing: -0.02em;
}
.hero-meta-value.small {
    font-size: 11px; color: var(--fg-subtle);
}

/* ---------- Cards ---------- */
.card {
    background: var(--paper-00);
    border: 1px solid var(--border);
    border-radius: 0;
    box-shadow: var(--shadow-1);
}
.card-pad { padding: 24px; }
.card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 16px;
    gap: 16px;
}
.card-eyebrow {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--fg-muted);
    margin-bottom: 4px;
}
.card-title {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 20px;
    line-height: 1.2;
    letter-spacing: -0.015em;
    color: var(--ink-90);
    margin: 0;
}
.card-title-row { display: flex; align-items: center; gap: 12px; }
.card-sub {
    font-size: 13px;
    color: var(--fg-muted);
    margin-top: 4px;
}
.legend {
    display: flex; gap: 18px; align-items: center;
    font-family: var(--font-mono); font-size: 11px; color: var(--fg-muted);
}
.legend .swatch {
    display: inline-flex; align-items: center; gap: 6px;
}
.legend .swatch .pill {
    width: 18px; height: 2px; border-radius: 1px;
}
.legend .swatch.dashed .pill {
    background: repeating-linear-gradient(90deg, var(--paper-40) 0 4px, transparent 4px 7px);
    background-size: 7px 2px;
    height: 2px;
}
.legend .swatch.actual .pill {
    background: var(--gold);
}

/* ---------- Bars ---------- */
.bars { display: flex; flex-direction: column; gap: 20px; }
.bar-row { display: flex; flex-direction: column; gap: 8px; }
.bar-head { display: flex; justify-content: space-between; align-items: baseline; }
.bar-label {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ink-80);
    display: flex; align-items: center; gap: 8px;
}
.bar-label .dot { width: 6px; height: 6px; border-radius: 999px; }
.bar-value {
    font-family: var(--font-mono);
    font-size: 14px;
    color: var(--ink-90);
    font-variant-numeric: tabular-nums;
}
.bar-value .pct {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 600;
    letter-spacing: -0.02em;
}
.bar-value .of {
    color: var(--fg-subtle);
    margin-left: 6px;
}
.bar-track {
    height: 14px;
    background: var(--paper-20);
    border-radius: 0;
    position: relative;
    overflow: hidden;
}
.bar-fill {
    height: 100%;
    border-radius: 0;
    transition: width 400ms cubic-bezier(0.2,0.8,0.25,1);
}
.bar-fill.posts { background: var(--gold); }
.bar-fill.time  { background: var(--ink-80); }
.bar-marker {
    position: absolute;
    top: -4px; bottom: -4px;
    width: 1px;
    background: var(--ink-90);
}
.bar-marker::before {
    content: '';
    position: absolute;
    top: 0; left: -4px;
    width: 9px; height: 4px;
    background: var(--ink-90);
}
.bar-marker::after {
    content: '';
    position: absolute;
    bottom: 0; left: -4px;
    width: 9px; height: 4px;
    background: var(--ink-90);
}

/* ---------- Status callout ---------- */
.status {
    margin-top: 24px;
    padding: 18px 20px;
    border-radius: 0;
    background: var(--paper-10);
    border: 1px solid var(--border);
    border-left: 3px solid var(--peacock-80);
    display: flex;
    align-items: flex-start;
    gap: 16px;
}
.status .gap-num {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 32px;
    letter-spacing: -0.02em;
    line-height: 1;
    color: var(--peacock-80);
    font-feature-settings: "tnum" 1, "lnum" 1;
    flex-shrink: 0;
    padding-top: 2px;
    min-width: 64px;
}
.status .gap-num.behind { color: var(--signal-warning); }
.status .gap-num.ahead { color: var(--signal-positive); }
.status .msg {
    font-size: 15px;
    color: var(--ink-80);
    line-height: 1.45;
    text-wrap: pretty;
}
.status .msg strong { color: var(--ink-90); font-weight: 600; }
.status .msg .pace {
    display: block;
    margin-top: 4px;
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--fg-muted);
}

/* ---------- Milestones ---------- */
.milestones {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
.milestone {
    background: var(--paper-00);
    border: 1px solid var(--border);
    border-radius: 0;
    padding: 20px;
    box-shadow: var(--shadow-1);
    position: relative;
    overflow: hidden;
    display: flex; flex-direction: column; gap: 8px;
    transition: transform 240ms cubic-bezier(0.2,0.8,0.25,1), box-shadow 240ms;
}
.milestone .top {
    display: flex; justify-content: space-between; align-items: flex-start;
}
.milestone .num {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 56px;
    letter-spacing: -0.025em;
    line-height: 0.95;
    color: var(--ink-90);
    font-feature-settings: "tnum" 1, "lnum" 1;
}
.milestone .badge {
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 4px 8px;
    border-radius: 999px;
    background: var(--paper-20);
    color: var(--fg-muted);
    border: 1px solid var(--border);
}
.milestone .label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--fg-subtle);
    margin-top: 4px;
}
.milestone .prize {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 18px;
    line-height: 1.25;
    letter-spacing: -0.012em;
    color: var(--ink-90);
    text-wrap: balance;
}
.milestone .prize-note {
    font-size: 12px;
    color: var(--fg-muted);
    line-height: 1.4;
}

/* unlocked */
.milestone.unlocked {
    background: var(--gold-tint);
    border-color: var(--gold);
}
.milestone.unlocked .num { color: var(--peacock-80); }
.milestone.unlocked .badge {
    background: var(--peacock-80); color: var(--paper-00); border-color: var(--peacock-80);
}

/* next */
.milestone.next {
    border-color: var(--ink-90);
    box-shadow: 0 0 0 1px var(--ink-90), var(--shadow-2);
}
.milestone.next .badge {
    background: var(--ink-90); color: var(--paper-00); border-color: var(--ink-90);
}
.milestone.next .progress-strip {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: var(--paper-20);
}
.milestone.next .progress-strip > div {
    height: 100%;
    background: var(--gold);
    transition: width 400ms cubic-bezier(0.2,0.8,0.25,1);
}

/* locked */
.milestone.locked .num { color: var(--paper-40); }
.milestone.locked .prize { color: var(--ink-70); }

/* the ring at 108 — special */
.milestone.ring {
    background: var(--ink-90);
    color: var(--paper-00);
    border-color: var(--ink-90);
    overflow: hidden;
}
.milestone.ring::before {
    content: '';
    position: absolute;
    inset: 0;
    background: transparent;
    pointer-events: none;
}
.milestone.ring > * { position: relative; z-index: 1; }
.milestone.ring .num {
    background: var(--grad-spectrum);
    -webkit-background-clip: text;
            background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.milestone.ring .label { color: rgba(255,255,255,0.55); }
.milestone.ring .prize { color: var(--paper-00); }
.milestone.ring .prize-note { color: rgba(255,255,255,0.65); }
.milestone.ring .badge {
    background: rgba(248,244,237,0.08); color: var(--dark-accent); border-color: rgba(242,196,74,0.4);
}
.milestone.ring .glint-mark {
    position: absolute;
    top: 16px; right: 16px;
    color: var(--dark-accent);
    font-size: 14px;
    z-index: 1;
}

/* ---------- Layout grid ---------- */
.grid-chart-side {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 20px;
    margin-bottom: 20px;
}
.grid-2-1 {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 20px;
    margin-top: 20px;
}
.section-head {
    display: flex; justify-content: space-between; align-items: baseline;
    margin: 8px 0 14px;
}
.section-head h2 {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 22px;
    letter-spacing: -0.015em;
    margin: 0;
    color: var(--ink-90);
}
.section-head .aside {
    font-size: 12px;
    color: var(--fg-muted);
    font-family: var(--font-mono);
}
.section-head .aside strong { color: var(--ink-90); font-weight: 500; }

/* ---------- Chart ---------- */
.chart-wrap {
    position: relative;
    width: 100%;
}
.chart-wrap svg { width: 100%; height: auto; display: block; }

/* ---------- Pace tile ---------- */
.pace-tile {
    background-color: var(--dark-bg);
    background-image:
        radial-gradient(ellipse 80% 60% at 15% 25%, rgba(242,196,74, 0.22), transparent 60%),
        radial-gradient(ellipse 70% 55% at 85% 35%, rgba(184,115,26, 0.28), transparent 65%),
        radial-gradient(ellipse 90% 70% at 50% 95%, rgba(140,58,20,  0.32), transparent 70%),
        radial-gradient(ellipse 60% 50% at 90% 90%, rgba(92,26,20,   0.40), transparent 70%);
    color: var(--dark-fg);
    border-radius: 0;
    padding: 28px;
    position: relative;
    overflow: hidden;
    display: flex; flex-direction: column; gap: 14px;
}
.pace-tile::before {
    content: '';
    position: absolute;
    inset: 0;
    background: transparent;
    pointer-events: none;
}
.pace-tile > * { position: relative; z-index: 1; }
.pace-eyebrow {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--peacock-50);
    display: flex; align-items: center; gap: 8px;
}
.pace-eyebrow img {
    width: 11px; height: 11px;
}
.pace-num {
    font-family: var(--font-mono);
    font-weight: 500;
    font-size: 88px;
    line-height: 1;
    letter-spacing: -0.01em;
    margin: 0;
    background: var(--grad-spectrum);
    -webkit-background-clip: text;
            background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    font-feature-settings: "tnum" 1, "lnum" 1;
}
.pace-num .unit {
    color: var(--dark-muted);
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0;
    margin-left: 8px;
}
.pace-line {
    font-size: 14px;
    color: rgba(255,255,255,0.78);
    line-height: 1.5;
    text-wrap: pretty;
}
.pace-line strong { color: var(--paper-00); font-weight: 600; }
.pace-divide {
    height: 1px;
    background: rgba(255,255,255,0.08);
    margin: 4px 0;
}
.pace-row {
    display: flex; justify-content: space-between; align-items: center;
    font-family: var(--font-mono);
    font-size: 12px;
}
.pace-row .k { color: rgba(255,255,255,0.55); letter-spacing: 0.04em; }
.pace-row .v { color: var(--paper-00); font-variant-numeric: tabular-nums; }

/* ---------- Empty / placeholder slot ---------- */
.empty-slot {
    border: 1px dashed var(--paper-40);
    border-radius: 0; padding: 28px;
    text-align: center; color: var(--fg-subtle);
    font-size: 13px;
}
.empty-slot strong { color: var(--ink-90); font-weight: 600; display: block; margin-bottom: 4px; }

/* ---------- Helpers ---------- */
.glint-bullet { width: 11px; height: 11px; vertical-align: -1px; }
.num-mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

@media (max-width: 1100px) {
    .app { grid-template-columns: 1fr; }
    .nav { position: relative; height: auto; flex-direction: row; align-items: center; gap: 16px; padding: 14px 20px; overflow-x: auto; }
    .nav-section-label, .nav-foot { display: none; }
    .nav-section { flex-direction: row; gap: 4px; }
    .grid-chart-side, .grid-2-1 { grid-template-columns: 1fr; }
    .milestones { grid-template-columns: repeat(2, 1fr); }
    .hero { grid-template-columns: 1fr; }
    .hero-meta { text-align: left; grid-template-columns: repeat(3, auto); justify-content: start; }
}

/* ============================================================
   Other-page glue: keep weeks/stats/checkin/login/public
   functional under the new design tokens. Light styling only.
   ============================================================ */

/* common page header for sub-pages */
.page-head {
    display: flex; justify-content: space-between; align-items: end;
    padding-bottom: 18px; border-bottom: 1px solid var(--border);
    margin-bottom: 24px;
}
.page-head h1 {
    font-family: var(--font-display); font-weight: 600;
    font-size: 36px; letter-spacing: -0.025em; margin: 0;
}
.page-head h1 small { font-family: var(--font-mono); font-size: 13px; color: var(--fg-subtle); margin-left: 8px; letter-spacing: 0; font-weight: 400; }
.back-link { font-family: var(--font-mono); font-size: 12px; color: var(--fg-muted); text-decoration: none; }
.back-link:hover { color: var(--peacock-80); }

/* tables */
.b-table { width: 100%; border-collapse: collapse; background: var(--paper-00); border: 1px solid var(--border); border-radius: 0; overflow: hidden; }
.b-table th, .b-table td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--border); }
.b-table tr:last-child td { border-bottom: 0; }
.b-table th { background: var(--paper-20); color: var(--fg-subtle); font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600; }
.b-table td.num, .b-table th.num { text-align: right; font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.b-table tr.current td { background: var(--peacock-10); }
.b-table .muted { color: var(--fg-subtle); }

.pill {
    display: inline-block; padding: 2px 10px;
    font-size: 10px; font-family: var(--font-mono);
    text-transform: uppercase; letter-spacing: 0.12em;
    border-radius: 999px;
    border: 1px solid var(--border); color: var(--fg-muted);
}
.pill.in_progress { color: var(--peacock-80); border-color: var(--peacock-30); background: var(--peacock-10); }
.pill.completed { color: var(--signal-positive); border-color: var(--signal-positive); }

.btn {
    display: inline-block; padding: 8px 14px 8px 18px;
    background: var(--gold); color: var(--paper);
    border-radius: 0; font-size: 13px; font-weight: 600;
    text-decoration: none; border: 0; cursor: pointer;
    position: relative;
}
.btn::before {
    content: ""; position: absolute;
    left: 0; top: 0; bottom: 0; width: 3px;
    background: var(--grad-spectrum-v);
    pointer-events: none;
}
.btn:hover { background: var(--gold-hover); text-decoration: none; }
.btn-sm { font-size: 12px; color: var(--peacock-80); font-family: var(--font-mono); text-decoration: none; }
.btn-sm:hover { color: var(--peacock-90); }

/* form */
.form { display: flex; flex-direction: column; gap: 14px; max-width: 480px; }
.form label { display: flex; flex-direction: column; gap: 6px; font-size: 12px; color: var(--fg-muted); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; }
.form input, .form textarea {
    background: var(--paper-00); color: var(--ink-90);
    border: 1px solid var(--border); border-radius: 0;
    padding: 10px 12px; font-family: var(--font-text); font-size: 14px;
}
.form input:focus, .form textarea:focus { outline: 0; border-color: var(--peacock-80); }
.form textarea { min-height: 120px; resize: vertical; }
.form button { align-self: flex-start; background: var(--peacock-80); color: var(--paper-00); border: 0; padding: 10px 18px; border-radius: 0; font-weight: 600; cursor: pointer; }
.form button:hover { background: var(--peacock-90); }
.form details { background: var(--paper-00); border: 1px solid var(--border); border-radius: 0; padding: 10px 12px; }

/* week detail tasks */
.plan-day { padding: 12px 0; border-top: 1px solid var(--border); }
.plan-day:first-child { border-top: 0; padding-top: 0; }
.plan-day h3 { font-family: var(--font-display); font-weight: 600; font-size: 16px; margin: 0 0 8px; color: var(--peacock-80); letter-spacing: -0.01em; }
.task-list { list-style: none; padding: 0; margin: 0; }
.task { padding: 4px 0; }
.task-form { display: flex; align-items: center; gap: 10px; margin: 0; }
.task-checkbox {
    width: 18px; height: 18px;
    background: var(--paper-00); border: 1px solid var(--border); border-radius: 0;
    color: var(--peacock-80); cursor: pointer; padding: 0;
    font-size: 13px; line-height: 1; display: flex; align-items: center; justify-content: center;
}
.task.done .task-checkbox { background: var(--peacock-80); color: var(--paper-00); border-color: var(--peacock-80); }
.task-checkbox:hover { border-color: var(--peacock-80); }
.task-label { font-size: 14px; color: var(--ink-80); }
.task.done .task-label { color: var(--fg-subtle); text-decoration: line-through; }
.retro-existing, .reasoning-existing {
    background: var(--paper-20); border: 1px solid var(--border); border-radius: 0;
    padding: 12px; margin: 0 0 12px; white-space: pre-wrap;
    font-family: var(--font-text); font-size: 14px; color: var(--ink-80);
}

/* login + public */
.login-page, .public-page { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 32px; }
.login-box { background: var(--paper-00); border: 1px solid var(--border); border-radius: 0; padding: 36px 40px; min-width: 360px; box-shadow: var(--shadow-2); }
.login-box h1 { font-family: var(--font-display); font-weight: 600; font-size: 36px; color: var(--ink-90); margin: 0 0 20px; letter-spacing: -0.025em; }
.login-box h1 em {
    font-family: var(--font-display); font-style: italic; font-weight: 600;
    background: var(--grad-spectrum);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.login-box form { display: flex; flex-direction: column; gap: 10px; }
.login-box input { background: var(--paper-00); color: var(--ink-90); border: 1px solid var(--border); border-radius: 0; padding: 12px 14px; font-size: 14px; }
.login-box input:focus { outline: 0; border-color: var(--peacock-80); }
.login-box button { background: var(--peacock-80); color: var(--paper-00); border: 0; border-radius: 0; padding: 12px; font-weight: 600; font-size: 14px; cursor: pointer; }
.login-box button:hover { background: var(--peacock-90); }
.err { color: var(--signal-negative); font-size: 12px; margin: 0; }

.public-box { text-align: center; max-width: 520px; padding: 48px; background: var(--paper-00); border: 1px solid var(--border); border-radius: 0; box-shadow: var(--shadow-2); }
.public-box .public-action { font-size: 11px; text-transform: uppercase; letter-spacing: 0.18em; color: var(--peacock-80); margin: 0 0 24px; font-weight: 600; }
.public-box .num {
    font-family: var(--font-display); font-weight: 600;
    font-size: 144px; line-height: 0.95; letter-spacing: -0.025em;
    color: var(--gold);
    display: block;
}
.public-box .lbl { display: block; color: var(--fg-subtle); font-size: 12px; text-transform: uppercase; letter-spacing: 0.18em; margin-top: 12px; }
.public-box .streak-line { font-size: 14px; color: var(--ink-80); margin: 24px 0 0; }
.public-box .streak-line strong { color: var(--peacock-80); font-weight: 600; }
.public-box .footer { font-family: var(--font-mono); font-size: 10px; color: var(--fg-subtle); letter-spacing: 0.18em; text-transform: uppercase; margin-top: 24px; }

/* sub-page wrapper that uses left nav */
.subpage-main { padding: 32px 40px 48px; max-width: 1100px; }

/* ============================================================
   Posts page — Backlog · Drafts · Scheduled · Published
   ============================================================ */

.posts-head {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: 32px; padding-bottom: 22px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 22px;
}
.posts-head h1 {
    font-family: var(--font-display); font-weight: 600;
    font-size: 44px; line-height: 1.02; letter-spacing: -0.025em;
    color: var(--ink-90); margin: 0;
}
.posts-head h1 em {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 600;
    background: var(--grad-spectrum);
    -webkit-background-clip: text;
            background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.posts-head .lead {
    font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--peacock-80);
    margin-bottom: 10px;
    display: flex; align-items: center; gap: 8px;
}
.posts-head .lead img { width: 11px; height: 11px; }
.posts-head .sub {
    font-size: 15px; color: var(--fg-muted);
    margin: 8px 0 0; max-width: 520px;
}
.posts-head .stats {
    display: grid; grid-template-columns: repeat(4, auto);
    gap: 28px; text-align: right;
}
.stat-item .k {
    font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--fg-subtle); margin-bottom: 4px;
}
.stat-item .v {
    font-family: var(--font-display); font-weight: 600;
    font-size: 28px; letter-spacing: -0.025em; line-height: 1;
    color: var(--ink-90); font-feature-settings: "tnum" 1, "lnum" 1;
}
.stat-item .v.peacock { color: var(--peacock-80); }
.stat-item .v.glint { color: var(--glint-80); }

/* tabs */
.tabs {
    display: flex; gap: 4px;
    border-bottom: 1px solid var(--border); margin-bottom: 24px;
}
.tab {
    padding: 12px 18px;
    font-size: 14px; font-weight: 500;
    color: var(--fg-muted); cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    display: flex; align-items: center; gap: 8px;
    transition: color 150ms cubic-bezier(0.2,0.8,0.25,1), border-color 150ms;
    text-decoration: none;
}
.tab:hover { color: var(--ink-90); text-decoration: none; }
.tab.active {
    color: var(--ink-90);
    border-bottom-color: var(--peacock-80);
    font-weight: 600;
}
.tab .count {
    font-family: var(--font-mono); font-size: 11px;
    padding: 2px 7px; border-radius: 999px;
    background: var(--paper-20); color: var(--fg-muted);
    font-variant-numeric: tabular-nums; font-weight: 500;
}
.tab.active .count { background: var(--ink-90); color: var(--paper-00); }

/* capture */
.capture {
    background: var(--paper-00);
    border: 1px solid var(--border); border-radius: 0;
    padding: 6px; box-shadow: var(--shadow-1);
    display: flex; align-items: center; gap: 4px;
    margin-bottom: 18px;
    transition: box-shadow 150ms cubic-bezier(0.2,0.8,0.25,1), border-color 150ms;
}
.capture:focus-within { border-color: var(--ink-90); box-shadow: var(--shadow-2); }
.capture .glint-mark {
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    color: var(--peacock-80);
}
.capture input {
    flex: 1; border: 0; outline: none; background: transparent;
    font-family: var(--font-text); font-size: 16px;
    color: var(--ink-90); padding: 8px 0; letter-spacing: -0.005em;
}
.capture input::placeholder { color: var(--ink-50); }
.capture .add-btn {
    padding: 9px 16px 9px 18px; border-radius: 0;
    background: var(--ink); color: var(--paper);
    font-size: 13px; font-weight: 600;
    border: 0; cursor: pointer;
    font-family: var(--font-text);
    display: flex; align-items: center; gap: 6px;
    transition: background 150ms;
    position: relative;
}
.capture .add-btn::before {
    content: ""; position: absolute;
    left: 0; top: 0; bottom: 0; width: 3px;
    background: var(--grad-spectrum-v);
    pointer-events: none;
}
.capture .add-btn:hover { background: var(--ink-secondary); }
.capture .kbd {
    font-family: var(--font-mono); font-size: 10px;
    color: rgba(255,255,255,0.55);
    padding: 2px 5px;
    background: rgba(255,255,255,0.1);
    border-radius: 0;
}

/* filter chips */
.filter-bar {
    display: flex; align-items: center; gap: 8px;
    margin-bottom: 16px; flex-wrap: wrap;
}
.filter-bar .label {
    font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--fg-subtle); margin-right: 6px;
}
.chip {
    padding: 5px 11px; border-radius: 999px;
    font-size: 13px; font-weight: 500;
    background: var(--paper-00); color: var(--ink-70);
    border: 1px solid var(--border);
    cursor: pointer; text-decoration: none;
    display: inline-flex; align-items: center; gap: 6px;
    transition: background 150ms, color 150ms, border-color 150ms;
}
.chip:hover { border-color: var(--ink-50); text-decoration: none; }
.chip.active {
    background: var(--ink-90); color: var(--paper-00); border-color: var(--ink-90);
}
.chip .dot { width: 6px; height: 6px; border-radius: 999px; }
.chip .num {
    font-family: var(--font-mono); font-size: 11px;
    color: var(--fg-subtle); margin-left: 2px;
}
.chip.active .num { color: rgba(255,255,255,0.55); }

/* two-pane */
.pane-grid {
    display: grid; grid-template-columns: 1fr;
    gap: 16px; align-items: start;
    transition: grid-template-columns 240ms cubic-bezier(0.2,0.8,0.25,1);
}
.pane-grid.with-detail { grid-template-columns: 1fr 460px; }

/* idea list */
.idea-list {
    background: var(--paper-00);
    border: 1px solid var(--border); border-radius: 0;
    box-shadow: var(--shadow-1); overflow: hidden;
}
.idea-row {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    gap: 16px; align-items: center;
    padding: 14px 18px;
    border-bottom: 1px solid var(--border);
    text-decoration: none; color: inherit;
    transition: background 150ms;
    position: relative;
}
.idea-row:last-child { border-bottom: none; }
.idea-row:hover { background: var(--paper-10); text-decoration: none; }
.idea-row.selected {
    background: var(--peacock-10);
    box-shadow: inset 3px 0 0 var(--peacock-80);
}
.idea-row.discarded .idea-title { color: var(--ink-50); text-decoration: line-through; text-decoration-color: var(--ink-50); }
.idea-row.done .idea-title { color: var(--ink-60); }

.status-pip {
    width: 10px; height: 10px; border-radius: 999px;
    flex-shrink: 0; border: 1.5px solid;
}
.status-pip.idea       { background: var(--paper-00); border-color: var(--paper-40); }
.status-pip.promising  { background: var(--glint-80); border-color: var(--glint-80); }
.status-pip.drafting   { background: var(--peacock-80); border-color: var(--peacock-80); }
.status-pip.done       { background: var(--signal-positive); border-color: var(--signal-positive); }
.status-pip.discarded  { background: var(--paper-30); border-color: var(--paper-40); }

.idea-title {
    font-size: 15px; color: var(--ink-90);
    line-height: 1.45; font-weight: 500;
    text-wrap: pretty;
}
.idea-meta {
    font-family: var(--font-mono); font-size: 11px;
    color: var(--fg-subtle);
    font-variant-numeric: tabular-nums; white-space: nowrap;
}
.idea-actions { display: flex; gap: 4px; align-items: center; }
.icon-btn {
    width: 28px; height: 28px; border-radius: 0;
    border: 1px solid var(--border);
    background: var(--paper-00); color: var(--ink-70);
    cursor: pointer; padding: 0;
    display: flex; align-items: center; justify-content: center;
    transition: background 150ms, color 150ms, border-color 150ms;
}
.icon-btn:hover { background: var(--paper-20); color: var(--ink-90); border-color: var(--ink-50); }
.icon-btn.peacock { color: var(--peacock-80); border-color: var(--peacock-30); background: var(--peacock-10); }
.icon-btn.peacock:hover { background: var(--peacock-30); color: var(--peacock-90); }
.icon-btn-form { display: inline; margin: 0; padding: 0; }

/* detail pane */
.detail {
    background: var(--paper-00);
    border: 1px solid var(--border); border-radius: 0;
    box-shadow: var(--shadow-2);
    position: sticky; top: 24px;
    max-height: calc(100vh - 48px);
    display: flex; flex-direction: column; overflow: hidden;
}
.detail-head {
    padding: 18px 20px;
    border-bottom: 1px solid var(--border);
    display: flex; flex-direction: column; gap: 8px;
}
.detail-head .row { display: flex; justify-content: space-between; align-items: center; }
.detail-head .eyebrow {
    font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--fg-muted);
}
.detail-head .close {
    width: 26px; height: 26px; border-radius: 0;
    border: 1px solid var(--border);
    background: var(--paper-00); color: var(--fg-muted);
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    text-decoration: none;
}
.detail-head .close:hover { background: var(--paper-20); color: var(--ink-90); text-decoration: none; }
.detail-head h3 {
    font-family: var(--font-display); font-weight: 600;
    font-size: 18px; line-height: 1.3; letter-spacing: -0.012em;
    color: var(--ink-90); margin: 0; text-wrap: balance;
}
.detail-status-row {
    display: flex; gap: 6px; flex-wrap: wrap;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border);
    background: var(--paper-10);
}
.status-btn {
    padding: 5px 10px; font-size: 12px; font-weight: 500;
    border-radius: 4px; border: 1px solid var(--border);
    background: var(--paper-00); color: var(--ink-70);
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 5px;
    transition: all 150ms;
    font-family: var(--font-text);
}
.status-btn:hover { border-color: var(--ink-50); color: var(--ink-90); }
.status-btn.active.idea { background: var(--paper-30); color: var(--ink-90); border-color: var(--paper-40); }
.status-btn.active.promising { background: var(--glint-30); color: var(--glint-90); border-color: var(--glint-80); }
.status-btn.active.drafting { background: var(--peacock-10); color: var(--peacock-90); border-color: var(--peacock-80); }
.status-btn.active.done { background: #DCEEDF; color: #0F5C36; border-color: var(--signal-positive); }
.status-btn.active.discarded { background: var(--paper-20); color: var(--ink-60); border-color: var(--paper-40); }

.detail-body {
    padding: 16px 20px 20px;
    overflow-y: auto;
    display: flex; flex-direction: column; gap: 16px;
    flex: 1;
}
.draft-section {
    border: 1px solid var(--border); border-radius: 0;
    overflow: hidden;
}
.draft-section .head {
    padding: 12px 14px;
    background: var(--paper-10);
    border-bottom: 1px solid var(--border);
    display: flex; justify-content: space-between; align-items: center; gap: 10px;
}
.draft-section .head .title {
    font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--peacock-80);
    display: flex; align-items: center; gap: 8px;
}
.draft-section .head .title img { width: 11px; height: 11px; }
.draft-section textarea {
    width: 100%; border: 0; outline: none;
    background: var(--paper-00); color: var(--ink-90);
    font-family: var(--font-text); font-size: 14px; line-height: 1.55;
    padding: 14px; resize: vertical; min-height: 220px;
    font-feature-settings: "ss01", "cv11";
    box-sizing: border-box; display: block;
}
.draft-section textarea::placeholder { color: var(--ink-50); }
.draft-section .foot {
    padding: 10px 14px;
    border-top: 1px solid var(--border);
    background: var(--paper-10);
    display: flex; justify-content: space-between; align-items: center;
    gap: 10px;
    font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle);
}
.draft-section .foot .actions { display: flex; gap: 6px; }
.small-btn {
    padding: 6px 11px; border-radius: 4px;
    border: 1px solid var(--border);
    background: var(--paper-00); color: var(--ink-80);
    font-family: var(--font-text); font-size: 12px; font-weight: 500;
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 5px;
    transition: all 150ms;
    text-decoration: none;
}
.small-btn:hover { background: var(--paper-20); border-color: var(--ink-50); text-decoration: none; }
.small-btn.primary {
    background: var(--peacock-80); color: var(--paper-00);
    border-color: var(--peacock-80);
}
.small-btn.primary:hover { background: var(--peacock-90); border-color: var(--peacock-90); }
.small-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.claude-empty {
    padding: 28px 18px; text-align: center;
    color: var(--fg-muted); font-size: 13px; line-height: 1.55;
    background: var(--paper-card);
}
.claude-empty .glint-row { color: var(--glint-80); font-size: 13px; letter-spacing: 0.4em; margin-bottom: 10px; }
.claude-empty strong { display: block; color: var(--ink-90); font-weight: 600; margin-bottom: 4px; font-size: 14px; }

.tone-row { display: flex; gap: 4px; align-items: center; }
.tone-row .lbl {
    font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--fg-subtle); margin-right: 4px;
}
.tone-pill {
    padding: 4px 9px; border-radius: 999px;
    font-size: 11px; font-weight: 500;
    border: 1px solid var(--border);
    background: var(--paper-00); color: var(--ink-70);
    cursor: pointer; font-family: var(--font-text);
}
.tone-pill.active { background: var(--ink-90); color: var(--paper-00); border-color: var(--ink-90); }

.notes-area textarea { min-height: 90px; font-size: 13px; }

.meta-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 8px 16px;
    font-family: var(--font-mono); font-size: 12px;
    padding: 14px;
    background: var(--paper-10);
    border-radius: 0; border: 1px solid var(--border);
}
.meta-grid .k { color: var(--fg-subtle); letter-spacing: 0.04em; }
.meta-grid .v { color: var(--ink-90); font-variant-numeric: tabular-nums; text-align: right; }

.empty-state {
    padding: 60px 24px; text-align: center;
    color: var(--fg-muted); font-size: 14px;
    background: var(--paper-00);
    border: 1px solid var(--border); border-radius: 0;
}
.empty-state .em {
    font-family: var(--font-display);
    font-size: 26px; color: var(--ink-90);
    font-weight: 600; letter-spacing: -0.02em;
    margin-bottom: 8px; display: block;
}

/* drafts grid */
.drafts-grid {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px;
}
.draft-card {
    background: var(--paper-00);
    border: 1px solid var(--border); border-radius: 0;
    padding: 18px 20px; box-shadow: var(--shadow-1);
    display: flex; flex-direction: column; gap: 10px;
    text-decoration: none; color: inherit;
    transition: box-shadow 150ms, border-color 150ms;
}
.draft-card:hover { box-shadow: var(--shadow-2); border-color: var(--paper-40); text-decoration: none; }
.draft-card .hk {
    font-family: var(--font-display); font-weight: 600;
    font-size: 16px; letter-spacing: -0.01em;
    line-height: 1.3; color: var(--ink-90); text-wrap: balance;
}
.draft-card .preview {
    font-size: 13px; color: var(--fg-muted); line-height: 1.5;
    display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical;
    overflow: hidden;
}
.draft-card .foot {
    display: flex; justify-content: space-between; align-items: center;
    padding-top: 10px; border-top: 1px solid var(--border);
    font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle);
}

/* drafting spinner state for the primary button */
.drafting-state .small-btn.primary { opacity: 0.7; }

@media (max-width: 1100px) {
    .pane-grid.with-detail { grid-template-columns: 1fr; }
    .detail { position: relative; top: auto; max-height: none; }
    .posts-head { flex-direction: column; align-items: flex-start; gap: 16px; }
    .posts-head .stats { text-align: left; grid-template-columns: repeat(2, auto); }
    .drafts-grid { grid-template-columns: 1fr; }
}
