:root{--espresso: #3E2723;--coffee: #6F4E37;--caramel: #8B5A2B;--sunrise: #F5A65B;--foam: #F5E6D3;--cream: #FBF3E4;--linen: #FFFDF8;--tan: #E8D5B7;--bg-page: var(--cream);--bg-surface: var(--linen);--bg-surface-muted: #F8EBD5;--cal-block-bg: #EAD7B4;--text-primary: var(--espresso);--text-secondary: var(--coffee);--border: var(--tan);--border-strong: var(--coffee);--text-hover: #4A3122;--hover-fill: var(--foam);--row-hover: rgba(245, 230, 211, .35);--border-hover: var(--coffee);--btn-primary-bg: var(--espresso);--btn-primary-fg: var(--linen);--btn-primary-bg-hover: #2C1B17;--chart-fill: var(--coffee);--chart-fill-alt: var(--caramel);--chart-track: var(--foam);--chart-ramp-0: var(--foam);--chart-ramp-1: var(--tan);--chart-ramp-2: var(--caramel);--chart-ramp-3: var(--coffee);--chart-ramp-4: var(--espresso);--danger: #B5483F;--danger-bg: #F0D6D2;--logo-body: var(--espresso);--logo-rim: #1F1410;--swatch-edge: rgba(0, 0, 0, .1);--modal-scrim: rgba(31, 20, 16, .45);--focus-ring: rgba(139, 90, 43, .15);--chip-wash: rgba(139, 90, 43, .12);--chip-wash-border: rgba(139, 90, 43, .25);--font-display: "Fraunces", Georgia, serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: ui-monospace, "SF Mono", Menlo, monospace;--fraunces-soft: 100;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--radius-control: 8px;--radius-card: 12px;--radius-pill: 999px;--ease: cubic-bezier(.22, .61, .36, 1);--dur-quick: .12s;--dur-base: .22s;color-scheme:light}:root[data-theme=dark]{--bg-page: #1F1410;--bg-surface: #2A1F18;--bg-surface-muted: #2F2620;--cal-block-bg: #443223;--text-primary: var(--foam);--text-secondary: #D5BFA5;--border: #4A3A2D;--border-strong: var(--caramel);--text-hover: #EFDDC1;--hover-fill: #3A2C22;--row-hover: rgba(245, 230, 211, .08);--border-hover: var(--caramel);--btn-primary-bg: var(--foam);--btn-primary-fg: var(--espresso);--btn-primary-bg-hover: var(--linen);--chart-fill: var(--foam);--chart-fill-alt: var(--caramel);--chart-track: #2F2620;--chart-ramp-0: #2F2620;--chart-ramp-1: #5A4634;--chart-ramp-2: var(--caramel);--chart-ramp-3: #D7B379;--chart-ramp-4: var(--foam);--danger: #DB7B72;--danger-bg: #4A2521;--logo-body: var(--foam);--logo-rim: var(--linen);--swatch-edge: rgba(255, 255, 255, .14);--modal-scrim: rgba(0, 0, 0, .65);--focus-ring: rgba(245, 166, 91, .22);color-scheme:dark}:root[data-theme=matcha]{--espresso: #333A29;--coffee: #586041;--caramel: #5E6A3D;--foam: #E4EDCD;--cream: #EFF4E0;--linen: #FBFDF5;--tan: #D5E0B6;--bg-surface-muted: #E8EFD3;--cal-block-bg: #DCE7BB;--text-hover: #414B30;--row-hover: rgba(150, 165, 120, .18);--btn-primary-bg-hover: #2A311F;--logo-rim: #1B2114;--modal-scrim: rgba(28, 32, 20, .45);--focus-ring: rgba(94, 106, 61, .2);--chip-wash: rgba(94, 106, 61, .14);--chip-wash-border: rgba(94, 106, 61, .28);color-scheme:light}:root[data-theme=taro]{--espresso: #383143;--coffee: #5A5172;--caramel: #645579;--foam: #E9E1F2;--cream: #F3EEF8;--linen: #FCFAFE;--tan: #DCD0EA;--bg-surface-muted: #ECE4F4;--cal-block-bg: #DED0EC;--text-hover: #29242F;--row-hover: rgba(150, 135, 175, .16);--btn-primary-bg-hover: #262030;--logo-rim: #1B1722;--modal-scrim: rgba(30, 26, 40, .45);--focus-ring: rgba(100, 85, 121, .22);--chip-wash: rgba(100, 85, 121, .14);--chip-wash-border: rgba(100, 85, 121, .28);color-scheme:light}:root[data-theme=sea-blue]{--espresso: #233238;--coffee: #44606C;--caramel: #3D5C6A;--foam: #DBE9EE;--cream: #E9F2F4;--linen: #F7FBFC;--tan: #C8DCE2;--bg-surface-muted: #DCEAEE;--cal-block-bg: #C9DFE6;--text-hover: #1B2A30;--row-hover: rgba(110, 145, 160, .14);--btn-primary-bg-hover: #1B272C;--logo-rim: #182329;--modal-scrim: rgba(22, 30, 35, .45);--focus-ring: rgba(61, 92, 106, .22);--chip-wash: rgba(61, 92, 106, .13);--chip-wash-border: rgba(61, 92, 106, .27);color-scheme:light}.btn{--btn-bg: var(--btn-primary-bg);--btn-fg: var(--btn-primary-fg);--btn-border: var(--btn-primary-bg);font-family:var(--font-body);font-weight:500;font-size:15px;line-height:1;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:12px 18px;border-radius:var(--radius-control);border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--btn-fg);cursor:pointer;transition:background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease),border-color var(--dur-quick) var(--ease);text-decoration:none;letter-spacing:.01em}.btn:focus-visible{outline:2px solid var(--sunrise);outline-offset:2px}.btn[disabled]{opacity:.55;cursor:not-allowed}.btn:hover{background:var(--btn-primary-bg-hover);border-color:var(--btn-primary-bg-hover)}.btn--ghost{--btn-bg: transparent;--btn-fg: var(--text-primary);--btn-border: var(--border-strong)}.btn--ghost:hover{background:var(--hover-fill)}.btn--danger{--btn-bg: transparent;--btn-fg: var(--danger);--btn-border: var(--danger)}.btn--danger:hover{background:var(--danger-bg)}.btn--sm{padding:8px 12px;font-size:13px}.btn--block{width:100%}.input{font-family:var(--font-body);font-weight:400;font-size:16px;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);padding:12px 14px;width:100%;transition:border-color var(--dur-quick) var(--ease),background var(--dur-quick) var(--ease)}.input::placeholder{color:var(--text-secondary);opacity:.7}.input:hover{border-color:var(--border-hover)}.input:focus{outline:none;border-color:var(--caramel);background:var(--bg-surface);box-shadow:0 0 0 3px var(--focus-ring)}.field{display:flex;flex-direction:column;gap:6px}.field__label{font-size:13px;font-weight:500;color:var(--text-secondary)}.field__hint{font-size:12px;color:var(--text-secondary)}.field__error{font-size:12px;color:var(--danger)}.checkbox{--size: 22px;width:var(--size);height:var(--size);border-radius:50%;border:1.5px solid var(--coffee);background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background var(--dur-base) var(--ease),border-color var(--dur-base) var(--ease),transform var(--dur-quick) var(--ease);flex-shrink:0;padding:0}.checkbox:hover{background:var(--hover-fill)}.checkbox:focus-visible{outline:2px solid var(--sunrise);outline-offset:2px}.checkbox:active{transform:scale(.92)}.checkbox__check{width:14px;height:14px;color:var(--coffee);opacity:0;transform:scale(.6);transition:opacity var(--dur-base) var(--ease),transform var(--dur-base) var(--ease)}.checkbox[aria-checked=true]{background:var(--foam);border-color:var(--coffee)}.checkbox[aria-checked=true] .checkbox__check{opacity:1;transform:scale(1)}.checkbox--locked{pointer-events:none;cursor:default}.label-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-pill);font-family:var(--font-body);font-size:12px;font-weight:500;letter-spacing:.02em;line-height:1.4;white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:default;max-width:16rem;min-width:0}.label-pill__name{overflow:hidden;text-overflow:ellipsis;min-width:0}.label-pill__remove{cursor:pointer;font-weight:500;opacity:.7;flex:0 0 auto}.label-pill--button{cursor:pointer;border:1px solid transparent;transition:filter var(--dur-quick) var(--ease)}.label-pill--button:hover{filter:brightness(.96)}.date-header{font-family:var(--font-display);font-weight:500;font-variation-settings:"opsz" 96,"SOFT" var(--fraunces-soft);font-size:clamp(28px,4vw,40px);line-height:1.1;letter-spacing:-.01em;color:var(--text-primary);margin:0;display:inline-flex;flex-direction:column;gap:6px}.date-header__sub{font-family:var(--font-body);font-weight:400;font-size:13px;letter-spacing:.04em;text-transform:lowercase;color:var(--text-secondary)}.date-header--today:after{content:"";display:block;width:56px;height:3px;background:var(--sunrise);border-radius:2px;margin-top:2px}.logo{display:inline-flex;align-items:center;gap:10px;line-height:1}.logo__wordmark{font-family:var(--font-display);font-weight:400;font-variation-settings:"opsz" 144,"SOFT" 100;letter-spacing:-.012em;line-height:1}.stack{display:flex;flex-direction:column}.row{display:flex;align-items:center}.row--between{justify-content:space-between}.row--gap-2{gap:var(--space-2)}.row--gap-3{gap:var(--space-3)}.stack--gap-4{gap:var(--space-4)}.muted{color:var(--text-secondary)}.auth-shell{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--space-5);background:radial-gradient(80% 60% at 20% 0%,var(--bg-surface-muted),transparent 70%),radial-gradient(60% 60% at 90% 100%,var(--foam),transparent 75%),var(--bg-page)}.auth-card{width:100%;max-width:420px;padding:var(--space-7) var(--space-6);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);display:flex;flex-direction:column;gap:var(--space-5)}.auth-card__brand{display:inline-block;text-decoration:none}.auth-card__header{display:flex;flex-direction:column;gap:var(--space-2)}.auth-title{font-family:var(--font-display);font-weight:500;font-variation-settings:"opsz" 96,"SOFT" 100;font-size:30px;line-height:1.1;letter-spacing:-.01em;color:var(--text-primary);margin:0}.auth-sub{font-family:var(--font-body);font-weight:400;font-size:15px;color:var(--text-secondary);margin:0}.auth-error{font-size:14px;color:var(--danger);background:var(--danger-bg);border-radius:var(--radius-control);padding:10px 12px;margin:0}.auth-footer{font-size:14px;color:var(--text-secondary);text-align:center;margin:0}.auth-footer a{color:var(--coffee);font-weight:500}.auth-alt{display:flex;flex-direction:column;gap:var(--space-4)}.auth-divider{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-body);font-size:13px;color:var(--text-secondary)}.auth-divider:before,.auth-divider:after{content:"";flex:1 1 auto;height:1px;background:var(--border)}.btn--google{gap:var(--space-3)}.btn--google svg{flex-shrink:0}.auth-confirm{display:flex;flex-direction:column;gap:var(--space-3);font-size:15px;line-height:1.55;color:var(--text-primary);background:var(--bg-surface-muted);border:1px solid var(--border);border-radius:var(--radius-control);padding:14px 16px;margin:0}.auth-confirm p{margin:0}.auth-confirm strong{font-weight:500;color:var(--text-primary)}.verify-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);background:var(--bg-surface-muted);border:1px solid var(--tan);border-left:3px solid var(--sunrise);border-radius:var(--radius-control);padding:12px 16px;margin-bottom:var(--space-5);font-size:14px;color:var(--text-primary);overflow-wrap:anywhere}.verify-banner__body{display:flex;align-items:center;gap:10px;min-width:0}.verify-banner__dot{width:8px;height:8px;background:var(--sunrise);border-radius:50%;flex-shrink:0}.verify-banner strong{font-weight:500}.verify-banner__action{background:transparent;border:1px solid var(--coffee);color:var(--coffee);font-family:var(--font-body);font-size:13px;font-weight:500;padding:6px 12px;border-radius:var(--radius-control);cursor:pointer;white-space:nowrap;transition:background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.verify-banner__action:hover{background:var(--coffee);color:var(--linen)}.verify-banner__action[disabled]{opacity:.55;cursor:not-allowed}@media (max-width: 560px){.verify-banner{flex-direction:column;align-items:flex-start}}.shell{display:grid;grid-template-columns:256px minmax(0,1fr);min-height:100dvh;max-width:100%}.shell__nav{position:sticky;top:0;height:100dvh;padding:var(--space-5);border-right:1px solid var(--border);background:var(--bg-page);display:flex;flex-direction:column;gap:var(--space-5)}.shell__nav-top{display:flex;flex-direction:column;gap:var(--space-4);flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-gutter:stable;padding-inline-end:var(--space-2);scrollbar-width:thin;scrollbar-color:transparent transparent}.shell__nav-top:hover,.shell__nav-top:focus-within{scrollbar-color:var(--border-strong) transparent}.shell__nav-bottom{flex-shrink:0}.shell__logo{display:inline-block;text-decoration:none;padding:4px 2px;border-radius:var(--radius-control)}.shell__menu{display:flex;flex-direction:column;gap:2px}.shell__menu-link{display:flex;align-items:center;gap:10px;font-family:var(--font-body);font-size:15px;font-weight:500;color:var(--text-secondary);text-decoration:none;padding:8px 12px;border-radius:var(--radius-control);transition:background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.shell__menu-link svg{flex-shrink:0;opacity:.8}.shell__menu-link:not(.active):hover{color:var(--text-hover)}.shell__menu-link:hover svg,.shell__menu-link.active svg{opacity:1}.shell__menu-link.active{color:var(--text-primary);background:var(--hover-fill)}.shell__menu-link--sub{font-weight:400;padding-left:18px}.shell__menu-divider{height:1px;background:var(--border);margin:var(--space-2) 0}.shell__menu-section{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);font-weight:500;padding:0 12px}.shell__user{display:flex;flex-direction:column;gap:4px;padding:8px 12px;border-top:1px solid var(--border);padding-top:var(--space-4)}.shell__user-email{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shell__signout{background:none;border:none;padding:0;text-align:left;font-family:var(--font-body);font-size:13px;color:var(--coffee);cursor:pointer}.shell__signout:hover{color:var(--text-hover);text-decoration:underline;text-underline-offset:2px}.shell__user-bottom{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3)}.shell__version{font-size:11px;color:var(--text-secondary);opacity:.7;font-variant-numeric:tabular-nums}.shell__main{padding:var(--space-7) clamp(var(--space-5),6vw,80px);max-width:1100px;width:100%;min-width:0;overflow-x:hidden;overflow-x:clip}.shell__topbar,.shell__drawer-scrim,.shell__drawer-close{display:none}.global{display:flex;flex-direction:column;gap:var(--space-7)}.global__section{display:flex;flex-direction:column;gap:var(--space-3)}.global__empty{font-family:var(--font-body);font-size:14px;color:var(--text-secondary);padding:var(--space-3) 0 var(--space-2);font-style:italic}.global__subgroup{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-3)}.history-controls{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border);margin-bottom:var(--space-4)}.history-nav{display:flex;align-items:center;gap:var(--space-3)}.history-controls__nav{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:15px;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);cursor:pointer;transition:background var(--dur-quick) var(--ease),border-color var(--dur-quick) var(--ease)}.history-controls__nav:hover:not([disabled]){background:var(--hover-fill);border-color:var(--border-hover)}.history-controls__nav[disabled]{opacity:.45;cursor:not-allowed}.history-controls__jump{margin-left:auto;background:transparent;border:none;font-family:var(--font-body);font-size:13px;color:var(--coffee);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.history-controls__jump:hover{color:var(--text-hover)}.history-count{font-size:14px;color:var(--text-secondary);margin:0}.history-view{display:flex;gap:var(--space-1);margin-right:var(--space-1)}.history-view__chip{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border);border-radius:var(--radius-control);padding:6px 12px;cursor:pointer}.history-view__chip:not(.history-view__chip--active):hover{color:var(--text-hover)}.history-view__chip--active{background:var(--espresso);color:var(--linen);border-color:var(--espresso)}.history-day-group{margin-top:var(--space-6)}.history-day-group:first-of-type{margin-top:var(--space-3)}.history-day{display:flex;align-items:baseline;gap:var(--space-2);margin:0 0 var(--space-2);font-family:var(--font-display);font-weight:400;font-variation-settings:"opsz" 40,"SOFT" var(--fraunces-soft);font-size:19px;letter-spacing:-.005em;color:var(--text-secondary)}.history-day__sub{font-family:var(--font-body);font-size:12px;letter-spacing:.04em;text-transform:lowercase;color:var(--text-secondary);opacity:.8}.history-more{display:block;margin:var(--space-5) auto 0;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border);border-radius:var(--radius-control);padding:8px 20px;cursor:pointer}.history-more:hover:not([disabled]){color:var(--text-hover);border-color:var(--border-hover)}.history-more[disabled]{opacity:.55;cursor:progress}.history-period{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:var(--font-body);font-size:14px;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);padding:6px 10px;cursor:pointer;white-space:nowrap;transition:border-color var(--dur-quick) var(--ease)}.history-period:hover{border-color:var(--border-hover)}.history-period:focus-visible{outline:2px solid var(--sunrise);outline-offset:2px}.history-period__caret{font-size:10px;color:var(--text-secondary)}.history-period--day{min-width:14.5rem}.history-period--week{min-width:12.5rem}.history-period--month{min-width:9.5rem}.cal{position:fixed;z-index:70;width:264px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-3)}.cal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.cal__title{font-family:var(--font-display);font-weight:500;font-variation-settings:"opsz" 40,"SOFT" var(--fraunces-soft);font-size:16px;color:var(--text-primary)}.cal__step{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;font-size:18px;line-height:1;color:var(--text-secondary);background:transparent;border:none;border-radius:var(--radius-control);cursor:pointer;transition:background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.cal__step:hover:not([disabled]){background:var(--hover-fill);color:var(--text-hover)}.cal__step[disabled]{opacity:.4;cursor:not-allowed}.cal__weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}.cal__weekday{text-align:center;font-size:11px;font-weight:500;color:var(--text-secondary)}.cal__weeks{display:flex;flex-direction:column;gap:2px}.cal__week{display:grid;grid-template-columns:repeat(7,1fr);align-items:center;width:100%;padding:2px 0;background:transparent;border:none;border-radius:var(--radius-control);cursor:pointer;transition:background var(--dur-quick) var(--ease)}.cal__week:hover:not([disabled]){background:var(--hover-fill)}.cal__week--selected{background:var(--hover-fill);box-shadow:inset 0 0 0 1.5px var(--caramel)}.cal__week[disabled]{opacity:.4;cursor:not-allowed}.cal__week:focus-visible{outline:2px solid var(--sunrise);outline-offset:1px}.cal__day{text-align:center;font-size:12px;padding:5px 0;color:var(--text-primary);font-variant-numeric:tabular-nums}.cal__day--muted{color:var(--text-secondary);opacity:.45}.cal__day--today{position:relative;font-weight:500}.cal__day--today:after{content:"";position:absolute;left:50%;bottom:0;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--sunrise)}.cal__days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal__date{aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-primary);background:transparent;border:none;border-radius:var(--radius-control);cursor:pointer;position:relative;font-variant-numeric:tabular-nums;transition:background var(--dur-quick) var(--ease)}.cal__date:hover:not([disabled]){background:var(--hover-fill)}.cal__date--selected{background:var(--hover-fill);box-shadow:inset 0 0 0 1.5px var(--caramel)}.cal__date--muted{color:var(--text-secondary);opacity:.4}.cal__date--today{font-weight:500}.cal__date--today:after{content:"";position:absolute;left:50%;bottom:4px;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--sunrise)}.cal__date[disabled]{opacity:.3;cursor:not-allowed}.cal__date:focus-visible{outline:2px solid var(--sunrise);outline-offset:1px}.cal__months{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.cal__month{padding:9px 0;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-primary);background:transparent;border:none;border-radius:var(--radius-control);cursor:pointer;position:relative;transition:background var(--dur-quick) var(--ease)}.cal__month:hover:not([disabled]){background:var(--hover-fill)}.cal__month--selected{background:var(--hover-fill);box-shadow:inset 0 0 0 1.5px var(--caramel)}.cal__month--today:after{content:"";position:absolute;left:50%;bottom:5px;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--sunrise)}.cal__month[disabled]{opacity:.4;cursor:not-allowed}.cal__month:focus-visible{outline:2px solid var(--sunrise);outline-offset:1px}.composer{display:flex;align-items:center;gap:var(--space-3);padding:4px 0 4px 4px}.composer__bullet{width:22px;height:22px;border-radius:50%;border:1.5px dashed var(--tan);flex-shrink:0}.composer__field{position:relative;flex:1;min-width:42%}.composer__input{width:100%;border:none;background:transparent;font-family:var(--font-body);font-size:16px;color:var(--text-primary);padding:4px 0}.composer__input::placeholder{color:var(--text-secondary);opacity:.65;font-style:italic}.composer__input:focus{outline:none}.composer__submit{border:none;background:var(--espresso);color:var(--linen);border-radius:50%;width:26px;height:26px;font-size:14px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-family:var(--font-mono)}.composer__date-chip{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);background:var(--bg-surface-muted);border:1px solid var(--border);border-radius:var(--radius-pill);padding:4px 12px;cursor:pointer;flex-shrink:0;white-space:nowrap;transition:border-color var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease),background var(--dur-quick) var(--ease)}.composer__date-chip:hover{color:var(--text-hover)}.composer__date-chip:focus-visible{outline:2px solid var(--sunrise);outline-offset:2px}.composer__date-chip[disabled]{opacity:.55;cursor:not-allowed}.composer__dest-chip{flex-shrink:1;min-width:0;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--caramel);background:var(--chip-wash);border:1px solid var(--chip-wash-border);border-radius:var(--radius-pill);padding:4px 9px;white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}.composer-wrap{display:flex;flex-direction:column;gap:4px;padding:var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card)}.agenda__composer-slot{margin-bottom:calc(-1 * var(--space-5))}.filter-bar+.agenda__composer-slot{margin-top:calc(-1 * var(--space-5))}.composer__error{font-size:13px;color:var(--danger);background:var(--danger-bg);border-radius:var(--radius-control);padding:8px 12px;margin:4px 0 0}.composer-block{display:flex;flex-direction:column;gap:6px}.composer__hint{margin:0;padding-left:2px;font-size:12px;color:var(--text-secondary)}.composer__hint-key{font-family:var(--font-mono);font-weight:500;color:var(--coffee)}.composer-suggest{position:absolute;top:calc(100% + 6px);left:0;z-index:30;min-width:220px;max-width:320px;max-height:280px;overflow-y:auto;list-style:none;margin:0;padding:var(--space-2);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);display:flex;flex-direction:column;gap:2px}.composer-suggest__hint{font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;color:var(--text-secondary);padding:4px 10px 6px}.composer-suggest__row{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:none;background:transparent;cursor:pointer;border-radius:var(--radius-control);padding:7px 10px;font-family:var(--font-body);font-size:14px;color:var(--text-primary)}.composer-suggest__row:hover{background:var(--hover-fill)}.composer-suggest__row--on{background:var(--bg-surface-muted)}.composer-suggest__swatch{width:12px;height:12px;border-radius:50%;border:1px solid var(--swatch-edge);flex-shrink:0}.composer-suggest__sigil{width:12px;text-align:center;color:var(--coffee);font-weight:500;flex-shrink:0}.composer-suggest__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.todo-row{display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:var(--space-3);padding:6px 4px;border-bottom:1px solid transparent;transition:background var(--dur-quick) var(--ease);cursor:pointer}.todo-row:hover{background:var(--row-hover);border-radius:var(--radius-control)}.todo-row__body{display:flex;flex-direction:column;gap:6px;min-width:0;padding-top:1px}.todo-row__title{background:none;border:none;padding:0;text-align:left;font-family:var(--font-body);font-size:15px;font-weight:400;color:var(--text-primary);line-height:1.45;cursor:pointer;word-break:break-word}.todo-row__title:focus-visible{outline:2px solid var(--coffee);outline-offset:2px;border-radius:3px}.todo-row__link{color:var(--coffee);text-decoration:underline;text-underline-offset:2px;cursor:pointer}.todo-row__link:hover{filter:brightness(.92)}.todo-row__edit{border:none;background:transparent;font-family:var(--font-body);font-size:16px;color:var(--text-primary);width:100%;padding:0}.todo-row__edit:focus{outline:none;border-bottom:1px solid var(--coffee)}.todo-dialog{max-height:84vh;overflow-y:auto}.token-input{position:relative}.rich-notes{display:flex;flex-direction:column;gap:var(--space-2)}.rich-notes__bar{display:flex;flex-wrap:wrap;gap:2px;padding:3px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control)}.rich-notes__tool{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:none;border-radius:6px;color:var(--text-secondary);cursor:pointer}.rich-notes__tool:hover{background:var(--hover-fill);color:var(--text-primary)}.rich-notes__tool--on{background:var(--foam);color:var(--text-primary)}.rich-notes__tool:disabled{opacity:.4;cursor:default;background:none}.rich-notes__tool svg{width:15px;height:15px}.rich-notes__linkpop{position:fixed;z-index:400;display:flex;gap:2px;padding:3px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control)}.rich-notes__linkpop-item{font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text-secondary);background:none;border:none;padding:4px 9px;border-radius:6px;cursor:pointer;text-decoration:none;white-space:nowrap}.rich-notes__linkpop-item:hover{background:var(--hover-fill);color:var(--text-primary)}.rich-notes__linkpop-open{color:var(--coffee)}.rich-notes__linkpop-input{min-width:200px;padding:4px 8px;font-family:var(--font-body);font-size:13px;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);border-radius:6px}.rich-notes__linkpop-input:focus{outline:none;border-color:var(--coffee)}.rich-notes__content{min-height:200px;max-height:min(360px,50vh);overflow-y:auto;padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control)}.rich-notes__content:focus{outline:none;border-color:var(--coffee)}.rich-notes__content p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--text-secondary);float:left;height:0;pointer-events:none}@media (max-width: 600px){.rich-notes__content.md-body,.rich-notes__linkpop-input{font-size:16px}}.ProseMirror{white-space:pre-wrap;word-wrap:break-word}.ProseMirror:focus{outline:none}.todo-dialog__title-static{margin:0;font-family:var(--font-body);font-size:16px;color:var(--text-primary);word-break:break-word}.todo-dialog__notes-static{font-family:var(--font-body);font-size:14px;line-height:1.5;color:var(--text-primary);word-break:break-word;max-height:55vh;overflow-y:auto}.todo-dialog__empty{color:var(--text-secondary);font-style:italic}.todo-dialog__err{margin:0;font-family:var(--font-body);font-size:12px;color:var(--danger)}.todo-dialog__footer{align-items:flex-start}.todo-dialog__meta{display:flex;flex-direction:column;align-items:stretch;gap:var(--space-2);flex:1 1 0;min-width:0}.todo-dialog__field{display:flex;align-items:center;gap:var(--space-2);min-width:0}.todo-dialog__field-label{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);min-width:64px;white-space:nowrap;flex-shrink:0}.todo-dialog__field .composer__date-chip{flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.md-body{font-family:var(--font-body);font-size:14px;line-height:1.6;color:var(--text-primary);word-break:break-word}.md-body>:first-child{margin-top:0}.md-body>:last-child{margin-bottom:0}.md-body p{margin:0 0 .7em}.md-body h1,.md-body h2,.md-body h3,.md-body h4{font-family:var(--font-display);font-weight:500;line-height:1.3;margin:1em 0 .5em}.md-body h1{font-size:19px}.md-body h2{font-size:17px}.md-body h3{font-size:15px}.md-body h4{font-size:14px}.md-body ul,.md-body ol{margin:0 0 .7em;padding-left:1.4em}.md-body li{margin:.15em 0}.md-body li::marker{color:var(--text-secondary)}.md-body a{color:var(--coffee);text-decoration:underline;text-underline-offset:2px}.md-body code{font-family:var(--font-mono);font-size:.9em;background:var(--foam);padding:1px 5px;border-radius:4px}.md-body pre{margin:0 0 .7em;padding:var(--space-2) var(--space-3);background:var(--foam);border:1px solid var(--border);border-radius:var(--radius-control);overflow-x:auto}.md-body pre code{background:none;padding:0}.md-body blockquote{margin:0 0 .7em;padding:.1em 0 .1em .9em;border-left:3px solid var(--tan);color:var(--text-secondary)}.md-body hr{border:none;border-top:1px solid var(--border);margin:1em 0}.md-body img{max-width:100%;height:auto;border-radius:6px}.md-body ul[data-type=taskList]{list-style:none;padding-left:.1em}.md-body ul[data-type=taskList] li{display:flex;align-items:flex-start;gap:.5em;margin:.15em 0}.md-body ul[data-type=taskList] li>label{flex:0 0 auto;margin:0;-webkit-user-select:none;user-select:none}.md-body ul[data-type=taskList] li>div{flex:1 1 auto;min-width:0}.md-body ul[data-type=taskList] li>div>p{margin:0}.md-body input[type=checkbox]{margin-top:.28em;accent-color:var(--coffee);cursor:pointer}.todo-row__meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding-top:2px}.todo-row__chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-pill);font-size:11px;font-weight:500;background:var(--bg-surface-muted);color:var(--text-secondary);border:1px solid var(--border);letter-spacing:.02em}.todo-row__chip--project{background:var(--chip-wash);color:var(--caramel);border-color:var(--chip-wash-border)}.todo-row__delete{opacity:0;border:none;background:transparent;color:var(--text-secondary);font-size:18px;cursor:pointer;width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;transition:opacity var(--dur-quick) var(--ease),background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.todo-row:hover .todo-row__delete{opacity:1}.todo-row__delete:hover{background:var(--danger-bg);color:var(--danger)}.todo-row__foot{display:flex;align-items:center;margin-left:-4px}@media (hover: hover){.todo-row__meta--empty,.todo-row__foot--empty{max-height:0;margin-top:-6px;opacity:0;transition:max-height 275ms var(--ease),margin-top 275ms var(--ease),opacity .15s var(--ease)}.todo-row:hover .todo-row__meta--empty,.todo-row:focus-within .todo-row__meta--empty,.todo-row:hover .todo-row__foot--empty,.todo-row:focus-within .todo-row__foot--empty{max-height:2rem;margin-top:0;opacity:1}}@media (hover: hover) and (prefers-reduced-motion: reduce){.todo-row__meta--empty,.todo-row__foot--empty{transition:none}}.assignee-control{display:inline-flex;align-items:center;gap:6px;flex:none;max-width:220px;border:none;background:none;padding:2px 8px 2px 4px;border-radius:var(--radius-pill);font-family:var(--font-body);font-size:12px;color:var(--text-secondary);cursor:pointer;transition:background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}button.assignee-control:hover{background:var(--hover-fill);color:var(--text-primary)}.assignee-control--static{cursor:default}.assignee-control__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (hover: hover){.assignee-control--empty{opacity:0;transition:opacity var(--dur-quick) var(--ease)}.todo-row:hover .assignee-control--empty,.assignee-control--empty:focus-visible,.assignee-control--empty[aria-expanded=true]{opacity:1}}.todo-row__add-label-wrap{position:relative;display:inline-block}.todo-row__add-label{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-pill);font-size:11px;font-weight:500;background:transparent;color:var(--text-secondary);border:1px dashed var(--border);cursor:pointer;opacity:0;letter-spacing:.02em}.todo-row:hover .todo-row__add-label,.todo-row__add-label:focus-visible{opacity:1}.todo-row__add-label:hover{color:var(--text-hover)}.label-picker{position:absolute;top:calc(100% + 6px);left:0;z-index:30;min-width:220px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-2);display:flex;flex-direction:column;gap:2px}.label-picker__head{font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;color:var(--text-secondary);padding:6px 10px 2px}.label-picker__empty{padding:8px 10px;font-size:13px;color:var(--text-secondary)}.label-picker__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;max-height:280px;overflow-y:auto}.label-picker__row{display:grid;grid-template-columns:14px 1fr auto;gap:10px;align-items:center;background:transparent;border:none;text-align:left;padding:6px 10px;border-radius:var(--radius-control);cursor:pointer;font-family:var(--font-body);font-size:14px;color:var(--text-primary)}.label-picker__row:hover{background:var(--hover-fill)}.label-picker__row--on{background:var(--bg-surface-muted)}.label-picker__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.label-picker__swatch{width:12px;height:12px;border-radius:50%;border:1px solid var(--swatch-edge)}.label-picker__swatch[data-color=terracotta]{background:#e0a18a}.label-picker__swatch[data-color=mustard]{background:#e8c870}.label-picker__swatch[data-color=sage]{background:#b2c6a4}.label-picker__swatch[data-color=sky]{background:#a8c0d6}.label-picker__swatch[data-color=plum]{background:#c4a6bf}.label-picker__swatch[data-color=rose]{background:#e0aeb6}.label-picker__swatch[data-color=slate]{background:#b4bbc5}.label-picker__swatch[data-color=charcoal]{background:#cfcac3}.label-picker__swatch[data-color=moss]{background:#a8bd93}.label-picker__swatch[data-color=ochre]{background:#d7b379}.label-picker__swatch[data-color=lavender]{background:#c2b5dd}.label-picker__swatch[data-color=teal]{background:#9dc4be}.label-picker__swatch[data-color=brick]{background:#b98075}.label-picker__swatch[data-color=olive]{background:#c8c58b}.label-picker__swatch[data-color=denim]{background:#9dafc4}.label-picker__swatch[data-color=mauve]{background:#c49daf}.label-picker__check{color:var(--coffee);font-size:13px}.labels-new{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:var(--space-3);align-items:center}.labels-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.labels-list__row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:var(--space-3);align-items:center;padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control)}.labels-list__primary{display:flex;flex-direction:column;align-items:flex-start;gap:6px;min-width:0}.labels-list__sample{display:flex;align-items:center;gap:8px;max-width:100%}.labels-list__name{background:none;border:none;padding:0;font-family:var(--font-body);font-size:16px;text-align:left;cursor:text;color:var(--text-primary);max-width:100%;overflow-wrap:anywhere}.labels-list__actions{display:flex;gap:var(--space-2);align-items:center}.labels-list__row--archived{background:var(--bg-page);border-style:dashed}.labels-list__row--archived .labels-list__name,.labels-list__row--archived .label-pill{opacity:.65}.list-toolbar{display:flex;justify-content:flex-end;align-items:center;padding:0 2px;margin-bottom:calc(-1 * var(--space-1))}.list-toolbar__toggle{background:none;border:none;padding:4px 2px;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);letter-spacing:.01em;cursor:pointer;transition:color var(--dur-quick) var(--ease)}.list-toolbar__toggle:hover{color:var(--text-hover)}.archived-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-pill);background:transparent;border:1px dashed var(--border-strong);font-family:var(--font-body);font-size:11px;font-weight:500;letter-spacing:.04em;color:var(--text-secondary);text-transform:lowercase}.color-picker{display:grid;grid-template-columns:repeat(8,auto);gap:6px;justify-content:start}.color-swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform var(--dur-quick) var(--ease);padding:0}.color-swatch:hover{transform:scale(1.08)}.color-swatch--active{transform:scale(1.1);box-shadow:0 0 0 2px var(--bg-page),0 0 0 4px var(--text-primary)}@media (max-width: 600px){.labels-new,.labels-list__row{grid-template-columns:1fr}}.todo-row--done .todo-row__title{color:var(--text-secondary);text-decoration:line-through;text-decoration-color:var(--coffee);text-decoration-thickness:1px}.todo-row--done .todo-row__link{color:var(--text-secondary);text-decoration:line-through;text-decoration-color:var(--coffee)}.todo-row__title--static{display:inline-block}@media (hover: hover){.todo-row--done:hover .todo-row__title,.todo-row--done:hover .todo-row__link{text-decoration:none;color:var(--text-primary)}.todo-row--done:hover .todo-row__link{color:var(--coffee)}}@media (hover: none){.todo-row--done:active .todo-row__title,.todo-row--done:active .todo-row__link{text-decoration:none;color:var(--text-primary)}.todo-row--done:active .todo-row__link{color:var(--coffee)}}.todo-row__title-text{background-image:linear-gradient(var(--coffee),var(--coffee));background-repeat:no-repeat;background-position:left center;background-size:0% 1.5px}.todo-row--exiting{pointer-events:none}.todo-row--exiting .todo-row__title-text{animation:todo-strike .46s var(--ease) forwards}.todo-row--exiting .todo-row__meta--empty,.todo-row--exiting .todo-row__foot--empty{max-height:0;margin-top:-6px;opacity:0;transition:none}@keyframes todo-strike{to{background-size:100% 1.5px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-scrim);display:flex;align-items:center;justify-content:center;padding:var(--space-5);z-index:60;animation:fade-in .18s var(--ease)}.modal{width:100%;max-width:440px;max-height:100%;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);animation:slide-up .24s var(--ease)}.modal__title{font-family:var(--font-display);font-weight:500;font-variation-settings:"opsz" 72,"SOFT" 100;font-size:26px;line-height:1.15;letter-spacing:-.01em;margin:0;color:var(--text-primary)}.modal__body{font-family:var(--font-body);font-size:15px;line-height:1.55;color:var(--text-secondary);margin:0}.modal__body strong{color:var(--text-primary);font-weight:500}.modal__actions{display:flex;justify-content:flex-end;gap:var(--space-3);flex-wrap:wrap}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.usage-badge{display:flex;flex-direction:column;gap:6px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);padding:10px 12px;cursor:pointer;font-family:var(--font-body);text-align:left;margin-bottom:var(--space-3);transition:border-color var(--dur-quick) var(--ease);width:100%}.usage-badge:hover{border-color:var(--border-hover)}.usage-badge--warn{border-color:var(--sunrise)}.usage-badge__count{font-size:13px;font-weight:500;color:var(--text-primary)}.usage-badge__bar{display:block;height:4px;background:var(--bg-surface-muted);border-radius:2px;overflow:hidden}.usage-badge__bar-fill{display:block;height:100%;background:var(--coffee);border-radius:2px;transition:width var(--dur-base) var(--ease)}.usage-badge--warn .usage-badge__bar-fill{background:var(--sunrise)}.usage-badge__cta{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--coffee);font-weight:500}.usage-badge--warn .usage-badge__cta{color:var(--caramel)}.settings-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.settings-card__title{font-family:var(--font-display);font-weight:500;font-variation-settings:"opsz" 48,"SOFT" 100;font-size:22px;margin:0}.settings-row{display:flex;flex-direction:column;gap:2px}.settings-row__label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-weight:500}.settings-row__value{font-size:15px;color:var(--text-primary);overflow-wrap:anywhere}.settings-name{display:flex;align-items:center;gap:var(--space-2);max-width:460px;margin-top:2px}.settings-name .input{flex:1;min-width:0;padding-block:5px;line-height:1.2}.settings-name__saved{font-size:13px;color:var(--text-secondary);white-space:nowrap}.plan-badge{font-family:var(--font-body);font-size:12px;font-weight:500;letter-spacing:.04em;padding:4px 10px;border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--bg-surface-muted);color:var(--text-secondary)}.plan-badge--active{background:var(--sunrise);color:var(--espresso);border-color:var(--sunrise)}.plan-badge--past_due{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.usage{display:flex;flex-direction:column;gap:6px}.usage__head{display:flex;justify-content:space-between;font-size:13px;color:var(--text-secondary)}.usage__bar{height:6px;background:var(--bg-surface-muted);border-radius:3px;overflow:hidden}.usage__fill{height:100%;background:var(--coffee);border-radius:3px;transition:width var(--dur-base) var(--ease)}.usage__fill--capped{background:var(--sunrise)}.usage__hint{font-size:13px;color:var(--text-secondary);margin:0}.token-reveal{display:flex;flex-direction:column;gap:10px;padding:var(--space-4);background:var(--bg-surface-muted);border:1px solid var(--border);border-radius:var(--radius-control)}.token-reveal__label{font-size:13px;color:var(--text-secondary);margin:0}.token-reveal__row{display:flex;align-items:center;gap:10px}.token-reveal__value{flex:1;font-family:var(--font-mono);font-size:13px;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);padding:8px 10px;overflow-wrap:anywhere}.token-reveal__dismiss{align-self:flex-start;font-family:var(--font-body);font-size:13px;color:var(--text-secondary);background:none;border:none;padding:0;cursor:pointer}.token-reveal__dismiss:hover{color:var(--text-hover)}.token-create{display:flex;gap:10px;align-items:center}.token-create .input{flex:1}.token-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.token-list__row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}.token-list__row+.token-list__row{border-top:1px solid var(--border)}.token-list__main{display:flex;flex-direction:column;gap:2px;min-width:0}.token-list__name{font-size:15px;color:var(--text-primary)}.token-list__meta{font-size:13px;color:var(--text-secondary)}.token-list__meta code{font-family:var(--font-mono)}.theme-toggle{display:inline-flex;flex-wrap:wrap;padding:4px;gap:4px;background:var(--bg-surface-muted);border:1px solid var(--border);border-radius:var(--radius-pill);align-self:flex-start}.theme-toggle__option{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid transparent;padding:6px 14px;border-radius:var(--radius-pill);cursor:pointer;transition:background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.theme-toggle__option:not(.theme-toggle__option--active):hover{color:var(--text-hover)}.theme-toggle__option:focus-visible{outline:2px solid var(--sunrise);outline-offset:2px}.theme-toggle__option--active{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border)}@media (max-width: 600px){.theme-toggle{width:100%;border-radius:var(--radius-control)}.theme-toggle__option{flex:1 1 auto;text-align:center}}.contact-form{display:flex;flex-direction:column;gap:var(--space-4);align-items:flex-start}.contact-form .field{width:100%}.contact-form select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--coffee) 50%),linear-gradient(135deg,var(--coffee) 50%,transparent 50%);background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:36px;cursor:pointer}.contact-form textarea.input{resize:vertical;min-height:120px;font-family:var(--font-body);line-height:1.5}.contact-form__error{font-size:13px;color:var(--danger);margin:0}.contact-form__success{font-size:13px;color:var(--coffee);margin:0}.search{position:relative}.search__input{width:100%;font-family:var(--font-body);font-size:16px;padding:8px 12px;border-radius:var(--radius-control);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary);transition:border-color var(--dur-quick) var(--ease)}.search__input::placeholder{color:var(--text-secondary)}.search__input:focus{outline:none;border-color:var(--coffee)}.search__kbd{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:10px;color:var(--text-secondary);background:var(--bg-surface-muted);border:1px solid var(--border);border-radius:4px;padding:2px 5px;pointer-events:none}.search__input:focus+.search__kbd{display:none}.search__panel{position:absolute;top:calc(100% + 6px);left:0;right:0;width:100%;max-width:360px;z-index:40;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-2);max-height:60vh;overflow:auto}.search__empty{font-size:13px;color:var(--text-secondary);padding:8px 10px;margin:0}.search__group{display:flex;flex-direction:column}.search__group-head{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);font-weight:500;padding:8px 10px 4px}.search__row{display:flex;flex-direction:column;gap:2px;text-align:left;border:none;background:transparent;padding:8px 10px;border-radius:var(--radius-control);cursor:pointer;font-family:var(--font-body);text-decoration:none;color:var(--text-primary)}.search__row:hover{background:var(--hover-fill)}.search__title{font-size:14px;font-weight:500;color:var(--text-primary)}.search__sub{font-size:12px;color:var(--text-secondary)}.filter-bar{display:flex;align-items:center;gap:var(--space-3);padding:10px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.page>.filter-bar{margin-block:calc(-1 * var(--space-2))}.filter-bar__legend{font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;color:var(--text-secondary)}.filter-bar__pills{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.filter-bar__add-wrap{position:relative}.filter-bar__add{background:transparent;border:1px dashed var(--border);border-radius:var(--radius-pill);padding:3px 10px;font-size:11px;font-weight:500;letter-spacing:.02em;color:var(--text-secondary);cursor:pointer}.filter-bar__add:hover{color:var(--text-hover)}.filter-bar__clear{background:transparent;border:none;font-size:12px;color:var(--text-secondary);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.filter-bar__menu{position:absolute;top:calc(100% + 6px);left:0;z-index:30;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-2);display:flex;flex-direction:column;gap:4px;min-width:180px;max-height:280px;overflow-y:auto}.filter-bar__menu-item{background:transparent;border:none;padding:4px;cursor:pointer;text-align:left}.filter-bar__menu-empty{font-size:12px;color:var(--text-secondary);padding:6px}.history-filters{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);padding:10px 0;border-bottom:1px solid var(--border)}.page>.history-filters{margin-block:calc(-1 * var(--space-2))}.history-filters:empty{display:none}.history-filters .filter-bar{padding:0;border-bottom:none}.project-filter{position:relative}.project-filter__trigger{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-pill);border:1px solid var(--chip-wash-border);background:transparent;color:var(--caramel);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--dur-quick) var(--ease)}.project-filter__trigger:hover,.project-filter__trigger--active{background:var(--chip-wash)}.project-filter__trigger:focus-visible{outline:2px solid var(--sunrise);outline-offset:2px}.project-filter__caret{font-size:10px;opacity:.8}.project-filter__clear{display:inline-flex;line-height:1;font-weight:500;opacity:.7;cursor:pointer}.project-filter__clear:hover{opacity:1}.project-filter__menu{position:absolute;top:calc(100% + 6px);left:0;z-index:30;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-2);display:flex;flex-direction:column;gap:2px;min-width:180px;max-height:280px;overflow-y:auto}.project-filter__item{background:transparent;border:none;padding:6px 8px;border-radius:var(--radius-control);cursor:pointer;text-align:left;font-size:13px;color:var(--text-primary)}.project-filter__item:hover{background:var(--hover-fill)}.project-filter__item--on{color:var(--caramel);font-weight:500}.page{display:flex;flex-direction:column;gap:var(--space-5)}.page__back{font-family:var(--font-body);font-size:13px;color:var(--text-secondary);text-decoration:none;width:fit-content}.page__back:hover{color:var(--text-hover)}.page__header{display:flex;flex-direction:column;gap:var(--space-2)}.page__title{font-family:var(--font-display);font-weight:500;font-variation-settings:"opsz" 96,"SOFT" 100;font-size:clamp(28px,4vw,40px);line-height:1.1;letter-spacing:-.01em;color:var(--text-primary);margin:0}.page__title--button{background:none;border:none;padding:0;text-align:left;cursor:text}.page__title-edit{font-family:var(--font-display);font-weight:500;font-variation-settings:"opsz" 96,"SOFT" 100;font-size:clamp(28px,4vw,40px);line-height:1.1;letter-spacing:-.01em;color:var(--text-primary);background:transparent;border:none;border-bottom:1px solid var(--coffee);outline:none;padding:0;width:100%}.page__sub{font-family:var(--font-body);font-weight:400;font-size:15px;color:var(--text-secondary);margin:0}.page__danger{margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px dashed var(--border)}.page__danger--row{display:flex;gap:var(--space-3);flex-wrap:wrap;align-items:center}.page__title-row{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.project-new{display:flex;flex-direction:column;gap:var(--space-2)}.project-new__top{align-items:stretch}.project-new__desc{resize:vertical;min-height:64px;font-family:var(--font-body);line-height:1.5}.project-desc__button{background:none;border:none;padding:0;text-align:left;font:inherit;color:inherit;cursor:text}.project-desc__button:hover{color:var(--text-hover)}.project-desc__button--placeholder{color:var(--text-secondary);font-style:italic;opacity:.7}.project-desc__edit{resize:vertical;min-height:56px;font-family:var(--font-body);font-size:16px;line-height:1.5}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-3)}.project-card{display:flex;flex-direction:column;gap:6px;padding:var(--space-5);border-radius:var(--radius-card);background:var(--bg-surface);border:1px solid var(--border);text-decoration:none;color:var(--text-primary);transition:border-color var(--dur-quick) var(--ease),transform var(--dur-quick) var(--ease)}.project-card:hover{border-color:var(--border-hover);transform:translateY(-1px)}.project-card__head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.project-card--archived{background:var(--bg-page);border-style:dashed}.project-card--archived .project-card__name,.project-card--archived .project-card__desc{color:var(--text-secondary)}.project-card__name{font-family:var(--font-display);font-weight:500;font-variation-settings:"opsz" 48,"SOFT" 100;font-size:19px;letter-spacing:-.005em}.project-card__desc{font-size:13px;color:var(--text-secondary);line-height:1.4}.drag-row{position:relative;cursor:grab}.drag-row:active{cursor:grabbing}.drag-row--dragging{opacity:.4}.drag-row__indicator{height:2px;background:var(--sunrise);border-radius:1px;margin:2px 0}body.is-dragging-list{touch-action:none;-webkit-user-select:none;user-select:none}@media (max-width: 860px){.shell{grid-template-columns:minmax(0,1fr);grid-template-rows:auto 1fr}.shell__nav--desktop{display:none}.shell__topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:10px var(--space-4);position:sticky;top:0;z-index:40;background:var(--bg-page);border-bottom:1px solid var(--border);min-height:56px}.shell__topbar-logo{text-decoration:none;display:inline-flex;align-items:center}.shell__topbar-spacer{width:40px}.shell__hamburger{width:40px;height:40px;border-radius:var(--radius-control);border:1px solid var(--border);background:var(--bg-surface);cursor:pointer;display:inline-flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:0;transition:border-color var(--dur-quick) var(--ease),background var(--dur-quick) var(--ease)}.shell__hamburger:hover{border-color:var(--border-hover)}.shell__hamburger:focus-visible{outline:2px solid var(--sunrise);outline-offset:2px}.shell__hamburger>span{display:block;width:18px;height:1.5px;background:var(--text-primary);border-radius:1px}.shell__drawer-scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-scrim);z-index:70;animation:fade-in .16s var(--ease)}.shell__nav--drawer{display:flex;position:fixed;top:0;left:0;bottom:0;width:min(82vw,320px);height:100dvh;padding:var(--space-5);border-right:1px solid var(--border);background:var(--bg-page);z-index:71;flex-direction:column;gap:var(--space-5);overflow:hidden;animation:drawer-in .22s var(--ease)}.shell__drawer-close{display:inline-flex;align-items:center;justify-content:center;position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);font-size:22px;line-height:1;cursor:pointer;padding:0}.shell__drawer-close:hover{color:var(--text-hover)}.shell__main{padding:var(--space-5) var(--space-4) var(--space-7);max-width:100%}}@keyframes drawer-in{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@media (max-width: 560px){.auth-shell{padding:var(--space-4)}.auth-card{padding:var(--space-6) var(--space-5)}.modal-overlay{padding:var(--space-4);align-items:flex-end}.modal{padding:var(--space-5);border-radius:var(--radius-card) var(--radius-card) 0 0}.modal__title{font-size:22px}.modal__actions{flex-direction:column-reverse;align-items:stretch}.modal__actions .btn{width:100%}.page__title{font-size:clamp(26px,8vw,36px)}.date-header{font-size:clamp(24px,7vw,34px)}.composer__date-chip{font-size:12px;padding:4px 10px}.composer-wrap{padding:var(--space-3)}.history-controls{flex-direction:column;align-items:stretch;gap:var(--space-3)}.history-view{width:100%;margin-right:0}.history-view__chip{flex:1;text-align:center}.history-nav{width:100%;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center}.history-period{min-width:0}.history-controls__jump{margin-left:0;align-self:flex-start}.filter-bar{padding:var(--space-2) 0}.history-filters{flex-direction:column;align-items:stretch;gap:var(--space-2)}.project-filter{width:100%}.project-filter__trigger{width:100%;justify-content:space-between}.project-filter__menu{left:0;right:0;min-width:0}.project-grid{grid-template-columns:1fr}.todo-row__delete,.todo-row__add-label{opacity:1}}.recurring-new{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card)}.recurring-new__actions{display:flex;justify-content:flex-end;margin-top:var(--space-2)}.recurring-freq{display:flex;gap:var(--space-2);flex-wrap:wrap}.recurring-freq__chip{font-family:var(--font-body);font-size:14px;padding:6px 14px;border-radius:var(--radius-control);border:1px solid var(--border);background:var(--bg-page);color:var(--text-secondary);cursor:pointer;text-transform:lowercase;transition:all var(--dur-quick) var(--ease)}.recurring-freq__chip:not(.recurring-freq__chip--active):hover{color:var(--text-hover)}.recurring-freq__chip--active{background:var(--espresso);color:var(--linen);border-color:var(--espresso)}.recurring-days{display:flex;gap:6px;flex-wrap:wrap}.recurring-days__chip{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--border);background:var(--bg-page);color:var(--text-secondary);font-family:var(--font-body);font-weight:500;font-size:14px;cursor:pointer;transition:all var(--dur-quick) var(--ease)}.recurring-days__chip:not(.recurring-days__chip--active):hover{color:var(--text-hover)}.recurring-days__chip--active{background:var(--espresso);color:var(--linen);border-color:var(--espresso)}.recurring-yearly{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.recurring-labels{display:flex;gap:var(--space-2);flex-wrap:wrap}.recurring-labels__chip{font-family:var(--font-body);font-size:13px;font-weight:500;padding:4px 10px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:filter var(--dur-quick) var(--ease)}.recurring-labels__chip[aria-pressed=false]{filter:grayscale(.35) opacity(.7)}.recurring-labels__chip:hover{filter:none}.recurring-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.recurring-list__row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:var(--space-3);align-items:center;padding:14px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control)}.recurring-list__main{display:flex;flex-direction:column;gap:4px;min-width:0}.recurring-list__title{font-family:var(--font-body);font-weight:500;font-size:15px;color:var(--text-primary)}.recurring-list__meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.recurring-list__cadence{font-size:13px;color:var(--text-secondary)}.recurring-list__chip{font-size:12px;font-weight:500;padding:2px 8px;border-radius:999px;background:var(--caramel);color:var(--linen)}.recurring-list__labels{display:inline-flex;gap:4px;flex-wrap:wrap}.recurring-list__desc{font-size:13px;color:var(--text-secondary)}@media (max-width: 600px){.recurring-list__row{grid-template-columns:1fr}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.chart-tooltip{position:fixed;top:0;left:0;z-index:80;pointer-events:none;background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-control);padding:6px 10px;font-family:var(--font-body);font-size:12px;font-weight:500;line-height:1.3;white-space:nowrap;transition:opacity var(--dur-quick) var(--ease)}.chart-tooltip__date{font-family:var(--font-display);font-weight:400;font-size:13px;font-variation-settings:"SOFT" var(--fraunces-soft);margin-right:var(--space-2)}.chart-tooltip__value{color:var(--text-secondary)}.chart-frame{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-5);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card)}.chart-frame--full{grid-column:1 / -1}.chart-frame__head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3)}.chart-frame__title{margin:0;font-family:var(--font-display);font-weight:500;font-size:22px;line-height:1.2;color:var(--text-primary);font-variation-settings:"SOFT" var(--fraunces-soft)}.chart-frame__sub{margin:4px 0 0;font-size:13px;color:var(--text-secondary)}.chart-frame__aside{font-size:12px;color:var(--text-secondary);white-space:nowrap}.chart-frame__body{display:flex;flex-direction:column}.stat-tile{display:flex;flex-direction:column;gap:4px;padding:var(--space-5);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);justify-content:center}.stat-tile__row{display:flex;align-items:baseline;gap:var(--space-3);flex-wrap:wrap}.stat-tile__value{font-family:var(--font-display);font-weight:500;font-size:clamp(40px,6vw,64px);line-height:1;color:var(--text-primary);letter-spacing:-.01em;font-variation-settings:"SOFT" var(--fraunces-soft)}.stat-tile__value--highlight{color:var(--sunrise)}.stat-tile__trailing{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary)}.stat-tile__label{font-family:var(--font-body);font-size:13px;color:var(--text-secondary)}.year-heatmap{display:flex;flex-direction:column;gap:var(--space-3)}.year-heatmap__scroll{overflow-x:auto;margin:0 calc(-1 * var(--space-2));padding:0 var(--space-2)}.year-heatmap__svg{display:block}.year-heatmap__month{font-family:var(--font-display);font-size:11px;font-weight:400;letter-spacing:.05em;text-transform:lowercase;fill:var(--text-secondary);font-variation-settings:"SOFT" var(--fraunces-soft)}.year-heatmap__dow{font-family:var(--font-mono);font-size:10px;fill:var(--text-secondary)}.year-heatmap__legend{display:flex;align-items:center;gap:6px;align-self:flex-end;font-family:var(--font-body);font-size:11px;color:var(--text-secondary)}.year-heatmap__legend-label{margin:0 2px}.year-heatmap__legend-swatch{display:inline-block;width:12px;height:12px;border-radius:3px}.hbar{display:flex;flex-direction:column;gap:6px}.hbar--label-below{gap:var(--space-3)}.hbar__row{display:grid;grid-template-columns:var(--hbar-label-width, 72px) 1fr;align-items:center;gap:var(--space-3);min-height:22px;cursor:default}.hbar__row--below{display:flex;flex-direction:column;align-items:stretch;gap:4px}.hbar__label{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);text-align:right;white-space:nowrap}.hbar__track{position:relative;display:flex;align-items:center;height:18px}.hbar__fill{height:18px;border-radius:4px;background:var(--coffee);transition:width .4s var(--ease)}.hbar__below-label{font-family:var(--font-body);font-size:13px;font-weight:500;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hbar__value{margin-left:var(--space-2);font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);white-space:nowrap}.chart-empty{margin:0;font-size:13px;color:var(--text-secondary);font-style:italic}.stack-bar{display:flex;flex-direction:column;gap:var(--space-3)}.stack-bar__track{display:flex;width:100%;height:18px;border-radius:4px;overflow:hidden;background:var(--chart-track)}.stack-bar__seg{height:100%;transition:width .4s var(--ease);box-shadow:inset -1px 0 0 var(--bg-page);cursor:default}.stack-bar__seg:last-child{box-shadow:none}.stack-bar__total{font-family:var(--font-body);font-size:12px;color:var(--text-secondary)}.stack-bar__legend{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:var(--space-3) var(--space-4)}.stack-bar__legend-item{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:12px;color:var(--text-secondary)}.stack-bar__swatch{display:inline-block;width:10px;height:10px;border-radius:2px}.stack-bar__legend-label{color:var(--text-primary);font-weight:500}.stack-bar__legend-value{font-family:var(--font-mono);font-size:11px}.dual-line{display:flex;flex-direction:column;gap:var(--space-3)}.dual-line__svg{width:100%;height:auto;display:block}.dual-line__baseline{stroke:var(--border);stroke-width:1;stroke-dasharray:2 3}.dual-line__tick,.dual-line__max{font-family:var(--font-mono);font-size:10px;fill:var(--text-secondary)}.dual-line__legend{display:flex;gap:var(--space-4);font-family:var(--font-body);font-size:12px;color:var(--text-secondary)}.dual-line__legend-item{display:inline-flex;align-items:center;gap:6px}.dual-line__legend-swatch{display:inline-block;width:14px;height:2px;border-radius:2px}.dual-line__legend-swatch--dashed{background:transparent;height:0;border-radius:0;width:18px;border-top:2px dashed currentColor}.histogram{display:flex;flex-direction:column;gap:var(--space-3)}.histogram__bars{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-3);height:160px;align-items:end}.histogram__col{display:flex;flex-direction:column;align-items:center;justify-content:end;gap:6px;height:100%;cursor:default}.histogram__count{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary)}.histogram__bar-track{width:100%;flex:1 1 auto;display:flex;align-items:flex-end;min-height:0}.histogram__bar-fill{width:100%;border-radius:4px 4px 0 0;transition:height .4s var(--ease)}.histogram__label{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);text-align:center;white-space:nowrap}.velocity{display:flex;flex-direction:column}.velocity__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.velocity__row{display:grid;grid-template-columns:1fr 64px 32px;align-items:center;gap:var(--space-3);padding:6px 0;border-bottom:1px solid var(--border);cursor:default}.velocity__row:last-child{border-bottom:0}.velocity__name{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.velocity__spark{width:64px;height:18px;display:block}.velocity__recent{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);text-align:right}.progress-bars{display:flex;flex-direction:column}.progress-bars__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-3)}.progress-bars__row{display:flex;flex-direction:column;gap:6px}.progress-bars__head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3)}.progress-bars__name{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.progress-bars__count{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);white-space:nowrap}.progress-bars__track{height:6px;border-radius:3px;background:var(--chart-track);overflow:hidden}.progress-bars__fill{height:100%;border-radius:3px;transition:width .4s var(--ease)}.moments{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.moments__item{display:grid;grid-template-columns:20px 1fr;align-items:baseline;font-family:var(--font-body);font-size:15px;color:var(--text-primary)}.moments__glyph{font-family:var(--font-display);font-size:20px;line-height:1;color:var(--caramel);text-align:center;font-variation-settings:"SOFT" var(--fraunces-soft)}.shell__main:has(.patterns-page){max-width:1240px}.patterns-page__loading{margin:var(--space-6) 0;font-family:var(--font-body);font-size:15px;color:var(--text-secondary)}.patterns-page__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--space-4);padding:var(--space-7) var(--space-5);min-height:380px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card)}.patterns-page__empty-title{margin:0;font-family:var(--font-display);font-weight:500;font-size:clamp(28px,4vw,36px);line-height:1.1;color:var(--text-primary);font-variation-settings:"SOFT" var(--fraunces-soft)}.patterns-page__empty-sub{margin:0;max-width:38ch;font-family:var(--font-body);font-size:15px;color:var(--text-secondary)}.brewing-mug__steam{opacity:0;transform-box:fill-box;transform-origin:bottom center;animation:brewing-steam 3.6s ease-in-out infinite}.brewing-mug__steam--b{animation-delay:1.4s}@keyframes brewing-steam{0%{opacity:0;transform:translateY(8px) scaleY(.7)}25%{opacity:.55}to{opacity:0;transform:translateY(-14px) scaleY(1.2)}}@media (prefers-reduced-motion: reduce){.brewing-mug__steam{animation:none;opacity:.55;transform:none}}.patterns-page__section{margin-top:var(--space-5);opacity:0;transform:translateY(8px);animation:patterns-reveal .6s var(--ease) forwards}.patterns-page__section:nth-child(1){animation-delay:0ms}.patterns-page__section:nth-child(2){animation-delay:70ms}.patterns-page__section:nth-child(3){animation-delay:.14s}.patterns-page__section:nth-child(4){animation-delay:.21s}.patterns-page__section:nth-child(5){animation-delay:.28s}.patterns-page__section:nth-child(6){animation-delay:.35s}.patterns-page__section:nth-child(7){animation-delay:.42s}.patterns-page__section:nth-child(8){animation-delay:.49s}.patterns-page__section:nth-child(9){animation-delay:.56s}.patterns-page__section:nth-child(10){animation-delay:.63s}@keyframes patterns-reveal{to{opacity:1;transform:none}}@media (prefers-reduced-motion: reduce){.patterns-page__section{animation:none;opacity:1;transform:none}}.patterns-page__strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-4)}@media (max-width: 900px){.patterns-page__strip{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 520px){.patterns-page__strip{grid-template-columns:1fr}}.stat-tile__delta{color:var(--text-secondary)}.patterns-page__row{display:grid;gap:var(--space-4)}.patterns-page__row--4{grid-template-columns:repeat(4,minmax(0,1fr))}.patterns-page__row--3{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 1100px){.patterns-page__row--4,.patterns-page__row--3{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 700px){.patterns-page__row--4,.patterns-page__row--3{grid-template-columns:1fr}}.cleared-projects{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.cleared-projects__row{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-3);padding:10px 0;border-bottom:1px solid var(--border)}.cleared-projects__row:last-child{border-bottom:0}.cleared-projects__name{font-family:var(--font-display);font-size:16px;color:var(--text-primary);font-variation-settings:"SOFT" var(--fraunces-soft)}.cleared-projects__days{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary)}.shared-chip{display:inline-flex;align-items:center;gap:4px;max-width:100%;min-width:0;padding:2px 8px;border-radius:var(--radius-pill);background:transparent;border:1px solid var(--border);font-family:var(--font-body);font-size:11px;font-weight:500;letter-spacing:.04em;color:var(--text-secondary);text-transform:lowercase;white-space:nowrap}.shared-chip svg{width:12px;height:12px;flex:none}.shared-chip__text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shared-chip--solid{background:var(--foam);border-color:var(--foam)}.project-card__foot{display:flex;min-width:0;margin-top:auto;padding-top:2px}.project-detail__owner{font-style:italic;margin:0}.page__title-action{margin-left:auto}.board-page__title--static{display:inline-block;font-family:var(--font-display);font-weight:500;font-variation-settings:"opsz" 72,"SOFT" 100;font-size:28px;line-height:1.15;color:var(--text-primary)}.board-page__owner{font-size:12px;color:var(--text-secondary);font-style:italic}.invite-banner{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.invite-banner__row{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card)}.invite-banner__icon{display:inline-flex;color:var(--text-secondary)}.invite-banner__text{flex:1;min-width:180px;font-size:14px;color:var(--text-primary)}.invite-banner__text strong{font-weight:500}.invite-banner__actions{display:inline-flex;gap:var(--space-2)}.share-dialog{max-width:750px}.share-dialog__invite{display:flex;gap:var(--space-2)}.share-dialog__invite .input{flex:1}.share-dialog__hint,.share-dialog__note{margin:0;font-size:13px;color:var(--text-secondary)}.share-dialog__members{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;max-height:330px;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-gutter:stable;padding-inline-end:var(--space-2);scrollbar-width:thin;scrollbar-color:transparent transparent}.share-dialog__members:hover,.share-dialog__members:focus-within{scrollbar-color:var(--border-strong) transparent}.share-dialog__member{display:flex;align-items:center;gap:var(--space-3);padding:10px 0;border-bottom:1px solid var(--border)}.share-dialog__member:last-child{border-bottom:0}.share-dialog__avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;flex:none;border-radius:50%;background:var(--foam);color:var(--text-secondary);font-family:var(--font-display);font-size:14px}.share-dialog__who{display:flex;flex-direction:column;min-width:0;flex:1}.share-dialog__name{font-size:14px;font-weight:500;color:var(--text-primary);overflow-wrap:anywhere}.share-dialog__email{font-size:12px;color:var(--text-secondary);overflow-wrap:anywhere}.share-dialog__remove{border:0;background:none;padding:2px 6px;font-size:18px;line-height:1;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-input);transition:color var(--dur-quick) var(--ease),background var(--dur-quick) var(--ease)}.share-dialog__remove:hover{color:var(--danger);background:var(--danger-bg)}.share-dialog__loading{padding:10px 0;font-size:13px}.toast-region{position:fixed;right:var(--space-4);bottom:var(--space-4);z-index:200;display:flex;flex-direction:column;gap:var(--space-2);width:min(330px,calc(100vw - 2 * var(--space-4)));pointer-events:none}.invite-toasts{display:flex;flex-direction:column;gap:var(--space-2);width:100%;pointer-events:auto}.invite-toast{display:flex;align-items:center;gap:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid var(--caramel);border-radius:var(--radius-card);padding:var(--space-3);animation:toast-in var(--dur-base) var(--ease)}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.invite-toast__icon{display:inline-flex;color:var(--caramel);flex-shrink:0}.invite-toast__body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1 1 auto}.invite-toast__title{font-family:var(--font-body);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.invite-toast__who{font-size:12px;color:var(--text-secondary)}.invite-toast__actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0}.invite-toast__accept{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--btn-primary-fg);background:var(--btn-primary-bg);border:1px solid var(--btn-primary-bg);border-radius:var(--radius-control);padding:5px 11px;cursor:pointer;transition:background var(--dur-quick) var(--ease)}.invite-toast__accept:hover{background:var(--btn-primary-bg-hover)}.invite-toast__accept:disabled{opacity:.6;cursor:default}.invite-toast__later{font-family:var(--font-body);font-size:12px;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-control);padding:3px 6px;cursor:pointer;transition:background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.invite-toast__later:hover{background:var(--hover-fill);color:var(--text-primary)}@media (prefers-reduced-motion: reduce){.invite-toast{animation:none}}.share-dialog__invite{position:relative}.share-dialog__menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-2);display:flex;flex-direction:column;gap:2px}.share-dialog__section-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-weight:500;padding:2px 8px 4px}.share-dialog__suggestion{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:6px 8px;background:none;border:none;border-radius:var(--radius-input);font-family:var(--font-body);text-align:left;cursor:pointer;transition:background var(--dur-quick) var(--ease)}.share-dialog__suggestion:hover:not(:disabled){background:var(--hover-fill)}.share-dialog__suggestion:disabled{opacity:.6;cursor:default}.share-dialog__invite-cue{font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:lowercase;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-pill);padding:2px 8px;transition:color var(--dur-quick) var(--ease),border-color var(--dur-quick) var(--ease)}.share-dialog__suggestion:hover:not(:disabled) .share-dialog__invite-cue{color:var(--text-primary);border-color:var(--border-hover)}.landing{min-height:100dvh;background:radial-gradient(70% 50% at 12% 0%,var(--bg-surface-muted),transparent 65%),radial-gradient(50% 40% at 95% 15%,var(--foam),transparent 70%),radial-gradient(60% 50% at 100% 100%,var(--bg-surface-muted),transparent 65%),var(--bg-page);color:var(--text-primary);font-family:var(--font-body)}.landing__container{max-width:1120px;margin:0 auto;padding:0 clamp(20px,4vw,48px)}.landing__nav{display:flex;align-items:center;justify-content:space-between;padding:22px 0 12px}.landing__nav-actions{display:flex;align-items:center;gap:var(--space-4)}.landing__nav-link{font-size:14px;font-weight:500;color:var(--text-secondary);text-decoration:none;letter-spacing:.01em}.landing__nav-link:hover{color:var(--text-hover)}.landing__hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:clamp(32px,6vw,80px);align-items:center;padding:clamp(48px,9vw,96px) 0 clamp(56px,9vw,104px)}.landing__eyebrow{font-family:var(--font-body);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--coffee);font-weight:500;margin:0 0 18px;display:inline-flex;align-items:center;gap:10px}.landing__eyebrow:before{content:"";width:28px;height:1px;background:var(--coffee);display:inline-block}.landing__headline{font-family:var(--font-display);font-variation-settings:"opsz" 144,"SOFT" 100;font-weight:500;font-size:clamp(44px,7.2vw,88px);line-height:1.02;letter-spacing:-.018em;margin:0 0 24px;color:var(--text-primary)}.landing__headline-mark{position:relative;font-weight:400;font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 100;color:var(--espresso);display:inline-block}.landing__headline-mark:after{content:"";position:absolute;left:-2px;right:-2px;bottom:.05em;height:.32em;background:var(--sunrise);opacity:.55;z-index:-1;border-radius:2px;transform:translateY(.08em)}.landing__lede{font-size:clamp(16px,1.4vw,18px);line-height:1.55;color:var(--text-secondary);max-width:52ch;margin:0 0 32px}.landing__cta-row{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-4)}.landing__cta-row .btn{padding:14px 22px;font-size:15px}.landing__hero-mock{position:relative;display:flex;justify-content:center}.landing__hero-mock:before{content:"";position:absolute;inset:-28px -28px auto auto;width:220px;height:220px;border:1px solid var(--tan);border-radius:50%;opacity:.55;z-index:0}.landing__hero-mock:after{content:"";position:absolute;bottom:-36px;left:-16px;width:130px;height:130px;border:1px solid var(--caramel);border-radius:50%;opacity:.18;z-index:0}.mock-card{position:relative;z-index:1;width:100%;max-width:420px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:28px 28px 22px;transform:rotate(-1.2deg);transition:transform var(--dur-base) var(--ease)}.landing__hero-mock .mock-card:hover{transform:rotate(0)}.mock-card--straight{transform:none}.mock-card--tilt-right{transform:rotate(1.4deg)}.mock-date-header{display:flex;flex-direction:column;gap:4px;margin-bottom:22px;position:relative}.mock-date-header__main{font-family:var(--font-display);font-variation-settings:"opsz" 96,"SOFT" 100;font-weight:500;font-size:34px;line-height:1;letter-spacing:-.012em;color:var(--text-primary)}.mock-date-header__sub{font-family:var(--font-body);font-weight:400;font-size:12px;letter-spacing:.05em;text-transform:lowercase;color:var(--text-secondary)}.mock-date-header--today .mock-date-header__main:after{content:"";display:block;width:44px;height:3px;background:var(--sunrise);border-radius:2px;margin-top:6px}.mock-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.mock-row{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center;padding:11px 0;border-bottom:1px solid transparent}.mock-row+.mock-row{border-top:1px dashed rgba(232,213,183,.55)}.mock-row__body{display:flex;flex-wrap:wrap;align-items:center;gap:6px;min-width:0}.mock-check{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--coffee);background:transparent;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.mock-check--done{background:var(--foam);border-color:var(--coffee)}.mock-check--done:after{content:"✓";font-family:var(--font-body);font-size:12px;color:var(--coffee);font-weight:500;line-height:1}.mock-title{font-family:var(--font-body);font-size:14.5px;font-weight:400;color:var(--text-primary);line-height:1.4}.mock-title--done{color:var(--text-secondary);text-decoration:line-through;text-decoration-color:var(--coffee)}.mock-pill{display:inline-flex;align-items:center;padding:2px 9px;border-radius:var(--radius-pill);font-size:10.5px;font-weight:500;letter-spacing:.04em;line-height:1.3;white-space:nowrap}.mock-pill--mustard{background:#f4e2a3;color:#6d5512}.mock-pill--sage{background:#cfe0ba;color:#3a5224}.mock-pill--sky{background:#c9dae9;color:#2a4664}.mock-pill--plum{background:#dac4d6;color:#4e2d48}.mock-pill--rose{background:#eeccd2;color:#6a2a36}.mock-pill--slate{background:#ccd2da;color:#2e3744}.mock-pill--caramel{background:#8b5a2b2e;color:var(--caramel)}.mock-pill--terracotta{background:#efc4b0;color:#793e27}.landing__ring{border:none;height:60px;position:relative;margin:0;display:flex;align-items:center;justify-content:center}.landing__ring:before,.landing__ring:after{content:"";flex:1;height:1px;background:var(--tan)}.landing__ring-glyph{width:36px;height:36px;border:1px solid var(--tan);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin:0 16px;background:var(--bg-page);color:var(--coffee)}.landing__ring-glyph:after{content:"";width:14px;height:14px;border:1px solid currentColor;border-radius:50%;opacity:.55}.landing__section{padding:clamp(48px,6.5vw,80px) 0}.landing__section-eyebrow{font-family:var(--font-body);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--coffee);font-weight:500;margin:0 0 20px;display:flex;align-items:center;gap:14px}.landing__section-eyebrow:before,.landing__section-eyebrow:after{content:"";flex:0 0 28px;height:1px;background:var(--coffee);opacity:.45}.landing__section-eyebrow:after{flex:1;opacity:.18}.landing__section-title{font-family:var(--font-display);font-variation-settings:"opsz" 96,"SOFT" 100;font-weight:500;font-size:clamp(32px,4.4vw,52px);line-height:1.08;letter-spacing:-.012em;color:var(--text-primary);margin:0 0 18px;max-width:22ch}.landing__section-lede{font-size:clamp(15px,1.2vw,17px);line-height:1.6;color:var(--text-secondary);max-width:58ch;margin:0 0 56px}.landing__split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,48px)}.landing__mode{display:flex;flex-direction:column;gap:var(--space-4)}.landing__mode-tag{font-family:var(--font-body);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:var(--text-secondary)}.landing__mode-title{font-family:var(--font-display);font-variation-settings:"opsz" 72,"SOFT" 100;font-weight:500;font-size:clamp(26px,2.8vw,34px);line-height:1.12;letter-spacing:-.01em;margin:0}.landing__mode-body{font-size:15.5px;line-height:1.6;color:var(--text-secondary);margin:0;max-width:38ch}.landing__mode-art{margin-top:var(--space-4)}.landing__details{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.landing__details>div{background:var(--bg-surface);padding:clamp(32px,4vw,56px);display:flex;flex-direction:column}.landing__detail-title{font-family:var(--font-display);font-variation-settings:"opsz" 48,"SOFT" 100;font-weight:500;font-size:clamp(22px,2vw,26px);line-height:1.2;letter-spacing:-.005em;margin:0 0 10px;color:var(--text-primary)}.landing__detail-body{font-size:15px;line-height:1.6;color:var(--text-secondary);margin:0 0 22px;max-width:42ch}.landing__detail-art{display:flex;flex-wrap:wrap;align-items:center;gap:6px;min-height:38px;margin-top:auto}.kanban-mock{display:flex;gap:clamp(8px,1.2vw,14px);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:clamp(16px,2.4vw,30px);max-width:720px;margin:0}.kanban-mock__col{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:7px;background:var(--bg-surface-muted);border-radius:var(--radius-control);padding:11px 9px}.kanban-mock__col-head{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:12.5px;font-weight:500;color:var(--text-secondary);padding:0 2px 1px}.kanban-mock__count{font-size:11px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:0 7px;line-height:17px}.kanban-mock__card{display:flex;align-items:center;flex-wrap:wrap;gap:5px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);padding:8px 9px;font-size:12.5px;line-height:1.3;color:var(--text-primary)}.kanban-mock__drop{position:relative}.kanban-mock__card--lift{position:absolute;top:-10px;left:0;right:0;z-index:3;border-color:var(--coffee);transform:rotate(-3deg) translate(-54%)}.kanban-mock__card--done{background:var(--foam);color:var(--text-secondary)}.kanban-mock__card--done:before{content:"✓";margin-right:4px;color:var(--coffee);font-weight:500}.kanban-mock__ph{height:32px;border:1px dashed var(--coffee);border-radius:var(--radius-control);background:var(--foam);opacity:.55}.collab-mock{max-width:540px;margin:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:clamp(14px,2.2vw,24px);display:flex;flex-direction:column;gap:14px}.collab-mock__bar{display:flex;flex-wrap:wrap;align-items:center;gap:7px}.collab-mock__bar-label{font-size:12px;color:var(--text-secondary);margin-right:2px}.collab-mock__chip{display:inline-flex;align-items:center;gap:6px;padding:2px 11px 2px 3px;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:12px;color:var(--text-secondary)}.collab-mock__board{display:flex;gap:clamp(8px,1.4vw,13px)}.collab-mock__col{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:7px;background:var(--bg-surface-muted);border-radius:var(--radius-control);padding:10px 9px}.collab-mock__col-head{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:12.5px;font-weight:500;color:var(--text-secondary);padding:0 2px 1px}.collab-mock__count{font-size:11px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:0 7px;line-height:17px}.collab-mock__card{display:flex;flex-direction:column;align-items:flex-start;gap:7px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);padding:9px 10px}.collab-mock__card-title{font-size:12.5px;line-height:1.3;color:var(--text-primary)}.collab-mock__foot{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text-secondary)}.collab-mock__foot--empty{opacity:.7}.collab-avatar{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;flex:none;border-radius:50%;background:var(--foam);color:var(--text-secondary);font-family:var(--font-display);font-size:10.5px}.collab-avatar--sm{width:17px;height:17px;font-size:9.5px}.collab-avatar--empty{background:transparent;border:1px dashed var(--border-strong);color:var(--text-secondary)}.planner-mock{--pm-gutter: 44px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:clamp(16px,2.2vw,26px);max-width:540px;margin:0}.planner-mock__day{position:relative;background:var(--bg-surface-muted);border:1px solid var(--border);border-radius:var(--radius-control);overflow:hidden}.planner-mock__hour{position:relative;border-top:1px solid var(--border);box-sizing:border-box}.planner-mock__hour:first-child{border-top:none}.planner-mock__hour-label{position:absolute;top:3px;left:0;width:var(--pm-gutter);padding-right:8px;text-align:right;font-size:10px;color:var(--text-secondary);opacity:.7;font-variant-numeric:tabular-nums}.planner-mock__now{position:absolute;left:var(--pm-gutter);right:8px;height:0;border-top:2px solid var(--sunrise);z-index:3}.planner-mock__now span{position:absolute;left:-4px;top:-4px;width:7px;height:7px;border-radius:50%;background:var(--sunrise)}.planner-mock__block{position:absolute;left:calc(var(--pm-gutter) + 6px);right:8px;display:flex;align-items:center;gap:6px;background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid var(--coffee);border-radius:var(--radius-control);padding:4px 8px;font-size:12px;line-height:1.25;color:var(--text-primary);overflow:hidden;z-index:2}.planner-mock__block--project{border-left-color:var(--caramel)}.planner-mock__block--calendar{background:var(--cal-block-bg);border-color:var(--caramel);border-left-color:var(--coffee)}.planner-mock__cal-icon{color:var(--coffee);flex-shrink:0;opacity:.85;display:inline-flex}.planner-mock__block-title{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.planner-mock__bell{color:var(--coffee);flex-shrink:0}.patterns-mock{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:clamp(24px,3.4vw,44px);max-width:900px}.patterns-mock:before{content:"";position:absolute;inset:-24px -24px auto auto;width:132px;height:132px;border:1px solid var(--tan);border-radius:50%;opacity:.5;pointer-events:none}.patterns-mock__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,2vw,28px);padding-bottom:clamp(20px,2.6vw,28px);border-bottom:1px dashed var(--tan)}.patterns-mock__stat{display:flex;flex-direction:column;gap:7px;min-width:0}.patterns-mock__stat-num{font-family:var(--font-display);font-variation-settings:"opsz" 96,"SOFT" 100;font-weight:500;font-size:clamp(28px,3.4vw,46px);line-height:1;letter-spacing:-.015em;color:var(--text-primary)}.patterns-mock__stat-num--streak{color:var(--sunrise)}.patterns-mock__stat-label{font-size:12px;line-height:1.35;color:var(--text-secondary)}.patterns-mock__grid{padding-top:clamp(20px,2.6vw,28px)}.patterns-mock__heat{display:grid;grid-template-columns:repeat(44,1fr);gap:clamp(2px,.5vw,4px)}.patterns-mock__cell{aspect-ratio:1 / 1;border-radius:2px}.patterns-mock .lvl-0{background:var(--chart-ramp-0)}.patterns-mock .lvl-1{background:var(--chart-ramp-1)}.patterns-mock .lvl-2{background:var(--chart-ramp-2)}.patterns-mock .lvl-3{background:var(--chart-ramp-3)}.patterns-mock .lvl-4{background:var(--chart-ramp-4)}.patterns-mock__legend{display:flex;align-items:center;justify-content:flex-end;gap:7px;margin-top:12px;font-size:11px;color:var(--text-secondary)}.patterns-mock__legend-swatches{display:inline-flex;gap:3px}.patterns-mock__legend-swatch{width:11px;height:11px;border-radius:2px}.patterns-mock__notes{list-style:none;margin:clamp(20px,2.6vw,28px) 0 0;padding:clamp(18px,2.4vw,24px) 0 0;border-top:1px dashed var(--tan);display:flex;flex-direction:column;gap:9px}.patterns-mock__note{display:grid;grid-template-columns:18px 1fr;align-items:baseline;font-size:14.5px;line-height:1.45;color:var(--text-primary)}.patterns-mock__note-glyph{font-family:var(--font-display);font-size:20px;line-height:1;color:var(--caramel);text-align:center}.pets-mock{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:clamp(28px,3.4vw,44px);max-width:600px}.pets-mock__shelf{display:flex;align-items:flex-end;justify-content:center;gap:clamp(8px,3vw,40px)}.pets-mock__pet{margin:0;display:flex;flex-direction:column;align-items:center;gap:8px}.pets-mock__art{width:clamp(76px,12vw,116px);height:auto;overflow:visible}.pets-mock__name{font-family:var(--font-display);font-variation-settings:"opsz" 96,"SOFT" 100;font-weight:500;font-size:clamp(14px,1.4vw,16px);color:var(--text-primary)}.pets-mock__caption{margin:clamp(22px,2.6vw,30px) 0 0;padding-top:clamp(18px,2.4vw,24px);border-top:1px dashed var(--tan);text-align:center;font-size:13.5px;color:var(--text-secondary)}.landing__pricing{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,28px);margin-top:8px}.pricing-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:clamp(28px,3.5vw,40px);display:flex;flex-direction:column;gap:var(--space-4);position:relative}.pricing-card--featured{border-color:var(--espresso);background:linear-gradient(180deg,rgba(245,166,91,.06),transparent 30%),var(--bg-surface)}.pricing-card--featured:after{content:"recommended";position:absolute;top:-10px;right:24px;background:var(--sunrise);color:var(--espresso);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:var(--radius-pill)}.pricing-card__name{font-family:var(--font-display);font-variation-settings:"opsz" 48,"SOFT" 100;font-weight:500;font-size:26px;line-height:1.1;margin:0;color:var(--text-primary)}.pricing-card__price{display:flex;align-items:baseline;gap:6px;margin:0}.pricing-card__price-num{font-family:var(--font-display);font-variation-settings:"opsz" 144,"SOFT" 100;font-weight:500;font-size:clamp(48px,5vw,64px);line-height:1;letter-spacing:-.02em;color:var(--text-primary)}.pricing-card__price-unit{font-size:14px;color:var(--text-secondary);letter-spacing:.02em}.pricing-card__tagline{font-size:14.5px;color:var(--text-secondary);line-height:1.5;margin:0;min-height:2.8em}.pricing-card__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.pricing-card__list li{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;color:var(--text-primary);line-height:1.5}.pricing-card__list li:before{content:"";flex-shrink:0;width:16px;height:16px;margin-top:3px;border-radius:50%;border:1.5px solid var(--coffee);background:radial-gradient(circle at 50% 50%,var(--foam) 0 36%,transparent 38%)}.pricing-card__list li.muted{color:var(--text-secondary)}.pricing-card__list li.muted:before{border-color:var(--tan);background:transparent}.pricing-card__cta{margin-top:auto}.landing__finale{padding:clamp(72px,10vw,128px) 0 clamp(80px,10vw,128px);text-align:center}.landing__finale-quote{font-family:var(--font-display);font-variation-settings:"opsz" 144,"SOFT" 100;font-weight:500;font-style:italic;font-size:clamp(28px,3.6vw,44px);line-height:1.18;letter-spacing:-.012em;color:var(--text-primary);max-width:22ch;margin:0 auto 28px}.landing__finale-cta{display:inline-flex;align-items:center;gap:10px}.landing__footer{border-top:1px solid var(--border);padding:28px 0 36px;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;font-size:13px;color:var(--text-secondary)}.landing__footer-links{display:flex;gap:20px}.landing__footer-links a{color:var(--text-secondary);text-decoration:none}.landing__footer-links a:hover{color:var(--text-hover)}.legal{min-height:100dvh;background:var(--bg-page);color:var(--text-primary);font-family:var(--font-body)}.legal__container{max-width:760px;margin:0 auto;padding:0 clamp(20px,4vw,40px) 96px}.legal__nav{display:flex;align-items:center;justify-content:space-between;padding:22px 0 12px}.legal__back{font-size:14px;font-weight:500;color:var(--text-secondary);text-decoration:none}.legal__back:hover{color:var(--text-hover)}.legal__title{font-family:var(--font-display);font-variation-settings:"opsz" 96,"SOFT" 100;font-weight:500;font-size:clamp(34px,5vw,52px);line-height:1.05;letter-spacing:-.015em;color:var(--text-primary);margin:clamp(24px,5vw,48px) 0 8px}.legal__updated{font-size:14px;color:var(--text-secondary);margin:0 0 36px}.legal__content h2{font-family:var(--font-display);font-variation-settings:"opsz" 48,"SOFT" 100;font-weight:500;font-size:clamp(22px,2.6vw,28px);line-height:1.2;letter-spacing:-.01em;color:var(--text-primary);margin:40px 0 12px}.legal__content p{font-size:16px;line-height:1.65;color:var(--text-primary);margin:0 0 16px}.legal__content ul{margin:0 0 16px;padding-left:22px}.legal__content li{font-size:16px;line-height:1.65;color:var(--text-primary);margin:0 0 8px}.legal__content strong{font-weight:500}@media (max-width: 920px){.landing__hero{grid-template-columns:1fr;gap:48px;padding-top:36px}.landing__hero-mock:before{right:-16px}.landing__split,.landing__details,.landing__pricing{grid-template-columns:1fr}}@media (max-width: 560px){.landing__nav-actions .landing__nav-link{display:none}.landing__headline{font-size:clamp(40px,11vw,56px)}.landing__finale-quote{font-size:clamp(24px,6vw,32px)}.landing__nav{padding:16px 0 8px}.landing__hero{padding:28px 0 56px;gap:36px}.landing__section{padding:56px 0}.landing__hero-mock:before{width:140px;height:140px;inset:-16px -8px auto auto}.landing__hero-mock:after{width:90px;height:90px;bottom:-22px;left:-4px}.mock-card{padding:22px 20px 18px;transform:none}.mock-date-header__main{font-size:28px}.landing__cta-row{flex-direction:column;align-items:stretch}.landing__cta-row .btn{width:100%}.pricing-card--featured:after{right:16px}.pricing-card,.landing__details{padding:24px}.patterns-mock{padding:22px}.patterns-mock__stats{grid-template-columns:repeat(2,1fr);gap:22px 16px}.landing__footer{flex-direction:column;align-items:flex-start;gap:12px}}.shell__main:has(.board-page){max-width:none;padding:var(--space-6) clamp(var(--space-4),4vw,var(--space-6))}.board-page{display:flex;flex-direction:column;gap:var(--space-4);min-width:0}.board-page__head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.board-page__titles{display:flex;flex-direction:column;gap:var(--space-1)}.board-page__title{font-family:var(--font-display);font-weight:500;font-size:28px;color:var(--text-primary);background:none;border:none;padding:2px 4px;margin-left:-4px;text-align:left;cursor:text;border-radius:var(--radius-control)}.board-page__title:hover{background:var(--hover-fill)}.board-page__title-edit{font-family:var(--font-display);font-size:28px;max-width:420px}.board-page__error{margin:0}.board-page__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);flex:1 1 auto;min-width:0}.board-page__addcol{display:flex;align-items:center;gap:var(--space-2)}.board-page__addcol .input{max-width:180px}.overflow-actions{position:relative;display:flex;flex:1 1 auto;min-width:0;flex-wrap:nowrap;align-items:center;justify-content:flex-end;gap:var(--space-2)}.overflow-actions__more{position:relative;flex:none;display:inline-flex}.overflow-actions__trigger{padding:6px 10px;flex:none}.overflow-actions__icon{width:16px;height:16px;display:block}.overflow-actions__menu{position:absolute;top:calc(100% + 6px);right:0;z-index:70;min-width:180px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-2);display:flex;flex-direction:column;gap:2px}.overflow-actions__item{display:flex;align-items:center;width:100%;padding:8px 10px;background:none;border:none;border-radius:var(--radius-input);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.overflow-actions__item:hover{background:var(--hover-fill)}.overflow-actions__item--danger{color:var(--danger)}.overflow-actions__item--danger:hover{background:var(--danger-bg)}.overflow-actions__item[disabled]{opacity:.55;cursor:not-allowed}.overflow-actions__measure{position:absolute;top:0;left:0;visibility:hidden;pointer-events:none;white-space:nowrap;display:flex;flex-wrap:nowrap;align-items:center;gap:var(--space-2)}.kanban-board{display:flex;align-items:flex-start;gap:var(--space-4);overflow-x:auto;padding-bottom:var(--space-4)}.kanban-col{flex:0 0 300px;width:300px;max-height:calc(100dvh - 220px);display:flex;flex-direction:column;background:var(--bg-surface-muted);border:1px solid var(--border);border-radius:var(--radius-card);scroll-snap-align:start}.kanban-col--done{background:var(--bg-surface)}@media (min-width: 861px){.shell__main:has(.board-page){height:100dvh;overflow:hidden;display:flex;flex-direction:column}.board-page{flex:1;min-height:0}.kanban-board{flex:1;min-height:0;align-items:stretch;overflow-y:hidden}.kanban-col{max-height:none}.kanban-col__body{flex:1;min-height:0}}@media (max-width: 860px){.shell:has(.board-page){height:100dvh}.shell__main:has(.board-page){min-height:0;overflow:hidden;display:flex;flex-direction:column}.board-page{flex:1;min-height:0}.kanban-board{flex:1;min-height:0;align-items:stretch;overflow-y:hidden}.kanban-col{max-height:none}.kanban-col__body{flex:1;min-height:0}}.kanban-col__head{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-3) var(--space-2)}.kanban-col__name{font-family:var(--font-body);font-weight:500;font-size:14px;color:var(--text-primary);background:none;border:none;padding:2px 4px;margin-left:-4px;border-radius:var(--radius-control);cursor:pointer}.kanban-col__name:disabled{cursor:default}.kanban-col__name:not(:disabled):hover{background:var(--hover-fill)}.kanban-col__rename{font-size:14px;font-weight:500;padding:4px 8px}.kanban-col__count{margin-left:auto;font-size:12px;font-variant-numeric:tabular-nums;color:var(--text-secondary);background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-pill);padding:1px 8px}.kanban-col__delete{border:none;background:none;color:var(--text-secondary);font-size:18px;line-height:1;cursor:pointer;padding:0 2px;border-radius:var(--radius-control)}.kanban-col__delete:hover{color:var(--danger)}.kanban-col__grip{cursor:grab;color:var(--text-secondary);font-size:13px;line-height:1;padding:0 2px;opacity:.5;-webkit-user-select:none;user-select:none;touch-action:none}.kanban-col__grip:hover{opacity:1;color:var(--text-primary)}.kanban-col__grip:active{cursor:grabbing}.kanban-col__body{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2) var(--space-3) var(--space-3);overflow-y:auto;min-height:60px;border-radius:0 0 var(--radius-card) var(--radius-card);transition:background var(--dur-quick) var(--ease);scrollbar-width:thin;scrollbar-color:transparent transparent}.kanban-col__body:hover,.kanban-col__body:focus-within{scrollbar-color:var(--border-strong) transparent}.kanban-col__body--over{background:var(--row-hover)}.kanban-col__empty{margin:var(--space-2) 0;font-size:13px;color:var(--text-secondary);opacity:.75}.kanban-col__add-cards{margin:var(--space-2) var(--space-3) var(--space-3);padding:var(--space-2);border:1px dashed var(--border-strong);border-radius:var(--radius-control);background:none;color:var(--text-secondary);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer}.kanban-col__add-cards:hover{color:var(--text-primary);border-color:var(--coffee)}.kanban-card{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.kanban-col--done .kanban-card{background:var(--foam)}.kanban-card-ph{flex:0 0 38px;height:38px;border:1px dashed var(--coffee);border-radius:var(--radius-control);background:var(--foam);opacity:.7}.kanban-card--grab{cursor:grab}.kanban-card--grab:active{cursor:grabbing}.kanban-card__title{position:relative;font-size:14px;line-height:1.4;color:var(--text-primary);word-break:break-word;padding-right:18px}.kanban-card--done .kanban-card__title{text-decoration:line-through;text-decoration-color:var(--coffee);color:var(--text-secondary)}.kanban-card--completing .kanban-card__title{text-decoration:none}.kanban-card__strike{position:absolute;top:0;right:0;bottom:0;left:0;padding-right:18px;color:var(--text-secondary);text-decoration:line-through;text-decoration-color:var(--coffee);pointer-events:none;clip-path:inset(0 100% 0 0);animation:kanban-strike .46s var(--ease) forwards}@keyframes kanban-strike{to{clip-path:inset(0 0 0 0)}}@media (prefers-reduced-motion: reduce){.kanban-card__strike{animation:none;clip-path:none}}.kanban-card__meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-1)}.kanban-card__due,.kanban-card__project{font-size:11px;border-radius:var(--radius-pill);padding:1px 8px;white-space:nowrap}.kanban-card__due{color:var(--caramel);border:1px solid var(--caramel)}.kanban-card__project{color:var(--coffee);background:var(--foam)}.kanban-card__remove{position:absolute;top:4px;right:4px;border:none;background:none;color:var(--text-secondary);font-size:16px;line-height:1;cursor:pointer;opacity:0;border-radius:var(--radius-control);padding:2px 5px;transition:opacity var(--dur-quick) var(--ease)}.kanban-card:hover .kanban-card__remove{opacity:1}.kanban-card__remove:hover{color:var(--danger)}.kanban-card--overlay{cursor:grabbing;border-color:var(--border-strong);transform:rotate(2deg)}.kanban-avatar{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;flex:none;border-radius:50%;background:var(--foam);color:var(--text-secondary);font-family:var(--font-display);font-size:11px}.kanban-avatar--empty{background:transparent;border:1px dashed var(--border-strong);color:var(--text-secondary)}.kanban-card__foot{display:flex;align-items:center;min-width:0}.kanban-card__assignee{display:inline-flex;align-items:center;gap:var(--space-2);min-width:0;max-width:100%;border:none;background:none;padding:0;font-family:var(--font-body);font-size:12px;color:var(--text-secondary);text-align:left}button.kanban-card__assignee{cursor:pointer}button.kanban-card__assignee:hover .kanban-card__assignee-name{color:var(--text-primary)}.kanban-card__assignee-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color var(--dur-quick) var(--ease)}.kanban-card__assignee--empty{transition:opacity var(--dur-quick) var(--ease)}@media (hover: hover){.kanban-card__assignee--empty{opacity:0}.kanban-card:hover .kanban-card__assignee--empty,.kanban-card__assignee--empty:focus-visible,.kanban-card__assignee--empty[aria-expanded=true]{opacity:1}}.kanban-assign-menu,.kanban-filter__menu{z-index:70;width:240px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-2);display:flex;flex-direction:column;gap:2px;max-height:272px;overflow-y:auto;overscroll-behavior:contain;cursor:default}.kanban-assign-menu,.kanban-filter__menu{position:fixed}.kanban-assign-menu__label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-weight:500;padding:2px 8px 4px}.kanban-assign-menu__option,.kanban-filter__menu-row{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:6px 8px;background:none;border:none;border-radius:var(--radius-input);font-family:var(--font-body);font-size:13px;color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--dur-quick) var(--ease)}.kanban-assign-menu__option:hover,.kanban-filter__menu-row:hover{background:var(--hover-fill)}.kanban-assign-menu__option[aria-selected=true],.kanban-filter__menu-row--on{background:var(--foam)}.kanban-assign-menu__who{display:flex;flex-direction:column;min-width:0;flex:1}.kanban-assign-menu__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kanban-assign-menu__email{font-size:11px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kanban-filter__check{flex:none;color:var(--coffee);font-size:12px}.kanban-filter{position:relative;display:flex;flex-wrap:nowrap;align-items:center;gap:var(--space-2);padding:0 0 var(--space-3)}.page>.kanban-filter{padding-bottom:0;margin-bottom:calc(-1 * var(--space-2))}.board-page>.kanban-filter{padding-bottom:0}.kanban-filter__label{font-size:13px;color:var(--text-secondary);margin-right:var(--space-1);flex:none}.kanban-filter__chip{display:inline-flex;align-items:center;gap:var(--space-2);flex:none;max-width:220px;padding:3px 12px 3px 4px;border:1px solid var(--border);border-radius:var(--radius-pill);background:none;font-family:var(--font-body);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:border-color var(--dur-quick) var(--ease),background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.kanban-filter__chip:hover{border-color:var(--border-strong);color:var(--text-primary)}.kanban-filter__chip--on{background:var(--foam);border-color:var(--coffee);color:var(--text-primary)}.kanban-filter__chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kanban-filter__clear{flex:none;border:none;background:none;font-family:var(--font-body);font-size:13px;color:var(--text-secondary);cursor:pointer;padding:3px 6px;border-radius:var(--radius-input);transition:color var(--dur-quick) var(--ease)}.kanban-filter__clear:hover{color:var(--text-primary);text-decoration:underline}.kanban-filter__more{position:relative;flex:none;display:inline-flex}.kanban-filter__more-btn{gap:4px;padding-inline:10px;font-variant-numeric:tabular-nums}.kanban-filter__more-dot{width:6px;height:6px;border-radius:50%;background:var(--coffee)}.kanban-filter__measure{position:absolute;top:0;left:0;visibility:hidden;pointer-events:none;white-space:nowrap;display:flex;flex-wrap:nowrap;align-items:center;gap:var(--space-2)}.kanban-modal__scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-scrim);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:50}.kanban-modal{width:100%;max-width:440px;max-height:80dvh;display:flex;flex-direction:column;gap:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-5)}.kanban-modal__head{display:flex;align-items:center;justify-content:space-between}.kanban-modal__title{font-family:var(--font-display);font-weight:500;font-size:20px;margin:0}.kanban-modal__close{border:none;background:none;cursor:pointer;font-size:22px;line-height:1;color:var(--text-secondary)}.kanban-modal__close:hover{color:var(--text-primary)}.kanban-modal__results{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;gap:var(--space-1);overflow-y:auto}.kanban-modal__hint{font-size:13px;padding:var(--space-2) 0}.kanban-modal__actions{display:flex;justify-content:flex-end;gap:var(--space-2)}.kanban-pick{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid transparent;border-radius:var(--radius-control);background:none;text-align:left;cursor:pointer;font-size:14px;color:var(--text-primary)}.kanban-pick:not(:disabled):hover{background:var(--hover-fill)}.kanban-pick--on{border-color:var(--coffee);background:var(--hover-fill)}.kanban-pick:disabled{opacity:.55;cursor:default}.kanban-pick__check{width:16px;flex-shrink:0;color:var(--coffee);font-size:13px;line-height:20px}.kanban-pick__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.kanban-pick__line{display:flex;align-items:center;gap:var(--space-2)}.kanban-pick__title{flex:1;word-break:break-word;line-height:20px}.kanban-pick__labels{display:flex;flex-wrap:wrap;gap:4px}.kanban-pick__already{font-size:11px;color:var(--text-secondary)}.kanban-pick__ctx{font-size:11px;color:var(--coffee);background:var(--foam);border-radius:var(--radius-pill);padding:1px 8px;white-space:nowrap}.kanban-pick--nav .kanban-pick__ctx{background:none;color:var(--text-secondary)}.kanban-pick--todo{position:relative;background:var(--bg-surface-muted);border-color:var(--border);padding-left:calc(var(--space-3) + 8px)}.kanban-pick--todo:before{content:"";position:absolute;left:5px;top:7px;bottom:7px;width:3px;border-radius:var(--radius-pill);background:var(--caramel)}.kanban-pick--todo:not(:disabled):hover{border-color:var(--border-hover);background:var(--hover-fill)}.kanban-pick--todo.kanban-pick--on{border-color:var(--coffee);background:var(--hover-fill)}.kanban-pick--todo .kanban-pick__ctx{background:var(--bg-surface)}.kanban-pick--todo .kanban-pick__check{color:var(--text-secondary)}.kanban-modal--wide{max-width:750px;height:min(620px,80dvh)}.kanban-tabs{display:flex;gap:var(--space-1);border-bottom:1px solid var(--border);padding-bottom:var(--space-2)}.kanban-tab{border:none;background:none;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-secondary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);cursor:pointer}.kanban-tab:not(.kanban-tab--on):hover{color:var(--text-primary)}.kanban-tab--on{background:var(--espresso);color:var(--linen)}.kanban-modal__group{display:flex;flex-direction:column;gap:var(--space-1)}.kanban-modal__group-head{font-family:var(--font-display);font-size:14px;color:var(--text-secondary);padding:var(--space-2) var(--space-2) var(--space-1)}.kanban-back{align-self:flex-start;border:none;background:none;cursor:pointer;color:var(--text-secondary);font-size:13px;font-weight:500;padding:var(--space-1) var(--space-2);margin-left:-4px;border-radius:var(--radius-control)}.kanban-back:hover{color:var(--text-primary)}.kanban-modal__count{margin-right:auto;font-size:13px;color:var(--text-secondary)}.kanban-modal__selectall{display:flex;justify-content:flex-end;padding:0 var(--space-1) var(--space-1)}.kanban-selectall-btn{border:none;background:none;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--coffee);padding:var(--space-1) var(--space-2);border-radius:var(--radius-control)}.kanban-selectall-btn:hover{background:var(--hover-fill)}.kanban-modal__results--open{overflow:visible}.kanban-modal__new{display:flex;flex-direction:column;gap:var(--space-2);min-height:300px}.kanban-undo{position:fixed;left:50%;bottom:var(--space-5);transform:translate(-50%);display:flex;align-items:center;gap:var(--space-3);background:var(--espresso);color:var(--linen);border-radius:var(--radius-pill);padding:var(--space-2) var(--space-3) var(--space-2) var(--space-4);font-size:14px;z-index:60}.kanban-undo__msg{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}.kanban-undo__btn{border:none;background:var(--sunrise);color:var(--espresso);font-family:var(--font-body);font-weight:500;font-size:13px;border-radius:var(--radius-pill);padding:4px 14px;cursor:pointer}.kanban-undo__btn:hover{filter:brightness(1.04)}@media (max-width: 600px){.shell__main:has(.board-page){padding:var(--space-4) var(--space-3)}.board-page__head{gap:var(--space-2)}.board-page__title{font-size:24px}.kanban-board{scroll-snap-type:x mandatory;gap:var(--space-3)}.kanban-board--dragging{scroll-snap-type:none}.kanban-col{flex-basis:86vw;width:86vw}}.shell__main:has(.planner){max-width:none;padding:var(--space-6) clamp(var(--space-4),4vw,var(--space-6))}.planner{--planner-gutter: 56px;display:flex;flex-direction:column;gap:var(--space-4);min-width:0}.planner__head{display:grid;grid-template-columns:1fr auto;grid-template-areas:"title    controls" "date     controls";column-gap:var(--space-4);row-gap:var(--space-1);align-items:start}.planner__title{grid-area:title;margin:0}.planner__day-label{grid-area:date}.planner__controls-col{grid-area:controls}.planner__views{display:flex;gap:var(--space-1);align-self:stretch}.planner__view-chip{flex:1;text-align:center;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);padding:5px 13px;cursor:pointer;text-transform:lowercase;transition:background var(--dur-quick) var(--ease),border-color var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.planner__view-chip:not(.planner__view-chip--active):hover{color:var(--text-primary);border-color:var(--border-hover)}.planner__view-chip--active{background:var(--espresso);color:var(--linen);border-color:var(--espresso)}.planner__view-chip:focus-visible{outline:2px solid var(--sunrise);outline-offset:2px}.planner__controls{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0;position:relative}.planner__controls-col{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);flex-shrink:0}.planner__nav{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:15px;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);cursor:pointer;transition:background var(--dur-quick) var(--ease),border-color var(--dur-quick) var(--ease)}.planner__nav:hover{background:var(--hover-fill);border-color:var(--border-hover)}.planner__date{font-family:var(--font-body);font-size:13px;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);padding:7px 10px;cursor:pointer;white-space:nowrap;width:12rem;text-align:center;transition:border-color var(--dur-quick) var(--ease)}.planner__date{display:inline-flex;align-items:center;justify-content:center;gap:6px}.planner__date:hover{border-color:var(--border-hover)}.planner__date:focus-visible{outline:2px solid var(--sunrise);outline-offset:2px}.planner__date-caret{font-size:10px;color:var(--text-secondary);flex-shrink:0}.planner__date-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.planner__jump{font-family:var(--font-body);font-size:13px;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:6px 8px;border-radius:var(--radius-control);position:absolute;right:100%;top:50%;transform:translateY(-50%);margin-right:var(--space-1);white-space:nowrap}.planner__jump:hover{background:var(--hover-fill);color:var(--text-primary)}@media (max-width: 600px){.planner__head{grid-template-columns:1fr;grid-template-areas:"title" "controls" "date";row-gap:var(--space-3)}.planner__controls-col{align-items:stretch}.planner__controls{flex-wrap:wrap;row-gap:var(--space-1)}.planner__date{flex:1;width:auto;min-width:0}.planner__nav{flex-shrink:0}.planner__jump{order:1;position:static;transform:none;margin-right:0;flex-basis:100%;text-align:left}}.planner__day-label{margin-top:0}.planner__error{margin:0;padding:var(--space-2) var(--space-3);font-size:13px;color:var(--danger);background:var(--danger-bg);border-radius:var(--radius-control)}.planner__body{display:block}.planner__timeline-card{background:var(--bg-surface-muted);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.planner__scroll{max-height:calc(100dvh - 230px);min-height:420px;overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:transparent transparent}.planner__scroll:hover,.planner__scroll:focus-within{scrollbar-color:var(--border-strong) transparent}.planner__grid{position:relative;width:100%}.planner__tracks{position:absolute;top:0;bottom:0;left:calc(var(--planner-gutter) + 6px);right:var(--space-3);display:flex}.planner__track{position:relative;flex:1 1 0;min-width:0;cursor:copy}.planner__track--locked{cursor:default}.planner__tracks--week{gap:5px}.planner__tracks--week .planner__track+.planner__track:before{content:"";position:absolute;top:0;bottom:0;left:-3px;width:1px;background:var(--border);pointer-events:none}.planner__add-guide{position:absolute;left:0;right:0;height:0;border-top:1px dashed var(--caramel);z-index:1;pointer-events:none}.planner__add-guide-label{position:absolute;left:2px;top:-10px;font-family:var(--font-body);font-size:11px;font-weight:500;color:var(--caramel);background:var(--bg-surface);border:1px solid var(--tan);border-radius:var(--radius-pill);padding:0 7px;white-space:nowrap;font-variant-numeric:tabular-nums}.planner__drag-time{position:absolute;left:4px;z-index:7;font-family:var(--font-body);font-size:11px;font-weight:500;color:var(--caramel);background:var(--bg-surface);border:1px solid var(--tan);border-radius:var(--radius-pill);padding:0 7px;white-space:nowrap;font-variant-numeric:tabular-nums;pointer-events:none}.planner__drag-time--start{transform:translateY(calc(-100% - 2px))}.planner__drag-time--end{transform:translateY(2px)}.planner__hour{position:relative;border-top:1px solid var(--border);box-sizing:border-box}.planner__hour:first-child{border-top:none}.planner__hour-label{position:absolute;top:4px;left:0;width:var(--planner-gutter);padding-right:10px;text-align:right;font-size:11px;font-variant-numeric:tabular-nums;color:var(--text-secondary);opacity:.75;-webkit-user-select:none;user-select:none}.planner__now{position:absolute;left:0;right:0;height:0;border-top:2px solid var(--sunrise);z-index:3;pointer-events:none}.planner__now-dot{position:absolute;left:-5px;top:-5px;width:9px;height:9px;border-radius:var(--radius-pill);background:var(--sunrise)}.planner__timeline-empty{position:absolute;top:576px;left:var(--planner-gutter);right:var(--space-3);margin:0;text-align:center;color:var(--text-secondary);font-size:14px}.planner__week-head{position:sticky;top:0;z-index:5;display:flex;background:var(--bg-surface-muted);border-bottom:1px solid var(--border)}.planner__week-gutter{flex:0 0 calc(var(--planner-gutter) + 6px)}.planner__week-days{display:flex;flex:1 1 0;min-width:0;gap:5px;padding-right:var(--space-3)}.planner__week-day{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;gap:1px;padding:var(--space-2) 4px;text-align:center;background:none;border:none;border-radius:var(--radius-control);cursor:pointer;transition:background var(--dur-quick) var(--ease)}.planner__week-day:hover{background:var(--hover-fill)}.planner__week-day:focus-visible{outline:2px solid var(--sunrise);outline-offset:-2px}.planner__week-weekday{font-family:var(--font-body);font-size:11px;color:var(--text-secondary);text-transform:lowercase;letter-spacing:.02em}.planner__week-date{font-family:var(--font-display);font-weight:500;font-size:17px;color:var(--text-primary);font-variant-numeric:tabular-nums;line-height:1.4}.planner__week-day--past .planner__week-weekday,.planner__week-day--past .planner__week-date{opacity:.55}.planner__week-day--today .planner__week-weekday{color:var(--sunrise)}.planner__week-day--today .planner__week-date{display:inline-flex;align-items:center;justify-content:center;min-width:1.7em;height:1.7em;padding:0 .3em;color:var(--espresso);background:var(--sunrise);border-radius:var(--radius-pill)}.planner-block{--col-index: 0;--col-count: 1;--planner-colgap: 4px;--planner-colw: calc((100% - (var(--col-count) - 1) * var(--planner-colgap)) / var(--col-count));position:absolute;left:calc(var(--col-index) * (var(--planner-colw) + var(--planner-colgap)));width:var(--planner-colw);display:flex;overflow:hidden;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-control);box-sizing:border-box;z-index:2;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;transition:border-color var(--dur-quick) var(--ease);container-type:size}.planner-block:hover{border-color:var(--border-hover)}.planner-block--locked{cursor:default}.planner-block--locked:hover{border-color:var(--border)}.planner-block--active{z-index:6;border-color:var(--caramel);cursor:grabbing}.planner-block__accent{flex:0 0 3px;align-self:stretch;background:var(--border-strong);border-radius:var(--radius-pill)}.planner-block--project .planner-block__accent{background:var(--caramel)}.planner-block__body{min-width:0;flex:1 1 auto;display:flex;flex-direction:column;justify-content:safe center;gap:3px;padding:5px 26px 5px 9px;overflow:hidden}.planner-block__titlerow{display:flex;align-items:center;gap:6px;min-width:0}.planner-block__title{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;position:relative}.planner-block .checkbox{--size: 16px}.planner-block .checkbox__check{width:11px;height:11px}.planner-block__check-wrap{display:inline-flex;flex-shrink:0}.planner-block__bell{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;flex-shrink:0;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-control);cursor:pointer;opacity:.9;transition:color var(--dur-quick) var(--ease),background var(--dur-quick) var(--ease),opacity var(--dur-quick) var(--ease)}.planner-block__bell:hover{opacity:1;background:var(--hover-fill);color:var(--text-primary)}.planner-block__bell--on{opacity:1;color:var(--caramel)}.planner-block__time{font-size:11px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.planner-block__meta{flex-wrap:wrap;align-items:center;gap:4px}.planner-block__time,.planner-block__meta{display:none}@container (min-height: 42px){.planner-block__time{display:inline}.planner-block__meta{display:flex}}@container (min-width: 360px) and (min-height: 30px){.planner-block__body{flex-direction:row;align-items:center;justify-content:flex-start;gap:8px}.planner-block__titlerow{flex:0 1 auto}.planner-block__time{display:inline;flex-shrink:0}.planner-block__meta{display:flex;flex-wrap:nowrap;flex-shrink:0;overflow:hidden}}@container (max-height: 30px){.planner-block__body{gap:0;padding-top:2px;padding-bottom:2px}}.planner-block--done{background:var(--foam);border-color:var(--border)}.planner-block--done .planner-block__accent{background:var(--foam)}.planner-block--done .planner-block__title{text-decoration:line-through;text-decoration-color:var(--coffee);color:var(--text-secondary)}.planner-block--completing .planner-block__title{text-decoration:none}.planner-block__strike{position:absolute;top:0;right:0;bottom:0;left:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-secondary);text-decoration:line-through;text-decoration-color:var(--coffee);pointer-events:none;clip-path:inset(0 100% 0 0);animation:planner-strike .46s var(--ease) forwards}@keyframes planner-strike{to{clip-path:inset(0 0 0 0)}}@media (prefers-reduced-motion: reduce){.planner-block__strike{animation:none;clip-path:none}}.planner-block__resize{position:absolute;left:0;right:0;bottom:0;height:8px;cursor:ns-resize;touch-action:none}.planner-block__resize:after{content:"";position:absolute;left:50%;bottom:2px;width:22px;height:2px;margin-left:-11px;border-radius:var(--radius-pill);background:var(--border-strong);opacity:0;transition:opacity var(--dur-quick) var(--ease)}.planner-block:hover .planner-block__resize:after,.planner-block--active .planner-block__resize:after{opacity:.5}.planner-block__delete{position:absolute;top:2px;right:3px;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-control);cursor:pointer;opacity:.5;transition:opacity var(--dur-quick) var(--ease),background var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.planner-block__delete:hover{opacity:1;background:var(--hover-fill);color:var(--text-primary)}.planner-edit__actions{display:flex;justify-content:flex-end;gap:var(--space-2)}body.planner-dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}.planner-chip{display:inline-block;font-size:11px;font-weight:500;padding:1px 7px;border-radius:var(--radius-pill);white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}.planner-chip--project{background:var(--foam);color:var(--caramel)}.planner-chip--due{background:transparent;color:var(--caramel);border:1px solid var(--tan)}.planner-chip--due-today{color:var(--text-primary);border-color:var(--border-strong)}.planner-month{background:var(--bg-surface-muted);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.planner-month__weekdays{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border)}.planner-month__weekday{padding:var(--space-2);text-align:center;font-family:var(--font-body);font-size:11px;color:var(--text-secondary);text-transform:lowercase;letter-spacing:.02em}.planner-month__grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(104px,1fr)}.planner-month__cell{position:relative;display:flex;flex-direction:column;gap:3px;min-width:0;padding:4px;background:var(--bg-surface);border-left:1px solid var(--border);border-top:1px solid var(--border)}.planner-month__grid>.planner-month__cell:nth-child(7n+1){border-left:none}.planner-month__grid>.planner-month__cell:nth-child(-n+7){border-top:none}.planner-month__cell--muted{background:var(--bg-surface-muted)}.planner-month__cell--muted .planner-month__daynum{color:var(--text-secondary)}.planner-month__daynum{position:relative;z-index:1;align-self:flex-start;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-display);font-weight:500;font-size:13px;color:var(--text-primary);background:none;border:none;padding:1px 5px;border-radius:var(--radius-control);cursor:pointer;font-variant-numeric:tabular-nums}.planner-month__daynum:hover{background:var(--hover-fill)}.planner-month__today-dot{width:7px;height:7px;border-radius:var(--radius-pill);background:var(--sunrise)}.planner-month__chips{display:flex;flex-direction:column;gap:2px;min-width:0;z-index:1}.planner-month__chip{display:flex;align-items:baseline;gap:5px;min-width:0;text-align:left;font-family:var(--font-body);font-size:11px;color:var(--text-primary);background:var(--hover-fill);border:none;border-left:2px solid var(--border-strong);border-radius:3px;padding:1px 5px 1px 4px;cursor:pointer;overflow:hidden}.planner-month__chip:hover{background:var(--bg-surface);box-shadow:inset 0 0 0 1px var(--border)}.planner-month__chip--project{border-left-color:var(--caramel)}.planner-month__chip--calendar{border-left-color:var(--coffee);background:var(--bg-surface-muted)}.planner-month__chip--done .planner-month__chip-title{text-decoration:line-through;text-decoration-color:var(--coffee);color:var(--text-secondary)}.planner-month__chip-time{font-size:10px;color:var(--text-secondary);font-variant-numeric:tabular-nums;flex-shrink:0}.planner-month__chip-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.planner-month__more{align-self:flex-start;z-index:1;font-family:var(--font-body);font-size:11px;font-weight:500;color:var(--text-secondary);background:none;border:none;padding:0 5px;cursor:pointer}.planner-month__more:hover{color:var(--text-primary)}.planner-month__fill{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;background:none;border:none;padding:0;cursor:pointer}@media (max-width: 860px){.planner__scroll{max-height:none;overflow:visible}.planner--week .planner__scroll{max-height:calc(100dvh - 250px);min-height:360px;overflow:auto;overscroll-behavior:contain}.planner--week .planner__grid,.planner--week .planner__week-head{min-width:680px}}@media (max-width: 600px){.planner-month__grid{grid-auto-rows:minmax(76px,1fr)}.planner-month__chip-time{display:none}.planner-month__weekday{padding:var(--space-1)}}.planner-reminders{display:flex;flex-direction:column;gap:var(--space-2);width:100%;pointer-events:auto}.planner-reminders__all{align-self:flex-end;font-family:var(--font-body);font-size:12px;color:var(--text-secondary);background:none;border:none;padding:2px 6px;border-radius:var(--radius-control);cursor:pointer}.planner-reminders__all:hover{background:var(--hover-fill);color:var(--text-primary)}.planner-reminder{display:flex;align-items:center;gap:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid var(--sunrise);border-radius:var(--radius-card);padding:var(--space-3);animation:planner-reminder-in var(--dur-base) var(--ease)}@keyframes planner-reminder-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.planner-reminder__bell{color:var(--sunrise);flex-shrink:0}.planner-reminder__body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1 1 auto}.planner-reminder__title{font-family:var(--font-body);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.planner-reminder__time{font-size:12px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.planner-reminder__dismiss{flex-shrink:0;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-primary);background:none;border:1px solid var(--border);border-radius:var(--radius-control);padding:6px 11px;cursor:pointer;transition:background var(--dur-quick) var(--ease),border-color var(--dur-quick) var(--ease)}.planner-reminder__dismiss:hover{background:var(--hover-fill);border-color:var(--border-hover)}@media (prefers-reduced-motion: reduce){.planner-reminder{animation:none}}.planner-modal__scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:var(--modal-scrim);display:flex;align-items:flex-start;justify-content:center;padding:12vh var(--space-4) var(--space-4)}.planner-modal{width:100%;max-width:750px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.planner-modal__head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.planner-modal__title{margin:0;font-family:var(--font-display);font-weight:500;font-size:18px;color:var(--text-primary)}.planner-modal__close{background:none;border:none;font-size:20px;line-height:1;color:var(--text-secondary);cursor:pointer;padding:2px 6px;border-radius:var(--radius-control)}.planner-modal__close:hover{background:var(--hover-fill);color:var(--text-primary)}.planner__sync{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.planner__resync{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:var(--radius-control);padding:4px 9px;cursor:pointer;transition:background var(--dur-quick) var(--ease),border-color var(--dur-quick) var(--ease),color var(--dur-quick) var(--ease)}.planner__resync:hover:not(:disabled){background:var(--hover-fill);border-color:var(--border-hover);color:var(--text-primary)}.planner__resync:disabled{cursor:default;opacity:.7}.planner__resync-icon--spin{animation:planner-spin .9s linear infinite}@keyframes planner-spin{to{transform:rotate(360deg)}}.planner__sync-status{font-size:12px;color:var(--text-secondary)}.planner__sync-status--warn{color:var(--caramel)}.planner__sync--connect{align-self:stretch}.planner__sync--connect .planner__resync{width:100%;justify-content:center;background:var(--bg-surface);color:var(--text-primary)}@media (prefers-reduced-motion: reduce){.planner__resync-icon--spin{animation:none}}.planner-block--calendar{cursor:default;touch-action:auto;background:var(--cal-block-bg);border-color:var(--caramel)}.planner-block--calendar:hover{border-color:var(--caramel)}.planner-block--calendar .planner-block__accent{background:var(--coffee)}.planner-block--allday{opacity:.92}.planner-block--allday .planner-block__accent{background:var(--caramel)}.planner-block__cal-icon{display:inline-flex;flex-shrink:0;color:var(--coffee);opacity:.85}.planner-chip--calendar{background:var(--foam);color:var(--coffee);border:1px solid var(--tan)}.calendar-list{list-style:none;margin:var(--space-2) 0 0;padding:0;display:flex;flex-direction:column}.calendar-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap;padding:var(--space-3) 0;border-top:1px solid var(--border)}.calendar-row:first-child{border-top:none}.calendar-row__main{display:flex;flex-direction:column;gap:2px;min-width:0}.calendar-row__name{font-family:var(--font-body);font-weight:500;color:var(--text-primary)}.calendar-row__meta{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.calendar-row__actions{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.calendar-row__scope{max-width:220px;font-size:13px;padding:6px 8px}.calendar-row__option{flex-basis:100%;display:flex;align-items:center;gap:8px;margin-top:2px;font-size:13px;color:var(--text-secondary);cursor:pointer}.calendar-row__option input{cursor:pointer;accent-color:var(--coffee)}:root{--milo-coat: #DBA45C;--milo-coat-deep: #B97E3E;--milo-coat-light: #F0DCB0}:root[data-theme=matcha]{--milo-coat: #BFB45E;--milo-coat-deep: #94954A;--milo-coat-light: #E6E8C2}:root[data-theme=taro]{--milo-coat: #C2A8AE;--milo-coat-deep: #9C8696;--milo-coat-light: #E7DCEC}:root[data-theme=sea-blue]{--milo-coat: #A9BFBE;--milo-coat-deep: #84A0A0;--milo-coat-light: #DAE8E8}:root{--lemon-coat: #E8BE44;--lemon-coat-deep: #A0692B;--lemon-coat-light: #F7E6B0}:root[data-theme=matcha]{--lemon-coat: #C9C257;--lemon-coat-deep: #6E7233;--lemon-coat-light: #E9EDC8}:root[data-theme=taro]{--lemon-coat: #C6AAB0;--lemon-coat-deep: #6E5A6A;--lemon-coat-light: #E7DCEC}:root[data-theme=sea-blue]{--lemon-coat: #AAC0BD;--lemon-coat-deep: #57726F;--lemon-coat-light: #DAE8E8}.pet-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;pointer-events:none}.pet{position:absolute;pointer-events:auto;cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;animation:pet-pop .32s var(--ease) both}.pet:active{cursor:grabbing}.pet svg{width:100%;height:100%;display:block;overflow:visible}@keyframes pet-pop{0%{opacity:0;transform:translateY(8px) scale(.92)}to{opacity:1;transform:none}}.pet-setting-list{display:flex;flex-direction:column;gap:16px}.pet-setting{display:flex;align-items:center;gap:16px}.pet-setting__preview{flex:0 0 auto;width:64px;height:70px;display:grid;place-items:center;background:var(--bg-surface-muted);border:1px solid var(--border);border-radius:12px}.pet-setting__preview svg{width:52px;height:57px;overflow:visible}.pet-setting__body{flex:1 1 auto;min-width:0}.pet-setting__name{font-weight:500}.pet-setting__desc{color:var(--text-secondary);font-size:14px}@media (prefers-reduced-motion: reduce){.pet{animation:none}}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}html,body,#root{min-height:100%}html,body{overflow-x:hidden;overflow-x:clip;max-width:100%}#root{max-width:100%;overflow-x:hidden;overflow-x:clip}html{overflow-anchor:none}img,svg,video{max-width:100%;height:auto}body{font-family:var(--font-body);font-weight:400;font-size:16px;line-height:1.55;color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}a{color:var(--coffee);text-underline-offset:2px}a:not(.btn):hover{color:var(--text-hover)}button{font:inherit}::selection{background:var(--foam);color:var(--espresso)}
