:root {
    /* Subtly warm near-white + near-black — placeholder for the artist */
    --bg: #faf8f4;
    --fg: #1a1816;
    --muted: #6b6862;
    --accent: #1a1816;   /* same as fg — no decorative accent */
    --line: #e6e2da;
    --maxw: 36rem;
    --pad: 1.5rem;
}

@media (prefers-color-scheme: dark) {
    :root {
        --bg: #18171a;
        --fg: #ece8e0;
        --muted: #8a8680;
        --accent: #ece8e0;
        --line: #2c2925;
    }
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--fg);
    font-family: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    font-size: 18px;
    line-height: 1.5;
}

main {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: var(--pad);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

a { color: var(--fg); text-decoration: underline; text-underline-offset: 0.2em; }
a:hover { color: var(--accent); }

p { margin: 0 0 1em; }

/* ===== Hero (eyes + heading + status + byline) ===== */

.hero {
    text-align: center;
    margin: 4rem 0 3rem;
}

.eyes {
    font-size: 5rem;
    line-height: 1;
    letter-spacing: 0.1em;
    user-select: none;
    margin-bottom: 1.5rem;
}
.eyes-open .eyes-glyph { color: var(--fg); }
.eyes-half .eyes-glyph { color: var(--fg); opacity: 0.7; }
.eyes-closed .eyes-glyph { color: var(--muted); opacity: 0.6; }

h1.heading {
    font-size: 3rem;
    font-weight: 600;
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin: 0 0 2.2rem;
}
body.phase-open       h1.heading { color: var(--accent); }
body.phase-opens_soon h1.heading { color: var(--fg); }

.status-line {
    font-size: 1.3rem;
    color: var(--fg);
    margin: 0 0 1.4rem;
}

.featured-description {
    font-size: 0.95rem;
    color: var(--muted);
    margin: 0 0 0.5rem;
    font-style: italic;
}

.featured-note {
    font-size: 0.95rem;
    color: var(--muted);
    margin: 0.6rem 0 0;
    font-style: italic;
}

.override-message {
    background: var(--line);
    color: var(--fg);
    padding: 1.2em 1.5em;
    border-radius: 0.3rem;
    margin: 1rem auto 1.5rem;
    max-width: 28rem;
    font-style: italic;
}
.override-message p { margin: 0; }
.override-message a { color: var(--fg); }

/* ===== About block ===== */

.about {
    text-align: center;
    padding: 1.5rem 1rem;
    margin: 2rem 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    color: var(--muted);
    font-size: 0.95rem;
}
.about p { margin: 0.3em 0; }
.about p:first-child { margin-top: 0; }
.about p:last-child  { margin-bottom: 0; }

/* ===== Open again on (tiny list) ===== */

.more-dates {
    margin: 2rem 0 4rem;
    text-align: center;
}
.more-dates h2 {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0 0 0.6rem;
}
.more-dates ul {
    list-style: none;
    padding: 0;
    margin: 0;
    font-size: 0.85rem;
    color: var(--muted);
}
.more-dates li {
    padding: 0.15rem 0;
}
.more-when { color: var(--fg); }
.more-what { margin-left: 0.3em; }

/* ===== Admin (separate aesthetic, kept simple) ===== */

body.admin .hero,
body.admin .about,
body.admin .more-dates { display: none; }

body.admin h1 {
    font-size: 1.4rem;
    text-align: left;
    margin: 0 0 1rem;
}

.flash {
    padding: 0.7em 1em;
    border-radius: 0.3rem;
    margin: 0 0 1rem;
}
.flash-ok    { background: #d4edda; color: #155724; }
.flash-error { background: #f8d7da; color: #721c24; }
.flash-info  { background: #e9ecef; color: #383d41; }

.status-banner {
    padding: 0.8em 1em;
    background: rgba(0,0,0,0.04);
    border-radius: 0.3rem;
    margin: 0 0 1.5rem;
}
@media (prefers-color-scheme: dark) {
    .status-banner { background: rgba(255,255,255,0.05); }
}
.status-banner .phase { font-size: 0.95rem; }
.override-badge {
    display: inline-block;
    margin-top: 0.4em;
    padding: 0.2em 0.6em;
    background: var(--accent);
    color: white;
    border-radius: 0.2rem;
    font-size: 0.85rem;
}

.quick-actions {
    background: rgba(0,0,0,0.03);
    padding: 1rem;
    border-radius: 0.3rem;
    margin-bottom: 2rem;
}
@media (prefers-color-scheme: dark) {
    .quick-actions { background: rgba(255,255,255,0.04); }
}
.quick-actions h2 { margin: 0 0 0.6rem; font-size: 1rem; }
.action-row {
    display: flex;
    gap: 0.5rem;
    align-items: flex-end;
    flex-wrap: wrap;
    padding: 0.6rem 0;
    border-bottom: 1px solid var(--line);
}
.action-row:last-child { border-bottom: none; }
.action-row label { flex: 1; min-width: 12rem; }
.action-row input[type="text"], .action-row input[type="time"] { width: 100%; }
.action-row.danger { background: rgba(201,56,56,0.05); padding: 0.8rem; border-radius: 0.2rem; border-bottom: none; }

.schedule-editor h2 { font-size: 1rem; margin: 1.5rem 0 0.4rem; }

label { display: block; margin: 0.6rem 0; font-size: 0.9rem; color: var(--muted); }
label.checkbox { display: flex; align-items: center; gap: 0.4em; }

input[type="text"], input[type="date"], input[type="time"], textarea {
    display: block;
    width: 100%;
    padding: 0.5em 0.6em;
    font-family: inherit;
    font-size: 1rem;
    color: var(--fg);
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: 0.2rem;
    margin-top: 0.2em;
}
textarea { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 0.95rem; }
label.checkbox input { width: auto; }

button {
    padding: 0.6em 1.2em;
    font-size: 1rem;
    font-family: inherit;
    border: 1px solid var(--fg);
    background: var(--bg);
    color: var(--fg);
    border-radius: 0.2rem;
    cursor: pointer;
}
button:hover { background: var(--fg); color: var(--bg); }
.btn-danger { border-color: var(--accent); color: var(--accent); }
.btn-danger:hover { background: var(--accent); color: white; }
.btn-primary { background: var(--fg); color: var(--bg); }
.btn-primary:hover { background: var(--accent); border-color: var(--accent); color: white; }

.cal-row {
    border-bottom: 1px solid var(--line);
    margin: 0;
}
.cal-row > summary {
    cursor: pointer;
    padding: 0.55rem 0.5rem;
    font-size: 0.95rem;
    list-style: none;
}
.cal-row > summary::-webkit-details-marker { display: none; }
.cal-row > summary::before {
    content: "▸ ";
    color: var(--muted);
    display: inline-block;
    width: 1em;
}
.cal-row[open] > summary::before { content: "▾ "; }
.cal-row.stale > summary { color: var(--muted); }
.cal-row.cal-add > summary { color: var(--accent); font-weight: 600; }
.cal-row.cal-add > summary::before { content: ""; width: 0; }

.cal-form {
    padding: 0.6rem 1rem 1rem 1.5rem;
    background: rgba(0,0,0,0.02);
}
@media (prefers-color-scheme: dark) {
    .cal-form { background: rgba(255,255,255,0.03); }
}
.cal-form .row { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.cal-form .row label { flex: 1; min-width: 7rem; margin: 0.2rem 0; }
.cal-row-actions { margin-top: 0.6rem; text-align: right; }

.content-editor {
    border: 1px solid var(--line);
    border-radius: 0.2rem;
    padding: 0.8rem 1rem;
    margin: 1.5rem 0;
}
.content-editor summary { cursor: pointer; font-weight: 600; }

.save-row {
    margin: 1.5rem 0;
    text-align: right;
}

.hint { color: var(--muted); font-size: 0.85rem; }

.btn-link-danger {
    border: none;
    background: none;
    color: var(--accent);
    text-decoration: underline;
    padding: 0;
    font-size: 0.85rem;
    cursor: pointer;
}
.btn-link-danger:hover { background: none; color: var(--accent); opacity: 0.7; }
