:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;color-scheme:light;--bg: #f5f5f5;--bg-elevated: #ffffff;--bg-hover: #eeeeee;--text: rgba(0, 0, 0, .88);--text-muted: rgba(0, 0, 0, .55);--border: rgba(0, 0, 0, .12);--border-strong: rgba(0, 0, 0, .25);--input-bg: #eeeeee;--input-border: rgba(0, 0, 0, .2);--cell-bg: rgba(0, 0, 0, .06);--cell-bg-hover: rgba(0, 0, 0, .25);--cell-active-text: #111;--today-ring: rgba(0, 0, 0, .5);--popover-bg: #ffffff;--popover-border: rgba(0, 0, 0, .12);--dialog-backdrop-bg: rgba(255, 255, 255, .5);--btn-secondary-bg: rgba(0, 0, 0, .08);--btn-secondary-hover: rgba(0, 0, 0, .12);--swatch-selected-border: #333}@media(prefers-color-scheme:dark){:root{color-scheme:dark;--bg: #242424;--bg-elevated: #1a1a1a;--bg-hover: #222;--text: rgba(255, 255, 255, .9);--text-muted: rgba(255, 255, 255, .6);--border: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .25);--input-bg: #242424;--input-border: rgba(255, 255, 255, .2);--cell-bg: rgba(255, 255, 255, .06);--cell-bg-hover: rgba(255, 255, 255, .25);--cell-active-text: #fff;--today-ring: rgba(255, 255, 255, .7);--popover-bg: #1a1a1a;--popover-border: rgba(255, 255, 255, .15);--dialog-backdrop-bg: rgba(0, 0, 0, .6);--btn-secondary-bg: rgba(255, 255, 255, .1);--btn-secondary-hover: rgba(255, 255, 255, .15);--swatch-selected-border: #fff}}:root{color:var(--text);background-color:var(--bg)}html{min-height:100%}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg)}#root{min-height:100vh;background-color:var(--bg)}.app{max-width:900px;margin:0 auto;padding:1.5rem;min-height:100vh;box-sizing:border-box}.calendars-screen{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.calendars-screen__header{text-align:center;margin-bottom:.5rem}.calendars-screen__title{font-size:2rem;font-weight:600;margin:0 0 .25rem}.calendars-screen__subtitle{margin:0;color:var(--text-muted);font-size:.95rem}.all-calendars-calendar-link{margin-top:.5rem;padding:.4rem .75rem;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text);font:inherit;font-size:.9rem;cursor:pointer;transition:background .2s,border-color .2s}.all-calendars-calendar-link:hover{background:var(--cell-bg);border-color:var(--border-strong)}.calendar-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:400px}.calendar-card{display:flex;align-items:center;gap:.75rem;width:100%;padding:1rem 1.25rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;color:inherit;font:inherit;text-align:left;cursor:pointer;transition:border-color .2s,background .2s}.calendar-card:hover{background:var(--bg-hover);border-color:var(--border-strong)}.calendar-card__swatch{width:24px;height:24px;border-radius:6px;flex-shrink:0}.calendar-card__name{flex:1;font-weight:500}.calendar-card__delete{padding:.25rem .5rem;background:transparent;border:none;color:var(--text-muted);font-size:1.25rem;line-height:1;cursor:pointer;border-radius:6px;transition:color .2s,background .2s}.calendar-card__delete:hover{color:#ef4444;background:#ef444426}.add-calendar-btn{padding:.75rem 1.5rem;background:var(--btn-secondary-bg);border:1px dashed var(--border-strong);border-radius:12px;color:var(--text);font:inherit;cursor:pointer;transition:border-color .2s,background .2s}.add-calendar-btn:hover{background:var(--btn-secondary-hover);border-color:var(--border)}.add-calendar-form{width:100%;max-width:400px;display:flex;flex-direction:column;gap:1rem;padding:1.25rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;box-sizing:border-box}.add-calendar-form__input{padding:.6rem .75rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--text);font:inherit;outline:none}.add-calendar-form__input:focus{border-color:var(--border-strong)}.add-calendar-form__input::placeholder{color:var(--text-muted)}.add-calendar-form__colors{display:flex;flex-wrap:wrap;gap:.5rem}.add-calendar-form__swatch{width:28px;height:28px;border-radius:8px;border:2px solid transparent;transition:transform .15s,border-color .15s}.add-calendar-form__swatch:hover{transform:scale(1.1)}.add-calendar-form__swatch--selected{border-color:var(--swatch-selected-border);box-shadow:0 0 0 1px var(--border)}.add-calendar-form__actions{display:flex;gap:.5rem;justify-content:flex-end}.btn{padding:.5rem 1rem;border-radius:8px;font:inherit;border:none;transition:opacity .2s,background .2s}.btn--primary{background:#3b82f6;color:#fff}.btn--primary:hover:not(:disabled){background:#2563eb}.btn--primary:disabled{opacity:.5;cursor:not-allowed}.btn--secondary{background:var(--btn-secondary-bg);color:var(--text)}.btn--secondary:hover{background:var(--btn-secondary-hover)}.calendar-screen{display:flex;flex-direction:column;gap:1rem;min-height:100%}.calendar-header{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;position:relative}.calendar-header__back{padding:.5rem;background:transparent;border:none;color:var(--text);font-size:1.25rem;cursor:pointer;border-radius:8px;transition:background .2s}.calendar-header__back:hover{background:var(--btn-secondary-bg)}.calendar-header__title{flex:1;font-size:1.25rem;font-weight:600;margin:0;text-align:center}.calendar-header--no-back .calendar-header__calendar-wrap{flex:1;position:relative;display:flex;justify-content:flex-start;align-items:center}.calendar-header__calendar-trigger{padding:.4rem .75rem;background:var(--btn-secondary-bg);border:1px solid var(--border-strong);border-radius:8px;color:inherit;font:inherit;font-size:1.1rem;font-weight:600;transition:background .2s,border-color .2s}.calendar-header__calendar-trigger:hover{background:var(--btn-secondary-hover);border-color:var(--border)}.calendar-header__edit-btn{padding:.5em .75em;margin-left:.25rem;background:var(--btn-secondary-bg);border:1px solid var(--border-strong);border-radius:8px;color:var(--text-muted);font-size:.875rem;transition:background .2s,color .2s,border-color .2s}.calendar-header__edit-btn:hover{background:var(--btn-secondary-hover);color:var(--text);border-color:var(--border)}.calendar-header__popover--left{left:0;right:auto;min-width:160px}.calendar-header__option--with-swatch{display:flex;align-items:center;gap:.5rem}.calendar-header__option-swatch{width:14px;height:14px;border-radius:4px;flex-shrink:0}.calendar-header__view-wrap{position:relative}.calendar-header__view-trigger{padding:.4rem .75rem;background:var(--btn-secondary-bg);border:1px solid var(--border-strong);border-radius:8px;color:inherit;font:inherit;transition:background .2s,border-color .2s}.calendar-header__view-trigger:hover{background:var(--btn-secondary-hover);border-color:var(--border)}.calendar-header__popover{position:absolute;top:100%;right:0;margin-top:.25rem;min-width:120px;padding:.25rem;background:var(--popover-bg);border:1px solid var(--popover-border);border-radius:8px;box-shadow:0 4px 12px #0003;z-index:10}.calendar-header__option{display:block;width:100%;padding:.5rem .75rem;background:transparent;border:none;border-radius:6px;color:inherit;font:inherit;text-align:left;transition:background .2s}.calendar-header__option:hover{background:var(--cell-bg)}.calendar-header__option--selected{background:#3b82f640}.calendar-header__option--action{border-top:1px solid var(--cell-bg);margin-top:.25rem;padding-top:.5rem;font-weight:500}.calendar-view{display:flex;flex-direction:column;gap:1rem}.calendar-view__nav{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.calendar-view__nav-btn{padding:.4rem .75rem;background:var(--btn-secondary-bg);border:1px solid var(--border);border-radius:8px;color:inherit;font:inherit;transition:background .2s}.calendar-view__nav-btn:hover:not(:disabled){background:var(--cell-bg-hover)}.calendar-view__nav-btn:disabled{opacity:.4}.calendar-view__period{font-size:1.1rem;font-weight:600;margin:0}.month-view__grid-wrap{display:flex;flex-direction:column;gap:.25rem}.month-view__day-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.month-view__day-header{padding:.4rem;font-size:.75rem;font-weight:600;color:var(--text-muted);text-align:center}.month-view__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.month-view__grid-wrap--weekdays-only .month-view__grid,.month-view__grid-wrap--weekdays-only .month-view__day-headers{grid-template-columns:repeat(5,1fr)}.month-view__cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:0;background:var(--cell-bg);border:none;border-radius:8px;color:inherit;font:inherit;font-size:.9rem;transition:background .2s,transform .1s}.month-view__cell:hover{background:var(--cell-bg-hover)}.month-view__cell--active{color:var(--cell-active-text);font-weight:600}.month-view__cell--active:hover{filter:brightness(1.1)}.month-view__cell--other-month{background-color:transparent;color:var(--text-muted);transition-property:background-color,color}.month-view__cell--other-month:hover{color:revert}.month-view__cell--today{box-shadow:inset 0 0 0 2px var(--today-ring)}.month-view__cell--future,.month-view__cell:disabled{opacity:.5;cursor:default;pointer-events:none}.month-view__cell.month-view__cell--future:hover,.month-view__cell:disabled:hover{background:var(--cell-bg)}.all-calendars-calendar__cell{flex-direction:column;gap:.2rem;cursor:default;pointer-events:none}.all-calendars-calendar__cell--clickable{pointer-events:auto}.all-calendars-calendar__cell--clickable:hover{background-color:var(--cell-bg-hover)}.all-calendars-calendar__cell .all-calendars-calendar__dots{pointer-events:auto}.all-calendars-calendar__day-num{font-size:.85rem;line-height:1}.all-calendars-calendar__dots{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:2px;max-width:100%}.all-calendars-calendar__dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;cursor:default}.all-calendars-calendar.week-view .week-view__cell--day.all-calendars-calendar__cell--clickable,.all-calendars-calendar.year-view .year-view__cell.all-calendars-calendar__cell--clickable{pointer-events:auto}.all-calendars-calendar.week-view .week-view__cell--day.all-calendars-calendar__cell--clickable:not(.week-view__cell--future):hover,.all-calendars-calendar.year-view .year-view__cell.all-calendars-calendar__cell--clickable:not(.year-view__cell--future):hover{background:var(--cell-bg-hover)}.week-view__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.week-view__grid.week-view__grid--weekdays-only{grid-template-columns:repeat(5,1fr)}.week-view__cell{padding:1rem .5rem;border-radius:8px;font:inherit;text-align:center;min-height:60px;display:flex;align-items:center;justify-content:center}.week-view__cell--header{font-size:.75rem;font-weight:600;color:var(--text-muted);background:transparent;border:none;cursor:default}.week-view__cell--day{background:var(--cell-bg);border:none;color:inherit;transition:background .2s}.week-view__cell--day:hover{background:var(--cell-bg-hover)}.week-view__cell--active{color:var(--cell-active-text);font-weight:600}.week-view__cell--active:hover{filter:brightness(1.1)}.week-view__cell--today{box-shadow:inset 0 0 0 2px var(--today-ring)}.week-view__cell--future,.week-view__cell--day:disabled{opacity:.5;cursor:default;pointer-events:none}.week-view__cell--future:hover,.week-view__cell--day:disabled:hover{background:var(--cell-bg)}.year-view__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem}.year-view__month{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;padding:.75rem}.year-view__month-title{font-size:.8rem;font-weight:600;margin-bottom:.5rem;color:var(--text-muted)}.year-view__month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.year-view__month-grid--weekdays-only{grid-template-columns:repeat(5,1fr)}.year-view__cell{aspect-ratio:1;min-height:22px;padding:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;background:var(--cell-bg);border:none;border-radius:4px;color:inherit;transition:background .2s}.year-view__cell:hover:not(:disabled){background:var(--cell-bg-hover)}.year-view__cell--active{color:var(--cell-active-text);font-weight:600}.year-view__cell--empty{visibility:hidden;pointer-events:none;cursor:default}.year-view__cell--today{box-shadow:inset 0 0 0 1px var(--today-ring)}.year-view__cell--future,.year-view__cell:disabled{opacity:.5;cursor:default;pointer-events:none}.year-view__cell:disabled:hover{background:var(--cell-bg)}.dialog__title{margin:0}.date-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--dialog-backdrop-bg);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;box-sizing:border-box}.date-dialog{background-color:#ffffff0d;-webkit-backdrop-filter:blur(.25em);backdrop-filter:blur(.25em);border-radius:1em;max-width:360px;width:100%;max-height:80vh;overflow:auto;padding:1em;display:flex;flex-direction:column;gap:.5rem}.date-dialog__header{display:flex;flex-direction:column;align-items:stretch;gap:.75rem;margin-block-end:1em;padding:0}.date-dialog__header-top{display:flex;justify-content:center}.date-dialog__header-nav{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.date-dialog__nav-btn{padding:.35rem .5rem;background:transparent;border:1px solid currentColor;font-size:1.1rem;line-height:1;border-radius:6px;flex-shrink:0;opacity:.75;transition:opacity .25s ease-in-out}.date-dialog__nav-btn:hover{opacity:1}.date-dialog__nav-btn:disabled{opacity:.4}.date-dialog__title{margin:0;font-size:1.1rem;font-weight:600;line-height:1.3;text-align:center;flex:1;min-width:0}.date-dialog__close{padding:.25rem;background:transparent;border:none;font-size:1.5rem;line-height:1;border-radius:6px;flex-shrink:0;opacity:.75;transition:opacity .25s ease-in-out}.date-dialog__close:hover{opacity:1}.date-dialog__calendars{padding:0;display:flex;flex-direction:column;gap:.5rem}.date-dialog__empty{margin:0;font-size:.95rem}.date-dialog__calendar-row{display:flex;align-items:center;gap:.75rem;width:100%;padding:.5rem .75rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.3);border-radius:8px;font:inherit;text-align:left;opacity:.6;transition:opacity .2s,background .2s}.date-dialog__calendar-row:hover{background:#ffffff14}.date-dialog__calendar-row--on{opacity:1}.date-dialog__calendar-row--green{border-color:#22c55e;color:#22c55e}.date-dialog__calendar-row--blue{border-color:#3b82f6;color:#3b82f6}.date-dialog__calendar-row--purple{border-color:#a855f7;color:#a855f7}.date-dialog__calendar-row--red{border-color:#ef4444;color:#ef4444}.date-dialog__calendar-row--amber{border-color:#f59e0b;color:#f59e0b}.date-dialog__calendar-row--pink{border-color:#ec4899;color:#ec4899}.date-dialog__calendar-row--cyan{border-color:#06b6d4;color:#06b6d4}.date-dialog__calendar-row--lime{border-color:#84cc16;color:#84cc16}.date-dialog__calendar-row--default{border-color:#ffffff4d;color:#ffffffb3}.date-dialog__calendar-swatch{width:20px;height:20px;border-radius:6px;flex-shrink:0}.date-dialog__calendar-swatch--green{background-color:#22c55e}.date-dialog__calendar-swatch--blue{background-color:#3b82f6}.date-dialog__calendar-swatch--purple{background-color:#a855f7}.date-dialog__calendar-swatch--red{background-color:#ef4444}.date-dialog__calendar-swatch--amber{background-color:#f59e0b}.date-dialog__calendar-swatch--pink{background-color:#ec4899}.date-dialog__calendar-swatch--cyan{background-color:#06b6d4}.date-dialog__calendar-swatch--lime{background-color:#84cc16}.date-dialog__calendar-swatch--default{background-color:#fff6}.date-dialog__calendar-name{flex:1;font-weight:500}.calendar-settings-checkboxes{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.calendar-settings-checkboxes__item{display:flex;align-items:center;gap:.5rem;font-size:.95rem}.calendar-settings-checkboxes__item input[type=checkbox]{width:1.1rem;height:1.1rem;accent-color:var(--border-strong);cursor:pointer}.calendar-settings-checkboxes__item input[type=checkbox]:disabled+span{color:var(--text-muted)}.calendars-visibility-dialog__hint{margin:0 0 1rem;font-size:.9rem;color:var(--text-muted);line-height:1.4}.calendars-visibility-dialog__list{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:.35rem}.calendars-visibility-dialog__item{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;border-radius:8px;cursor:pointer;transition:background .2s}.calendars-visibility-dialog__item:hover{background:var(--cell-bg)}.calendars-visibility-dialog__item input[type=checkbox]{width:1.1rem;height:1.1rem;accent-color:var(--border-strong);cursor:pointer}.calendars-visibility-dialog__swatch{width:1rem;height:1rem;border-radius:4px;flex-shrink:0}.calendars-page-settings__title{margin-block-start:0}@media(prefers-reduced-motion:reduce){*,:before,:after{animation:none!important;transition-duration:.01ms!important}}
