@import "https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--pico-background-color:#0b0f14;--pico-color:#fff;--home-surface:#111827;--home-ink:#f8fafc;--home-muted:#cbd5f5;--home-accent:#34d399;--home-accent-strong:#f59e0b;--surface-1:#0f172ac7;--surface-2:#0f172aeb;--surface-3:#1e293bd9;--border-soft:#94a3b840;--border-strong:#94a3b873;--text-muted:#9ca3af;--accent-blue:#60a5fa;--accent-pink:#f472b6}body{background-color:var(--pico-background-color);color:var(--pico-color);font-family:Space Grotesk,Segoe UI,sans-serif}.container{width:min(1100px,100%);margin:0 auto;padding:clamp(1rem,2vw,2rem) 0}.home{min-height:100vh;color:var(--home-ink);justify-content:center;align-items:center;padding:5rem clamp(1.5rem,4vw,4rem);display:flex;position:relative;overflow:hidden}.home.histogram-page{box-sizing:border-box;padding-left:0;padding-right:0}.schedule-page{justify-content:flex-start;align-items:flex-start}.schedule-content{z-index:1;width:min(1100px,100%);margin:0 auto;padding:0 clamp(.5rem,2vw,1.5rem);animation:.7s ease-out both home-fade-up;position:relative}.schedule-content .container{padding-top:0}.home-bg{z-index:0;background:radial-gradient(circle at 20% 20%,#34d3992e,#0000 45%),radial-gradient(circle at 80% 10%,#f59e0b38,#0000 40%),radial-gradient(circle at 50% 90%,#3b82f62e,#0000 45%),linear-gradient(135deg,#0b0f14 0%,#0f172a 55%,#0b0f14 100%);position:absolute;inset:-20%}.home-hero{z-index:1;background:var(--surface-1);border:1px solid var(--border-soft);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:24px;max-width:900px;padding:clamp(2rem,5vw,4rem);animation:.7s ease-out both home-fade-up;position:relative;box-shadow:0 24px 80px #0006}.histogram-shell{z-index:1;box-sizing:border-box;width:100%;max-width:900px;margin:0 auto;padding:clamp(2rem,5vw,4rem);animation:.7s ease-out both home-fade-up;position:relative}.home-kicker{text-transform:uppercase;letter-spacing:.22em;color:var(--home-muted);margin-bottom:1rem;font-size:.78rem}.home-title{margin:0 0 1rem;font-family:DM Serif Display,Space Grotesk,serif;font-size:clamp(2.4rem,5vw,4.4rem);line-height:1.05}.home-subtitle{color:var(--home-muted);margin-bottom:2.5rem;font-size:clamp(1rem,2vw,1.35rem)}.home-actions{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;display:grid}.home-card{border:1px solid var(--border-soft);color:inherit;background:linear-gradient(145deg,#1e293be6,#0f172ad9);border-radius:18px;flex-direction:column;gap:.7rem;padding:1.6rem;text-decoration:none;transition:transform .22s,box-shadow .22s,border-color .22s;animation:.8s ease-out both home-card-rise;display:flex}.home-card:nth-child(2){animation-delay:.12s}.home-card-title{font-size:1.4rem;font-weight:600}.home-card-text{color:var(--home-muted);line-height:1.4}.home-card-cta{color:var(--home-accent);letter-spacing:.02em;font-weight:600}.home-card:hover{border-color:#34d39980;transform:translateY(-6px);box-shadow:0 20px 40px #0f172a80}.home-card:hover .home-card-cta{color:var(--home-accent-strong)}@keyframes home-fade-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes home-card-rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media (max-width:720px){.home{padding:3.5rem 1.25rem}.home.histogram-page{padding-left:0;padding-right:0}.home-hero{padding:2rem 1.5rem}}#hero{flex-direction:column;justify-content:center;align-items:center;margin:0;display:flex}#links{text-align:left;color:#fff;flex-direction:column;width:400px;font-size:x-large;display:flex}#links a{color:#fff;border:1px solid #fff;border-radius:5px;margin:10px 0;padding:10px;text-decoration:none}#links a:hover{cursor:pointer;background-color:#1f1f1f}#header{max-width:1200px}.button-container{flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:12px;margin:18px 0;display:flex}.button-container button,.form-button-group button,.filter-clear,.filter-add{border:1px solid var(--border-strong);color:var(--home-ink);cursor:pointer;background:#1e293bb3;border-radius:999px;padding:.45rem 1rem;font-size:.85rem;transition:transform .18s,border-color .18s,background .18s,box-shadow .18s}.button-container button:hover,.form-button-group button:hover,.filter-clear:hover,.filter-add:hover{background:#1e293be6;border-color:#60a5fab3;transform:translateY(-1px);box-shadow:0 0 0 2px #60a5fa26}.button-container button:active,.form-button-group button:active,.filter-clear:active,.filter-add:active{transform:translateY(0)}.form-button-group button.secondary{color:var(--home-muted);background:#0f172a99}.schedule-content input,.schedule-content select,.schedule-content textarea{border:1px solid var(--border-strong);color:var(--home-ink);box-shadow:none;background:#0f172ab8;border-radius:12px}.schedule-content input:focus,.schedule-content select:focus,.schedule-content textarea:focus{border-color:var(--home-accent);outline:none;box-shadow:0 0 0 3px #34d39933}.task-item{background-color:var(--surface-2);border:1px solid var(--border-soft);border-radius:14px;margin:0;padding:.8rem;box-shadow:0 8px 16px #02061747}.task-item:hover{border-color:#60a5fa66;box-shadow:0 10px 20px #02061761}.task-list{gap:.35rem;display:grid}.task-item-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.task-item-left{flex-direction:column;align-items:flex-start;gap:.4rem;min-width:0;display:flex}.task-tag-list{flex-wrap:wrap;align-items:center;gap:.35rem;min-height:1.4rem;display:flex}.task-item-right{text-align:right;margin-left:auto}.task-item-due{border-left:3px solid var(--accent-blue)}.task-item-meta{color:var(--text-muted);flex-wrap:wrap;align-items:flex-end;gap:.35rem;display:flex}.task-item-sep{opacity:.7}.task-tag{color:#e2e8f0;letter-spacing:.02em;white-space:nowrap;background:#94a3b824;border:1px solid #94a3b847;border-radius:999px;align-self:flex-start;align-items:center;padding:.1rem .5rem;line-height:1;display:inline-flex}.task-tag.tag-uncategorized{color:#cbd5e1;background:#94a3b833;border-color:#94a3b873}.tag-input-container{border:1px solid var(--border-soft);background:#0f172a99;border-radius:12px;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.6rem;display:flex}.tag-pill{color:#dbeafe;white-space:nowrap;background:#60a5fa33;border:1px solid #60a5fa73;border-radius:999px;align-self:center;align-items:center;gap:.4rem;padding:.2rem .6rem;font-size:.85rem;line-height:1;display:inline-flex}.remove-tag{cursor:pointer;color:#e2e8f0}.tag-input{color:#e2e8f0;background:0 0;border:none;outline:none;min-width:140px}.tag-input::placeholder,.filter-input::placeholder{color:var(--text-muted)}.tag-suggestions{flex-wrap:wrap;align-items:center;gap:.4rem;margin-top:.4rem;display:flex}.tag-suggestions-label{color:#94a3b8;font-size:.85rem}.tag-suggestion-pill{color:#e2e8f0;white-space:nowrap;background:#94a3b82e;border:1px solid #94a3b859;border-radius:999px;padding:.1rem .6rem;line-height:1}.filter-bar{flex-wrap:wrap;align-items:center;gap:.6rem;margin:.4rem 0 1rem;display:flex}.filter-label{color:#94a3b8;font-size:.85rem;line-height:1}.filter-menu{--filter-width:180px;box-shadow:none;background:0 0;border:none;align-items:center;margin:0;padding:0;display:inline-flex;position:relative}.filter-summary{cursor:pointer;border:1px solid var(--border-strong);color:#e2e8f0;min-width:0;max-width:100%;box-shadow:none;width:var(--filter-width);background:#94a3b814;border-bottom:none;border-radius:999px;outline:none;justify-content:space-between;align-items:center;gap:.4rem;padding:.15rem .6rem;font-size:.85rem;line-height:1;text-decoration:none;list-style:none;display:inline-flex}.filter-summary::marker{content:""}.filter-summary::-webkit-details-marker{display:none}.filter-summary:focus,.filter-summary:focus-visible{outline:none}.filter-summary-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.filter-menu[open] .filter-summary{box-shadow:inset 0 0 0 1px #e2e8f059}.filter-menu-list{z-index:10;width:min(var(--filter-width),90vw);min-width:min(var(--filter-width),90vw);max-width:min(var(--filter-width),90vw);box-sizing:border-box;border:1px solid var(--border-soft);background:#0f172afa;border-radius:10px;gap:.4rem;max-height:240px;margin-top:.4rem;padding:.6rem;display:grid;position:absolute;inset-inline-start:0;overflow-y:auto;box-shadow:0 12px 24px #02061766}.filter-menu-actions{gap:.4rem;display:flex}.filter-clear{align-self:flex-start;padding:.2rem .6rem;font-size:.8rem}.filter-option{color:#e2e8f0;align-items:center;gap:.5rem;font-size:.85rem;display:flex}.filter-option input{accent-color:var(--accent-blue)}.filter-swatch{border-radius:999px;width:.7rem;height:.7rem}.filter-swatch-muted{background:#94a3b833;border:1px dashed #94a3b873}.filter-missing-label{color:#94a3b8;font-size:.75rem}.filter-option-missing{opacity:.85}.filter-selected-tags{justify-content:flex-start}.filter-empty{color:#94a3b8;font-size:.85rem}.filter-input-row{align-items:center;gap:.4rem;width:100%;display:flex}.filter-input{border:1px solid var(--border-strong);color:#e2e8f0;background:#0f172ab3;border-radius:10px;flex:2 1 0;min-width:0;padding:.3rem .6rem}.filter-input:focus{border-color:var(--home-accent);outline:none;box-shadow:0 0 0 3px #34d39933}.filter-add{flex:1 1 0;justify-content:center;min-width:0;padding:.2rem .6rem;font-size:.8rem}@media (max-width:480px){.filter-menu{--filter-width:min(90vw,220px)}}.swipeable-task{-webkit-user-select:none;user-select:none;touch-action:pan-y;cursor:grab}.swipeable-task:active{cursor:grabbing}.form-button-group{flex-direction:row;gap:.75rem;display:flex}.form-button-group>button{flex-grow:1}.notification-item{border-radius:8px;align-items:center;gap:.75rem;min-width:300px;max-width:400px;padding:1rem;transition:opacity .3s ease-out,transform .3s ease-out;animation:.3s ease-out slideInRight;display:flex;box-shadow:0 14px 32px #02061773}.notification-container{z-index:1000;flex-direction:column;gap:10px;display:flex;position:fixed;top:20px;right:20px}.notification-success{color:#dcfce7;background-color:#22c55e33;border-left:4px solid #22c55ecc}.notification-error{color:#fee2e2;background-color:#f8717133;border-left:4px solid #f87171cc}.notification-info{color:#dbeafe;background-color:#3b82f633;border-left:4px solid #3b82f6cc}.notification-warning{color:#ffedd5;background-color:#f9731633;border-left:4px solid #f97316cc}.notification-progress{color:#e2e8f0;background-color:#94a3b833;border-left:4px solid #94a3b8b3}.notification-content{flex-grow:1;min-width:0}.notification-message{margin-bottom:.5rem;font-weight:500}progress.progress-bar{appearance:none;border:none;border-radius:3px;width:100%;height:6px;overflow:hidden}progress.progress-bar::-webkit-progress-bar{background-color:#ffffff4d}progress.progress-bar::-webkit-progress-value{background-color:#fff;border-radius:3px;transition:width .3s ease-out}progress.progress-bar::-moz-progress-bar{background-color:#fff;border-radius:3px;transition:width .3s ease-out}.notification-close{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:1.25rem;font-weight:700;transition:background-color .2s;display:flex}.notification-close:hover{background-color:#fff3}.histogram-panel{gap:1.5rem;display:grid}.histogram-card{box-sizing:border-box;border:1px solid var(--border-soft);background:linear-gradient(145deg,#1e293be6,#0f172ad9);border-radius:18px;place-items:center;gap:1.25rem;width:100%;max-width:420px;margin:0 auto;padding:1.6rem;display:grid;box-shadow:0 18px 40px #0f172a59}.histogram-card>*{margin:0}.histogram-figure{border-radius:14px;width:100%;max-width:320px;height:auto;margin:0;display:block}.histogram-controls{gap:0;width:100%;max-width:320px;display:grid}.histogram-input{border:1px solid var(--border-strong);color:#e2e8f0;background:#0f172ae6;border-radius:12px;width:100%;padding:.55rem .8rem}.histogram-input::placeholder{color:#94a3b8}.histogram-input:focus{border-color:var(--home-accent);outline:none;box-shadow:0 0 0 3px #34d39933}.helper-text{color:#e5e7ebb3;margin-top:0;font-size:.88rem;line-height:1.35}.helper-link{color:#38bdf8;text-underline-offset:2px;margin-left:6px;text-decoration:underline}.helper-link:hover,.helper-link:active{opacity:.9}.histogram-button{color:#ecfdf3;cursor:pointer;background:#34d39933;border:1px solid #34d39999;border-radius:12px;margin-top:.7rem;padding:.6rem 1rem;font-size:.95rem;transition:transform .2s,border-color .2s,background .2s}.histogram-button:hover{background:#34d39959;border-color:#34d399e6;transform:translateY(-2px)}.histogram-button:active{transform:translateY(0)}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}