.app-shell{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;background:radial-gradient(circle at top left,color-mix(in srgb,var(--md-sys-color-primary) 13%,transparent),transparent 26%),radial-gradient(circle at top right,color-mix(in srgb,var(--md-sys-color-secondary) 10%,transparent),transparent 28%),linear-gradient(180deg,color-mix(in srgb,var(--md-sys-color-surface-container-low) 36%,transparent),transparent 18%),var(--md-sys-color-surface)}.app-top-bar{position:sticky;top:0;z-index:40;display:flex;flex-direction:column;gap:var(--md-sys-spacing-3);padding-block:calc(var(--md-sys-spacing-3) + env(safe-area-inset-top,0px)) var(--md-sys-spacing-3);padding-inline:calc(clamp(var(--md-sys-spacing-4),2vw,var(--md-sys-spacing-8)) + env(safe-area-inset-left,0px)) calc(clamp(var(--md-sys-spacing-4),2vw,var(--md-sys-spacing-8)) + env(safe-area-inset-right,0px));border-bottom:1px solid color-mix(in srgb,var(--md-sys-color-outline-variant) 72%,transparent);background-color:color-mix(in srgb,var(--md-sys-color-surface) 84%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 10px 32px #0000001f}.app-top-bar__row{display:flex;align-items:center;justify-content:space-between;gap:var(--md-sys-spacing-4);min-height:56px}.app-brand-block{min-width:0}.app-brand-link{display:inline-flex;align-items:center;gap:var(--md-sys-spacing-4);min-width:0;color:inherit;text-decoration:none;transition:transform .2s ease,opacity .2s ease}.app-brand-link:hover{transform:translateY(-1px)}.app-brand-link__icon{width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--md-sys-shape-corner-large);background:radial-gradient(circle at 30% 30%,color-mix(in srgb,var(--md-sys-color-on-primary-container) 26%,transparent),transparent 45%),color-mix(in srgb,var(--md-sys-color-primary-container) 92%,transparent);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-1);flex-shrink:0;border:1px solid color-mix(in srgb,var(--md-sys-color-on-primary-container) 12%,transparent)}.app-brand-link__icon .md-symbol{font-size:28px;font-variation-settings:"FILL" 1,"wght" 500,"GRAD" 0,"opsz" 24}.app-brand-copy{min-width:0;display:flex;flex-direction:column;justify-content:center}.app-brand-copy__eyebrow{display:block;margin-bottom:2px;color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);letter-spacing:.04em;text-transform:uppercase}.app-brand-copy h1{margin:0;font-size:clamp(1.4rem,1rem + 1vw,2rem);line-height:1.1;letter-spacing:-.03em;color:var(--md-sys-color-on-surface)}.app-top-bar__actions{display:flex;align-items:center;gap:var(--md-sys-spacing-3);flex-shrink:0}.app-public-nav{display:flex;align-items:center;gap:var(--md-sys-spacing-2)}.app-family-pill{display:inline-flex;align-items:center;gap:var(--md-sys-spacing-2);padding-inline:var(--md-sys-spacing-4);min-height:44px;border-radius:var(--md-sys-shape-corner-full);box-shadow:var(--md-sys-elevation-1);white-space:nowrap;border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 30%,transparent)}.user-avatar-button{width:48px;height:48px;min-width:48px;min-height:48px;padding:0;border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 72%,transparent);border-radius:var(--md-sys-shape-corner-full);background:color-mix(in srgb,var(--md-sys-color-secondary-container) 82%,transparent);color:var(--md-sys-color-on-secondary-container);font-size:var(--md-sys-typescale-label-large-size);font-weight:700;cursor:pointer;box-shadow:var(--md-sys-elevation-1);transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.user-avatar-button:hover{transform:translateY(-1px);box-shadow:var(--md-sys-elevation-2)}.user-avatar-button:active{transform:translateY(0)}.app-primary-nav{display:flex;align-items:center;gap:var(--md-sys-spacing-2);min-height:48px;overflow-x:auto;scrollbar-width:none}.app-primary-nav::-webkit-scrollbar{display:none}.app-primary-nav__link,.app-bottom-nav__item{display:inline-flex;align-items:center;justify-content:center;gap:var(--md-sys-spacing-2);min-height:48px;text-decoration:none;transition:background-color .2s ease,color .2s ease,transform .2s ease}.app-primary-nav__link{padding:0 var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-full);color:var(--md-sys-color-on-surface-variant);white-space:nowrap;border:1px solid transparent}.app-primary-nav__link:hover{background:color-mix(in srgb,var(--md-sys-color-primary) 10%,transparent);border-color:color-mix(in srgb,var(--md-sys-color-outline) 28%,transparent)}.app-primary-nav__link.is-active{background:linear-gradient(180deg,color-mix(in srgb,var(--md-sys-color-secondary-container) 96%,transparent),color-mix(in srgb,var(--md-sys-color-secondary-container) 88%,transparent));color:var(--md-sys-color-on-secondary-container);box-shadow:var(--md-sys-elevation-1);border-color:color-mix(in srgb,var(--md-sys-color-on-secondary-container) 10%,transparent)}.app-nav-text{font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight)}.user-menu-backdrop{position:fixed;inset:0;z-index:79;background:transparent}.app-account-menu{position:fixed;top:calc(88px + env(safe-area-inset-top,0px));right:clamp(var(--md-sys-spacing-4),2vw,var(--md-sys-spacing-8));width:min(360px,calc(100vw - 32px));z-index:80;overflow-y:auto}.app-account-menu__header{display:flex;align-items:center;gap:var(--md-sys-spacing-4);padding:var(--md-sys-spacing-4);border-bottom:1px solid color-mix(in srgb,var(--md-sys-color-outline-variant) 72%,transparent)}.app-account-menu__avatar{width:48px;height:48px;border-radius:var(--md-sys-shape-corner-full);display:inline-flex;align-items:center;justify-content:center;background:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);font-weight:700}.app-account-menu__name{color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight)}.app-account-menu__email{color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-small-size)}.app-account-menu__section{padding:var(--md-sys-spacing-2) 0}.app-account-menu__section+.app-account-menu__section{border-top:1px solid color-mix(in srgb,var(--md-sys-color-outline-variant) 72%,transparent)}.app-family-switcher{width:100%}.app-family-switcher__content,.app-family-submenu__content{display:flex;flex:1;min-width:0;flex-direction:column;align-items:flex-start}.app-family-switcher__title{color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-body-large-size);font-weight:600}.app-family-switcher__meta{color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-small-size)}.app-family-submenu{padding-top:var(--md-sys-spacing-1)}.app-family-submenu__item{width:100%;border:none;border-radius:var(--md-sys-shape-corner-large);background:transparent;text-align:left}.app-family-submenu__item.is-active{background:color-mix(in srgb,var(--md-sys-color-primary) 12%,transparent)}.app-shell-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--md-sys-spacing-4);min-height:100vh;padding:var(--md-sys-spacing-8);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-large-size)}.app-main{flex:1;width:100%;padding-bottom:calc(88px + env(safe-area-inset-bottom,0px))}.app-footer{padding-block:var(--md-sys-spacing-6);padding-inline:calc(clamp(var(--md-sys-spacing-4),2vw,var(--md-sys-spacing-8)) + env(safe-area-inset-left,0px)) calc(clamp(var(--md-sys-spacing-4),2vw,var(--md-sys-spacing-8)) + env(safe-area-inset-right,0px));text-align:center;color:var(--md-sys-color-on-surface-variant);border-top:1px solid color-mix(in srgb,var(--md-sys-color-outline-variant) 72%,transparent);background:color-mix(in srgb,var(--md-sys-color-surface-container-low) 72%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app-bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:35;display:none;align-items:stretch;justify-content:space-around;gap:var(--md-sys-spacing-1);padding:var(--md-sys-spacing-2) calc(var(--md-sys-spacing-2) + env(safe-area-inset-right,0px)) calc(var(--md-sys-spacing-2) + env(safe-area-inset-bottom,0px)) calc(var(--md-sys-spacing-2) + env(safe-area-inset-left,0px));border-top:1px solid color-mix(in srgb,var(--md-sys-color-outline-variant) 72%,transparent);background:color-mix(in srgb,var(--md-sys-color-surface-container) 92%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 -12px 30px #0000002e}.app-bottom-nav__item{min-width:0;flex:1;flex-direction:column;gap:2px;padding:var(--md-sys-spacing-2) var(--md-sys-spacing-1);border-radius:var(--md-sys-shape-corner-large);color:var(--md-sys-color-on-surface-variant)}.app-bottom-nav__item.is-active{background:linear-gradient(180deg,color-mix(in srgb,var(--md-sys-color-secondary-container) 92%,transparent),color-mix(in srgb,var(--md-sys-color-secondary-container) 84%,transparent));color:var(--md-sys-color-on-secondary-container);box-shadow:inset 0 1px #ffffff0d}.app-bottom-nav .app-nav-text{font-size:var(--md-sys-typescale-label-small-size)}.md-menu-item{text-decoration:none}@media(max-width:900px){.app-primary-nav{display:none}.app-bottom-nav{display:flex}.app-family-pill{display:none}.app-footer{padding-bottom:calc(var(--md-sys-spacing-8) + env(safe-area-inset-bottom,0px))}}@media(max-width:700px){.app-top-bar{gap:var(--md-sys-spacing-3);padding-inline:calc(var(--md-sys-spacing-4) + env(safe-area-inset-left,0px)) calc(var(--md-sys-spacing-4) + env(safe-area-inset-right,0px))}.app-brand-link{gap:var(--md-sys-spacing-3)}.app-brand-link__icon{width:44px;height:44px}.app-brand-link__icon .md-symbol{font-size:24px}.app-account-menu{top:calc(80px + env(safe-area-inset-top,0px));right:calc(var(--md-sys-spacing-4) + env(safe-area-inset-right,0px));left:calc(var(--md-sys-spacing-4) + env(safe-area-inset-left,0px));width:auto}.app-public-nav{gap:0}.app-public-nav .md-button{min-width:auto;padding-inline:var(--md-sys-spacing-4)}}@media(max-width:560px){.app-top-bar__row{align-items:flex-start}.app-brand-copy__eyebrow{font-size:var(--md-sys-typescale-label-small-size)}.app-brand-copy h1{font-size:1.35rem}.app-top-bar__actions{gap:var(--md-sys-spacing-2)}.user-avatar-button{width:44px;height:44px;min-width:44px;min-height:44px}.app-main{padding-bottom:calc(92px + env(safe-area-inset-bottom,0px))}}.page-scaffold{width:min(1440px,100%);margin:0 auto;padding-block:clamp(var(--md-sys-spacing-4),2vw,var(--md-sys-spacing-8));padding-inline:calc(clamp(var(--md-sys-spacing-4),2vw,var(--md-sys-spacing-8)) + env(safe-area-inset-left,0px)) calc(clamp(var(--md-sys-spacing-4),2vw,var(--md-sys-spacing-8)) + env(safe-area-inset-right,0px));display:flex;flex-direction:column;gap:var(--md-sys-spacing-4)}.page-scaffold__hero{display:grid;gap:var(--md-sys-spacing-3);padding:clamp(var(--md-sys-spacing-4),1.2vw,var(--md-sys-spacing-5));border-radius:var(--md-sys-shape-corner-medium);background:radial-gradient(circle at 18% 18%,color-mix(in srgb,var(--md-sys-color-on-surface) 5%,transparent),transparent 18%),radial-gradient(circle at top right,color-mix(in srgb,var(--md-sys-color-primary) 14%,transparent),transparent 34%),radial-gradient(circle at bottom left,color-mix(in srgb,var(--md-sys-color-tertiary) 10%,transparent),transparent 28%),linear-gradient(180deg,color-mix(in srgb,var(--md-sys-color-surface-container-high) 88%,transparent),var(--md-sys-color-surface-container-low));border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 22%,transparent);box-shadow:var(--md-sys-elevation-2)}.page-scaffold__hero.md-card{overflow:visible}.page-scaffold__hero--collapsed{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:var(--md-sys-spacing-3)}.page-scaffold__header{min-width:0}.page-scaffold__copy{min-width:0;max-width:54ch}.page-scaffold__eyebrow{margin:0 0 var(--md-sys-spacing-1);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-medium-weight);letter-spacing:.08em;text-transform:uppercase}.page-scaffold__title{margin:0;color:var(--md-sys-color-on-surface);font-size:clamp(1.55rem,1.25rem + .75vw,2.1rem);line-height:1.08;letter-spacing:-.04em}.page-scaffold__description{margin:var(--md-sys-spacing-2) 0 0;color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height);max-width:50ch}.page-scaffold__aside{display:grid;gap:var(--md-sys-spacing-2);min-width:0;position:relative;z-index:1}.page-scaffold__controls{display:flex;align-items:center;justify-content:flex-start;gap:var(--md-sys-spacing-2);min-width:0}.page-scaffold__actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:var(--md-sys-spacing-2);min-width:0}.page-scaffold__actions .md-button{min-height:40px}.page-scaffold__collapse{flex-shrink:0}.page-scaffold__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:var(--md-sys-spacing-2);max-width:720px}.page-scaffold__stat{display:flex;align-items:center;gap:var(--md-sys-spacing-2);padding:calc(var(--md-sys-spacing-2) + 2px) var(--md-sys-spacing-3);border-radius:var(--md-sys-shape-corner-large);min-width:0;border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 18%,transparent);background:color-mix(in srgb,var(--md-sys-color-surface-container-highest) 72%,transparent);box-shadow:inset 0 1px #ffffff08;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.page-scaffold__stat>div{min-width:0}.page-scaffold__stat:hover{transform:translateY(-1px);box-shadow:var(--md-sys-elevation-1);border-color:color-mix(in srgb,var(--md-sys-color-primary) 24%,transparent)}.page-scaffold__stat .md-symbol{color:var(--md-sys-color-primary);font-size:1rem}.page-scaffold__stat-value{margin:0;color:var(--md-sys-color-on-surface);font-size:clamp(1rem,.95rem + .3vw,1.25rem);line-height:1;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-scaffold__stat-label{margin:2px 0 0;color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-label-small-size)}.page-scaffold__body{display:flex;flex-direction:column;gap:var(--md-sys-spacing-4);min-width:0}.page-scaffold__empty{min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--md-sys-spacing-3);padding:var(--md-sys-spacing-5);text-align:center;color:var(--md-sys-color-on-surface-variant)}.page-scaffold__empty .md-symbol{color:var(--md-sys-color-primary)}@media(min-width:1200px){.page-scaffold__hero--with-stats{grid-template-columns:minmax(0,1fr) auto;align-items:center}.page-scaffold__hero--with-stats .page-scaffold__aside{align-self:center;justify-items:end}.page-scaffold__hero--with-stats .page-scaffold__controls,.page-scaffold__hero--collapsed .page-scaffold__controls,.page-scaffold__hero--with-stats .page-scaffold__actions{justify-content:flex-end}.page-scaffold__hero--with-stats .page-scaffold__stats{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(126px,156px);max-width:none}.page-scaffold__hero--with-stats .page-scaffold__stat{min-height:56px}}.page-scaffold__hero--collapsed .page-scaffold__copy{max-width:none}.page-scaffold__hero--collapsed .page-scaffold__title{font-size:clamp(1.18rem,1.08rem + .4vw,1.55rem);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-scaffold__hero--collapsed .page-scaffold__controls,.page-scaffold__hero--collapsed .page-scaffold__actions{flex-wrap:nowrap}@media(max-width:900px){.page-scaffold__aside{width:100%}.page-scaffold__actions{width:100%;justify-content:flex-start}}@media(max-width:640px){.page-scaffold{gap:var(--md-sys-spacing-3);padding-inline:calc(var(--md-sys-spacing-4) + env(safe-area-inset-left,0px)) calc(var(--md-sys-spacing-4) + env(safe-area-inset-right,0px))}.page-scaffold__hero{padding:var(--md-sys-spacing-3);border-radius:var(--md-sys-shape-corner-medium)}.page-scaffold__title{font-size:clamp(1.28rem,1.18rem + .6vw,1.55rem);line-height:1.1}.page-scaffold__description{margin-top:var(--md-sys-spacing-2);font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height)}.page-scaffold__actions{gap:var(--md-sys-spacing-2)}.page-scaffold__actions .md-button{width:100%;min-height:38px;padding-inline:var(--md-sys-spacing-4)}.page-scaffold__hero--collapsed{grid-template-columns:minmax(0,1fr) auto}.page-scaffold__hero--collapsed .page-scaffold__controls{justify-content:flex-end}.page-scaffold__hero--collapsed .page-scaffold__actions .md-button{width:auto;min-height:36px;padding-inline:var(--md-sys-spacing-3)}.page-scaffold__stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--md-sys-spacing-2)}.page-scaffold__stat{flex-direction:column;align-items:flex-start;gap:var(--md-sys-spacing-2);padding:6px var(--md-sys-spacing-2);border-radius:var(--md-sys-shape-corner-medium)}.page-scaffold__stat .md-symbol,.page-scaffold__stat-value{font-size:1rem}.page-scaffold__stat-label{margin-top:2px;font-size:var(--md-sys-typescale-label-small-size);line-height:1.2}}@media(max-width:420px){.page-scaffold{padding-inline:calc(var(--md-sys-spacing-3) + env(safe-area-inset-left,0px)) calc(var(--md-sys-spacing-3) + env(safe-area-inset-right,0px))}.page-scaffold__header{gap:var(--md-sys-spacing-4)}.page-scaffold__hero{padding:var(--md-sys-spacing-3)}.page-scaffold__eyebrow{margin-bottom:var(--md-sys-spacing-1);font-size:var(--md-sys-typescale-label-small-size)}.page-scaffold__actions .md-button{min-height:40px}.page-scaffold__hero--collapsed .page-scaffold__title{font-size:1.05rem}.page-scaffold__stat{padding:var(--md-sys-spacing-2)}}.admin-page,.admin-container{width:100%}.admin-header h1{font-size:var(--md-sys-typescale-headline-large-size);font-weight:var(--md-sys-typescale-headline-large-weight);line-height:var(--md-sys-typescale-headline-large-line-height);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-6) 0}.admin-tabs{display:flex;gap:var(--md-sys-spacing-2);border-bottom:1px solid var(--md-sys-color-outline-variant);margin-bottom:var(--md-sys-spacing-6);overflow-x:auto}.admin-tabs .tab,.tab-button{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-6);font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight);line-height:var(--md-sys-typescale-title-medium-line-height);border:none;background:transparent;color:var(--md-sys-color-on-surface-variant);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s cubic-bezier(.2,0,0,1);white-space:nowrap}.admin-tabs .tab:hover,.tab-button:hover{background-color:var(--md-sys-color-surface-container);color:var(--md-sys-color-on-surface)}.admin-tabs .tab.active,.tab-button.active{color:var(--md-sys-color-primary);border-bottom-color:var(--md-sys-color-primary)}.admin-content{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);padding:var(--md-sys-spacing-6);box-shadow:var(--md-sys-elevation-1);overflow-x:auto}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--md-sys-spacing-5)}.list-header h2{font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);line-height:var(--md-sys-typescale-title-large-line-height);color:var(--md-sys-color-on-surface);margin:0}.header-actions{display:flex;align-items:center;gap:var(--md-sys-spacing-4)}.user-count,.family-count{font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface-variant)}.tab-content{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);padding:var(--md-sys-spacing-6);box-shadow:var(--md-sys-elevation-1)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--md-sys-spacing-4)}.section-header h2{font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);line-height:var(--md-sys-typescale-title-large-line-height);color:var(--md-sys-color-on-surface);margin:0}.admin-table,.users-table,.invites-table,.families-table,.feeds-table{width:100%;border-collapse:collapse;background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-medium);overflow:hidden}.feeds-table{table-layout:fixed}.admin-table thead,.users-table thead,.invites-table thead,.families-table thead,.feeds-table thead{background-color:var(--md-sys-color-surface-container-high)}.admin-table th,.users-table th,.invites-table th,.families-table th,.feeds-table th{padding:var(--md-sys-spacing-4) var(--md-sys-spacing-5);text-align:left;font-size:var(--md-sys-typescale-title-small-size);font-weight:var(--md-sys-typescale-title-small-weight);line-height:var(--md-sys-typescale-title-small-line-height);color:var(--md-sys-color-on-surface);border-bottom:1px solid var(--md-sys-color-outline-variant)}.admin-table td,.users-table td,.invites-table td,.families-table td,.feeds-table td{padding:var(--md-sys-spacing-4) var(--md-sys-spacing-5);font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height);color:var(--md-sys-color-on-surface-variant);border-bottom:1px solid var(--md-sys-color-outline-variant);vertical-align:middle}.admin-table tr:last-child td,.users-table tr:last-child td,.invites-table tr:last-child td,.families-table tr:last-child td,.feeds-table tr:last-child td{border-bottom:none}.admin-table tbody tr:hover,.users-table tbody tr:hover,.invites-table tbody tr:hover,.families-table tbody tr:hover,.feeds-table tbody tr:hover{background-color:var(--md-sys-color-surface-container)}.url-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.url-cell a{color:var(--md-sys-color-primary);text-decoration:none;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.url-cell a:hover{text-decoration:underline}td.actions,.actions{white-space:nowrap}td.actions button,.actions button{display:inline-flex;vertical-align:middle}.btn{padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-label-large-line-height);border:none;border-radius:var(--md-sys-shape-corner-full);cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);white-space:nowrap}.btn-text{background-color:transparent;color:var(--md-sys-color-primary)}.btn-icon{padding:var(--md-sys-spacing-2);border-radius:var(--md-sys-shape-corner-small)}.action-buttons{display:flex;gap:var(--md-sys-spacing-2)}.message{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-medium);font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height);margin-bottom:var(--md-sys-spacing-4)}.message.success{background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container)}.message.error{background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container)}.badge{display:inline-block;padding:var(--md-sys-spacing-1) var(--md-sys-spacing-2);background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);border-radius:var(--md-sys-shape-corner-small);font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);line-height:var(--md-sys-typescale-label-small-line-height)}.badge.admin{background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container)}.status-badge{display:inline-block;padding:var(--md-sys-spacing-1) var(--md-sys-spacing-3);font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);line-height:var(--md-sys-typescale-label-medium-line-height);border-radius:var(--md-sys-shape-corner-full);white-space:nowrap}.status-valid,.status-active{background-color:#81c78433;color:#81c784}.status-used,.status-synced{background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.status-expired,.status-error{background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container)}.invite-code{font-family:Roboto Mono,monospace;font-size:var(--md-sys-typescale-body-small-size);padding:var(--md-sys-spacing-1) var(--md-sys-spacing-2);background-color:var(--md-sys-color-surface-container-high);border-radius:var(--md-sys-shape-corner-extra-small);cursor:pointer;transition:background-color .2s ease;display:inline-block;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-code:hover{background-color:var(--md-sys-color-surface-container-highest)}.admin-badge{display:inline-block;padding:var(--md-sys-spacing-1) var(--md-sys-spacing-2);font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);border-radius:var(--md-sys-shape-corner-small);background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.admin-badge.is-admin{background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container)}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--md-sys-spacing-2);margin-top:var(--md-sys-spacing-4)}.pagination-info{font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface-variant)}.loading{text-align:center;padding:var(--md-sys-spacing-8);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-large-size)}.modal-backdrop{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--md-sys-spacing-4)}.modal{background-color:var(--md-sys-color-surface-container-high);border-radius:var(--md-sys-shape-corner-extra-large);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--md-sys-elevation-5);padding:var(--md-sys-spacing-6)}.modal h2{font-size:var(--md-sys-typescale-headline-medium-size);font-weight:var(--md-sys-typescale-headline-medium-weight);line-height:var(--md-sys-typescale-headline-medium-line-height);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-6) 0}.modal-form{display:flex;flex-direction:column;gap:var(--md-sys-spacing-4)}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group textarea{padding:var(--md-sys-spacing-3);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-medium);background-color:var(--md-sys-color-surface-container-low);color:var(--md-sys-color-on-surface);transition:all .2s cubic-bezier(.2,0,0,1);outline:none}.form-group input:focus,.form-group textarea:focus{border-color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container);box-shadow:0 0 0 1px var(--md-sys-color-primary)}.form-group textarea{min-height:100px;resize:vertical}.checkbox-group{display:flex;align-items:center;gap:var(--md-sys-spacing-2)}.checkbox-group input[type=checkbox]{width:20px;height:20px;cursor:pointer}.modal-actions{display:flex;gap:var(--md-sys-spacing-2);justify-content:flex-end;margin-top:var(--md-sys-spacing-4)}.color-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--md-sys-spacing-3);padding:var(--md-sys-spacing-4) 0}.color-option{width:56px;height:56px;border-radius:var(--md-sys-shape-corner-medium);border:3px solid transparent;cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);font-size:1.5rem;color:#fff;display:flex;align-items:center;justify-content:center;text-shadow:0 1px 2px rgba(0,0,0,.5);box-shadow:var(--md-sys-elevation-1)}.color-option:hover{transform:scale(1.08);box-shadow:var(--md-sys-elevation-3)}.color-option.selected{border-color:var(--md-sys-color-on-surface);box-shadow:0 0 0 2px var(--md-sys-color-primary),var(--md-sys-elevation-2)}.custom-color-picker{margin-top:var(--md-sys-spacing-4);padding-top:var(--md-sys-spacing-4);border-top:1px solid var(--md-sys-color-outline-variant)}.custom-color-picker label{display:block;font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);color:var(--md-sys-color-on-surface);margin-bottom:var(--md-sys-spacing-2)}.custom-color-controls{display:flex;align-items:center;gap:var(--md-sys-spacing-3)}.custom-color-controls input[type=color]{width:56px;height:56px;border:none;border-radius:var(--md-sys-shape-corner-medium);cursor:pointer;background:transparent;padding:0}.custom-color-controls input[type=color]::-webkit-color-swatch-wrapper{padding:0}.custom-color-controls input[type=color]::-webkit-color-swatch{border:none;border-radius:var(--md-sys-shape-corner-medium);box-shadow:var(--md-sys-elevation-1)}.custom-color-value{font-family:monospace;font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface-variant);background-color:var(--md-sys-color-surface-container);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-3);border-radius:var(--md-sys-shape-corner-small)}.feed-name-display{display:flex;align-items:center;gap:var(--md-sys-spacing-3);font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight);color:var(--md-sys-color-on-surface);margin-bottom:var(--md-sys-spacing-4)}.feed-color{display:inline-block;width:16px;height:16px;border-radius:var(--md-sys-shape-corner-small);flex-shrink:0;vertical-align:middle;margin-right:var(--md-sys-spacing-2)}@media(max-width:768px){.admin-page{padding:var(--md-sys-spacing-4)}.admin-header h1{font-size:var(--md-sys-typescale-headline-medium-size)}.admin-header p{font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface-variant)}.admin-tabs{gap:var(--md-sys-spacing-2);padding:var(--md-sys-spacing-2);background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);margin-bottom:var(--md-sys-spacing-4);border-bottom:none}.admin-tabs .tab{flex:1;padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);border-radius:var(--md-sys-shape-corner-medium);border-bottom:none;text-align:center;transition:all .2s cubic-bezier(.2,0,0,1)}.admin-tabs .tab.active{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.admin-tabs .tab:not(.active){color:var(--md-sys-color-on-surface-variant)}.admin-content{background:transparent;border-radius:0;padding:0;box-shadow:none}.tab-content{padding:0;background:transparent;box-shadow:none}.list-header{flex-direction:column;align-items:stretch;gap:var(--md-sys-spacing-3);margin-bottom:var(--md-sys-spacing-4)}.list-header h2{font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);color:var(--md-sys-color-on-surface);margin:0}.header-actions{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.user-count,.family-count{font-size:var(--md-sys-typescale-label-medium-size);color:var(--md-sys-color-on-surface-variant);background-color:var(--md-sys-color-surface-container);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-3);border-radius:var(--md-sys-shape-corner-small);text-align:center}.users-table,.feeds-table,.invites-table,.families-table{display:flex;flex-direction:column;gap:var(--md-sys-spacing-3);background:transparent;border-radius:0}.users-table thead,.feeds-table thead,.invites-table thead,.families-table thead{display:none}.users-table tbody,.feeds-table tbody,.invites-table tbody,.families-table tbody{display:flex;flex-direction:column;gap:var(--md-sys-spacing-3)}.users-table tr,.feeds-table tr,.invites-table tr,.families-table tr{display:flex;flex-direction:column;background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);padding:var(--md-sys-spacing-4);gap:var(--md-sys-spacing-3);box-shadow:var(--md-sys-elevation-1);border:none}.users-table td,.feeds-table td,.invites-table td,.families-table td{display:flex;justify-content:space-between;align-items:center;padding:0;border:none;min-height:auto;font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface)}.users-table td:first-child,.feeds-table td:first-child,.invites-table td:first-child,.families-table td:first-child{font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight);color:var(--md-sys-color-on-surface);padding-bottom:var(--md-sys-spacing-2);border-bottom:1px solid var(--md-sys-color-outline-variant);margin-bottom:var(--md-sys-spacing-1)}.users-table td:before,.feeds-table td:before,.invites-table td:before,.families-table td:before{content:attr(data-label);font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);color:var(--md-sys-color-on-surface-variant);text-transform:uppercase;letter-spacing:.5px}.users-table td:first-child:before,.feeds-table td:first-child:before,.invites-table td:first-child:before,.families-table td:first-child:before{content:none}.users-table td.actions,.feeds-table td.actions,.invites-table td.actions,.families-table td.actions,.users-table td[data-label=Actions],.feeds-table td[data-label=Actions],.invites-table td[data-label=Actions],.families-table td[data-label=Actions]{flex-direction:column;align-items:stretch;gap:var(--md-sys-spacing-2);padding-top:var(--md-sys-spacing-3);border-top:1px solid var(--md-sys-color-outline-variant);margin-top:var(--md-sys-spacing-1)}.users-table td.actions:before,.feeds-table td.actions:before,.invites-table td.actions:before,.families-table td.actions:before,.users-table td[data-label=Actions]:before,.feeds-table td[data-label=Actions]:before,.invites-table td[data-label=Actions]:before,.families-table td[data-label=Actions]:before{content:none}.users-table .md-button,.feeds-table .md-button,.invites-table .md-button,.families-table .md-button{width:100%;justify-content:center;min-height:48px}.admin-badge{padding:var(--md-sys-spacing-1) var(--md-sys-spacing-3);font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);border-radius:var(--md-sys-shape-corner-full);background-color:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-on-surface-variant)}.admin-badge.is-admin{background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container)}.status-badge{padding:var(--md-sys-spacing-1) var(--md-sys-spacing-3);font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);border-radius:var(--md-sys-shape-corner-full)}.created-column{display:none!important}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--md-sys-spacing-3);margin-top:var(--md-sys-spacing-4);padding:var(--md-sys-spacing-3);background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large)}.pagination-info{font-size:var(--md-sys-typescale-label-large-size);color:var(--md-sys-color-on-surface-variant)}.admin-error{background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container);padding:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-medium);margin-bottom:var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-body-medium-size)}.admin-success{background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container);padding:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-medium);margin-bottom:var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-body-medium-size)}.admin-loading,.empty-message{text-align:center;padding:var(--md-sys-spacing-8);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-large-size);background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large)}.modal-overlay{align-items:flex-end;padding:0}.modal-content{width:100%;max-width:100%;max-height:90vh;border-radius:var(--md-sys-shape-corner-extra-large) var(--md-sys-shape-corner-extra-large) 0 0;padding:var(--md-sys-spacing-6);animation:slideUp .3s cubic-bezier(.2,0,0,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--md-sys-spacing-6)}.modal-header h2{font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);color:var(--md-sys-color-on-surface);margin:0}.modal-close{width:48px;height:48px;border:none;background:transparent;color:var(--md-sys-color-on-surface-variant);font-size:24px;cursor:pointer;border-radius:var(--md-sys-shape-corner-full);display:flex;align-items:center;justify-content:center}.modal-close:hover{background-color:var(--md-sys-color-surface-container-highest)}.modal-actions{flex-direction:column-reverse;gap:var(--md-sys-spacing-2);margin-top:var(--md-sys-spacing-6)}.modal-actions .md-button{width:100%;min-height:48px;justify-content:center}.form-group{margin-bottom:var(--md-sys-spacing-4)}.form-group label{font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);color:var(--md-sys-color-on-surface);margin-bottom:var(--md-sys-spacing-2);display:block}.form-group input,.form-group textarea{width:100%;min-height:48px}.password-reset-row td{padding:var(--md-sys-spacing-4)!important;background-color:var(--md-sys-color-surface-container-high);border-radius:var(--md-sys-shape-corner-medium)}.password-reset-form{display:flex;flex-direction:column;gap:var(--md-sys-spacing-3)}.password-reset-actions{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.password-reset-actions .md-button{width:100%;min-height:48px;justify-content:center}.helper-text{font-size:var(--md-sys-typescale-body-small-size);color:var(--md-sys-color-on-surface-variant);margin-top:var(--md-sys-spacing-1)}.color-picker-grid{grid-template-columns:repeat(4,1fr);gap:var(--md-sys-spacing-2)}.color-option{width:100%;aspect-ratio:1;height:auto}.custom-color-controls{flex-wrap:wrap}.custom-color-controls .md-button{flex:1;min-width:100px}}@media(max-width:480px){.admin-page{padding:var(--md-sys-spacing-3)}.admin-header h1{font-size:var(--md-sys-typescale-title-large-size)}.admin-tabs .tab{padding:var(--md-sys-spacing-2) var(--md-sys-spacing-3);font-size:var(--md-sys-typescale-label-medium-size)}.color-picker-grid{grid-template-columns:repeat(3,1fr)}}.settings-container{width:100%}.settings-header{margin-bottom:var(--md-sys-spacing-6)}.settings-header h1{font-size:var(--md-sys-typescale-headline-large-size);font-weight:var(--md-sys-typescale-headline-large-weight);line-height:var(--md-sys-typescale-headline-large-line-height);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-2) 0}.settings-header p{font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);color:var(--md-sys-color-on-surface-variant);margin:0}.settings-tabs{display:flex;gap:var(--md-sys-spacing-1);border-bottom:1px solid var(--md-sys-color-outline-variant);margin-bottom:var(--md-sys-spacing-6);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.settings-tabs::-webkit-scrollbar{display:none}.settings-tab{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-5);font-size:var(--md-sys-typescale-title-small-size);font-weight:var(--md-sys-typescale-title-small-weight);line-height:var(--md-sys-typescale-title-small-line-height);border:none;background:transparent;color:var(--md-sys-color-on-surface-variant);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s cubic-bezier(.2,0,0,1);white-space:nowrap;min-height:48px;display:flex;align-items:center;justify-content:center}.settings-tab:hover{background-color:var(--md-sys-color-surface-container);color:var(--md-sys-color-on-surface)}.settings-tab.active{color:var(--md-sys-color-primary);border-bottom-color:var(--md-sys-color-primary)}.settings-content{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);padding:var(--md-sys-spacing-6);box-shadow:var(--md-sys-elevation-1)}.settings-section{max-width:600px}.settings-section h2{font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);line-height:var(--md-sys-typescale-title-large-line-height);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-4) 0}.section-description{font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height);color:var(--md-sys-color-on-surface-variant);margin:0 0 var(--md-sys-spacing-5) 0}.settings-message{padding:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-medium);font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height);margin-bottom:var(--md-sys-spacing-5);display:flex;align-items:center;gap:var(--md-sys-spacing-3)}.settings-message.success{background-color:#81c78426;color:#81c784;border:1px solid rgba(129,199,132,.3)}.settings-message.error{background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container)}.settings-form{display:flex;flex-direction:column;gap:var(--md-sys-spacing-5)}.form-group label{font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-label-large-line-height);color:var(--md-sys-color-on-surface)}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password]{padding:var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-medium);background-color:var(--md-sys-color-surface-container-low);color:var(--md-sys-color-on-surface);transition:all .2s cubic-bezier(.2,0,0,1);outline:none;width:100%}.form-group small,.form-hint{font-size:var(--md-sys-typescale-body-small-size);line-height:var(--md-sys-typescale-body-small-line-height);color:var(--md-sys-color-on-surface-variant)}.color-group{display:flex;flex-direction:column;gap:var(--md-sys-spacing-3)}.color-picker-wrapper{display:flex;gap:var(--md-sys-spacing-4);align-items:flex-start;flex-wrap:wrap}.color-preview-item{display:flex;flex-direction:column;align-items:center;gap:var(--md-sys-spacing-2)}.color-preview-item input[type=color]{width:64px;height:64px;cursor:pointer;padding:0;border:2px solid var(--md-sys-color-outline-variant);border-radius:var(--md-sys-shape-corner-medium);background:transparent}.color-preview-item input[type=color]::-webkit-color-swatch-wrapper{padding:4px}.color-preview-item input[type=color]::-webkit-color-swatch{border:none;border-radius:var(--md-sys-shape-corner-small)}.color-swatch{width:64px;height:64px;border-radius:var(--md-sys-shape-corner-medium);border:2px solid var(--md-sys-color-outline-variant)}.color-label{font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);color:var(--md-sys-color-on-surface-variant)}.color-hex{font-size:var(--md-sys-typescale-label-small-size);font-family:Roboto Mono,monospace;color:var(--md-sys-color-on-surface);background-color:var(--md-sys-color-surface-container-high);padding:var(--md-sys-spacing-1) var(--md-sys-spacing-2);border-radius:var(--md-sys-shape-corner-extra-small)}.api-keys-section{width:100%;max-width:none}.api-keys-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--md-sys-spacing-5)}.api-keys-header h2{margin:0}.created-key-notice{background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container);padding:var(--md-sys-spacing-5);border-radius:var(--md-sys-shape-corner-medium);margin-bottom:var(--md-sys-spacing-5)}.created-key-notice h3{font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight);margin:0 0 var(--md-sys-spacing-2) 0}.created-key-notice p{font-size:var(--md-sys-typescale-body-medium-size);margin:0 0 var(--md-sys-spacing-4) 0;opacity:.9}.key-display{display:flex;gap:var(--md-sys-spacing-3);align-items:center;background-color:#0003;padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-small);margin-bottom:var(--md-sys-spacing-4);overflow-x:auto}.key-display code{font-family:Roboto Mono,monospace;font-size:var(--md-sys-typescale-body-medium-size);flex:1;word-break:break-all}.create-form{background-color:var(--md-sys-color-surface-container-high);padding:var(--md-sys-spacing-5);border-radius:var(--md-sys-shape-corner-medium);margin-bottom:var(--md-sys-spacing-5);display:flex;flex-direction:column;gap:var(--md-sys-spacing-4)}.create-form .form-row{display:flex;gap:var(--md-sys-spacing-4);align-items:flex-end}.create-form .form-row .form-group{flex:1}.keys-table{width:100%;border-collapse:collapse;background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-medium);overflow:hidden}.keys-table thead{background-color:var(--md-sys-color-surface-container-high)}.keys-table th{padding:var(--md-sys-spacing-4) var(--md-sys-spacing-5);text-align:left;font-size:var(--md-sys-typescale-title-small-size);font-weight:var(--md-sys-typescale-title-small-weight);color:var(--md-sys-color-on-surface);border-bottom:1px solid var(--md-sys-color-outline-variant)}.keys-table td{padding:var(--md-sys-spacing-4) var(--md-sys-spacing-5);font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface-variant);border-bottom:1px solid var(--md-sys-color-outline-variant);vertical-align:middle}.keys-table tr:last-child td{border-bottom:none}.keys-table tbody tr:hover{background-color:var(--md-sys-color-surface-container)}.keys-table td.actions{white-space:nowrap}.no-keys,.loading{text-align:center;padding:var(--md-sys-spacing-8);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-large-size)}.error-message{background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container);padding:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-medium);margin-bottom:var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-body-medium-size)}@media(max-width:768px){.settings-container{padding:var(--md-sys-spacing-4)}.settings-tabs{gap:var(--md-sys-spacing-2);padding:var(--md-sys-spacing-2);border-bottom:none;background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-full);margin-bottom:var(--md-sys-spacing-4)}.settings-tab{padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-full);border-bottom:none;font-size:var(--md-sys-typescale-label-large-size);min-height:40px}.settings-tab.active{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);border-bottom:none}.settings-tab:not(.active){color:var(--md-sys-color-on-surface-variant)}.settings-content{background:transparent;padding:0;box-shadow:none}.settings-section{max-width:100%}.keys-table{display:flex;flex-direction:column;gap:var(--md-sys-spacing-3);background:transparent}.keys-table thead{display:none}.keys-table tbody{display:flex;flex-direction:column;gap:var(--md-sys-spacing-3)}.keys-table tr{display:flex;flex-direction:column;background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-medium);padding:var(--md-sys-spacing-4);gap:var(--md-sys-spacing-2)}.keys-table td{display:flex;justify-content:space-between;align-items:center;padding:var(--md-sys-spacing-2) 0;border-bottom:none}.keys-table td:before{content:attr(data-label);font-weight:var(--md-sys-typescale-label-large-weight);color:var(--md-sys-color-on-surface)}.keys-table td.actions{justify-content:flex-end;padding-top:var(--md-sys-spacing-3);border-top:1px solid var(--md-sys-color-outline-variant);margin-top:var(--md-sys-spacing-2)}.keys-table td.actions:before{display:none}.api-keys-header{flex-direction:column;align-items:stretch;gap:var(--md-sys-spacing-3)}.create-form .form-row{flex-direction:column}.color-picker-wrapper{justify-content:center}}.login-page{min-height:max(520px,calc(100vh - 220px));display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--md-sys-color-primary-container) 0%,var(--md-sys-color-surface) 100%);padding:clamp(var(--md-sys-spacing-4),3vw,var(--md-sys-spacing-8));border-radius:var(--md-sys-shape-corner-extra-large)}.login-container{width:100%;max-width:440px;background-color:var(--md-sys-color-surface-container-high);border-radius:var(--md-sys-shape-corner-extra-large);padding:var(--md-sys-spacing-8);box-shadow:var(--md-sys-elevation-3)}.login-container h1{font-size:var(--md-sys-typescale-headline-large-size);font-weight:var(--md-sys-typescale-headline-large-weight);line-height:var(--md-sys-typescale-headline-large-line-height);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-6) 0;text-align:center}.login-form{display:flex;flex-direction:column;gap:var(--md-sys-spacing-5)}.form-group input{padding:var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-medium);background-color:var(--md-sys-color-surface-container-low);color:var(--md-sys-color-on-surface);transition:all .2s cubic-bezier(.2,0,0,1);outline:none}.form-group input:focus{border-color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container);box-shadow:0 0 0 1px var(--md-sys-color-primary)}.form-group input:disabled{opacity:.6;cursor:not-allowed}.error-message{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container);border-radius:var(--md-sys-shape-corner-medium);font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height)}.submit-button{padding:var(--md-sys-spacing-4) var(--md-sys-spacing-6);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-label-large-line-height);border:none;border-radius:var(--md-sys-shape-corner-full);background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);margin-top:var(--md-sys-spacing-2)}.submit-button:hover:not(:disabled){background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-2)}.submit-button:active:not(:disabled){box-shadow:var(--md-sys-elevation-1)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:var(--md-sys-spacing-6);text-align:center;font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height);color:var(--md-sys-color-on-surface-variant)}.login-footer a{color:var(--md-sys-color-primary);text-decoration:none;font-weight:var(--md-sys-typescale-label-large-weight);transition:color .2s}.login-footer a:hover{color:var(--md-sys-color-on-primary-container);text-decoration:underline}@media(max-width:480px){.login-container{padding:var(--md-sys-spacing-6)}.login-container h1{font-size:var(--md-sys-typescale-headline-medium-size)}}.calendar-feed-manager{padding:20px;max-width:800px;margin:0 auto;color:var(--text)}.calendar-feed-manager h2,.calendar-feed-manager h3{color:var(--text)}.feeds-list{margin-bottom:30px}.feed-card{border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:16px;background:var(--surface);color:var(--text)}.feed-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.feed-color-indicator{width:4px;height:48px;border-radius:2px;flex-shrink:0}.feed-info{flex:1;min-width:0}.feed-info h3{margin:0 0 4px;font-size:18px;color:var(--text);display:flex;align-items:center;gap:8px}.global-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background-color:#2d4a2f;color:#4caf50;border-radius:12px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.feed-url{margin:0;font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.feed-actions{display:flex;gap:6px;flex-shrink:0}.feed-status{display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:12px;color:var(--text-secondary);padding-left:16px}.feed-status-left{display:flex;gap:16px;align-items:center}.feed-status-right{display:flex;gap:8px;align-items:center}.feed-status .error{color:var(--danger)}.calendar-feed-manager button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.feed-actions button{padding:6px 12px;font-size:13px}.btn-enabled{background:var(--success);color:#fff;padding:4px 10px;font-size:12px}.btn-disabled{background:#9e9e9e;color:#fff;padding:4px 10px;font-size:12px}.btn-sync{background:var(--secondary);color:#fff}.btn-sync:hover{background:var(--secondary-dark)}.btn-refresh{background:var(--warning);color:#fff}.btn-refresh:hover{background:var(--warning-dark)}.btn-refresh:disabled{background:#ffb74d;cursor:not-allowed;opacity:.7}.btn-delete{background:var(--danger);color:#fff}.btn-delete:hover{background:var(--danger-dark)}.btn-primary{background:var(--secondary);color:#fff;width:100%;padding:12px}.btn-primary:hover{background:var(--secondary-dark)}.add-feed-form{border:1px solid var(--border);border-radius:8px;padding:20px;background:var(--surface);color:var(--text)}.add-feed-form h3{color:var(--text);margin-bottom:16px}.calendar-feed-manager .form-group{margin-bottom:16px}.calendar-feed-manager .form-group label{display:block;margin-bottom:4px;font-weight:500;color:var(--text)}.calendar-feed-manager .form-group input,.calendar-feed-manager .form-group select{width:100%;padding:8px;border:1px solid var(--border);border-radius:4px;font-size:14px;background:var(--background-secondary);color:var(--text)}.calendar-feed-manager .form-group input:focus,.calendar-feed-manager .form-group select:focus{outline:none;border-color:var(--secondary)}.calendar-feed-manager .form-group small{display:block;margin-top:4px;color:var(--text-secondary);font-size:12px}.color-picker{display:flex;gap:8px;align-items:center}.color-option{width:32px;height:32px;border-radius:50%;border:2px solid transparent;padding:0}.color-option.selected{border-color:var(--text);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--text)}.color-input{width:48px;height:32px;padding:0;border:none}.calendar-feed-manager .empty-state{text-align:center;color:var(--text-secondary);padding:40px}.calendar-feed-manager .loading{text-align:center;padding:40px;color:var(--text)}.calendar-page{width:100%;position:relative}.calendar-nav{display:flex;align-items:center;justify-content:space-between;gap:var(--md-sys-spacing-4);margin-bottom:var(--md-sys-spacing-5);flex-wrap:wrap;padding:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-extra-large);background:color-mix(in srgb,var(--md-sys-color-surface-container) 82%,transparent);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 16%,transparent);box-shadow:var(--md-sys-elevation-1)}.calendar-nav-row-primary,.calendar-nav-row-secondary{display:contents}.calendar-title{font-size:var(--md-sys-typescale-headline-medium-size);font-weight:var(--md-sys-typescale-headline-medium-weight);line-height:var(--md-sys-typescale-headline-medium-line-height);color:var(--md-sys-color-on-surface);margin:0}.calendar-date-navigation{display:flex;align-items:center;gap:var(--md-sys-spacing-2);background-color:var(--md-sys-color-surface-container);padding:var(--md-sys-spacing-2);border-radius:var(--md-sys-shape-corner-full);box-shadow:var(--md-sys-elevation-1);margin-left:auto;border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 16%,transparent)}.calendar-controls{display:flex;align-items:center;gap:var(--md-sys-spacing-4);flex-wrap:wrap;justify-content:flex-end}.calendar-date-navigation .md-icon-button{width:52px;height:52px;font-size:20px;font-weight:600;color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container-highest);border:none;border-radius:var(--md-sys-shape-corner-full);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.calendar-date-navigation .md-icon-button:hover:not(:disabled){background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.calendar-date-navigation .md-icon-button:disabled{opacity:.38;cursor:not-allowed}.date-picker{background-color:transparent;border:none;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight);padding:0 var(--md-sys-spacing-2);cursor:pointer;text-align:center;min-width:140px}.date-picker::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.calendar-nav .md-button-tonal{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-6);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);height:48px;min-height:48px;border:none;border-radius:var(--md-sys-shape-corner-large);background-color:var(--md-sys-color-surface-container);color:var(--md-sys-color-primary);box-shadow:var(--md-sys-elevation-1);transition:all .2s;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.calendar-nav .md-button-tonal:hover:not(:disabled){box-shadow:var(--md-sys-elevation-2);background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.calendar-nav .md-button-tonal:disabled{opacity:.38;cursor:not-allowed}.calendar-nav .md-icon-button.menu-button{width:48px;height:48px;min-width:48px;min-height:48px;color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container);border:none;border-radius:var(--md-sys-shape-corner-large);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;box-shadow:var(--md-sys-elevation-1);flex-shrink:0}.calendar-nav .md-icon-button.menu-button:hover{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-2)}.mobile-view-select{display:none}.md-select{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);background-color:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-on-surface);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-medium);font-size:var(--md-sys-typescale-body-medium-size);font-weight:var(--md-sys-typescale-body-medium-weight);line-height:var(--md-sys-typescale-body-medium-line-height);cursor:pointer;transition:all .2s;min-height:44px;font-family:inherit}.desktop-view-switcher{display:flex;gap:0;background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);overflow:hidden;box-shadow:var(--md-sys-elevation-1);height:48px}.view-btn{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);height:48px;min-height:48px;border:none;background:none;color:var(--md-sys-color-on-surface-variant);cursor:pointer;font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);transition:all .2s;min-width:64px}.view-btn.active{background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.view-btn:hover:not(.active){background-color:var(--md-sys-color-surface-container-highest)}.calendar-content{display:grid;grid-template-columns:3fr 1fr;gap:var(--md-sys-spacing-5)}.btn-primary{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-5);background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);border:none;border-radius:var(--md-sys-shape-corner-large);cursor:pointer;font-weight:var(--md-sys-typescale-label-large-weight);font-size:var(--md-sys-typescale-label-large-size);transition:all .2s;box-shadow:var(--md-sys-elevation-1)}.btn-primary:hover{background-color:var(--md-sys-color-primary);box-shadow:var(--md-sys-elevation-2)}.btn-secondary{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-5);background-color:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-primary);border:none;border-radius:var(--md-sys-shape-corner-large);cursor:pointer;font-weight:var(--md-sys-typescale-label-large-weight);font-size:var(--md-sys-typescale-label-large-size);transition:all .2s}.btn-secondary:hover{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.calendar{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);padding:var(--md-sys-spacing-3);box-shadow:var(--md-sys-elevation-2);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 14%,transparent);max-width:1800px;width:100%;margin:0 auto}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);background-color:transparent;border-bottom:1px solid var(--md-sys-color-outline-variant);margin-bottom:var(--md-sys-spacing-3)}.calendar-header div{padding:var(--md-sys-spacing-3);text-align:center;font-weight:var(--md-sys-typescale-label-large-weight);font-size:var(--md-sys-typescale-label-small-size);color:var(--md-sys-color-on-surface-variant);text-transform:uppercase;letter-spacing:.5px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--md-sys-spacing-1);background-color:transparent;border-radius:var(--md-sys-shape-corner-medium);overflow:hidden}.calendar-day{background-color:var(--md-sys-color-surface-container-high);min-height:100px;max-height:150px;padding:var(--md-sys-spacing-2);position:relative;cursor:pointer;transition:all .2s;border-radius:var(--md-sys-shape-corner-small);box-shadow:0 6px 16px #0000001f;overflow:hidden;overflow-y:auto;border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 10%,transparent)}.calendar-day:hover{background-color:var(--md-sys-color-surface-container-highest);box-shadow:var(--md-sys-elevation-2);transform:translateY(-1px)}.calendar-day:focus-visible{outline:2px solid var(--md-sys-color-primary);outline-offset:2px}.calendar-day.empty,.calendar-day.other-month{background-color:transparent;box-shadow:none;opacity:0;pointer-events:none;min-height:0}.calendar-day.today{background-color:var(--md-sys-color-primary-container);box-shadow:var(--md-sys-elevation-2)}.calendar-day.today .day-number{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);border-radius:var(--md-sys-shape-corner-full);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;font-weight:var(--md-sys-typescale-label-large-weight)}.day-number{font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface);margin-bottom:var(--md-sys-spacing-1)}.day-events{display:flex;flex-direction:column;gap:var(--md-sys-spacing-1);margin-top:var(--md-sys-spacing-2)}.day-event{padding:var(--md-sys-spacing-1) var(--md-sys-spacing-2);background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);border-radius:var(--md-sys-shape-corner-small);font-size:var(--md-sys-typescale-body-small-size);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:3px solid var(--md-sys-color-secondary);cursor:pointer;transition:background-color .15s ease}.day-event:hover{background-color:var(--md-sys-color-secondary-container);filter:brightness(1.1)}.day-event:focus-visible{outline:2px solid var(--md-sys-color-primary);outline-offset:2px}.more-events{font-size:var(--md-sys-typescale-label-small-size);color:var(--md-sys-color-primary);padding:var(--md-sys-spacing-1) 0;font-weight:var(--md-sys-typescale-label-medium-weight)}.event-list{background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-large);padding:var(--md-sys-spacing-5);box-shadow:var(--md-sys-elevation-1);max-height:600px;overflow-y:auto}.event-list h3{margin:0 0 var(--md-sys-spacing-4) 0;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight)}.events{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.event-item{display:flex;gap:var(--md-sys-spacing-3);padding:var(--md-sys-spacing-3);border-radius:var(--md-sys-shape-corner-medium);position:relative;background-color:var(--md-sys-color-surface-container);transition:all .2s}.event-item:hover{background-color:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-1)}.event-color{width:4px;border-radius:var(--md-sys-shape-corner-full);flex-shrink:0}.event-details{flex:1;min-width:0}.event-title{font-weight:var(--md-sys-typescale-body-large-weight);font-size:var(--md-sys-typescale-body-medium-size);margin-bottom:var(--md-sys-spacing-1);cursor:pointer;color:var(--md-sys-color-on-surface);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-title:hover{color:var(--md-sys-color-primary)}.event-time{font-size:var(--md-sys-typescale-body-small-size);color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--md-sys-spacing-1)}.event-location{font-size:var(--md-sys-typescale-body-small-size);color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--md-sys-spacing-1);display:flex;align-items:center;gap:var(--md-sys-spacing-1)}.event-location .location-icon,.day-event-location .location-icon,.week-list-event-location .location-icon{flex-shrink:0;color:var(--md-sys-color-on-surface-variant)}.event-source{font-size:var(--md-sys-typescale-label-small-size);color:var(--md-sys-color-on-surface-variant);font-style:italic}.delete-btn{position:absolute;top:var(--md-sys-spacing-2);right:var(--md-sys-spacing-2);background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container);border:none;width:40px;height:40px;min-width:40px;min-height:40px;border-radius:var(--md-sys-shape-corner-full);cursor:pointer;padding:0;transition:all .2s;display:flex;align-items:center;justify-content:center}.delete-btn svg{width:18px;height:18px}.delete-btn:hover{background-color:var(--md-sys-color-error);color:var(--md-sys-color-on-error)}.empty-state{text-align:center;color:var(--md-sys-color-on-surface-variant);padding:var(--md-sys-spacing-10);font-size:var(--md-sys-typescale-body-medium-size)}.feed-filter-toggle{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);border:none;padding:var(--md-sys-spacing-3) var(--md-sys-spacing-5);border-radius:var(--md-sys-shape-corner-large);cursor:pointer;font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);transition:all .2s;box-shadow:var(--md-sys-elevation-1)}.feed-filter-toggle:hover{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);box-shadow:var(--md-sys-elevation-2)}.feed-filter-panel{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);padding:var(--md-sys-spacing-4);margin-bottom:var(--md-sys-spacing-4);box-shadow:var(--md-sys-elevation-2);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.feed-filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--md-sys-spacing-3);padding-bottom:var(--md-sys-spacing-3);border-bottom:1px solid var(--md-sys-color-outline-variant)}.feed-filter-header h4{margin:0;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight)}.close-filter-btn{background:none;border:none;color:var(--md-sys-color-on-surface-variant);cursor:pointer;padding:0;width:48px;height:48px;min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--md-sys-shape-corner-full);transition:all .2s}.close-filter-btn svg{width:24px;height:24px}.close-filter-btn:hover{background-color:var(--md-sys-color-surface-container-highest);color:var(--md-sys-color-on-surface)}.feed-filter-list{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.feed-filter-item{display:flex;align-items:center;gap:var(--md-sys-spacing-3);padding:var(--md-sys-spacing-3);background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-medium);cursor:pointer;transition:all .2s}.feed-filter-item:hover{background-color:var(--md-sys-color-surface-container-high)}.feed-filter-item input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--md-sys-color-primary)}.feed-color-indicator{width:16px;height:16px;border-radius:var(--md-sys-shape-corner-full);flex-shrink:0;border:2px solid var(--md-sys-color-outline-variant)}.feed-name{flex:1;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-body-medium-size)}.feed-badge{background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container);padding:var(--md-sys-spacing-1) var(--md-sys-spacing-3);border-radius:var(--md-sys-shape-corner-full);font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight)}.calendar-page .modal-overlay{position:fixed!important;inset:0!important;background-color:#0009!important;background:#0009!important;opacity:1!important;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out;padding:var(--md-sys-spacing-4)}.calendar-page .modal-content{background-color:var(--md-sys-color-surface-container-high)!important;background:var(--md-sys-color-surface-container-high)!important;border-radius:var(--md-sys-shape-corner-extra-large);max-width:600px;width:90%;max-height:80vh;min-height:400px;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--md-sys-elevation-5);animation:slideUp .3s cubic-bezier(.4,0,.2,1);position:relative;z-index:1001;opacity:1!important}.calendar-page .modal-header{padding:var(--md-sys-spacing-5) var(--md-sys-spacing-6);border-bottom:1px solid var(--md-sys-color-outline-variant);display:flex;justify-content:space-between;align-items:center;background-color:transparent!important;flex-shrink:0}.calendar-page .modal-header h2{margin:0;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-headline-medium-size);font-weight:var(--md-sys-typescale-headline-medium-weight)}.calendar-page .close-btn{background:none;border:none;cursor:pointer;color:var(--md-sys-color-on-surface-variant);width:48px;height:48px;min-width:48px;min-height:48px;border-radius:var(--md-sys-shape-corner-full);transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.calendar-page .close-btn svg{width:24px;height:24px}.calendar-page .close-btn:hover{background-color:var(--md-sys-color-surface-container-highest);color:var(--md-sys-color-on-surface)}.calendar-page .modal-body{padding:var(--md-sys-spacing-6);background-color:transparent!important;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0}.calendar-page form{display:flex;flex-direction:column;gap:var(--md-sys-spacing-3);height:100%}.calendar-page .form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--md-sys-spacing-3)}.calendar-page .form-group{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.calendar-page .form-group label{color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-body-medium-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-body-medium-line-height)}.calendar-page .form-group label input[type=checkbox]{margin-right:var(--md-sys-spacing-2);width:auto;cursor:pointer}.calendar-page .form-group input,.calendar-page .form-group textarea,.calendar-page .form-group select{width:100%;padding:var(--md-sys-spacing-3);background-color:var(--md-sys-color-surface-container-highest);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-extra-small);color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height);font-family:inherit;transition:all .2s;outline:none;min-height:44px}.calendar-page .form-group input::placeholder,.calendar-page .form-group textarea::placeholder{color:var(--md-sys-color-on-surface-variant);opacity:.7}.calendar-page .form-group input:focus,.calendar-page .form-group textarea:focus,.calendar-page .form-group select:focus{border-color:var(--md-sys-color-primary);box-shadow:0 0 0 1px var(--md-sys-color-primary)}.calendar-page .form-group textarea{min-height:80px;resize:vertical;padding:var(--md-sys-spacing-3)}.calendar-page .form-actions{display:flex;gap:var(--md-sys-spacing-3);justify-content:flex-end;padding-top:var(--md-sys-spacing-4);margin-top:auto;border-top:1px solid var(--md-sys-color-outline-variant);flex-shrink:0}.calendar-page .form-actions button{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-8);border:none;border-radius:var(--md-sys-shape-corner-full);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);cursor:pointer;transition:all .2s;min-width:100px;height:40px;display:inline-flex;align-items:center;justify-content:center}.calendar-page .form-actions .md-button-filled{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);box-shadow:var(--md-sys-elevation-1)}.calendar-page .form-actions .md-button-filled:hover{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-2)}.calendar-page .form-actions .md-button-filled:disabled{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);opacity:.38;cursor:not-allowed;box-shadow:none}.calendar-page .form-actions .md-button-text{background-color:transparent;color:var(--md-sys-color-primary)}.calendar-page .form-actions .md-button-text:hover{background-color:var(--md-sys-color-surface-container-highest)}.calendar-page .color-picker{display:flex;gap:var(--md-sys-spacing-2);flex-wrap:wrap;padding:var(--md-sys-spacing-1) 0}.calendar-page .color-option{width:40px;height:40px;border-radius:var(--md-sys-shape-corner-full);border:3px solid transparent;cursor:pointer;transition:all .2s;padding:0;position:relative;flex-shrink:0}.calendar-page .color-option:hover{transform:scale(1.1);box-shadow:var(--md-sys-elevation-2)}.calendar-page .color-option.selected{border-color:var(--md-sys-color-on-surface);box-shadow:var(--md-sys-elevation-3)}.calendar-page .color-option.selected:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:20px;font-weight:700;text-shadow:0 0 3px rgba(0,0,0,.5)}.week-view{width:100%}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--md-sys-spacing-2);width:100%}.desktop-week-grid{display:grid}.mobile-week-list{display:none}.week-day{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-medium);overflow:hidden;display:flex;flex-direction:column;min-height:300px;max-height:calc(100vh - 280px);box-shadow:var(--md-sys-elevation-1);transition:all .2s}.week-day:hover{box-shadow:var(--md-sys-elevation-2)}.week-day.today{background-color:var(--md-sys-color-primary-container);box-shadow:var(--md-sys-elevation-2)}.week-day-header{padding:var(--md-sys-spacing-2) var(--md-sys-spacing-2);background-color:var(--md-sys-color-surface-container-high);border-bottom:1px solid var(--md-sys-color-outline-variant);text-align:center;flex-shrink:0}.week-day.today .week-day-header{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary)}.week-day-name{font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);text-transform:uppercase;color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--md-sys-spacing-1);letter-spacing:.5px}.week-day.today .week-day-name{color:var(--md-sys-color-on-primary)}.week-day-number{font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight);color:var(--md-sys-color-on-surface)}.week-day.today .week-day-number{color:var(--md-sys-color-on-primary)}.week-day-events{padding:var(--md-sys-spacing-2);flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.week-event{background-color:var(--md-sys-color-surface-container-highest);padding:var(--md-sys-spacing-2);border-radius:var(--md-sys-shape-corner-small);border-left:3px solid var(--md-sys-color-primary);cursor:pointer;transition:all .2s;box-shadow:var(--md-sys-elevation-1)}.week-event:hover{background-color:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-2);transform:translate(2px)}.week-event-time{font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--md-sys-spacing-1)}.week-event-title{font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface);font-weight:var(--md-sys-typescale-body-medium-weight);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.week-list-day{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-medium);padding:var(--md-sys-spacing-4);margin-bottom:var(--md-sys-spacing-3);box-shadow:var(--md-sys-elevation-1)}.week-list-day.today{background-color:var(--md-sys-color-primary-container);box-shadow:var(--md-sys-elevation-2)}.week-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--md-sys-spacing-3);padding-bottom:var(--md-sys-spacing-3);border-bottom:1px solid var(--md-sys-color-outline-variant)}.week-list-date{display:flex;flex-direction:column;gap:var(--md-sys-spacing-1)}.week-list-day-name{font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);color:var(--md-sys-color-on-surface);text-transform:uppercase}.week-list-day-short{font-size:var(--md-sys-typescale-body-small-size);color:var(--md-sys-color-on-surface-variant)}.overlap-indicator{background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container);padding:var(--md-sys-spacing-1) var(--md-sys-spacing-3);border-radius:var(--md-sys-shape-corner-full);font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight)}.week-list-events{display:flex;flex-direction:column;gap:var(--md-sys-spacing-3)}.week-list-empty{color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-medium-size);font-style:italic;padding:var(--md-sys-spacing-4);text-align:center}.week-list-event{display:flex;gap:var(--md-sys-spacing-3);cursor:pointer;padding:var(--md-sys-spacing-3);background-color:var(--md-sys-color-surface-container-high);border-radius:var(--md-sys-shape-corner-small);transition:all .2s}.week-list-event:hover{background-color:var(--md-sys-color-surface-container-highest);box-shadow:var(--md-sys-elevation-1)}.week-list-event-indicator{display:flex;flex-direction:column;align-items:center;width:8px}.week-list-event-dot{width:8px;height:8px;border-radius:var(--md-sys-shape-corner-full);flex-shrink:0}.week-list-event-line{width:2px;flex:1;background-color:var(--md-sys-color-outline-variant);margin-top:var(--md-sys-spacing-1)}.week-list-event-content{flex:1}.week-list-event-time{font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--md-sys-spacing-1)}.week-list-event-title{font-size:var(--md-sys-typescale-body-medium-size);font-weight:var(--md-sys-typescale-label-large-weight);color:var(--md-sys-color-on-surface);margin-bottom:var(--md-sys-spacing-1)}.week-list-event-location{font-size:var(--md-sys-typescale-body-small-size);color:var(--md-sys-color-on-surface-variant);display:flex;align-items:center;gap:var(--md-sys-spacing-1);margin-top:var(--md-sys-spacing-1)}@media(max-width:968px){.calendar-content{grid-template-columns:1fr}.event-list{order:-1;max-height:300px}.calendar-content-full .event-list{max-height:none;padding-bottom:50px}}@media(max-width:768px){.calendar-page{padding:var(--md-sys-spacing-2);padding-bottom:100px}.calendar-nav{flex-direction:column;gap:var(--md-sys-spacing-3)}.calendar-nav-row-primary{display:flex;align-items:center;justify-content:space-between;gap:var(--md-sys-spacing-4);width:100%}.calendar-nav-row-secondary{display:flex;align-items:center;gap:var(--md-sys-spacing-3);width:100%;justify-content:space-between}.calendar-title{font-size:var(--md-sys-typescale-title-large-size)}.calendar-date-navigation{flex-shrink:0}.calendar-date-navigation .md-icon-button{width:44px;height:44px}.date-picker{min-width:110px;font-size:var(--md-sys-typescale-body-medium-size)}.calendar-nav .md-button-tonal{height:44px;padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);flex:1}.desktop-view-switcher{display:none}.mobile-view-select{display:block;flex:1;min-width:100px}.calendar-nav .md-icon-button.menu-button{width:44px;height:44px}.calendar-day{min-height:80px;padding:var(--md-sys-spacing-1)}.calendar-page .md-fab{bottom:var(--md-sys-spacing-5);right:var(--md-sys-spacing-4)}.desktop-week-grid{display:none!important}.mobile-week-list{display:block}}.day-view{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);padding:var(--md-sys-spacing-6);box-shadow:var(--md-sys-elevation-1)}.day-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--md-sys-spacing-4);margin-bottom:var(--md-sys-spacing-4);border-bottom:1px solid var(--md-sys-color-outline-variant)}.day-header h3{margin:0;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);line-height:var(--md-sys-typescale-title-large-line-height)}.day-event-count{color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-medium-size);font-weight:var(--md-sys-typescale-body-medium-weight);line-height:var(--md-sys-typescale-body-medium-line-height)}.day-timeline{max-height:600px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--md-sys-color-outline-variant) transparent}.day-timeline::-webkit-scrollbar{width:8px}.day-timeline::-webkit-scrollbar-track{background:transparent}.day-timeline::-webkit-scrollbar-thumb{background-color:var(--md-sys-color-outline-variant);border-radius:var(--md-sys-shape-corner-full)}.day-hour{display:grid;grid-template-columns:80px 1fr;gap:var(--md-sys-spacing-4);padding:var(--md-sys-spacing-3) 0;border-bottom:1px solid var(--md-sys-color-surface-container-high);min-height:60px;align-items:start}.day-hour-label{font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);line-height:var(--md-sys-typescale-label-medium-line-height);color:var(--md-sys-color-on-surface-variant);text-align:right;padding-right:var(--md-sys-spacing-4);padding-top:var(--md-sys-spacing-1)}.day-hour-events{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.day-event-item{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);background-color:var(--md-sys-color-surface-container-highest);border-left:4px solid;border-radius:var(--md-sys-shape-corner-medium);cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);box-shadow:var(--md-sys-elevation-0)}.day-event-item:hover{background-color:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-1);transform:translate(2px)}.day-event-time{font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);line-height:var(--md-sys-typescale-label-small-line-height);color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--md-sys-spacing-1);display:block}.day-event-title{font-size:var(--md-sys-typescale-body-large-size);font-weight:var(--md-sys-typescale-body-large-weight);line-height:var(--md-sys-typescale-body-large-line-height);color:var(--md-sys-color-on-surface);display:block}.day-event-location{font-size:var(--md-sys-typescale-body-small-size);line-height:var(--md-sys-typescale-body-small-line-height);color:var(--md-sys-color-on-surface-variant);margin-top:var(--md-sys-spacing-1);display:flex;align-items:center;gap:var(--md-sys-spacing-1)}@media(max-width:768px){.day-view{padding:var(--md-sys-spacing-4)}.day-hour{grid-template-columns:60px 1fr;gap:var(--md-sys-spacing-2)}.day-hour-label{font-size:var(--md-sys-typescale-label-small-size);padding-right:var(--md-sys-spacing-2)}.day-timeline{max-height:500px}}.md-day-view-modal{background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-extra-large);width:90%;max-width:480px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--md-sys-elevation-3);animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.md-day-view-header{background:linear-gradient(135deg,var(--md-sys-color-primary-container) 0%,var(--md-sys-color-secondary-container) 100%);padding:var(--md-sys-spacing-6) var(--md-sys-spacing-6) var(--md-sys-spacing-5);display:flex;justify-content:space-between;align-items:flex-start;flex-shrink:0;position:relative}.md-day-view-date{display:flex;flex-direction:column;gap:var(--md-sys-spacing-1)}.md-day-view-weekday{font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight);color:var(--md-sys-color-on-primary-container);text-transform:uppercase;letter-spacing:.5px}.md-day-view-day-num{font-size:56px;font-weight:400;line-height:1;color:var(--md-sys-color-on-primary-container);letter-spacing:-2px}.md-day-view-month{font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);color:var(--md-sys-color-on-primary-container);margin-top:var(--md-sys-spacing-1)}.md-close-btn{background:var(--md-sys-color-surface-container-highest);border:none;width:48px;height:48px;min-width:48px;min-height:48px;border-radius:var(--md-sys-shape-corner-full);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--md-sys-color-on-surface);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--md-sys-elevation-1);padding:0}.md-close-btn svg{width:24px;height:24px}.md-close-btn:hover{background:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-2);transform:scale(1.05)}.md-close-btn:active{transform:scale(.95)}.md-day-view-content{flex:1;overflow-y:auto;padding:var(--md-sys-spacing-4) var(--md-sys-spacing-5);background-color:var(--md-sys-color-surface-container-low)}.md-day-view-event-count{font-size:var(--md-sys-typescale-title-small-size);font-weight:var(--md-sys-typescale-title-small-weight);color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--md-sys-spacing-4);padding-left:var(--md-sys-spacing-1);text-transform:uppercase;letter-spacing:.5px}.md-day-view-events{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.md-day-view-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--md-sys-spacing-10) var(--md-sys-spacing-4);color:var(--md-sys-color-on-surface-variant);text-align:center}.md-empty-icon{width:64px;height:64px;margin-bottom:var(--md-sys-spacing-4);opacity:.4;color:var(--md-sys-color-on-surface-variant)}.md-day-view-empty p{margin:0;font-size:var(--md-sys-typescale-body-large-size);color:var(--md-sys-color-on-surface-variant)}.md-day-event-card{background-color:var(--md-sys-color-surface-container-high);border-radius:var(--md-sys-shape-corner-medium);padding:var(--md-sys-spacing-4);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--md-sys-elevation-1);display:flex;gap:var(--md-sys-spacing-3);align-items:flex-start;position:relative;overflow:hidden}.md-day-event-card:hover{background-color:var(--md-sys-color-surface-container-highest);box-shadow:var(--md-sys-elevation-2);transform:translateY(-1px)}.md-day-event-card:active{transform:scale(.98)}.md-day-event-indicator{width:4px;height:100%;border-radius:var(--md-sys-shape-corner-full);flex-shrink:0;position:absolute;left:0;top:0;bottom:0}.md-day-event-content{flex:1;display:flex;flex-direction:column;gap:var(--md-sys-spacing-1);padding-left:var(--md-sys-spacing-3)}.md-day-event-time{font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);color:var(--md-sys-color-primary);letter-spacing:.3px}.md-day-event-title{font-size:var(--md-sys-typescale-body-large-size);font-weight:var(--md-sys-typescale-body-large-weight);color:var(--md-sys-color-on-surface);line-height:1.4}.md-day-event-location{display:flex;align-items:center;gap:var(--md-sys-spacing-1);font-size:var(--md-sys-typescale-body-small-size);color:var(--md-sys-color-on-surface-variant);margin-top:var(--md-sys-spacing-1)}.md-location-icon{width:16px;height:16px;color:var(--md-sys-color-on-surface-variant)}@media(max-width:768px){.md-day-view-modal{max-width:100%;width:95%;max-height:90vh}.md-day-view-header{padding:var(--md-sys-spacing-5) var(--md-sys-spacing-5) var(--md-sys-spacing-4)}.md-day-view-day-num{font-size:48px}.md-day-view-content{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4)}.md-day-event-card{padding:var(--md-sys-spacing-3)}}@media(max-width:480px){.md-day-view-modal{width:100%;max-height:95vh;border-radius:var(--md-sys-shape-corner-large) var(--md-sys-shape-corner-large) 0 0}.md-day-view-header{padding:var(--md-sys-spacing-4)}.md-day-view-day-num{font-size:40px}}.md-event-modal-overlay{z-index:1100!important}.md-event-modal{background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-extra-large);max-width:480px;width:90%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--md-sys-elevation-3);animation:slideUp .3s cubic-bezier(.4,0,.2,1);z-index:1101}.md-event-header{background:linear-gradient(135deg,var(--md-sys-color-primary-container) 0%,var(--md-sys-color-secondary-container) 100%);padding:var(--md-sys-spacing-5);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.md-event-title{font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);color:var(--md-sys-color-on-primary-container);margin:0}.md-event-close-btn{background:var(--md-sys-color-surface-container-highest);border:none;width:40px;height:40px;min-width:40px;min-height:40px;border-radius:var(--md-sys-shape-corner-full);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--md-sys-color-on-surface);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--md-sys-elevation-1);padding:0}.md-event-close-btn svg{width:24px;height:24px}.md-event-close-btn:hover{background:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-2);transform:scale(1.05)}.md-event-close-btn:active{transform:scale(.95)}.md-event-content{flex:1;overflow-y:auto;padding:var(--md-sys-spacing-5);background-color:var(--md-sys-color-surface-container-low)}.md-event-section{margin-bottom:var(--md-sys-spacing-4);padding-bottom:var(--md-sys-spacing-4);border-bottom:1px solid var(--md-sys-color-outline-variant)}.md-event-name{font-size:var(--md-sys-typescale-headline-small-size);font-weight:var(--md-sys-typescale-headline-small-weight);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-2) 0;line-height:1.3}.md-event-time{font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--md-sys-spacing-2)}.md-event-source{font-size:var(--md-sys-typescale-body-small-size);color:var(--md-sys-color-on-surface-variant)}.md-source-label{font-weight:var(--md-sys-typescale-label-medium-weight);color:var(--md-sys-color-primary)}.md-event-detail-section{margin-bottom:var(--md-sys-spacing-4)}.md-detail-label{font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);color:var(--md-sys-color-on-surface-variant);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--md-sys-spacing-2)}.md-detail-value{font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface);line-height:1.5;display:flex;align-items:flex-start;gap:var(--md-sys-spacing-2)}.md-detail-value svg{flex-shrink:0;margin-top:2px;color:var(--md-sys-color-primary)}.md-event-actions{display:flex;justify-content:flex-end;gap:var(--md-sys-spacing-3);padding-top:var(--md-sys-spacing-4);border-top:1px solid var(--md-sys-color-outline-variant);flex-wrap:wrap}.md-sync-notice{width:100%;padding:var(--md-sys-spacing-3);background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);border-radius:var(--md-sys-shape-corner-medium);font-size:var(--md-sys-typescale-body-small-size);text-align:center}@media(max-width:768px){.md-event-modal{max-width:95%}.md-event-header,.md-event-content{padding:var(--md-sys-spacing-4)}.md-event-actions{flex-direction:column-reverse}.md-event-actions button{width:100%;justify-content:center}}.contacts-page{width:100%}.contacts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--md-sys-spacing-6)}.contacts-title{margin:0;font-size:var(--md-sys-typescale-headline-medium-size);font-weight:var(--md-sys-typescale-headline-medium-weight);line-height:var(--md-sys-typescale-headline-medium-line-height);color:var(--md-sys-color-on-surface)}.contacts-toolbar{display:flex;gap:var(--md-sys-spacing-3);margin-bottom:var(--md-sys-spacing-5);padding:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-large);background-color:var(--md-sys-color-surface-container);box-shadow:var(--md-sys-elevation-1);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 16%,transparent)}.md-search-input{flex:1;padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-medium);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);background-color:var(--md-sys-color-surface-container-low);color:var(--md-sys-color-on-surface);transition:all .2s;min-height:48px}.md-search-input:focus{outline:none;border-color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container-highest)}.md-select{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);background-color:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-on-surface);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-medium);font-size:var(--md-sys-typescale-body-medium-size);font-weight:var(--md-sys-typescale-body-medium-weight);line-height:var(--md-sys-typescale-body-medium-line-height);cursor:pointer;transition:all .2s;min-height:48px;font-family:inherit}.md-select:hover{background-color:var(--md-sys-color-surface-container-highest);border-color:var(--md-sys-color-primary)}.md-select:focus{outline:none;border-color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container-highest)}.md-button-filled{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-6);background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);border:none;border-radius:var(--md-sys-shape-corner-large);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);cursor:pointer;transition:all .2s;box-shadow:var(--md-sys-elevation-1);min-height:40px}.contacts-list{background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-large);overflow:hidden;box-shadow:var(--md-sys-elevation-1);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 14%,transparent)}.contact-group{border-bottom:1px solid var(--md-sys-color-outline-variant)}.contact-group:last-child{border-bottom:none}.group-header{background-color:var(--md-sys-color-surface-container);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);font-weight:var(--md-sys-typescale-label-large-weight);font-size:var(--md-sys-typescale-label-large-size);line-height:var(--md-sys-typescale-label-large-line-height);color:var(--md-sys-color-on-surface-variant);text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:1}.contact-card{display:flex;align-items:center;gap:var(--md-sys-spacing-4);padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);cursor:pointer;transition:background-color .2s;border-bottom:1px solid var(--md-sys-color-outline-variant)}.contact-card:last-child{border-bottom:none}.contact-card:hover{background-color:var(--md-sys-color-surface-container-highest);box-shadow:inset 0 1px #ffffff05}.contact-avatar{flex-shrink:0;width:48px;height:48px;border-radius:var(--md-sys-shape-corner-full);overflow:hidden;background-color:var(--md-sys-color-primary-container);display:flex;align-items:center;justify-content:center}.contact-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight)}.contact-info{flex:1;min-width:0}.contact-name{font-weight:600;font-size:16px;color:var(--text);margin-bottom:4px}.contact-meta{font-size:14px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edit-btn-small{padding:6px 12px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text);font-size:14px;cursor:pointer;transition:background .2s,border-color .2s}.edit-btn-small:hover{background:var(--background-secondary);border-color:var(--primary)}.empty-state{text-align:center;padding:60px 20px;background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);box-shadow:var(--md-sys-elevation-1)}.empty-state p{color:var(--text-secondary);font-size:16px;margin-bottom:20px}.loading{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px;background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--surface);border-radius:12px;max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 12px #0000004d;overflow:hidden}.contact-form.modal-content{max-height:85vh}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;font-size:22px;font-weight:600}.close-btn{background:none;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1;transition:color .2s}.close-btn:hover{color:var(--text)}.modal-body{flex:1;overflow-y:auto;padding:24px;min-height:0}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border)}.contact-details-header{text-align:center;margin-bottom:32px}.contact-photo-large{width:100px;height:100px;border-radius:50%;margin:0 auto 16px;overflow:hidden;object-fit:cover}.contact-photo-large.avatar-placeholder{font-size:48px}.contact-details-header h3{margin:0 0 8px;font-size:24px;font-weight:600}.contact-details-header .organization,.contact-details-header .job-title{color:var(--text-secondary);margin:0}.detail-section{margin-bottom:24px}.detail-section h4{margin:0 0 12px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.detail-item{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.detail-item:last-child{border-bottom:none}.detail-label{min-width:80px;font-size:14px;color:var(--text-secondary);text-transform:capitalize}.detail-value{flex:1;font-size:15px;color:var(--text);text-decoration:none}.detail-value:hover{color:var(--primary)}.detail-value.notes{white-space:pre-wrap;word-break:break-word}.contact-form .modal-body{padding:16px 24px;overflow-y:auto;max-height:calc(85vh - 140px)}.form-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}.form-section:last-child{border-bottom:none;padding-bottom:0}.form-section h3{margin:0 0 16px;font-size:16px;font-weight:600;display:flex;justify-content:space-between;align-items:center}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:var(--text)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:15px;background:var(--surface);color:var(--text);font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary)}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1;margin-bottom:0}.multi-field-group{display:flex;gap:8px;margin-bottom:12px;align-items:center}.multi-field-group select{flex:0 0 120px;padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;background:var(--surface);color:var(--text)}.multi-field-group input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:15px;background:var(--surface);color:var(--text)}.btn-icon{background:none;border:none;color:var(--primary);font-size:24px;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;line-height:1;transition:transform .2s}.btn-icon:hover{transform:scale(1.1)}.btn-remove{background:none;border:none;color:var(--text-secondary);font-size:28px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1;transition:color .2s}.btn-remove:hover:not(:disabled){color:#dc3545}.btn-remove:disabled{opacity:.3;cursor:not-allowed}.address-group{padding:16px;background:var(--background-secondary);border-radius:8px;margin-bottom:12px}.address-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.address-header select{padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:15px;background:var(--surface);color:var(--text);font-family:inherit}.address-group input{width:100%;padding:10px 12px;margin-bottom:12px;border:1px solid var(--border);border-radius:6px;font-size:15px;background:var(--surface);color:var(--text);font-family:inherit}.address-group input:focus{outline:none;border-color:var(--primary)}.address-group .form-row{display:flex;gap:12px;margin-bottom:12px}.address-group .form-row input{flex:1;margin-bottom:0}.address-group .form-row input:last-child{margin-bottom:0}.address-group>input:last-of-type,.address-group>.form-row:last-child{margin-bottom:0}.btn-primary{background:var(--primary);color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:15px;font-weight:500;cursor:pointer;transition:opacity .2s,transform .2s}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border);padding:10px 20px;border-radius:6px;font-size:15px;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s}.btn-secondary:hover{background:var(--background-secondary);border-color:var(--text-secondary)}.btn-danger{background:#dc3545;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:15px;font-weight:500;cursor:pointer;transition:opacity .2s,transform .2s}.btn-danger:hover{opacity:.9;transform:translateY(-1px)}@media(max-width:768px){.contacts-page{padding:12px}.contacts-header{flex-direction:column;align-items:stretch;gap:12px}.contacts-header h1{font-size:24px}.add-contact-btn{width:100%;justify-content:center}.contacts-toolbar{flex-direction:column}.modal-content{max-height:95vh}.form-row{flex-direction:column}.form-row .form-group{margin-bottom:16px}.contact-card{padding:10px 12px}.contact-avatar{width:40px;height:40px}.avatar-placeholder{font-size:18px}.contact-name{font-size:15px}.contact-meta{font-size:13px}}.md-contact-modal{background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-extra-large);width:90%;max-width:440px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--md-sys-elevation-3);animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.md-contact-header{background:linear-gradient(135deg,var(--md-sys-color-primary-container) 0%,var(--md-sys-color-tertiary-container) 100%);padding:var(--md-sys-spacing-5);display:flex;flex-direction:column;align-items:center;position:relative;flex-shrink:0}.md-contact-close-btn{position:absolute;top:var(--md-sys-spacing-4);right:var(--md-sys-spacing-4);background:var(--md-sys-color-surface-container-highest);border:none;width:40px;height:40px;border-radius:var(--md-sys-shape-corner-full);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--md-sys-color-on-surface);font-size:24px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--md-sys-elevation-1);z-index:1}.md-contact-close-btn:hover{background:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-2);transform:scale(1.05)}.md-contact-close-btn:active{transform:scale(.95)}.md-contact-avatar-section{margin-bottom:var(--md-sys-spacing-3)}.md-contact-avatar{width:80px;height:80px;border-radius:var(--md-sys-shape-corner-full);overflow:hidden;object-fit:cover;box-shadow:var(--md-sys-elevation-2);background:var(--md-sys-color-surface-container-highest)}.md-avatar-placeholder{display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:500;color:var(--md-sys-color-on-primary-container);background:var(--md-sys-color-primary)}.md-contact-title-section{text-align:center}.md-contact-name{margin:0 0 var(--md-sys-spacing-1) 0;font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);color:var(--md-sys-color-on-primary-container);line-height:var(--md-sys-typescale-title-large-line-height)}.md-contact-org,.md-contact-job{margin:0;font-size:var(--md-sys-typescale-body-small-size);color:var(--md-sys-color-on-primary-container);opacity:.9;line-height:var(--md-sys-typescale-body-small-line-height)}.md-contact-content{flex:1;overflow-y:auto;padding:var(--md-sys-spacing-4);background-color:var(--md-sys-color-surface-container-low)}.md-contact-section{margin-bottom:var(--md-sys-spacing-3)}.md-contact-section:last-child{margin-bottom:0}.md-section-header{display:flex;align-items:center;gap:var(--md-sys-spacing-2);margin-bottom:var(--md-sys-spacing-2);padding-bottom:var(--md-sys-spacing-2);border-bottom:1px solid var(--md-sys-color-outline-variant)}.md-section-icon{width:18px;height:18px;color:var(--md-sys-color-primary);flex-shrink:0}.md-contact-modal .md-section-title{font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);color:var(--md-sys-color-on-surface-variant);text-transform:uppercase;letter-spacing:.5px}.md-contact-items{display:flex;flex-direction:column;gap:var(--md-sys-spacing-1)}.md-contact-item{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-medium);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-3);display:flex;flex-direction:column;gap:var(--md-sys-spacing-1);transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none;cursor:pointer;box-shadow:var(--md-sys-elevation-0)}.md-contact-item:hover{background-color:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-1);transform:translate(2px)}.md-contact-item:active{transform:scale(.98)}.md-item-label{font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);color:var(--md-sys-color-on-surface-variant);text-transform:uppercase;letter-spacing:.3px}.md-item-value{font-size:var(--md-sys-typescale-body-small-size);font-weight:var(--md-sys-typescale-body-small-weight);color:var(--md-sys-color-on-surface);line-height:var(--md-sys-typescale-body-small-line-height)}.md-item-value a{color:var(--md-sys-color-primary);text-decoration:none}.md-item-value a:hover{text-decoration:underline}.md-notes{white-space:pre-wrap;word-break:break-word;color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-small-size);line-height:1.4}.md-contact-actions{display:flex;justify-content:flex-end;gap:var(--md-sys-spacing-3);padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);border-top:1px solid var(--md-sys-color-outline-variant);background-color:var(--md-sys-color-surface-container-lowest);flex-shrink:0}.md-btn-text,.md-btn-filled{display:flex;align-items:center;gap:var(--md-sys-spacing-2);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-5);border:none;border-radius:var(--md-sys-shape-corner-full);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);height:40px}.md-btn-text svg,.md-btn-filled svg{width:18px;height:18px}.md-btn-text{background:transparent;color:var(--md-sys-color-on-surface)}.md-btn-text:hover{background:var(--md-sys-color-surface-container-highest)}.md-btn-text:active{transform:scale(.95)}.md-btn-danger:hover{background:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container)}.md-btn-filled{background:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);box-shadow:var(--md-sys-elevation-1)}.md-btn-filled:hover{background:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-2)}.md-btn-filled:active{transform:scale(.95);box-shadow:var(--md-sys-elevation-1)}@media(max-width:768px){.contacts-page{padding:var(--md-sys-spacing-4)}.contacts-page .md-fab{bottom:var(--md-sys-spacing-5);right:var(--md-sys-spacing-4)}.contacts-toolbar{flex-direction:column}.md-contact-modal{max-width:100%;width:95%;max-height:92vh}.md-contact-header{padding:var(--md-sys-spacing-5)}.md-contact-avatar{width:80px;height:80px}.md-avatar-placeholder{font-size:32px}.md-contact-content,.md-contact-actions{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4)}}@media(max-width:480px){.md-contact-modal{width:100%;max-height:95vh;border-radius:var(--md-sys-shape-corner-large) var(--md-sys-shape-corner-large) 0 0}.md-contact-header{padding:var(--md-sys-spacing-4)}.md-contact-avatar{width:72px;height:72px}.md-avatar-placeholder{font-size:28px}.md-contact-name{font-size:var(--md-sys-typescale-title-large-size)}.md-contact-actions{flex-direction:column;gap:var(--md-sys-spacing-2)}.md-btn-text,.md-btn-filled{width:100%;justify-content:center}}.home-page{width:min(1440px,100%);margin:0 auto;padding:clamp(var(--md-sys-spacing-4),2vw,var(--md-sys-spacing-8));display:flex;flex-direction:column;gap:var(--md-sys-spacing-4)}.home-page--empty{min-height:calc(100vh - 220px);justify-content:center}.home-hero{padding:clamp(var(--md-sys-spacing-4),1.2vw,var(--md-sys-spacing-5));display:grid;align-items:start;gap:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-medium);background:radial-gradient(circle at top right,color-mix(in srgb,var(--md-sys-color-primary) 16%,transparent),transparent 32%),linear-gradient(180deg,color-mix(in srgb,var(--md-sys-color-surface-container-high) 88%,transparent),var(--md-sys-color-surface-container-low))}.home-hero--collapsed{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:var(--md-sys-spacing-3)}.home-hero__content{max-width:720px}.home-hero__eyebrow,.home-section__eyebrow,.home-feeds__eyebrow{margin:0 0 var(--md-sys-spacing-1);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-medium-weight);letter-spacing:.08em;text-transform:uppercase}.home-hero__title{margin:0;font-size:clamp(1.7rem,1.35rem + 1vw,2.3rem);line-height:1.08;letter-spacing:-.04em;color:var(--md-sys-color-on-surface)}.home-hero__summary{margin:var(--md-sys-spacing-2) 0 0;max-width:52ch;font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface-variant)}.home-hero__aside{display:grid;gap:var(--md-sys-spacing-2);min-width:0}.home-hero__controls{display:flex;align-items:center;justify-content:flex-start;gap:var(--md-sys-spacing-2);min-width:0}.home-hero__actions{display:flex;flex-wrap:wrap;gap:var(--md-sys-spacing-2);justify-content:flex-start}.home-hero__actions .md-button{min-height:40px}.home-hero__collapse{flex-shrink:0}.home-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--md-sys-spacing-2);align-content:start}.home-stat{display:flex;align-items:center;gap:var(--md-sys-spacing-2);padding:calc(var(--md-sys-spacing-2) + 2px) var(--md-sys-spacing-3);border-radius:var(--md-sys-shape-corner-medium);min-width:0}.home-stat .md-symbol{font-size:1rem;color:var(--md-sys-color-primary)}.home-stat>div{min-width:0}.home-stat__value{margin:0;font-size:clamp(1rem,.95rem + .35vw,1.3rem);line-height:1;font-weight:700;color:var(--md-sys-color-on-surface);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-stat__label{margin:2px 0 0;color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-label-small-size)}.home-feeds{padding:clamp(var(--md-sys-spacing-4),2vw,var(--md-sys-spacing-6));border-radius:var(--md-sys-shape-corner-extra-large);background:color-mix(in srgb,var(--md-sys-color-surface-container) 82%,transparent);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 16%,transparent);box-shadow:var(--md-sys-elevation-1)}.home-feeds__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--md-sys-spacing-4);margin-bottom:var(--md-sys-spacing-4)}.home-feeds__header h3,.home-section__header h3{margin:0;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-title-large-size);line-height:var(--md-sys-typescale-title-large-line-height)}.home-feeds__empty{margin:0;padding:var(--md-sys-spacing-6);text-align:center;color:var(--md-sys-color-on-surface-variant)}.home-feed-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--md-sys-spacing-3)}.home-feed-item{display:flex;align-items:center;gap:var(--md-sys-spacing-3);padding:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-large);cursor:pointer;background:color-mix(in srgb,var(--md-sys-color-surface-container-high) 56%,transparent);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 14%,transparent);transition:transform .2s ease,background-color .2s ease,border-color .2s ease}.home-feed-item:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--md-sys-color-surface-container-highest) 78%,transparent);border-color:color-mix(in srgb,var(--md-sys-color-primary) 20%,transparent)}.home-feed-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--md-sys-color-primary)}.home-feed-item__dot{width:14px;height:14px;border-radius:var(--md-sys-shape-corner-full);flex-shrink:0}.home-feed-item__content{min-width:0;flex:1;display:flex;flex-direction:column}.home-feed-item__name{color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-body-large-size);font-weight:500}.home-feed-item__meta{color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-small-size)}.home-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--md-sys-spacing-3)}.home-section{padding:clamp(var(--md-sys-spacing-3),1.4vw,var(--md-sys-spacing-4));border-radius:var(--md-sys-shape-corner-large);background:color-mix(in srgb,var(--md-sys-color-surface-container) 84%,transparent);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 16%,transparent);box-shadow:var(--md-sys-elevation-1)}.home-section__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--md-sys-spacing-3);margin-bottom:var(--md-sys-spacing-4)}.home-section__state{min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--md-sys-spacing-3);text-align:center;color:var(--md-sys-color-on-surface-variant)}.home-section__state--error{color:var(--md-sys-color-error)}.home-event-list{list-style:none;display:flex;flex-direction:column;gap:var(--md-sys-spacing-3);margin:0;padding:0}.home-event-card{display:flex;gap:var(--md-sys-spacing-3);padding:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-large);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 14%,transparent);background:color-mix(in srgb,var(--md-sys-color-surface-container-highest) 72%,transparent)}.home-event-card__bar{width:6px;border-radius:var(--md-sys-shape-corner-full);flex-shrink:0}.home-event-card__body{min-width:0;flex:1}.home-event-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--md-sys-spacing-3)}.home-event-card__title{margin:0;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight)}.home-event-card__time{margin:var(--md-sys-spacing-1) 0 0;color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-medium-size)}.home-event-card__feed{flex-shrink:0;white-space:nowrap}.home-event-card__location{margin:var(--md-sys-spacing-3) 0 0;display:inline-flex;align-items:center;gap:var(--md-sys-spacing-2);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-small-size)}.home-empty-state{max-width:620px;margin:0 auto;padding:clamp(var(--md-sys-spacing-6),4vw,var(--md-sys-spacing-10));border-radius:var(--md-sys-shape-corner-extra-large);display:flex;flex-direction:column;align-items:center;gap:var(--md-sys-spacing-4);text-align:center}.home-empty-state>.md-symbol{font-size:48px;color:var(--md-sys-color-primary)}.home-empty-state h2{margin:0;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-headline-small-size)}.home-empty-state p{margin:0;color:var(--md-sys-color-on-surface-variant)}@media(min-width:1100px){.home-hero{grid-template-columns:minmax(0,1fr) auto;align-items:center}.home-hero__content{max-width:58ch}.home-hero__aside{align-self:center;justify-items:end}.home-hero__controls,.home-hero--collapsed .home-hero__controls,.home-hero__actions{justify-content:flex-end}.home-stats{grid-auto-flow:column;grid-auto-columns:minmax(126px,156px)}}.home-hero--collapsed .home-hero__content{max-width:none}.home-hero--collapsed .home-hero__title{font-size:clamp(1.18rem,1.08rem + .4vw,1.55rem);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-hero--collapsed .home-hero__controls,.home-hero--collapsed .home-hero__actions{flex-wrap:nowrap}@media(max-width:980px){.home-hero__aside,.home-stats,.home-grid{grid-template-columns:1fr}}@media(max-width:640px){.home-page{padding:var(--md-sys-spacing-4)}.home-hero,.home-feeds,.home-section,.home-empty-state{border-radius:var(--md-sys-shape-corner-medium)}.home-hero__actions,.home-section__header,.home-feeds__header,.home-event-card__header{flex-direction:column;align-items:stretch}.home-hero__actions .md-button{width:100%}.home-hero--collapsed{grid-template-columns:minmax(0,1fr) auto}.home-hero--collapsed .home-hero__controls{justify-content:flex-end}.home-hero--collapsed .home-hero__actions{flex-direction:row;align-items:center}.home-hero--collapsed .home-hero__actions .md-button{width:auto;min-height:36px;padding-inline:var(--md-sys-spacing-3)}.home-feed-list{grid-template-columns:1fr}.home-feed-item,.home-event-card{padding:var(--md-sys-spacing-2)}.home-stat{padding:6px var(--md-sys-spacing-2)}}.menu-page .modal-overlay{position:fixed!important;inset:0!important;background-color:#0009!important;background:#0009!important;opacity:1!important;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--md-sys-spacing-4);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.menu-page .modal-content{background-color:var(--md-sys-color-surface-container-high)!important;background:var(--md-sys-color-surface-container-high)!important;border-radius:var(--md-sys-shape-corner-extra-large);max-width:600px;width:100%;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--md-sys-elevation-5);animation:slideUp .3s cubic-bezier(.4,0,.2,1);position:relative;z-index:1001;opacity:1!important}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.menu-page .modal-header{padding:var(--md-sys-spacing-5) var(--md-sys-spacing-6);border-bottom:1px solid var(--md-sys-color-outline-variant);display:flex;justify-content:space-between;align-items:center;background-color:transparent!important;flex-shrink:0}.menu-page .modal-header h2{margin:0;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-headline-medium-size);font-weight:var(--md-sys-typescale-headline-medium-weight)}.menu-page .close-btn{background:none;border:none;font-size:32px;cursor:pointer;color:var(--md-sys-color-on-surface-variant);width:48px;height:48px;border-radius:var(--md-sys-shape-corner-full);transition:all .2s;display:flex;align-items:center;justify-content:center}.menu-page .close-btn:hover{background-color:var(--md-sys-color-surface-container-highest);color:var(--md-sys-color-on-surface)}.menu-page .modal-body{padding:var(--md-sys-spacing-6);background-color:transparent!important;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0}.menu-page .mode-tabs{display:flex;gap:var(--md-sys-spacing-2);margin-bottom:var(--md-sys-spacing-6);background-color:var(--md-sys-color-surface-container);padding:var(--md-sys-spacing-1);border-radius:var(--md-sys-shape-corner-full)}.menu-page .mode-tabs .tab{flex:1;background:none;border:none;padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);cursor:pointer;color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);border-radius:var(--md-sys-shape-corner-full);transition:all .2s}.menu-page .mode-tabs .tab:hover{background-color:var(--md-sys-color-surface-container-high)}.menu-page .mode-tabs .tab.active{background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.menu-page form{display:flex;flex-direction:column;gap:var(--md-sys-spacing-3);height:100%;min-height:0}.menu-page .form-group{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.menu-page .form-group label{color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-body-medium-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-body-medium-line-height)}.menu-page .form-group input,.menu-page .form-group textarea,.menu-page .form-group select,.menu-page .form-input{width:100%;padding:var(--md-sys-spacing-3);background-color:var(--md-sys-color-surface-container-highest);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-extra-small);color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height);font-family:inherit;transition:all .2s;outline:none;min-height:44px}.menu-page .form-group input::placeholder,.menu-page .form-group textarea::placeholder,.menu-page .form-input::placeholder{color:var(--md-sys-color-on-surface-variant);opacity:.7}.menu-page .form-group input:focus,.menu-page .form-group textarea:focus,.menu-page .form-group select:focus,.menu-page .form-input:focus{border-color:var(--md-sys-color-primary);box-shadow:0 0 0 1px var(--md-sys-color-primary)}.menu-page .form-group textarea,.menu-page textarea.form-input{min-height:80px;resize:vertical;padding:var(--md-sys-spacing-3)}.menu-page .recipe-mode{display:flex;flex-direction:column;flex:1;min-height:0;gap:var(--md-sys-spacing-3)}.menu-page .recipe-list{flex:1;min-height:120px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:var(--md-sys-spacing-1)}.menu-page .recipe-item{display:flex;align-items:center;gap:var(--md-sys-spacing-2);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-3);cursor:pointer;border-radius:var(--md-sys-shape-corner-small);background-color:var(--md-sys-color-surface-container);border:1px solid var(--md-sys-color-outline-variant);transition:all .2s cubic-bezier(.2,0,0,1);position:relative;flex-shrink:0;overflow:hidden;max-width:100%;box-sizing:border-box}.menu-page .recipe-item:before{content:"";position:absolute;inset:0;background:var(--md-sys-color-on-surface);opacity:0;transition:opacity .2s}.menu-page .recipe-item:hover:before{opacity:.08}.menu-page .recipe-item:hover{background-color:var(--md-sys-color-surface-container-high);border-color:var(--md-sys-color-outline)}.menu-page .recipe-item.selected{background-color:var(--md-sys-color-secondary-container);border-color:var(--md-sys-color-secondary)}.menu-page .recipe-item.selected:before{background:var(--md-sys-color-secondary)}.menu-page .recipe-thumb{width:40px;height:40px;object-fit:cover;border-radius:var(--md-sys-shape-corner-extra-small);flex-shrink:0;background-color:var(--md-sys-color-surface-container-highest)}.menu-page .recipe-item .recipe-info{flex:1;min-width:0;display:flex!important;flex-direction:column;gap:0;padding:0!important;margin:0!important;background:transparent!important;border-radius:0!important;grid-template-columns:none!important}.menu-page .recipe-title{font-size:var(--md-sys-typescale-body-medium-size);font-weight:var(--md-sys-typescale-label-large-weight);color:var(--md-sys-color-on-surface);line-height:1.3;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-page .recipe-item.selected .recipe-title{color:var(--md-sys-color-on-secondary-container)}.menu-page .recipe-description{font-size:var(--md-sys-typescale-body-small-size);line-height:1.2;color:var(--md-sys-color-on-surface-variant);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin:0}.menu-page .recipe-item.selected .recipe-description{color:var(--md-sys-color-on-secondary-container);opacity:.8}.menu-page .loading-recipes,.menu-page .no-recipes{padding:var(--md-sys-spacing-10);text-align:center;color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-medium-size)}.menu-page .modal-footer{display:flex;gap:var(--md-sys-spacing-3);justify-content:flex-end;padding-top:var(--md-sys-spacing-4);margin-top:auto;border-top:1px solid var(--md-sys-color-outline-variant);flex-shrink:0}.menu-page .modal-footer button{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-8);border:none;border-radius:var(--md-sys-shape-corner-full);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);cursor:pointer;transition:all .2s;min-width:100px;height:40px;display:inline-flex;align-items:center;justify-content:center}.menu-page .modal-footer .md-button-filled{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);box-shadow:var(--md-sys-elevation-1)}.menu-page .modal-footer .md-button-filled:hover{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-2)}.menu-page .modal-footer .md-button-filled:disabled{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);opacity:.38;cursor:not-allowed;box-shadow:none}.menu-page .modal-footer .md-button-text{background-color:transparent;color:var(--md-sys-color-primary)}.menu-page .modal-footer .md-button-text:hover{background-color:var(--md-sys-color-surface-container-highest)}@media(max-width:768px){.menu-page .modal-overlay{padding:0!important}.menu-page .modal-content{max-width:100%;max-height:100vh;border-radius:0}.menu-page .recipe-item{flex-direction:row}.menu-page .recipe-thumb{width:48px;height:48px;flex-shrink:0}}.menu-container{width:100%}.menu-header{display:flex;justify-content:flex-end;align-items:center;margin-bottom:var(--md-sys-spacing-6);flex-wrap:wrap;gap:var(--md-sys-spacing-4)}.menu-title{font-size:var(--md-sys-typescale-headline-medium-size);line-height:var(--md-sys-typescale-headline-medium-line-height);font-weight:var(--md-sys-typescale-headline-medium-weight);color:var(--md-sys-color-on-surface)}.menu-controls{display:flex;align-items:center;gap:var(--md-sys-spacing-4);padding:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-extra-large);background:color-mix(in srgb,var(--md-sys-color-surface-container) 82%,transparent);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 16%,transparent);box-shadow:var(--md-sys-elevation-1)}.menu-controls .md-button-tonal{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-6);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);height:48px;border:none;border-radius:var(--md-sys-shape-corner-large);background-color:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-primary);box-shadow:var(--md-sys-elevation-1);transition:all .2s}.menu-controls .md-button-tonal:hover{box-shadow:var(--md-sys-elevation-2);background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.week-navigation{display:flex;align-items:center;gap:var(--md-sys-spacing-2);background-color:var(--md-sys-color-surface-container);padding:var(--md-sys-spacing-2);border-radius:var(--md-sys-shape-corner-full);box-shadow:var(--md-sys-elevation-1)}.week-navigation .md-icon-button{width:48px;height:48px;font-size:20px;font-weight:600;color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container-highest)}.week-navigation .md-icon-button:hover{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.week-range{font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight);color:var(--md-sys-color-on-surface);padding:0 var(--md-sys-spacing-4);min-width:220px;text-align:center}.week-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--md-sys-spacing-4)}.day-card{background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-large);overflow:hidden;transition:all .2s;box-shadow:var(--md-sys-elevation-1);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 14%,transparent)}.day-card:hover{box-shadow:var(--md-sys-elevation-2)}.day-card.today{background-color:var(--md-sys-color-primary-container)}.day-card.today .day-header-content{color:var(--md-sys-color-on-primary-container)}.day-header{padding:var(--md-sys-spacing-4);background-color:var(--md-sys-color-surface-container);border-bottom:1px solid var(--md-sys-color-outline-variant)}.day-card.today .day-header{background-color:var(--md-sys-color-primary)}.day-card.today .day-header-content{color:var(--md-sys-color-on-primary)}.day-header-content h3{margin:0;font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);line-height:var(--md-sys-typescale-title-large-line-height);color:var(--md-sys-color-on-surface)}.day-date{font-size:var(--md-sys-typescale-body-medium-size);font-weight:var(--md-sys-typescale-body-medium-weight);color:var(--md-sys-color-on-surface-variant);margin-top:var(--md-sys-spacing-1)}.day-card.today .day-date{color:var(--md-sys-color-on-primary);opacity:.9}.meals{display:flex;flex-direction:column;gap:0;padding:var(--md-sys-spacing-2);min-height:100px}.meal-entry{background-color:var(--md-sys-color-surface-container-highest);border-radius:var(--md-sys-shape-corner-medium);padding:var(--md-sys-spacing-3);margin-bottom:var(--md-sys-spacing-2);transition:all .2s;position:relative;border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 14%,transparent)}.meal-entry:hover{background-color:var(--md-sys-color-surface-container-high);border-color:var(--md-sys-color-outline)}.meal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--md-sys-spacing-2)}.meal-type-badge{display:inline-flex;align-items:center;padding:var(--md-sys-spacing-1) var(--md-sys-spacing-3);background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container);border-radius:var(--md-sys-shape-corner-small);font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);line-height:var(--md-sys-typescale-label-small-line-height);text-transform:capitalize}.meal-actions{display:flex;gap:var(--md-sys-spacing-1)}.meal-title{font-size:var(--md-sys-typescale-body-large-size);font-weight:var(--md-sys-typescale-body-large-weight);line-height:var(--md-sys-typescale-body-large-line-height);color:var(--md-sys-color-on-surface);margin-bottom:var(--md-sys-spacing-1)}.meal-notes{font-size:var(--md-sys-typescale-body-small-size);line-height:var(--md-sys-typescale-body-small-line-height);color:var(--md-sys-color-on-surface-variant);font-style:italic;margin-top:var(--md-sys-spacing-1)}.btn-add-meal{width:100%;padding:var(--md-sys-spacing-3);background-color:transparent;border:1px dashed var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-medium);color:var(--md-sys-color-primary);cursor:pointer;font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);transition:all .2s;display:flex;align-items:center;justify-content:center;gap:var(--md-sys-spacing-2);min-height:48px}.btn-add-meal:hover{background-color:var(--md-sys-color-primary-container);border-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary-container);border-style:solid}.loading,.error{text-align:center;padding:var(--md-sys-spacing-10);font-size:var(--md-sys-typescale-body-large-size);color:var(--md-sys-color-on-surface-variant)}.error{color:var(--md-sys-color-error)}@media(max-width:768px){.menu-container{padding:var(--md-sys-spacing-4)}.week-grid{grid-template-columns:1fr}.menu-header{flex-direction:column;align-items:stretch;gap:var(--md-sys-spacing-3)}.menu-controls{flex-direction:column;gap:var(--md-sys-spacing-3);width:100%}.week-navigation{width:100%;justify-content:space-between}.menu-controls .md-button-tonal{width:100%;height:44px}}.shopping-modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--md-sys-spacing-4)}.shopping-modal-content{background-color:var(--md-sys-color-surface-container-high);border-radius:var(--md-sys-shape-corner-extra-large);max-width:560px;width:100%;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--md-sys-elevation-5)}.shopping-modal-header{padding:var(--md-sys-spacing-5) var(--md-sys-spacing-6);border-bottom:1px solid var(--md-sys-color-outline-variant);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.shopping-modal-header h2{margin:0;color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-headline-small-size);font-weight:var(--md-sys-typescale-headline-small-weight)}.shopping-modal-close-btn{background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--md-sys-color-on-surface-variant);width:40px;height:40px;border-radius:var(--md-sys-shape-corner-full);display:flex;align-items:center;justify-content:center;transition:background-color .2s;flex-shrink:0}.shopping-modal-close-btn:hover{background-color:var(--md-sys-color-surface-container-highest);color:var(--md-sys-color-on-surface)}.shopping-modal-body{padding:var(--md-sys-spacing-5) var(--md-sys-spacing-6);overflow-y:auto;flex:1;min-height:0}.shopping-modal-subtitle{margin:0 0 var(--md-sys-spacing-4) 0;color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-medium-size);line-height:1.5}.shopping-modal-subtitle strong{color:var(--md-sys-color-on-surface)}.shopping-modal-actions{display:flex;align-items:center;gap:var(--md-sys-spacing-3);margin-bottom:var(--md-sys-spacing-4);flex-wrap:wrap}.shopping-selection-count{margin-left:auto;color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-small-size);white-space:nowrap}.shopping-ingredients-list{display:flex;flex-direction:column;gap:var(--md-sys-spacing-1)}.shopping-checkbox-item{display:flex;align-items:center;gap:var(--md-sys-spacing-3);padding:var(--md-sys-spacing-3) var(--md-sys-spacing-3);border-radius:var(--md-sys-shape-corner-small);cursor:pointer;transition:background-color .2s;border:1px solid var(--md-sys-color-outline-variant);background-color:var(--md-sys-color-surface-container);-webkit-user-select:none;user-select:none}.shopping-checkbox-item:hover{background-color:var(--md-sys-color-surface-container-high)}.shopping-checkbox-item input[type=checkbox]{width:18px;height:18px;flex-shrink:0;accent-color:var(--md-sys-color-primary);cursor:pointer}.shopping-ingredient-text{color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-body-medium-size);line-height:1.4}.shopping-ingredient-text strong{color:var(--md-sys-color-on-surface)}.shopping-modal-footer{padding:var(--md-sys-spacing-4) var(--md-sys-spacing-6);border-top:1px solid var(--md-sys-color-outline-variant);display:flex;justify-content:flex-end;align-items:center;gap:var(--md-sys-spacing-3);flex-shrink:0}.shopping-btn{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-6);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);border:none;border-radius:var(--md-sys-shape-corner-full);cursor:pointer;transition:all .2s;min-height:40px;display:inline-flex;align-items:center;justify-content:center;min-width:80px}.shopping-btn-primary{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);box-shadow:var(--md-sys-elevation-1)}.shopping-btn-primary:hover:not(:disabled){background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-2)}.shopping-btn-primary:disabled{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);opacity:.38;cursor:not-allowed;box-shadow:none}.shopping-btn-text{background-color:transparent;color:var(--md-sys-color-primary)}.shopping-btn-text:hover{background-color:var(--md-sys-color-surface-container-highest)}.shopping-loading{text-align:center;padding:var(--md-sys-spacing-10);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-medium-size)}@media(max-width:768px){.shopping-modal-overlay{padding:0;align-items:flex-end}.shopping-modal-content{max-width:100%;max-height:90vh;border-radius:var(--md-sys-shape-corner-extra-large) var(--md-sys-shape-corner-extra-large) 0 0}}.recipe-detail{max-width:900px;margin:0 auto;padding:var(--md-sys-spacing-6);background-color:var(--md-sys-color-surface)}.recipe-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--md-sys-spacing-6);flex-wrap:wrap;gap:var(--md-sys-spacing-3)}.recipe-actions{display:flex;gap:var(--md-sys-spacing-2)}.recipe-detail-image{width:100%;height:400px;border-radius:var(--md-sys-shape-corner-large);overflow:hidden;margin-bottom:var(--md-sys-spacing-6);background-color:var(--md-sys-color-surface-container-highest);box-shadow:var(--md-sys-elevation-2)}.recipe-detail-image img{width:100%;height:100%;object-fit:cover}.md-recipe-detail-content{background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-extra-large);padding:var(--md-sys-spacing-8);box-shadow:var(--md-sys-elevation-2)}.md-recipe-header-section{margin-bottom:var(--md-sys-spacing-6)}.md-recipe-title{font-size:var(--md-sys-typescale-display-small-size);font-weight:var(--md-sys-typescale-display-small-weight);line-height:var(--md-sys-typescale-display-small-line-height);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-3) 0}.md-recipe-category-chip{display:inline-flex;align-items:center;padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);border-radius:var(--md-sys-shape-corner-small);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);text-transform:capitalize}.md-recipe-description{font-size:var(--md-sys-typescale-body-large-size);line-height:1.6;color:var(--md-sys-color-on-surface-variant);margin:var(--md-sys-spacing-6) 0}.md-recipe-meta-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--md-sys-spacing-3);margin-bottom:var(--md-sys-spacing-8)}.md-meta-card{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-medium);padding:var(--md-sys-spacing-4);display:flex;align-items:center;gap:var(--md-sys-spacing-3);box-shadow:var(--md-sys-elevation-1);transition:all .2s cubic-bezier(.4,0,.2,1)}.md-meta-card:hover{background-color:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-2);transform:translateY(-2px)}.md-meta-icon{width:32px;height:32px;color:var(--md-sys-color-primary);flex-shrink:0}.md-meta-content{display:flex;flex-direction:column;gap:var(--md-sys-spacing-1)}.md-meta-label{font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);color:var(--md-sys-color-on-surface-variant);text-transform:uppercase;letter-spacing:.5px}.md-meta-value{font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);color:var(--md-sys-color-on-surface)}.md-recipe-section{margin-bottom:var(--md-sys-spacing-8)}.md-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--md-sys-spacing-4);padding-bottom:var(--md-sys-spacing-3);border-bottom:2px solid var(--md-sys-color-outline-variant)}.md-section-title-wrapper{display:flex;align-items:center;gap:var(--md-sys-spacing-3)}.md-section-icon{width:28px;height:28px;color:var(--md-sys-color-primary)}.md-section-title{font-size:var(--md-sys-typescale-headline-medium-size);font-weight:var(--md-sys-typescale-headline-medium-weight);color:var(--md-sys-color-on-surface);margin:0}.md-btn-add-shopping{display:flex;align-items:center;gap:var(--md-sys-spacing-2);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container);border:none;border-radius:var(--md-sys-shape-corner-full);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--md-sys-elevation-1)}.md-btn-add-shopping svg{width:20px;height:20px}.md-btn-add-shopping:hover{background-color:var(--md-sys-color-tertiary);color:var(--md-sys-color-on-tertiary);box-shadow:var(--md-sys-elevation-2);transform:scale(1.02)}.md-btn-add-shopping:active{transform:scale(.98)}.md-ingredients-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--md-sys-spacing-1)}.md-ingredient-item{padding:var(--md-sys-spacing-2) var(--md-sys-spacing-3);display:flex;align-items:center;gap:var(--md-sys-spacing-2);border-left:3px solid var(--md-sys-color-primary-container);transition:border-color .2s cubic-bezier(.4,0,.2,1)}.md-ingredient-item:hover{border-left-color:var(--md-sys-color-primary)}.md-ingredient-check{display:none}.md-ingredient-text{font-size:var(--md-sys-typescale-body-medium-size);line-height:1.4;color:var(--md-sys-color-on-surface);flex:1}.md-ingredient-amount{color:var(--md-sys-color-primary);font-weight:var(--md-sys-typescale-label-large-weight)}.md-ingredient-unit{color:var(--md-sys-color-on-surface-variant)}.md-ingredient-name{color:var(--md-sys-color-on-surface)}.md-steps-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--md-sys-spacing-3)}.md-step-item{display:flex;gap:var(--md-sys-spacing-3);background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-medium);padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);box-shadow:var(--md-sys-elevation-1);transition:all .2s cubic-bezier(.4,0,.2,1)}.md-step-item:hover{box-shadow:var(--md-sys-elevation-2);transform:translateY(-1px)}.md-step-number{width:32px;height:32px;background:linear-gradient(135deg,var(--md-sys-color-primary) 0%,var(--md-sys-color-tertiary) 100%);color:var(--md-sys-color-on-primary);border-radius:var(--md-sys-shape-corner-full);display:flex;align-items:center;justify-content:center;font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight);flex-shrink:0;box-shadow:var(--md-sys-elevation-1)}.md-step-content{flex:1}.md-step-text{font-size:var(--md-sys-typescale-body-medium-size);line-height:1.5;color:var(--md-sys-color-on-surface);margin:0}.md-step-media{margin-top:var(--md-sys-spacing-3);border-radius:var(--md-sys-shape-corner-medium);overflow:hidden;box-shadow:var(--md-sys-elevation-1)}.md-step-media img,.md-step-media video{width:100%;display:block;border-radius:var(--md-sys-shape-corner-medium)}.md-recipe-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--md-sys-spacing-4)}.md-gallery-item{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);overflow:hidden;box-shadow:var(--md-sys-elevation-1);transition:all .2s cubic-bezier(.4,0,.2,1)}.md-gallery-item:hover{box-shadow:var(--md-sys-elevation-3);transform:translateY(-4px)}.md-gallery-item img,.md-gallery-item video{width:100%;height:200px;object-fit:cover;display:block}.md-media-caption{padding:var(--md-sys-spacing-3);font-size:var(--md-sys-typescale-body-medium-size);color:var(--md-sys-color-on-surface-variant);margin:0}.recipe-detail-content{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);padding:var(--md-sys-spacing-6);box-shadow:var(--md-sys-elevation-1)}.recipe-detail-content h1{font-size:var(--md-sys-typescale-headline-large-size);font-weight:var(--md-sys-typescale-headline-large-weight);line-height:var(--md-sys-typescale-headline-large-line-height);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-4) 0}.recipe-category-badge{display:inline-block;padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container);border-radius:var(--md-sys-shape-corner-full);font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);margin-bottom:var(--md-sys-spacing-4)}.recipe-description{font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--md-sys-spacing-6)}.recipe-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--md-sys-spacing-4);margin-bottom:var(--md-sys-spacing-6);padding:var(--md-sys-spacing-4);background-color:var(--md-sys-color-surface-container-high);border-radius:var(--md-sys-shape-corner-medium)}.meta-item{display:flex;flex-direction:column;gap:var(--md-sys-spacing-1)}.meta-label{font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);color:var(--md-sys-color-on-surface-variant);text-transform:uppercase}.meta-value{font-size:var(--md-sys-typescale-title-medium-size);font-weight:var(--md-sys-typescale-title-medium-weight);color:var(--md-sys-color-on-surface)}.recipe-section{margin-bottom:var(--md-sys-spacing-6)}.recipe-section h2{font-size:var(--md-sys-typescale-headline-small-size);font-weight:var(--md-sys-typescale-headline-small-weight);line-height:var(--md-sys-typescale-headline-small-line-height);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-4) 0}.ingredients-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.ingredients-list li{padding:var(--md-sys-spacing-3);background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-small);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);color:var(--md-sys-color-on-surface)}.steps-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--md-sys-spacing-3);counter-reset:step-counter}.steps-list li{counter-increment:step-counter;padding:var(--md-sys-spacing-4);background-color:var(--md-sys-color-surface-container-low);border-radius:var(--md-sys-shape-corner-medium);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);color:var(--md-sys-color-on-surface);position:relative;padding-left:var(--md-sys-spacing-12)}.steps-list li:before{content:counter(step-counter);position:absolute;left:var(--md-sys-spacing-4);top:var(--md-sys-spacing-4);width:32px;height:32px;background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);border-radius:var(--md-sys-shape-corner-full);display:flex;align-items:center;justify-content:center;font-weight:var(--md-sys-typescale-label-large-weight);font-size:var(--md-sys-typescale-label-large-size)}.recipe-form-container{max-width:900px;margin:0 auto;padding:var(--md-sys-spacing-6);background-color:var(--md-sys-color-surface)}.recipe-form{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);padding:var(--md-sys-spacing-6);box-shadow:var(--md-sys-elevation-1)}.recipe-form h1{font-size:var(--md-sys-typescale-headline-medium-size);font-weight:var(--md-sys-typescale-headline-medium-weight);line-height:var(--md-sys-typescale-headline-medium-line-height);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-6) 0}.form-section{margin-bottom:var(--md-sys-spacing-6)}.form-section h2{font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);line-height:var(--md-sys-typescale-title-large-line-height);color:var(--md-sys-color-on-surface);margin:0 0 var(--md-sys-spacing-4) 0}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--md-sys-spacing-4)}.form-group{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.form-group label{font-size:var(--md-sys-typescale-body-medium-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-body-medium-line-height);color:var(--md-sys-color-on-surface)}.form-group input[type=text],.form-group input[type=number],.form-group input[type=url],.form-group select,.form-group textarea{padding:var(--md-sys-spacing-3);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-medium);background-color:var(--md-sys-color-surface-container-low);color:var(--md-sys-color-on-surface);transition:all .2s cubic-bezier(.2,0,0,1);outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container);box-shadow:0 0 0 1px var(--md-sys-color-primary)}.form-group textarea{min-height:100px;resize:vertical;font-family:inherit}.dynamic-list{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.list-item{display:flex;gap:var(--md-sys-spacing-2);align-items:center}.list-item input{flex:1}.form-actions{display:flex;gap:var(--md-sys-spacing-3);justify-content:flex-end;margin-top:var(--md-sys-spacing-6);padding-top:var(--md-sys-spacing-6);border-top:1px solid var(--md-sys-color-outline-variant)}.btn{padding:var(--md-sys-spacing-3) var(--md-sys-spacing-6);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-label-large-line-height);border:none;border-radius:var(--md-sys-shape-corner-full);cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);white-space:nowrap}.btn-primary:hover:not(:disabled){background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-1)}.btn-secondary:hover:not(:disabled){background-color:var(--md-sys-color-secondary);color:var(--md-sys-color-on-secondary);box-shadow:var(--md-sys-elevation-1)}.btn-danger{background-color:var(--md-sys-color-error);color:var(--md-sys-color-on-error)}.btn-danger:hover:not(:disabled){background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container);box-shadow:var(--md-sys-elevation-1)}.btn-icon{padding:var(--md-sys-spacing-2);background-color:transparent;color:var(--md-sys-color-error)}.btn-icon:hover{background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-add{background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4)}.btn-add:hover{background-color:var(--md-sys-color-tertiary);color:var(--md-sys-color-on-tertiary)}.loading{text-align:center;padding:var(--md-sys-spacing-12);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-large-size)}@media(max-width:768px){.recipe-detail,.recipe-form-container,.recipe-detail-content,.recipe-form{padding:var(--md-sys-spacing-4)}.recipe-detail-image{height:250px}.recipe-detail-header{flex-direction:column;align-items:flex-start}.recipe-actions{width:100%}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}.md-recipe-meta-cards{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.md-recipe-gallery{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.md-section-header{flex-direction:column;align-items:flex-start;gap:var(--md-sys-spacing-3)}.md-btn-add-shopping{width:100%;justify-content:center}.md-step-item{flex-direction:column;gap:var(--md-sys-spacing-3)}}@media(max-width:480px){.md-recipe-detail-content{padding:var(--md-sys-spacing-5)}.md-recipe-title{font-size:var(--md-sys-typescale-headline-large-size)}.md-recipe-meta-cards{grid-template-columns:1fr 1fr;gap:var(--md-sys-spacing-2)}.md-meta-card{padding:var(--md-sys-spacing-3)}.md-meta-icon{width:24px;height:24px}.md-recipe-gallery{grid-template-columns:1fr}.md-step-number{width:32px;height:32px;font-size:var(--md-sys-typescale-title-medium-size)}}.recipe-importer-modal{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.recipe-importer-content{background:var(--surface);border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 4px 20px #0000004d}.recipe-importer-content.large{max-width:800px}.importer-header{padding:20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.importer-header h2{margin:0;font-size:1.5rem;color:var(--text)}.btn-close{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.btn-close:hover{background:var(--surface-hover);color:var(--text)}.importer-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--background-secondary)}.importer-tabs .tab{flex:1;padding:12px 20px;background:none;border:none;color:var(--text-secondary);font-size:1rem;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}.importer-tabs .tab:hover{background:var(--surface-hover);color:var(--text)}.importer-tabs .tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:500}.importer-body{padding:20px;flex:1;overflow-y:auto}.import-section{display:flex;flex-direction:column;gap:8px}.import-section label{font-weight:500;color:var(--text)}.input-field{padding:12px;border:1px solid var(--border);border-radius:6px;background:var(--background);color:var(--text);font-size:1rem;transition:border-color .2s}.input-field:focus{outline:none;border-color:var(--primary)}.input-field:disabled,.text-input:disabled{opacity:.6;cursor:not-allowed}.text-input{padding:12px;border:1px solid var(--border);border-radius:6px;background:var(--background);color:var(--text);font-size:.95rem;font-family:inherit;resize:vertical;transition:border-color .2s}.text-input:focus{outline:none;border-color:var(--primary)}.hint{font-size:.875rem;color:var(--text-tertiary);margin:0}.error-message{padding:12px;background:#f443361a;border:1px solid var(--danger);border-radius:6px;color:var(--danger);margin-top:12px}.importing-status{text-align:center;padding:20px;margin-top:12px}.importing-status p{margin:12px 0 0;color:var(--text-secondary)}.spinner{border:3px solid var(--border);border-top:3px solid var(--primary);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.importer-actions{padding:20px;border-top:1px solid var(--border);display:flex;gap:12px;justify-content:flex-end}.recipe-preview{display:flex;flex-direction:column;gap:20px;max-height:calc(90vh - 380px);overflow-y:auto;padding:0 20px 20px}.preview-title-section{padding:20px 20px 16px;border-bottom:2px solid var(--border);background:var(--surface)}.preview-title-section h3{margin:0 0 12px;font-size:1.875rem;color:var(--text);line-height:1.2}.preview-section{display:flex;flex-direction:column;gap:12px}.preview-section h4{margin:0;font-size:1.25rem;color:var(--text);border-bottom:2px solid var(--border);padding-bottom:8px}.recipe-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:.9rem;color:var(--text-secondary);margin:0}.badge{background:var(--primary);color:#fff;padding:4px 12px;border-radius:12px;font-size:.875rem;font-weight:500}.description{color:var(--text-secondary);line-height:1.6;margin:0}.ingredients-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:8px}.ingredients-list li{padding:4px 8px;background:var(--background);border-radius:4px;border-left:3px solid var(--primary);font-size:.9rem}.steps-list{list-style:none;counter-reset:step-counter;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.steps-list li{counter-increment:step-counter;position:relative;padding-left:48px;line-height:1.6}.steps-list li:before{content:counter(step-counter);position:absolute;left:0;top:0;width:32px;height:32px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}@media(max-width:768px){.recipe-importer-modal{padding:0}.recipe-importer-content{max-width:100%;max-height:100vh;border-radius:0}.recipe-importer-content.large{max-width:100%}.importer-header h2{font-size:1.25rem}.preview-title-section h3{font-size:1.5rem}.ingredients-list{grid-template-columns:1fr}.text-input,.input-field{font-size:16px}}.recipes-page{width:100%}.recipes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--md-sys-spacing-6);flex-wrap:wrap;gap:var(--md-sys-spacing-4)}.recipes-header h1{font-size:var(--md-sys-typescale-headline-large-size);font-weight:var(--md-sys-typescale-headline-large-weight);line-height:var(--md-sys-typescale-headline-large-line-height);color:var(--md-sys-color-on-surface);margin:0}.header-actions{display:flex;gap:var(--md-sys-spacing-3)}.recipes-hero-actions{position:relative}.recipes-hero-actions__desktop{display:flex;gap:var(--md-sys-spacing-2)}.recipes-hero-actions__mobile{position:relative}.recipes-hero-actions__trigger{justify-content:space-between}.recipes-hero-actions__menu{position:absolute;top:calc(100% + var(--md-sys-spacing-2));right:0;min-width:220px;z-index:20}.recipes-search{margin-bottom:var(--md-sys-spacing-3)}.recipes-search form{display:flex;align-items:center;gap:var(--md-sys-spacing-2);width:min(780px,100%);max-width:100%;padding:var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-large);background:color-mix(in srgb,var(--md-sys-color-surface-container) 82%,transparent);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 16%,transparent);box-shadow:var(--md-sys-elevation-1)}.search-input{flex:1;padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-large);background-color:var(--md-sys-color-surface-container-low);color:var(--md-sys-color-on-surface);transition:all .2s cubic-bezier(.2,0,0,1);outline:none}.search-input::placeholder{color:var(--md-sys-color-on-surface-variant)}.search-input:focus{border-color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container);box-shadow:0 0 0 1px var(--md-sys-color-primary)}.recipes-filters{display:flex;gap:var(--md-sys-spacing-2);flex-wrap:wrap;margin-bottom:var(--md-sys-spacing-5);padding:var(--md-sys-spacing-1) 0}.filter-btn{padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-label-large-line-height);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-full);background-color:var(--md-sys-color-surface-container-low);color:var(--md-sys-color-on-surface-variant);cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1)}.filter-btn:hover{background-color:var(--md-sys-color-surface-container-high);border-color:var(--md-sys-color-outline)}.filter-btn.active{background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);border-color:var(--md-sys-color-secondary-container)}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--md-sys-spacing-4);align-items:stretch}.recipe-card{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-large);overflow:hidden;cursor:pointer;transition:all .3s cubic-bezier(.2,0,0,1);border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 18%,transparent);display:flex;flex-direction:column;box-shadow:var(--md-sys-elevation-1);min-height:100%}.recipe-card:hover{box-shadow:var(--md-sys-elevation-2);transform:translateY(-2px);background-color:var(--md-sys-color-surface-container-high)}.recipe-card:active{transform:translateY(0);box-shadow:var(--md-sys-elevation-1)}.recipe-card-image{width:100%;height:200px;overflow:hidden;background-color:var(--md-sys-color-surface-container-highest)}.recipe-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s cubic-bezier(.2,0,0,1)}.recipe-card:hover .recipe-card-image img{transform:scale(1.05)}.recipe-card-content{padding:var(--md-sys-spacing-5) var(--md-sys-spacing-4);display:flex;flex-direction:column;gap:var(--md-sys-spacing-3);flex:1}.recipe-card-content h3{font-size:var(--md-sys-typescale-title-large-size);font-weight:var(--md-sys-typescale-title-large-weight);line-height:var(--md-sys-typescale-title-large-line-height);color:var(--md-sys-color-on-surface);margin:0;display:-webkit-box;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:2.7em}.recipe-category{display:inline-block;padding:var(--md-sys-spacing-1) var(--md-sys-spacing-3);background-color:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container);border-radius:var(--md-sys-shape-corner-full);font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);line-height:var(--md-sys-typescale-label-small-line-height);width:fit-content}.recipe-description{font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height);color:var(--md-sys-color-on-surface-variant);margin:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;min-height:4.2em}.recipe-meta{display:flex;flex-wrap:wrap;gap:var(--md-sys-spacing-2);margin-top:auto;padding-top:var(--md-sys-spacing-3)}.meta-item{font-size:var(--md-sys-typescale-body-small-size);line-height:var(--md-sys-typescale-body-small-line-height);color:var(--md-sys-color-on-surface-variant);display:flex;align-items:center;gap:var(--md-sys-spacing-1)}.btn{padding:var(--md-sys-spacing-2) var(--md-sys-spacing-6);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-label-large-line-height);border:none;border-radius:var(--md-sys-shape-corner-full);cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);white-space:nowrap}.btn-primary{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary)}.btn-primary:hover{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-1)}.btn-secondary{background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.btn-secondary:hover{background-color:var(--md-sys-color-secondary);color:var(--md-sys-color-on-secondary);box-shadow:var(--md-sys-elevation-1)}.btn-text{background-color:transparent;color:var(--md-sys-color-primary);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4)}.btn-text:hover{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.loading,.error,.empty-state{padding:var(--md-sys-spacing-12) var(--md-sys-spacing-6);text-align:center;font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height)}.loading{color:var(--md-sys-color-on-surface-variant)}.error{color:var(--md-sys-color-error);background-color:var(--md-sys-color-error-container);border-radius:var(--md-sys-shape-corner-medium);padding:var(--md-sys-spacing-4)}.empty-state{color:var(--md-sys-color-on-surface-variant)}.empty-state p{margin:0}@media(max-width:768px){.recipes-page{padding:var(--md-sys-spacing-4)}.recipes-hero-actions,.recipes-hero-actions__trigger{width:100%}.recipes-hero-actions__menu{left:0;right:0;min-width:0}.recipes-header{flex-direction:column;align-items:flex-start}.recipes-header h1{font-size:var(--md-sys-typescale-headline-medium-size)}.header-actions{width:100%;flex-direction:column}.header-actions .btn{width:100%}.recipes-search form{flex-direction:column;align-items:stretch}.recipes-grid{grid-template-columns:1fr}}@media(min-width:769px)and (max-width:1024px){.recipes-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media(min-width:1025px){.recipes-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}.shopping-page{--shopping-swipe-action-width: 88px;width:100%;overflow-x:clip}.shopping-layout{width:100%;overflow-x:clip}@media(min-width:1024px){.shopping-layout{max-width:980px;margin-inline:auto}}.add-item-form{position:sticky;top:0;z-index:10;background-color:color-mix(in srgb,var(--md-sys-color-surface) 86%,transparent);padding:0 0 var(--md-sys-spacing-4);margin-bottom:var(--md-sys-spacing-2);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.add-item-input{width:100%;padding:var(--md-sys-spacing-4) var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-large);background-color:var(--md-sys-color-surface-container-low);color:var(--md-sys-color-on-surface);transition:all .2s cubic-bezier(.2,0,0,1);outline:none}.add-item-input::placeholder{color:var(--md-sys-color-on-surface-variant)}.add-item-input:focus{border-color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container);box-shadow:0 0 0 1px var(--md-sys-color-primary)}.shopping-list{display:flex;flex-direction:column;gap:var(--md-sys-spacing-2);overflow-x:clip}.shopping-item-shell{position:relative;width:100%;min-width:0;border-radius:var(--md-sys-shape-corner-medium);overflow:hidden}.shopping-item-shell.swiped .shopping-item{transform:translate(calc(-1 * var(--shopping-swipe-action-width)))}.shopping-item-shell.swiped .delete-btn-swipe{opacity:1;pointer-events:auto}.shopping-item{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;gap:var(--md-sys-spacing-3);padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-medium);border:1px solid var(--md-sys-color-outline-variant);transition:all .2s cubic-bezier(.2,0,0,1);min-height:56px;width:100%;min-width:0;overflow:hidden;position:relative;z-index:1}.shopping-item:hover{background-color:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-1)}.shopping-item.completed{background-color:var(--md-sys-color-surface-container-low)}.shopping-item.drag-over{border-color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container-highest)}.drag-handle{cursor:grab;color:var(--md-sys-color-on-surface-variant);padding:var(--md-sys-spacing-1);border-radius:var(--md-sys-shape-corner-small);transition:all .2s;display:flex;align-items:center;justify-content:center}.drag-handle:hover{background-color:var(--md-sys-color-surface-container-highest);color:var(--md-sys-color-on-surface)}.drag-handle:active{cursor:grabbing}.item-content{display:flex;align-items:center;gap:var(--md-sys-spacing-3);cursor:pointer;padding:var(--md-sys-spacing-1) 0;min-width:0}.checkbox{width:20px;height:20px;border:2px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-extra-small);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s cubic-bezier(.2,0,0,1)}.checkbox.checked{background-color:var(--md-sys-color-primary);border-color:var(--md-sys-color-primary)}.checkmark{color:var(--md-sys-color-on-primary);font-size:14px;font-weight:700;line-height:1}.item-text{font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);color:var(--md-sys-color-on-surface);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shopping-item.completed .item-text{text-decoration:line-through;color:var(--md-sys-color-on-surface-variant)}.shopping-item.completed .drag-handle,.shopping-item.completed .edit-btn{color:var(--md-sys-color-on-surface-variant)}.edit-mode{grid-column:1 / -1;display:flex;flex-direction:column;gap:var(--md-sys-spacing-2)}.edit-input{width:100%;padding:var(--md-sys-spacing-2) var(--md-sys-spacing-3);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);border:2px solid var(--md-sys-color-primary);border-radius:var(--md-sys-shape-corner-small);background-color:var(--md-sys-color-surface);color:var(--md-sys-color-on-surface);outline:none}.edit-actions{display:flex;gap:var(--md-sys-spacing-2);justify-content:flex-end}.edit-btn,.delete-btn-desktop,.delete-btn-swipe,.btn-save,.btn-cancel{padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-label-large-line-height);border:none;border-radius:var(--md-sys-shape-corner-full);cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);white-space:nowrap;flex-shrink:0}.edit-btn{background-color:transparent;color:var(--md-sys-color-primary)}.edit-btn:hover{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.delete-btn-desktop{background-color:transparent;color:var(--md-sys-color-error)}.delete-btn-desktop:hover{background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container)}.delete-btn-swipe{position:absolute;right:0;top:0;bottom:0;width:var(--shopping-swipe-action-width);background-color:var(--md-sys-color-error);color:var(--md-sys-color-on-error);z-index:0;border-radius:0 var(--md-sys-shape-corner-medium) var(--md-sys-shape-corner-medium) 0;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s cubic-bezier(.2,0,0,1),background-color .2s cubic-bezier(.2,0,0,1),color .2s cubic-bezier(.2,0,0,1)}.delete-btn-swipe:hover{background-color:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container)}.btn-save{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary)}.btn-save:hover{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-1)}.btn-cancel{background-color:transparent;color:var(--md-sys-color-on-surface-variant);border:1px solid var(--md-sys-color-outline)}.btn-cancel:hover{background-color:var(--md-sys-color-surface-container-highest);border-color:var(--md-sys-color-outline)}.shopping-list>div[style*="textAlign: center"]{padding:var(--md-sys-spacing-12) var(--md-sys-spacing-6)!important;color:var(--md-sys-color-on-surface-variant)!important;font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height)}@media(max-width:768px){.delete-btn-desktop{display:none}.shopping-item{grid-template-columns:auto minmax(0,1fr) auto;align-items:flex-start;padding:var(--md-sys-spacing-2) var(--md-sys-spacing-3)}.item-content{align-items:flex-start}.item-text{white-space:normal;overflow-wrap:anywhere;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.shopping-item-shell.swiped .shopping-item{transform:translate(calc(-1 * var(--shopping-swipe-action-width)))}.edit-btn{align-self:center;padding-inline:var(--md-sys-spacing-2);font-size:var(--md-sys-typescale-label-medium-size)}}@media(min-width:769px){.delete-btn-swipe{display:none}}.loading-spinner{display:flex;justify-content:center;align-items:center;padding:var(--md-sys-spacing-12)}.loading-spinner:after{content:"";width:40px;height:40px;border:4px solid var(--md-sys-color-surface-container-highest);border-top-color:var(--md-sys-color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.pwa-install-banner{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:1rem;box-shadow:0 -4px 12px #0000004d;z-index:9999;animation:slideUp .3s ease-out}.pwa-install-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:1rem}.pwa-install-icon{flex-shrink:0;width:48px;height:48px;background:#fff3;border-radius:12px;display:flex;align-items:center;justify-content:center}.pwa-install-text{flex:1}.pwa-install-text strong{display:block;font-size:1.1rem;margin-bottom:.25rem}.pwa-install-text p{margin:0;font-size:.9rem;opacity:.9}.pwa-install-actions{display:flex;gap:.5rem;align-items:center}.pwa-install-btn{background:#fff;color:var(--primary);border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:1rem}.pwa-install-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #0003}.pwa-install-btn:active{transform:scale(.98)}.pwa-dismiss-btn{background:#fff3;color:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1}.pwa-dismiss-btn:hover{background:#ffffff4d}@media(max-width:480px){.pwa-install-banner{padding:.75rem}.pwa-install-content{gap:.75rem}.pwa-install-icon{width:40px;height:40px}.pwa-install-icon svg{width:20px;height:20px}.pwa-install-text strong{font-size:1rem}.pwa-install-text p{font-size:.8rem}.pwa-install-btn{padding:.6rem 1rem;font-size:.9rem}.pwa-dismiss-btn{width:32px;height:32px;font-size:1.25rem}}.update-notification{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem;box-shadow:0 -2px 10px #0000001a;z-index:10000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.update-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:1rem}.update-icon{font-size:2rem;animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.update-text{flex:1}.update-text strong{display:block;font-size:1.1rem;margin-bottom:.25rem}.update-text p{margin:0;opacity:.9;font-size:.9rem}.update-actions{display:flex;gap:.5rem}.update-button-primary,.update-button-secondary{padding:.5rem 1.5rem;border:none;border-radius:4px;font-size:.95rem;cursor:pointer;transition:all .2s;font-weight:500}.update-button-primary:disabled,.update-button-secondary:disabled{opacity:.7;cursor:wait;transform:none;box-shadow:none}.update-button-primary{background:#fff;color:#667eea}.update-button-primary:hover{background:#f0f0f0;transform:translateY(-1px);box-shadow:0 2px 8px #0003}.update-button-secondary{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5)}.update-button-secondary:hover{background:#ffffff1a;border-color:#fff}@media(max-width:768px){.update-content{flex-direction:column;text-align:center}.update-actions{width:100%}.update-button-primary,.update-button-secondary{flex:1}}.md-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--md-sys-spacing-2);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-6);border:none;border-radius:var(--md-sys-shape-corner-full);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight);line-height:var(--md-sys-typescale-label-large-line-height);cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);text-decoration:none;min-height:48px;position:relative;overflow:hidden;letter-spacing:.01em}.md-button:before{content:"";position:absolute;inset:0;background:currentColor;opacity:0;transition:opacity .2s}.md-button:hover:before{opacity:.08}.md-button:active:before{opacity:.12}.md-button:disabled{opacity:.38;cursor:not-allowed}.md-button-filled{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);box-shadow:var(--md-sys-elevation-1)}.md-button-filled:hover{box-shadow:var(--md-sys-elevation-2)}.md-button-outlined{background-color:transparent;color:var(--md-sys-color-primary);border:1px solid var(--md-sys-color-outline)}.md-button-text{background-color:transparent;color:var(--md-sys-color-primary);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-3)}.md-btn-danger{color:var(--md-sys-color-error)}.md-btn-danger:hover:before{background:var(--md-sys-color-error)}.md-button-tonal{background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);box-shadow:var(--md-sys-elevation-1)}.md-button-elevated{background-color:var(--md-sys-color-surface-container-low);color:var(--md-sys-color-primary);box-shadow:var(--md-sys-elevation-1)}.md-button-elevated:hover{box-shadow:var(--md-sys-elevation-2)}.md-icon-button{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;padding:0;border:none;border-radius:var(--md-sys-shape-corner-full);background-color:transparent;color:var(--md-sys-color-on-surface-variant);cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.md-icon-button:before{content:"";position:absolute;inset:0;background:currentColor;opacity:0;transition:opacity .2s}.md-icon-button:hover:before{opacity:.08}.md-icon-button:active:before{opacity:.12}.md-fab{position:fixed;bottom:var(--md-sys-spacing-6);right:var(--md-sys-spacing-6);display:flex;align-items:center;justify-content:center;gap:var(--md-sys-spacing-3);width:56px;height:56px;border:none;border-radius:var(--md-sys-shape-corner-large);background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);font-size:28px;font-weight:300;box-shadow:var(--md-sys-elevation-3);cursor:pointer;transition:all .2s;z-index:100}.md-fab:hover{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);box-shadow:var(--md-sys-elevation-4)}.md-fab:active{box-shadow:var(--md-sys-elevation-2)}.md-fab-extended{width:auto;padding:var(--md-sys-spacing-4) var(--md-sys-spacing-5);font-size:var(--md-sys-typescale-label-large-size);font-weight:var(--md-sys-typescale-label-large-weight)}.md-card{background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-medium);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background-color .2s ease;border:1px solid color-mix(in srgb,var(--md-sys-color-outline) 14%,transparent)}.md-card-elevated{background-color:var(--md-sys-color-surface-container-low);box-shadow:var(--md-sys-elevation-1)}.md-card-elevated:hover{box-shadow:var(--md-sys-elevation-2)}.md-card-filled{background-color:var(--md-sys-color-surface-container-highest);box-shadow:var(--md-sys-elevation-1)}.md-card-outlined{background-color:var(--md-sys-color-surface);border:1px solid var(--md-sys-color-outline-variant)}.md-card:hover{box-shadow:var(--md-sys-elevation-2)}.md-text-field{position:relative;display:flex;flex-direction:column;gap:var(--md-sys-spacing-1)}.md-text-field-outlined{position:relative}.md-text-field-outlined input,.md-text-field-outlined textarea,.md-text-field-outlined select{width:100%;padding:var(--md-sys-spacing-4);border:1px solid var(--md-sys-color-outline);border-radius:var(--md-sys-shape-corner-extra-small);background-color:color-mix(in srgb,var(--md-sys-color-surface-container-low) 72%,transparent);color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);transition:all .2s}.md-text-field-outlined input:focus,.md-text-field-outlined textarea:focus,.md-text-field-outlined select:focus{outline:none;border-color:var(--md-sys-color-primary);border-width:2px;padding:calc(var(--md-sys-spacing-4) - 1px)}.md-text-field-outlined label{font-size:var(--md-sys-typescale-body-small-size);font-weight:var(--md-sys-typescale-body-small-weight);color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--md-sys-spacing-1)}.md-chip{display:inline-flex;align-items:center;gap:var(--md-sys-spacing-2);padding:var(--md-sys-spacing-1) var(--md-sys-spacing-4);border-radius:var(--md-sys-shape-corner-small);font-size:var(--md-sys-typescale-label-medium-size);font-weight:var(--md-sys-typescale-label-medium-weight);line-height:var(--md-sys-typescale-label-medium-line-height);background-color:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-on-surface-variant);border:1px solid var(--md-sys-color-outline);cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.md-chip:hover{background-color:var(--md-sys-color-surface-container-highest)}.md-chip-filled{background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);border:none}.md-list{display:flex;flex-direction:column;gap:0;padding:var(--md-sys-spacing-2) 0}.md-list-item{display:flex;align-items:center;gap:var(--md-sys-spacing-4);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4);min-height:56px;cursor:pointer;transition:background-color .2s;position:relative}.md-list-item:hover{background-color:var(--md-sys-color-surface-container-highest)}.md-list-item-title{font-size:var(--md-sys-typescale-body-large-size);font-weight:var(--md-sys-typescale-body-large-weight);line-height:var(--md-sys-typescale-body-large-line-height);color:var(--md-sys-color-on-surface)}.md-list-item-subtitle{font-size:var(--md-sys-typescale-body-medium-size);font-weight:var(--md-sys-typescale-body-medium-weight);line-height:var(--md-sys-typescale-body-medium-line-height);color:var(--md-sys-color-on-surface-variant)}.md-divider{height:1px;background-color:var(--md-sys-color-outline-variant);border:none;margin:0}.md-display-large{font-size:var(--md-sys-typescale-display-large-size);line-height:var(--md-sys-typescale-display-large-line-height);font-weight:var(--md-sys-typescale-display-large-weight)}.md-headline-large{font-size:var(--md-sys-typescale-headline-large-size);line-height:var(--md-sys-typescale-headline-large-line-height);font-weight:var(--md-sys-typescale-headline-large-weight)}.md-headline-medium{font-size:var(--md-sys-typescale-headline-medium-size);line-height:var(--md-sys-typescale-headline-medium-line-height);font-weight:var(--md-sys-typescale-headline-medium-weight)}.md-title-large{font-size:var(--md-sys-typescale-title-large-size);line-height:var(--md-sys-typescale-title-large-line-height);font-weight:var(--md-sys-typescale-title-large-weight)}.md-title-medium{font-size:var(--md-sys-typescale-title-medium-size);line-height:var(--md-sys-typescale-title-medium-line-height);font-weight:var(--md-sys-typescale-title-medium-weight)}.md-body-large{font-size:var(--md-sys-typescale-body-large-size);line-height:var(--md-sys-typescale-body-large-line-height);font-weight:var(--md-sys-typescale-body-large-weight)}.md-body-medium{font-size:var(--md-sys-typescale-body-medium-size);line-height:var(--md-sys-typescale-body-medium-line-height);font-weight:var(--md-sys-typescale-body-medium-weight)}.md-label-large{font-size:var(--md-sys-typescale-label-large-size);line-height:var(--md-sys-typescale-label-large-line-height);font-weight:var(--md-sys-typescale-label-large-weight)}.md-symbol{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0,"wght" 500,"GRAD" 0,"opsz" 24}.md-badge{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 var(--md-sys-spacing-2);border-radius:var(--md-sys-shape-corner-full);background:var(--md-sys-color-tertiary-container);color:var(--md-sys-color-on-tertiary-container);font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight)}.md-menu-surface{border-radius:var(--md-sys-shape-corner-extra-large);border:1px solid color-mix(in srgb,var(--md-sys-color-outline-variant) 70%,transparent);background:color-mix(in srgb,var(--md-sys-color-surface-container-high) 94%,transparent);box-shadow:var(--md-sys-elevation-3);overflow:hidden;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.md-menu-item{display:flex;align-items:center;gap:var(--md-sys-spacing-3);width:100%;min-height:52px;padding:var(--md-sys-spacing-3) var(--md-sys-spacing-4);border:none;background:transparent;color:var(--md-sys-color-on-surface);cursor:pointer;text-align:left;transition:background-color .2s ease,color .2s ease}.md-menu-item:hover{background:color-mix(in srgb,var(--md-sys-color-primary) 8%,transparent)}.md-menu-item-danger{color:var(--md-sys-color-error)}.md-section-label{padding:0 var(--md-sys-spacing-4) var(--md-sys-spacing-2);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-label-small-size);font-weight:var(--md-sys-typescale-label-small-weight);letter-spacing:.08em;text-transform:uppercase}.md-progress-indicator{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px}.md-progress-indicator__spinner{width:32px;height:32px;border-radius:50%;border:3px solid color-mix(in srgb,var(--md-sys-color-primary) 20%,transparent);border-top-color:var(--md-sys-color-primary);animation:md-spin .9s linear infinite}@keyframes md-spin{to{transform:rotate(360deg)}}:root{font-family:Roboto,Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--md-sys-color-primary: #A8C7FA;--md-sys-color-on-primary: #0A3055;--md-sys-color-primary-container: #194975;--md-sys-color-on-primary-container: #D3E4FF;--md-sys-color-secondary: #BAC9DB;--md-sys-color-on-secondary: #253140;--md-sys-color-secondary-container: #3B4858;--md-sys-color-on-secondary-container: #D6E4F7;--md-sys-color-tertiary: #D5BEE4;--md-sys-color-on-tertiary: #3B2948;--md-sys-color-tertiary-container: #52405F;--md-sys-color-on-tertiary-container: #F2DAFF;--md-sys-color-error: #FFB4AB;--md-sys-color-on-error: #690005;--md-sys-color-error-container: #93000A;--md-sys-color-on-error-container: #FFDAD6;--md-sys-color-surface: #1A1C1E;--md-sys-color-on-surface: #E3E2E6;--md-sys-color-surface-variant: #42474E;--md-sys-color-on-surface-variant: #C3C6CF;--md-sys-color-surface-container-lowest: #0F1113;--md-sys-color-surface-container-low: #22262A;--md-sys-color-surface-container: #262A2E;--md-sys-color-surface-container-high: #313539;--md-sys-color-surface-container-highest: #3C4043;--md-sys-color-outline: #8D9199;--md-sys-color-outline-variant: #42474E;--md-sys-color-inverse-surface: #E3E2E6;--md-sys-color-inverse-on-surface: #2F3033;--md-sys-color-inverse-primary: #335C9B;--md-sys-color-scrim: #000000;--md-sys-color-shadow: #000000;--md-sys-elevation-0: none;--md-sys-elevation-1: 0px 1px 2px 0px rgba(0, 0, 0, .3), 0px 1px 3px 1px rgba(0, 0, 0, .15);--md-sys-elevation-2: 0px 1px 2px 0px rgba(0, 0, 0, .3), 0px 2px 6px 2px rgba(0, 0, 0, .15);--md-sys-elevation-3: 0px 1px 3px 0px rgba(0, 0, 0, .3), 0px 4px 8px 3px rgba(0, 0, 0, .15);--md-sys-elevation-4: 0px 2px 3px 0px rgba(0, 0, 0, .3), 0px 6px 10px 4px rgba(0, 0, 0, .15);--md-sys-elevation-5: 0px 4px 4px 0px rgba(0, 0, 0, .3), 0px 8px 12px 6px rgba(0, 0, 0, .15);--md-sys-typescale-display-large-size: 57px;--md-sys-typescale-display-large-line-height: 64px;--md-sys-typescale-display-large-weight: 400;--md-sys-typescale-display-medium-size: 45px;--md-sys-typescale-display-medium-line-height: 52px;--md-sys-typescale-display-medium-weight: 400;--md-sys-typescale-display-small-size: 36px;--md-sys-typescale-display-small-line-height: 44px;--md-sys-typescale-display-small-weight: 400;--md-sys-typescale-headline-large-size: 32px;--md-sys-typescale-headline-large-line-height: 40px;--md-sys-typescale-headline-large-weight: 400;--md-sys-typescale-headline-medium-size: 28px;--md-sys-typescale-headline-medium-line-height: 36px;--md-sys-typescale-headline-medium-weight: 400;--md-sys-typescale-headline-small-size: 24px;--md-sys-typescale-headline-small-line-height: 32px;--md-sys-typescale-headline-small-weight: 400;--md-sys-typescale-title-large-size: 22px;--md-sys-typescale-title-large-line-height: 28px;--md-sys-typescale-title-large-weight: 400;--md-sys-typescale-title-medium-size: 16px;--md-sys-typescale-title-medium-line-height: 24px;--md-sys-typescale-title-medium-weight: 500;--md-sys-typescale-title-small-size: 14px;--md-sys-typescale-title-small-line-height: 20px;--md-sys-typescale-title-small-weight: 500;--md-sys-typescale-body-large-size: 16px;--md-sys-typescale-body-large-line-height: 24px;--md-sys-typescale-body-large-weight: 400;--md-sys-typescale-body-medium-size: 14px;--md-sys-typescale-body-medium-line-height: 20px;--md-sys-typescale-body-medium-weight: 400;--md-sys-typescale-body-small-size: 12px;--md-sys-typescale-body-small-line-height: 16px;--md-sys-typescale-body-small-weight: 400;--md-sys-typescale-label-large-size: 14px;--md-sys-typescale-label-large-line-height: 20px;--md-sys-typescale-label-large-weight: 500;--md-sys-typescale-label-medium-size: 12px;--md-sys-typescale-label-medium-line-height: 16px;--md-sys-typescale-label-medium-weight: 500;--md-sys-typescale-label-small-size: 11px;--md-sys-typescale-label-small-line-height: 16px;--md-sys-typescale-label-small-weight: 500;--md-sys-spacing-0: 0px;--md-sys-spacing-1: 4px;--md-sys-spacing-2: 8px;--md-sys-spacing-3: 12px;--md-sys-spacing-4: 16px;--md-sys-spacing-5: 20px;--md-sys-spacing-6: 24px;--md-sys-spacing-7: 28px;--md-sys-spacing-8: 32px;--md-sys-spacing-10: 40px;--md-sys-spacing-12: 48px;--md-sys-spacing-16: 64px;--md-sys-shape-corner-none: 0px;--md-sys-shape-corner-extra-small: 4px;--md-sys-shape-corner-small: 8px;--md-sys-shape-corner-medium: 12px;--md-sys-shape-corner-large: 16px;--md-sys-shape-corner-extra-large: 28px;--md-sys-shape-corner-full: 9999px;--primary: var(--md-sys-color-primary);--primary-dark: var(--md-sys-color-primary-container);--primary-light: var(--md-sys-color-on-primary-container);--secondary: var(--md-sys-color-secondary);--secondary-dark: var(--md-sys-color-secondary-container);--danger: var(--md-sys-color-error);--danger-dark: var(--md-sys-color-error-container);--warning: #FB8C00;--warning-dark: #E65100;--success: #81C784;--background: var(--md-sys-color-surface);--background-secondary: var(--md-sys-color-surface-container-low);--background-tertiary: var(--md-sys-color-surface-container);--surface: var(--md-sys-color-surface-container);--surface-hover: var(--md-sys-color-surface-container-high);--text: var(--md-sys-color-on-surface);--text-secondary: var(--md-sys-color-on-surface-variant);--text-tertiary: rgba(227, 226, 230, .4);--border: var(--md-sys-color-outline-variant);--border-light: rgba(195, 198, 207, .08);color-scheme:dark;color:var(--md-sys-color-on-surface);background-color:var(--md-sys-color-surface);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh;margin:0;background-color:var(--background);color:var(--text);overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}
