*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--red:#e63946;--red-light:#ff6b75;--bg:#fafafa;--surface:#fff;--border:#dbdbdb;--text:#262626;--text-secondary:#8e8e8e;--text-muted:#c7c7c7;--nav-height:60px;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px);--max-width:430px}html,body,#root{width:100%;height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}#root{justify-content:center;display:flex}.app-container{width:100%;max-width:var(--max-width);background:var(--bg);flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}.main-content{padding-bottom:calc(var(--nav-height) + var(--safe-bottom));padding-top:var(--safe-top);-webkit-overflow-scrolling:touch;flex:1;overflow:hidden auto}.bottom-nav{width:100%;max-width:var(--max-width);height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--surface);border-top:1px solid var(--border);z-index:100;align-items:flex-start;padding-top:8px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:2px;padding:4px 0;transition:color .15s;display:flex}.nav-item.active{color:var(--red)}.nav-icon{justify-content:center;align-items:center;display:flex}.nav-label{font-size:10px;font-weight:500}.page{min-height:100%}.page-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.app-title{letter-spacing:-.5px;color:var(--red);font-size:20px;font-weight:800}.icon-btn{cursor:pointer;color:var(--text);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:background .15s;display:flex}.icon-btn:active{background:var(--bg)}.dienste-section{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 0}.stories-row{scrollbar-width:none;gap:8px;padding:0 12px;display:flex;overflow-x:auto}.stories-row::-webkit-scrollbar{display:none}.story-item{flex-direction:column;align-items:center;gap:4px;min-width:76px;display:flex}.story-ring{background:var(--border);border-radius:50%;justify-content:center;align-items:center;width:66px;height:66px;padding:3px;display:flex}.story-username{color:var(--text);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:72px;font-size:11px;font-weight:500;overflow:hidden}.story-duty{align-items:center;gap:3px;display:flex}.duty-emoji{font-size:12px}.duty-name{color:var(--text);font-size:10px;font-weight:700}.notify-btn{cursor:pointer;opacity:.55;background:0 0;border:none;padding:2px 4px;font-size:15px;line-height:1;transition:opacity .15s,transform .15s}.notify-btn:active{opacity:1;transform:scale(1.25)}.avatar{object-fit:cover;color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex;overflow:hidden}.section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;padding:14px 16px 6px;font-size:12px;font-weight:700}.balance-scroll{scrollbar-width:none;gap:10px;padding:0 16px 12px;display:flex;overflow-x:auto}.balance-scroll::-webkit-scrollbar{display:none}.balance-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:2px;min-width:130px;padding:12px;display:flex}.balance-card__header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.balance-card__name{color:var(--text);font-size:13px;font-weight:600}.balance-card__amount{font-size:22px;font-weight:800;line-height:1}.balance-card__amount.positive{color:#2dd4bf}.balance-card__amount.negative{color:var(--red)}.balance-card__label{color:var(--text-secondary);margin-top:2px;font-size:10px}.totals-bar{background:var(--surface);border-bottom:1px solid var(--border);gap:0;padding:14px 16px;display:flex}.total-item{flex-direction:column;flex:1;gap:2px;display:flex}.total-item+.total-item{border-left:1px solid var(--border);padding-left:16px}.total-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:700}.total-value{font-size:24px;font-weight:800;line-height:1}.total-value.green{color:#2dd4bf}.total-value.red{color:var(--red)}.form-group{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.form-label{color:var(--text);font-size:13px;font-weight:600}.form-input{border:1.5px solid var(--border);background:var(--surface);width:100%;color:var(--text);-webkit-appearance:none;border-radius:10px;outline:none;padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .15s}.form-input:focus{border-color:var(--red)}.form-input::placeholder{color:var(--text-muted)}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;padding:13px;font-family:inherit;font-size:15px;font-weight:600;transition:opacity .15s,transform .1s;display:flex}.btn:active{opacity:.85;transform:scale(.98)}.btn--primary{background:var(--red);color:#fff}.btn--secondary{background:var(--bg);color:var(--text);border:1.5px solid var(--border)}.btn--ghost{color:var(--red);background:0 0}.btn:disabled{opacity:.45;cursor:not-allowed}.modal-overlay{z-index:200;background:#00000080;justify-content:center;align-items:flex-end;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{width:100%;max-width:var(--max-width);background:var(--surface);padding:12px 20px calc(24px + var(--safe-bottom));border-radius:20px 20px 0 0;max-height:90dvh;animation:.25s slideUp;overflow-y:auto}.modal-handle{background:var(--border);border-radius:2px;width:40px;height:4px;margin:0 auto 16px}.modal--keyboard{flex-direction:column;transition:transform .15s,max-height .15s;display:flex;padding-bottom:0!important}.modal-scroll-body{-webkit-overflow-scrolling:touch;flex:1;padding:0 0 12px;overflow-y:auto}.modal-sticky-actions{padding:12px 0 calc(16px + var(--safe-bottom));background:var(--surface);flex-shrink:0;gap:8px;display:flex}.modal-title{text-align:center;margin-bottom:16px;font-size:17px;font-weight:700}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes birthdayPop{0%{opacity:0;transform:scale(.85)}60%{opacity:1;transform:scale(1.03)}to{opacity:1;transform:scale(1)}}@keyframes birthdayGlow{0%,to{box-shadow:0 0 #f472b659}50%{box-shadow:0 0 0 10px #f472b600}}@keyframes birthdayFloat{0%,to{transform:translateY(0)rotate(-8deg)}50%{transform:translateY(-8px)rotate(8deg)}}.birthday-banner{text-align:center;background:linear-gradient(135deg,#ffe4e6 0%,#fce7f3 50%,#fef3c7 100%);border:1px solid #fbcfe8;border-radius:16px;margin:12px 16px 0;padding:18px 16px 16px;animation:.5s cubic-bezier(.34,1.56,.64,1) birthdayPop,2.6s ease-in-out .5s infinite birthdayGlow;position:relative;overflow:hidden}.birthday-floaters{justify-content:center;gap:14px;margin-bottom:6px;display:flex}.birthday-floater{font-size:26px;animation:2.4s ease-in-out infinite birthdayFloat;display:inline-block}.auth-screen{background:var(--surface);flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.auth-logo{margin-bottom:6px;font-size:52px}.auth-title{color:var(--red);letter-spacing:-1px;margin-bottom:4px;font-size:30px;font-weight:800}.auth-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:32px;font-size:14px;line-height:1.5}.auth-form{flex-direction:column;gap:4px;width:100%;max-width:360px;display:flex}.auth-switch{text-align:center;color:var(--text-secondary);margin-top:16px;font-size:14px}.auth-switch button{color:var(--red);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:14px;font-weight:700}.avatar-upload{cursor:pointer;flex-direction:column;align-items:center;gap:8px;margin-bottom:12px;display:flex}.avatar-upload-circle{background:var(--bg);border:2px dashed var(--border);border-radius:50%;justify-content:center;align-items:center;width:84px;height:84px;font-size:30px;transition:border-color .15s;display:flex;position:relative;overflow:hidden}.avatar-upload-circle:hover{border-color:var(--red)}.avatar-upload-circle img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.avatar-upload-label{color:var(--text-secondary);font-size:12px}.chat-page{height:calc(100dvh - var(--nav-height) - var(--safe-bottom));flex-direction:column;display:flex}.chat-messages{-webkit-overflow-scrolling:touch;-webkit-user-select:none;user-select:none;flex-direction:column;flex:1;gap:6px;padding:12px 16px;display:flex;overflow-y:auto}.chat-message{align-items:flex-end;gap:8px;max-width:82%;display:flex}.chat-message--own{flex-direction:row-reverse;align-self:flex-end;margin-left:auto}.chat-message--other{align-self:flex-start}.chat-bubble-wrap{flex-direction:column;gap:2px;display:flex}.chat-bubble{word-break:break-word;border-radius:18px;padding:9px 13px;font-size:14px;line-height:1.45}.chat-message--other .chat-bubble{background:var(--bg);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:5px}.chat-message--own .chat-bubble{background:var(--red);color:#fff;border-bottom-right-radius:5px}.chat-sender{color:var(--text-secondary);font-size:11px;font-weight:600}.chat-message--own .chat-sender{text-align:right}.chat-time{color:var(--text-muted);white-space:nowrap;align-self:flex-end;padding-bottom:2px;font-size:10px}.chat-input-bar{background:var(--surface);border-top:1px solid var(--border);align-items:center;gap:8px;padding:10px 16px;display:flex}.chat-input{border:1.5px solid var(--border);background:var(--bg);color:var(--text);border-radius:22px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:15px;transition:border-color .15s}.chat-input:focus{border-color:var(--red)}.chat-send-btn{background:var(--red);cursor:pointer;color:#fff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:opacity .15s;display:flex}.chat-send-btn:disabled{opacity:.4}.todo-add-bar{background:var(--surface);border-bottom:1px solid var(--border);z-index:5;gap:8px;padding:10px 16px;display:flex;position:sticky;top:0}.todo-add-bar .form-input{margin-bottom:0}.todo-item{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:14px 16px;animation:.2s fadeIn;display:flex}.todo-checkbox{border:2px solid var(--border);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;transition:all .15s;display:flex}.todo-checkbox.checked{background:var(--red);border-color:var(--red);color:#fff}.todo-text{color:var(--text);flex:1;font-size:15px;line-height:1.4}.todo-text.done{color:var(--text-muted);text-decoration:line-through}.todo-meta{color:var(--text-muted);white-space:nowrap;font-size:11px}.todo-delete{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;padding:4px;transition:color .15s;display:flex}.todo-delete:active{color:var(--red)}.calendar-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.calendar-table{border-collapse:collapse;width:100%;min-width:300px}.calendar-table th{background:var(--bg);text-align:left;color:var(--text-secondary);text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 8px;font-size:11px;font-weight:700}.calendar-table td{border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 8px;font-size:13px}.calendar-table tr.current-week td{background:#e6394612;font-weight:700}.settings-section{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:16px}.settings-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.settings-row:last-child{border-bottom:none}.settings-row-label{color:var(--text);font-size:15px}.settings-row-value{color:var(--text-secondary);font-size:14px}.toggle{flex-shrink:0;width:50px;height:28px;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{background:var(--border);cursor:pointer;border-radius:28px;transition:background .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.toggle input:checked+.toggle-slider{background:var(--red)}.toggle input:checked+.toggle-slider:before{transform:translate(22px)}.expense-form{background:var(--surface);border-bottom:1px solid var(--border);padding:16px}.expense-form-row{align-items:flex-start;gap:10px;display:flex}.split-chips{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.split-chip{border:1.5px solid var(--border);cursor:pointer;color:var(--text);background:0 0;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:flex}.split-chip.selected{border-color:var(--red);color:var(--red);background:#e6394614}.expense-item{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:13px 16px;display:flex}.expense-item__info{flex-direction:column;flex:1;gap:2px;display:flex}.expense-item__desc{color:var(--text);font-size:14px;font-weight:600}.expense-item__meta{color:var(--text-secondary);font-size:12px}.expense-item__amount{color:var(--text);font-size:16px;font-weight:700}.spinner{border:3px solid var(--border);border-top-color:var(--red);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{color:var(--text-secondary);flex-direction:column;align-items:center;gap:8px;padding:48px 24px;display:flex}.empty-state-icon{font-size:44px}.empty-state-text{text-align:center;font-size:14px;line-height:1.5}.error-text{color:var(--red);text-align:center;padding:8px;font-size:13px}.profile-header{background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;align-items:center;gap:8px;padding:28px 16px 20px;display:flex}.profile-name{color:var(--text);font-size:18px;font-weight:700}.profile-email{color:var(--text-secondary);font-size:13px}.toast{top:calc(20px + var(--safe-top));background:var(--text);color:#fff;z-index:999;white-space:nowrap;pointer-events:none;border-radius:20px;padding:10px 18px;font-size:14px;font-weight:500;animation:.25s toastIn,.25s 2.5s forwards toastOut;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0003}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}.story-ring--done{background:linear-gradient(135deg,#2dd4bf,#10b981)}.story-ring--overdue{background:linear-gradient(135deg,#f59e0b,#f97316)}.story-ring--absent{background:0 0;border:2.5px dashed #94a3b8}.done-btn{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:12px;align-items:center;gap:4px;padding:4px 8px;font-family:inherit;font-size:11px;font-weight:600;transition:all .15s;display:flex}.done-btn:active{opacity:.7}.done-btn--done{color:#2dd4bf;background:#2dd4bf14;border-color:#2dd4bf}.notify-btn-card{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:12px;align-items:center;gap:4px;padding:4px 8px;font-family:inherit;font-size:11px;font-weight:600;transition:all .15s;display:flex}.notify-btn-card:active{border-color:var(--red);color:var(--red)}.monthly-results{background-color:#dfc49a;background-image:radial-gradient(circle at 20% 30%,#643c1417 1.5px,#0000 1.5px),radial-gradient(circle at 70% 60%,#643c140f 1px,#0000 1px),radial-gradient(circle at 50% 80%,#643c1412 2px,#0000 2px);background-size:18px 18px,12px 12px,22px 22px;border:3px solid #b8905a;border-radius:16px;margin:12px 16px;padding-bottom:12px;overflow:hidden;box-shadow:inset 0 2px 8px #0000001f,0 2px 6px #0000001a}.mr-month{color:#3b1f08;text-align:center;letter-spacing:-.3px;text-shadow:0 1px 2px #ffffff4d;padding:16px 16px 8px;font-size:14px;font-weight:800}.mr-podium{justify-content:center;align-items:flex-end;gap:6px;padding:8px 16px 0;display:flex}.mr-podium-slot{flex-direction:column;flex:1;align-items:center;max-width:110px;display:flex}.mr-podium-avatars{filter:drop-shadow(0 2px 4px #00000026);flex-wrap:wrap;justify-content:center;gap:3px;margin-bottom:3px;display:flex}.mr-podium-names{color:#3b1f08;text-align:center;text-shadow:0 1px 2px #fff6;flex-direction:column;gap:1px;margin-bottom:2px;font-size:12px;font-weight:700;display:flex}.mr-podium-count{color:#5c3d1e;text-shadow:0 1px 1px #ffffff4d;margin-bottom:5px;font-size:10px}.mr-podium-bar{flex-direction:column;justify-content:flex-start;align-items:center;gap:2px;width:100%;padding-top:10px;display:flex}.mr-podium-medal{font-size:22px;line-height:1}.mr-podium-rank{color:#00000073;font-size:14px;font-weight:800}.mr-ground{opacity:.5;filter:url(#sketchy-podium);background:#7a5530;border-radius:3px;height:5px;margin:0 16px}.mr-rest{border-top:1px solid var(--border);margin-top:10px;padding:4px 0}.mr-rest-row{align-items:center;gap:8px;padding:8px 16px;display:flex}.mr-rest-avatars{gap:3px;display:flex}.mr-rest-rank{min-width:24px;color:var(--text-secondary);font-size:14px;font-weight:700}.mr-rest-names{color:var(--text);flex:1;font-size:14px;font-weight:600}.weekly-feedback{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:4px}.wf-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:11px 16px;display:flex}.wf-row:last-child{border-bottom:none}.wf-status{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.wf-status.done{color:#fff;background:#2dd4bf}.wf-status.pending{background:var(--red);color:#fff}.wf-info{flex-direction:column;gap:1px;display:flex}.wf-name{color:var(--text);font-size:14px;font-weight:600}.wf-duty{color:var(--text-secondary);font-size:12px}.mr-rest-count{color:var(--text-secondary);font-size:13px}.todo-tabs{background:var(--surface);border-bottom:1px solid var(--border);display:flex}.todo-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2.5px solid #0000;flex:1;justify-content:center;align-items:center;gap:6px;padding:12px;font-family:inherit;font-size:14px;font-weight:600;transition:all .15s;display:flex}.todo-tab.active{color:var(--red);border-bottom-color:var(--red)}.meal-widget{padding:0 0 8px}.meal-widget-header{justify-content:space-between;align-items:center;padding:4px 0 8px;display:flex}.meal-create-form{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:8px;padding:12px}.postit-card{background:#fffde7;border-radius:3px;flex-direction:column;gap:8px;padding:20px 14px 14px;display:flex;position:relative;box-shadow:2px 3px 10px #00000026,0 1px 2px #00000014}.postit-tape{background:#ffeb64b3;border-radius:2px;width:50px;height:22px;position:absolute;top:-10px;left:50%;transform:translate(-50%)rotate(-2deg);box-shadow:0 1px 3px #0000001a}.postit-header{align-items:baseline;gap:10px;display:flex}.postit-time{color:var(--text);white-space:nowrap;cursor:pointer;border-radius:4px;padding:2px 4px;font-size:15px;font-weight:800;transition:background .15s}.postit-time:hover{background:#0000000f}.postit-title{color:var(--text);border-radius:4px;flex:1;padding:2px 4px;font-size:15px;font-weight:700;transition:background .15s}.postit-title.editable{cursor:pointer}.postit-title.editable:hover{background:#0000000f}.postit-rsvp{gap:8px;display:flex}.rsvp-btn{border:1.5px solid var(--border);cursor:pointer;color:var(--text-secondary);background:0 0;border-radius:20px;align-items:center;gap:4px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s;display:flex}.rsvp-btn:disabled{opacity:.4;cursor:default}.rsvp-btn--yes.active{color:#2dd4bf;background:#2dd4bf1a;border-color:#2dd4bf}.rsvp-btn--no.active{border-color:var(--red);color:var(--red);background:#e639461a}.postit-attendees{flex-wrap:wrap;gap:6px;display:flex}.postit-attendee{color:var(--text-secondary);align-items:center;gap:4px;font-size:12px;display:flex}.postit-desc{color:var(--text);cursor:pointer;border-radius:4px;min-height:28px;padding:4px;font-size:13px;line-height:1.5;transition:background .15s}.postit-desc.editable:hover{background:#0000000d}.postit-placeholder{color:var(--text-muted);font-style:italic}.postit-amount{color:#2e7d32;cursor:pointer;border-radius:4px;align-items:center;gap:5px;padding:4px;font-size:13px;font-weight:600;transition:background .15s;display:flex}.postit-amount.editable:hover{background:#0000000d}.postit-inline-input{color:var(--text);background:#fffc;border:1.5px solid #00000026;border-radius:4px;outline:none;padding:3px 7px;font-family:inherit;font-size:13px}.postit-inline-input:focus{border-color:var(--red)}.postit-divider{background:#00000014;height:1px;margin:2px 0}.postit-toggle{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:6px;padding:2px 0;font-family:inherit;font-size:12px;font-weight:600;display:flex}.postit-toggle:last-of-type{margin-bottom:2px}.postit-comments,.postit-shopping{flex-direction:column;gap:6px;padding:4px 0 6px;display:flex}.postit-comment{align-items:flex-start;gap:8px;display:flex}.postit-comment-body{flex-direction:column;gap:1px;display:flex}.postit-comment-author{color:var(--text-secondary);font-size:11px;font-weight:700}.postit-comment-text{color:var(--text);font-size:13px;line-height:1.4}.postit-add-row{align-items:center;gap:6px;margin-top:2px;display:flex}.postit-add-btn{background:var(--red);cursor:pointer;color:#fff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.postit-add-btn:disabled{opacity:.4}.postit-shop-item{align-items:center;gap:8px;display:flex}.postit-delete{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;gap:5px;margin-top:2px;padding:4px 0 0;font-family:inherit;font-size:12px;transition:color .15s;display:flex}.postit-delete:hover{color:var(--red)}.cal-page{flex-direction:column;height:100%;min-height:100%;display:flex}.cal-body{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex:1;overflow-y:auto}.cal-modal{flex-direction:column;max-height:92dvh;padding:12px 0 0;display:flex;overflow:hidden}.cal-modal .modal-handle{margin-bottom:0}.cal-tabs{border-bottom:1px solid var(--border);flex-shrink:0;margin-bottom:0;display:flex}.cal-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2.5px solid #0000;flex:1;padding:10px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.cal-tab.active{color:var(--red);border-bottom-color:var(--red)}.cal-nav{flex-shrink:0;align-items:center;gap:4px;padding:10px 12px;display:flex}.cal-view-toggle{background:var(--bg);border-radius:8px;margin-right:8px;padding:2px;display:flex}.cal-view-toggle button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.cal-view-toggle button.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #0000001a}.cal-nav-label{text-align:center;color:var(--text);flex:1;font-size:14px;font-weight:700}.cal-add-btn{background:var(--red);cursor:pointer;color:#fff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:opacity .15s;display:flex}.cal-add-btn:active{opacity:.8}.cal-month{flex-shrink:0;padding:0 12px}.cal-weekdays{grid-template-columns:repeat(7,1fr);margin-bottom:4px;display:grid}.cal-weekdays span{text-align:center;color:var(--text-secondary);padding:4px 0;font-size:11px;font-weight:700}.cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cal-day{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;align-items:center;min-height:40px;padding:4px 2px;transition:background .15s;display:flex}.cal-day:active{background:var(--bg)}.cal-day.other-month .cal-day-num{color:var(--text-muted)}.cal-day.today .cal-day-num{background:var(--red);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.cal-day.selected{background:#e6394614}.cal-day-num{color:var(--text);font-size:13px;font-weight:500;line-height:1}.cal-day-dots{gap:2px;height:5px;margin-top:3px;display:flex}.cal-dot{border-radius:50%;width:5px;height:5px}.cal-week{flex-shrink:0;padding:0 12px}.cal-week-row{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:flex-start;gap:10px;width:100%;padding:8px 6px;font-family:inherit;transition:background .15s;display:flex}.cal-week-row.today{background:#e639460f}.cal-week-row.selected{background:#e639461a}.cal-week-label{flex-direction:column;align-items:center;min-width:32px;display:flex}.cal-week-dow{color:var(--text-secondary);font-size:11px;font-weight:600}.cal-week-num{color:var(--text);border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;font-weight:700;display:flex}.cal-week-num.today{background:var(--red);color:#fff}.cal-week-events{flex-wrap:wrap;flex:1;align-items:center;gap:4px;min-height:30px;display:flex}.cal-week-empty{color:var(--text-muted);font-size:12px}.cal-week-bars{flex-shrink:0;align-items:stretch;gap:4px;display:flex}.cal-week-bar{border-radius:6px;flex-direction:column;align-items:center;gap:3px;width:32px;min-height:44px;padding:4px 2px;display:flex;overflow:hidden}.cal-week-bar-text{writing-mode:vertical-rl;text-orientation:mixed;text-overflow:ellipsis;white-space:nowrap;max-height:70px;font-size:10px;font-weight:700;line-height:1.2;overflow:hidden}.cal-week-pill{white-space:nowrap;text-overflow:ellipsis;border:1px solid;border-radius:10px;max-width:160px;padding:3px 8px;font-size:11px;font-weight:600;overflow:hidden}.cal-selected{border-top:1px solid var(--border);-webkit-overflow-scrolling:touch;flex:1;margin-top:8px;padding:0 16px 24px;overflow-y:auto}.cal-selected-header{justify-content:space-between;align-items:center;padding:10px 0 8px;display:flex}.cal-selected-date{color:var(--text);font-size:14px;font-weight:700}.cal-create-form{background:var(--bg);border:1px solid var(--border);border-radius:12px;margin-bottom:10px;padding:12px}.cal-type-toggle{gap:8px;margin-bottom:10px;display:flex}.cal-type-toggle button{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:7px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.cal-type-toggle button.active{border-color:var(--red);color:var(--red);background:#e6394612}.cal-personal-event{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 0;display:flex}.cal-personal-dot{background:#457b9d;border-radius:50%;flex-shrink:0;width:8px;height:8px}.cal-personal-title{color:var(--text);flex:1;font-size:14px;font-weight:600}.cal-personal-author{color:var(--text-secondary);font-size:12px}.onboarding-card{background:var(--surface);border:1.5px solid var(--border);cursor:pointer;text-align:left;border-radius:14px;align-items:center;gap:16px;width:100%;padding:18px 20px;font-family:inherit;transition:all .15s;display:flex}.onboarding-card:active{border-color:var(--red);background:#e639460a;transform:scale(.98)}.onboarding-card-icon{flex-shrink:0;font-size:32px;line-height:1}.onboarding-card-title{color:var(--text);font-size:16px;font-weight:700}.onboarding-card-sub{color:var(--text-secondary);margin-top:2px;font-size:13px}.settings-back-header{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;margin-bottom:0;padding:10px 12px 4px;display:flex}.corkboard{background-color:#c8a97e;background-image:radial-gradient(circle at 20% 30%,#643c141f 1.5px,#0000 1.5px),radial-gradient(circle at 70% 60%,#643c1414 1px,#0000 1px),radial-gradient(circle at 50% 80%,#643c141a 2px,#0000 2px);background-size:18px 18px,12px 12px,22px 22px;border:3px solid #a0784a;border-radius:16px;margin:12px 16px;padding:12px 12px 16px;box-shadow:inset 0 2px 8px #0000002e,0 2px 6px #0000001f}.corkboard-title{color:#5c3d1e;text-align:center;letter-spacing:.3px;margin-bottom:8px;font-size:13px;font-weight:700}.corkboard-grid{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.corkboard-card{background:#fffde7;border-radius:3px;flex-direction:column;align-items:center;gap:3px;width:68px;padding:8px 6px;transition:transform .15s;display:flex;position:relative;box-shadow:2px 3px 8px #00000038,0 1px 2px #0000001a}.corkboard-card--done{background:#f1fff6}.corkboard-card--miss{background:#fff8f8}.corkboard-pin{z-index:1;background:radial-gradient(circle at 35% 35%,#ff6b6b,#c0392b);border-radius:50%;width:12px;height:12px;position:absolute;top:-8px;left:50%;transform:translate(-50%);box-shadow:0 1px 3px #0000004d}.corkboard-duty-emoji{font-size:17px;line-height:1}.corkboard-duty-name{color:#555;text-align:center;font-size:9px;font-weight:700}.corkboard-person-name{color:#333;text-align:center;white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:10px;font-weight:600;overflow:hidden}.corkboard-status{border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;margin-top:1px;display:flex}.corkboard-status.done{color:#fff;background:#2dd4bf}.corkboard-status.miss{color:#fff;background:#e63946}.duty-streak-badge{color:#c2410c;white-space:nowrap;background:#fff7ed;border:1px solid #fdba74;border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:700;animation:.4s cubic-bezier(.34,1.56,.64,1) birthdayPop;display:inline-flex}.corkboard-note{text-align:center;background:#fffde7;border-radius:3px;margin:10px 4px 0;padding:10px 12px 8px;animation:.4s cubic-bezier(.34,1.56,.64,1) birthdayPop;position:relative;transform:rotate(-.8deg);box-shadow:2px 4px 10px #00000038,0 1px 2px #0000001a}.corkboard-note p{color:#166534;margin:0;font-size:12px;font-weight:700;line-height:1.4}.tutorial-overlay{background:var(--surface);z-index:300;max-width:var(--max-width);padding-top:calc(16px + var(--safe-top));padding-bottom:calc(16px + var(--safe-bottom));flex-direction:column;margin:0 auto;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.tutorial-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:0 16px 8px;display:flex}.tutorial-dots{gap:6px;display:flex}.tutorial-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:background .2s,transform .2s}.tutorial-dot.active{background:var(--red);transform:scale(1.2)}.tutorial-body{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;flex:1;min-height:0;padding:16px;display:flex;overflow-y:auto}.tutorial-content{text-align:center;width:100%;margin:auto 0}.tutorial-icon{margin-bottom:12px;font-size:52px}.tutorial-title{color:var(--text);margin-bottom:12px;font-size:22px;font-weight:800}.tutorial-text{color:var(--text-secondary);margin-bottom:16px;font-size:14px;line-height:1.6}.tutorial-subtle{color:var(--text-muted);margin-top:16px;font-size:12px;font-style:italic;line-height:1.5}.tutorial-callout{background:var(--bg);border:1px solid var(--border);text-align:left;color:var(--text);border-radius:14px;padding:14px 16px;font-size:14px;line-height:1.5}.tutorial-callout--warn{color:#92400e;background:#fffde7;border-color:#fde68a}.tutorial-browser-list{text-align:left;margin-top:20px}.tutorial-browser-list-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:5px;margin-bottom:8px;font-size:11px;font-weight:700;display:flex}.tutorial-browser-row{flex-wrap:wrap;gap:6px;margin-bottom:6px;display:flex}.tutorial-browser-ok,.tutorial-browser-no{border-radius:8px;padding:4px 8px;font-size:11px}.tutorial-browser-ok{color:#0f766e;background:#2dd4bf1f}.tutorial-browser-no{color:var(--red);background:#e6394614}.tutorial-mock-event{background:var(--bg);border:1px solid var(--border);text-align:left;border-radius:14px;padding:14px 16px}.tutorial-mock-event-date{color:var(--red);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:700}.tutorial-mock-event-title{color:var(--text);margin-bottom:10px;font-size:16px;font-weight:700}.tutorial-mock-event-avatars{gap:6px;margin-bottom:10px;display:flex}.tutorial-mock-event-feature{color:var(--text-secondary);align-items:flex-start;gap:8px;margin-top:6px;font-size:12.5px;line-height:1.5;display:flex}.tutorial-list{text-align:left;flex-direction:column;gap:10px;margin:14px 0 0;padding:0;list-style:none;display:flex}.tutorial-list li{color:var(--text-secondary);padding-left:20px;font-size:13px;line-height:1.5;position:relative}.tutorial-list li:before{content:"•";color:var(--red);font-weight:800;position:absolute;left:4px}.tutorial-list li strong{color:var(--text)}.tutorial-footer{flex-shrink:0;gap:10px;padding:8px 16px 0;display:flex}.tutorial-footer .btn{justify-content:center;align-items:center;gap:4px;display:flex}
