/* =============================================================
   JOURNAL — custom theme on Datasette
   Kraftwerk geometry · Silo amber · Notion calm
   ============================================================= */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
    color-scheme: dark;
    --bg:          #0d0c0a;
    --bg-deep:     #080705;
    --surface:     #141210;
    --surface-2:   #1b1814;
    --surface-3:   #242019;
    --border:      #2a251e;
    --border-2:    #3a3428;
    --text:        #ece7db;
    --text-dim:    #c3bdac;
    --text-muted:  #8a8378;
    --text-quiet:  #5a554b;
    --accent:      #e0ae4c;
    --accent-hot:  #f2bd5c;
    --accent-soft: rgba(224, 174, 76, 0.1);
    --accent-line: rgba(224, 174, 76, 0.35);
    --red:         #d8483f;
    --green:       #8fa968;

    --font-serif:  'Fraunces', 'Newsreader', Georgia, serif;
    --font-sans:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
    --font-mono:   'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

    --max-width:   900px;
    --pad-x:       1.5rem;
}

html { -webkit-tap-highlight-color: transparent; }
a { -webkit-tap-highlight-color: transparent; }

/* hard reset of Datasette defaults we need to replace ---------- */
*, *::before, *::after { box-sizing: border-box; }

html, body {
    background: var(--bg) !important;
    color: var(--text) !important;
    font-family: var(--font-sans) !important;
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
    padding: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body { min-height: 100vh; }

/* kill Datasette's stock blue header/footer backgrounds on native HTML tags */
header, footer, article, aside, section, nav {
    background: transparent !important;
    background-color: transparent !important;
    color: inherit;
    overflow: visible;
}

::selection { background: var(--accent-soft); color: var(--accent-hot); }

/* layout shell ----------------------------------------------- */
.not-footer {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 var(--pad-x);
}

header {
    padding: 2.5rem 0 0.75rem;
    position: relative;
}

header::after {
    content: '';
    display: block;
    height: 1px;
    background: var(--border);
    margin-top: 1.25rem;
}

/* crumbs / nav ----------------------------------------------- */
nav p.crumbs {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--text-quiet);
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

nav p.crumbs a {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    min-height: 44px;
    padding: 0.4rem 0.85rem 0.4rem 0.7rem;
    margin-left: -0.7rem;  /* optical align to edge, expand tap target */
    border: 1px solid transparent !important;
    border-radius: 8px;
    color: var(--text) !important;
    text-decoration: none !important;
    font-weight: 500;
    letter-spacing: 0.22em;
    font-size: 0.8rem;
    transition: background 0.15s, border-color 0.15s;
}
nav p.crumbs a:hover, nav p.crumbs a:focus-visible {
    background: var(--surface);
    border-color: var(--border) !important;
    color: var(--text) !important;
    outline: none;
}
nav p.crumbs a::before {
    content: '←';
    color: var(--accent);
    font-weight: 300;
    font-size: 1.1rem;
    line-height: 1;
    margin-right: 0.15rem;
}

/* Index / root pages don't show a back arrow — just the wordmark */
body.index nav p.crumbs a::before { content: none; }
body.index nav p.crumbs a {
    color: var(--text-dim) !important;
    letter-spacing: 0.22em;
}
body.index nav p.crumbs a:hover { color: var(--text) !important; }

nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.nav-menu { margin-left: auto; }
.nav-menu summary {
    cursor: pointer;
    color: var(--text-muted);
    padding: 0.3rem 0.4rem;
    list-style: none;
    border-radius: 4px;
}
.nav-menu summary::-webkit-details-marker { display: none; }
.nav-menu summary:hover { color: var(--accent); }

.nav-menu-inner {
    position: absolute;
    right: 0;
    top: 2.8rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 0.5rem 0;
    min-width: 200px;
    z-index: 10;
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.nav-menu-inner ul { list-style: none; margin: 0; padding: 0; }
.nav-menu-inner li a {
    display: block;
    padding: 0.45rem 1rem;
    color: var(--text);
    text-decoration: none;
    font-size: 0.88rem;
}
.nav-menu-inner li a:hover { background: var(--surface-2); color: var(--accent-hot); }

/* content ---------------------------------------------------- */
section.content { padding: 2rem 0 4rem; }

h1 {
    font-family: var(--font-serif);
    font-weight: 400;
    font-size: clamp(2rem, 5vw, 2.75rem);
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--text);
    margin: 0 0 0.5rem;
    font-variation-settings: 'opsz' 96;
}

h2 {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 1.4rem;
    line-height: 1.2;
    letter-spacing: -0.01em;
    color: var(--text);
    margin: 2.5rem 0 0.5rem;
    padding-left: 0 !important;
    border-left: none !important;
}

h2 a {
    color: var(--text);
    text-decoration: none;
}
h2 a:hover { color: var(--accent-hot); }

h3 {
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: 0.75rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin: 2rem 0 0.75rem;
}

p { color: var(--text-dim); margin: 0.75rem 0; }

a, a:link, a:visited, a:active {
    color: var(--accent);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.15s, color 0.15s;
}
a:hover { color: var(--accent-hot); border-bottom-color: var(--accent-line); }

/* Cards & directory rows — no underline even on hover */
.log-entry, .log-entry:link, .log-entry:visited,
.directory-row, .directory-row:link, .directory-row:visited,
.related-list a, .related-list a:link, .related-list a:visited {
    text-decoration: none;
    border-bottom: none;
}
.log-entry:hover, .directory-row:hover, .related-list a:hover {
    border-bottom: none;
}

/* Safari iOS data-detector links (auto-underlined dates/phones/addresses).
   Must use !important — Safari injects inline styles. */
a[href^="x-apple-data-detectors:"],
a[href^="tel:"],
a[href^="sms:"],
a[href^="addressbook:"],
a[x-apple-data-detectors],
a[data-apple-data-detector] {
    color: inherit !important;
    -webkit-text-fill-color: inherit !important;
    background-color: transparent !important;
    background: transparent !important;
    text-decoration: none !important;
    border: 0 !important;
    border-bottom: 0 !important;
    pointer-events: none !important;
    font-weight: inherit !important;
    font-style: inherit !important;
    font-size: inherit !important;
}

/* Prevent iOS text-size adjust pulling fonts bigger in landscape */
html { -webkit-text-size-adjust: 100%; }

hr { border: 0; border-top: 1px solid var(--border); margin: 2rem 0; }

code, tt, pre {
    font-family: var(--font-mono);
    font-size: 0.85em;
    color: var(--text-dim);
    background: var(--surface-2);
    padding: 0.12em 0.4em;
    border-radius: 3px;
    border: 1px solid var(--border);
}

pre {
    display: block;
    padding: 1rem;
    overflow-x: auto;
    line-height: 1.5;
}

pre code { background: transparent; border: 0; padding: 0; }

/* forms ------------------------------------------------------ */
input[type=text], input[type=search], input[type=email], textarea, select {
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 0.55rem 0.75rem;
    font-family: var(--font-mono);
    font-size: 0.85rem;
    transition: border-color 0.15s;
}
input[type=text]:focus, input[type=search]:focus, input[type=email]:focus, textarea:focus, select:focus {
    outline: none;
    border-color: var(--accent);
    background: var(--surface-2);
}
input::placeholder { color: var(--text-quiet); }

input[type=submit], button {
    background: var(--accent);
    color: var(--bg-deep);
    border: 0;
    border-radius: 4px;
    padding: 0.55rem 1.1rem;
    font-family: var(--font-sans);
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.15s;
}
input[type=submit]:hover, button:hover { background: var(--accent-hot); }

form.core { margin: 1.5rem 0; }
form.core input[type=search] { width: 100%; max-width: 420px; font-size: 0.92rem; padding: 0.7rem 0.85rem; }

/* tables ----------------------------------------------------- */
table.rows-and-columns, .table-wrapper table {
    border-collapse: collapse;
    width: 100%;
    font-family: var(--font-mono);
    font-size: 0.82rem;
    margin: 1.5rem 0;
    border: 1px solid var(--border);
    border-radius: 6px;
    overflow: hidden;
    background: var(--surface);
}

.table-wrapper {
    overflow-x: auto;
    border-radius: 6px;
    -webkit-overflow-scrolling: touch;
}

table.rows-and-columns thead th,
.table-wrapper table thead th {
    background: var(--surface-2);
    color: var(--text-muted);
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-align: left;
    padding: 0.85rem 1rem;
    border-bottom: 1px solid var(--border-2);
    white-space: nowrap;
}

table.rows-and-columns tbody td,
.table-wrapper table tbody td {
    padding: 0.7rem 1rem;
    border-bottom: 1px solid var(--border);
    color: var(--text-dim);
    vertical-align: top;
}

table.rows-and-columns tbody tr:last-child td,
.table-wrapper table tbody tr:last-child td {
    border-bottom: 0;
}

table.rows-and-columns tbody tr:hover,
.table-wrapper table tbody tr:hover {
    background: var(--surface-2);
}

table.rows-and-columns tbody td a,
.table-wrapper table tbody td a {
    color: var(--text);
    border-bottom: 1px dotted var(--border-2);
}
table.rows-and-columns tbody td a:hover,
.table-wrapper table tbody td a:hover {
    color: var(--accent);
    border-bottom-color: var(--accent-line);
}

/* column count indicator, etc */
.count {
    font-family: var(--font-mono);
    color: var(--text-quiet);
    font-size: 0.8rem;
    letter-spacing: 0.05em;
}

/* facets ----------------------------------------------------- */
.facets {
    margin: 1.5rem 0;
    padding: 0;
}

.facet-info, details.facet-info {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 0.8rem 1rem;
    margin: 0.4rem 0;
}

.facet-info-name, .facet-info summary {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.facet-info ul { list-style: none; margin: 0.5rem 0 0; padding: 0; }
.facet-info li {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.25rem 0.55rem;
    margin: 0.15rem 0.25rem 0.15rem 0;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 3px;
    font-family: var(--font-mono);
    font-size: 0.78rem;
}

.facet-info li a { color: var(--text); border: 0; }
.facet-info li a:hover { color: var(--accent); }
.facet-info li .count { color: var(--text-quiet); font-size: 0.72rem; }

/* pagination / meta ------------------------------------------ */
p.export-links, p.filter-row, .rows-and-table-meta {
    font-family: var(--font-mono);
    font-size: 0.78rem;
    color: var(--text-muted);
}

p.export-links a { color: var(--text-dim); margin-right: 0.75rem; }

.filter-row {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    flex-wrap: wrap;
    margin: 0.5rem 0;
}

.filter-row select, .filter-row input { font-size: 0.78rem; padding: 0.35rem 0.55rem; }

/* messages --------------------------------------------------- */
.message-info, .message-warning, .message-error {
    padding: 0.75rem 1rem;
    border-left: 3px solid;
    border-radius: 2px;
    font-family: var(--font-mono);
    font-size: 0.85rem;
    margin: 1rem 0;
}
.message-info    { border-color: var(--accent); background: var(--accent-soft); }
.message-warning { border-color: var(--accent); background: var(--accent-soft); }
.message-error   { border-color: var(--red); background: rgba(216,72,63,0.08); color: var(--red); }

/* footer ----------------------------------------------------- */
footer.ft {
    max-width: var(--max-width);
    margin: 3rem auto 2rem;
    padding: 1.5rem var(--pad-x) 0;
    border-top: 1px solid var(--border);
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-quiet);
    text-align: center;
}
footer.ft a { color: var(--text-muted); }
footer.ft a:hover { color: var(--accent); }

/* ============================================================
   Custom classes used by our overridden templates
   ============================================================ */

.hero {
    padding: 3rem 0 2rem;
    border-bottom: 1px solid var(--border);
    margin-bottom: 2.5rem;
    position: relative;
}

/* View toggle floats in top-right corner of the hero.
   Higher specificity (.view-toggle.hero-view-toggle) beats `button.view-toggle`
   which uses `all: unset` and would otherwise reset positioning. */
.view-toggle.hero-view-toggle {
    position: absolute;
    top: 2.75rem;
    right: 0;
    z-index: 2;
}
@media (max-width: 600px) {
    .view-toggle.hero-view-toggle { top: 1.25rem; }
}

.hero .kicker {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 0.8rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.hero .kicker::before {
    content: '';
    width: 1.2rem;
    height: 1px;
    background: var(--accent);
}

.hero h1 {
    margin: 0 0 0.8rem;
    font-size: clamp(2.4rem, 6vw, 3.5rem);
    font-weight: 300;
    font-variation-settings: 'opsz' 144;
}

.hero .subtitle {
    font-family: var(--font-serif);
    font-style: italic;
    font-weight: 300;
    font-size: 1.1rem;
    color: var(--text-muted);
    max-width: 42ch;
    line-height: 1.5;
}

/* directory listing (silo floors) ---------------------------- */
.directory {
    display: grid;
    gap: 0;
    margin: 1rem 0 3rem;
}

.directory-row {
    display: grid;
    grid-template-columns: 3.5rem 1fr auto;
    gap: 1.25rem;
    align-items: baseline;
    padding: 1.1rem 0.25rem;
    border-bottom: 1px solid var(--border);
    transition: background 0.15s, padding 0.15s;
    text-decoration: none;
    border-left: 0;
}

.directory-row:hover {
    background: linear-gradient(to right, var(--accent-soft), transparent 60%);
    padding-left: 0.75rem;
}

.directory-row .num {
    font-family: var(--font-mono);
    font-size: 0.85rem;
    color: var(--text-quiet);
    letter-spacing: 0.05em;
    font-variant-numeric: tabular-nums;
}

.directory-row .label {
    font-family: var(--font-serif);
    font-weight: 400;
    font-size: 1.25rem;
    color: var(--text);
    letter-spacing: -0.005em;
}

.directory-row:hover .label { color: var(--accent-hot); }

.directory-row .meta {
    font-family: var(--font-mono);
    font-size: 0.75rem;
    color: var(--text-muted);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
}

/* stat strip ------------------------------------------------- */
.strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 1rem;
    margin: 2rem 0;
}

.strip .cell {
    padding: 1rem 0;
    border-top: 1px solid var(--border);
}

.strip .cell .k {
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--text-muted);
    display: block;
    margin-bottom: 0.35rem;
}

.strip .cell .v {
    font-family: var(--font-serif);
    font-size: 1.65rem;
    font-weight: 400;
    color: var(--text);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.strip .cell .v.accent { color: var(--accent); }

/* section headers on index ----------------------------------- */
.section-heading {
    display: flex;
    align-items: baseline;
    gap: 1rem;
    margin: 2.5rem 0 0.5rem;
    padding-bottom: 0.5rem;
}

.section-heading .tag {
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--accent);
}

.section-heading .dots { flex: 1; height: 1px; background: var(--border); }

/* ============================================================
   Logbook (feed view)
   ============================================================ */

.type-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin: 1.25rem 0 1rem;
}

.type-nav .chip {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.38rem 0.8rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-dim);
    background: var(--surface);
    transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.type-nav .chip:hover {
    color: var(--accent-hot);
    border-color: var(--accent-line);
    background: var(--accent-soft);
}
.type-nav .chip.active {
    color: var(--accent-hot);
    border-color: var(--accent);
    background: var(--accent-soft);
}
.type-nav .chip-count {
    color: var(--text-quiet);
    font-weight: 500;
    padding: 0.05rem 0.35rem;
    background: var(--surface-2);
    border-radius: 999px;
    font-size: 0.66rem;
}
.type-nav .chip.active .chip-count { background: rgba(0,0,0,0.35); color: var(--text-dim); }

/* secondary tag row */
.tag-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin: 0 0 1.25rem;
}
.tag-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.22rem 0.6rem;
    border: 1px solid transparent;
    border-radius: 3px;
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.04em;
    color: var(--text-muted);
    background: var(--surface);
    transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.tag-chip:hover {
    color: var(--accent-hot);
    border-color: var(--accent-line);
}
.tag-chip.active {
    color: var(--accent-hot);
    border-color: var(--accent);
    background: var(--accent-soft);
}
.tag-chip-count {
    color: var(--text-quiet);
    font-size: 0.62rem;
}
.tag-chip-clear {
    color: var(--text-dim);
    border-color: var(--border);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.62rem;
}
.tag-chip-clear:hover {
    color: var(--red);
    border-color: var(--red);
}

/* ============================================================
   Filters button + slide-up sheet
   ============================================================ */

/* Hide Datasette's default burger menu — it's empty clutter for us */
.nav-menu, .nav-menu-inner { display: none !important; }

.filter-btn {
    position: fixed;
    right: 1rem;
    bottom: calc(env(safe-area-inset-bottom, 0px) + 1rem);
    z-index: 40;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.7rem 1rem;
    border: 1px solid var(--border-2);
    border-radius: 999px;
    background: var(--surface-2);
    color: var(--text);
    font-family: var(--font-sans);
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    cursor: pointer;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5), 0 0 0 4px rgba(13,12,10,0.3);
    text-transform: uppercase;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    transition: transform 0.15s, background 0.15s, border-color 0.15s;
}
.filter-btn:hover, .filter-btn:focus-visible {
    background: var(--surface-3);
    border-color: var(--accent-line);
    color: var(--accent-hot);
    outline: none;
    transform: translateY(-1px);
}
.filter-btn svg { flex: none; color: var(--text-dim); }
.filter-btn:hover svg { color: var(--accent-hot); }
.filter-btn-label { letter-spacing: 0.12em; }

.filter-btn-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 0.35rem;
    background: var(--accent);
    color: var(--bg-deep);
    border-radius: 999px;
    font-family: var(--font-mono);
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
    margin-right: -0.25rem;
}

/* Slide-up sheet */
.filter-sheet {
    position: fixed;
    inset: 0;
    z-index: 50;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}
.filter-sheet[hidden] { display: none; }

.filter-sheet-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.6);
    opacity: 0;
    transition: opacity 0.22s ease;
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
}
.filter-sheet.open .filter-sheet-backdrop { opacity: 1; }

.filter-sheet-panel {
    position: relative;
    width: 100%;
    max-width: 560px;
    max-height: 85dvh;                  /* dynamic vh: accounts for iOS toolbar */
    overflow-y: auto;
    overscroll-behavior: contain;       /* keeps scroll inside the sheet */
    -webkit-overflow-scrolling: touch;  /* momentum scroll on iOS */
    background: var(--bg);
    border: 1px solid var(--border);
    border-bottom: 0;
    border-radius: 16px 16px 0 0;
    padding: 1.25rem 1.5rem calc(env(safe-area-inset-bottom, 0px) + 2rem);
    transform: translateY(100%);
    transition: transform 0.25s cubic-bezier(.22,.9,.33,1);
    box-shadow: 0 -20px 40px rgba(0,0,0,0.5);
}

/* Subtle scrollbar — only visible when scrolling on webkit */
.filter-sheet-panel::-webkit-scrollbar { width: 6px; }
.filter-sheet-panel::-webkit-scrollbar-track { background: transparent; }
.filter-sheet-panel::-webkit-scrollbar-thumb {
    background: var(--border-2);
    border-radius: 3px;
}
.filter-sheet-panel::-webkit-scrollbar-thumb:hover { background: var(--text-quiet); }

/* ============================================================
   PUBLIC-SITE LAYOUT (log.atheo.dev)
   Uses its own wrapper classes (.shell, .site-head, .site-foot)
   so internal and public sites share this stylesheet cleanly.
   ============================================================ */

.shell {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 var(--pad-x);
}

.site-head {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1.25rem 0 1rem;
    border-bottom: 1px solid var(--border);
    margin-bottom: 2rem;
    flex-wrap: wrap;
}

.home-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    min-height: 44px;
    padding: 0.4rem 0.9rem 0.4rem 0.7rem;
    margin-left: -0.7rem;  /* optical align to edge, expand tap target */
    border: 1px solid transparent !important;
    border-radius: 8px;
    text-decoration: none !important;
    transition: background 0.15s, border-color 0.15s;
}
.home-link:hover, .home-link:focus-visible {
    background: var(--surface);
    border-color: var(--border) !important;
    outline: none;
}

.home-link .home-back {
    font-size: 1.15rem;
    color: var(--accent);
    font-weight: 300;
    line-height: 1;
}
.home-link .home-mark {
    font-family: var(--font-mono);
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--text);
}
.site-head-home .home-link .home-mark {
    /* softer on home — you're already here */
    color: var(--text-dim);
}
.site-head-home .home-link:hover .home-mark { color: var(--text); }

/* Optional additional crumb content after the home link */
.site-head > *:not(.home-link) {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--text-quiet);
}
.site-head a:not(.home-link) {
    color: var(--text-dim) !important;
    border-bottom: 1px solid transparent !important;
}
.site-head a:not(.home-link):hover { color: var(--accent-hot) !important; }

.site-foot {
    margin: 4rem auto 2rem;
    padding: 1.5rem 0 0;
    border-top: 1px solid var(--border);
    font-family: var(--font-mono);
    font-size: 0.7rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-quiet);
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}
.site-foot .dot { color: var(--border-2); }

.stream { margin: 2rem 0 1.5rem; }

.stream-heading {
    display: flex;
    align-items: baseline;
    gap: 1rem;
    margin: 0 0 0.5rem;
}
.stream-heading .tag {
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--accent);
}
.stream-heading .dots { flex: 1; height: 1px; background: var(--border); }

.tagline {
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--text-muted);
    max-width: 48ch;
    margin: 0.5rem 0 0;
}

/* Clickable type chips on the public homepage */
.type-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin: 0 0 1.5rem;
}
.type-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.3rem 0.65rem 0.3rem 0.75rem;
    border: 1px solid var(--border) !important;
    border-radius: 999px;
    font-family: var(--font-mono);
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-dim) !important;
    background: var(--surface);
    text-decoration: none !important;
    transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.type-chip:hover {
    color: var(--accent-hot) !important;
    border-color: var(--accent-line) !important;
    background: var(--accent-soft);
}
.type-chip-count {
    color: var(--text-muted);
    font-size: 0.62rem;
    padding: 0.05rem 0.3rem;
    background: var(--surface-2);
    border-radius: 999px;
    font-variant-numeric: tabular-nums;
    line-height: 1.3;
}

/* Directory on the public homepage (retained as secondary nav if present) */
.type-directory {
    display: grid;
    gap: 0;
    margin: 0.5rem 0 0;
}
.type-row {
    display: grid;
    grid-template-columns: 3.5rem 1fr auto;
    gap: 1.25rem;
    align-items: baseline;
    padding: 1rem 0.25rem;
    border-top: 1px solid var(--border);
    text-decoration: none !important;
    border-bottom: 0 !important;
    transition: background 0.15s, padding 0.15s;
}
.type-row:last-child { border-bottom: 1px solid var(--border) !important; }
.type-row:hover {
    background: linear-gradient(to right, var(--accent-soft), transparent 60%);
    padding-left: 0.75rem;
}
.type-row .num {
    font-family: var(--font-mono);
    font-size: 0.82rem;
    color: var(--text-quiet);
    letter-spacing: 0.05em;
    font-variant-numeric: tabular-nums;
}
.type-row .label {
    font-family: var(--font-serif);
    font-size: 1.2rem;
    color: var(--text);
    letter-spacing: -0.005em;
}
.type-row:hover .label { color: var(--accent-hot); }
.type-row .meta {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    color: var(--text-muted);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
}

/* Mobile layout for the public site */
@media (max-width: 600px) {
    .site-head { padding: 1.25rem 0 0.75rem; margin-bottom: 1.25rem; }
    .stream { margin: 1.5rem 0 1.25rem; }
    .type-chips { gap: 0.35rem; }
    .type-chip { font-size: 0.66rem; padding: 0.32rem 0.65rem; }
    .type-row { grid-template-columns: 2.5rem 1fr auto; gap: 0.75rem; padding: 0.85rem 0.2rem; }
    .type-row .label { font-size: 1.02rem; }
    .type-row .meta { font-size: 0.66rem; }
}
.filter-sheet.open .filter-sheet-panel { transform: translateY(0); }

.filter-sheet-panel::before {
    content: '';
    display: block;
    width: 44px;
    height: 4px;
    border-radius: 2px;
    background: var(--border-2);
    margin: 0 auto 1rem;
}

.filter-sheet-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 0.25rem;
}
.filter-sheet-head h2 {
    font-family: var(--font-serif);
    font-size: 1.6rem;
    font-weight: 400;
    margin: 0;
    letter-spacing: -0.01em;
}
.filter-sheet-close {
    background: transparent;
    border: 0;
    color: var(--text-muted);
    padding: 0.4rem;
    cursor: pointer;
    border-radius: 4px;
}
.filter-sheet-close:hover { color: var(--accent-hot); background: var(--surface-2); }

.sheet-section { padding: 1rem 0; border-top: 1px solid var(--border); }
.sheet-section:first-child { border-top: 0; }
.sheet-section h3 {
    font-family: var(--font-sans);
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--accent);
    margin: 0 0 0.75rem;
    font-weight: 600;
}
.sheet-search {
    width: 100%;
    margin-bottom: 0.75rem;
    font-size: 0.85rem;
    padding: 0.55rem 0.75rem;
    background: var(--surface);
}
.sheet-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}
.sheet-tags .tag-chip { font-size: 0.78rem; padding: 0.35rem 0.75rem; }
.sheet-no-match {
    font-size: 0.85rem;
    color: var(--text-muted);
    margin: 0.75rem 0 0;
    font-style: italic;
}
.sheet-empty {
    font-size: 0.88rem;
    color: var(--text-muted);
    font-style: italic;
}
a.sheet-clear-all, a.sheet-clear-all:link, a.sheet-clear-all:visited {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--red);
    padding: 0.45rem 0.75rem;
    border: 1px solid var(--red);
    border-radius: 4px;
}
a.sheet-clear-all:hover {
    background: rgba(216,72,63,0.12);
    color: var(--red);
    border-color: var(--red);
}

@media (min-width: 601px) {
    /* Desktop: button sits inline near the top, not thumb-fixed. */
    .filter-btn {
        position: sticky;
        top: 1rem;
        right: auto;
        bottom: auto;
        margin-left: auto;
        float: right;
    }
    /* Center the sheet vertically on desktop */
    .filter-sheet { align-items: center; }
    .filter-sheet-panel {
        max-width: 480px;
        border-radius: 12px;
        border: 1px solid var(--border);
        transform: translateY(20px) scale(0.98);
        opacity: 0;
    }
    .filter-sheet.open .filter-sheet-panel {
        transform: translateY(0) scale(1);
        opacity: 1;
    }
    .filter-sheet-panel::before { display: none; }
}

.search-form {
    margin: 0.5rem 0 1rem;
}
.feed-state {
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--text-quiet);
    min-height: 1rem;
    margin-bottom: 0.75rem;
}
.search-form input[type=search] {
    width: 100%;
    max-width: none;
    font-size: 0.95rem;
    padding: 0.75rem 1rem;
    background: var(--surface);
}

/* Native clear button — force-visible on iOS + style for dark theme.
   WebKit renders a default magnifier/cancel pair; we override with our own. */
input[type=search]::-webkit-search-decoration,
input[type=search]::-webkit-search-results-button,
input[type=search]::-webkit-search-results-decoration { display: none; }

input[type=search]::-webkit-search-cancel-button {
    -webkit-appearance: none;
    appearance: none;
    height: 18px;
    width: 18px;
    margin-left: 0.4rem;
    cursor: pointer;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238a8378' stroke-width='2.4' stroke-linecap='round'><line x1='5' y1='5' x2='19' y2='19'/><line x1='19' y1='5' x2='5' y2='19'/></svg>");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 14px 14px;
    opacity: 0.85;
}
input[type=search]::-webkit-search-cancel-button:hover { opacity: 1; }

.logbook {
    display: flex;
    flex-direction: column;
    margin: 0 0 2rem;
}

.log-entry {
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 1.1rem;
    padding: 1.25rem 0.25rem;
    border-top: 1px solid var(--border);
    border-bottom: none;
    border-left: none;
    text-decoration: none;
    color: inherit;
    transition: background 0.15s, padding 0.15s;
}
.log-entry:first-child { border-top: 1px solid var(--border-2); }
.log-entry:last-child { border-bottom: 1px solid var(--border); }
.log-entry:hover {
    background: linear-gradient(to right, var(--accent-soft), transparent 70%);
    padding-left: 0.75rem;
}

.log-poster {
    width: 72px;
    height: 108px;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 4px;
    overflow: hidden;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.log-poster img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.log-poster-empty {
    font-family: var(--font-serif);
    font-size: 2rem;
    color: var(--text-quiet);
    font-weight: 300;
}

.log-body {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    min-width: 0;
}

.log-meta {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: 0.15rem;
    flex-wrap: wrap;
}

.log-type {
    color: var(--accent);
    font-weight: 500;
}
.log-meta .log-date {
    color: var(--text-quiet);
    font-variant-numeric: tabular-nums;
}

.log-status {
    padding: 0.08rem 0.4rem;
    border-radius: 3px;
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text-muted);
    font-size: 0.62rem;
}
.log-status-doing { color: var(--accent); border-color: var(--accent-line); }
.log-status-want  { color: var(--text-dim); }
.log-status-abandoned { color: var(--text-quiet); text-decoration: line-through; }

.log-title {
    font-family: var(--font-serif);
    font-size: 1.2rem;
    font-weight: 400;
    line-height: 1.25;
    color: var(--text);
    letter-spacing: -0.005em;
    overflow-wrap: anywhere;
}
.log-entry:hover .log-title { color: var(--accent-hot); }

.log-creator {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 0.92rem;
    color: var(--text-muted);
    font-weight: 300;
}

.log-attribution {
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-quiet);
    margin-top: 0.15rem;
}
.log-attribution::before {
    content: '·  ';
    color: var(--accent);
}

.log-rating {
    font-family: var(--font-mono);
    font-size: 0.85rem;
    color: var(--accent);
    margin-top: 0.15rem;
}
.log-rating .rating-max { color: var(--text-quiet); font-size: 0.7rem; }

.log-excerpt {
    font-size: 0.9rem;
    color: var(--text-dim);
    margin-top: 0.35rem;
    line-height: 1.55;
}

.empty {
    padding: 3rem 1rem;
    text-align: center;
    color: var(--text-muted);
    border: 1px dashed var(--border);
    border-radius: 6px;
    margin: 1.5rem 0;
}

/* ============================================================
   Collections list — single-column, description below title
   ============================================================ */
.collection-list {
    display: flex;
    flex-direction: column;
    margin: 0.25rem 0 0.5rem;
}
.collection-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.9rem 0.2rem;
    border-top: 1px solid var(--border);
    text-decoration: none !important;
    color: inherit !important;
    border-bottom: 0 !important;
    transition: background 0.15s, padding 0.15s;
}
.collection-row:last-child { border-bottom: 1px solid var(--border) !important; }
.collection-row:hover {
    background: linear-gradient(to right, var(--accent-soft), transparent 70%);
    padding-left: 0.7rem;
}
.collection-row-main { flex: 1; min-width: 0; }
.collection-title {
    font-family: var(--font-serif);
    font-size: 1.1rem;
    color: var(--text);
    margin-bottom: 0.2rem;
}
.collection-row:hover .collection-title { color: var(--accent-hot); }
.collection-desc {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 0.88rem;
    color: var(--text-muted);
    font-weight: 300;
    line-height: 1.4;
    max-width: 60ch;
}
.collection-meta {
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-quiet);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    white-space: nowrap;
    padding-top: 0.25rem;
}
.pill-public {
    padding: 0.08rem 0.4rem;
    border: 1px solid var(--accent-line);
    border-radius: 3px;
    color: var(--accent);
    font-size: 0.6rem;
}

/* Curator note inside a collection listing */
.curator-note {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 0.88rem;
    color: var(--text-muted);
    margin: -0.25rem 0 0.75rem 72px;
    padding-left: 1.25rem;
    border-left: 2px solid var(--accent-line);
    line-height: 1.45;
}
@media (max-width: 600px) {
    .curator-note { margin-left: 60px; font-size: 0.82rem; }
}

/* ============================================================
   Shelf grid — compact poster tiles for owned items
   ============================================================ */
.shelf-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 1rem 0.9rem;
    margin: 0.25rem 0 0;
}

.shelf-tile {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    text-decoration: none !important;
    border-bottom: 0 !important;
    color: inherit !important;
    transition: transform 0.15s;
}
.shelf-tile:hover { transform: translateY(-2px); }

.shelf-poster {
    aspect-ratio: 2 / 3;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 3px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 16px rgba(0,0,0,0.4);
    transition: border-color 0.15s, box-shadow 0.15s;
}
.shelf-tile:hover .shelf-poster {
    border-color: var(--accent-line);
    box-shadow: 0 10px 24px rgba(0,0,0,0.55);
}
.shelf-poster img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.shelf-poster-empty {
    font-family: var(--font-serif);
    font-size: 2rem;
    color: var(--text-quiet);
    font-weight: 300;
    aspect-ratio: 2 / 3;
}

.shelf-title {
    font-family: var(--font-serif);
    font-size: 0.95rem;
    line-height: 1.25;
    color: var(--text);
    font-weight: 400;
}
.shelf-tile:hover .shelf-title { color: var(--accent-hot); }

.shelf-type {
    font-family: var(--font-mono);
    font-size: 0.6rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--text-quiet);
}

@media (max-width: 600px) {
    .shelf-grid { grid-template-columns: repeat(auto-fill, minmax(95px, 1fr)); gap: 0.75rem 0.6rem; }
    .shelf-title { font-size: 0.88rem; }
}

/* ============================================================
   View toggle (cards <-> compact list)
   ============================================================ */
/* Segmented-look toggle — the whole surface is one button. Tap anywhere flips. */
button.view-toggle {
    all: unset;
    display: inline-flex;
    align-items: center;
    gap: 0;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    padding: 2px;
    flex-shrink: 0;
    cursor: pointer;
    transition: border-color 0.15s;
}
button.view-toggle:hover, button.view-toggle:focus-visible {
    border-color: var(--accent-line);
    outline: none;
}
.view-toggle .view-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 28px;
    border-radius: 6px;
    color: var(--text-muted);
    transition: color 0.15s, background 0.15s;
    pointer-events: none;  /* icons are decorative; clicks go to the button */
}
.view-toggle svg { width: 14px; height: 14px; }

/* Highlight the currently-active view */
html:not([data-view="compact"]) .view-icon-cards,
html[data-view="compact"] .view-icon-compact {
    background: var(--accent-soft);
    color: var(--accent-hot);
}

.feed-toolbar {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin: 0.5rem 0 1.25rem;
    justify-content: flex-end;
}
.feed-toolbar .search-form {
    flex: 1;
    margin: 0;
    min-width: 0;
    margin-right: auto;
}
.feed-toolbar .view-toggle { flex-shrink: 0; }

/* --- Compact list mode --- */
.logbook.compact {
    display: block;
    border-top: 1px solid var(--border-2);
    margin-top: 0;
}

.logbook.compact .log-entry {
    display: grid;
    grid-template-columns: 6.5rem 1fr auto;
    grid-template-rows: auto;
    column-gap: 0.9rem;
    row-gap: 0.1rem;
    align-items: baseline;
    padding: 0.7rem 0.25rem;
    border-top: none;
    border-bottom: 1px solid var(--border);
    transition: background 0.15s, padding 0.15s;
}
.logbook.compact .log-entry:first-child { border-top: none; }
.logbook.compact .log-entry:hover {
    background: linear-gradient(to right, var(--accent-soft), transparent 70%);
    padding-left: 0.65rem;
}

/* Hide poster + excerpt + extra in list mode */
.logbook.compact .log-poster,
.logbook.compact .log-excerpt { display: none; }

/* Column 1 — date (mono, muted) */
.logbook.compact .log-meta {
    grid-column: 1;
    grid-row: 1 / 3;
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    color: var(--text-quiet);
    font-variant-numeric: tabular-nums;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    align-items: flex-start;
    text-transform: none;
    padding-top: 0.15rem;
    margin: 0;
}
.logbook.compact .log-meta .log-type {
    color: var(--accent);
    font-size: 0.6rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}
.logbook.compact .log-meta .log-date { color: var(--text-quiet); }
.logbook.compact .log-meta .log-status {
    font-size: 0.58rem;
    padding: 0 0.3rem;
}

/* Column 2 — title + creator on two rows */
.logbook.compact .log-body {
    grid-column: 2;
    display: contents;
}
.logbook.compact .log-title {
    grid-column: 2;
    grid-row: 1;
    font-family: var(--font-serif);
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.2;
    color: var(--text);
    margin: 0;
}
.logbook.compact .log-entry:hover .log-title { color: var(--accent-hot); }
.logbook.compact .log-creator {
    grid-column: 2;
    grid-row: 2;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 0.82rem;
    color: var(--text-muted);
    font-weight: 300;
    line-height: 1.2;
}

/* Column 3 — rating right-aligned */
.logbook.compact .log-rating {
    grid-column: 3;
    grid-row: 1 / 3;
    font-family: var(--font-mono);
    font-size: 0.88rem;
    color: var(--accent);
    font-variant-numeric: tabular-nums;
    margin: 0;
    align-self: center;
    white-space: nowrap;
}
.logbook.compact .log-rating .rating-max {
    color: var(--text-quiet);
    font-size: 0.66rem;
}

@media (max-width: 600px) {
    .logbook.compact .log-entry {
        grid-template-columns: 4.25rem 1fr auto;
        column-gap: 0.65rem;
        padding: 0.6rem 0.15rem;
    }
    .logbook.compact .log-meta { font-size: 0.62rem; }
    .logbook.compact .log-meta .log-type { font-size: 0.56rem; }
    .logbook.compact .log-title { font-size: 0.95rem; }
    .logbook.compact .log-creator { font-size: 0.78rem; }
    .logbook.compact .log-rating { font-size: 0.82rem; }
}

.raw-links {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    color: var(--text-quiet);
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    margin: 0.5rem 0 3rem;
}
.raw-links a {
    color: var(--text-muted);
    border: 0;
}
.raw-links a:hover { color: var(--accent); }

/* ============================================================
   Entry detail
   ============================================================ */

.entry { padding: 1rem 0 0; }

.entry-head {
    padding-bottom: 2rem;
    margin-bottom: 1rem;
    position: relative;
}
.entry-head::after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 48px;
    height: 2px;
    background: var(--accent);
}

.entry-kicker {
    font-family: var(--font-mono);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
}
.entry-kicker-type {
    color: var(--accent);
    font-weight: 500;
}
.entry-kicker .dot { color: var(--text-quiet); }

.entry-status {
    padding: 0.12rem 0.45rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: var(--surface-2);
    color: var(--text-dim);
    font-size: 0.64rem;
    letter-spacing: 0.14em;
}
.entry-status-doing { color: var(--accent); border-color: var(--accent-line); }
.entry-status-want  { color: var(--text-dim); }
.entry-status-abandoned { color: var(--text-quiet); text-decoration: line-through; }

.entry-title {
    font-family: var(--font-serif);
    font-size: clamp(2.1rem, 5vw, 3.2rem);
    font-weight: 300;
    font-variation-settings: 'opsz' 144;
    line-height: 1.08;
    letter-spacing: -0.02em;
    color: var(--text);
    margin: 0 0 0.75rem;
    overflow-wrap: anywhere;
}

.entry-creator {
    font-family: var(--font-serif);
    font-style: italic;
    font-weight: 300;
    font-size: 1.2rem;
    color: var(--text-muted);
    margin-bottom: 1.5rem;
}

.entry-rating {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-top: 1.25rem;
}
.rating-dots {
    display: inline-flex;
    gap: 5px;
}
.rating-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--surface-2);
    border: 1px solid var(--border);
}
.rating-dot.filled {
    background: var(--accent);
    border-color: var(--accent);
}
.rating-num {
    font-family: var(--font-serif);
    font-size: 1.4rem;
    font-weight: 400;
    font-variant-numeric: tabular-nums;
    color: var(--accent);
    line-height: 1;
    letter-spacing: -0.01em;
}
.rating-num .m { color: var(--text-quiet); font-size: 0.8rem; margin-left: 0.05rem; font-weight: 300; }

/* entry hero: metadata panel left, smaller poster right */
.entry-hero {
    display: grid;
    grid-template-columns: 1fr 140px;
    gap: 2.5rem;
    align-items: start;
    margin-bottom: 2.5rem;
}
.entry-hero.no-poster { grid-template-columns: 1fr; }
.entry-hero.no-meta   { grid-template-columns: 140px; justify-content: end; }

.entry-meta {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.entry-meta-row {
    display: grid;
    grid-template-columns: 105px 1fr;
    gap: 1rem;
    padding: 0.6rem 0;
    border-bottom: 1px solid var(--border);
}
.entry-meta-row:first-child { border-top: 1px solid var(--border); }
.entry-meta-row dt {
    font-family: var(--font-sans);
    font-size: 0.64rem;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin: 0;
    padding-top: 0.1rem;
    align-self: start;
}
.entry-meta-row dd {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 0.98rem;
    color: var(--text);
    line-height: 1.45;
    font-weight: 400;
    overflow-wrap: anywhere;
}

.entry-poster {
    width: 140px;
    justify-self: end;
}
.entry-poster img {
    width: 100%;
    border-radius: 2px;
    display: block;
    border: 1px solid var(--border);
    box-shadow: 0 10px 28px rgba(0,0,0,0.45);
    cursor: zoom-in;
    transition: transform 0.15s, box-shadow 0.15s;
}
.entry-poster img:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 36px rgba(0,0,0,0.55);
}

/* Lightbox — full-size poster overlay */
.lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.92);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
    cursor: zoom-out;
    opacity: 0;
    transition: opacity 0.2s ease;
    padding: 2rem;
}
.lightbox.open { opacity: 1; }
.lightbox img {
    max-width: 100%;
    max-height: 100%;
    border-radius: 3px;
    box-shadow: 0 20px 70px rgba(0,0,0,0.9);
    transform: scale(0.96);
    transition: transform 0.22s cubic-bezier(.22,.9,.33,1);
}
.lightbox.open img { transform: scale(1); }

.entry-prose { min-width: 0; margin-bottom: 3rem; }

/* parent back-link on child entries (notes referring to their parent) */
.parent-link {
    font-family: var(--font-serif);
    font-style: italic;
    font-weight: 300;
    font-size: 1rem;
    color: var(--text-muted);
    margin-top: 0.5rem;
}
.parent-link a {
    color: var(--text);
    border-bottom: 1px solid var(--border-2);
    font-style: italic;
    font-weight: 400;
}
.parent-link a:hover { color: var(--accent-hot); border-bottom-color: var(--accent-line); }
.parent-link .parent-type {
    display: inline-block;
    font-family: var(--font-mono);
    font-style: normal;
    font-size: 0.65rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent);
    margin-left: 0.45rem;
    padding: 0.1rem 0.4rem;
    border: 1px solid var(--accent-line);
    border-radius: 3px;
    vertical-align: 1px;
}

/* child notes/entries attached to a parent */
.children {
    margin: 0.5rem 0 3rem;
}
.children h3 {
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--accent);
    margin: 0 0 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}
.children h3::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border);
}
.children-list {
    display: flex;
    flex-direction: column;
}
.child-note {
    display: block;
    padding: 1.1rem 0.25rem;
    border-top: 1px solid var(--border);
    border-left: 0 !important;
    border-bottom: 0 !important;
    text-decoration: none !important;
    color: inherit !important;
    transition: background 0.15s, padding 0.15s;
}
.child-note:last-child { border-bottom: 1px solid var(--border) !important; }
.child-note:hover {
    background: linear-gradient(to right, var(--accent-soft), transparent 70%);
    padding-left: 0.7rem;
}
.child-meta {
    font-family: var(--font-mono);
    font-size: 0.66rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--text-muted);
    display: flex;
    gap: 0.55rem;
    align-items: center;
    margin-bottom: 0.45rem;
}
.child-type { color: var(--accent); }
.child-meta .dot { color: var(--text-quiet); }
.child-body {
    font-family: var(--font-serif);
    font-size: 1rem;
    line-height: 1.55;
    color: var(--text-dim);
    font-weight: 300;
    overflow-wrap: anywhere;
}
.child-note:hover .child-body { color: var(--text); }

/* --- Seasons block (show-detail page) ------------------------------ */
.seasons { margin-bottom: 2rem; }

.season-block {
    border-top: 1px solid var(--border);
    padding: 1rem 0 1.1rem;
}
.seasons .season-block:last-child { border-bottom: 1px solid var(--border); }

.season-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    text-decoration: none !important;
    color: inherit !important;
    border-bottom: 0 !important;
}
.season-head-main {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    min-width: 0;
}
.season-title {
    font-family: var(--font-serif);
    font-size: 1.15rem;
    font-weight: 500;
    color: var(--text);
    letter-spacing: -0.005em;
}
.season-head:hover .season-title { color: var(--accent-hot); }

.season-meta {
    font-family: var(--font-mono);
    font-size: 0.66rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.season-meta .dot { color: var(--text-quiet); }
.season-meta time { color: var(--text-quiet); }

.season-rating {
    font-family: var(--font-serif);
    font-size: 1.1rem;
    font-weight: 400;
    color: var(--accent);
    flex-shrink: 0;
    padding-top: 0.15rem;
    font-variant-numeric: tabular-nums;
}
.season-rating .m { color: var(--text-quiet); font-size: 0.7rem; }

.season-review {
    font-family: var(--font-serif);
    font-size: 0.92rem;
    color: var(--text-dim);
    line-height: 1.55;
    margin: 0.55rem 0 0.75rem;
    font-weight: 300;
    max-width: 62ch;
}

.season-episodes {
    list-style: none;
    margin: 0.5rem 0 0;
    padding: 0;
    counter-reset: ep;
}
.season-episodes li {
    counter-increment: ep;
}
.season-episodes a {
    display: grid;
    grid-template-columns: 1.75rem 1fr auto;
    gap: 0.6rem;
    align-items: baseline;
    padding: 0.45rem 0.1rem;
    color: var(--text-dim);
    border: 0 !important;
    text-decoration: none !important;
    border-top: 1px dashed var(--border) !important;
    transition: color 0.15s, padding 0.15s, background 0.15s;
}
.season-episodes a::before {
    content: counter(ep, decimal-leading-zero);
    font-family: var(--font-mono);
    font-size: 0.66rem;
    color: var(--text-quiet);
    letter-spacing: 0.05em;
}
.season-episodes a:hover {
    color: var(--accent-hot);
    background: linear-gradient(to right, var(--accent-soft), transparent 70%);
    padding-left: 0.4rem;
}
.ep-title {
    font-family: var(--font-serif);
    font-size: 0.95rem;
    color: var(--text);
}
.season-episodes a:hover .ep-title { color: var(--accent-hot); }
.ep-meta {
    font-family: var(--font-mono);
    font-size: 0.66rem;
    color: var(--text-quiet);
    letter-spacing: 0.06em;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    white-space: nowrap;
}
.ep-rating { color: var(--accent); }

/* prose-type entry (notes) */
.entry-prose-type .entry-head { border-bottom: none; padding-bottom: 0.5rem; margin-bottom: 1.5rem; }
.entry-prose-type .entry-kicker { margin-bottom: 0; }

.note-body {
    padding: 2rem 0 3rem;
    max-width: 62ch;
}
.prose-lg {
    font-family: var(--font-serif);
    font-size: 1.25rem;
    line-height: 1.6;
    color: var(--text);
    font-weight: 300;
    letter-spacing: -0.005em;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}
.note-attribution {
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 0.95rem;
    color: var(--text-muted);
    margin-top: 1.5rem;
}
.tag-strip-inline { margin-top: 1.5rem; }

.prose-section { margin-bottom: 2.25rem; }

.prose-section h3 {
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--accent);
    margin: 0 0 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
}
.prose-section h3::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border);
}

.prose {
    font-family: var(--font-serif);
    font-size: 1.05rem;
    line-height: 1.65;
    color: var(--text-dim);
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.tag-strip { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.tag-pill {
    padding: 0.22rem 0.6rem;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 3px;
    font-family: var(--font-mono);
    font-size: 0.72rem;
    color: var(--text-dim) !important;
    text-decoration: none !important;
    border-bottom: 1px solid var(--border) !important;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.tag-pill:hover {
    color: var(--accent-hot) !important;
    border-color: var(--accent-line) !important;
    background: var(--accent-soft);
}

.related-list { list-style: none; margin: 0; padding: 0; }
.related-list li { border-top: 1px solid var(--border); }
.related-list li:last-child { border-bottom: 1px solid var(--border); }
.related-list a {
    display: flex;
    gap: 0.75rem;
    align-items: baseline;
    padding: 0.75rem 0.25rem;
    color: var(--text);
    border: 0;
    transition: background 0.15s, padding 0.15s;
}
.related-list a:hover {
    background: linear-gradient(to right, var(--accent-soft), transparent 70%);
    padding-left: 0.6rem;
}
.rel-type {
    font-family: var(--font-mono);
    font-size: 0.66rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent);
    flex-shrink: 0;
    min-width: 60px;
}
.rel-title { font-family: var(--font-serif); }
.rel-kind { font-family: var(--font-mono); font-size: 0.72rem; color: var(--text-quiet); }

.entry-foot {
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--border);
    display: grid;
    gap: 2rem;
}

.entry-facts {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0.75rem 1.75rem;
    margin: 0;
    font-size: 0.9rem;
    -webkit-user-modify: read-only;
    -webkit-touch-callout: none;
}
.entry-facts dt {
    font-family: var(--font-sans);
    color: var(--text-muted);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 600;
    padding-top: 0.25rem;
}
.entry-facts dd {
    font-family: var(--font-mono);
    color: var(--text);
    margin: 0;
    font-variant-numeric: tabular-nums;
    overflow-wrap: anywhere;
    font-size: 0.82rem;
}
.entry-facts dd a { color: var(--accent); border: 0; }
.entry-facts dd a:hover { color: var(--accent-hot); border-bottom: 1px solid var(--accent-line); }

.events h3 {
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin: 0 0 0.75rem;
}

.event-log {
    list-style: none;
    margin: 0;
    padding: 0;
    border-left: 1px solid var(--border);
}
.event-log li {
    display: flex;
    gap: 1rem;
    padding: 0.4rem 0 0.4rem 1rem;
    font-family: var(--font-mono);
    font-size: 0.78rem;
    color: var(--text-muted);
    position: relative;
}
.event-log li::before {
    content: '';
    position: absolute;
    left: -3.5px;
    top: 0.85rem;
    width: 6px;
    height: 6px;
    background: var(--accent);
    border-radius: 50%;
}
.event-log .ev-time { color: var(--text-quiet); font-variant-numeric: tabular-nums; }
.event-log .ev-type { color: var(--text-dim); }

.entry-raw {
    font-family: var(--font-mono);
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    color: var(--text-quiet);
    display: flex;
    gap: 0.9rem;
    margin: 0;
    flex-wrap: wrap;
    align-items: center;
}
.entry-raw-meta {
    color: var(--text-quiet);
    flex: 1 1 auto;
    min-width: 0;
}
.entry-raw a { color: var(--text-muted); border: 0; }
.entry-raw a:hover { color: var(--accent); }

/* mobile ----------------------------------------------------- */
@media (max-width: 600px) {
    :root { --pad-x: 1rem; }
    header { padding-top: 1.5rem; }
    section.content { padding: 1.25rem 0 3rem; }
    h1 { font-size: 2.1rem; }
    .hero { padding: 1.5rem 0 1.25rem; margin-bottom: 1.5rem; }
    .hero h1 { font-size: 2.1rem; }
    .directory-row { grid-template-columns: 2.5rem 1fr auto; gap: 0.75rem; padding: 0.9rem 0.2rem; }
    .directory-row .label { font-size: 1.05rem; }
    .directory-row .meta { font-size: 0.68rem; }
    .log-entry { grid-template-columns: 60px 1fr; gap: 0.85rem; padding: 1rem 0.1rem; }
    .log-poster { width: 60px; height: 90px; }
    .log-title { font-size: 1.05rem; }
    .log-creator { font-size: 0.85rem; }
    .log-excerpt { font-size: 0.85rem; }
    .type-nav .chip { font-size: 0.66rem; padding: 0.32rem 0.65rem; }

    /* entry detail */
    .entry-hero {
        grid-template-columns: 1fr 110px;
        gap: 1.25rem;
    }
    .entry-hero.no-meta { grid-template-columns: 110px; justify-content: center; }
    .entry-poster { width: 110px; }
    .entry-title { font-size: 1.9rem; }
    .entry-creator { font-size: 1.02rem; }
    .prose { font-size: 0.98rem; }
    .entry-meta-row {
        grid-template-columns: 1fr;
        gap: 0.2rem;
        padding: 0.55rem 0;
    }
    .entry-meta-row dt { font-size: 0.6rem; }
    .entry-meta-row dd { font-size: 0.92rem; }
    .entry-facts { grid-template-columns: 1fr; gap: 0.15rem 0; }
    .entry-facts dt { padding-top: 0.6rem; }
    .entry-facts dt:first-child { padding-top: 0; }

    /* Datasette table: stack on mobile (definition-list style) */
    .rows-and-columns { border: 0; background: transparent; }
    .rows-and-columns thead { display: none; }
    .rows-and-columns tbody tr {
        display: block;
        margin: 0 0 1rem;
        padding: 0.8rem;
        border: 1px solid var(--border);
        border-radius: 6px;
        background: var(--surface);
    }
    .rows-and-columns tbody tr:hover { background: var(--surface-2); }
    .rows-and-columns tbody td {
        display: block;
        padding: 0.35rem 0;
        border: 0;
        font-size: 0.82rem;
    }
    /* Datasette injects per-column `content:` via nth-of-type. We style it. */
    .rows-and-columns tbody td::before {
        font-family: var(--font-sans);
        font-size: 0.62rem;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        color: var(--text-muted);
        display: block;
        margin-bottom: 0.15rem;
        font-weight: 600;
    }
}
