:root{--bg:#0d1117;--surface:#161b22;--surface2:#21262d;--border:#30363d;--text:#e6edf3;--muted:#7d8590;--today-bg:#132b4a;--today-ring:#2563eb;--green:#3fb950;--red:#f85149;--blue:#58a6ff}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);height:100%;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;overflow:hidden}.topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:10px 28px;display:flex}.topbar-title{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);white-space:nowrap;font-size:.85rem;font-weight:700}.topbar-clock{letter-spacing:.04em;font-variant-numeric:tabular-nums;white-space:nowrap;font-size:2.6rem;font-weight:200}.topbar-date{color:var(--muted);text-align:right;white-space:nowrap;font-size:.95rem}.main-layout{flex:1;height:calc(100vh - 84px);min-height:0;display:flex}.cal-panel{border-right:1px solid var(--border);flex-direction:column;flex:0 0 58%;min-height:0;padding:18px 22px 14px;display:flex}.month-nav{flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.month-title{letter-spacing:-.01em;font-size:1.55rem;font-weight:600}.nav-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:3px 14px 4px;font-size:1.3rem;line-height:1;transition:background .12s,color .12s}.nav-btn:hover{background:var(--surface2);color:var(--text)}.dow-row{flex-shrink:0;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px;display:grid}.dow-label{text-align:center;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:2px 0 4px;font-size:.7rem;font-weight:700}.cal-grid{flex:1;grid-template-columns:repeat(7,1fr);grid-auto-rows:1fr;gap:2px;min-height:0;display:grid}.day-cell{background:var(--surface);cursor:pointer;border-radius:6px;flex-direction:column;min-height:0;padding:5px 6px 4px;transition:background .1s;display:flex;overflow:hidden}.day-cell:hover{background:var(--surface2)}.day-cell.other-month{opacity:.3}.day-cell.today{background:var(--today-bg);box-shadow:inset 0 0 0 1px var(--today-ring)}.day-cell.today .day-num{color:var(--blue);font-weight:700}.day-num{flex-shrink:0;margin-bottom:3px;font-size:.82rem;font-weight:500}.day-dots{flex-wrap:wrap;align-content:flex-start;gap:2px;display:flex}.ev-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.upcoming-panel{flex-direction:column;flex:1;min-height:0;padding:18px 18px 14px 20px;display:flex;overflow:hidden}.upcoming-label{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);flex-shrink:0;margin-bottom:12px;font-size:.7rem;font-weight:700}.upcoming-scroll{flex:1;min-height:0;overflow-y:auto}.upcoming-scroll::-webkit-scrollbar{width:3px}.upcoming-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.ev-group{margin-bottom:14px}.group-header{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);margin-bottom:6px;padding-bottom:4px;font-size:.68rem;font-weight:700}.group-header.is-today{color:var(--blue)}.ev-row{cursor:pointer;border-radius:6px;align-items:stretch;gap:8px;margin-bottom:3px;padding:5px 6px;transition:background .1s;display:flex}.ev-row:hover{background:var(--surface2)}.ev-bar{border-radius:2px;flex-shrink:0;width:3px;min-height:20px}.ev-body{flex:1;min-width:0}.ev-time{color:var(--muted);margin-bottom:1px;font-size:.68rem}.ev-title{align-items:baseline;gap:2px;font-size:.88rem;font-weight:500;display:flex;overflow:hidden}.ev-title-text{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.ev-owner{margin-top:1px;font-size:.65rem}.empty-msg{color:var(--muted);padding:24px 0;font-size:.88rem}.statusbar{background:var(--surface);border-top:1px solid var(--border);color:var(--muted);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:7px 28px;font-size:.78rem;display:flex}.acct-statuses{gap:20px;display:flex}.acct-badge{align-items:center;gap:6px;display:flex}.acct-led{border-radius:50%;flex-shrink:0;width:7px;height:7px}.acct-led.on{background:var(--green)}.acct-led.off{background:var(--red)}.connect-link{color:var(--blue);margin-left:4px;text-decoration:none}.connect-link:hover{text-decoration:underline}.settings-btn{color:var(--blue);cursor:pointer;background:0 0;border:none;padding:0;font-size:.78rem}.settings-btn:hover{text-decoration:underline}.overlay{z-index:50;background:#0d1117e0;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.overlay.open{display:flex}.setup-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:440px;max-width:94vw;padding:32px 36px}.setup-card h2{margin-bottom:6px;font-size:1.25rem}.setup-desc{color:var(--muted);margin-bottom:22px;font-size:.88rem;line-height:1.6}.no-creds-warn{color:#f8a4a4;background:#2a1a1a;border:1px solid #5a2a2a;border-radius:8px;margin-bottom:18px;padding:12px 14px;font-size:.82rem;line-height:1.6}.acct-btn{border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;border-radius:8px;align-items:center;gap:12px;width:100%;margin-bottom:10px;padding:14px 16px;font-size:.92rem;text-decoration:none;transition:background .12s;display:flex}.acct-btn:hover{background:#2d333b}.acct-btn-dot{border-radius:50%;flex-shrink:0;width:11px;height:11px}.acct-btn-check{color:var(--green);margin-left:auto;font-size:1rem}.setup-footer{justify-content:flex-end;margin-top:20px;display:flex}.close-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:7px 18px;font-size:.85rem;transition:background .12s,color .12s}.close-btn:hover{background:var(--surface2);color:var(--text)}.setup-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.participant-badge{cursor:default;flex-shrink:0;font-size:.85em;line-height:1}.participants-manager{border-top:1px solid var(--border);padding-top:24px}.participants-title{margin-bottom:4px;font-size:1rem;font-weight:600}.participants-desc{color:var(--muted);margin-bottom:16px;font-size:.82rem;line-height:1.5}.pm-error{color:var(--red);margin-bottom:10px;font-size:.82rem}.pm-loading{color:var(--muted);margin-bottom:10px;font-size:.85rem}.pm-list{margin-bottom:16px;list-style:none}.pm-empty{color:var(--muted);padding:8px 0;font-size:.85rem}.pm-row{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 0;display:flex}.pm-emoji{flex-shrink:0;font-size:1.1rem}.pm-name{flex:1;font-size:.92rem}.pm-emoji-input{background:var(--surface2);border:1px solid var(--border);width:48px;color:var(--text);text-align:center;border-radius:6px;padding:5px 8px;font-size:.92rem}.pm-name-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:6px;flex:1;padding:5px 10px;font-size:.92rem}.pm-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:4px 10px;font-size:.78rem;transition:background .12s,color .12s}.pm-btn:hover{background:var(--surface2);color:var(--text)}.pm-btn--save{border-color:var(--green);color:var(--green)}.pm-btn--add{border-color:var(--blue);color:var(--blue)}.pm-btn--delete:hover{border-color:var(--red);color:var(--red);background:0 0}.pm-add-form{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.pm-add-err{color:var(--red);flex-basis:100%;font-size:.78rem}.hidden{display:none!important}.form-label{color:var(--muted);text-transform:uppercase;letter-spacing:.07em;flex-direction:column;gap:5px;font-size:.82rem;font-weight:600;display:flex}.form-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;width:100%;padding:9px 12px;font-size:.95rem;transition:border-color .12s}.form-input:focus{border-color:var(--blue)}.duration-group{flex-wrap:wrap;gap:6px;margin-top:2px;display:flex}.duration-chip{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:20px;padding:6px 14px;font-size:.82rem;transition:background .12s,border-color .12s}.duration-chip.active{background:var(--blue);border-color:var(--blue);color:#fff}.toggle-row{display:flex}.toggle-label{cursor:pointer;color:var(--text);align-items:center;gap:10px;font-size:.92rem;display:flex}.toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--blue);cursor:pointer}.form-error{color:var(--red);padding:6px 0;font-size:.82rem}.form-warn{color:var(--muted);text-align:center;font-size:.78rem}.submit-btn{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-top:4px;padding:13px;font-size:.95rem;font-weight:600;transition:background .12s,opacity .12s}.submit-btn:disabled{opacity:.5;cursor:default}.participant-chips{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.participant-chip{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:5px;padding:7px 14px;font-size:.88rem;transition:background .12s,border-color .12s;display:flex}.participant-chip.active{background:var(--blue);border-color:var(--blue);color:#fff}.event-card{width:100%;max-width:480px}.event-card h2{margin-bottom:10px;font-size:1.2rem}.event-card-form{flex-direction:column;gap:14px;margin-top:8px;display:flex}.event-card-row{gap:10px;display:flex}.detail-time,.detail-date{color:var(--muted);margin-bottom:3px;font-size:.85rem}.detail-owner{margin-bottom:12px;font-size:.82rem}.detail-participants{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.detail-participants .participant-badge{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:4px 10px;font-size:.82rem}.detail-actions{gap:10px;margin-top:6px;display:flex}.edit-btn{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:8px;flex:1;padding:10px;font-size:.9rem;transition:opacity .12s}.edit-btn:hover{opacity:.85}.delete-btn{color:var(--red);border:1px solid var(--red);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:10px;font-size:.9rem;transition:background .12s}.delete-btn:hover{background:#f851491a}.delete-confirm{border:1px solid var(--red);background:#f851490f;border-radius:8px;margin-top:12px;padding:12px 14px;font-size:.88rem}.delete-confirm-actions{gap:8px;margin-top:10px;display:flex}.delete-confirm-yes{background:var(--red);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 18px;font-size:.85rem;transition:opacity .12s}.delete-confirm-yes:disabled{opacity:.6;cursor:default}.delete-confirm-cancel{background:var(--surface2);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:8px 18px;font-size:.85rem}.settings-panel{flex:1;min-height:0;overflow-y:auto}.settings-overlay-content{width:100%;max-width:560px}.settings-overlay-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.settings-sections{padding:4px 0 8px}.settings-section{margin-bottom:28px}.settings-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px;font-size:.7rem;font-weight:600}.color-row{align-items:center;gap:12px;margin-bottom:10px;display:flex}.color-row-label{font-size:.88rem}input[type=color]{cursor:pointer;background:0 0;border:none;border-radius:6px;width:36px;height:36px;padding:0}.seg-ctrl{border:1px solid var(--border);border-radius:6px;display:flex;overflow:hidden}.seg-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;flex:1;padding:7px 12px;font-size:.85rem;transition:background .12s,color .12s}.seg-btn.active{background:var(--blue);color:#fff}.pref-row{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.pref-label{color:var(--muted);font-size:.82rem}.pref-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:6px;width:100%;padding:8px 10px;font-size:.88rem}@media (min-width:768px){body{overflow:hidden}.topbar{padding:12px 32px}.month-title{font-size:1.7rem}.upcoming-panel{min-width:260px}.account-selector,.tab-bar,.fab,.bottom-sheet,.sheet-backdrop,.day-detail,.settings-panel{display:none!important}}@media (max-width:767px){html,body{height:auto;overflow:auto}.topbar{flex-wrap:wrap;gap:4px;padding:8px 16px}.topbar-clock{font-size:1.6rem}.topbar-date{font-size:.78rem}.topbar-title{font-size:.75rem}.account-selector{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:8px 16px;display:flex}.account-selector-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;font-size:.75rem;font-weight:600}.account-chip{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:20px;padding:4px 14px;font-size:.82rem;transition:background .12s,border-color .12s}.account-chip.active{background:var(--chip-color,var(--blue));color:#fff;border-color:#0000;font-weight:600}.main-layout{flex-direction:column;height:auto}.cal-panel{border-right:none;border-bottom:1px solid var(--border);flex-direction:column;flex:none;height:42vh;min-height:260px;padding:10px 12px 8px;display:flex;overflow:hidden}.month-title{font-size:1.1rem}.month-nav{margin-bottom:6px}.nav-btn{padding:2px 10px;font-size:1.1rem}.dow-label{font-size:.6rem}.day-num{font-size:.72rem}.day-detail{flex-direction:column;flex:1;min-height:0;padding:10px 0 70px;display:flex;overflow-y:auto}.day-detail-header{justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.88rem;font-weight:600;display:flex}.day-detail-close{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:1rem}.day-detail-list{flex:1}.upcoming-panel{flex:1;min-height:0;padding:12px 16px 70px;overflow-y:auto}.settings-panel{flex-direction:column;padding:12px 16px 80px;display:flex}.statusbar{display:none}.tab-bar{background:var(--surface);border-top:1px solid var(--border);z-index:20;height:56px;display:flex;position:fixed;bottom:0;left:0;right:0}.tab-btn{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;font-size:.65rem;font-weight:600;transition:color .12s;display:flex}.tab-btn.active{color:var(--blue)}.tab-icon{font-size:1.2rem}.fab{background:var(--blue);color:#fff;cursor:pointer;z-index:30;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.7rem;font-weight:300;line-height:1;transition:background .12s,transform .1s;display:flex;position:fixed;bottom:68px;right:20px;box-shadow:0 4px 12px #0006}.fab:active{transform:scale(.95)}.sheet-backdrop{z-index:40;background:#0d1117b3;display:block;position:fixed;inset:0}.bottom-sheet{background:var(--surface);border-top:1px solid var(--border);z-index:50;border-radius:16px 16px 0 0;flex-direction:column;max-height:90dvh;transition:transform .3s cubic-bezier(.25,.8,.25,1);display:flex;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(100%)}.bottom-sheet--open{transform:translateY(0)}.sheet-handle{background:var(--border);border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:10px auto 0}.sheet-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 20px 10px;display:flex}.sheet-title{font-size:1.1rem;font-weight:600}.sheet-close{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:1.1rem}.sheet-form{flex-direction:column;gap:14px;padding:4px 20px 32px;display:flex}}
