*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{color:#3f3a36;background:radial-gradient(circle at top,#e8d4c6 0%,#fbf2ed 45%,#ceced7 100%);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}button,input,textarea{font:inherit}:root{--fk-bg:#fbf2ed;--fk-surface:#e8d4c6;--fk-border:#ceced7;--fk-accent:#cdeffe;--fk-text:#3f3a36;--fk-text-soft:#6d6661}.family-app{max-width:1080px;margin:28px auto;padding:16px}.family-shell{border:1px solid var(--fk-border);background:color-mix(in srgb, var(--fk-bg) 92%, white 8%);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);border-radius:14px;overflow:hidden;box-shadow:0 16px 38px #3f3a361f}.ph-topbar{border:1px solid var(--fk-border);background:#fffaf7;border-radius:12px;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:1rem 1.25rem;display:flex;box-shadow:0 4px 12px #3f3a361a}.ph-topbar-brand h1{color:var(--fk-text);margin:0;font-size:1.4rem;font-weight:700}.ph-topbar-brand p{color:var(--fk-text-soft);margin:.25rem 0 0;font-size:.875rem}.ph-topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.75rem;display:flex}.ph-user-chip{color:var(--fk-text-soft);border:1px solid var(--fk-border);white-space:nowrap;background:#f0e8e2;border-radius:999px;padding:4px 12px;font-size:.85rem}.ph-portal-btn{cursor:pointer;background:var(--fk-surface);color:var(--fk-text);border:none;border-radius:8px;justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.ph-portal-btn:hover{background:color-mix(in srgb, var(--fk-surface) 82%, #cbb3a0 18%)}.ph-action-btn{border:1px solid var(--fk-border);cursor:pointer;color:var(--fk-text-soft);background:#fffaf7;border-radius:8px;justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;display:inline-flex}.ph-action-btn:hover{background:#f5ede6}.submit-btn,.cancel-btn,.edit-btn,.delete-btn,.login-link{cursor:pointer;border:0;border-radius:10px;justify-content:center;align-items:center;padding:9px 12px;font-weight:600;text-decoration:none;display:inline-flex}.submit-btn,.login-link{background:var(--fk-surface);color:var(--fk-text)}.submit-btn:hover,.login-link:hover{background:color-mix(in srgb, var(--fk-surface) 82%, #ca473d 18%)}.family-content{display:block}.form-grid{gap:10px;display:grid}.form-grid label{color:var(--fk-text);gap:4px;font-size:.88rem;font-weight:600;display:grid}.form-grid input,.form-grid select,.form-grid textarea{border:1px solid var(--fk-border);background:#fffaf7;border-radius:9px;padding:9px 10px}.form-grid textarea{resize:vertical;min-height:80px}.optional-input-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.field-clear-btn{border:1px solid var(--fk-border);color:var(--fk-text);cursor:pointer;background:#f7efe9;border-radius:9px;padding:8px 10px;font-weight:600}.field-clear-btn:hover:not(:disabled){background:#ead9cc}.field-clear-btn:disabled{opacity:.55;cursor:not-allowed}.form-actions{gap:8px;display:flex}.submit-btn,.cancel-btn{flex:1}.cancel-btn{background:var(--fk-border);color:var(--fk-text)}.events-panel{padding:20px}.top-actions{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.top-actions .submit-btn{color:#fff;background:#ca473d}.top-actions .submit-btn:hover{background:#ae3d34}.create-menu-wrap{display:inline-flex;position:relative}.create-menu-dropdown{border:1px solid var(--fk-border);z-index:30;background:#fffaf7;border-radius:10px;gap:4px;min-width:152px;padding:6px;display:grid;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 10px 24px #3f3a362e}.create-menu-item{color:var(--fk-text);cursor:pointer;text-align:left;background:0 0;border:0;border-radius:8px;padding:9px 10px;font-size:.9rem;font-weight:600;line-height:1.2}.create-menu-item:hover,.create-menu-item:focus-visible{background:var(--fk-accent);outline:none}.events-panel h2{margin:0 0 14px}.view-switch{border:1px solid var(--fk-border);background:var(--fk-bg);border-radius:12px;gap:6px;margin-bottom:12px;padding:4px;display:inline-flex}.view-btn{cursor:pointer;color:var(--fk-text);background:0 0;border:0;border-radius:8px;padding:7px 12px;font-weight:600}.view-btn.active{background:var(--fk-accent);color:var(--fk-text)}.view-btn:hover{background:var(--fk-surface)}.view-btn.active:hover{background:color-mix(in srgb, var(--fk-accent) 82%, #b5dfe9 18%)}.month-nav{justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.month-nav h2{text-transform:capitalize;margin:0}.date-jump-wrap{flex-direction:column;align-items:flex-start;display:inline-flex;position:relative}.month-label-btn{border:1px solid var(--fk-border);background:var(--fk-bg);color:var(--fk-text);text-transform:capitalize;cursor:pointer;border-radius:10px;align-items:baseline;gap:4px;padding:7px 10px;font-size:1.02rem;font-weight:700;display:inline-flex}.month-label-btn:hover{background:var(--fk-accent);border-color:color-mix(in srgb, var(--fk-accent) 65%, var(--fk-border) 35%)}.month-label-btn:focus-visible{outline:2px solid color-mix(in srgb, var(--fk-accent) 65%, #79b6cd 35%);outline-offset:1px}.month-label-prefix{font-size:.92rem}.date-jump-popover{border:1px solid var(--fk-border);z-index:35;background:#fffaf7;border-radius:10px;min-width:320px;max-width:min(420px,100vw - 48px);padding:10px;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 10px 24px #3f3a362e}.date-jump-form{gap:10px;display:grid}.date-jump-fields{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.date-jump-fields label{color:var(--fk-text);gap:4px;font-size:.8rem;font-weight:600;display:grid}.date-jump-fields select{border:1px solid var(--fk-border);color:var(--fk-text);background:#fff;border-radius:8px;padding:7px 8px;font-size:.85rem}.date-jump-actions{justify-content:flex-end;gap:6px;display:flex}.date-jump-cancel,.date-jump-submit{cursor:pointer;border-radius:8px;padding:6px 10px;font-size:.82rem;font-weight:600}.date-jump-cancel{border:1px solid var(--fk-border);background:var(--fk-bg);color:var(--fk-text)}.date-jump-cancel:hover{background:color-mix(in srgb, var(--fk-bg) 84%, var(--fk-border) 16%)}.date-jump-submit{border:1px solid color-mix(in srgb, var(--fk-accent) 65%, var(--fk-border) 35%);background:var(--fk-accent);color:var(--fk-text)}.date-jump-submit:hover{background:color-mix(in srgb, var(--fk-accent) 82%, #b5dfe9 18%)}.month-nav-actions{gap:8px;display:flex}.month-nav.compact{gap:8px;margin-bottom:10px}.month-nav.compact h2,.month-nav.compact .month-label-btn{font-size:1.02rem}.month-nav.compact .month-nav-actions{gap:6px}.month-nav.compact .nav-btn{border-radius:8px;padding:6px 9px;font-size:.82rem;line-height:1.1}.month-nav-bottom{justify-content:flex-end;margin-top:10px;margin-bottom:0}.month-nav-bottom .month-nav-actions{margin-left:auto}.nav-btn{border:1px solid var(--fk-border);background:var(--fk-bg);color:var(--fk-text);cursor:pointer;border-radius:10px;padding:8px 10px;font-weight:600}.nav-btn:hover{background:var(--fk-accent);border-color:color-mix(in srgb, var(--fk-accent) 65%, var(--fk-border) 35%)}.error-box{color:#b91c1c;background:#fee2e2;border:1px solid #fecaca;border-radius:10px;margin-bottom:12px;padding:10px 12px}.info-box{color:#1e3a8a;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;margin-bottom:12px;padding:10px 12px}.empty-state{color:var(--fk-text-soft)}.month-day-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.month-days-toggle-btn{border:1px solid var(--fk-border);background:var(--fk-bg);color:var(--fk-text);cursor:pointer;border-radius:10px;margin-bottom:10px;padding:8px 10px;font-weight:600}.month-days-toggle-btn:hover{background:var(--fk-accent);border-color:color-mix(in srgb, var(--fk-accent) 65%, var(--fk-border) 35%)}.month-day-item{border:1px solid var(--fk-border);background-color:var(--fk-bg);border-radius:10px;padding:10px}.month-day-item.weekday{background:#fffaf7}.month-day-item.weekend,.month-day-item.holiday{background:var(--fk-surface);border-color:var(--fk-border)}.month-day-item.today{background:var(--fk-accent);border-color:color-mix(in srgb, var(--fk-accent) 65%, #79b6cd 35%);border-width:2px}.month-day-item.today .month-day-header{color:var(--fk-text)}.month-day-header{color:var(--fk-text);text-transform:capitalize;font-size:.92rem;font-weight:700}.month-day-header-row,.day-head-row{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.day-add-actions{gap:6px;display:inline-flex}.month-day-empty{color:var(--fk-text-soft);margin:0;font-size:.88rem}.holiday-label{color:#92400e;margin:0 0 8px;font-size:.78rem;font-weight:700}.school-holiday-hints{gap:4px;margin:0 0 8px;display:grid}.school-holiday-label{color:#1e3a8a;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;align-items:center;width:fit-content;padding:2px 8px;font-size:.78rem;line-height:1.2;display:inline-flex}.school-holiday-action{cursor:pointer;font:inherit}.week-holiday-hints{gap:8px;margin:0 0 10px;display:grid}.week-holiday-day{border:1px solid var(--fk-border);background:#fffaf7;border-radius:10px;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 10px;display:flex}.week-holiday-date{color:var(--fk-text-soft);font-size:.78rem;font-weight:700}.month-day-events{gap:8px;margin:0;padding:0;list-style:none;display:grid}.month-table-wrap{overflow-x:auto}.month-table{border-collapse:collapse;table-layout:fixed;width:100%}.month-table th,.month-table td{border:1px solid var(--fk-border);vertical-align:top}.month-table th{background:var(--fk-surface);color:var(--fk-text);text-align:left;padding:8px;font-size:.82rem;font-weight:700}.month-table td{background:#fffaf7;min-height:120px}.month-table td.out-month{background:var(--fk-bg)}.month-table td.holiday{background:var(--fk-surface)}.month-table .school-holiday-hints{gap:2px;margin:0 0 6px}.month-table .school-holiday-label{padding:1px 6px;font-size:.62rem;line-height:1.1}.month-table td.today{background:var(--fk-accent);outline:2px solid color-mix(in srgb, var(--fk-accent) 65%, #79b6cd 35%);outline-offset:-2px}.month-table td.today .day-number{color:var(--fk-text);font-size:1rem}.day-cell{flex-direction:column;gap:6px;min-height:120px;padding:8px;display:flex}.day-number{color:var(--fk-text);font-size:.85rem;font-weight:700}.add-day-btn{border:1px solid color-mix(in srgb, var(--fk-accent) 65%, var(--fk-border) 35%);background:var(--fk-accent);color:var(--fk-text);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;width:24px;height:24px;font-weight:700;line-height:1;display:inline-flex}.add-day-btn:hover{background:color-mix(in srgb, var(--fk-accent) 82%, #b5dfe9 18%)}.no-events{color:var(--fk-text-soft);font-size:.78rem}.work-location-row{border:1px solid var(--fk-border);background:#fffaf7;border-radius:8px;gap:6px;margin:6px 0;padding:6px;display:grid}.work-location-row.office{background:#f2f4f9}.work-location-row.home{background:#f3fbf1}.work-location-row.vacation{background:#fff8e6}.work-location-current{color:var(--fk-text-soft);align-items:center;gap:6px;font-size:.8rem;line-height:1.2;display:inline-flex}.work-location-note{color:var(--fk-text-soft);font-size:.74rem;line-height:1.2}.work-location-code{border:1px solid var(--fk-border);width:18px;height:18px;color:var(--fk-text-soft);background:#fff;border-radius:999px;justify-content:center;align-items:center;font-size:.68rem;font-weight:700;display:inline-flex}.work-location-code.office{color:#1e3a8a;background:#dbeafe;border-color:#93c5fd}.work-location-code.home{color:#14532d;background:#dcfce7;border-color:#86efac}.work-location-code.vacation{color:#78350f;background:#fef3c7;border-color:#fcd34d}.work-location-actions{flex-wrap:wrap;gap:6px;display:flex}.work-location-btn{border:1px solid var(--fk-border);color:var(--fk-text-soft);cursor:pointer;background:#fff;border-radius:999px;padding:2px 8px;font-size:.74rem;line-height:1.2}.work-location-btn.active{border-color:var(--fk-accent);background:color-mix(in srgb, var(--fk-accent) 35%, #fff 65%);color:var(--fk-text);font-weight:600}.work-location-btn.clear{color:#991b1b;border-color:#fecaca}.work-location-btn:disabled{opacity:.45;cursor:not-allowed}.day-events{gap:5px;margin:0;padding:0;list-style:none;display:grid}.day-event{border-radius:8px;gap:2px;padding:4px 6px;font-size:.76rem;display:grid}.day-event.family{background:var(--fk-accent);color:var(--fk-text)}.day-event.anniversary{color:#5b4522;background:#fde68a}.day-event.photo{background:var(--fk-surface);color:var(--fk-text)}.day-event-time{font-weight:700}.day-event-title{flex-wrap:wrap;align-items:center;gap:4px;line-height:1.2;display:inline-flex}.event-title-main{display:inline}.event-symbols{align-items:center;gap:4px;display:inline-flex}.event-symbol{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;font-size:.66rem;font-weight:700;line-height:1;display:inline-flex}.event-symbol.anniversary{color:#5b4522;background:#fde68a;border-color:#f5cf62}.event-symbol.weekly{color:#1e3a8a;background:#dbeafe;border-color:#93c5fd}.event-symbol.monthly{color:#14532d;background:#dcfce7;border-color:#86efac}.event-symbol.photo-status-idee,.event-symbol.photo-status-angefragt,.event-symbol.photo-status-gebucht,.event-symbol.photo-status-abgesagt{background:0 0;border:0;width:auto;height:auto;font-size:1.3rem;line-height:1}.event-symbol.photo-status-idee{color:#ca8a04}.event-symbol.photo-status-angefragt{color:#ea580c}.event-symbol.photo-status-gebucht{color:#15803d}.event-symbol.photo-status-abgesagt{color:#111827}.event-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.photo-list-view{gap:10px;display:grid}.photo-event-list{gap:12px}.event-item{border:1px solid var(--fk-border);background:#fffaf7;border-radius:10px;padding:12px}.event-item.photo{border-left:4px solid var(--fk-surface);background:color-mix(in srgb, var(--fk-surface) 40%, #fffaf7 60%)}.event-item.family{border-left:4px solid var(--fk-accent)}.event-item.anniversary{background:#fef3d2;border-left:4px solid #eab308}.event-compact-row{grid-template-columns:78px 1fr;align-items:start;gap:10px;display:grid}.event-time-col{color:var(--fk-text);font-variant-numeric:tabular-nums;gap:4px;font-size:.8rem;font-weight:700;line-height:1.25;display:grid}.event-time-start,.event-time-end{display:block}.event-text-col{gap:4px;min-width:0;display:grid}.event-title-row{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.event-title-row .event-badges{justify-content:flex-end;margin-top:0}.event-title{flex-wrap:wrap;align-items:center;gap:6px;margin:0;font-size:1rem;line-height:1.25;display:inline-flex}.event-title-btn{text-align:left;cursor:pointer;color:var(--fk-text);background:0 0;border:0;flex-wrap:wrap;align-items:center;gap:6px;margin:0;padding:0;font-size:1rem;font-weight:700;line-height:1.25;display:inline-flex}.event-title-btn:hover{color:color-mix(in srgb, var(--fk-accent) 50%, #3f3a36 50%);text-decoration:underline}.event-location{color:var(--fk-text-soft);margin:0;font-size:.88rem;line-height:1.2}.event-badges{flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:6px;margin-top:8px;display:flex}.source-badge,.creator-badge{white-space:nowrap;border-radius:999px;padding:3px 8px;font-size:.74rem}.source-badge{background:var(--fk-accent);color:var(--fk-text)}.creator-badge{background:var(--fk-bg);color:var(--fk-text-soft);border:1px solid var(--fk-border)}.source-badge.photo{background:var(--fk-surface);color:var(--fk-text)}.source-badge.anniversary{color:#5b4522;background:#fde68a}.age-badge{white-space:nowrap;color:#5b4522;background:#fde68a;border-radius:999px;padding:3px 8px;font-size:.74rem;font-weight:600}.event-meta{color:var(--fk-text);gap:5px;margin-top:8px;font-size:.84rem;display:grid}.delete-btn{color:#991b1b;background:#fee2e2}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.loading,.login-shell{border:1px solid var(--fk-border);background:#fffaf7;border-radius:12px;max-width:560px;margin:84px auto;padding:20px;box-shadow:0 8px 24px #3f3a3617}.modal-backdrop{z-index:40;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{border:1px solid var(--fk-border);background:#fffaf7;border-radius:12px;width:min(560px,100%);max-height:calc(100vh - 40px);padding:18px;overflow:auto;box-shadow:0 20px 45px #0f172a59}.modal-card h2{margin:0 0 12px;font-size:1.12rem}.modal-delete-btn{cursor:pointer;color:#991b1b;background:#fee2e2;border:0;border-radius:10px;padding:9px 12px;font-weight:600}.modal-delete-btn:hover{background:#fecaca}@media (width<=920px){.ph-topbar-actions{flex-wrap:wrap;justify-content:flex-end}.month-nav{flex-direction:column;align-items:flex-start}.month-nav.compact,.date-jump-wrap{width:100%}.month-label-btn{justify-content:space-between;width:100%}.date-jump-popover{width:min(430px,100%);min-width:0;max-width:100%}.month-nav.compact .month-nav-actions{width:100%}.month-nav.compact .nav-btn{flex:1;justify-content:center}.month-nav-bottom{margin-top:8px}.view-switch{box-sizing:border-box;justify-content:space-between;width:100%}.view-btn{text-align:center;flex:1}.month-table{min-width:760px}.event-item{padding:10px}.event-compact-row{grid-template-columns:72px 1fr;gap:8px}.event-time-col{font-size:.78rem}.event-title,.event-title-btn{font-size:.94rem}.event-location{font-size:.82rem}.source-badge,.creator-badge{padding:2px 7px;font-size:.7rem}}@media (width<=600px){.family-app{margin:18px auto;padding:10px}.events-panel{padding:14px}.month-nav{margin-bottom:10px}.date-jump-fields{grid-template-columns:1fr}.date-jump-actions{justify-content:stretch}.date-jump-cancel,.date-jump-submit{text-align:center;flex:1}.event-item{border-radius:9px;padding:8px 9px}.event-compact-row{grid-template-columns:58px 1fr;gap:6px}.event-time-col{gap:2px;font-size:.72rem;line-height:1.15}.event-text-col{gap:3px}.event-title-row{flex-direction:column;align-items:stretch;gap:4px}.event-title-row .event-badges{justify-content:flex-start;margin-top:0}.event-title,.event-title-btn{gap:5px;font-size:.9rem;line-height:1.2}.event-symbols{gap:3px}.creator-badge,.source-badge{display:none}.age-badge{padding:2px 6px;font-size:.68rem}.event-location{font-size:.78rem;line-height:1.15}.event-meta{gap:4px;margin-top:6px;font-size:.78rem}}
