:root{
  --paper:#F8F7F5;
  --paper-2:#FFFFFF;
  --surface:#FFFFFF;
  --ink:#252E32;
  --muted:#9D9A91;
  --line:#E5E2DC;
  --line-strong:#C3BDB0;
  --accent:#9C9B5C;
  --today:#252E32;
  --shadow:0 1px 2px rgba(37,46,50,.04),0 8px 24px rgba(37,46,50,.06);
}
[data-theme="dark"]{
  --paper:#252E32;
  --paper-2:#2B3941;
  --surface:#2F383D;
  --ink:#F0EEEA;
  --muted:#9D9A91;
  --line:#3A4449;
  --line-strong:#4A545A;
  --accent:#B2B16C;
  --today:#F0EEEA;
  --shadow:0 1px 2px rgba(0,0,0,.12),0 8px 24px rgba(0,0,0,.25);
}
[data-theme="dark"] body{
  background-image:radial-gradient(rgba(200,200,180,.03) 1px,transparent 1px);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:"Hanken Grotesk",sans-serif;-webkit-font-smoothing:antialiased}
body{
  background-image:radial-gradient(rgba(37,46,50,.04) 1px,transparent 1px);
  background-size:22px 22px;
  padding:clamp(20px,4vw,52px);
  min-height:100vh;
}
.wrap{max-width:1240px;margin:0 auto}

header.top{
  display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;
  gap:20px;padding-bottom:22px;border-bottom:2px solid var(--ink);margin-bottom:8px;
}
.eyebrow{
  font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted);
  font-weight:600;margin-bottom:10px;
}
h1#title{
  font-family:"Fraunces",serif;font-weight:600;font-optical-sizing:auto;
  font-size:clamp(34px,6vw,64px);line-height:.95;letter-spacing:-.02em;
  outline:none;border-radius:4px;transition:background .2s;
}
h1#title:hover,h1#title:focus{background:rgba(156,155,92,.08)}
.top .right{display:flex;gap:10px;align-items:center}
.ghost-btn{
  font-family:inherit;font-size:13px;font-weight:600;letter-spacing:.02em;
  background:transparent;border:1.5px solid var(--ink);color:var(--ink);
  padding:9px 16px;border-radius:999px;cursor:pointer;transition:.18s;white-space:nowrap;
}
.ghost-btn:hover{background:var(--ink);color:var(--paper-2)}

.toggles{display:flex;gap:6px;align-items:center}
.toggle-pill{
  font-family:inherit;font-size:13px;font-weight:600;
  background:var(--paper-2);border:1.5px solid var(--line-strong);color:var(--ink);
  padding:7px 12px;border-radius:999px;cursor:pointer;transition:.18s;line-height:1;
  min-width:38px;text-align:center;
}
.toggle-pill:hover{border-color:var(--ink)}

.meta{
  display:flex;flex-wrap:wrap;gap:8px 22px;align-items:center;
  font-size:13.5px;color:var(--muted);margin:14px 0 26px;
}
.meta .hint{display:flex;align-items:center;gap:7px}
.dot-mini{width:9px;height:9px;border-radius:50%;background:var(--accent)}

.legend{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 30px}
.legend .sw{
  display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;
  background:var(--surface);border:1px solid var(--line);padding:6px 11px 6px 8px;border-radius:999px;
}
.legend .sw i{width:11px;height:11px;border-radius:3px;display:inline-block}

.months{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:22px;align-items:start;
}
.month{
  background:var(--surface);border:1px solid var(--line);border-radius:16px;
  padding:18px 18px 14px;box-shadow:var(--shadow);
  opacity:0;transform:translateY(10px);animation:rise .5s forwards;
}
@keyframes rise{to{opacity:1;transform:none}}
.month h2{
  font-family:"Fraunces",serif;font-weight:600;font-size:22px;letter-spacing:-.01em;
  display:flex;align-items:baseline;gap:8px;margin-bottom:14px;
}
.month h2 span{font-family:"Hanken Grotesk";font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.08em}
.dow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:6px}
.dow div{font-size:10.5px;font-weight:700;color:var(--muted);text-align:center;letter-spacing:.04em;text-transform:uppercase}
.grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cell{
  aspect-ratio:1/1;border-radius:9px;border:1px solid transparent;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  padding-top:5px;font-size:13px;font-weight:500;cursor:pointer;position:relative;
  transition:.14s;background:var(--paper-2);
}
.cell.empty{background:transparent;cursor:default}
.cell:not(.empty):hover{border-color:var(--line-strong);transform:translateY(-1px)}
.cell.past{color:var(--muted);background:transparent}
.cell.past:not(.empty){opacity:.55}
.cell.today{background:var(--today);color:var(--paper);font-weight:700}
.cell.today:hover{border-color:var(--today)}
.cell.has-ev{font-weight:700}
.dots{display:flex;gap:2.5px;position:absolute;bottom:5px;flex-wrap:wrap;justify-content:center;max-width:90%}
.dots i{width:6px;height:6px;border-radius:50%}

.agenda{margin-top:46px}
.agenda h3{
  font-family:"Fraunces",serif;font-size:26px;font-weight:600;letter-spacing:-.01em;
  padding-bottom:12px;border-bottom:1.5px solid var(--line-strong);margin-bottom:6px;
  display:flex;align-items:center;justify-content:space-between;
}
.agenda h3 small{font-family:"Hanken Grotesk";font-size:13px;font-weight:600;color:var(--muted)}
.ev{
  display:grid;grid-template-columns:96px 6px 1fr auto;gap:16px;align-items:start;
  padding:18px 4px;border-bottom:1px solid var(--line);
}
.ev .when{text-align:right}
.ev .when .d{font-family:"Fraunces",serif;font-size:30px;font-weight:600;line-height:1}
.ev .when .m{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.ev .when .y{font-size:11px;color:var(--muted)}
.ev .bar{border-radius:3px;align-self:stretch;min-height:46px}
.ev .body .t{font-family:"Fraunces",serif;font-size:19px;font-weight:600;letter-spacing:-.01em;line-height:1.15}
.ev .body .sp{font-size:13px;font-weight:600;color:var(--accent);margin-top:3px}
.ev .body .ds{font-size:14px;color:var(--muted);margin-top:7px;line-height:1.5;max-width:62ch}
.ev .body .cat{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-top:8px}
.ev .acts{display:flex;gap:6px}
.icon-btn{
  background:transparent;border:1px solid var(--line-strong);border-radius:8px;cursor:pointer;
  width:30px;height:30px;font-size:14px;color:var(--muted);transition:.15s;display:grid;place-items:center;
}
.icon-btn:hover{border-color:var(--ink);color:var(--ink)}
.empty-state{padding:40px 0;text-align:center;color:var(--muted);font-size:15px}
.empty-state b{color:var(--ink)}

.overlay{
  position:fixed;inset:0;background:rgba(37,46,50,.45);backdrop-filter:blur(3px);
  display:none;align-items:center;justify-content:center;padding:20px;z-index:50;
}
.overlay.open{display:flex}
.modal{
  background:var(--paper-2);border-radius:18px;width:100%;max-width:480px;
  padding:26px 26px 22px;box-shadow:0 24px 60px rgba(37,46,50,.3);
  max-height:90vh;overflow:auto;animation:pop .25s;
}
@keyframes pop{from{transform:scale(.96);opacity:0}to{transform:none;opacity:1}}
.modal .mh{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}
.modal .date-lbl{font-family:"Fraunces",serif;font-size:24px;font-weight:600}
.modal .close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--muted);line-height:1}
.existing{margin:14px 0;display:flex;flex-direction:column;gap:8px}
.existing .row{
  display:flex;align-items:center;gap:10px;background:var(--surface);
  border:1px solid var(--line);border-radius:10px;padding:9px 11px;
}
.existing .row i{width:10px;height:10px;border-radius:3px;flex:0 0 auto}
.existing .row .x{flex:1;font-size:14px;font-weight:600}
.existing .row .x small{display:block;font-weight:400;color:var(--muted);font-size:12px}
.existing .row button{background:none;border:none;cursor:pointer;color:var(--muted);font-size:13px}
.existing .row button:hover{color:var(--accent)}
.divider{height:1px;background:var(--line);margin:16px 0}
.form-title{font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
label.f{display:block;font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:0 0 5px}
input.f,textarea.f{
  width:100%;font-family:inherit;font-size:15px;color:var(--ink);background:var(--surface);
  border:1.5px solid var(--line-strong);border-radius:10px;padding:10px 12px;margin-bottom:14px;outline:none;transition:.15s;
}
input.f:focus,textarea.f:focus{border-color:var(--accent)}
textarea.f{resize:vertical;min-height:64px;line-height:1.45}
.swatches{display:flex;gap:9px;margin-bottom:18px}
.swatches button{
  width:30px;height:30px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:.12s;
}
.swatches button.sel{border-color:var(--ink);transform:scale(1.08)}
.save-btn{
  width:100%;font-family:inherit;font-size:15px;font-weight:700;letter-spacing:.02em;
  background:var(--ink);color:var(--paper-2);border:none;border-radius:999px;padding:13px;cursor:pointer;transition:.18s;
}
.save-btn:hover{background:var(--accent)}

.loading{padding:60px;text-align:center;color:var(--muted);font-size:15px}

#authBtn.unlocked{background:var(--accent);color:var(--paper-2);border-color:var(--accent)}
.auth-modal{max-width:360px}
.auth-desc{font-size:14px;color:var(--muted);margin:10px 0 16px;line-height:1.45}
.auth-error{font-size:13px;color:#c0392b;font-weight:600;min-height:20px;margin:-8px 0 10px}
h1#title[contenteditable="false"]{cursor:default}
h1#title[contenteditable="false"]:hover,h1#title[contenteditable="false"]:focus{background:transparent}

@media print{
  body{background:#fff !important;padding:0;background-image:none !important;color:#252E32 !important}
  .ghost-btn,.icon-btn,.meta .hint:last-child,#authBtn,.toggles{display:none}
  .month{box-shadow:none;break-inside:avoid}
  .ev{break-inside:avoid}
}
@media (max-width:520px){
  .ev{grid-template-columns:64px 5px 1fr;gap:11px}
  .ev .acts{grid-column:1/-1;justify-content:flex-end;margin-top:-6px}
  .ev .when .d{font-size:24px}
}
