:root{font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f1f5f9;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:inherit}a{color:inherit}button{font-family:inherit}:root{--glass-bg-light: linear-gradient(135deg, #eff6ff 0%, #f5fff9 100%);--glass-bg: rgba(255, 255, 255, .85);--glass-bg-hover: rgba(255, 255, 255, .95);--glass-border: rgba(148, 163, 184, .4);--glass-border-hover: rgba(148, 163, 184, .6);--glass-shadow: 0 25px 60px rgba(15, 23, 42, .12);--glass-shadow-hover: 0 30px 70px rgba(15, 23, 42, .18);--text-primary: #1f2937;--text-secondary: #4b5563;--text-tertiary: #6b7280;--glass-highlight: rgba(255, 255, 255, .8);--accent-blue: #2563eb;--accent-green: #10b981;--radius-sm: .75rem;--radius-md: 1rem;--radius-lg: 1.5rem;--radius-xl: 2rem;--blur-light: blur(10px) saturate(180%);--blur-medium: blur(15px) saturate(180%);--blur-heavy: blur(20px) saturate(180%)}.liquid-glass{background:var(--glass-bg);backdrop-filter:var(--blur-medium);-webkit-backdrop-filter:var(--blur-medium);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.liquid-glass:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6) 50%,transparent);opacity:.4;pointer-events:none}.liquid-glass:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover);box-shadow:var(--glass-shadow-hover);transform:translateY(-2px)}.liquid-glass-panel{border-radius:var(--radius-lg);padding:1.5rem}.liquid-glass-card{border-radius:var(--radius-md);padding:1.25rem}.liquid-glass-button{border-radius:var(--radius-sm);padding:.75rem 1.5rem;cursor:pointer;border:none;font-weight:600;color:var(--text-primary);transition:all .2s ease}.liquid-glass-button:hover{background:var(--glass-bg-hover);transform:translateY(-1px)}.liquid-glass-button:active{transform:translateY(0)}.liquid-glass-bg{min-height:100vh;background:var(--glass-bg-light);position:relative;overflow-x:hidden}.liquid-glass-text-primary{color:var(--text-primary)}.liquid-glass-text-secondary{color:var(--text-secondary)}.liquid-glass-text-tertiary{color:var(--text-tertiary)}@media(max-width:767px){.liquid-glass-panel{border-radius:var(--radius-md);padding:1.25rem}.liquid-glass-card{border-radius:var(--radius-sm);padding:1rem}}@keyframes glass-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.liquid-glass-animate{animation:glass-fade-in .4s cubic-bezier(.4,0,.2,1)}.liquid-glass-active{background:var(--glass-bg-hover);border-color:var(--accent-blue);box-shadow:0 0 0 4px #2563eb1a}.logo{display:flex;align-items:flex-end;gap:.5rem;color:#1f2937}.logo__title{font-size:1.6rem;font-weight:700;letter-spacing:-.01em}:root{color-scheme:light}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3rem;padding:2rem 1.5rem 4rem;background:linear-gradient(135deg,#eff6ff,#f5fff9)}.login-card{width:min(100%,420px);background:#ffffffd9;backdrop-filter:blur(10px);border-radius:1.5rem;box-shadow:0 25px 60px #0f172a1f;padding:2.5rem;display:flex;flex-direction:column;gap:1.25rem}.login-card__subtitle{color:#4b5563;font-size:.95rem;line-height:1.5;margin:0}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-form__label{font-weight:600;color:#1f2937;font-size:.95rem}.login-form__input{width:100%;padding:.75rem .9rem;border-radius:.75rem;border:1px solid rgba(148,163,184,.4);background:#fffffff2;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.login-form__input:focus-visible{outline:none;border-color:#2563ebb3;box-shadow:0 0 0 4px #2563eb33}.login-form__input:disabled{background:#e2e8f080;cursor:not-allowed}.login-form__submit{margin-top:.5rem;padding:.85rem;border-radius:.9rem;border:none;background:linear-gradient(135deg,#2563eb,#10b981);color:#fff;font-weight:600;font-size:1rem;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease}.login-form__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 15px 35px #2563eb40}.login-form__submit:disabled{opacity:.75;cursor:wait}.login-form__error{color:#dc2626;background:#f871711a;border-radius:.75rem;padding:.65rem .75rem;margin:.25rem 0 0}.login-form__success{color:#047857;background:#10b9811f;border-radius:.75rem;padding:.65rem .75rem;margin:.25rem 0 0}.login-form__success strong{font-weight:700}.login-form__logout{margin-top:.5rem;padding:.75rem;border-radius:.9rem;border:1px solid rgba(148,163,184,.6);background:#f8fafce6;color:#1f2937;font-weight:600;font-size:.95rem;cursor:pointer;transition:border-color .2s ease,background-color .2s ease}.login-form__logout:hover{border-color:#2563eb80;background:#e2e8f0cc}.login-card__footer{display:flex;justify-content:flex-end}.login-card__imprint{border:none;background:transparent;color:#2563eb;font-weight:600;cursor:pointer;padding:0;font-size:.95rem;text-decoration:none}.login-card__imprint:hover,.login-card__imprint:focus-visible{text-decoration:underline}.login-card__imprint:focus-visible{outline:none}.imprint-modal__backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:1000}.imprint-modal{width:min(100%,560px);max-height:min(90vh,640px);overflow-y:auto;background:#fffffff7;border-radius:1.25rem;box-shadow:0 25px 60px #0f172a40;padding:1.75rem 1.75rem 2rem;color:#1f2937;display:flex;flex-direction:column;gap:1.25rem}.imprint-modal__header{display:flex;justify-content:space-between;align-items:center;gap:1rem;border-bottom:1px solid rgba(148,163,184,.35);padding-bottom:.75rem}.imprint-modal__header h2{margin:0;font-size:1.3rem}.imprint-modal__close{border:none;background:#e2e8f0a6;color:#1f2937;font-size:.9rem;font-weight:600;border-radius:999px;padding:.45rem .95rem;cursor:pointer;transition:background-color .2s ease,transform .2s ease}.imprint-modal__close:hover,.imprint-modal__close:focus-visible{background:#3b82f626;transform:translateY(-1px);outline:none}.imprint-modal__content{display:flex;flex-direction:column;gap:1.1rem}.imprint-modal__section h3{margin:0 0 .25rem;font-size:1.05rem}.imprint-modal__section p{margin:.15rem 0;line-height:1.55}.imprint-modal__section a{color:#2563eb;font-weight:600}@media(max-width:600px){.login-card{padding:2rem}.logo__title{font-size:1.3rem}.logo__icon{width:2.75rem;height:2.75rem;font-size:1.1rem}}.mobile-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;padding:.75rem .5rem calc(.75rem + env(safe-area-inset-bottom));background:#ffffffd9;backdrop-filter:blur(15px) saturate(180%);-webkit-backdrop-filter:blur(15px) saturate(180%);border-top:1px solid rgba(148,163,184,.4);box-shadow:0 -4px 24px #0f172a14;z-index:1000;gap:.5rem}.mobile-nav:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6) 50%,transparent);opacity:.4;pointer-events:none}.mobile-nav__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem .75rem;border-radius:.75rem;text-decoration:none;color:#4b5563;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;min-width:60px;flex:1;max-width:120px}.mobile-nav__item:hover{background:#f8fafce6;color:#1f2937;transform:translateY(-2px)}.mobile-nav__item--active{color:#1f2937;background:#fffffff2;box-shadow:0 0 0 4px #2563eb1a;border:1px solid rgba(37,99,235,.2)}.mobile-nav__item--active:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(37,99,235,.8) 50%,transparent);border-radius:.75rem .75rem 0 0}.mobile-nav__icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:currentColor;opacity:.8;transition:all .2s ease}.mobile-nav__icon svg{width:100%;height:100%;stroke-width:2}.mobile-nav__item:hover .mobile-nav__icon{transform:scale(1.1);opacity:1}.mobile-nav__item--active .mobile-nav__icon{transform:scale(1.15);opacity:1;color:#2563eb}.mobile-nav__label{font-size:.7rem;font-weight:600;letter-spacing:.02em;text-align:center;line-height:1.2}@media(min-width:768px){.mobile-nav{display:none}}.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;display:flex;flex-direction:column;background:#ffffffd9;backdrop-filter:blur(15px) saturate(180%);-webkit-backdrop-filter:blur(15px) saturate(180%);border-right:1px solid rgba(148,163,184,.4);box-shadow:4px 0 24px #0f172a14;z-index:100;transition:width .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6) 50%,transparent);opacity:.4;pointer-events:none;z-index:1}.sidebar--collapsed{width:80px}.sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.25rem;border-bottom:1px solid rgba(148,163,184,.3);min-height:70px}.sidebar__logo{flex:1}.sidebar__logo-text{font-size:1.25rem;font-weight:700;color:#1f2937;letter-spacing:-.01em}.sidebar__toggle{width:32px;height:32px;border-radius:.5rem;border:1px solid rgba(148,163,184,.4);background:#f8fafce6;color:#4b5563;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;transition:all .2s ease;flex-shrink:0}.sidebar__toggle:hover{background:#e2e8f0cc;border-color:#2563eb80;color:#1f2937;transform:scale(1.05)}.sidebar__toggle:active{transform:scale(.95)}.sidebar--collapsed .sidebar__header{justify-content:center;padding:1.5rem .75rem}.sidebar--collapsed .sidebar__logo{display:none}.sidebar__nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;overflow-x:hidden}.sidebar__item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:.75rem;text-decoration:none;color:#4b5563;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;font-weight:500}.sidebar__item:hover{background:#f8fafce6;color:#1f2937;transform:translate(4px)}.sidebar__item--active{background:#fffffff2;color:#1f2937;box-shadow:0 0 0 4px #2563eb1a;border:1px solid rgba(37,99,235,.2)}.sidebar__item--active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:linear-gradient(180deg,transparent,rgba(37,99,235,.8) 50%,transparent);border-radius:0 2px 2px 0}.sidebar__icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:currentColor;opacity:.8;flex-shrink:0;transition:all .2s ease}.sidebar__icon svg{width:100%;height:100%;stroke-width:2}.sidebar__item:hover .sidebar__icon{transform:scale(1.1);opacity:1}.sidebar__item--active .sidebar__icon{transform:scale(1.15);opacity:1;color:#2563eb}.sidebar__label{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar--collapsed .sidebar__item{justify-content:center;padding:.875rem}.sidebar--collapsed .sidebar__label{display:none}.sidebar__footer{padding:1rem .75rem;border-top:1px solid rgba(148,163,184,.3)}.sidebar__logout{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:.75rem;border:1px solid rgba(148,163,184,.4);background:#f8fafce6;color:#4b5563;cursor:pointer;width:100%;font-size:.95rem;font-weight:500;transition:all .2s ease;font-family:inherit}.sidebar__logout:hover{background:#e2e8f0cc;border-color:#dc262680;color:#dc2626;transform:translate(4px)}.sidebar--collapsed .sidebar__logout{justify-content:center;padding:.875rem}.sidebar--collapsed .sidebar__logout .sidebar__label{display:none}@media(max-width:767px){.sidebar{display:none}}.sidebar__nav::-webkit-scrollbar{width:6px}.sidebar__nav::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.sidebar__nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar__nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.dashboard-layout{min-height:100vh;background:linear-gradient(135deg,#eff6ff,#f5fff9);position:relative;display:flex;flex-direction:column}.dashboard-layout__main{flex:1;margin-left:0;margin-bottom:0;padding:1.5rem;position:relative;z-index:1;padding-bottom:calc(80px + 1.5rem)}.dashboard-layout__content{max-width:1400px;margin:0 auto;width:100%}@media(min-width:768px){.dashboard-layout__main{margin-left:260px;padding-bottom:1.5rem;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.dashboard-layout__main--sidebar-collapsed{margin-left:80px}}@media(max-width:767px){.dashboard-layout__main{padding:1rem;padding-bottom:calc(90px + 1rem)}}.dashboard-calendar-events{display:flex;flex-direction:column;gap:1.5rem}.dashboard-calendar-events__loading,.dashboard-calendar-events__error,.dashboard-calendar-events__empty{text-align:center;padding:1rem;font-size:.95rem}.dashboard-calendar-events__day{display:flex;flex-direction:column;gap:.75rem}.dashboard-calendar-events__day-title{font-size:1.1rem;font-weight:600;margin:0;letter-spacing:-.01em;padding-bottom:.5rem;border-bottom:1px solid var(--glass-border)}.dashboard-calendar-events__events-list{display:flex;flex-direction:column;gap:.75rem}.dashboard-calendar-events__event{padding:1rem;display:flex;flex-direction:column;gap:.75rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.dashboard-calendar-events__event:hover{background:var(--glass-bg-hover);border-color:var(--glass-border)}.dashboard-calendar-events__event-header{display:flex;flex-direction:column;gap:.25rem}.dashboard-calendar-events__event-title{font-size:1rem;font-weight:600;margin:0;line-height:1.4}.dashboard-calendar-events__event-time{font-size:.875rem;font-weight:500}.dashboard-calendar-events__event-details{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem;line-height:1.5}.dashboard-calendar-events__event-location{display:flex;align-items:flex-start;gap:.5rem}.dashboard-calendar-events__event-description{line-height:1.5;word-wrap:break-word}.dashboard-calendar-events__event-members{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding-top:.5rem;border-top:1px solid var(--glass-border)}.dashboard-calendar-events__event-members-label{font-size:.875rem;font-weight:500}.dashboard-calendar-events__event-members-icons{display:flex;align-items:center;gap:-10%}.dashboard-calendar-events__event-member-icon{width:40px;height:40px;border-radius:50%;border:2px solid;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#ffffff80;margin-left:-5%}.dashboard-calendar-events__event-member-icon:first-child{margin-left:0}.dashboard-calendar-events__event-member-image{width:100%;height:100%;object-fit:cover}@media(min-width:768px){.dashboard-calendar-events{gap:2rem}.dashboard-calendar-events__day{gap:1rem}.dashboard-calendar-events__day-title{font-size:1.25rem}.dashboard-calendar-events__events-list{gap:1rem}.dashboard-calendar-events__event{padding:1.25rem;gap:1rem}.dashboard-calendar-events__event-title{font-size:1.1rem}.dashboard-calendar-events__event-member-icon{width:44px;height:44px}}.dashboard-shopping-list{display:flex;flex-direction:column;gap:1rem}.dashboard-shopping-list__loading,.dashboard-shopping-list__error,.dashboard-shopping-list__empty{padding:1rem;text-align:center;font-size:.9rem}.dashboard-shopping-list__items{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.dashboard-shopping-list__item{padding:.75rem 1rem;transition:transform .2s ease,box-shadow .2s ease}.dashboard-shopping-list__item:hover{transform:translateY(-1px)}.dashboard-shopping-list__item-content{display:flex;flex-direction:column;gap:.25rem}.dashboard-shopping-list__item-name{font-size:.95rem;font-weight:500;line-height:1.4}.dashboard-shopping-list__item-note{font-size:.85rem;line-height:1.4;opacity:.7}.dashboard-shopping-list__link{display:inline-block;margin-top:.5rem;font-size:.9rem;text-decoration:none;transition:opacity .2s ease;align-self:flex-start}.dashboard-shopping-list__link:hover{opacity:.8;text-decoration:underline}.dashboard-page{display:flex;flex-direction:column;gap:2rem}.dashboard-page__header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.dashboard-page__title{font-size:2rem;font-weight:700;margin:0;letter-spacing:-.02em}.dashboard-page__subtitle{font-size:1rem;margin:0;line-height:1.6}.dashboard-page__grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.dashboard-page__section{display:flex;flex-direction:column;gap:1rem;min-height:200px}.dashboard-page__section-title{font-size:1.25rem;font-weight:600;margin:0;letter-spacing:-.01em}.dashboard-page__section-content{font-size:.95rem;line-height:1.6;margin:0}@media(min-width:768px){.dashboard-page__grid{grid-template-columns:repeat(2,1fr)}.dashboard-page__section{min-height:250px}}@media(min-width:1024px){.dashboard-page__grid{grid-template-columns:repeat(3,1fr)}.dashboard-page__title{font-size:2.5rem}}.calendar-page{display:flex;flex-direction:column;gap:1.5rem}.calendar-page__header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.calendar-page__title{font-size:2rem;font-weight:700;margin:0;letter-spacing:-.02em}.calendar-page__subtitle{font-size:1rem;margin:0;line-height:1.6}.calendar-page__calendar{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;transform:none!important}.calendar-page__calendar:hover{transform:none!important}.calendar-page__calendar-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.calendar-page__calendar-header>div:nth-child(2){flex:1;display:flex;justify-content:center;align-items:center}.calendar-page__navigation{display:flex;align-items:center;gap:1rem}.calendar-page__nav-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-sm);background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary);cursor:pointer;transition:all .2s ease;padding:0}.calendar-page__nav-button:hover{background:var(--glass-bg-hover);border-color:var(--accent-blue);transform:translateY(-1px);box-shadow:var(--glass-shadow-hover)}.calendar-page__nav-button:active{transform:translateY(0)}.calendar-page__date-info{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:200px}.calendar-page__calendar-title{font-size:1.5rem;font-weight:600;margin:0;letter-spacing:-.01em}.calendar-page__week-range{font-size:.875rem;margin:0}.calendar-page__today-button{padding:.5rem 1rem;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent-blue),var(--accent-green));border:none;color:#fff;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease}.calendar-page__today-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.calendar-page__today-button:active{transform:translateY(0)}.calendar-page__loading,.calendar-page__error{text-align:center;padding:2rem;font-size:.95rem}.calendar-page__week-view{display:flex;flex-direction:column;gap:.5rem}.calendar-page__week-header{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:.5rem;padding-right:calc(17px - .5rem)}.calendar-page__day-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;border-radius:var(--radius-sm);background:#f8fafc99;border:1px solid var(--glass-border);transition:all .2s ease}.calendar-page__day-header--today{background:#2563eb1a;border-color:var(--accent-blue);box-shadow:0 2px 8px #2563eb33}.calendar-page__day-name{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.calendar-page__day-number{font-size:1.25rem;font-weight:600}.calendar-page__day-number--today{color:var(--accent-blue);font-weight:700}.calendar-page__week-grid-container{overflow-y:auto;overflow-x:hidden;height:702px;border-radius:var(--radius-sm);scroll-behavior:smooth;scrollbar-gutter:stable}.calendar-page__week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;position:relative}.calendar-page__week-day{position:relative;border-radius:var(--radius-sm);background:#f8fafc66;border:1px solid var(--glass-border);transition:all .2s ease;min-height:1872px}.calendar-page__week-day--today{background:#2563eb0d;border-color:var(--accent-blue);border-width:2px}.calendar-page__hours-grid{position:absolute;inset:0;pointer-events:none}.calendar-page__hour-marker{position:absolute;left:0;right:0;height:78px;border-top:1px solid rgba(148,163,184,.2)}.calendar-page__hour-marker--focus{background:#2563eb08;border-top-color:#94a3b84d}.calendar-page__hour-label{position:absolute;left:.5rem;top:.25rem;font-size:.7rem;font-weight:500;color:var(--text-secondary);background:var(--glass-bg);padding:.125rem .375rem;border-radius:.25rem;z-index:1}.calendar-page__hour-line{position:absolute;left:3rem;right:0;top:0;height:1px;background:#94a3b833}.calendar-page__hour-marker--focus .calendar-page__hour-line{background:#94a3b84d}.calendar-page__current-time-indicator{position:absolute;left:0;right:0;z-index:10;pointer-events:none}.calendar-page__current-time-line{position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent-blue),transparent);box-shadow:0 0 4px #2563eb80}.calendar-page__current-time-label{position:absolute;left:.5rem;top:-.75rem;background:var(--accent-blue);color:#fff;font-size:.7rem;font-weight:600;padding:.25rem .5rem;border-radius:.25rem;box-shadow:0 2px 8px #2563eb66;white-space:nowrap}.calendar-page__day-events{position:absolute;inset:0;pointer-events:none}.calendar-page__event{position:absolute;left:.5rem;right:.5rem;padding:.5rem;border-radius:var(--radius-sm);background:var(--glass-bg);border:1px solid var(--glass-border);cursor:pointer;transition:all .2s ease;font-size:.875rem;pointer-events:auto;overflow:visible;z-index:5;min-height:50px;display:flex;flex-direction:column;box-sizing:border-box}.calendar-page__event[style*=width]{right:auto}.calendar-page__event--compact{padding:.375rem .5rem;min-height:50px;justify-content:center}.calendar-page__event--compact .calendar-page__event-time{margin-bottom:.125rem;font-size:.7rem}.calendar-page__event--compact .calendar-page__event-title{font-size:.8rem;margin-bottom:.125rem;line-height:1.2;-webkit-line-clamp:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-page__event--compact .calendar-page__event-time{margin-top:0}.calendar-page__event:hover{background:var(--glass-bg-hover);border-color:var(--accent-blue);transform:translateY(-1px);box-shadow:0 4px 12px #0f172a26;z-index:6;overflow:visible;min-height:auto}.calendar-page__event:hover .calendar-page__event-title{-webkit-line-clamp:unset;white-space:normal;overflow:visible;max-height:none}.calendar-page__event--compact:hover{min-height:auto;padding:.5rem}.calendar-page__event--compact:hover .calendar-page__event-time{margin-bottom:.25rem;font-size:.75rem}.calendar-page__event--compact:hover .calendar-page__event-title{font-size:.875rem;margin-bottom:.25rem}.calendar-page__event-title{font-size:.875rem;font-weight:600;margin-bottom:.25rem;word-break:break-word;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;min-height:0}.calendar-page__event-time{font-size:.75rem;font-weight:500;white-space:nowrap;flex-shrink:0;margin-top:auto}.calendar-page__event--drag-over{background:var(--glass-bg-hover);border-color:var(--accent-blue);border-width:2px;box-shadow:0 4px 16px #2563eb4d}@media(min-width:768px){.calendar-page{gap:2rem}.calendar-page__title{font-size:2.5rem}.calendar-page__calendar{padding:2rem}.calendar-page__week-grid-container{height:702px}.calendar-page__date-info{min-width:250px}.calendar-page__calendar-title{font-size:1.75rem}.calendar-page__hour-label{font-size:.75rem}}.family-member-icons{display:flex;gap:1rem;align-items:center;justify-content:center;padding:.5rem}.family-member-icon{width:48px;height:48px;border-radius:50%;border:3px solid;background:var(--glass-bg);backdrop-filter:var(--blur-medium);display:flex;align-items:center;justify-content:center;cursor:grab;transition:all .2s ease;box-shadow:var(--glass-shadow);user-select:none;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none}.family-member-icon:active{cursor:grabbing}.family-member-icon:hover{transform:scale(1.1);box-shadow:0 4px 12px #0f172a33}.family-member-icon--touch-dragging{opacity:.7;transform:scale(1.05);z-index:1000;position:relative}.family-member-icon__placeholder{font-size:.875rem;font-weight:600;color:var(--text-primary)}.family-member-icon__image{width:100%;height:100%;object-fit:cover;border-radius:50%}.family-member-trash{width:48px;height:48px;border-radius:50%;background:var(--glass-bg);backdrop-filter:var(--blur-medium);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--glass-shadow);user-select:none;margin-left:1rem;min-width:88px;min-height:88px;margin:-20px}.family-member-trash--active{width:72px;height:72px;transform:scale(1.2)}.family-member-trash__underlay{position:absolute;inset:-8px;border-radius:50%;background:#dc26264d;animation:pulse 1.5s ease-in-out infinite;z-index:-1;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.family-member-trash--active .family-member-trash__underlay{inset:-20px;background:#dc262680;animation:pulseActive 1s ease-in-out infinite}@keyframes pulseActive{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.5;transform:scale(1.1)}}.family-member-trash__icon{color:#dc2626;width:24px;height:24px;z-index:1}.family-member-trash:hover{transform:scale(1.1);box-shadow:0 4px 12px #dc26264d}@media(min-width:768px){.family-member-icon{width:56px;height:56px}.family-member-icon__placeholder{font-size:1rem}.family-member-icon__image{width:100%;height:100%}.family-member-trash{width:56px;height:56px}.family-member-trash--active{width:84px;height:84px}.family-member-trash__icon{width:28px;height:28px}.family-member-trash--active .family-member-trash__icon{width:36px;height:36px}}.event-assignment-icons{position:absolute;bottom:-24px;left:0;right:0;display:flex;gap:-10%;align-items:center;justify-content:flex-start;padding:0 .5rem;z-index:10;pointer-events:none}.event-assignment-icon{width:32px;height:32px;border-radius:50%;border:2px solid;background:var(--glass-bg);backdrop-filter:var(--blur-medium);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:var(--glass-shadow);pointer-events:auto;flex-shrink:0;animation:fadeInScale .3s ease;margin-left:-5%;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.event-assignment-icon:first-child{margin-left:0}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.event-assignment-icon:hover{transform:scale(1.15);box-shadow:0 4px 12px #0f172a40}.event-assignment-icon--dragging{opacity:.6;transform:scale(.95);cursor:grabbing;z-index:100}.event-assignment-icon--snap-back{animation:snapBack .3s cubic-bezier(.34,1.56,.64,1)}@keyframes snapBack{0%{transform:scale(.95);opacity:.6}to{transform:scale(1);opacity:1}}.event-assignment-icon__placeholder{font-size:.75rem;font-weight:600;color:var(--text-primary)}.event-assignment-icon__image{width:100%;height:100%;object-fit:cover;border-radius:50%}@media(min-width:768px){.event-assignment-icon{width:36px;height:36px}.event-assignment-icon__placeholder{font-size:.875rem}.event-assignment-icon__image{width:100%;height:100%}.event-assignment-icons{bottom:-28px}}.todo-page{display:flex;flex-direction:column;gap:2rem}.todo-page__header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.todo-page__title{font-size:2rem;font-weight:700;margin:0;letter-spacing:-.02em}.todo-page__subtitle{font-size:1rem;margin:0;line-height:1.6}.todo-page__container{display:flex;flex-direction:column;gap:1.5rem}.todo-page__tasks{display:flex;flex-direction:column;gap:1.5rem;flex:2;min-height:400px}.todo-page__tasks-header{display:flex;justify-content:space-between;align-items:center}.todo-page__tasks-title{font-size:1.5rem;font-weight:600;margin:0;letter-spacing:-.01em}.todo-page__tasks-list{display:flex;flex-direction:column;gap:1rem}.todo-page__task-empty{text-align:center;padding:3rem 2rem;display:flex;flex-direction:column;gap:.5rem}.todo-page__task-empty p{margin:0;font-size:.95rem;line-height:1.6}.todo-page__stats{display:flex;flex-direction:column;gap:1.5rem;flex:1}.todo-page__stats-title{font-size:1.25rem;font-weight:600;margin:0;letter-spacing:-.01em}.todo-page__stats-list{display:flex;flex-direction:column;gap:1.25rem}.todo-page__stat{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-radius:.75rem;background:#f8fafce6;border:1px solid rgba(148,163,184,.3);transition:all .2s ease}.todo-page__stat:hover{background:#fffffff2;border-color:#2563eb66;transform:translate(4px)}.todo-page__stat-label{font-size:.95rem;font-weight:500}.todo-page__stat-value{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}@media(min-width:768px){.todo-page__container{flex-direction:row;align-items:flex-start}.todo-page__stats{min-width:300px}.todo-page__title{font-size:2.5rem}}.einkaufen-page{display:flex;flex-direction:column;gap:2rem}.einkaufen-page__header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.einkaufen-page__title{font-size:2rem;font-weight:700;margin:0;letter-spacing:-.02em}.einkaufen-page__subtitle{font-size:1rem;margin:0;line-height:1.6}.einkaufen-page__container{display:flex;flex-direction:column;gap:1.5rem}.einkaufen-page__list{display:flex;flex-direction:column;gap:1.5rem;flex:2;min-height:400px;transition:none}.einkaufen-page__list:hover{transform:none}.einkaufen-page__list-header{display:flex;justify-content:space-between;align-items:center}.einkaufen-page__list-title{font-size:1.5rem;font-weight:600;margin:0;letter-spacing:-.01em}.einkaufen-page__list-items{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;list-style:none;padding:0;margin:0}.einkaufen-page__list-loading,.einkaufen-page__list-error{text-align:center;padding:3rem 2rem;display:flex;flex-direction:column;gap:.5rem}.einkaufen-page__list-loading p,.einkaufen-page__list-error p{margin:0;font-size:.95rem;line-height:1.6}.einkaufen-page__list-item{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius-md);background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);transition:all .2s ease;cursor:pointer;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.einkaufen-page__list-item:hover{background:var(--glass-bg-hover);border-color:var(--accent-blue);box-shadow:0 4px 12px #0f172a26;transform:translateY(-2px)}.einkaufen-page__list-item:active{transform:translateY(0);box-shadow:var(--glass-shadow)}.einkaufen-page__list-item--processing{opacity:.6;pointer-events:none;animation:pulse .6s ease-in-out}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(.98)}}.einkaufen-page__list-item--glow-add{animation:glow-green 1.5s ease-out}.einkaufen-page__list-item--glow-remove{animation:glow-red 1.5s ease-out}@keyframes glow-green{0%{box-shadow:0 0 #10b98100;border-color:var(--glass-border)}50%{box-shadow:0 0 20px 8px #10b98199;border-color:#10b981cc;background:#10b9811a}to{box-shadow:0 0 #10b98100;border-color:var(--glass-border)}}@keyframes glow-red{0%{box-shadow:0 0 #dc262600;border-color:var(--glass-border);opacity:1;transform:scale(1)}30%{box-shadow:0 0 20px 8px #dc262699;border-color:#dc2626cc;background:#dc26261a}70%{opacity:.5;transform:scale(.95)}to{opacity:0;transform:scale(.9);box-shadow:0 0 #dc262600}}.einkaufen-page__item-content{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.einkaufen-page__item-action{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background:var(--glass-bg-hover);border:1px solid var(--glass-border);flex-shrink:0;transition:all .2s ease}.einkaufen-page__list-item:hover .einkaufen-page__item-action{background:var(--accent-blue);border-color:var(--accent-blue);transform:scale(1.1)}.einkaufen-page__item-action-icon{font-size:1.25rem;font-weight:600;line-height:1;color:var(--text-primary);transition:color .2s ease}.einkaufen-page__list-item:hover .einkaufen-page__item-action-icon{color:#fff}.einkaufen-page__item-name{font-size:.9375rem;font-weight:600;line-height:1.4;margin:0;letter-spacing:-.01em}.einkaufen-page__item-note{font-size:.8125rem;line-height:1.3;margin:0;opacity:.7}.einkaufen-page__list-empty{text-align:center;padding:3rem 2rem;display:flex;flex-direction:column;gap:.5rem}.einkaufen-page__list-empty p{margin:0;font-size:.95rem;line-height:1.6}.einkaufen-page__add-section{display:flex;flex-direction:column;gap:1.5rem;flex:2;min-height:200px;transition:none}.einkaufen-page__add-section:hover{transform:none}.einkaufen-page__add-section--collapsed{min-height:auto;gap:0}.einkaufen-page__add-section--collapsed .einkaufen-page__add-content{display:none}.einkaufen-page__add-header-wrapper{display:flex;justify-content:space-between;align-items:center}.einkaufen-page__add-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:0;background:transparent;border:none;cursor:pointer;transition:opacity .2s ease}.einkaufen-page__add-header:hover{opacity:.8}.einkaufen-page__add-title{font-size:1.5rem;font-weight:600;margin:0;letter-spacing:-.01em}.einkaufen-page__add-toggle{font-size:.875rem;opacity:.7;transition:transform .3s ease}.einkaufen-page__add-content{display:flex;flex-direction:column;gap:1.5rem;padding-top:.5rem}.einkaufen-page__recent-section{display:flex;flex-direction:column;gap:.75rem}.einkaufen-page__recent-title{font-size:.9375rem;font-weight:600;margin:0;opacity:.8}.einkaufen-page__recent-items{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;list-style:none;padding:0;margin:0}.einkaufen-page__input-form{display:flex;flex-direction:column;gap:.75rem}.einkaufen-page__input-wrapper{position:relative}.einkaufen-page__input{width:100%;padding:.875rem 1rem;border-radius:var(--radius-md);background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);font-size:.9375rem;color:var(--text-primary);transition:all .2s ease}.einkaufen-page__input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #2563eb1a}.einkaufen-page__input::placeholder{color:var(--text-secondary);opacity:.6}.einkaufen-page__suggestions{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--glass-shadow);z-index:10;max-height:300px;overflow-y:auto}.einkaufen-page__suggestions-list{list-style:none;padding:.25rem;margin:0}.einkaufen-page__suggestion-item{padding:.75rem 1rem;border-radius:var(--radius-sm);cursor:pointer;transition:background-color .2s ease}.einkaufen-page__suggestion-item:hover{background:var(--glass-bg-hover)}.einkaufen-page__submit-button{padding:.875rem 1.5rem;border-radius:var(--radius-md);background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);font-size:.9375rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s ease;align-self:flex-start}.einkaufen-page__submit-button:hover{background:var(--glass-bg-hover);border-color:var(--accent-blue);transform:translateY(-1px)}.einkaufen-page__submit-button:active{transform:translateY(0)}@media(min-width:768px){.einkaufen-page__list-items{grid-template-columns:repeat(3,1fr);gap:1rem}.einkaufen-page__list-item{padding:1rem 1.25rem}.einkaufen-page__item-name{font-size:1rem}.einkaufen-page__item-note{font-size:.875rem}.einkaufen-page__recent-items{grid-template-columns:repeat(3,1fr);gap:1rem}.einkaufen-page__input-form{flex-direction:row;align-items:flex-start}.einkaufen-page__input-wrapper{flex:1}}#root{width:100%;margin:0;padding:0}
