:root{--brand-green: #9AB878;--brand-blue: #284651;--accent: #284651;--accent-soft: #E8EFE2;--accent-green: #9AB878;--link: #284651;--bg: #FFFFFF;--bg-card: #F7F9F5;--text: #212121;--text-secondary: #6B7B73;--border: #D6DFD0;--error: #D32F2F;--error-light: #FDECEA;--font-heading: "Raleway", sans-serif;--font-body: "Open Sans", sans-serif;--radius: 12px;--radius-sm: 8px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading)}.app{width:100%;padding:0 12px;min-height:100dvh;display:flex;flex-direction:column}.app>main{flex:1}.app>main:first-child{margin-top:12px}.app-loading{display:flex;align-items:center;justify-content:center;padding:48px 20px;color:var(--text-secondary);font-size:.95rem}.app-error{text-align:center;padding:48px 20px;color:#d63031;font-size:.95rem}.footer{margin-top:24px;padding:8px 0;border-top:1px solid var(--border);font-size:12px;color:var(--text-secondary)}.footer--justified{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}.footer__user{display:inline-flex;align-items:center;gap:4px}.footer__user .avatar{font-size:9px}.footer--justified>a{margin-left:auto}.footer a{color:var(--link);text-decoration:none}.footer a:hover{text-decoration:underline}.footer-separator{margin:0 4px}.footer-logout{background:none;border:none;color:var(--link);font-size:12px;cursor:pointer;padding:0;font-family:var(--font-body)}.footer-logout:hover{text-decoration:underline}.toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background:var(--text);color:#fff;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-body);box-shadow:0 4px 12px #00000026;z-index:1000;animation:toast-in .3s ease-out;max-width:calc(100% - 32px);text-align:center}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(-12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toast--error{background:var(--error);color:#fff}.app-error__retry{display:inline-block;margin-top:12px;padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;cursor:pointer}.app-error__retry:hover{opacity:.9}.mini-calendar{display:flex;gap:4px;padding:8px 0;overflow-x:auto;-webkit-overflow-scrolling:touch}.calendar-day{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1 1 0;min-width:44px;min-height:44px;padding:6px 4px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;font-family:var(--font-body);transition:background .15s ease,border-color .15s ease}.calendar-day:hover{background:var(--accent-soft)}.calendar-day--selected{background:var(--accent);color:#fff;border-color:var(--accent)}.calendar-day--selected:hover{background:var(--accent)}.calendar-day--visible:not(.calendar-day--selected){background:var(--accent-soft);border-color:var(--accent)}.calendar-day--today{border-color:var(--accent-green);border-width:2px}.calendar-day--selected.calendar-day--today{border-color:var(--accent-green)}.calendar-day__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.02em;font-family:var(--font-heading)}.calendar-day__number{font-size:16px;font-weight:700;line-height:1.2;font-family:var(--font-heading)}.calendar-day__avatars{display:flex;align-items:center;min-height:14px}.calendar-day__avatars .avatar{font-size:7px;line-height:1;margin-left:-4px}.calendar-day__avatars .avatar:first-child{margin-left:0}.calendar-day__count{font-size:11px;font-weight:700;color:var(--text-secondary);margin-left:3px;font-family:var(--font-heading)}.calendar-day--selected .calendar-day__count{color:#ffffffd9}.calendar-day__empty{font-size:14px;color:var(--text-secondary);line-height:1}.calendar-day--selected .calendar-day__empty{color:#ffffffd9}.poll-view{container-type:inline-size;overflow:hidden}.poll-view__track{display:grid;grid-template-columns:repeat(var(--total-cols, 1),calc((100cqi + 8px) / var(--visible-cols, 1) - 8px));gap:8px;transform:translate(calc(-1 * var(--start-index, 0) * (100cqi + 8px) / var(--visible-cols, 1)));transition:transform .3s ease}@media(prefers-reduced-motion:reduce){.poll-view__track{transition:none}}.day-column{display:flex;flex-direction:column;gap:6px;overflow:hidden;min-width:0}.day-header{font-family:var(--font-heading);font-weight:600;font-size:14px;color:var(--text);padding:8px 4px 4px;border-bottom:1px solid var(--border);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.day-header--selected{background:var(--accent);color:#fff;border-bottom-color:var(--accent)}.slot-row{display:flex;flex-direction:column;padding:10px 12px;gap:4px;background:var(--bg-card);border-left:3px solid transparent;border-radius:6px;cursor:pointer;transition:border-color .2s ease,background .15s ease;-webkit-user-select:none;user-select:none}.slot-row.joined{border-left-color:var(--accent-green)}.slot-row:hover{background:var(--accent-soft)}.slot-row.toggling{opacity:.65;pointer-events:none}.slot-row.past{cursor:default;opacity:.55;pointer-events:none}.slot-row.past .slot-row__time{color:var(--text-secondary)}.slot-row.past .checkbox{border-color:var(--border);opacity:.5}.slot-row.past .checkbox.checked{background:var(--text-secondary);border-color:var(--text-secondary)}.slot-row.past .progress-bar__fill--joined{background:var(--text-secondary)}.slot-row__top{display:flex;align-items:center;gap:4px}.slot-row__time{font-family:var(--font-body);font-weight:600;font-size:15px;flex-shrink:0;z-index:5}.slot-row__avatars{flex:1;min-width:0;min-height:32px;display:flex;align-items:center;gap:0;cursor:pointer;justify-content:flex-end;-webkit-mask-image:linear-gradient(to right,transparent 0%,black 24px);mask-image:linear-gradient(to right,transparent 0%,black 24px)}.slot-row__avatars .avatar-stack{min-width:0;flex:1;justify-content:flex-end}.slot-row__expand{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:24px;flex-shrink:0;gap:0}.slot-row__count{font-family:var(--font-body);font-weight:600;font-size:12px;line-height:1;color:var(--text-secondary)}.slot-row__caret{color:var(--text-secondary);transition:transform .2s ease;flex-shrink:0}.slot-row__avatars--open .slot-row__caret{transform:rotate(180deg)}.slot-row__avatars:hover .slot-row__caret{transform:scale(1.3)}.slot-row__avatars--open:hover .slot-row__caret{transform:rotate(180deg) scale(1.3)}.checkbox{width:24px;height:24px;min-width:24px;border-radius:50%;border:2px solid var(--border);background:transparent;transition:background .15s ease-in,border-color .15s ease-in,transform .2s ease-out;cursor:pointer;display:flex;align-items:center;justify-content:center}.checkbox.checked{background:var(--accent-green);border-color:var(--accent-green);animation:checkbox-bounce .2s ease-out}@keyframes checkbox-bounce{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.checkbox .checkmark{stroke:#fff;stroke-width:2.5;stroke-dasharray:16;stroke-dashoffset:16;fill:none;transition:stroke-dashoffset .2s ease-out .1s,stroke .2s ease,stroke-opacity .2s ease}.checkbox.checked .checkmark{stroke-dashoffset:0}.slot-row:not(.past):not(.toggling):hover:not(:has(.slot-row__avatars:hover)) .checkbox:not(.checked){border-color:var(--accent-green);background:color-mix(in srgb,var(--accent-green) 15%,transparent);transform:scale(1.1)}.slot-row:not(.past):not(.toggling):not(.just-toggled):hover:not(:has(.slot-row__avatars:hover)) .checkbox:not(.checked) .checkmark{stroke:var(--accent-green);stroke-opacity:.45;stroke-dashoffset:0}.slot-row:not(.past):not(.toggling):hover:not(:has(.slot-row__avatars:hover)) .checkbox.checked{background:color-mix(in srgb,var(--accent-green) 80%,black);border-color:color-mix(in srgb,var(--accent-green) 80%,black);transform:scale(1.1)}.slot-row:not(.past):not(.toggling):not(.just-toggled):hover:not(:has(.slot-row__avatars:hover)) .checkbox.checked .checkmark{stroke-opacity:.35;stroke-dashoffset:8}.progress-bar{height:4px;border-radius:2px;background:var(--border);overflow:hidden}.progress-bar__fill{height:100%;border-radius:2px;transition:width .3s ease-out}.progress-bar__fill--joined{background:var(--accent-green)}.progress-bar__fill--default{background:var(--accent)}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:12px;font-weight:600;color:#fff;font-family:var(--font-body);flex-shrink:0;position:relative}.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-stack{display:flex;align-items:center;cursor:pointer}.avatar-stack__item{margin-left:var(--avatar-overlap, -8px)}.avatar-stack__item:first-child{margin-left:0}.slot-detail{max-height:0;overflow:hidden;transition:max-height .3s ease}.slot-detail--open{max-height:none}.slot-detail__list{display:flex;flex-direction:column;gap:6px;padding:8px 0 4px}.participant-row{display:flex;align-items:center;gap:10px;padding:4px 0}.participant-row__name{font-family:var(--font-body);font-size:14px;color:var(--text)}.participant-row__name--current{font-weight:600}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:900;padding:16px}.login-modal{background:var(--bg);border-radius:var(--radius);padding:28px 24px 24px;width:100%;max-width:400px;position:relative;box-shadow:0 8px 32px #0000002e;animation:modal-in .25s ease-out}@keyframes modal-in{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-modal__close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-secondary);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%}.login-modal__close:hover{background:var(--accent-soft)}.login-modal__header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.login-modal__title{font-family:var(--font-heading);font-size:20px;font-weight:700;margin-bottom:0;color:var(--text)}.login-modal__field{margin-bottom:14px}.login-modal__label{display:block;font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:4px}.login-modal__input{width:100%;padding:10px 12px;font-family:var(--font-body);font-size:15px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);outline:none;transition:border-color .15s ease}.login-modal__input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #2846511f}.login-modal__info-toggle{background:none;border:none;cursor:pointer;font-size:14px;color:var(--text-secondary);padding:2px 4px;margin-left:6px;vertical-align:middle}.login-modal__info-toggle:hover{color:var(--accent)}.login-modal__info-block{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease,margin .25s ease;margin-top:0;margin-bottom:0}.login-modal__info-block--open{grid-template-rows:1fr;margin-top:8px;margin-bottom:8px}.login-modal__info-block-inner{overflow:hidden;background:var(--accent-soft);border-radius:4px;padding:0 8px;font-size:12px;color:var(--text-secondary);line-height:1.6;transition:padding .25s ease}.login-modal__info-block--open .login-modal__info-block-inner{padding:8px}.login-modal__info-block a{color:var(--link)}.login-modal__avatar-row{display:flex;align-items:center;gap:10px}.login-modal__avatar-row .login-modal__input{flex:1;min-width:0}.login-modal__preview{flex-shrink:0}.login-modal__preview-error{font-size:12px;color:var(--text-secondary);margin-top:4px}.login-modal__submit{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s ease;margin-top:4px}.login-modal__submit:hover:not(:disabled){opacity:.9}.login-modal__submit:disabled{opacity:.5;cursor:not-allowed}.login-modal__checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary);cursor:pointer;margin:8px 0 4px;line-height:1.4}.login-modal__checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.toast__action{background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-sm);cursor:pointer;color:inherit;font-size:inherit;font-family:var(--font-body);text-decoration:none;padding:4px 12px;min-height:44px;display:inline-flex;align-items:center;opacity:.9;transition:background .15s ease,opacity .15s ease}.toast__action:hover{background:#ffffff40;opacity:1}.toast__separator{opacity:.5;margin:0 4px}.participant-row__ics-btn{margin-left:auto;background:none;border:none;cursor:pointer;padding:4px;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;color:var(--accent-green);opacity:.7;transition:opacity .15s ease}.participant-row__ics-btn:hover{opacity:1}.footer__ics-link{background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:12px;font-family:var(--font-body);padding:0;display:inline-flex;align-items:center;gap:2px;transition:color .15s ease}.footer__ics-link:hover{color:var(--accent)}
