:root{--bg:#eceef3;--card:#fff;--ink:#1b2330;--muted:#69727f;--faint:#9aa2af;--line:#e3e7ef;--line-strong:#d3d9e4;--primary:#2f54eb;--primary-ink:#fff;--primary-soft:#eaeefe;--heart:#ec4d6b;--green:#2f9e44;--green-soft:#e8f6ec;--yellow:#f3a712;--red:#e23b3b;--host-wash:#f4f1fc;--host-line:#ddd4f5;--host-ink:#5a44b8;--radius:14px;--radius-sm:9px;--shadow:0 1px 2px #141e320d, 0 2px 8px #141e320d;--shadow-pop:0 8px 28px #141e3229;--brand-display:"Poetsen One", "Fraunces", Georgia, serif;--sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--serif:"Fraunces", Georgia, serif;--mono:"IBM Plex Mono", ui-monospace, Menlo, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}h1,h2,h3{font-family:var(--serif);letter-spacing:-.01em;font-weight:600}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}.topbar{z-index:40;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);background:#ffffffeb;align-items:center;gap:16px;padding:12px 20px;display:flex;position:sticky;top:0}.brand{color:var(--ink);font-family:var(--brand-display);letter-spacing:0;align-items:center;gap:10px;font-size:20px;font-weight:400;line-height:1;display:flex}.brand:hover{text-decoration:none}.brand-logo{object-fit:contain;flex:none;width:30px;height:30px}.timetable-cover,.topic-cover{border:1px solid var(--line);background-position:50%;background-size:cover;width:100%}.timetable-cover{border-radius:var(--radius);height:150px;margin:-2px 0 18px}.topic-cover{aspect-ratio:16/7;border-radius:var(--radius-sm)}.auth-page{place-items:center;gap:18px;display:grid}.auth-fallback{text-align:center;max-width:460px}.auth-fallback h1{margin-bottom:6px}.auth-fallback p{color:var(--muted);margin:0;font-size:13px}.spacer{flex:1}.container{max-width:980px;margin:0 auto;padding:28px 20px 64px}.page-head h1{margin:0;font-size:26px}.page-head p{color:var(--muted);margin:6px 0 0;font-size:14px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.grid{gap:14px;display:grid}@media (min-width:640px){.grid-2{grid-template-columns:repeat(2,1fr)}}.btn{border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:var(--card);color:var(--ink);align-items:center;gap:7px;padding:9px 15px;font-size:14px;font-weight:600;display:inline-flex}.btn:hover{background:#f6f7fa;text-decoration:none}.btn-primary{background:var(--primary);color:var(--primary-ink);border-color:#0000}.btn-primary:hover{filter:brightness(1.05);background:var(--primary)}.btn-ghost{color:var(--muted);background:0 0;border-color:#0000}.field{margin-bottom:12px;display:block}.field label{color:var(--muted);margin-bottom:5px;font-size:13px;font-weight:600;display:block}input,textarea,select{width:100%;color:var(--ink);border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:#fff;padding:9px 11px;font-family:inherit;font-size:14px}textarea{resize:vertical;min-height:80px}.pill{border:1px solid var(--line-strong);color:var(--muted);background:#fff;border-radius:999px;align-items:center;gap:6px;padding:4px 9px;font-size:12px;font-weight:600;display:inline-flex}.pill-owner,.pill-admin{color:#b23a4c;background:#fdeef0;border-color:#f6d2d8}.pill-host{background:var(--host-wash);color:var(--host-ink);border-color:var(--host-line)}.pill-elector{background:var(--primary-soft);color:var(--primary);border-color:#0000}.muted{color:var(--muted)}.faint{color:var(--faint)}.mono{font-family:var(--mono)}.row{align-items:center;gap:10px;display:flex}.wrap{flex-wrap:wrap}.nav{flex-wrap:wrap;gap:6px;display:flex}.nav a{color:var(--muted);border-radius:10px;padding:8px 12px;font-size:14px;font-weight:600}.nav a:hover{background:#e4e7ef;text-decoration:none}.nav a.on{background:var(--primary-soft);color:var(--primary)}.stack{flex-direction:column;gap:14px;display:flex}.notice{border:1px dashed var(--line-strong);color:var(--faint);background:#fff;border-radius:10px;padding:12px 14px;font-size:13px}.list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.avatar{color:#fff;border-radius:50%;flex:none;place-items:center;width:34px;height:34px;font-size:13px;font-weight:600;display:grid}.avatar-sm{width:26px;height:26px;font-size:11px}.topic-title{font-family:var(--serif);margin:0;font-size:20px;font-weight:600}.topic-body{color:var(--ink);font-size:15px;line-height:1.6}.topic-body p:first-child{margin-top:0}.topic-body img{border-radius:8px;max-width:100%}.toolbar{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;padding:10px 13px;display:flex}.toolbar label{color:var(--muted);font-size:12px;font-weight:600}.toolbar select{width:auto;padding:6px 9px}.heart-btn{border:1px solid var(--line-strong);background:var(--card);color:var(--muted);border-radius:999px;align-items:center;gap:7px;padding:7px 13px;font-size:14px;font-weight:600;display:inline-flex}.heart-btn.on{color:var(--heart);background:#fde7ec;border-color:#0000}.heart-btn .ic{font-size:15px}.comments{border-top:1px solid var(--line);flex-direction:column;gap:12px;margin-top:14px;padding-top:12px;display:flex}.comment{gap:10px;display:flex}.comment-main{flex:1;min-width:0}.comment-meta{font-size:13px}.comment-meta .who{font-weight:600}.comment-body{white-space:pre-wrap;word-wrap:break-word;margin:2px 0 4px;font-size:14px}.comment-actions{gap:12px;font-size:12px;display:flex}.comment-actions button{color:var(--muted);background:0 0;border:none;padding:0;font-size:12px;font-weight:600}.replies{border-left:2px solid var(--line);flex-direction:column;gap:10px;margin-top:10px;padding-left:14px;display:flex}.comment.hidden .comment-body{color:var(--faint);font-style:italic}.host-panel{background:var(--host-wash);border:1px solid var(--host-line);border-radius:var(--radius-sm);margin-top:14px;padding:12px 14px}.host-panel h4{font-family:var(--sans);text-transform:uppercase;letter-spacing:.04em;color:var(--host-ink);margin:0 0 8px;font-size:12px}.weight-row{justify-content:space-between;padding:3px 0;font-size:13px;display:flex}.weight-row .mono{color:var(--host-ink)}.inline-form{align-items:flex-start;gap:8px;display:flex}.inline-form textarea{min-height:38px}.status-badge{border-radius:999px;padding:3px 9px;font-size:12px;font-weight:600;display:inline-block}.status-draft{color:#7a756c;background:#f1f0ee}.status-submitted{color:#a9700f;background:#fff4e0}.status-published{background:var(--green-soft);color:#207a32}.status-unpublished,.status-archived{color:#7d8694;background:#eef0f5}.avail-btns{gap:4px;display:inline-flex}.avail-btn{border:1px solid var(--line-strong);opacity:.5;background:#fff;border-radius:8px;place-items:center;width:30px;height:30px;font-size:14px;display:grid}.avail-btn.on{opacity:1;border-color:var(--ink)}.avail-btn.green{background:var(--green-soft)}.avail-btn.yellow{background:var(--yellow-soft,#fdf2dc)}.avail-btn.red{background:var(--red-soft,#fbe9e9)}.avail-bar{border:1px solid var(--line);border-radius:999px;min-width:120px;height:10px;display:inline-flex;overflow:hidden}.avail-bar>span{height:100%;display:block}.avail-bar .g{background:var(--green)}.avail-bar .y{background:var(--yellow)}.avail-bar .r{background:var(--red)}.dot{border-radius:50%;width:12px;height:12px;display:inline-block}.dot.green{background:var(--green)}.dot.yellow{background:var(--yellow)}.dot.red{background:var(--red)}.slot-when{font-family:var(--serif);font-size:16px;font-weight:600}.weekday-grid{flex-wrap:wrap;gap:6px;display:flex}
