.app-settings{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer}.app-settings:hover{color:var(--color-text);background:var(--color-muted-bg)}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;display:flex;align-items:center;justify-content:center;z-index:300;animation:settingsFadeIn .25s cubic-bezier(.16,1,.3,1) forwards}.settings-backdrop.minimap-mode{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}@keyframes settingsFadeIn{0%{opacity:0}to{opacity:1}}@keyframes settingsScaleUp{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.settings-card{width:420px;max-width:calc(100vw - 2 * var(--space-4));max-height:calc(100vh - 2 * var(--space-5));overflow-y:auto;background:var(--color-surface);border-radius:16px;box-shadow:0 30px 60px #0000001f,0 0 0 1px #0000000a;border:1px solid rgba(255,255,255,.7);padding:24px 28px 28px;animation:settingsScaleUp .3s cubic-bezier(.16,1,.3,1) forwards}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.settings-header h2{font-size:19px;font-weight:600;margin:0;color:var(--color-text)}.settings-close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--color-muted-bg);color:var(--color-text-secondary);border:none;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1)}.settings-close:hover{background:var(--color-border-strong);color:var(--color-text);transform:rotate(90deg)}.settings-section{padding:20px 0 0;border-top:1px solid rgba(0,0,0,.06)}.settings-section h3{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary);margin:0 0 12px}.settings-empty{font-size:12px;line-height:1.5;color:var(--color-text-secondary);margin:0 0 16px;opacity:.85}.settings-actions{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:24px}.settings-connect{display:flex;align-items:center;text-align:left;font-size:13px;font-weight:500;padding:12px 16px;border:1px solid transparent;border-radius:10px;background:var(--color-muted-bg);color:var(--color-text);cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1)}.settings-btn-icon{margin-right:12px;color:var(--color-text);opacity:.8;transition:transform .2s ease}.settings-connect:hover{background:var(--color-border)}.settings-connect:hover .settings-btn-icon{transform:scale(1.1)}.settings-field{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);font-size:13px}.settings-field select{font-family:inherit;font-size:13px;padding:var(--space-1) var(--space-2);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm)}.settings-subhead{margin-top:var(--space-5);margin-bottom:var(--space-2)}.settings-mode{width:100%;font-family:inherit;font-size:13px;font-weight:500;padding:10px 14px;border:1px solid transparent;background-color:var(--color-muted-bg);border-radius:10px;color:var(--color-text);cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2386868b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:12px;padding-right:40px!important;transition:all .2s ease}.settings-mode:hover{background-color:var(--color-border)}.settings-mode:focus{outline:none;border-color:var(--color-accent);background-color:var(--color-surface);box-shadow:0 0 0 3px var(--color-accent-soft)}.settings-month-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2);margin-top:var(--space-3)}.settings-month.is-disabled{color:var(--color-text-faint);background:#00000003;border-color:transparent;cursor:not-allowed;opacity:.6}.settings-month{display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;padding:8px 6px;border:1px solid transparent;background:var(--color-muted-bg);border-radius:8px;cursor:pointer;color:var(--color-text-secondary);transition:all .2s ease;-webkit-user-select:none;user-select:none}.settings-month input[type=checkbox]{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.settings-month:hover:not(.is-disabled){background:var(--color-border);color:var(--color-text)}.settings-month.is-checked{background:var(--color-accent-soft);border-color:var(--color-accent);color:var(--color-accent)}.settings-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--color-border-strong);outline:none;transition:background .2s}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-accent);cursor:pointer;box-shadow:0 1px 3px #0003;transition:transform .1s ease}.settings-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.settings-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-accent);cursor:pointer;border:none;box-shadow:0 1px 3px #0003;transition:transform .1s ease}.settings-slider::-moz-range-thumb:hover{transform:scale(1.15)}.settings-size-reset-btn{background:none;border:none;color:var(--color-accent);cursor:pointer;padding:0;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background-color .1s,opacity .15s ease}.settings-size-reset-btn:hover:not(:disabled){background-color:var(--color-accent-soft)}.settings-size-reset-btn:disabled{color:var(--color-text-faint);cursor:not-allowed;opacity:.35}.settings-reset-btn{display:block;width:100%;font-family:inherit;font-size:13px;font-weight:500;padding:10px 14px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);border-radius:10px;cursor:pointer;margin-top:var(--space-5);margin-bottom:var(--space-4);text-align:center;transition:all .2s ease}.settings-reset-btn:hover{background:var(--color-muted-bg);color:var(--color-text);border-color:var(--color-border-strong)}@media(max-width:768px){.settings-backdrop{align-items:flex-end}.settings-card{width:100%;max-width:100%;max-height:90dvh;border-radius:18px 18px 0 0;padding:20px 20px calc(24px + env(safe-area-inset-bottom))}.settings-header h2{font-size:20px}.settings-close{width:32px;height:32px}.settings-connect{padding:14px 16px;font-size:15px}.settings-mode{padding:13px 16px;font-size:16px;padding-right:44px!important}.settings-empty{font-size:13px}.settings-month-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.settings-month{padding:12px 6px;font-size:14px}.settings-reset-btn{padding:13px;font-size:15px}.color-circle{width:30px;height:30px}.color-options{gap:var(--space-3);flex-wrap:wrap}}.settings-cleanup-btn{display:block;width:100%;font-family:inherit;font-size:13px;font-weight:500;padding:10px 14px;border:1px solid rgba(255,69,58,.3);background:transparent;color:var(--color-danger, #ff453a);border-radius:10px;cursor:pointer;margin-top:var(--space-4);margin-bottom:var(--space-4);text-align:center;transition:all .2s ease}.settings-cleanup-btn:hover{background:#ff453a14;border-color:var(--color-danger, #ff453a)}.settings-calendar-list{margin-top:var(--space-3);margin-bottom:var(--space-4);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;background:var(--color-muted-bg)}.settings-calendar-item{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;padding:12px 16px;transition:background-color .15s ease}.settings-calendar-item:hover{background-color:#00000005}.settings-calendar-item input[type=checkbox]{width:18px;height:18px;border-radius:4px;cursor:pointer}.settings-calendar-label{font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;width:100%}.settings-calendar-name{color:var(--color-text)}.settings-calendar-count{color:var(--color-text-secondary);font-size:12px;margin-left:auto;opacity:.8}@media(max-width:768px){.settings-cleanup-btn{padding:13px;font-size:15px}}.popover{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-popover);padding:var(--space-3);min-width:260px;z-index:100}.popover-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;display:flex;align-items:flex-end;justify-content:center;background:#0006;animation:sheetBackdropIn .2s ease forwards}.popover.popover-sheet{width:100%;max-width:520px;min-width:0;max-height:90dvh;overflow-y:auto;border:none;border-radius:18px 18px 0 0;padding:var(--space-3) var(--space-4) calc(var(--space-4) + env(safe-area-inset-bottom));box-shadow:0 -10px 40px #00000038;animation:sheetUp .28s cubic-bezier(.16,1,.3,1) forwards}.sheet-grabber{width:36px;height:4px;border-radius:999px;background:var(--color-border-strong);margin:2px auto var(--space-3)}.popover-sheet .event-editor,.popover-sheet .quick-entry,.popover-sheet .delete-choices-container{width:100%}@keyframes sheetBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.popover.popover-sheet,.popover-backdrop{animation:none}}.month-grid{display:flex;flex-direction:column;height:100%;padding:var(--space-4) var(--space-5);--effective-tile-scale: calc(var(--tile-scale, 1) * 1.6)}.month-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-3)}.month-title{font-size:20px;font-weight:700;margin:0}.month-year{color:var(--color-text-secondary);font-weight:400}.month-nav{display:flex;align-items:center;gap:var(--space-2)}.month-today-btn{background:none;border:none;color:var(--color-text-secondary);font-size:13px;cursor:pointer;padding:var(--space-1) var(--space-2)}.month-nav button:hover{color:var(--color-text)}.tile-zoom-control{display:inline-flex;align-items:center;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px;gap:2px;margin-right:var(--space-1);height:28px}.tile-zoom-percent{font-size:11px;font-weight:600;color:var(--color-text-secondary);padding:0 4px;-webkit-user-select:none;user-select:none;min-width:36px;text-align:center}.tile-zoom-btn{background:transparent;border:none;color:var(--color-text-secondary);font-size:14px;font-weight:600;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px;transition:background-color .1s;padding:0}.tile-zoom-btn:hover:not(:disabled){background:var(--color-border);color:var(--color-text)}.tile-zoom-btn:disabled{opacity:.35;cursor:not-allowed}.tile-zoom-reset{background:none;border:none;color:var(--color-accent);cursor:pointer;padding:0;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .1s,opacity .15s ease}.tile-zoom-reset:hover:not(:disabled){background:var(--color-accent-soft)}.tile-zoom-reset:disabled{color:var(--color-text-faint);cursor:not-allowed;opacity:.35}.month-nav button:disabled{color:var(--color-text-faint);cursor:default}.weekday-row{display:grid;grid-template-columns:repeat(7,1fr);font-size:12px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.weekday-row>div{padding:var(--space-1)}.week-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;overflow-anchor:none;scrollbar-width:thin;scrollbar-color:var(--color-border-strong) transparent}.week-row{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-1);padding-bottom:var(--space-1)}.day-tile{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:calc(var(--space-1) * var(--effective-tile-scale)) calc(var(--space-2) * var(--effective-tile-scale));font-size:calc(12px * var(--effective-tile-scale));cursor:pointer;overflow:hidden;display:flex;flex-direction:column;gap:calc(2px * var(--effective-tile-scale));min-height:0;-webkit-user-select:none;user-select:none}.day-tile:hover{border-color:var(--color-border-strong)}.month-tint-a{background:var(--color-surface)}.month-tint-b{background:var(--color-muted-bg)}.month-marker{display:inline-block;margin-right:calc(var(--space-1) * var(--effective-tile-scale));padding:0 calc(var(--space-1) * var(--effective-tile-scale));border-radius:4px;background:var(--color-accent-soft);color:var(--color-accent);font-size:calc(10px * var(--effective-tile-scale));font-weight:700;letter-spacing:.02em;text-transform:uppercase}.day-tile-today{border:2px solid var(--color-accent)}.day-tile-today .day-number{font-weight:700}.event-chip{display:block;width:100%;text-align:left;box-sizing:border-box;background:color-mix(in srgb,var(--event-color, var(--color-accent)) 8%,transparent);color:var(--color-text);border:none;border-left:3px solid var(--event-color, var(--color-accent));border-radius:4px;padding:calc(2px * var(--effective-tile-scale)) calc(6px * var(--effective-tile-scale));font-size:calc(10px * var(--effective-tile-scale));font-weight:500;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-user-drag:element;user-drag:element;transition:background-color .15s ease,filter .15s ease,box-shadow .15s ease}.event-time{font-weight:600;margin-right:4px;color:var(--event-color, var(--color-accent))}.event-chip:hover{background:color-mix(in srgb,var(--event-color, var(--color-accent)) 14%,transparent);box-shadow:0 1px 3px #0000000d,0 1px 2px #00000005}.event-chip:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-surface),0 0 0 4px var(--event-color, var(--color-accent))}.event-chip-allday{background:var(--event-color, var(--color-muted-bg));color:var(--event-text-color, var(--color-text));border-left:none;border-radius:4px;font-weight:600;transition:background-color .15s ease,filter .15s ease,box-shadow .15s ease}.event-chip-allday:hover{background:var(--event-color, var(--color-muted-bg));filter:brightness(.93);box-shadow:0 1px 3px #0000000d,0 1px 2px #00000005}.month-tint-b .event-chip-allday{background:var(--event-color, var(--color-surface))}.month-tint-b .event-chip-allday:hover{background:var(--event-color, var(--color-surface));filter:brightness(.93)}.event-more{font-size:calc(9px * var(--effective-tile-scale));color:var(--color-text-faint)}.span-seg{display:block;width:auto;margin:0 calc(-1 * var(--space-2) * var(--effective-tile-scale));padding:calc(2.5px * var(--effective-tile-scale)) calc(6px * var(--effective-tile-scale));font-size:calc(10px * var(--effective-tile-scale));font-weight:600;line-height:1.3;text-align:left;background:var(--event-color, var(--color-accent-soft));color:var(--event-text-color, var(--color-accent));border:none;border-radius:0;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:filter .15s ease,box-shadow .15s ease}.span-seg:hover{filter:brightness(.94)}.span-seg:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-surface),0 0 0 4px var(--event-color, var(--color-accent))}.span-seg-start{margin-left:calc(2px * var(--effective-tile-scale));border-top-left-radius:6px;border-bottom-left-radius:6px}.span-seg-end{margin-right:calc(2px * var(--effective-tile-scale));border-top-right-radius:6px;border-bottom-right-radius:6px}.span-seg.is-selected{outline:2px solid var(--event-color, var(--color-accent));outline-offset:1px}.day-tile.is-drag-range{border-color:var(--color-accent);background:var(--color-accent-soft)}@media(max-width:768px){.month-grid{padding:var(--space-3) var(--space-2) 0}.month-header{padding:0 var(--space-1) var(--space-2)}.month-title{font-size:22px}.month-nav>button:first-child{font-size:14px;padding:var(--space-2)}.month-nav .app-settings{width:38px;height:38px}.month-nav .app-settings svg{width:20px;height:20px}.weekday-row{padding:0 var(--space-1);font-size:10px}.week-row{gap:3px}.day-tile{padding:3px 4px;border-radius:5px}.day-number{font-size:13px}.event-chip{padding:2px 4px;font-size:10px}.month-marker{font-size:9px}}.event-chip.is-selected{outline:2px solid var(--event-color, var(--color-accent));outline-offset:1px;box-shadow:0 0 0 2px var(--color-surface)}.day-tile.is-drag-over{border-color:var(--color-accent);background:var(--color-accent-soft);box-shadow:inset 0 0 0 1px var(--color-accent)}.upcoming-panel{display:flex;flex-direction:column;height:100%}.upcoming-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-4) var(--space-2)}.upcoming-header .panel-label{padding:0}.upcoming-add{width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);font-size:18px;font-weight:400;line-height:1;cursor:pointer}.upcoming-add:hover{color:var(--color-accent);border-color:var(--color-accent)}.upcoming-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-2);padding:0 var(--space-4) var(--space-4)}.upcoming-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);text-align:left;cursor:pointer;flex-shrink:0}.upcoming-card:hover{border-color:var(--color-border-strong)}.upcoming-title{font-size:18px;font-weight:600}.upcoming-date{font-size:15px;color:var(--color-text-secondary)}.upcoming-repeat{color:var(--color-accent)}.upcoming-type{font-weight:600;text-transform:capitalize;background:linear-gradient(90deg,#6366f1,#a855f7,#ec4899,#f59e0b,#6366f1);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:upcoming-type-shift 6s linear infinite}@keyframes upcoming-type-shift{to{background-position:300% 50%}}@media(prefers-reduced-motion:reduce){.upcoming-type{animation:none}}.upcoming-card{display:flex;align-items:flex-start;gap:var(--space-2)}.upcoming-card-body{display:flex;flex-direction:column;gap:2px;min-width:0}.upcoming-card.is-selected{border-color:var(--color-accent);background:var(--color-accent-soft, rgba(10, 132, 255, .12))}.upcoming-check{flex-shrink:0;width:16px;height:16px;margin-top:1px;border:1.5px solid var(--color-border-strong);border-radius:4px;position:relative}.upcoming-check.is-checked{background:var(--color-accent);border-color:var(--color-accent)}.upcoming-check.is-checked:after{content:"";position:absolute;left:5px;top:1px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.upcoming-empty{font-size:17px;color:var(--color-text-faint);padding:var(--space-2) 0}.ongoing-section{display:flex;flex-direction:column;gap:var(--space-2);padding:0 var(--space-4) var(--space-3)}.panel-sublabel{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.ongoing-card{align-items:center}.ongoing-dot{flex-shrink:0;width:10px;height:10px;border-radius:50%;background:var(--color-accent)}.upcoming-header-actions{display:flex;align-items:center;gap:var(--space-2);flex:1;justify-content:flex-end;margin-left:var(--space-3)}.upcoming-search-mini{width:120px;padding:var(--space-1) var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:17px;box-sizing:border-box;transition:width .15s ease,border-color .15s ease}.upcoming-search-mini:focus{outline:none;border-color:var(--color-accent);width:160px}.upcoming-filter-btn{width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;box-sizing:border-box}.upcoming-filter-btn:hover,.upcoming-filter-btn.active{color:var(--color-accent);border-color:var(--color-accent)}.upcoming-popover-content{display:flex;flex-direction:column;gap:var(--space-2)}.upcoming-popover-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.upcoming-popover-row label{font-size:15px;font-weight:500;color:var(--color-text-secondary)}.upcoming-select{width:140px;padding:var(--space-1) var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:15px;cursor:pointer;box-sizing:border-box}.upcoming-select:focus{outline:none;border-color:var(--color-accent)}.upcoming-reset-btn{margin-top:var(--space-2);padding:var(--space-1) var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);font-size:15px;cursor:pointer;width:100%;text-align:center;box-sizing:border-box;transition:all .15s ease}.upcoming-reset-btn:hover:not(:disabled){background:var(--color-muted-bg);color:var(--color-text);border-color:var(--color-border-strong)}.upcoming-reset-btn:disabled{opacity:.5;cursor:not-allowed;border-color:var(--color-border)}.upcoming-delete-btn{margin-left:auto;align-self:center;opacity:0;pointer-events:none;background:transparent;border:none;color:var(--color-text-secondary);padding:var(--space-1);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .15s ease,color .15s ease,background-color .15s ease}.upcoming-card:hover .upcoming-delete-btn{opacity:1;pointer-events:auto}.upcoming-delete-btn:hover{color:var(--color-danger);background-color:#ff3b301a}@media(max-width:768px){.upcoming-header{padding:var(--space-4) var(--space-4) var(--space-3);gap:var(--space-2)}.upcoming-header .panel-label{font-size:13px}.upcoming-search-mini{flex:1;width:auto;min-width:0;padding:9px 12px;border-radius:var(--radius-md)}.upcoming-search-mini:focus{width:auto}.upcoming-add,.upcoming-filter-btn{width:40px;height:40px;flex-shrink:0;border-radius:var(--radius-md)}.upcoming-add svg,.upcoming-filter-btn svg{width:18px;height:18px}.upcoming-list{gap:var(--space-2);padding:0 var(--space-4) var(--space-5)}.upcoming-card{padding:var(--space-3)}.upcoming-title{font-size:15px}.upcoming-date{font-size:13px;margin-top:2px}.popover-sheet .upcoming-popover-content{gap:var(--space-3)}.popover-sheet .upcoming-popover-row label{font-size:14px}.popover-sheet .upcoming-select{width:60%;padding:10px 12px;font-size:16px}.popover-sheet .upcoming-reset-btn{padding:12px;font-size:15px}}.year-circle-panel{display:flex;flex-direction:column;height:100%;position:relative}.year-settings{position:absolute;top:var(--space-3);right:var(--space-3);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;opacity:0;transition:opacity .12s ease;z-index:2}.year-circle-panel:hover .year-settings,.year-settings:focus-visible{opacity:1}.year-settings:hover{color:var(--color-text);background:var(--color-muted-bg)}.year-circle-body{flex:1;display:flex;align-items:center;justify-content:center;min-height:0;padding:var(--space-2) var(--space-4) var(--space-4);position:relative}.year-circle-svg{height:100%;width:100%;max-height:calc(448px * var(--minimap-scale, 1));max-width:calc(448px * var(--minimap-scale, 1));cursor:pointer;transition:max-height .25s cubic-bezier(.16,1,.3,1),max-width .25s cubic-bezier(.16,1,.3,1)}.year-ring{fill:none;stroke:var(--color-border);stroke-width:1.5}.month-tick{fill:var(--color-text-faint);font-size:12px;text-anchor:middle}.today-marker,.today-arrow{fill:var(--color-accent)}.viewed-arrow{fill:var(--color-text-faint)}.viewed-arrow-group{transform-box:view-box;transform-origin:130px 130px;transition:transform .45s cubic-bezier(.22,1,.36,1),opacity .45s cubic-bezier(.22,1,.36,1);opacity:0;pointer-events:none}.viewed-arrow-group.is-visible{opacity:1;pointer-events:auto}@media(prefers-reduced-motion:reduce){.viewed-arrow-group{transition:none}}.year-tick-line{stroke:var(--color-text);stroke-width:2.5px;stroke-linecap:round;cursor:pointer}.year-tick-line:hover{stroke:var(--color-accent)}.year-band{fill:none;stroke:var(--color-accent);stroke-width:6px;stroke-linecap:round;opacity:.85;cursor:pointer}.year-band:hover{opacity:1;stroke-width:7px}.year-label{fill:var(--color-text);font-size:20px;font-weight:600;text-anchor:middle;cursor:pointer;transition:fill .12s ease}.year-label:hover{fill:var(--color-accent)}.year-input{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:20px;font-weight:600;text-align:center;padding:var(--space-1) var(--space-2);outline:none;font-family:inherit;box-shadow:0 2px 8px #0000001a}.year-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px #0a84ff26}@media(max-width:768px){.year-settings{opacity:1;width:40px;height:40px;top:var(--space-2);right:var(--space-2)}.year-settings svg{width:20px;height:20px}.year-circle-svg{max-height:min(70vh,460px)}.month-tick{font-size:8px}.year-tick-line{stroke-width:3px}}.main-screen{display:grid;grid-template-columns:var(--sidebar-width, 30%) 1fr;height:100%;overflow:hidden;position:relative}.sidebar{display:grid;grid-template-rows:var(--sidebar-split, 50%) 1fr;border-right:none;min-width:0;position:relative;height:100%;overflow:hidden}.sidebar-top{position:relative;overflow:hidden;min-height:0;height:100%}.sidebar-bottom{overflow:hidden;min-height:0;height:100%}.main-panel{position:relative;overflow:hidden;min-width:0;height:100%}.panel-label{font-size:14px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary);padding:var(--space-4) var(--space-4) var(--space-2)}.minimap-settings-active .sidebar-top:after,.minimap-settings-active .main-panel:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0000001a;z-index:10;pointer-events:none;animation:settingsFadeIn .25s cubic-bezier(.16,1,.3,1) forwards}.main-screen-mobile{display:flex;flex-direction:column;height:100%;height:100dvh;overflow:hidden}.mobile-view{flex:1;min-height:0;position:relative}.mobile-pane{height:100%;min-height:0}.mobile-pane[hidden]{display:none}.mobile-tabbar{display:flex;flex-shrink:0;border-top:1px solid var(--color-border);background:var(--color-surface);padding-bottom:env(safe-area-inset-bottom)}.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px 10px;border:none;background:none;color:var(--color-text-secondary);cursor:pointer;font-size:12px;font-weight:500;letter-spacing:.02em;-webkit-tap-highlight-color:transparent}.mobile-tab svg{opacity:.85}.mobile-tab.is-active{color:var(--color-accent)}.mobile-tab.is-active svg{opacity:1}.resize-handle-h{position:absolute;top:0;bottom:0;left:calc(var(--sidebar-width, 30%) - 3px);width:6px;cursor:col-resize;z-index:100;background-color:transparent;touch-action:none}.resize-handle-h:after{content:"";position:absolute;top:0;bottom:0;left:2px;width:1px;background-color:var(--color-border);transition:background-color .15s ease,width .15s ease,left .15s ease}.resize-handle-h:hover:after,.resize-handle-h.is-dragging:after{background-color:var(--color-accent);width:3px;left:1px}.resize-handle-v{position:absolute;left:0;right:0;top:calc(var(--sidebar-split, 50%) - 3px);height:6px;cursor:row-resize;z-index:100;background-color:transparent;touch-action:none}.resize-handle-v:after{content:"";position:absolute;left:0;right:0;top:2px;height:1px;background-color:var(--color-border);transition:background-color .15s ease,height .15s ease,top .15s ease}.resize-handle-v:hover:after,.resize-handle-v.is-dragging:after{background-color:var(--color-accent);height:3px;top:1px}body.is-dragging-h{cursor:col-resize!important;-webkit-user-select:none!important;user-select:none!important}body.is-dragging-v{cursor:row-resize!important;-webkit-user-select:none!important;user-select:none!important}.auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:var(--space-4)}.auth-card{width:360px;max-width:100%;display:flex;flex-direction:column;background:var(--color-surface);border-radius:16px;box-shadow:0 30px 60px #0000001f,0 0 0 1px #0000000a;padding:32px 28px}.auth-title{font-size:22px;font-weight:600;margin:0;color:var(--color-text);text-align:center}.auth-subtitle{font-size:13px;color:var(--color-text-secondary);margin:6px 0 24px;text-align:center}.auth-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:6px}.auth-input{font-family:inherit;font-size:14px;padding:10px 12px;margin-bottom:16px;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);transition:border-color .15s ease,box-shadow .15s ease}.auth-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.auth-submit{font-family:inherit;font-size:14px;font-weight:600;padding:11px 16px;margin-top:4px;border:none;border-radius:var(--radius-md);background:var(--color-accent);color:#fff;cursor:pointer;transition:opacity .15s ease,transform .1s ease}.auth-submit:hover:not(:disabled){opacity:.92}.auth-submit:active:not(:disabled){transform:scale(.99)}.auth-submit:disabled{opacity:.6;cursor:default}.auth-error{font-size:12px;color:var(--color-danger);margin:0 0 12px}.auth-info{font-size:12px;color:var(--color-accent);margin:0 0 12px}.auth-switch{font-size:12px;color:var(--color-text-secondary);text-align:center;margin:18px 0 0}.auth-switch button{border:none;background:none;padding:0;font-size:12px;font-weight:600;color:var(--color-accent);cursor:pointer}.auth-switch button:hover{text-decoration:underline}.quick-entry{display:flex;flex-direction:column;gap:var(--space-2);width:280px}.quick-entry-input{font-family:inherit;font-size:13px;padding:var(--space-2) var(--space-3);border:1px solid var(--color-accent);border-radius:var(--radius-sm);outline:none}.quick-entry-preview-container{display:flex;flex-direction:column;gap:var(--space-1);--effective-tile-scale: 1.25;margin-top:2px;margin-bottom:2px}.quick-entry-preview-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.event-chip.is-empty-preview{color:var(--color-text-faint);font-style:italic}.quick-entry-hint{font-size:10px;color:var(--color-text-faint)}@media(max-width:768px){.quick-entry{gap:var(--space-3)}.quick-entry-input{padding:12px 14px;border-radius:var(--radius-md)}.quick-entry-preview-container{--effective-tile-scale: 1.45}.quick-entry-hint{font-size:12px}}.color-options{display:flex;gap:var(--space-2);align-items:center}.color-circle{width:20px;height:20px;border-radius:50%;border:1px solid var(--color-border-strong);cursor:pointer;padding:0;position:relative;box-sizing:border-box;transition:transform .12s ease,border-color .12s ease;display:flex;align-items:center;justify-content:center;background:none}.color-circle:hover{transform:scale(1.15)}.color-circle.selected{border:2px solid var(--color-text);box-shadow:0 0 0 2px var(--color-accent-soft)}.default-slash{width:100%;height:1.5px;background:var(--color-text-secondary);transform:rotate(-45deg);display:block}.custom-color-circle{background:conic-gradient(red,#ff0,green,#0ff,#00f,#f0f,red);color:var(--color-text-secondary);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}.custom-color-circle.selected{background-image:none}.hidden-color-input{position:absolute;width:0;height:0;opacity:0;padding:0;margin:0;border:none;cursor:pointer}.palette-icon{font-size:10px;font-weight:700;display:inline-block;transform:translateY(-.5px)}.event-editor{display:flex;flex-direction:column;gap:var(--space-3);width:300px}.event-editor input,.event-editor textarea,.event-editor select{font-family:inherit;font-size:13px;color:var(--color-text);padding:7px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);outline:none;transition:border-color .12s ease,box-shadow .12s ease}.event-editor input:focus,.event-editor textarea:focus,.event-editor select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.editor-title{font-size:15px;font-weight:600}.editor-row{display:flex;gap:var(--space-2);align-items:center}.editor-row>input[type=date],.editor-row>input[type=time]{flex:1;min-width:0}.event-editor textarea{resize:vertical;min-height:56px}.editor-label{display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--color-text-secondary)}.editor-label select{flex:1}.editor-label input[type=number]{width:56px}.editor-actions{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-top:var(--space-1)}.editor-save{background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .12s ease}.editor-save:hover{opacity:.9}.editor-save:disabled{opacity:.4;cursor:default}.editor-delete{background:none;border:none;color:var(--color-text-secondary);font-size:13px;cursor:pointer;padding:8px 4px}.editor-delete:hover{color:var(--color-danger)}.delete-choices-container{display:flex;flex-direction:column;gap:var(--space-3);width:300px}.delete-choices-title{font-size:15px;font-weight:600;color:var(--color-text)}.delete-choices-desc{font-size:13px;color:var(--color-text-secondary);line-height:1.4}.delete-choices-actions{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-1)}.delete-choice-btn{background:var(--color-muted-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all .12s ease;font-family:inherit}.delete-choice-btn:hover{background:var(--color-border-strong)}.delete-choice-btn.danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.delete-choice-btn.danger:hover{opacity:.9}.delete-choice-cancel{background:none;border:none;color:var(--color-text-secondary);font-size:13px;cursor:pointer;padding:8px 12px;text-align:center;font-family:inherit}.delete-choice-cancel:hover{color:var(--color-text)}.color-selector-row{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-1);margin-bottom:var(--space-1)}.color-label{font-size:13px;color:var(--color-text-secondary)}.ios-switch-label{display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--color-text-secondary);margin-left:auto;cursor:pointer;-webkit-user-select:none;user-select:none}.minimap-toggle-row{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-1);margin-bottom:var(--space-1)}.minimap-toggle-row .ios-switch-label{width:100%;justify-content:space-between;margin-left:0}.ios-switch{position:relative;display:inline-block;width:36px;height:20px}.ios-switch input{opacity:0;width:0;height:0}.ios-switch-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-border);transition:.2s ease;border-radius:20px}.ios-switch-slider:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:var(--color-surface);transition:.2s ease;border-radius:50%;box-shadow:0 1px 3px #00000026}.ios-switch input:checked+.ios-switch-slider{background-color:#30d158}.ios-switch input:checked+.ios-switch-slider:before{transform:translate(16px)}@media(max-width:768px){.event-editor{gap:var(--space-4)}.event-editor input,.event-editor textarea,.event-editor select{padding:11px 12px;border-radius:var(--radius-md)}.editor-title{font-size:18px}.editor-row{flex-wrap:wrap}.editor-row>input[type=date],.editor-row>input[type=time]{min-width:120px}.editor-label{font-size:15px}.editor-label input[type=number]{width:72px}.event-editor textarea{min-height:72px}.color-label,.ios-switch-label{font-size:15px}.color-options{gap:var(--space-3)}.color-circle{width:28px;height:28px}.ios-switch{width:46px;height:28px}.ios-switch-slider{border-radius:28px}.ios-switch-slider:before{height:24px;width:24px}.ios-switch input:checked+.ios-switch-slider:before{transform:translate(18px)}.editor-actions{margin-top:var(--space-2)}.editor-save{padding:12px 24px;font-size:15px}.editor-delete{padding:12px 8px;font-size:15px}.delete-choices-title{font-size:17px}.delete-choices-desc{font-size:15px}.delete-choice-btn,.delete-choice-cancel{padding:13px 12px;font-size:15px}}.span-date-row{gap:var(--space-3)}.span-date-row .editor-label{flex:1}.span-date-row input[type=date]{width:100%}.span-chooser{display:flex;flex-direction:column;gap:var(--space-2);min-width:160px}.span-chooser-label{font-size:13px;font-weight:600;color:var(--color-text-secondary)}.span-chooser-btn{text-align:left;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:14px;cursor:pointer}.span-chooser-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.span-day-heading{font-size:13px;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-1)}.span-day-clear-time{align-self:flex-end;background:none;border:none;color:var(--color-accent);font-size:13px;cursor:pointer;padding:var(--space-1)}.selection-bar{position:fixed;left:50%;bottom:var(--space-4, 16px);transform:translate(-50%);z-index:1000;display:flex;align-items:center;gap:var(--space-3, 12px);padding:var(--space-2, 8px) var(--space-3, 12px);min-width:320px;max-width:calc(100vw - 32px);background:var(--color-surface, #1c1c1e);color:var(--color-text, #fff);border:1px solid var(--color-border, rgba(255, 255, 255, .12));border-radius:var(--radius-lg, 12px);box-shadow:0 8px 28px #00000059}.selection-count{font-size:13px;font-weight:500}.selection-spacer{flex:1}.selection-link{background:none;border:none;color:var(--color-accent, #0a84ff);font-size:13px;font-weight:500;cursor:pointer;padding:var(--space-1, 4px) var(--space-2, 8px);border-radius:var(--radius-sm, 6px)}.selection-link:hover{background:var(--color-accent-soft, rgba(10, 132, 255, .12))}.selection-confirm-text{font-size:13px;color:var(--color-text-secondary, rgba(255, 255, 255, .7))}.selection-danger{background:var(--color-danger, #ff453a);color:#fff;border:none;font-size:13px;font-weight:500;cursor:pointer;padding:var(--space-1, 4px) var(--space-3, 12px);border-radius:var(--radius-sm, 6px)}.selection-danger:disabled{opacity:.45;cursor:default}.toast{position:fixed;bottom:var(--space-5);left:50%;transform:translate(-50%);background:var(--color-text);color:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);font-size:13px;box-shadow:var(--shadow-popover);cursor:pointer;z-index:1000;max-width:480px}:root{--color-bg: #fafafa;--color-surface: #ffffff;--color-border: #e3e3e6;--color-border-strong: #d9d9de;--color-text: #1d1d1f;--color-text-secondary: #86868b;--color-text-faint: #aeaeb2;--color-accent: #0a84ff;--color-accent-soft: #eaf3ff;--color-muted-bg: #f5f5f7;--color-danger: #ff3b30;--radius-sm: 6px;--radius-md: 10px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--font-stack: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--shadow-popover: 0 8px 24px rgba(0, 0, 0, .14)}*{box-sizing:border-box}html{zoom:var(--font-scale, 1)}html,body,#root{height:100%;margin:0}body{font-family:var(--font-stack);background:var(--color-bg);color:var(--color-text);font-size:14px;-webkit-font-smoothing:antialiased}button,input,select,textarea{font-family:inherit;font-size:inherit}@media(max-width:768px){input,textarea,select{font-size:16px!important}}
