:root {
  --bg: #fffdf7;
  --paper: #ffffff;
  --paper-2: #fdf6e6;
  --ink: #2b2620;
  --ink-soft: #6b6357;
  --ink-fade: #a89f8d;
  --line: #ecd9b0;
  --line-strong: #d9c089;

  /* rainbow palette */
  --rose: #e0625a;
  --rose-soft: #fbe0d8;
  --sun: #e8a93b;
  --sun-soft: #fbeac8;
  --moss: #7fa04a;
  --moss-soft: #e4eecf;
  --sky: #5994b5;
  --sky-soft: #d6e6ee;
  --plum: #a05ea0;
  --plum-soft: #ebd9eb;
  --teal: #4fa893;
  --teal-soft: #d4ecdf;

  --posted: #5d8a3a;
  --drafting: #c98b1e;
  --pending: #d76040;
  --queued: #8b8270;

  --shadow: 0 2px 0 rgba(43, 38, 32, 0.04), 0 12px 36px -20px rgba(43, 38, 32, 0.25);
  --radius: 14px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: "Inter Tight", system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  background-image:
    radial-gradient(circle at 10% 0%, rgba(224, 98, 90, 0.04), transparent 50%),
    radial-gradient(circle at 90% 8%, rgba(232, 169, 59, 0.04), transparent 50%),
    radial-gradient(circle at 95% 95%, rgba(127, 160, 74, 0.035), transparent 50%),
    radial-gradient(circle at 5% 90%, rgba(160, 94, 160, 0.035), transparent 50%);
  min-height: 100vh;
}
a { color: var(--rose); text-decoration: none; border-bottom: 1px dotted currentColor; }
a:hover { color: var(--plum); }
code { background: var(--paper); padding: 1px 6px; border-radius: 5px; font-size: 0.92em; border: 1px solid var(--line); }

.app { max-width: 1240px; margin: 0 auto; padding: 56px 32px 80px; }

/* HERO */
.hero { max-width: 760px; margin-bottom: 56px; }
.hero-mini { display: flex; align-items: baseline; justify-content: space-between; gap: 18px; flex-wrap: wrap; margin-bottom: 36px; }
.hero-mini .title { margin: 0; font-size: clamp(34px, 5vw, 52px); }
.hero-nav { display: inline-flex; gap: 6px; }
.pill-link {
  font-family: "JetBrains Mono", monospace; font-size: 12px;
  color: var(--ink-soft); background: var(--paper);
  border: 1px solid var(--line); padding: 6px 12px; border-radius: 999px;
  text-decoration: none; transition: color .15s, border-color .15s, background .15s;
}
.pill-link:hover { color: var(--rose); border-color: var(--rose); background: var(--paper-2); }
.about-link {
  font-family: "JetBrains Mono", monospace; font-size: 12px;
  color: var(--ink-soft); background: var(--paper);
  border: 1px solid var(--line); padding: 6px 12px; border-radius: 999px;
  border-bottom-style: solid;
}
.about-link:hover { color: var(--rose); border-color: var(--rose); }
.kicker {
  display: inline-block;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; letter-spacing: 0.12em; text-transform: lowercase;
  color: var(--ink-soft);
  background: var(--paper);
  border: 1px dashed var(--line-strong);
  padding: 5px 12px; border-radius: 999px;
  margin-bottom: 16px;
}
.hero .title {
  font-family: "Fraunces", serif; font-weight: 500;
  font-size: clamp(40px, 6vw, 64px); line-height: 1.02;
  letter-spacing: -0.02em; margin: 0 0 14px;
  color: var(--ink);
}
.hero .lede { font-size: 17px; color: var(--ink-soft); margin: 0 0 22px; max-width: 640px; }
.hero .lede code { background: var(--paper-2); }

.meta-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.chip {
  display: inline-flex; gap: 6px; align-items: center;
  background: var(--paper);
  border: 1px solid var(--line);
  padding: 6px 11px; border-radius: 999px;
  font-size: 12px; color: var(--ink-soft);
  font-family: "JetBrains Mono", monospace; letter-spacing: -0.01em;
}
.chip em { color: var(--ink); font-style: normal; font-weight: 500; }
.chip.c-rose { background: var(--rose-soft); border-color: var(--rose); color: var(--rose); }
.chip.c-rose em { color: var(--rose); }
.chip.c-plum { background: var(--plum-soft); border-color: var(--plum); color: var(--plum); }
.chip.c-plum em { color: var(--plum); }
.chip.c-sky  { background: var(--sky-soft);  border-color: var(--sky);  color: var(--sky); }
.chip.c-sky em { color: var(--sky); }
.chip.c-moss { background: var(--moss-soft); border-color: var(--moss); color: var(--moss); }
.chip.c-moss em { color: var(--moss); }
.chip.c-sun  { background: var(--sun-soft);  border-color: var(--sun);  color: var(--sun); }

.ghost-btn {
  background: transparent; border: 1px solid var(--line);
  border-radius: 999px; padding: 5px 12px; font-size: 12px;
  color: var(--ink-soft); cursor: pointer; font-family: inherit;
  display: inline-flex; align-items: center; gap: 6px;
}
.ghost-btn:hover { border-color: var(--ink-soft); color: var(--ink); }

/* BLOCKS */
.block { margin-bottom: 64px; }
.block-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 16px; margin-bottom: 18px;
}
.block-title { display: flex; gap: 14px; align-items: center; }
.block-title .glyph {
  font-size: 28px; line-height: 1;
  width: 44px; height: 44px; display: grid; place-items: center;
  background: var(--paper);
  border-radius: 50%;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.block-title h2 {
  margin: 0; font-family: "Fraunces", serif; font-weight: 500;
  font-size: 28px; letter-spacing: -0.01em; line-height: 1;
}
.block-title .subtitle {
  display: block; color: var(--ink-soft); font-size: 13px; margin-top: 4px;
}

/* MONTH */
.month-nav { display: flex; gap: 6px; align-items: center; }
.nav-btn {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 999px; padding: 6px 14px; font: inherit; font-size: 13px;
  color: var(--ink); cursor: pointer;
  font-family: "JetBrains Mono", monospace;
}
.nav-btn:hover { border-color: var(--rose); color: var(--rose); }
.nav-btn.ghost { background: transparent; }
.toggle {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--ink-soft); cursor: pointer;
  margin-left: 8px;
  font-family: "JetBrains Mono", monospace;
}
.toggle input { accent-color: var(--rose); }

.grid {
  display: grid; grid-template-columns: repeat(7, minmax(0, 1fr));
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.grid.no-weekends { grid-template-columns: repeat(5, minmax(0, 1fr)); }

.dow {
  background: var(--paper-2);
  padding: 9px 12px;
  border-right: 1px solid var(--line); border-bottom: 1px solid var(--line);
  font-size: 11px; font-family: "JetBrains Mono", monospace;
  color: var(--ink-soft); text-transform: lowercase; letter-spacing: 0.08em;
}
.dow:last-child, .grid > .cell:nth-child(7n+8) { /* no-op safe */ }
.cell {
  background: var(--paper);
  border-right: 1px solid var(--line); border-bottom: 1px solid var(--line);
  padding: 10px 10px 12px; min-height: 138px;
  display: flex; flex-direction: column; gap: 6px;
  position: relative;
  transition: background .15s ease;
}
.cell.other-month { background: var(--paper-2); }
.cell.past { opacity: 0.55; }
.add-slot {
  margin-top: auto; align-self: stretch;
  background: transparent; border: 1px dashed var(--line);
  color: var(--ink-fade); border-radius: 8px;
  padding: 6px 8px; font: 11px "JetBrains Mono", monospace;
  cursor: pointer; opacity: 0; transition: opacity .15s ease, color .15s ease, border-color .15s ease;
}
.cell.open-slot:hover .add-slot { opacity: 1; }
.add-slot:hover { color: var(--rose); border-color: var(--rose); }
.add-form { display: grid; gap: 12px; margin-top: 14px; }
.add-form label { display: grid; gap: 5px; font-size: 12px; color: var(--ink-fade); font-family: "JetBrains Mono", monospace; text-transform: lowercase; }
.add-form select, .add-form textarea {
  font: 14px "Inter Tight", sans-serif; color: var(--ink);
  background: var(--paper); border: 1px solid var(--line); border-radius: 8px;
  padding: 8px 10px; resize: vertical;
}
.add-form select:focus, .add-form textarea:focus, .add-form input:focus { outline: 2px solid var(--rose); outline-offset: 1px; border-color: transparent; }
.add-form input[type="url"], .add-form input[type="number"] {
  font: 14px "Inter Tight", sans-serif; color: var(--ink);
  background: var(--paper); border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px;
}
.draft-area {
  width: 100%; min-height: 160px; resize: vertical; box-sizing: border-box;
  font: 14px/1.55 "Inter Tight", sans-serif; color: var(--ink);
  background: var(--paper); border: 1px solid var(--line); border-radius: 10px;
  padding: 12px 14px; margin-top: 8px;
}
.draft-area:focus { outline: 2px solid var(--rose); outline-offset: 1px; border-color: transparent; }
.metric-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin: 6px 0; }
.mcell { background: var(--paper-2); border: 1px solid var(--line); border-radius: 10px; padding: 8px 10px; display: grid; gap: 2px; }
.mlabel { font: 10.5px "JetBrains Mono", monospace; color: var(--ink-fade); text-transform: lowercase; letter-spacing: 0.05em; }
.mval { font: 500 18px "Fraunces", serif; color: var(--ink); }
.msub { font: 10px "JetBrains Mono", monospace; color: var(--ink-fade); }
.mcell input { font: 500 18px "Fraunces", serif; color: var(--ink); background: transparent; border: none; padding: 0; width: 100%; }
.mcell input:focus { outline: 1px dashed var(--rose); outline-offset: 2px; }
.metrics { display: inline-flex; gap: 6px; flex-wrap: wrap; }
.metrics .metric { font: 10.5px "JetBrains Mono", monospace; color: var(--ink-fade); }
.metrics .metric.x { color: var(--sky); }
.metrics .metric.li { color: var(--moss); }
.metrics .empty { font: 10px "JetBrains Mono", monospace; color: var(--ink-fade); opacity: 0.6; font-style: italic; }
.analytics-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width: 720px) { .analytics-grid { grid-template-columns: 1fr; } .metric-grid { grid-template-columns: repeat(2,1fr); } }
.ablock-h { font-family: "JetBrains Mono", monospace; font-size: 11px; color: var(--ink-fade); text-transform: lowercase; letter-spacing: 0.06em; margin-bottom: 10px; }
.arow { display: flex; justify-content: space-between; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px dashed var(--line); }
.arow:last-child { border-bottom: none; }
.arow-l { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink); flex: 1; min-width: 0; }
.arow-l.top { flex-direction: column; align-items: flex-start; gap: 3px; }
.arow-l .atopic { font-size: 13px; color: var(--ink-soft); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; width: 100%; }
.adot { width: 8px; height: 8px; border-radius: 999px; background: var(--c); }
.arow-r { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.abadge { font: 10.5px "JetBrains Mono", monospace; color: var(--ink-fade); border: 1px solid var(--line); padding: 2px 7px; border-radius: 999px; background: var(--paper); }
.abadge.x { color: var(--sky); border-color: var(--sky-soft); }
.abadge.li { color: var(--moss); border-color: var(--moss-soft); }
.apatterns { margin-top: 14px; font-size: 13px; line-height: 1.55; color: var(--ink-soft); background: var(--paper-2); padding: 10px 14px; border-radius: 10px; border-left: 3px solid var(--sun); }
.apatterns.muted { color: var(--ink-fade); border-left-color: var(--line); font-style: italic; }
.add-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 4px; }
.btn-primary, .btn-secondary {
  font: 13px "Inter Tight", sans-serif; padding: 8px 14px; border-radius: 999px; cursor: pointer; border: 1px solid var(--line);
}
.btn-primary { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.btn-secondary { background: transparent; color: var(--ink-fade); }
.btn-primary:hover { background: var(--rose); border-color: var(--rose); }
.btn-secondary:hover { color: var(--ink); }
.cell.past .post { background: var(--paper-2); }
.cell.weekend { background: #fdf8ec; }
.cell.today { background: linear-gradient(180deg, #fffaef 0%, #fff5d6 100%); }
.cell.today .date-num span:first-child { color: var(--rose); font-weight: 600; }
.cell.today::after {
  content:""; position: absolute; inset: 4px; pointer-events: none;
  border: 2px dashed var(--rose); border-radius: 10px; opacity: 0.55;
}
.date-num {
  font-family: "Fraunces", serif; font-size: 17px; font-weight: 500;
  color: var(--ink); line-height: 1;
  display: flex; justify-content: space-between; align-items: center;
}
.date-num .dom { color: var(--ink-fade); font-family: "JetBrains Mono", monospace; font-size: 10px; text-transform: lowercase; }
.cell.other-month .date-num span:first-child { color: var(--ink-fade); }
.cell .empty-hint {
  font-size: 11px; color: var(--ink-fade); font-style: italic;
  margin-top: auto; font-family: "JetBrains Mono", monospace;
}
.cell .empty-hint.off { color: var(--ink-fade); opacity: 0.6; }

.post {
  --c: var(--ink-fade);
  background: white;
  border: 1px solid var(--line);
  border-left: 4px solid var(--c);
  border-radius: 10px;
  padding: 8px 10px 9px;
  font-size: 12px;
  line-height: 1.4;
  cursor: grab;
  position: relative;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.post:active { cursor: grabbing; }
.post.dragging { opacity: 0.4; }
.post * { pointer-events: none; }
.post:hover {
  transform: translateY(-1px) rotate(-0.4deg);
  box-shadow: var(--shadow);
  border-color: var(--c);
}
.post .pcat {
  font-family: "JetBrains Mono", monospace;
  font-size: 9.5px; letter-spacing: 0.08em; text-transform: lowercase;
  color: var(--c); margin-bottom: 3px; font-weight: 500;
}
.post .ptitle { color: var(--ink); font-weight: 500; }
.post .pmeta { display: flex; gap: 5px; margin-top: 5px; align-items: center; flex-wrap: wrap; }

.badge {
  display: inline-block; font-size: 9.5px; letter-spacing: 0.05em;
  font-family: "JetBrains Mono", monospace; padding: 1.5px 7px;
  border-radius: 999px; border: 1px solid; text-transform: lowercase;
  font-weight: 500;
}
.badge.posted   { color: var(--posted);   border-color: var(--posted);   background: rgba(93, 138, 58, 0.1); }
.badge.drafting { color: var(--drafting); border-color: var(--drafting); background: rgba(201, 139, 30, 0.1); }
.badge.pending  { color: var(--pending);  border-color: var(--pending);  background: rgba(215, 96, 64, 0.1); }
.badge.queued   { color: var(--queued);   border-color: var(--line-strong); background: var(--paper); }
.badge.article  { color: var(--plum);     border-color: var(--plum);     background: var(--plum-soft); }
.badge.bridge   { color: var(--sky);      border-color: var(--sky);      background: var(--sky-soft); }

.legend-row {
  margin: 12px 4px 0; color: var(--ink-fade); font-size: 12px;
  display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
  font-family: "JetBrains Mono", monospace;
}
.legend-dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: var(--c); margin-right: 4px; vertical-align: middle;
}

/* LISTS */
.card-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; }
.card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 6px;
  box-shadow: var(--shadow);
  position: relative;
  overflow: hidden;
}
.card::before {
  content:""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: var(--accent, var(--rose));
}
.card .cdate {
  font-family: "JetBrains Mono", monospace; font-size: 11px;
  color: var(--ink-soft); letter-spacing: 0.04em;
}
.card .ctitle { font-weight: 500; color: var(--ink); font-size: 15px; line-height: 1.35; }
.card .crow { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 4px; }

.idea-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
.idea {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--shadow);
  position: relative;
}
.idea .icat {
  font-family: "JetBrains Mono", monospace; font-size: 10px;
  letter-spacing: 0.08em; text-transform: lowercase; font-weight: 500;
  margin-bottom: 6px;
  display: inline-block;
  padding: 2px 8px; border-radius: 999px;
  background: var(--accent-soft, var(--paper-2));
  color: var(--accent, var(--ink-soft));
}
.idea h4 {
  margin: 0 0 4px; font-family: "Fraunces", serif; font-weight: 500;
  font-size: 17px; letter-spacing: -0.005em;
}
.idea p { margin: 6px 0 0; font-size: 13px; color: var(--ink-soft); line-height: 1.5; }

.ideas-details > summary {
  list-style: none; cursor: pointer; user-select: none;
  display: block; padding: 4px 0;
}
.ideas-details > summary::-webkit-details-marker { display: none; }
.ideas-details .chev {
  display: inline-block; transition: transform .2s ease;
  color: var(--ink-fade); font-weight: 400; margin-left: 4px;
}
.ideas-details[open] .chev { transform: rotate(90deg); }
.ideas-details > summary:hover h2 { color: var(--rose); }

.perf-list { display: grid; gap: 12px; }
.perf {
  background: var(--paper);
  border: 1px solid var(--line);
  border-left: 4px solid var(--sun);
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 13.5px; color: var(--ink-soft);
  line-height: 1.55;
  box-shadow: var(--shadow);
}
.perf strong { color: var(--ink); }
.perf .pdate {
  font-family: "JetBrains Mono", monospace; font-size: 11px;
  color: var(--sun); display: block; margin-bottom: 6px;
  letter-spacing: 0.04em;
}

.footer {
  margin-top: 60px; padding-top: 20px;
  border-top: 1px dashed var(--line-strong);
  color: var(--ink-fade); font-size: 12px; text-align: center;
  font-family: "JetBrains Mono", monospace;
}
.footer code { background: var(--paper); }

/* DIALOG */
.dialog {
  border: none; padding: 0; border-radius: 18px;
  background: var(--paper); color: var(--ink);
  max-width: 620px; width: 92%;
  box-shadow: 0 30px 80px -20px rgba(43, 38, 32, 0.4);
  border-top: 6px solid var(--rose);
}
.dialog::backdrop { background: rgba(43, 38, 32, 0.35); backdrop-filter: blur(3px); }
.dialog article { padding: 28px 30px 12px; }
.dialog h2 {
  margin: 0 0 6px; font-family: "Fraunces", serif; font-weight: 500;
  font-size: 26px; letter-spacing: -0.01em;
}
.dialog .dmeta { color: var(--ink-soft); font-size: 12px; font-family: "JetBrains Mono", monospace; margin-bottom: 16px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.dialog .dbody { font-size: 14px; line-height: 1.6; color: var(--ink); white-space: pre-wrap; background: var(--paper-2); padding: 14px 16px; border-radius: 10px; border: 1px solid var(--line); }
.dialog .dlabel {
  font-family: "JetBrains Mono", monospace; font-size: 10px;
  color: var(--ink-fade); letter-spacing: 0.1em; text-transform: lowercase;
  margin: 16px 0 6px;
}
.dialog form { padding: 0 30px 24px; display: flex; justify-content: flex-end; }
.dialog .close-btn { font-size: 12px; }

.cell.drop-hover {
  background: linear-gradient(135deg, var(--sun-soft), var(--rose-soft)) !important;
  box-shadow: inset 0 0 0 2px var(--rose);
}

@media (max-width: 820px) {
  .app { padding: 32px 16px 60px; }
  .grid, .grid.no-weekends { grid-template-columns: repeat(7, minmax(0, 1fr)); }
  .cell { min-height: 92px; padding: 6px 6px 8px; }
  .post { font-size: 11px; padding: 6px 8px; border-left-width: 3px; }
  .date-num { font-size: 14px; }
  .block-title .glyph { width: 36px; height: 36px; font-size: 22px; }
  .block-title h2 { font-size: 22px; }
}

/* ============ view switch (month/list) ============ */
.view-switch { display: inline-flex; border: 1px solid var(--line); border-radius: 999px; overflow: hidden; margin-left: 6px; background: var(--paper); }
.view-btn {
  font: 11px "JetBrains Mono", monospace; color: var(--ink-fade); background: transparent;
  border: none; padding: 6px 11px; cursor: pointer; text-transform: lowercase;
}
.view-btn[aria-pressed="true"] { background: var(--ink); color: var(--paper); }
.view-btn + .view-btn { border-left: 1px solid var(--line); }

/* ============ list (calendar) view ============ */
.cal-list { display: grid; gap: 18px; }
.cal-week { background: var(--paper); border: 1px solid var(--line); border-radius: 14px; padding: 6px 0; }
.cal-week-h {
  font: 11px "JetBrains Mono", monospace; color: var(--ink-fade); text-transform: lowercase;
  padding: 10px 16px 6px; letter-spacing: 0.04em; border-bottom: 1px dashed var(--line); margin-bottom: 4px;
}
.cal-day {
  display: flex; gap: 12px; padding: 10px 16px; border-bottom: 1px solid var(--line);
}
.cal-day:last-child { border-bottom: none; }
.cal-day.is-today { background: linear-gradient(180deg, #fffaef 0%, #fff5d6 100%); }
.cal-day.is-past .cd-meta { opacity: 0.55; }
.cd-date {
  display: flex; flex-direction: column; align-items: center; justify-content: flex-start; gap: 0;
  min-width: 44px; padding-top: 2px;
}
.cd-date .cd-d { font: 500 22px/1 "Fraunces", serif; color: var(--ink); }
.cd-date .cd-dow { font: 10px "JetBrains Mono", monospace; color: var(--ink-fade); text-transform: lowercase; margin-top: 2px; }
.cd-day.is-today .cd-d { color: var(--rose); }
.cd-meta { flex: 1; display: grid; gap: 6px; }
.cd-empty { font: 11px "JetBrains Mono", monospace; color: var(--ink-fade); padding: 6px 0; font-style: italic; }
.cd-add {
  font: 11px "JetBrains Mono", monospace; color: var(--ink-fade);
  border: 1px dashed var(--line); border-radius: 8px; padding: 8px 10px; background: transparent; cursor: pointer;
  text-align: left;
}
.cd-add:hover { color: var(--rose); border-color: var(--rose); }

/* ============ mobile bottom nav ============ */
.mobile-nav { display: none; }

/* ============ mobile breakpoints ============ */
@media (max-width: 640px) {
  .app { padding: 20px 14px calc(96px + env(safe-area-inset-bottom)); }
  html { scroll-padding-bottom: 90px; }
  .hero-mini { margin-bottom: 22px; gap: 8px; }
  .hero-mini .title { font-size: 28px; }
  .about-link { font-size: 12px; }
  .pill-link { font-size: 11px; padding: 5px 10px; }

  .block { padding: 16px 14px; border-radius: 14px; margin-bottom: 18px; }
  .block-head { flex-direction: column; align-items: flex-start; gap: 12px; }
  .block-title h2 { font-size: 20px; }
  .block-title .subtitle { font-size: 12px; }
  .month-nav { flex-wrap: wrap; gap: 6px; width: 100%; }
  .month-nav .toggle { margin-left: auto; }
  .nav-btn { font-size: 12px; padding: 6px 10px; }
  .view-switch { margin-left: 0; }

  /* prefer list view on phones */
  .grid { display: none; }
  .cal-list { display: grid; }
  /* and disable the legend row noise */
  .legend-row { font-size: 11px; line-height: 1.7; }

  /* dialogs full-width-ish */
  .dialog { width: calc(100vw - 24px); max-width: 100%; padding: 16px; border-radius: 14px; }
  .dialog h2 { font-size: 19px; }
  .draft-area { font-size: 15px; min-height: 180px; }
  .metric-grid { grid-template-columns: repeat(2, 1fr); }
  .add-form input, .add-form select, .add-form textarea { font-size: 15px; }

  /* hide perf-notes block on mobile to reduce noise; user can scroll */
  /* (leave visible - just compact) */

  .mobile-nav {
    display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 50;
    background: var(--paper); border-top: 1px solid var(--line);
    padding: 8px 6px calc(8px + env(safe-area-inset-bottom));
    justify-content: space-around; gap: 4px;
  }
  .mn-btn {
    flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px;
    text-decoration: none; padding: 6px 4px; border-radius: 10px;
    font: 10.5px "JetBrains Mono", monospace; color: var(--ink-fade); text-transform: lowercase;
    min-height: 44px; justify-content: center;
  }
  .mn-btn .mn-g { font-size: 16px; color: var(--ink-soft); }
  .mn-btn.active { color: var(--rose); background: var(--paper-2); }
  .mn-btn.active .mn-g { color: var(--rose); }

  /* hide drag instructions on mobile */
  .legend-row { display: none; }
}

@media (max-width: 420px) {
  .hero-mini { flex-direction: column; align-items: flex-start; }
}

/* user explicitly switched to month view on mobile - allow horizontal scroll */
.grid.force-month {
  display: grid !important;
  overflow-x: auto; min-width: 720px;
}
.month.month-view .grid { display: grid; }
.month.month-view .cal-list { display: none !important; }
.month.list-view .grid { display: none !important; }
.month.list-view .cal-list { display: grid !important; }

/* "move to" date picker mini-popover inside modal */
.move-row { display: flex; gap: 8px; align-items: center; margin-top: 10px; flex-wrap: wrap; }
.move-row input[type="date"] {
  font: 14px "Inter Tight", sans-serif; color: var(--ink);
  background: var(--paper); border: 1px solid var(--line); border-radius: 8px; padding: 7px 10px;
}

/* ============ analysis section (rewritten "what's landing") ============ */
.alede {
  font: 16px/1.55 "Inter Tight", sans-serif; color: var(--ink-soft);
  margin: 4px 0 22px; max-width: 680px;
}
.atier { margin: 0 0 22px; padding: 14px 16px; border-radius: 14px; border: 1px solid var(--line); background: var(--paper); }
.atier.good { background: linear-gradient(180deg, #fff8ec 0%, #fffdf6 70%); border-color: #f0d9a8; }
.atier.mid  { background: #fbf6ef; }
.atier.flop { background: #fcf2f2; border-color: #f0d2d2; }
.atier-h {
  font: 11px "JetBrains Mono", monospace; color: var(--ink-fade);
  text-transform: lowercase; letter-spacing: 0.05em; margin-bottom: 12px;
  display: flex; align-items: center; gap: 10px;
}
.atier-tag {
  display: inline-block; font: 10.5px "JetBrains Mono", monospace; text-transform: lowercase;
  padding: 3px 9px; border-radius: 999px; background: var(--ink); color: var(--paper);
  letter-spacing: 0.04em;
}
.atier.good .atier-tag { background: var(--rose); }
.atier.mid  .atier-tag { background: var(--ink-soft); }
.atier.flop .atier-tag { background: #b88; }

.aentry { padding: 10px 0; border-top: 1px dashed var(--line); }
.aentry:first-of-type { border-top: none; }
.aentry blockquote {
  margin: 0 0 6px; font: 500 18px/1.5 "Fraunces", serif; color: var(--ink);
  letter-spacing: -0.005em;
}
.aentry.small { display: flex; flex-direction: column; gap: 2px; padding: 8px 0; }
.aentry.small .aquote { font: 500 15px/1.45 "Fraunces", serif; color: var(--ink); }
.ameta { font: 11.5px "JetBrains Mono", monospace; color: var(--ink-fade); text-transform: lowercase; }
.ameta em { font-style: italic; color: var(--rose); }
.anote {
  margin-top: 10px; padding-top: 10px; border-top: 1px dashed var(--line);
  font: italic 13px/1.5 "Fraunces", serif; color: var(--ink-soft);
}

.apatterns-list { margin: 28px 0 0; padding: 18px; border-radius: 14px; background: var(--paper-2); border: 1px solid var(--line); }
.apat-h { font: 500 13px "JetBrains Mono", monospace; color: var(--ink-fade); text-transform: lowercase; letter-spacing: 0.05em; margin-bottom: 14px; }
.apat { display: flex; gap: 14px; padding: 14px 0; border-top: 1px dashed var(--line); }
.apat:first-of-type { border-top: none; padding-top: 4px; }
.apat-n {
  font: 600 22px/1 "Fraunces", serif; color: var(--rose); min-width: 24px;
}
.apat-body { flex: 1; }
.apat-h2 { font: 600 16px/1.3 "Fraunces", serif; color: var(--ink); margin-bottom: 4px; }
.apat-body p { font: 14.5px/1.55 "Inter Tight", sans-serif; color: var(--ink-soft); margin: 0; }

.acoda {
  margin-top: 22px; padding: 14px 16px; border-radius: 12px;
  background: var(--ink); color: var(--paper);
  font: italic 14.5px/1.5 "Fraunces", serif; text-align: center;
}

@media (max-width: 640px) {
  .alede { font-size: 15px; }
  .aentry blockquote { font-size: 16px; }
  .apat { gap: 10px; }
  .apat-n { font-size: 19px; min-width: 18px; }
  .apat-h2 { font-size: 15px; }
  .apat-body p { font-size: 13.5px; }
  .acoda { font-size: 13.5px; }
}
