.rdp-root{--rdp-accent-color: blue;--rdp-accent-background-color: #f0f0ff;--rdp-day-height: 44px;--rdp-day-width: 44px;--rdp-day_button-border-radius: 100%;--rdp-day_button-border: 2px solid transparent;--rdp-day_button-height: 42px;--rdp-day_button-width: 42px;--rdp-selected-border: 2px solid var(--rdp-accent-color);--rdp-disabled-opacity: .5;--rdp-outside-opacity: .75;--rdp-today-color: var(--rdp-accent-color);--rdp-dropdown-gap: .5rem;--rdp-months-gap: 2rem;--rdp-nav_button-disabled-opacity: .5;--rdp-nav_button-height: 2.25rem;--rdp-nav_button-width: 2.25rem;--rdp-nav-height: 2.75rem;--rdp-range_middle-background-color: var(--rdp-accent-background-color);--rdp-range_middle-color: inherit;--rdp-range_start-color: white;--rdp-range_start-background: linear-gradient( var(--rdp-gradient-direction), transparent 50%, var(--rdp-range_middle-background-color) 50% );--rdp-range_start-date-background-color: var(--rdp-accent-color);--rdp-range_end-background: linear-gradient( var(--rdp-gradient-direction), var(--rdp-range_middle-background-color) 50%, transparent 50% );--rdp-range_end-color: white;--rdp-range_end-date-background-color: var(--rdp-accent-color);--rdp-week_number-border-radius: 100%;--rdp-week_number-border: 2px solid transparent;--rdp-week_number-height: var(--rdp-day-height);--rdp-week_number-opacity: .75;--rdp-week_number-width: var(--rdp-day-width);--rdp-weeknumber-text-align: center;--rdp-weekday-opacity: .75;--rdp-weekday-padding: .5rem 0rem;--rdp-weekday-text-align: center;--rdp-gradient-direction: 90deg;--rdp-animation_duration: .3s;--rdp-animation_timing: cubic-bezier(.4, 0, .2, 1)}.rdp-root[dir=rtl]{--rdp-gradient-direction: -90deg}.rdp-root[data-broadcast-calendar=true]{--rdp-outside-opacity: unset}.rdp-root{position:relative;box-sizing:border-box}.rdp-root *{box-sizing:border-box}.rdp-day{width:var(--rdp-day-width);height:var(--rdp-day-height);text-align:center}.rdp-day_button{background:none;padding:0;margin:0;cursor:pointer;font:inherit;color:inherit;justify-content:center;align-items:center;display:flex;width:var(--rdp-day_button-width);height:var(--rdp-day_button-height);border:var(--rdp-day_button-border);border-radius:var(--rdp-day_button-border-radius)}.rdp-day_button:disabled{cursor:revert}.rdp-caption_label{z-index:1;position:relative;display:inline-flex;align-items:center;white-space:nowrap;border:0}.rdp-dropdown:focus-visible~.rdp-caption_label{outline:5px auto Highlight;outline:5px auto -webkit-focus-ring-color}.rdp-button_next,.rdp-button_previous{border:none;background:none;padding:0;margin:0;cursor:pointer;font:inherit;color:inherit;-moz-appearance:none;-webkit-appearance:none;display:inline-flex;align-items:center;justify-content:center;position:relative;appearance:none;width:var(--rdp-nav_button-width);height:var(--rdp-nav_button-height)}.rdp-button_next:disabled,.rdp-button_next[aria-disabled=true],.rdp-button_previous:disabled,.rdp-button_previous[aria-disabled=true]{cursor:revert;opacity:var(--rdp-nav_button-disabled-opacity)}.rdp-chevron{display:inline-block;fill:var(--rdp-accent-color)}.rdp-root[dir=rtl] .rdp-nav .rdp-chevron{transform:rotate(180deg);transform-origin:50%}.rdp-dropdowns{position:relative;display:inline-flex;align-items:center;gap:var(--rdp-dropdown-gap)}.rdp-dropdown{z-index:2;opacity:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;position:absolute;inset-block-start:0;inset-block-end:0;inset-inline-start:0;width:100%;margin:0;padding:0;cursor:inherit;border:none;line-height:inherit}.rdp-dropdown_root{position:relative;display:inline-flex;align-items:center}.rdp-dropdown_root[data-disabled=true] .rdp-chevron{opacity:var(--rdp-disabled-opacity)}.rdp-month_caption{display:flex;align-content:center;height:var(--rdp-nav-height);font-weight:700;font-size:large}.rdp-root[data-nav-layout=around] .rdp-month,.rdp-root[data-nav-layout=after] .rdp-month{position:relative}.rdp-root[data-nav-layout=around] .rdp-month_caption{justify-content:center;margin-inline-start:var(--rdp-nav_button-width);margin-inline-end:var(--rdp-nav_button-width);position:relative}.rdp-root[data-nav-layout=around] .rdp-button_previous{position:absolute;inset-inline-start:0;top:0;height:var(--rdp-nav-height);display:inline-flex}.rdp-root[data-nav-layout=around] .rdp-button_next{position:absolute;inset-inline-end:0;top:0;height:var(--rdp-nav-height);display:inline-flex;justify-content:center}.rdp-months{position:relative;display:flex;flex-wrap:wrap;gap:var(--rdp-months-gap);max-width:fit-content}.rdp-month_grid{border-collapse:collapse}.rdp-nav{position:absolute;inset-block-start:0;inset-inline-end:0;display:flex;align-items:center;height:var(--rdp-nav-height)}.rdp-weekday{opacity:var(--rdp-weekday-opacity);padding:var(--rdp-weekday-padding);font-weight:500;font-size:smaller;text-align:var(--rdp-weekday-text-align);text-transform:var(--rdp-weekday-text-transform)}.rdp-week_number{opacity:var(--rdp-week_number-opacity);font-weight:400;font-size:small;height:var(--rdp-week_number-height);width:var(--rdp-week_number-width);border:var(--rdp-week_number-border);border-radius:var(--rdp-week_number-border-radius);text-align:var(--rdp-weeknumber-text-align)}.rdp-today:not(.rdp-outside){color:var(--rdp-today-color)}.rdp-selected{font-weight:700;font-size:large}.rdp-selected .rdp-day_button{border:var(--rdp-selected-border)}.rdp-outside{opacity:var(--rdp-outside-opacity)}.rdp-disabled:not(.rdp-selected){opacity:var(--rdp-disabled-opacity)}.rdp-hidden{visibility:hidden;color:var(--rdp-range_start-color)}.rdp-range_start{background:var(--rdp-range_start-background)}.rdp-range_start .rdp-day_button{background-color:var(--rdp-range_start-date-background-color);color:var(--rdp-range_start-color)}.rdp-range_middle{background-color:var(--rdp-range_middle-background-color)}.rdp-range_middle .rdp-day_button{border:unset;border-radius:unset;color:var(--rdp-range_middle-color)}.rdp-range_end{background:var(--rdp-range_end-background);color:var(--rdp-range_end-color)}.rdp-range_end .rdp-day_button{color:var(--rdp-range_start-color);background-color:var(--rdp-range_end-date-background-color)}.rdp-range_start.rdp-range_end{background:revert}.rdp-focusable{cursor:pointer}@keyframes rdp-slide_in_left{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes rdp-slide_in_right{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes rdp-slide_out_left{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes rdp-slide_out_right{0%{transform:translate(0)}to{transform:translate(100%)}}.rdp-weeks_before_enter{animation:rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_before_exit{animation:rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_after_enter{animation:rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_after_exit{animation:rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_after_enter{animation:rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_before_exit{animation:rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_before_enter{animation:rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_after_exit{animation:rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}@keyframes rdp-fade_in{0%{opacity:0}to{opacity:1}}@keyframes rdp-fade_out{0%{opacity:1}to{opacity:0}}.rdp-caption_after_enter{animation:rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_after_exit{animation:rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_before_enter{animation:rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_before_exit{animation:rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.duty-matrix{display:flex;flex-direction:column;flex:1;min-height:0;min-width:0;gap:var(--space-sm)}.duty-matrix__frame{display:flex;flex-direction:column;flex:1;min-height:0;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);overflow:hidden}.duty-matrix__nav{display:flex;flex-shrink:0;align-items:center;justify-content:space-between;gap:var(--space-sm);min-height:2.75rem}.duty-matrix__nav-btn{display:inline-flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border:none;border-radius:var(--radius);background:transparent;padding:0;color:var(--color-primary);cursor:pointer;font:inherit;-moz-appearance:none;appearance:none;-webkit-appearance:none}.duty-matrix__nav-btn:hover{background:var(--color-secondary-bg)}.duty-matrix__nav-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.duty-matrix__nav-chevron{display:inline-block;fill:var(--color-darkest)}.duty-matrix__scroll{flex:1;min-width:0;min-height:0;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.duty-matrix__table{width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0;font-size:.8125rem}.duty-matrix__table th,.duty-matrix__table td{border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);padding:0;vertical-align:middle}.duty-matrix__corner{position:sticky;top:0;left:0;z-index:3;width:clamp(7rem,18vw,11rem);background:var(--color-secondary-bg);font-weight:600;color:var(--color-muted);padding:8px 10px;text-align:center}.duty-matrix__date-head{position:sticky;top:0;z-index:2;min-width:0;padding:var(--space-sm) 4px 6px;text-align:center;background:var(--color-surface);font-weight:600;color:var(--color-primary)}.duty-matrix__date-head--weekend{background:var(--color-muted-bg)}.duty-matrix__date-head--weekend .duty-matrix__date-num{color:var(--color-muted);font-weight:700}.duty-matrix__date-head--weekend .duty-matrix__date-wd,.duty-matrix__date-head--weekend .duty-matrix__date-month{color:var(--color-muted)}.duty-matrix__date-head--holiday{background:var(--color-incomplete-bg)}.duty-matrix__date-head--holiday .duty-matrix__date-num{color:var(--color-incomplete);font-weight:700}.duty-matrix__date-head--holiday .duty-matrix__date-wd,.duty-matrix__date-head--holiday .duty-matrix__date-month{color:var(--color-incomplete)}.duty-matrix__date-head--weekend.duty-matrix__date-head--incomplete .duty-matrix__date-num,.duty-matrix__date-head--incomplete .duty-matrix__date-num{color:var(--color-incomplete);font-weight:700}.duty-matrix__date-head--holiday.duty-matrix__date-head--incomplete .duty-matrix__date-num{color:var(--color-darkest);font-weight:700}.duty-matrix__date-num{display:block;font-size:.875rem;line-height:1.2}.duty-matrix__date-wd{display:block;font-size:.65rem;font-weight:500;color:var(--color-muted);text-transform:lowercase}.duty-matrix__date-month{display:block;margin-top:1px;font-size:.6rem;font-weight:600;color:var(--color-primary);text-transform:lowercase;line-height:1.2}.duty-matrix__table td{overflow:hidden;background:var(--color-surface)}.duty-matrix__table td.duty-matrix__cell--weekend{background:var(--color-muted-bg)}.duty-matrix__table td.duty-matrix__cell--holiday{background:var(--color-incomplete-bg)}.duty-matrix__user{position:sticky;left:0;z-index:1;width:clamp(7rem,18vw,11rem);min-width:0;padding:6px 10px;background:var(--color-surface);font-weight:500;color:var(--color-primary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.duty-matrix__cell-btn{display:flex;align-items:center;justify-content:center;width:100%;min-width:0;min-height:2.5rem;padding:4px;border:none;background:var(--color-surface);color:var(--color-text);font:inherit;font-size:.8125rem;font-weight:600;font-variant-numeric:tabular-nums;cursor:default}.duty-matrix__cell-btn--clickable{cursor:pointer}.duty-matrix__cell-btn--clickable:hover:not(.duty-matrix__cell-btn--my){background:var(--color-muted-bg)}.duty-matrix__table td.duty-matrix__cell--weekend .duty-matrix__cell-btn,.duty-matrix__table td.duty-matrix__cell--holiday .duty-matrix__cell-btn{background:transparent}.duty-matrix__table td.duty-matrix__cell--weekend .duty-matrix__cell-btn--clickable:hover,.duty-matrix__table td.duty-matrix__cell--holiday .duty-matrix__cell-btn--clickable:hover{background:color-mix(in srgb,var(--color-darkest) 8%,transparent)}.duty-matrix__cell-btn--my{background:var(--color-duty-bg);color:var(--color-duty)}.duty-matrix__table td.duty-matrix__cell--weekend .duty-matrix__cell-btn--my,.duty-matrix__table td.duty-matrix__cell--holiday .duty-matrix__cell-btn--my{background:transparent;box-shadow:inset 0 0 0 2px var(--color-duty)}.duty-matrix__cell-btn--filled{color:var(--color-darkest)}.duty-matrix__cell-btn--drag-over{outline:2px solid var(--color-darkest);outline-offset:-2px;background:color-mix(in srgb,var(--color-darkest) 12%,transparent)}.duty-matrix__cell-btn--dragging{opacity:.45}.duty-matrix__cell-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:-2px}.duty-matrix__extra{display:block;font-size:.6rem;font-weight:500;color:var(--color-muted)}.duty-matrix__table td.duty-matrix__cell--absent{background:var(--color-muted-bg, #e8e8e8);border-left:3px solid var(--color-muted)}.duty-matrix__absence{display:flex;align-items:center;justify-content:center;width:100%;min-height:2.5rem;padding:4px 6px;border:none;background:transparent;color:var(--color-muted);font-size:.75rem;font-weight:600;line-height:1.25;text-align:center;-webkit-user-select:none;user-select:none}.duty-matrix__absence--clickable{cursor:pointer}.duty-matrix__absence--clickable:hover{color:var(--color-darkest)}.duty-matrix__absence-label{display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2;word-break:break-word}.duty-matrix-popover{position:fixed;z-index:200;left:50%;top:50%;transform:translate(-50%,-50%);width:min(20rem,calc(100vw - 2rem));padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:var(--shadow-modal)}.duty-matrix-popover__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-sm)}.duty-matrix-popover__title{margin:0;font-size:.9rem;font-weight:600;color:var(--color-primary);line-height:1.35}.duty-matrix-popover__close{flex-shrink:0;width:2rem;height:2rem;border:none;border-radius:var(--radius-sm);background:var(--color-muted-bg);color:var(--color-muted);font-size:1.25rem;line-height:1;cursor:pointer}.duty-matrix-popover__slots{display:flex;flex-direction:column;gap:6px;margin:0 0 var(--space-sm)}.duty-matrix-popover__slots-row{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.duty-matrix-popover__slot-btn{width:100%;min-height:2.75rem;padding:6px 8px;border:1px solid var(--color-input-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font:inherit;font-size:.875rem;font-weight:600;cursor:pointer}.duty-matrix-popover__slot-btn:hover:not(:disabled){border-color:var(--color-darkest);background:var(--color-muted-bg)}.duty-matrix-popover__slot-btn:disabled{opacity:.4;cursor:not-allowed}.duty-matrix-popover__clear{width:100%;min-height:2.75rem;border:1px dashed var(--color-danger);border-radius:var(--radius-sm);background:transparent;color:var(--color-danger);font:inherit;font-size:.875rem;font-weight:600;cursor:pointer}.duty-matrix-popover__hint,.duty-matrix-popover__error{margin:0;font-size:.85rem;line-height:1.4}.duty-matrix-popover__hint{color:var(--color-muted)}.duty-matrix-popover__error{color:var(--color-danger)}.duty-matrix-popover__absence-form{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.duty-matrix-popover__select{min-height:2.5rem;padding:8px 10px;border:1px solid var(--color-input-border);border-radius:var(--radius-sm);background:var(--color-surface);font:inherit;font-size:.875rem}.duty-matrix-popover-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:199;border:none;background:var(--color-modal-overlay);cursor:pointer}.home-page--matrix .home-page__legend-item--matrix-incomplete{color:var(--color-incomplete)}.home-page--matrix .home-page__legend-item--matrix-incomplete:before{background:var(--color-surface);border:2px solid var(--color-incomplete);border-radius:2px}.home-page--matrix .home-page__legend-item--matrix-weekend{color:var(--color-muted)}.home-page--matrix .home-page__legend-item--matrix-weekend:before{background:var(--color-muted-bg);border:1px solid var(--color-border)}.home-page--matrix .home-page__legend-item--matrix-holiday{color:var(--color-darkest)}.home-page--matrix .home-page__legend-item--matrix-holiday:before{background:var(--color-incomplete-bg);border:1px solid var(--color-darkest)}.home-page--matrix .home-page__legend-item--absent:before{background:var(--color-muted-bg, #e8e8e8);border:1px solid var(--color-muted);border-radius:2px}.payroll-page__subtitle{margin:0 0 var(--space-md);color:var(--color-muted);font-size:.875rem;line-height:1.45}.payroll-page__main{display:flex;flex-direction:column;gap:var(--space-md);align-items:stretch}.payroll-panel--form{order:1}.payroll-panel--result{order:2}@media(min-width:64rem){.payroll-page__main{display:grid;grid-template-columns:minmax(0,clamp(18rem,34vw,30rem)) minmax(0,1fr);align-items:start}.payroll-panel--form,.payroll-panel--result{order:unset}}.payroll-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);min-width:0;max-width:100%;box-shadow:var(--shadow)}.payroll-panel--form{overflow-x:clip;flex-shrink:0}@media(max-width:63.99rem){.payroll-panel--result{margin-top:var(--space-sm)}.payroll-page .breakdown h2{margin-top:0}}.payroll-page .form-section{margin-bottom:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);min-width:0;max-width:100%}.payroll-page .form-section summary{cursor:pointer;padding:.75rem 1rem;background:var(--color-muted-bg);font-weight:600;-webkit-user-select:none;user-select:none;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.payroll-page .section-body{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);min-width:0;max-width:100%}.payroll-page .calculator-form{width:100%;min-width:0;max-width:100%}.payroll-page label{display:flex;flex-direction:column;gap:var(--space-xs);font-size:.875rem;min-width:0;max-width:100%}.payroll-page label:has(.field-control){overflow:hidden}.payroll-page .field-control{display:block;width:100%;min-width:0;max-width:100%;overflow:hidden;contain:inline-size}.payroll-page input[type=number],.payroll-page select{display:block;width:100%;min-width:0;max-width:100%;padding:.5rem .65rem;border:1px solid var(--color-input-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-family:inherit;box-sizing:border-box}.payroll-page select{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:1.75rem}.payroll-page input:focus,.payroll-page select:focus{outline:2px solid var(--color-darkest);outline-offset:0}@media(max-width:56rem){.payroll-page input[type=number],.payroll-page select{font-size:1rem}}.payroll-page .hint{color:var(--color-muted);font-size:.8rem}.payroll-page fieldset{border:1px dashed var(--color-border);border-radius:var(--radius-sm);padding:.75rem;margin:0;min-width:0;max-width:100%}.payroll-page legend{padding:0 .35rem;font-size:.85rem;color:var(--color-muted)}.payroll-page .checkbox-grid{display:flex;flex-direction:column;gap:.4rem;max-height:clamp(12rem,28vh,16rem);overflow-y:auto;overscroll-behavior:contain}.payroll-page .checkbox-item{flex-direction:row;align-items:flex-start;gap:.5rem;font-size:.82rem}.payroll-page .checkbox-item input{margin-top:.2rem;accent-color:var(--color-darkest)}.payroll-page .checkbox-item em{color:var(--color-muted);font-style:normal;font-size:.75rem}.payroll-page .custom-regional{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,9.5rem),1fr));gap:var(--space-sm);min-width:0;max-width:100%}.payroll-page .breakdown{min-width:0}.payroll-page .breakdown h2{margin:0 0 var(--space-md);font-size:1.1rem}.payroll-page .summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,7.5rem),1fr));gap:var(--space-sm);margin-bottom:var(--space-md)}.payroll-page .card{background:var(--color-muted-bg);border-radius:var(--radius-sm);padding:.75rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.25rem}.payroll-page .card.highlight{border:1px solid var(--color-darkest)}.payroll-page .card.muted{opacity:.9}.payroll-page .card.highlight-secondary .card-value{color:var(--color-darkest)}.payroll-page .card-label{font-size:.75rem;color:var(--color-muted);text-transform:uppercase;letter-spacing:.03em}.payroll-page .card-value{font-size:1.15rem;font-weight:700;word-break:break-word}.payroll-page .card.highlight .card-value{color:var(--color-duty)}.payroll-page .card.deduction .card-value{color:var(--color-danger)}.payroll-page .card-hint{font-size:.7rem;color:var(--color-muted)}.payroll-page .warnings{background:color-mix(in srgb,var(--color-incomplete) 12%,transparent);border-left:3px solid var(--color-incomplete);margin:0 0 1rem;font-size:.85rem;list-style:disc;padding:.5rem 1rem .5rem 1.5rem}.payroll-page .table-scroll{width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;margin:0 -.5rem;padding:0 .5rem}.payroll-page .payroll-table{width:100%;min-width:min(100%,32rem);border-collapse:collapse;table-layout:auto;font-size:.85rem}.payroll-page .payroll-table col.col-num{width:18%}.payroll-page .payroll-table col.col-pct{width:10%}.payroll-page .payroll-table th,.payroll-page .payroll-table td{padding:.5rem .65rem;border-bottom:1px solid var(--color-border);text-align:left;vertical-align:top;word-break:break-word}.payroll-page .payroll-table th{color:var(--color-muted);font-weight:500}.payroll-page .payroll-table .num{text-align:right;white-space:nowrap;min-width:4.5rem}.payroll-page .payroll-table .amount{font-weight:600}.payroll-page .payroll-table .amount.deduction{color:var(--color-danger)}.payroll-page .payroll-table tfoot .deduction-row td{border-top:1px solid var(--color-border)}.payroll-page .payroll-table tfoot .net-row td{border-top:2px solid var(--color-darkest)}.payroll-page .payroll-table .note{font-size:.75rem;color:var(--color-muted);text-align:left;white-space:normal}.payroll-page .detail-row td{color:var(--color-muted);font-size:.8rem}.payroll-page .warn-row td{color:var(--color-incomplete);font-size:.8rem}.payroll-page .line-note{display:block;font-size:.75rem;color:var(--color-muted);margin-top:.15rem}.payroll-page .annual-aid{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--color-border)}.payroll-page .annual-aid h3{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:var(--color-muted)}.payroll-page .payroll-table.compact td,.payroll-page .payroll-table.compact th{padding:.4rem .65rem}.payroll-page .disclaimer{margin-top:1rem;font-size:.78rem;color:var(--color-muted);line-height:1.45}.payroll-page__error{color:var(--color-danger)}:root{--radius: 12px;--radius-sm: 8px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--transition-fast: .15s ease;--transition-normal: .2s ease;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--bp-sm: 30rem;--bp-md: 48rem;--bp-lg: 64rem;--shell-max: min(100%, 30rem);--content-pad: var(--space-md);font-family:Fira Sans,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5}html.native-app{--safe-top: 0px;--safe-bottom: 0px;--safe-left: 0px;--safe-right: 0px}:root,[data-theme=indigo]{--color-bg: #f8fafc;--color-surface: #ffffff;--color-darkest: #4f46e5;--color-darkest-hover: #4338ca;--color-primary: #1e293b;--color-primary-hover: #334155;--color-duty: #059669;--color-duty-bg: #d1fae5;--color-incomplete-bg: #fef2f2;--color-incomplete: #dc2626;--color-danger: #dc2626;--color-text: #0f172a;--color-muted: #64748b;--color-border: #e2e8f0;--color-input-border: #cbd5e1;--color-secondary-bg: #e2e8f0;--color-secondary-hover: #cbd5e1;--color-secondary-active: #94a3b8;--color-muted-bg: #f1f5f9;--color-list-row-bg: #f1f5f9;--color-list-row-hover: #e2e8f0;--color-list-row-selected: #e0e7ff;--shadow: 0 2px 12px rgba(15, 23, 42, .08);--shadow-toggle: 0 1px 4px rgba(15, 23, 42, .12);--shadow-modal: 0 -8px 32px rgba(15, 23, 42, .18);--color-modal-overlay: rgba(15, 23, 42, .45);--color-modal-surface: var(--color-surface);--color-status-pending-bg: #e0e7ff;--color-status-pending-text: #3730a3;--color-on-accent: #ffffff;color:var(--color-text);background:var(--color-bg)}[data-theme=teal]{--color-bg: #faf9f7;--color-surface: #ffffff;--color-darkest: #0d9488;--color-darkest-hover: #0f766e;--color-primary: #134e4a;--color-primary-hover: #115e59;--color-duty: #16a34a;--color-duty-bg: #dcfce7;--color-incomplete-bg: #fff1f2;--color-incomplete: #e11d48;--color-danger: #e11d48;--color-text: #1c1917;--color-muted: #78716c;--color-border: #e7e5e4;--color-input-border: #d6d3d1;--color-secondary-bg: #ccfbf1;--color-secondary-hover: #99f6e4;--color-secondary-active: #5eead4;--color-muted-bg: #f5f5f4;--color-list-row-bg: #f5f5f4;--color-list-row-hover: #ecfdf5;--color-list-row-selected: #ccfbf1;--shadow: 0 2px 12px rgba(19, 78, 74, .1);--shadow-toggle: 0 1px 4px rgba(19, 78, 74, .12);--shadow-modal: 0 -8px 32px rgba(19, 78, 74, .2);--color-modal-overlay: rgba(19, 78, 74, .4);--color-modal-surface: var(--color-surface);--color-status-pending-bg: #ccfbf1;--color-status-pending-text: #0f766e}[data-theme=cyan]{--color-bg: #f4f4f5;--color-surface: #ffffff;--color-darkest: #0891b2;--color-darkest-hover: #0e7490;--color-primary: #18181b;--color-primary-hover: #27272a;--color-duty: #22c55e;--color-duty-bg: #bbf7d0;--color-incomplete-bg: #ffe4e6;--color-incomplete: #be123c;--color-danger: #be123c;--color-text: #09090b;--color-muted: #71717a;--color-border: #e4e4e7;--color-input-border: #d4d4d8;--color-secondary-bg: #e4e4e7;--color-secondary-hover: #d4d4d8;--color-secondary-active: #a1a1aa;--color-muted-bg: #fafafa;--color-list-row-bg: #fafafa;--color-list-row-hover: #f4f4f5;--color-list-row-selected: #cffafe;--shadow: 0 2px 12px rgba(9, 9, 11, .08);--shadow-toggle: 0 1px 4px rgba(9, 9, 11, .1);--shadow-modal: 0 -8px 32px rgba(9, 9, 11, .22);--color-modal-overlay: rgba(9, 9, 11, .5);--color-modal-surface: var(--color-surface);--color-status-pending-bg: #cffafe;--color-status-pending-text: #0e7490}[data-theme=violet]{--color-bg: #faf5ff;--color-surface: #ffffff;--color-darkest: #7c3aed;--color-darkest-hover: #6d28d9;--color-primary: #4c1d95;--color-primary-hover: #5b21b6;--color-duty: #15803d;--color-duty-bg: #bbf7d0;--color-incomplete-bg: #fdf2f8;--color-incomplete: #db2777;--color-danger: #db2777;--color-text: #1e1b4b;--color-muted: #6b7280;--color-border: #e9d5ff;--color-input-border: #d8b4fe;--color-secondary-bg: #ede9fe;--color-secondary-hover: #ddd6fe;--color-secondary-active: #c4b5fd;--color-muted-bg: #f5f3ff;--color-list-row-bg: #f5f3ff;--color-list-row-hover: #ede9fe;--color-list-row-selected: #ede9fe;--shadow: 0 2px 12px rgba(76, 29, 149, .1);--shadow-toggle: 0 1px 4px rgba(76, 29, 149, .12);--shadow-modal: 0 -8px 32px rgba(76, 29, 149, .2);--color-modal-overlay: rgba(76, 29, 149, .35);--color-modal-surface: var(--color-surface);--color-status-pending-bg: #ede9fe;--color-status-pending-text: #5b21b6}[data-theme=forest]{--color-bg: #f7fee7;--color-surface: #ffffff;--color-darkest: #d97706;--color-darkest-hover: #b45309;--color-primary: #14532d;--color-primary-hover: #166534;--color-duty: #166534;--color-duty-bg: #bbf7d0;--color-incomplete-bg: #fee2e2;--color-incomplete: #b91c1c;--color-danger: #b91c1c;--color-text: #052e16;--color-muted: #4d7c0f;--color-border: #d9f99d;--color-input-border: #bef264;--color-secondary-bg: #ecfccb;--color-secondary-hover: #d9f99d;--color-secondary-active: #bef264;--color-muted-bg: #f7fee7;--color-list-row-bg: #f7fee7;--color-list-row-hover: #ecfccb;--color-list-row-selected: #fef3c7;--shadow: 0 2px 12px rgba(20, 83, 45, .1);--shadow-toggle: 0 1px 4px rgba(20, 83, 45, .12);--shadow-modal: 0 -8px 32px rgba(20, 83, 45, .25);--color-modal-overlay: rgba(5, 46, 22, .55);--color-modal-surface: var(--color-surface);--color-status-pending-bg: #fef3c7;--color-status-pending-text: #b45309}[data-theme=dark]{--color-bg: #0f1419;--color-surface: #1a2332;--color-darkest: #38bdf8;--color-darkest-hover: #0ea5e9;--color-primary: #e2e8f0;--color-primary-hover: #cbd5e1;--color-duty: #4ade80;--color-duty-bg: #14532d;--color-incomplete-bg: #450a0a;--color-incomplete: #f87171;--color-danger: #f87171;--color-text: #f1f5f9;--color-muted: #94a3b8;--color-border: #334155;--color-input-border: #475569;--color-secondary-bg: #1e293b;--color-secondary-hover: #334155;--color-secondary-active: #475569;--color-muted-bg: #1a2332;--color-list-row-bg: #1a2332;--color-list-row-hover: #243044;--color-list-row-selected: #1e3a5f;--shadow: 0 2px 12px rgba(0, 0, 0, .35);--shadow-toggle: 0 1px 4px rgba(0, 0, 0, .4);--shadow-modal: 0 -8px 40px rgba(0, 0, 0, .55);--color-modal-overlay: rgba(0, 0, 0, .65);--color-modal-surface: #243044;--color-status-pending-bg: #422006;--color-status-pending-text: #fbbf24}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100dvh}#root{min-height:100dvh}.app-shell{display:flex;flex-direction:column;width:100%;max-width:var(--shell-max);margin-inline:auto;min-height:100dvh;background:var(--color-bg)}@media(min-width:48rem){:root{--shell-max: 100%}.app-shell{max-width:100%;margin-inline:0}}.app-shell__main{position:relative;flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;isolation:isolate}.app-shell__main-scroll{position:relative;flex:1;display:flex;flex-direction:column;min-height:0;z-index:1}.app-shell__main:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 80% at 50% -25%,color-mix(in srgb,var(--color-darkest) 13%,transparent),transparent 58%),radial-gradient(85% 55% at 100% 100%,color-mix(in srgb,var(--color-duty) 11%,transparent),transparent 52%),var(--color-bg);pointer-events:none;z-index:0}.app-shell__main:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 92% 8%,color-mix(in srgb,var(--color-darkest) 7%,transparent),transparent 38%),radial-gradient(circle at 6% 92%,color-mix(in srgb,var(--color-duty) 6%,transparent),transparent 42%);pointer-events:none;z-index:0}.app-shell__main-scroll>*{position:relative}.app-shell__page-wrap{display:flex;flex-direction:column;min-height:100%}.app-shell:has(.home-page--list) .app-shell__page-wrap,.app-shell:has(.home-page--matrix) .app-shell__page-wrap,.app-shell:has(.chat-page--telegram) .app-shell__page-wrap,.app-shell:has(.chat-room--telegram) .app-shell__page-wrap,.app-shell:has(.subpage) .app-shell__page-wrap{flex:1;min-height:0}.app-shell:not(:has(.home-page--list,.home-page--matrix,.chat-page--telegram,.chat-room--telegram)){height:100dvh;max-height:100dvh;overflow:hidden}.app-shell:not(:has(.chat-page--telegram,.chat-room--telegram)) .app-shell__main{padding:var(--space-md);background:color-mix(in srgb,var(--color-surface) 90%,transparent);backdrop-filter:blur(16px) saturate(1.15);-webkit-backdrop-filter:blur(16px) saturate(1.15);border:1px solid color-mix(in srgb,var(--color-border) 75%,transparent);box-shadow:0 1px color-mix(in srgb,#fff 35%,transparent) inset,var(--shadow)}[data-theme=dark] .app-shell:not(:has(.chat-page--telegram,.chat-room--telegram)) .app-shell__main{background:color-mix(in srgb,var(--color-surface) 78%,transparent);box-shadow:0 1px color-mix(in srgb,#fff 6%,transparent) inset,var(--shadow)}.app-shell:not(:has(.home-page--list,.home-page--matrix,.chat-page--telegram,.chat-room--telegram)) .app-shell__main-scroll{display:block;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.app-shell:has(.chat-page--telegram,.chat-room--telegram) .app-shell__main:after,.app-shell:has(.home-page) .app-shell__main:after{display:none}.app-shell:has(.chat-page--telegram,.chat-room--telegram) .app-shell__main:before{display:none}.app-shell__footer{flex-shrink:0;margin-top:auto;padding-top:var(--space-md);padding-bottom:calc(var(--space-xs) + var(--safe-bottom));display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;font-size:.75rem;color:var(--color-muted);letter-spacing:.02em;border-top:1px solid color-mix(in srgb,var(--color-border) 35%,transparent)}.side-menu__version{flex-shrink:0;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border);font-size:.75rem;color:var(--color-muted);text-align:center}.page-loading{text-align:center;padding:24px;color:var(--color-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 20px;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s}.btn--primary{background:var(--color-darkest);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-darkest-hover)}.btn--secondary{background:var(--color-secondary-bg);color:var(--color-primary)}.btn--danger{background:var(--color-incomplete-bg);color:var(--color-danger)}.btn--ghost{background:transparent;color:var(--color-primary);min-height:44px;padding:0 12px}.btn:disabled{opacity:.6;cursor:not-allowed}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field__label{font-size:.875rem;font-weight:600;color:var(--color-muted)}.field__input{min-height:44px;padding:10px 14px;border:1px solid var(--color-input-border);border-radius:var(--radius);font-size:1rem;transition:border-color .15s}.field__input:hover:not(:disabled):not(:focus){border-color:var(--color-darkest)}.field__input:focus{outline:2px solid var(--color-darkest);outline-offset:1px;border-color:var(--color-darkest)}.field__password-wrap{position:relative}.field__input--password{width:100%;padding-right:48px}.field__password-toggle{position:absolute;top:0;right:0;bottom:0;width:44px;display:flex;align-items:center;justify-content:center;padding:0;border:none;background:transparent;color:var(--color-muted);cursor:pointer;border-radius:0 var(--radius) var(--radius) 0}.field__password-toggle:hover{color:var(--color-darkest)}.field__password-toggle:focus-visible{outline:2px solid var(--color-darkest);outline-offset:-2px}.field__error{font-size:.8rem;color:var(--color-danger)}.form-message{margin:0 0 12px;padding:10px 12px;border-radius:var(--radius);font-size:.9rem}.form-message--error{background:#ffebee;color:var(--color-danger)}.form-message--success{background:#e8f5e9;color:var(--color-duty)}.auth-page{padding-top:48px}.auth-page__title{margin:0 0 24px;font-size:1.5rem;color:var(--color-primary);text-align:center}.auth-form__submit{width:100%;margin-top:8px}.auth-page__link{margin-top:24px;text-align:center;font-size:.95rem}.auth-page__link a{color:var(--color-primary);font-weight:600}.home-page__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.home-page__menu-btn{position:relative;display:flex;align-items:center;justify-content:center;padding:0;border:none;background:transparent;color:var(--color-primary);cursor:pointer}.home-page__menu-badge{position:absolute;top:-2px;right:-6px;min-width:1.125rem;padding:2px 5px;border-radius:999px;background:var(--color-primary);color:#fff;font-size:.625rem;font-weight:700;line-height:1.2;text-align:center;pointer-events:none}.home-page__menu-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px;border-radius:var(--radius)}.avatar{display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-darkest);color:#fff;font-weight:600;flex-shrink:0;overflow:hidden}.avatar--sm{width:40px;height:40px;font-size:.875rem}.avatar--md{width:48px;height:48px;font-size:1rem}.avatar--lg{width:80px;height:80px;font-size:1.5rem}.avatar--image{object-fit:cover;padding:0;background:transparent}.home-page__header-avatar{flex-shrink:0}.home-page__header-avatar-btn{display:inline-flex;padding:0;border:none;border-radius:50%;background:transparent;cursor:pointer;flex-shrink:0;line-height:0}.home-page__header-avatar-btn:hover .home-page__header-avatar.avatar--image{outline:2px solid var(--color-primary);outline-offset:2px}.home-page__header-avatar-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px;border-radius:50%}.side-menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:110}.side-menu__overlay{position:absolute;top:0;right:0;bottom:0;left:0;border:none;background:#00000073;cursor:pointer}.side-menu__panel{position:absolute;top:0;left:0;bottom:0;width:min(280px,85vw);display:flex;flex-direction:column;overflow:hidden;padding:calc(var(--space-md) + var(--safe-top)) calc(var(--space-md) + var(--safe-right)) calc(var(--space-md) + var(--safe-bottom)) calc(var(--space-md) + var(--safe-left));background:var(--color-surface);box-shadow:4px 0 24px #00000026;animation:slideInLeft .2s ease-out}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}.side-menu__user{display:flex;align-items:center;gap:12px;flex-shrink:0;width:100%;padding:0 0 20px;margin:0 0 12px;border:none;border-bottom:1px solid var(--color-border);background:transparent;text-align:left;cursor:pointer;transition:opacity .2s ease}.side-menu__user:hover{opacity:.85}.side-menu__user:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px;border-radius:var(--radius)}.side-menu__user-text{min-width:0;flex:1}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.side-menu__name{margin:0;font-weight:600;color:var(--color-primary)}.side-menu__email{margin:4px 0 0;font-size:.85rem;color:var(--color-muted)}.side-menu__nav{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.side-menu__actions{list-style:none;margin:0;padding:8px 0 0;display:flex;flex-direction:column;gap:8px}.side-menu__actions--footer{margin-top:auto;padding-top:12px}.side-menu__actions>li{margin:0;padding:0}.side-menu__action{display:flex;align-items:center;justify-content:flex-start;gap:10px;box-sizing:border-box;width:100%;min-height:44px;padding:0 14px;border:none;border-radius:var(--radius);background:var(--color-secondary-bg);color:var(--color-primary);font:inherit;font-size:1rem;font-weight:600;line-height:1.2;text-align:left;text-decoration:none;cursor:pointer;transition:background .15s ease}.side-menu__action img{flex-shrink:0}.side-menu__action:hover{background:var(--color-secondary-hover);color:var(--color-primary)}.side-menu__action:active{background:var(--color-secondary-active)}.side-menu__action:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.settings-modal__section+.settings-modal__section,.profile-modal__section+.profile-modal__section{margin-top:24px;padding-top:24px;border-top:1px solid var(--color-border)}.settings-modal__label,.profile-modal__section-title{margin:0 0 6px;font-size:.9375rem;font-weight:600;color:var(--color-primary)}.settings-modal__hint,.profile-modal__section-hint{margin:0 0 14px;font-size:.875rem;line-height:1.45;color:var(--color-muted)}.profile-modal{display:flex;flex-direction:column}.profile-modal__hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid var(--color-border)}.profile-modal__avatar-wrap{position:relative;margin-bottom:16px}.profile-modal__avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#0f172a8c}.profile-modal__spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:profile-spinner .7s linear infinite}@keyframes profile-spinner{to{transform:rotate(360deg)}}.profile-modal__name{margin:0 0 4px;font-size:1.125rem;font-weight:700;color:var(--color-primary)}.profile-modal__email{margin:0 0 10px;font-size:.875rem;color:var(--color-muted)}.profile-modal__role{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.75rem;font-weight:600;background:var(--color-secondary-bg);color:var(--color-muted)}.profile-modal__avatar-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px}.profile-modal__action-btn{min-height:44px;padding:0 16px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:border-color .2s ease,background .2s ease,color .2s ease}.profile-modal__action-btn:hover:not(:disabled){border-color:var(--color-darkest);background:var(--color-muted-bg)}.profile-modal__action-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.profile-modal__action-btn:disabled{opacity:.6;cursor:not-allowed}.profile-modal__action-btn--danger{color:var(--color-danger);border-color:var(--color-incomplete-bg);background:var(--color-incomplete-bg)}.profile-modal__action-btn--danger:hover:not(:disabled){border-color:var(--color-danger);background:var(--color-incomplete-bg);color:var(--color-danger)}.profile-modal__error{margin:12px 0 0;max-width:100%;text-align:center}.profile-modal__section{margin:0}.theme-picker{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.theme-picker__option{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;min-height:44px;padding:12px 10px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font:inherit;font-size:.8125rem;font-weight:600;cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.theme-picker__option:hover{border-color:var(--color-darkest);background:var(--color-muted-bg)}.theme-picker__option--active{border-color:var(--color-darkest);background:var(--color-muted-bg);box-shadow:0 0 0 1px var(--color-darkest)}.theme-picker__option:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.theme-picker__check{position:absolute;top:8px;right:8px;display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--color-darkest);color:#fff}.theme-picker__swatch{display:flex;width:100%;max-width:72px;height:20px;border-radius:6px;overflow:hidden;border:1px solid var(--color-border)}.theme-picker__swatch-primary,.theme-picker__swatch-accent{flex:1}.theme-picker__label{line-height:1.2;text-align:center}.app-shell:has(.home-page--list),.app-shell:has(.home-page--matrix){display:flex;flex-direction:column;height:100dvh;max-height:100dvh;overflow:hidden}.app-shell:has(.home-page) .app-shell__main{padding:var(--space-md)}.app-shell:has(.home-page--list) .app-shell__main,.app-shell:has(.home-page--matrix) .app-shell__main{gap:4px}.app-shell:has(.home-page--list) .app-shell__main-scroll,.app-shell:has(.home-page--matrix) .app-shell__main-scroll{display:flex;flex-direction:column;overflow:hidden}.app-shell:has(.home-page--list) .app-shell__page-wrap,.app-shell:has(.home-page--matrix) .app-shell__page-wrap{gap:4px}.app-shell:has(.home-page--list) .app-shell__footer,.app-shell:has(.home-page--matrix) .app-shell__footer{padding-top:8px}.home-page--list,.home-page--matrix{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.home-page--list .home-page__header,.home-page--matrix .home-page__header{margin-bottom:8px;flex-shrink:0}.home-page--list .home-page__schedule-toolbar,.home-page--matrix .home-page__schedule-toolbar{margin-bottom:6px;flex-shrink:0}.home-page--matrix .home-page__matrix-fallback{flex-shrink:0;margin:0 0 6px;font-size:.8rem;color:var(--color-muted);line-height:1.35}.home-page--list .home-page__legend,.home-page--matrix .home-page__legend{flex-shrink:0;margin-top:0;padding:4px 0 0}.home-page--list .page-loading,.home-page--list .home-page__schedule-placeholder,.home-page--matrix .page-loading,.home-page--matrix .home-page__schedule-placeholder{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.home-page--list .home-page__schedule,.home-page--matrix .home-page__schedule,.home-page--list .home-page__schedule-view,.home-page--matrix .home-page__schedule-view{flex:1;min-height:0;display:flex;flex-direction:column}.home-page__schedule{position:relative;background:transparent}.home-page__schedule-placeholder{min-height:280px;display:flex;align-items:center;justify-content:center}.home-page__schedule-view{position:relative;background:transparent}.home-page__schedule-view--loading{pointer-events:none;opacity:.55}.home-page__schedule-toolbar{display:flex;justify-content:center;margin-bottom:8px}.home-page .duty-calendar{background:transparent;box-shadow:none;padding:0}.schedule-view-toggle{display:inline-flex;padding:4px;gap:4px;background:var(--color-secondary-bg);border-radius:var(--radius)}.schedule-view-toggle__btn{min-height:44px;padding:0 10px;border:none;border-radius:calc(var(--radius) - 4px);background:transparent;color:var(--color-primary);font-size:.8125rem;font-weight:600;cursor:pointer}.schedule-view-toggle__btn:disabled{opacity:.45;cursor:not-allowed}.schedule-view-toggle__btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.schedule-view-toggle__btn--active{background:var(--color-surface);color:var(--color-darkest);box-shadow:var(--shadow-toggle)}.schedule-month-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:2.75rem;margin-bottom:12px}.schedule-month-nav__label,.duty-calendar .rdp-caption_label{font-weight:700;color:var(--color-primary)}.schedule-month-nav__label{flex:1;text-align:center}.schedule-month-nav__btn,.duty-calendar .rdp-button_next,.duty-calendar .rdp-button_previous{width:2.75rem;height:2.75rem;border:none;border-radius:var(--radius);background:transparent;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font:inherit;color:var(--color-primary);-moz-appearance:none;appearance:none;-webkit-appearance:none}.schedule-month-nav__btn:hover:not(:disabled),.duty-calendar .rdp-button_next:hover:not(:disabled):not([aria-disabled=true]),.duty-calendar .rdp-button_previous:hover:not(:disabled):not([aria-disabled=true]){background:var(--color-secondary-bg)}.schedule-month-nav__btn:focus-visible,.duty-calendar .rdp-button_next:focus-visible,.duty-calendar .rdp-button_previous:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.schedule-month-nav__chevron,.duty-calendar .rdp-chevron{display:inline-block;fill:var(--color-darkest)}.duty-day-list{display:flex;flex-direction:column;background:transparent;border-radius:var(--radius);padding:12px}.home-page--list .duty-day-list{flex:1;min-height:0;width:100%;margin-inline:0;border-radius:0;padding:0;overflow:hidden}.home-page--list .schedule-month-nav{flex-shrink:0;position:sticky;top:0;z-index:1;margin-bottom:0;padding:2px 0 6px;background:transparent}.duty-day-list__scroll{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.home-page--list .duty-day-list__scroll{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.duty-day-list__row{display:grid;grid-template-columns:52px 1fr;gap:12px;align-items:start;width:100%;padding:10px 8px;border:1px solid color-mix(in srgb,var(--color-border) 75%,transparent);border-radius:calc(var(--radius) - 4px);background:var(--color-list-row-bg);text-align:left;cursor:pointer;font:inherit;color:inherit}.duty-day-list__row:hover{background:var(--color-list-row-hover)}.duty-day-list__date-trigger{display:flex;align-items:start;justify-content:center;padding:0;border:none;border-radius:calc(var(--radius) - 4px);background:transparent;font:inherit;color:inherit;cursor:pointer}.duty-day-list__date-trigger:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.duty-day-list__row--selected{background:var(--color-list-row-selected)}.duty-day-list__row--my{background:var(--color-secondary-bg);color:var(--color-darkest)}.duty-day-list__row--my .duty-day-list__day-num,.duty-day-list__row--my .duty-day-list__shift{color:var(--color-darkest)}.duty-day-list__row--my.duty-day-list__row--selected{box-shadow:inset 0 0 0 2px var(--color-darkest)}.duty-day-list__row--incomplete:not(.duty-day-list__row--my){background:var(--color-status-pending-bg)}.duty-day-list__row--incomplete:not(.duty-day-list__row--my) .duty-day-list__day-num{color:var(--color-status-pending-text)}.duty-day-list__row--incomplete.duty-day-list__row--my{box-shadow:inset 0 0 0 2px var(--color-status-pending-text)}.duty-day-list__date{display:flex;flex-direction:column;align-items:center;line-height:1.2}.duty-day-list__day-num{font-size:1.125rem;font-weight:700;color:var(--color-primary)}.duty-day-list__weekday{font-size:.7rem;color:var(--color-muted);text-transform:lowercase}.duty-day-list__shifts{display:flex;flex-direction:column;gap:4px;padding-top:2px}.duty-day-list__shift{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:600;color:var(--color-text)}.duty-day-list__person{display:inline-flex;align-items:center;gap:8px;min-width:0}.duty-day-list__avatar.avatar--sm{width:28px;height:28px;font-size:.65rem;flex-shrink:0}.duty-day-list__avatar-btn{display:inline-flex;padding:0;border:none;border-radius:50%;background:transparent;cursor:pointer;flex-shrink:0;line-height:0}.duty-day-list__avatar-btn:hover .duty-day-list__avatar.avatar--image{outline:2px solid var(--color-primary);outline-offset:2px}.duty-day-list__avatar-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px;border-radius:50%}.duty-day-list__name{min-width:0}.duty-day-list__name-btn{padding:0;border:none;background:none;font:inherit;font-weight:inherit;color:inherit;cursor:pointer;text-align:left;text-decoration:underline;text-decoration-color:transparent;text-underline-offset:2px;transition:text-decoration-color .15s ease}.duty-day-list__name-btn:hover{text-decoration-color:currentColor}.duty-day-list__name-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px;border-radius:2px}.duty-day-list__office{margin-left:auto;text-align:right;flex-shrink:0;font-size:.8rem;font-weight:500;color:var(--color-muted)}.duty-day-list__empty{color:var(--color-muted);font-size:.9rem}.duty-calendar{--rdp-day_button-width: 44px;--rdp-day_button-height: 44px;--rdp-accent-color: var(--color-darkest);--rdp-accent-background-color: var(--color-list-row-selected);--rdp-today-color: var(--color-darkest);--rdp-range_middle-color: var(--color-text);--rdp-range_start-color: var(--color-on-accent, #fff);--rdp-range_end-color: var(--color-on-accent, #fff);--rdp-range_start-date-background-color: var(--color-darkest);--rdp-range_end-date-background-color: var(--color-darkest);--rdp-selected-border: 2px solid var(--color-darkest);--rdp-outside-opacity: .45;--rdp-weekday-opacity: 1;width:fit-content;max-width:100%;margin-inline:auto;color:var(--color-text);background:var(--color-surface);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow)}.duty-calendar .rdp-month_caption{font-weight:inherit;font-size:inherit}.duty-calendar .rdp-weekday{color:var(--color-muted);font-weight:600}.duty-calendar .rdp-day_button{color:var(--color-text);transition:background .15s,color .15s,border-color .15s,box-shadow .15s}.duty-calendar .rdp-day_button:hover:not(:disabled){background:var(--color-muted-bg)}.duty-calendar .rdp-day_button:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px;z-index:1}.duty-calendar .rdp-outside .rdp-day_button{color:var(--color-muted)}.duty-calendar .rdp-today:not(.rdp-outside) .rdp-day_button{font-weight:700;color:var(--color-darkest)}.duty-calendar .rdp-selected .rdp-day_button{background:var(--color-darkest);color:var(--color-on-accent, #fff);border-color:var(--color-darkest);font-weight:700}.duty-calendar .rdp-day{width:44px;height:44px}.duty-calendar__day--my .rdp-day_button{background:var(--color-secondary-bg)!important;color:var(--color-darkest)!important;border-color:transparent!important;font-weight:700;border-radius:50%}.duty-calendar__day--my.rdp-selected .rdp-day_button{background:var(--color-secondary-bg)!important;color:var(--color-darkest)!important;box-shadow:inset 0 0 0 2px var(--color-darkest)}.duty-calendar__day--my.rdp-today:not(.rdp-outside) .rdp-day_button{color:var(--color-darkest)!important}.duty-calendar__day--incomplete:not(.duty-calendar__day--my) .rdp-day_button{background:var(--color-status-pending-bg)!important;color:var(--color-status-pending-text)!important;border-color:transparent!important;font-weight:600}.duty-calendar__day--incomplete.rdp-selected:not(.duty-calendar__day--my) .rdp-day_button{background:var(--color-status-pending-bg)!important;color:var(--color-status-pending-text)!important;box-shadow:inset 0 0 0 2px var(--color-darkest)}.duty-calendar__day--incomplete.duty-calendar__day--my .rdp-day_button{box-shadow:inset 0 0 0 2px var(--color-status-pending-text)!important}.duty-calendar__day--incomplete.duty-calendar__day--my.rdp-selected .rdp-day_button{box-shadow:inset 0 0 0 2px var(--color-status-pending-text),inset 0 0 0 4px var(--color-darkest)!important}.duty-calendar__day--absent:not(.duty-calendar__day--my) .rdp-day_button{background:var(--color-muted-bg, #e8e8e8)!important;color:var(--color-muted)!important;border-color:transparent!important}.duty-calendar__day--absent.duty-calendar__day--my .rdp-day_button{box-shadow:inset 0 0 0 2px var(--color-muted)!important}.duty-day-list__row--absent{border-left:3px solid var(--color-muted)}.home-page__legend{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 12px;margin-top:8px;font-size:.8rem;color:var(--color-muted)}.app-shell:has(.home-page:not(.home-page--list)) .app-shell__footer{padding-top:8px}.home-page__legend-item:before{content:"";display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:6px;vertical-align:middle}.home-page__legend-item--my{color:var(--color-darkest)}.home-page__legend-item--my:before{background:var(--color-secondary-bg);border:none}.home-page__legend-item--incomplete{color:var(--color-status-pending-text)}.home-page__legend-item--incomplete:before{background:var(--color-status-pending-bg);border:2px solid var(--color-status-pending-text)}.home-page__legend-item--absent:before{background:var(--color-muted-bg, #e8e8e8);border:1px solid var(--color-muted)}.day-detail__absence-banner{display:flex;align-items:center;gap:var(--space-sm);margin:0 0 var(--space-md);padding:12px 14px;border-radius:var(--radius-sm);border-left:3px solid var(--color-muted);background:var(--color-muted-bg);color:var(--color-text);font-weight:600;font-size:.9375rem}.day-detail__absence-icon{flex-shrink:0;color:var(--color-muted)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;display:flex;align-items:flex-end;justify-content:center}.modal__overlay{position:absolute;top:0;right:0;bottom:0;left:0;border:none;background:var(--color-modal-overlay);cursor:pointer}.modal__panel{position:relative;width:100%;max-width:min(100%,var(--shell-max));max-height:85dvh;color:var(--color-text);background:var(--color-modal-surface);border-top:3px solid var(--color-darkest);border-radius:var(--radius) var(--radius) 0 0;display:flex;flex-direction:column;box-shadow:var(--shadow-modal);animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.modal__panel,.side-menu__panel{animation:none}.profile-modal__spinner{animation:none;border-top-color:#ffffff59}.theme-picker__option,.profile-modal__action-btn,.side-menu__user,.modal__close,.schedule-view-toggle__btn,.duty-calendar .rdp-day_button,.duty-day-list__row,.duty-day-list__date-trigger,.duty-day-list__name-btn,.duty-swap-modal__select-chevron,.duty-swap-modal__select-list,.duty-swap-modal__select-option,.duty-swap-modal__select-trigger{transition:none}.duty-swap-modal__select-wrap--open .duty-swap-modal__select-chevron{transform:rotate(180deg)}.duty-swap-modal__select-wrap--open .duty-swap-modal__select-list,.duty-swap-modal__select-wrap--open .duty-swap-modal__select-option{opacity:1;transform:none}.home-page__schedule-view--loading{transition:none}}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 8px;background:var(--color-muted-bg);border-bottom:1px solid var(--color-border)}.modal__title{margin:0;font-size:1.1rem;font-weight:700;color:var(--color-primary)}.modal__close{width:44px;height:44px;border:none;border-radius:var(--radius);background:transparent;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--color-muted);transition:background .15s,color .15s}.modal__close:hover{background:var(--color-secondary-bg);color:var(--color-primary)}.modal__close:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.modal__body{padding:16px;overflow-y:auto;color:var(--color-text)}.modal__body strong{color:var(--color-primary)}.modal__footer{padding:12px 16px 24px;background:var(--color-muted-bg);border-top:1px solid var(--color-border)}.modal__footer .btn{width:100%}.modal__footer-actions{display:flex;gap:12px}.modal__footer-actions .btn{flex:1;width:auto}.day-detail-modal__title{display:flex;flex-direction:column;gap:2px;min-width:0}.day-detail-modal__title-date{font-size:1.05rem;line-height:1.25}.day-detail-modal__title-weekday{font-size:.8125rem;font-weight:500;color:var(--color-muted);text-transform:capitalize}.day-detail{display:flex;flex-direction:column;gap:var(--space-md)}.day-detail__summary{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:10px 12px;border-radius:var(--radius-sm);background:var(--color-muted-bg);border:1px solid var(--color-border)}.day-detail__summary-count{font-size:.875rem;font-weight:600;color:var(--color-primary)}.day-detail__summary-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;font-size:.6875rem;font-weight:600;white-space:nowrap}.day-detail__summary-badge-icon{flex-shrink:0}.day-detail__summary-badge--ok{background:var(--color-duty-bg);color:var(--color-duty)}.day-detail__summary-badge--warn{background:var(--color-status-pending-bg);color:var(--color-status-pending-text)}.day-detail__section-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.day-detail__section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:10px 12px;background:var(--color-muted-bg);border-bottom:1px solid var(--color-border)}.day-detail__section-title{margin:0;font-size:.8125rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted)}.day-detail__section-counter{flex-shrink:0;padding:2px 8px;border-radius:999px;font-size:.6875rem;font-weight:700;font-variant-numeric:tabular-nums;background:var(--color-secondary-bg);color:var(--color-darkest)}.day-detail__list{list-style:none;margin:0;padding:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-sm)}.day-detail__row{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);font-size:.9375rem;border-left:3px solid transparent;transition:background var(--transition-normal)}.day-detail__row--filled{background:var(--color-list-row-bg);border-left-color:var(--color-duty)}.day-detail__row--swapable{cursor:pointer;width:100%;text-align:left}.day-detail__row--swapable:hover,.day-detail__row--swapable:focus-visible{background:var(--color-list-row-hover)}.day-detail__row--swapable:focus-visible{outline:2px solid color-mix(in srgb,var(--color-duty) 50%,transparent);outline-offset:-2px}.day-detail__swap-hint{margin:0 0 var(--space-sm);padding:8px 12px;border-radius:var(--radius-sm);font-size:.8125rem;color:var(--color-text-muted);background:var(--color-muted-bg)}.day-detail__row--empty-mandatory{background:var(--color-status-pending-bg);border-left-color:var(--color-status-pending-text)}.day-detail__row--empty-optional{background:var(--color-muted-bg);border-left-color:var(--color-border)}.day-detail__office-badge{display:inline-flex;align-items:center;justify-content:center;min-width:4.5rem;padding:4px 8px;border-radius:999px;font-size:.75rem;font-weight:600;white-space:nowrap;background:var(--color-secondary-bg);color:var(--color-primary)}.day-detail__row--empty-mandatory .day-detail__office-badge{background:color-mix(in srgb,var(--color-status-pending-text) 12%,var(--color-surface));color:var(--color-status-pending-text)}.day-detail__row-body{min-width:0;display:flex;justify-content:flex-end}.day-detail__unassigned{font-weight:500;color:var(--color-status-pending-text)}.day-detail__row--empty-optional .day-detail__unassigned{color:var(--color-muted)}.day-detail__empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-md);text-align:center}.day-detail__empty-icon{color:var(--color-muted);opacity:.7}.day-detail__empty{margin:0;color:var(--color-muted);font-size:.95rem}.day-detail__person{display:inline-flex;align-items:center;justify-content:flex-end;gap:var(--space-sm);min-width:0;color:var(--color-text)}.day-detail__name{font-weight:500;text-align:right}.day-detail__avatar.avatar--sm{width:32px;height:32px;font-size:.7rem}.day-detail__avatar-btn{display:inline-flex;padding:6px;margin:-6px;border:none;border-radius:50%;background:transparent;cursor:pointer;flex-shrink:0;line-height:0;transition:opacity var(--transition-fast)}.day-detail__avatar-btn:hover{opacity:.85}.day-detail__avatar-btn:hover .day-detail__avatar.avatar--image{outline:2px solid var(--color-darkest);outline-offset:2px}.day-detail__name-btn{padding:0;border:none;background:none;font:inherit;font-weight:500;color:inherit;cursor:pointer;text-align:right;text-decoration:underline;text-decoration-color:transparent;text-underline-offset:2px;transition:text-decoration-color var(--transition-fast)}.day-detail__name-btn:hover{text-decoration-color:currentColor}.day-detail__name-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px;border-radius:2px}.day-detail__avatar-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}@keyframes day-detail-skeleton-pulse{0%,to{opacity:1}50%{opacity:.45}}.day-detail__skeleton-summary,.day-detail__skeleton-header,.day-detail__skeleton-row{border-radius:var(--radius-sm);background:var(--color-secondary-bg);animation:day-detail-skeleton-pulse 1.4s ease-in-out infinite}.day-detail__skeleton-summary{height:40px}.day-detail__skeleton-header{height:36px;margin:0;border-radius:0}.day-detail__section-card--skeleton .day-detail__list{padding:var(--space-sm)}.day-detail__skeleton-row{height:52px}@media(prefers-reduced-motion:reduce){.day-detail__skeleton-summary,.day-detail__skeleton-header,.day-detail__skeleton-row{animation:none}.day-detail__row,.day-detail__avatar-btn,.day-detail__name-btn{transition:none}}.avatar-preview{position:fixed;top:0;right:0;bottom:0;left:0;z-index:130;display:flex;align-items:center;justify-content:center;padding:16px}.avatar-preview__overlay{position:absolute;top:0;right:0;bottom:0;left:0;border:none;background:var(--color-modal-overlay);cursor:pointer}.avatar-preview__panel{position:relative;width:100%;max-width:min(360px,92vw);color:var(--color-text);background:var(--color-modal-surface);border:3px solid var(--color-darkest);border-radius:var(--radius);box-shadow:var(--shadow-modal);overflow:hidden}.avatar-preview__header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 12px 8px;background:var(--color-muted-bg);border-bottom:1px solid var(--color-border)}.avatar-preview__title{margin:0;font-size:1rem;font-weight:700;color:var(--color-primary);line-height:1.3}.avatar-preview__close{width:44px;height:44px;flex-shrink:0;border:none;border-radius:var(--radius);background:transparent;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--color-muted)}.avatar-preview__close:hover{background:var(--color-secondary-bg);color:var(--color-primary)}.avatar-preview__close:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.avatar-preview__body{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px;background:var(--color-surface);overflow:visible}.avatar-preview__image{display:block;width:min(320px,85vw);height:min(320px,85vw);max-width:100%;object-fit:cover;border-radius:var(--radius)}.avatar-focus-editor{display:flex;flex-direction:column;align-items:center;gap:12px;width:min(320px,85vw);max-width:100%}.avatar-focus-editor__hint{margin:0;font-size:.8125rem;line-height:1.4;color:var(--color-muted);text-align:center}.avatar-focus-editor__frame{position:relative;width:100%;aspect-ratio:1;overflow:hidden;border-radius:var(--radius);touch-action:none;cursor:grab;background:var(--color-muted-bg)}.avatar-focus-editor__frame--dragging{cursor:grabbing}.avatar-focus-editor__image{display:block;width:100%;height:100%}.avatar-focus-editor__mask{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;box-shadow:0 0 0 9999px #00000073;pointer-events:none}.avatar-focus-editor__reticle{position:absolute;width:14px;height:14px;margin:-7px 0 0 -7px;border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #00000059;pointer-events:none}.avatar-focus-editor__preview-row{display:flex;align-items:center;gap:12px}.avatar-focus-editor__preview{overflow:hidden}.avatar-focus-editor__preview img{display:block;width:100%;height:100%}.avatar-preview__actions{position:relative;z-index:3;display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:6px;width:100%;max-width:min(420px,92vw);margin-inline:auto;flex-shrink:0}.avatar-preview__action-btn{min-height:32px;padding:4px 10px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);font-size:.8125rem;font-weight:600;color:var(--color-primary);cursor:pointer;flex-shrink:0;transition:background .15s ease,border-color .15s ease}.avatar-preview__action-btn:hover:not(:disabled){background:var(--color-secondary-bg)}.avatar-preview__action-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.avatar-preview__action-btn:disabled{opacity:.55;cursor:not-allowed}.avatar-preview__action-btn--danger{color:var(--color-danger);border-color:var(--color-danger)}.avatar-preview__action-btn--danger:hover:not(:disabled){background:color-mix(in srgb,var(--color-danger) 12%,transparent)}.avatar-preview__like-wrap{position:relative;flex-shrink:0}.avatar-preview__like{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:var(--radius);background:transparent;color:var(--color-danger);cursor:pointer;flex-shrink:0;transition:color .15s ease,background .15s ease,opacity .15s ease}.avatar-preview__like-icon{display:block;width:20px;height:20px;flex-shrink:0}.avatar-preview__like:disabled{opacity:.55;cursor:not-allowed}.avatar-preview__like:hover{background:var(--color-secondary-bg);color:var(--color-primary)}.avatar-preview__like:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.avatar-preview__like--active{color:var(--color-danger)}.avatar-preview__like-count{min-width:1.25rem;font-size:.875rem;font-weight:700;color:var(--color-primary);text-align:left}.avatar-preview__hearts{position:absolute;left:50%;bottom:calc(100% + 2px);width:0;height:128px;transform:translate(-50%);pointer-events:none;overflow:visible;z-index:2}.avatar-preview__heart-particle{position:absolute;bottom:0;left:calc(50% + var(--heart-offset, 0px));font-size:1.75rem;line-height:1;color:var(--color-danger);opacity:0;animation:avatar-like-heart-rise 1.1s ease-out forwards;transform:translate(calc(-50% + var(--heart-drift, 0px)))}@keyframes avatar-like-heart-rise{0%{opacity:1;transform:translate(calc(-50% + var(--heart-drift, 0px))) translateY(0) scale(.95)}to{opacity:0;transform:translate(calc(-50% + var(--heart-drift, 0px))) translateY(-128px) scale(1.55)}}@media(prefers-reduced-motion:reduce){.avatar-preview__heart-particle{animation:none;display:none}}.photo-gallery-modal__hint{margin:0 0 12px;font-size:.875rem;color:var(--color-muted);line-height:1.45}.photo-gallery-modal__status{margin:0 0 12px;font-size:.875rem;color:var(--color-muted)}.photo-gallery-modal__add{width:100%}.photo-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(5.5rem,1fr));gap:10px;list-style:none;margin:0 0 12px;padding:0}.photo-gallery__item{display:flex;flex-direction:column;gap:6px;min-width:0}.photo-gallery__item--current .photo-gallery__thumb-btn{outline:2px solid var(--color-primary);outline-offset:2px}.photo-gallery__thumb-btn{position:relative;display:block;width:100%;aspect-ratio:1;padding:0;border:none;border-radius:var(--radius);overflow:hidden;cursor:pointer;background:var(--color-muted-bg)}.photo-gallery__thumb{display:block;width:100%;height:100%;object-fit:cover}.photo-gallery__thumb-placeholder{display:block;width:100%;height:100%;background:var(--color-secondary-bg)}.photo-gallery__badge{position:absolute;left:4px;bottom:4px;padding:2px 6px;font-size:.625rem;font-weight:700;color:#fff;background:var(--color-primary);border-radius:4px;line-height:1.2}.photo-gallery__item-actions{display:flex;flex-wrap:wrap;gap:4px}.photo-gallery__item-action{flex:1 1 auto;min-height:32px;padding:4px 6px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface);font-size:.6875rem;font-weight:600;color:var(--color-primary);cursor:pointer}.photo-gallery__item-action--danger{color:var(--color-danger);border-color:var(--color-danger)}.photo-gallery__item-action:disabled{opacity:.5;cursor:not-allowed}.profile-modal__gallery-loading,.profile-modal__gallery-empty{margin:0 0 12px;font-size:.875rem;color:var(--color-muted)}.subpage{display:flex;flex-direction:column;flex:1;min-height:100%}.subpage-main{flex:1;min-width:0;width:100%;max-width:var(--shell-max)}.subpage-footer{flex-shrink:0;margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid color-mix(in srgb,var(--color-border) 35%,transparent)}.subpage-header{display:flex;align-items:center;gap:12px;flex-shrink:0;margin-bottom:var(--space-md)}.subpage-header__back{display:flex;flex-shrink:0;padding:8px;margin:-8px;text-decoration:none;line-height:0;color:inherit}.subpage-header__title{flex:1;min-width:0;margin:0;font-size:1.25rem;font-weight:700;color:var(--color-primary)}.admin-page__list,.edit-day-page__list{list-style:none;margin:0;padding:0}.admin-page__card{background:var(--color-surface);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:var(--shadow)}.admin-page__card--with-delete{display:flex;align-items:flex-start;gap:12px}.admin-page__card-body{flex:1;min-width:0}.admin-page__delete{flex-shrink:0;padding:0;border:none;background:none;cursor:pointer;line-height:0}.admin-page__delete:hover:not(:disabled){opacity:.85}.admin-page__delete:disabled{opacity:.5;cursor:not-allowed}.admin-page__email{margin:4px 0 0;font-size:.875rem;color:var(--color-muted)}.admin-page__card-actions{display:flex;gap:8px;margin-top:12px}.admin-page__card-actions .btn{flex:1}@media(min-width:48rem){.admin-page__card-actions .btn{flex:0 1 auto}}.admin-page__card-actions--inline{flex-wrap:wrap}.admin-page__card-actions--inline .btn{flex:unset}.admin-page__empty{text-align:center;color:var(--color-muted);padding:32px}.settings-page__section-hint,.admin-push__text,.admin-push__hint{margin:0 0 16px;font-size:.875rem;line-height:1.45;color:var(--color-muted)}.admin-push+.admin-push__actions{margin-top:0}.admin-push__actions{display:flex;flex-wrap:wrap;gap:8px}.admin-push__actions .btn{flex:1;min-width:160px}.admin-page__tabs{display:flex;gap:8px;margin-bottom:20px}.admin-page__tab{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-size:.875rem;cursor:pointer}.admin-page__tab--active{border-color:var(--color-darkest);background:var(--color-list-row-selected);color:var(--color-darkest);font-weight:600}.admin-page__tab-badge{min-width:20px;padding:0 6px;border-radius:10px;background:var(--color-darkest);color:#fff;font-size:.75rem;font-weight:600;line-height:20px}.admin-page__card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.admin-page__meta{margin:4px 0 0;font-size:.8rem;color:var(--color-muted)}.admin-page__status{flex-shrink:0;padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:500}.admin-page__status--pending{background:var(--color-status-pending-bg);color:var(--color-status-pending-text)}.admin-page__status--approved{background:var(--color-duty-bg);color:var(--color-duty)}.admin-page__status--rejected{background:var(--color-incomplete-bg);color:var(--color-incomplete)}.edit-day-page__section{background:var(--color-surface);border-radius:var(--radius);padding:16px;margin-bottom:16px;box-shadow:var(--shadow)}.edit-day-page__section h2{margin:0 0 12px;font-size:1rem;color:var(--color-primary)}.edit-day-page__row{margin-bottom:12px}.edit-day-page__label{display:block;font-weight:600;margin-bottom:6px;font-size:.9rem}.edit-day-page__select{width:100%;min-height:44px;padding:8px 12px;border:1px solid var(--color-input-border);border-radius:var(--radius);font-size:1rem;background:var(--color-surface);color:var(--color-text)}.edit-day-page__save{width:100%;margin-top:8px}.admin-statistics-page .schedule-month-nav{margin-bottom:12px}.admin-statistics-page__tabs{display:flex;gap:8px;margin-bottom:12px}.admin-statistics-page__tab{flex:1;min-height:44px;padding:8px 12px;border:1px solid var(--color-input-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-muted);font-size:.9rem;font-weight:600;cursor:pointer}.admin-statistics-page__tab--active{background:var(--color-darkest);border-color:var(--color-darkest);color:var(--color-surface)}.admin-statistics-page__summary{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:12px}@media(min-width:48rem){.admin-statistics-page__summary{grid-template-columns:repeat(2,1fr)}}@media(min-width:64rem){.admin-statistics-page__summary{grid-template-columns:repeat(4,1fr)}}.admin-statistics-page__stat--activity{background:color-mix(in srgb,var(--color-secondary-bg) 70%,var(--color-darkest) 30%)}.admin-statistics-page__stat-value--sm{font-size:.85rem!important;font-weight:600!important;line-height:1.2!important}.admin-statistics-page__meta{margin:0 0 12px;font-size:.8rem;color:var(--color-muted);line-height:1.4}.admin-statistics-page__top-rooms,.admin-statistics-page__daily{margin-bottom:16px}.admin-statistics-page__daily-table-wrap{overflow-x:auto;overflow-y:visible;border:1px solid var(--color-input-border);border-radius:var(--radius);background:var(--color-surface)}.admin-statistics-page__daily-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-statistics-page__daily-table th,.admin-statistics-page__daily-table td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--color-input-border)}.admin-statistics-page__daily-table th{font-size:.75rem;font-weight:600;color:var(--color-muted);background:var(--color-secondary-bg)}.admin-statistics-page__daily-table tr:last-child td{border-bottom:none}.admin-statistics-page__daily-table td{font-variant-numeric:tabular-nums}.admin-statistics-page__daily-value{position:relative;display:inline-block;cursor:help;border-bottom:1px dotted var(--color-muted);outline:none}.admin-statistics-page__daily-tooltip{z-index:1000;min-width:9rem;max-width:min(14rem,calc(100vw - 16px));padding:8px 10px;border:1px solid var(--color-input-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:0 8px 24px var(--color-modal-overlay);text-align:left;pointer-events:none;box-sizing:border-box}.admin-statistics-page__daily-tooltip-title{display:block;margin-bottom:6px;font-size:.7rem;font-weight:600;color:var(--color-muted)}.admin-statistics-page__daily-tooltip-list{list-style:none;margin:0;padding:0;font-size:.8rem;line-height:1.35;color:var(--color-text);overflow-wrap:anywhere}.admin-statistics-page__daily-tooltip-list li+li{margin-top:4px}.admin-statistics-page__daily-chat{display:flex;align-items:center;gap:8px;min-width:5rem}.admin-statistics-page__daily-bar{display:block;height:6px;min-width:2px;max-width:4rem;border-radius:3px;background:var(--color-darkest)}.admin-statistics-page__hint{font-size:.875rem;color:var(--color-muted);margin:0 0 12px;line-height:1.45}.admin-statistics-page__toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end;margin-bottom:16px}.admin-statistics-page__sort-label{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.admin-statistics-page__sort-caption{font-size:.75rem;font-weight:600;color:var(--color-muted)}.admin-statistics-page__select{width:100%;min-height:44px;padding:8px 12px;border:1px solid var(--color-input-border);border-radius:var(--radius);font-size:.9rem;background:var(--color-surface);color:var(--color-text)}.admin-statistics-page__direction{flex-shrink:0;min-height:44px;min-width:4.5rem;padding:8px 10px;border:1px solid var(--color-input-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-darkest);font-size:.875rem;font-weight:600;cursor:pointer}.admin-statistics-page__direction:active{background:var(--color-secondary-bg)}.admin-statistics-page__empty{color:var(--color-muted);text-align:center;margin-top:24px}.admin-statistics-page__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.admin-statistics-page__card{padding:14px;border:1px solid var(--color-input-border);border-radius:var(--radius);background:var(--color-surface)}.admin-statistics-page__name{margin:0 0 12px;font-weight:600;font-size:1rem;line-height:1.3;word-break:break-word}.admin-statistics-page__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(8rem,1fr));gap:8px;margin:0}.admin-statistics-page__stat{margin:0;padding:10px 12px;border-radius:calc(var(--radius) - 2px);background:var(--color-secondary-bg)}.admin-statistics-page__stat--absence{background:var(--color-status-pending-bg)}.admin-statistics-page__stat--planned{background:color-mix(in srgb,var(--color-secondary-bg) 55%,var(--color-primary) 45%)}.admin-statistics-page__stat dt{margin:0 0 4px;font-size:.7rem;font-weight:500;line-height:1.3;color:var(--color-muted)}.admin-statistics-page__stat dd{margin:0;font-size:1.35rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1;color:var(--color-darkest)}.admin-statistics-page__details{margin-top:12px;padding-top:12px;border-top:1px dashed var(--color-input-border)}.admin-statistics-page__details-summary{font-size:.875rem;font-weight:600;color:var(--color-darkest);cursor:pointer;list-style:none}.admin-statistics-page__details-summary::-webkit-details-marker{display:none}.admin-statistics-page__details-body{margin-top:10px}.admin-statistics-page__breakdown{margin-top:12px}.admin-statistics-page__breakdown-title{margin:0 0 6px;font-size:.8rem;font-weight:600;color:var(--color-muted)}.admin-statistics-page__breakdown-empty{margin:12px 0 0;font-size:.85rem;color:var(--color-muted)}.admin-statistics-page__breakdown-list{list-style:none;padding:0;margin:0}.admin-statistics-page__breakdown-item{display:grid;grid-template-columns:1fr auto;gap:4px 8px;padding:6px 0;font-size:.85rem;border-bottom:1px solid var(--color-input-border)}.admin-statistics-page__breakdown-item:last-child{border-bottom:none}.admin-statistics-page__breakdown-type{font-weight:500}.admin-statistics-page__breakdown-count{font-variant-numeric:tabular-nums;font-weight:600;text-align:right}.admin-statistics-page__breakdown-dates{grid-column:1 / -1;font-size:.8rem;color:var(--color-muted);line-height:1.4}.admin-import-page__hint{font-size:.875rem;color:var(--color-muted);margin-bottom:16px;line-height:1.45}.admin-import-page__file-label{display:block;width:100%;min-height:44px;padding:12px 16px;margin-bottom:16px;border:1px dashed var(--color-input-border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--color-surface)}.admin-import-page__file-text{font-size:.95rem}.admin-import-page__meta{margin-bottom:12px;font-size:.9rem}.admin-import-page__range{display:grid;gap:12px;margin-bottom:16px}.admin-import-page__result{margin-top:24px;padding-top:16px;border-top:1px solid var(--color-input-border)}.admin-import-page__result h2{font-size:1.1rem;margin:0 0 12px}.admin-import-page__stats{list-style:none;padding:0;margin:0 0 16px}.admin-import-page__warnings{font-size:.85rem;color:var(--color-muted);padding-left:1.2rem}.admin-import-page__changes-link{display:inline-block;margin-top:12px;font-weight:600;color:var(--color-darkest)}.admin-absences-page__hint{font-size:.875rem;color:var(--color-muted);margin-bottom:16px;line-height:1.45}.admin-absences-page__form,.admin-absences-page__list{margin-top:24px;padding-top:16px;border-top:1px solid var(--color-input-border)}.admin-absences-page__section-title{font-size:1.05rem;margin:0 0 16px}.admin-absences-page__field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.admin-absences-page__label{font-size:.875rem;font-weight:600}.admin-absences-page__select{min-height:44px;padding:10px 12px;border:1px solid var(--color-input-border);border-radius:var(--radius);background:var(--color-surface);font-size:1rem}.admin-absences-page__range{display:grid;gap:12px;margin-bottom:16px}.admin-absences-page__result{margin-top:16px;font-size:.9rem;line-height:1.45}.admin-absences-page__link{font-weight:600;color:var(--color-darkest)}.admin-absences-page__empty{color:var(--color-muted);font-size:.9rem}.admin-absences-page__table-wrap{overflow-x:auto}.admin-absences-page__table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-absences-page__table th,.admin-absences-page__table td{padding:10px 8px;text-align:left;border-bottom:1px solid var(--color-input-border)}.admin-absences-page__table th{font-size:.8rem;color:var(--color-muted);font-weight:600}.admin-absences-page__delete{padding:4px 8px;border:none;background:transparent;color:var(--color-danger, #b42318);font-size:.85rem;font-weight:600;cursor:pointer}.admin-changes-page__empty{color:var(--color-muted);text-align:center;margin-top:24px}.admin-changes-page__list{list-style:none;padding:0;margin:0}.admin-changes-page__item{padding:14px 0;border-bottom:1px solid var(--color-input-border)}.admin-changes-page__desc{margin:0 0 8px;font-size:.95rem;line-height:1.4}.admin-changes-page__meta{display:flex;align-items:center;gap:10px;margin:0;font-size:.8rem;color:var(--color-muted)}.admin-changes-page__badge{padding:2px 8px;border-radius:4px;font-weight:600;background:var(--color-secondary-bg);color:var(--color-darkest)}.admin-changes-page__badge--manual{background:var(--color-status-pending-bg);color:var(--color-status-pending-text)}.admin-changes-page__badge--absence{background:#fde8e8;color:#9b1c1c}.admin-changes-page__more{width:100%;margin-top:16px}.side-menu__badge{margin-left:auto;min-width:1.25rem;padding:2px 6px;border-radius:999px;background:var(--color-primary);color:#fff;font-size:.75rem;font-weight:700;line-height:1.2;text-align:center}.notifications-page__badge{min-width:1.5rem;padding:4px 8px;border-radius:999px;background:var(--color-primary);color:#fff;font-size:.8rem;font-weight:700}.notifications-page__toolbar{margin-bottom:12px}.notifications-page__toolbar .btn{width:100%}.notifications-page__empty{color:var(--color-muted);text-align:center;margin-top:24px}.notifications-page__list{list-style:none;padding:0;margin:0}.notifications-page__item{display:flex;align-items:flex-start;gap:12px;width:100%;padding:14px 0;border:none;border-bottom:1px solid var(--color-input-border);background:transparent;text-align:left;cursor:pointer;color:inherit;font:inherit}.notifications-page__item--unread{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.notifications-page__item:disabled{opacity:.7;cursor:wait}.notifications-page__icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-secondary);flex-shrink:0;font-size:1.25rem}.notifications-page__content{flex:1;min-width:0}.notifications-page__body{display:block;font-size:.95rem;line-height:1.4}.notifications-page__meta{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:.8rem;color:var(--color-muted)}.notifications-page__tag{padding:2px 8px;border-radius:4px;font-weight:600;background:var(--color-status-pending-bg);color:var(--color-status-pending-text)}.notifications-page__more{width:100%;margin-top:16px}.settings-page__section+.settings-page__section{margin-top:28px;padding-top:28px;border-top:1px solid var(--color-input-border)}.settings-page__section-title{margin:0 0 8px;font-size:1rem;font-weight:600;text-align:center}.icon-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:10px;margin-bottom:20px}.icon-picker__option{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;transition:border-color .15s,background .15s}.icon-picker__option:hover,.icon-picker__option--active{border-color:var(--color-darkest);background:var(--color-muted-bg)}.icon-picker__option:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.icon-picker__check{position:absolute;top:6px;right:6px;color:var(--color-darkest);background:var(--color-surface);border-radius:50%}.icon-picker__preview{width:56px;height:56px;border-radius:22%;box-shadow:var(--shadow-toggle)}.icon-picker__label{font-size:.75rem;line-height:1.2;text-align:center;color:var(--color-text)}.pwa-install{margin-top:4px}.pwa-install__btn{width:100%;padding:12px 16px;border:none;border-radius:var(--radius);background:var(--color-darkest);color:#fff;font-size:1rem;font-weight:600;cursor:pointer}.pwa-install__btn:hover{background:var(--color-darkest-hover)}.pwa-install__btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.pwa-install__status{margin:0;font-size:.875rem;line-height:1.45;color:var(--color-muted)}.pwa-install__status--success{color:var(--color-duty)}.pwa-install__steps{margin:0;padding-left:1.25rem;font-size:.875rem;line-height:1.55;color:var(--color-text)}.pwa-install__steps li+li{margin-top:8px}.pwa-install__ios-icon{font-size:1.1em}.support-page__toolbar{margin-bottom:16px}.support-page__toolbar .btn{width:100%}.support-page__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.support-page__card{display:block;padding:14px 16px;border-radius:var(--radius);background:var(--color-surface);border:1px solid var(--color-input-border);text-decoration:none;color:inherit}.support-page__card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;font-size:.8125rem;color:var(--color-muted)}.support-page__card-head--admin{align-items:flex-start}.support-page__card-meta{flex:1;min-width:0}.support-page__author-name{margin:0 0 4px;font-size:.9375rem;font-weight:600;color:var(--color-text)}.support-page__preview{margin:0;font-size:.9375rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.support-page__empty{margin:0;font-size:.9375rem;color:var(--color-muted);line-height:1.5}.support-page__status{flex-shrink:0;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.support-page__status--open{background:var(--color-status-approved-bg);color:var(--color-status-approved-text)}.support-page__status--closed{background:var(--color-muted-bg);color:var(--color-muted)}.support-page__create-form{display:flex;flex-direction:column;gap:12px}.support-page__label{font-size:.875rem;font-weight:500}.support-page__textarea{width:100%;padding:12px;border:1px solid var(--color-input-border);border-radius:var(--radius);font:inherit;resize:vertical;min-height:120px;background:var(--color-surface);color:var(--color-text)}.support-thread-page{display:flex;flex-direction:column}.support-thread-page .subpage-header{flex-shrink:0}.support-thread-page__messages{flex:1;list-style:none;margin:0;padding:16px 0;display:flex;flex-direction:column;gap:12px;overflow-y:auto;min-height:200px}.support-thread-page__message{display:flex;gap:10px;align-items:flex-start}.support-thread-page__message--mine{flex-direction:row-reverse}.support-thread-page__bubble{max-width:85%;padding:10px 12px;border-radius:var(--radius);background:var(--color-muted-bg)}.support-thread-page__message--mine .support-thread-page__bubble{background:var(--color-darkest);color:var(--color-surface)}.support-thread-page__message--mine .support-thread-page__author,.support-thread-page__message--mine .support-thread-page__time{color:var(--color-surface);opacity:.85}.support-thread-page__message--admin:not(.support-thread-page__message--mine) .support-thread-page__bubble{border:1px solid var(--color-input-border)}.support-thread-page__author{margin:0 0 4px;font-size:.75rem;font-weight:600;color:var(--color-muted)}.support-thread-page__avatar-btn{display:inline-flex;flex-shrink:0;padding:0;border:none;border-radius:50%;background:none;cursor:pointer}.support-thread-page__avatar-btn:hover{opacity:.85}.support-thread-page__avatar-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.support-thread-page__author-btn{display:block;margin:0 0 4px;padding:0;border:none;background:none;font:inherit;font-size:.75rem;font-weight:600;color:var(--color-muted);text-align:left;cursor:pointer;text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .15s ease}.support-thread-page__author-btn:hover{text-decoration-color:currentColor}.support-thread-page__author-btn:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px;border-radius:2px}.support-thread-page__message--mine .support-thread-page__author-btn{color:var(--color-surface);opacity:.85}.support-thread-page__message--mine .support-thread-page__author-btn:hover{opacity:1}.support-thread-page__body{margin:0;font-size:.9375rem;line-height:1.45;white-space:pre-wrap;word-break:break-word}.support-thread-page__time{display:block;margin-top:6px;font-size:.6875rem;color:var(--color-muted)}.support-thread-page__admin-actions{margin-bottom:12px}.support-thread-page__admin-actions .btn{width:100%}.support-thread-page__closed-hint{margin:0 0 16px;font-size:.875rem;color:var(--color-muted);text-align:center}.support-thread-page__composer{flex-shrink:0;display:flex;flex-direction:column;gap:10px;padding-top:12px;border-top:1px solid var(--color-input-border)}.support-thread-page__input{width:100%;padding:12px;border:1px solid var(--color-input-border);border-radius:var(--radius);font:inherit;resize:none;background:var(--color-surface);color:var(--color-text)}.support-thread-page__composer .btn{width:100%}.app-shell:has(.chat-page--telegram),.app-shell:has(.chat-room--telegram){display:flex;flex-direction:column;height:100dvh;max-height:100dvh;overflow:hidden;padding-left:0;padding-right:0}.app-shell:has(.chat-page--telegram) .app-shell__main,.app-shell:has(.chat-room--telegram) .app-shell__main{padding-bottom:0}.app-shell:has(.chat-page--telegram) .app-shell__main-scroll,.app-shell:has(.chat-room--telegram) .app-shell__main-scroll{display:flex;flex-direction:column;overflow:hidden}.app-shell:has(.chat-room--telegram) .app-shell__footer{display:none}.chat-page--telegram,.chat-room--telegram{--chat-wallpaper: color-mix(in srgb, var(--color-muted-bg) 88%, var(--color-duty) 12%);--chat-bubble-in: var(--color-surface);--chat-bubble-out: color-mix(in srgb, var(--color-duty-bg) 70%, var(--color-surface));--chat-accent: var(--color-darkest);--chat-tick-pending: color-mix(in srgb, var(--color-duty) 45%, var(--color-muted));--chat-tick-read: #2aabee;display:flex;flex-direction:column;flex:1;min-height:0;width:100%;background:var(--color-surface)}.chat-page--telegram{margin:0;padding:0}.chat-page__header,.chat-room__header{display:flex;align-items:center;gap:8px;flex-shrink:0;padding:8px 12px;min-height:56px;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.chat-page__back,.chat-room__back{display:flex;flex-shrink:0;padding:8px;margin:-8px 0 -8px -8px;text-decoration:none;line-height:0;color:var(--chat-accent);border-radius:50%;transition:background var(--transition-fast)}.chat-page__back:hover,.chat-room__back:hover{background:var(--color-list-row-hover)}.chat-page__title,.chat-room__title{flex:1;min-width:0;margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-page__header-actions{display:flex;gap:4px;flex-shrink:0}.chat-page__icon-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;border:none;border-radius:50%;background:transparent;color:var(--chat-accent);cursor:pointer;transition:background var(--transition-fast)}.chat-page__icon-btn:hover{background:var(--color-list-row-hover)}.chat-page__icon-btn:focus-visible{outline:2px solid var(--chat-accent);outline-offset:2px}.chat-page__list{list-style:none;margin:0;padding:0;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.chat-page__row{display:flex;align-items:center;gap:12px;padding:10px 14px;text-decoration:none;color:inherit;border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);cursor:pointer}.chat-page__row:hover{background:var(--color-list-row-hover)}.chat-page__row:focus-visible{outline:2px solid var(--chat-accent);outline-offset:-2px}.chat-page__row-avatar{flex-shrink:0}.chat-page__row-body{flex:1;min-width:0}.chat-page__row-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.chat-page__row-title{font-weight:600;font-size:1rem;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-page__row--unread .chat-page__row-title{font-weight:700}.chat-page__row-time{flex-shrink:0;font-size:.75rem;color:var(--color-muted)}.chat-page__row--unread .chat-page__row-time{color:var(--chat-accent)}.chat-page__row-bottom{display:flex;align-items:center;gap:8px;margin-top:2px}.chat-page__row-preview{flex:1;min-width:0;margin:0;font-size:.875rem;color:var(--color-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-page__row--unread .chat-page__row-preview{color:var(--color-text);font-weight:500}.chat-page__unread{flex-shrink:0;min-width:22px;height:22px;padding:0 6px;border-radius:11px;font-size:.75rem;font-weight:600;line-height:22px;text-align:center;background:var(--chat-accent);color:var(--color-on-accent, #fff)}.chat-page__group-icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:color-mix(in srgb,var(--chat-accent) 18%,var(--color-muted-bg));color:var(--chat-accent)}.chat-page__empty,.chat-page__error{margin:var(--space-lg) 16px;text-align:center;font-size:.875rem;color:var(--color-muted)}.chat-page__contacts{list-style:none;margin:0;padding:0;max-height:50vh;overflow-y:auto}.chat-page__contact-row{display:flex;align-items:center;gap:12px;width:100%;padding:12px 0;border:none;border-bottom:1px solid var(--color-border);background:transparent;font:inherit;font-weight:500;text-align:left;cursor:pointer;transition:background var(--transition-fast)}.chat-page__contact-row:hover{background:var(--color-list-row-hover)}.chat-page__list--skeleton .chat-page__skeleton-row{height:72px;margin:0 14px;border-bottom:1px solid var(--color-border);background:linear-gradient(90deg,var(--color-muted-bg) 0%,var(--color-list-row-hover) 50%,var(--color-muted-bg) 100%);background-size:200% 100%;animation:chat-skeleton-pulse 1.2s ease-in-out infinite}@media(prefers-reduced-motion:reduce){.chat-page__list--skeleton .chat-page__skeleton-row{animation:none}}@keyframes chat-skeleton-pulse{0%,to{background-position:100% 0}50%{background-position:0 0}}.chat-room--telegram{margin:0;padding:0}.chat-room__header-main{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.chat-room__header-text{min-width:0;flex:1}.chat-room__header-avatar-btn{display:inline-flex;flex-shrink:0;padding:0;border:none;border-radius:50%;background:none;cursor:pointer}.chat-room__header-avatar-btn:hover .avatar--image{opacity:.88}.chat-room__header-avatar-btn:focus-visible{outline:2px solid var(--chat-accent);outline-offset:2px}.chat-room__title-btn{display:block;width:100%;margin:0;padding:0;border:none;background:none;font:inherit;font-size:1.125rem;font-weight:600;color:var(--color-text);text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.chat-room__title-btn:hover{text-decoration:underline}.chat-room__title-btn:focus-visible{outline:2px solid var(--chat-accent);outline-offset:2px}.chat-room__subtitle{margin:0;font-size:.8125rem;font-weight:400;color:var(--chat-accent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-room__subtitle--typing{font-style:italic}.chat-room__body-wrap{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;background:var(--chat-wallpaper);background-image:radial-gradient(circle at 20% 30%,color-mix(in srgb,var(--chat-accent) 6%,transparent) 0%,transparent 45%),radial-gradient(circle at 80% 70%,color-mix(in srgb,var(--color-duty) 8%,transparent) 0%,transparent 40%)}.chat-room__loading,.chat-room__error{padding:16px;text-align:center;font-size:.875rem;color:var(--color-muted)}.chat-room__messages{flex:1;list-style:none;margin:0;padding:8px 10px 12px;overflow-y:auto;-webkit-overflow-scrolling:touch}.chat-room__messages-top{list-style:none;display:flex;flex-direction:column;align-items:center;gap:4px;min-height:0}.chat-room__messages-spinner{font-size:.75rem;color:var(--color-muted);padding:4px 0 2px}.chat-room__messages-sentinel{width:100%;height:1px;flex-shrink:0;pointer-events:none;opacity:0}.chat-room__day-group{list-style:none}.chat-room__date-badge{display:table;margin:12px auto;padding:4px 12px;border-radius:999px;font-size:.75rem;font-weight:500;color:var(--color-muted);background:color-mix(in srgb,var(--color-surface) 85%,transparent);box-shadow:0 1px 2px #0f172a0f}.chat-room__day-messages{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}.chat-room__message{display:flex;align-items:flex-end;gap:8px;max-width:100%}.chat-room__message--mine{justify-content:flex-end}.chat-room__avatar-spacer,.chat-room__avatar-placeholder,.chat-room__avatar-btn{flex-shrink:0;width:36px}.chat-room__avatar-btn{display:inline-flex;padding:0;border:none;border-radius:50%;background:none;cursor:pointer}.chat-room__avatar-btn:focus-visible{outline:2px solid var(--chat-accent);outline-offset:2px}.chat-room__message-stack{display:flex;flex-direction:column;align-items:flex-start;max-width:min(82%,320px);min-width:0}.chat-room__message--mine .chat-room__message-stack{align-items:flex-end}.chat-room__bubble{position:relative;display:block;width:100%;max-width:100%;margin:0;padding:8px 10px 6px;border:none;border-radius:12px 12px 12px 4px;background:var(--chat-bubble-in);box-shadow:0 1px 1px #0f172a0f;text-align:left;font:inherit;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent}.chat-room__bubble:focus-visible{outline:2px solid var(--chat-accent);outline-offset:2px}.chat-room__message--mine .chat-room__bubble{border-radius:12px 12px 4px;background:var(--chat-bubble-out);box-shadow:0 1px 1px #0f172a0a}.chat-room__bubble--deleted{cursor:default}.chat-room__body--deleted,.chat-room__reply-quote--deleted .chat-room__reply-quote-body{font-style:italic;opacity:.72}.chat-room__author-btn{display:block;margin:0 0 2px;padding:0;border:none;background:none;font:inherit;font-size:.8125rem;font-weight:600;color:var(--chat-accent);text-align:left;cursor:pointer}.chat-room__author-btn:hover{text-decoration:underline}.chat-room__reply-quote{display:flex;flex-direction:column;gap:2px;margin:0 0 6px;padding:4px 8px 4px 10px;border-left:3px solid var(--chat-accent);border-radius:0 6px 6px 0;background:color-mix(in srgb,var(--chat-accent) 8%,transparent);text-align:left}.chat-room__message--mine .chat-room__reply-quote{background:color-mix(in srgb,var(--chat-accent) 10%,var(--chat-bubble-out))}.chat-room__reply-quote-author{font-size:.8125rem;font-weight:600;color:var(--chat-accent);line-height:1.25}.chat-room__reply-quote-body{font-size:.8125rem;line-height:1.3;color:var(--color-text-muted, var(--color-text));opacity:.85;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-room__reply-quote--composer{flex:1;min-width:0;margin:0;padding:0 0 0 10px;background:transparent}.chat-room__reply-quote--clickable{cursor:pointer}.chat-room__reply-quote--clickable:hover{opacity:.9}.chat-room__reply-quote--clickable:focus-visible{outline:2px solid var(--chat-accent);outline-offset:2px;border-radius:4px}.chat-room__message--highlight .chat-room__bubble{animation:chat-message-highlight 1.8s ease-out}@keyframes chat-message-highlight{0%,25%{box-shadow:0 0 0 2px color-mix(in srgb,var(--chat-accent) 55%,transparent)}to{box-shadow:0 1px 1px #0f172a0f}}.chat-room__message--mine.chat-room__message--highlight .chat-room__bubble{animation-name:chat-message-highlight-mine}@keyframes chat-message-highlight-mine{0%,25%{box-shadow:0 0 0 2px color-mix(in srgb,var(--chat-accent) 55%,transparent)}to{box-shadow:0 1px 1px #0f172a0a}}.chat-room__reply-bar{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:10px;background:var(--color-muted-bg)}.chat-room__reply-bar-close{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:36px;height:36px;padding:0;border:none;border-radius:50%;background:transparent;color:var(--color-text-muted, var(--color-text));cursor:pointer}.chat-room__reply-bar-close:hover{background:color-mix(in srgb,var(--color-text) 8%,transparent)}.chat-room__reply-bar-close:focus-visible{outline:2px solid var(--chat-accent);outline-offset:2px}.chat-room__reply-bar--edit{justify-content:space-between}.chat-room__edit-bar-label{flex:1;min-width:0;font-size:.875rem;font-weight:600;color:var(--chat-accent)}.chat-room__edited{font-size:.6875rem;color:var(--color-text-muted, var(--color-text));opacity:.75;margin-right:4px}.chat-room__bubble-row{display:flex;flex-direction:column;align-items:flex-end;gap:2px;line-height:1.4}.chat-room__body{align-self:stretch;margin:0;font-size:.9375rem;line-height:1.4;white-space:pre-wrap;word-break:break-word;color:var(--color-text)}.chat-room__bubble-footer{display:flex;align-items:flex-end;justify-content:space-between;gap:6px;align-self:stretch;width:100%;min-height:11px}.chat-room__meta{display:inline-flex;align-items:center;flex-wrap:nowrap;justify-content:flex-end;gap:3px;flex-shrink:0;margin-left:auto;min-height:11px;-webkit-user-select:none;user-select:none}.chat-room__time{font-size:.6875rem;line-height:11px;color:var(--color-muted);opacity:.85;white-space:nowrap}.chat-room__message--mine .chat-room__time{color:var(--chat-tick-pending);opacity:1}.chat-room__ticks{display:inline-flex;align-items:center;flex-shrink:0;color:var(--chat-tick-pending);line-height:0}.chat-room__ticks--double{height:11px;overflow:visible}.chat-room__ticks-icon{display:block;flex-shrink:0}.chat-room__ticks-icon path{fill:none;stroke:currentColor;stroke-width:1.65;stroke-linecap:round;stroke-linejoin:round}.chat-room__ticks--read{color:var(--chat-tick-read)}.chat-room__reactions--corner{display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;align-self:flex-end;gap:2px;margin:0;flex:0 1 auto;min-width:0}.chat-room__reactions--corner .chat-room__reaction-chip{padding:4px 10px 4px 6px;gap:5px;min-height:30px;font-size:.8125rem;line-height:1;background:var(--color-surface);border:1px solid color-mix(in srgb,var(--color-border) 85%,transparent);box-shadow:0 1px 4px #0f172a1f}.chat-room__reactions--corner .chat-room__reaction-chip--mine{background:color-mix(in srgb,var(--chat-accent) 14%,var(--color-surface));box-shadow:0 1px 4px #0f172a1a}.chat-room__reactions--corner .chat-room__reaction-emoji{font-size:1.25rem;line-height:1}.chat-room__reactions--corner .chat-room__reaction-count{font-size:.8125rem;font-weight:600}.chat-room__reaction-chip--direct{padding:4px 8px 4px 5px;gap:6px}.chat-room__reaction-avatars{display:inline-flex;align-items:center;flex-direction:row-reverse;padding-left:2px}.chat-room__reaction-avatar.avatar{width:22px;height:22px;font-size:.5625rem;border:none;margin-left:-7px}.chat-room__reaction-avatars .chat-room__reaction-avatar.avatar:first-child{margin-left:0}.chat-room__reaction-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border:1px solid color-mix(in srgb,var(--color-border) 80%,transparent);border-radius:999px;background:var(--color-surface);font-size:.8125rem;line-height:1.2;cursor:pointer}.chat-room__reaction-chip--mine{border-color:color-mix(in srgb,var(--chat-accent) 45%,var(--color-border));background:color-mix(in srgb,var(--chat-accent) 12%,var(--color-surface))}.chat-room__reaction-count{font-size:.75rem;font-weight:600;color:var(--color-muted)}.chat-message-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200}.chat-message-overlay__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:none;padding:0;background:#0f172a66;cursor:pointer}.chat-message-overlay__card{position:fixed;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;width:auto;max-width:none;background:transparent;box-shadow:none;overflow:visible;transform-origin:top center}.chat-message-overlay__emoji-panel,.chat-message-overlay__menu-panel{width:max-content;max-width:min(100vw - 24px,100%);border-radius:12px;background:var(--color-surface);box-shadow:0 8px 32px #0f172a2e;overflow:hidden}.chat-message-overlay__emoji-grid{display:flex;flex-wrap:nowrap;align-items:center;justify-content:center;gap:2px;padding:6px 8px}.chat-message-overlay__emoji-grid--expanded{flex-wrap:wrap;justify-content:flex-start;max-width:280px}.chat-message-overlay__emoji-btn,.chat-message-overlay__emoji-more{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:8px;background:transparent;font-size:1.375rem;line-height:1;cursor:pointer}.chat-message-overlay__emoji-btn:hover,.chat-message-overlay__emoji-more:hover{background:var(--color-muted-bg)}.chat-message-overlay__emoji-btn--picked{animation:chat-emoji-pick-pop .12s ease-out forwards}@keyframes chat-emoji-pick-pop{0%{transform:scale(1)}to{transform:scale(1.35)}}.chat-reaction-fly{position:fixed;z-index:300;font-size:1.75rem;line-height:1;pointer-events:none;will-change:transform}.chat-room__bubble--reaction-landed{overflow:hidden;animation:chat-reaction-bubble-hit .36s ease-out}@keyframes chat-reaction-bubble-hit{0%{transform:scale(1)}18%{transform:scale(.96)}42%{transform:scale(1.025)}to{transform:scale(1)}}.chat-reaction-hit-effects{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;overflow:hidden;border-radius:inherit}.chat-reaction-hit-flash{position:absolute;left:var(--hit-x);top:var(--hit-y);width:28px;height:28px;border-radius:50%;transform:translate(-50%,-50%) scale(.2);background:radial-gradient(circle,color-mix(in srgb,var(--chat-accent) 38%,transparent) 0%,transparent 72%);animation:chat-reaction-hit-flash .22s ease-out forwards}.chat-reaction-ripple{position:absolute;left:var(--hit-x);top:var(--hit-y);width:14px;height:14px;border-radius:50%;border:2px solid color-mix(in srgb,var(--chat-accent) 50%,transparent);background:color-mix(in srgb,var(--chat-accent) 14%,transparent);transform:translate(-50%,-50%) scale(.12);opacity:.65;animation:chat-reaction-ripple-wave .52s ease-out forwards}.chat-room__message--mine .chat-reaction-hit-flash{background:radial-gradient(circle,color-mix(in srgb,var(--color-darkest) 28%,transparent) 0%,transparent 72%)}.chat-room__message--mine .chat-reaction-ripple{border-color:color-mix(in srgb,var(--color-darkest) 42%,transparent);background:color-mix(in srgb,var(--color-darkest) 12%,transparent)}@keyframes chat-reaction-hit-flash{0%{transform:translate(-50%,-50%) scale(.15);opacity:.85}to{transform:translate(-50%,-50%) scale(2.2);opacity:0}}@keyframes chat-reaction-ripple-wave{0%{transform:translate(-50%,-50%) scale(.12);opacity:.7}to{transform:translate(-50%,-50%) scale(5.5);opacity:0}}@media(prefers-reduced-motion:reduce){.chat-message-overlay__emoji-btn--picked{animation:none}.chat-reaction-fly{display:none}.chat-room__bubble--reaction-landed{animation:none;overflow:visible}.chat-reaction-hit-effects{display:none}}.chat-message-overlay__emoji-more{color:var(--color-muted)}.chat-message-overlay__actions{list-style:none;margin:0;padding:0;width:max-content;min-width:100%}.chat-message-overlay__action{display:block;width:100%;box-sizing:border-box;white-space:nowrap;padding:12px 16px;border:none;border-bottom:1px solid var(--color-border);background:none;font:inherit;font-size:.9375rem;text-align:left;color:var(--color-text);cursor:pointer}.chat-message-overlay__action:last-child{border-bottom:none}.chat-message-overlay__action:hover:not(:disabled){background:var(--color-muted-bg)}.chat-message-overlay__action--meta{font-size:.8125rem;color:var(--color-muted);cursor:default}.chat-message-overlay__action--danger{color:#e53935}.chat-room__toast{position:fixed;left:50%;bottom:calc(80px + var(--safe-bottom));z-index:210;transform:translate(-50%);padding:10px 16px;border-radius:8px;background:color-mix(in srgb,var(--color-text) 92%,transparent);color:var(--color-surface);font-size:.875rem;pointer-events:none}.chat-room__composer{flex-shrink:0;display:flex;flex-wrap:wrap;align-items:flex-end;gap:8px;padding:8px 10px max(8px,var(--safe-bottom));border-top:1px solid var(--color-border);background:var(--color-surface)}.chat-room__composer-row{display:flex;align-items:flex-end;gap:6px;width:100%;min-width:0}.chat-room__attach,.chat-room__composer-menu-btn{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:40px;height:44px;padding:0;border:none;border-radius:50%;background:transparent;color:var(--color-text-muted, var(--color-text));cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast)}.chat-room__attach:hover:not(:disabled),.chat-room__composer-menu-btn:hover:not(:disabled){color:var(--chat-accent);background:var(--color-muted-bg)}.chat-room__attach:disabled,.chat-room__composer-menu-btn:disabled{opacity:.45;cursor:not-allowed}.chat-room__composer-menu{position:relative;flex-shrink:0}.chat-room__composer-menu-popover{position:absolute;left:0;bottom:calc(100% + 8px);z-index:20;min-width:168px;padding:4px 0;border-radius:12px;background:var(--color-surface);box-shadow:0 8px 32px #0f172a2e;border:1px solid var(--color-border)}.chat-room__composer-menu-item{display:flex;align-items:center;gap:12px;width:100%;box-sizing:border-box;padding:10px 14px;border:none;background:transparent;color:var(--color-text);font-size:.9375rem;text-align:left;cursor:pointer;transition:background var(--transition-fast)}.chat-room__composer-menu-item:hover:not(:disabled){background:var(--color-muted-bg)}.chat-room__composer-menu-item:disabled{opacity:.45;cursor:not-allowed}.chat-room__attachment-preview-strip{display:flex;flex-wrap:wrap;gap:8px;width:100%;padding:0 2px 4px}.chat-room__attachment-preview{position:relative;width:72px;height:72px;border-radius:10px;overflow:hidden;background:var(--color-muted-bg)}.chat-room__attachment-preview-img{width:100%;height:100%;object-fit:cover;display:block}.chat-room__attachment-preview-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;padding:0;border:none;border-radius:50%;background:color-mix(in srgb,var(--color-text) 72%,transparent);color:#fff;font-size:1rem;line-height:1;cursor:pointer}.chat-room__attachments{position:relative;flex-shrink:0;margin-bottom:4px;max-width:min(280px,72vw);border-radius:10px;overflow:hidden}.chat-room__attachments--album{max-width:min(280px,72vw)}.chat-room__attachment-link{display:block;padding:0;border:none;border-radius:10px;overflow:hidden;line-height:0;background:transparent;cursor:pointer;font:inherit;color:inherit}.chat-room__attachment-link:focus-visible{outline:2px solid var(--chat-accent);outline-offset:2px}.chat-room__attachment-link--cell{position:absolute;border-radius:0}.chat-room__attachment-overflow{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,#000 48%,transparent);color:#fff;font-size:1.25rem;font-weight:600;line-height:1;pointer-events:none}.chat-room__attachment-img{display:block;width:100%;height:auto;max-width:100%;border-radius:10px}.chat-room__attachment-img--cover{width:100%;height:100%;object-fit:cover;border-radius:0}.chat-room__attachment-preview-media{width:100%;height:100%}.chat-room__attachment-preview-media--video{position:relative}.chat-room__attachment-preview-play{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.125rem;text-shadow:0 1px 6px rgba(0,0,0,.45);pointer-events:none}.chat-room__upload-progress{width:100%;height:4px;border-radius:999px;overflow:hidden;background:color-mix(in srgb,var(--color-text) 10%,transparent)}.chat-room__upload-progress-bar{display:block;height:100%;border-radius:inherit;background:var(--chat-accent);transition:width .18s ease-out}.chat-room__videos{display:flex;flex-direction:column;gap:6px;margin-bottom:4px}.chat-room__video-link{display:block;padding:0;border:none;background:transparent;cursor:pointer;border-radius:10px;overflow:hidden;line-height:0}.chat-room__video-link:focus-visible{outline:2px solid var(--chat-accent);outline-offset:2px}.chat-room__video-poster-wrap{position:relative;display:block;width:100%}.chat-room__video-poster{display:block;width:100%;height:auto;max-height:320px;object-fit:cover;border-radius:10px}.chat-room__video-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:color-mix(in srgb,#000 45%,transparent);color:#fff;font-size:1.125rem;line-height:1;pointer-events:none}.chat-room__video-duration{position:absolute;right:8px;bottom:8px;padding:2px 6px;border-radius:6px;background:color-mix(in srgb,#000 55%,transparent);color:#fff;font-size:.75rem;line-height:1.2;pointer-events:none}.chat-media-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:250;display:flex;flex-direction:column;background:#000000eb;color:#fff}.chat-media-lightbox__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;border:none;padding:0;background:transparent;cursor:pointer}.chat-media-lightbox__header{position:relative;z-index:2;display:flex;align-items:center;gap:12px;flex-shrink:0;padding:max(10px,var(--safe-top)) 12px 10px;padding-left:max(12px,var(--safe-left));padding-right:max(12px,var(--safe-right));background:linear-gradient(to bottom,rgba(0,0,0,.55),transparent)}.chat-media-lightbox__meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.chat-media-lightbox__author{font-size:.9375rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-media-lightbox__time{font-size:.75rem;opacity:.75}.chat-media-lightbox__counter{flex-shrink:0;font-size:.8125rem;font-weight:500;opacity:.85}.chat-media-lightbox__close{flex-shrink:0;width:44px;height:44px;border:none;border-radius:50%;background:#ffffff1f;color:#fff;font-size:1.75rem;line-height:1;cursor:pointer}.chat-media-lightbox__close:hover{background:#fff3}.chat-media-lightbox__close:focus-visible{outline:2px solid #fff;outline-offset:2px}.chat-media-lightbox__viewport{position:relative;z-index:1;flex:1;min-height:0;overflow:hidden;touch-action:none;cursor:grab}.chat-media-lightbox__viewport--dragging{cursor:grabbing}.chat-media-lightbox__track{display:flex;height:100%;width:100%;will-change:transform}.chat-media-lightbox__slide{flex:0 0 100%;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:8px max(8px,var(--safe-left)) max(8px,var(--safe-bottom)) max(8px,var(--safe-right));box-sizing:border-box}.chat-media-lightbox__img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none}.chat-media-lightbox__video{display:block;max-width:100%;max-height:100%;width:auto;height:auto;background:#000;border-radius:8px}.chat-media-lightbox__nav{position:absolute;top:50%;z-index:3;transform:translateY(-50%);width:44px;height:72px;border:none;background:#00000059;color:#fff;font-size:2rem;line-height:1;cursor:pointer;opacity:.85}.chat-media-lightbox__nav:hover{opacity:1;background:#00000080}.chat-media-lightbox__nav:focus-visible{outline:2px solid #fff;outline-offset:2px}.chat-media-lightbox__nav--prev{left:max(0px,var(--safe-left));border-radius:0 8px 8px 0}.chat-media-lightbox__nav--next{right:max(0px,var(--safe-right));border-radius:8px 0 0 8px}.chat-room__composer-field{position:relative;flex:1;min-width:0;display:flex;align-items:stretch;border:1px solid var(--color-input-border);border-radius:22px;background:var(--color-muted-bg);transition:border-color var(--transition-fast),background var(--transition-fast)}.chat-room__composer-field:focus-within{border-color:var(--chat-accent);background:var(--color-surface)}.chat-room__input{display:block;width:100%;min-height:44px;max-height:120px;padding:10px 48px 10px 14px;border:none;border-radius:22px;font:inherit;font-size:.9375rem;line-height:1.35;resize:none;background:transparent;color:var(--color-text)}.chat-room__input:focus{outline:none}.chat-room__send{position:absolute;right:4px;bottom:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;width:36px;height:36px;padding:0;border:none;border-radius:50%;background:var(--chat-accent);color:var(--color-on-accent, #fff);cursor:pointer;transition:opacity var(--transition-fast),background var(--transition-fast)}.chat-room__send:hover:not(:disabled){background:var(--color-darkest-hover, var(--chat-accent))}.chat-room__send:disabled{opacity:.45;cursor:not-allowed}.chat-room__send svg{width:18px;height:18px}.chat-room__send:focus-visible{outline:2px solid var(--chat-accent);outline-offset:2px}.chat-room__composer-error{width:100%;margin:0}.chat-member-select{list-style:none;margin:0 0 var(--space-md);padding:0;max-height:40vh;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-xs)}.chat-member-select__row{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font:inherit;text-align:left;cursor:pointer;transition:background var(--transition-fast)}.chat-member-select__row:hover{background:var(--color-list-row-hover)}.chat-member-select__row--selected{border-left:3px solid var(--color-darkest);padding-left:9px}.chat-member-select__name{flex:1;font-weight:500}.chat-member-select__check{font-size:.6875rem;font-weight:600;color:var(--color-darkest)}.chat-create-group{display:flex;flex-direction:column;gap:var(--space-sm)}.chat-create-group__label{margin:0;font-size:.8125rem;font-weight:600;color:var(--color-muted)}.chat-create-group__input{width:100%;padding:12px;border:1px solid var(--color-input-border);border-radius:var(--radius);font:inherit;background:var(--color-surface);color:var(--color-text)}.profile-modal__actions{margin-bottom:var(--space-md)}.profile-modal__actions .btn{width:100%;min-height:44px}.duty-swaps-page .form-message{margin-bottom:12px}.duty-swaps-page__tabs{display:flex;padding:4px;gap:4px;margin-bottom:20px;background:var(--color-secondary-bg);border-radius:var(--radius)}.duty-swaps-page__tab{flex:1;min-height:44px;padding:0 12px;border:none;border-radius:calc(var(--radius) - 4px);background:transparent;color:var(--color-primary);font:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.duty-swaps-page__tab:focus-visible{outline:2px solid var(--color-darkest);outline-offset:2px}.duty-swaps-page__tab--active{background:var(--color-surface);color:var(--color-darkest);box-shadow:var(--shadow-toggle)}.duty-swaps-page__empty{margin:8px 0 0;padding:36px 20px;text-align:center;color:var(--color-muted);font-size:.95rem;line-height:1.5;border-radius:var(--radius);background:var(--color-muted-bg);border:1px dashed color-mix(in srgb,var(--color-border) 85%,transparent)}.duty-swaps-page__list{display:flex;flex-direction:column;gap:12px}.duty-swaps-page__card{background:var(--color-surface);border:1px solid color-mix(in srgb,var(--color-border) 80%,transparent);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.duty-swaps-page__card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.duty-swaps-page__card-head time{flex-shrink:0;font-size:.8125rem;color:var(--color-muted);white-space:nowrap;line-height:1.5}.duty-swaps-page__status{flex-shrink:1;min-width:0;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;line-height:1.35}.duty-swap-status--pending_counterparty,.duty-swap-status--pending_admin{background:var(--color-status-pending-bg);color:var(--color-status-pending-text)}.duty-swap-status--approved{background:var(--color-duty-bg);color:var(--color-duty)}.duty-swap-status--rejected_counterparty,.duty-swap-status--rejected_admin{background:var(--color-incomplete-bg);color:var(--color-incomplete)}.duty-swap-status--cancelled{background:var(--color-muted-bg);color:var(--color-muted)}.duty-swaps-page__participants{margin:0 0 14px;padding-bottom:14px;border-bottom:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);font-size:1rem;font-weight:700;color:var(--color-primary);text-align:center;letter-spacing:.01em}.duty-swaps-page__slots{list-style:none;margin:0 0 14px;padding:0;display:flex;flex-direction:column;gap:8px}.duty-swaps-page__slots li{position:relative;margin:0;padding:10px 12px 10px 38px;border-radius:var(--radius-sm);background:var(--color-muted-bg);font-size:.9375rem;line-height:1.45}.duty-swaps-page__slots li:before{content:"";position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;border-radius:50%;background:var(--color-surface);box-shadow:var(--shadow-toggle)}.duty-swaps-page__slots li:first-child:before{box-shadow:inset 0 0 0 2px var(--color-darkest),var(--shadow-toggle)}.duty-swaps-page__slots li:last-child:before{box-shadow:inset 0 0 0 2px var(--color-duty),var(--shadow-toggle)}.duty-swaps-page__reason{margin:0 0 10px;font-size:.9rem;line-height:1.5;color:var(--color-text)}.duty-swaps-page__reason strong{color:var(--color-muted);font-weight:600}.duty-swaps-page__note{margin:0 0 10px;padding:10px 12px;border-radius:var(--radius-sm);background:color-mix(in srgb,var(--color-status-pending-bg) 35%,var(--color-muted-bg));border-left:3px solid var(--color-darkest);font-size:.875rem;line-height:1.45;color:var(--color-text)}.duty-swaps-page__note strong{color:var(--color-muted);font-weight:600}.duty-swaps-page__card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid color-mix(in srgb,var(--color-border) 70%,transparent)}.duty-swaps-page__card-actions .btn{flex:1;min-width:calc(50% - 4px)}.duty-swaps-page__card-actions .btn:only-child{min-width:100%}.duty-swap-modal{display:flex;flex-direction:column;gap:16px}.duty-swap-modal__field{display:flex;flex-direction:column;gap:8px}.duty-swap-modal__label{font-weight:600;font-size:.9rem}.duty-swap-modal__select,.duty-swap-modal__textarea,.duty-swap-modal__date{width:100%;box-sizing:border-box;min-height:44px;padding:10px 12px;border:1px solid var(--color-input-border);border-radius:var(--radius);font:inherit;background:var(--color-surface);color:var(--color-text)}.duty-swap-modal__select-wrap{position:relative}.duty-swap-modal__select-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.duty-swap-modal__select-wrap--open .duty-swap-modal__select-trigger{border-color:var(--color-darkest);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-darkest) 18%,transparent)}.duty-swap-modal__select-value{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.duty-swap-modal__select-value--placeholder{color:var(--color-muted)}.duty-swap-modal__select-chevron{flex-shrink:0;color:var(--color-muted);transition:transform .25s cubic-bezier(.34,1.56,.64,1),color var(--transition-fast)}.duty-swap-modal__select-wrap--open .duty-swap-modal__select-chevron{transform:rotate(180deg);color:var(--color-darkest)}.duty-swap-modal__select-list{position:absolute;z-index:20;top:calc(100% + 6px);left:0;right:0;margin:0;padding:6px;list-style:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);box-shadow:var(--shadow),0 10px 28px #0f172a24;max-height:min(240px,40vh);overflow-y:auto;overflow-x:hidden;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-8px) scale(.97);transform-origin:top center;transition:opacity .22s cubic-bezier(.22,1,.36,1),transform .22s cubic-bezier(.22,1,.36,1),visibility .22s}.duty-swap-modal__select-wrap--open .duty-swap-modal__select-list{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0) scale(1)}.duty-swap-modal__select-option{display:block;width:100%;padding:10px 12px;border:none;border-radius:6px;background:transparent;font:inherit;font-size:.9375rem;text-align:left;color:var(--color-text);cursor:pointer;opacity:0;transform:translateY(-6px);transition:background var(--transition-fast),color var(--transition-fast),opacity .18s ease,transform .18s ease;transition-delay:0ms}.duty-swap-modal__select-wrap--open .duty-swap-modal__select-option{opacity:1;transform:translateY(0);transition-delay:calc(var(--option-index, 0) * 35ms + 45ms)}.duty-swap-modal__select-option:hover{background:var(--color-list-row-hover)}.duty-swap-modal__select-option--selected{background:var(--color-list-row-selected);font-weight:600;color:var(--color-darkest)}.duty-swap-modal__select-option:focus-visible{outline:2px solid var(--color-darkest);outline-offset:-2px}.modal__body:has(.duty-swap-modal__select-wrap--open){overflow:visible}.duty-swap-modal__textarea{min-height:auto;resize:vertical}.duty-swap-modal__fixed-slot{margin:0;padding:10px 12px;border-radius:8px;background:var(--color-muted-bg);font-size:.9375rem}.duty-swap-modal__actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.duty-swap-modal__success{margin:0 0 16px}.onboarding-modal__lead{margin:0 0 12px;color:var(--color-muted);font-size:.9375rem}.updates-page__version{margin:0 0 20px;font-size:.9375rem;color:var(--color-muted)}.updates-page__list{display:flex;flex-direction:column;gap:16px}.release-card{padding:16px;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface)}.release-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.release-card__title{margin:0 0 4px;font-size:1.0625rem;color:var(--color-primary)}.release-card__meta{margin:0;font-size:.8125rem;color:var(--color-muted)}.release-card__badge{flex-shrink:0;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;background:var(--color-duty-bg);color:var(--color-duty)}.release-card__list{margin:0;padding-left:1.25rem;font-size:.9375rem;line-height:1.5}.release-card__list li+li{margin-top:6px}.achievement-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.achievement-list__item{display:flex;gap:12px;align-items:flex-start;padding:12px;border-radius:var(--radius);background:var(--color-muted-bg)}.achievement-list__icon{font-size:1.75rem;line-height:1}.achievement-list__title{margin:0 0 4px;font-weight:600;color:var(--color-primary)}.achievement-list__desc{margin:0;font-size:.875rem;color:var(--color-muted)}.layout-stack{display:flex;flex-direction:column;gap:var(--space-md);min-width:0}.layout-cluster{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:flex-end;min-width:0}.layout-auto-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(12rem,1fr));gap:var(--space-md);min-width:0}.layout-safe{width:100%;min-width:0;max-width:100%}
