.app{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}.app-header{background-color:var(--background-secondary);padding:1rem 2rem;box-shadow:0 2px 4px #0000004d;border-bottom:1px solid var(--border)}.header-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.app-header h1{margin:0;color:var(--primary)}.user-avatar-button{width:44px;height:44px;min-width:44px;min-height:44px;border-radius:50%;background:var(--primary);color:#fff;border:2px solid var(--primary-dark);font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px color-mix(in srgb,var(--primary) 30%,transparent);padding:0;flex-shrink:0}.user-avatar-button:hover{background:var(--primary-dark);transform:scale(1.05);box-shadow:0 4px 12px color-mix(in srgb,var(--primary) 40%,transparent)}.user-avatar-button:active{transform:scale(.95)}.app-header nav{display:flex;gap:1.5rem;align-items:center}.app-header nav a{color:var(--text);text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:all .3s;position:relative;display:flex;align-items:center;gap:.5rem}.app-header nav a .nav-icon{width:20px;height:20px;flex-shrink:0}.app-header nav a .nav-text{white-space:nowrap}.app-header nav a:hover{background-color:var(--surface-hover)}.app-header nav a.active{color:var(--primary);font-weight:500}.app-header nav a.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--primary);border-radius:2px 2px 0 0}.nav-user{display:flex;align-items:center;gap:1rem;margin-left:auto;position:relative}.user-menu-button{background:transparent;color:var(--text);border:1px solid var(--border);padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:.5rem;font-size:14px}.user-menu-button:hover{background:var(--surface-hover);border-color:var(--text-secondary)}.user-menu-arrow{font-size:10px;transition:transform .2s}.user-menu-backdrop{position:fixed;inset:0;z-index:999}.user-menu{position:fixed;top:70px;right:1rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #00000080;min-width:220px;z-index:1000;overflow:hidden}.user-menu-header{padding:1rem;border-bottom:1px solid var(--border);background:var(--background-secondary)}.user-menu-name{font-weight:600;color:var(--text);margin-bottom:.25rem}.user-menu-email{font-size:12px;color:var(--text-secondary)}.user-menu-item{display:block;width:100%;padding:.75rem 1rem;background:transparent;border:none;color:var(--text);text-align:left;cursor:pointer;transition:background .2s;text-decoration:none;font-size:14px}.user-menu-item:hover{background:var(--surface-hover)}.user-menu-logout{border-top:1px solid var(--border);color:var(--danger)}.user-menu-logout:hover{background:#f443361a}.user-menu-section{border-bottom:1px solid var(--border)}.user-menu-section-title{padding:.75rem 1rem .5rem;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.family-switcher-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem!important}.family-switcher-current{display:flex;align-items:center;gap:.5rem;flex:1}.family-role-badge-small{background:var(--primary);color:#fff;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase}.family-switcher-icon{font-size:10px;color:var(--text-secondary)}.family-submenu{background:var(--background);border-top:1px solid var(--border);max-height:300px;overflow-y:auto}.family-submenu-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.75rem 1.5rem;background:transparent;border:none;color:var(--text);text-align:left;cursor:pointer;transition:background .2s;border-bottom:1px solid var(--border)}.family-submenu-item:last-child{border-bottom:none}.family-submenu-item:hover{background:var(--surface-hover)}.family-submenu-item.active{background:#4caf501a}.family-submenu-content{flex:1}.family-submenu-name{font-weight:500;margin-bottom:.25rem}.family-submenu-meta{display:flex;align-items:center;gap:.5rem;font-size:11px;color:var(--text-secondary)}.family-members-count{color:var(--text-secondary)}.family-checkmark{color:var(--primary);font-size:16px;font-weight:700}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;color:var(--text)}.app-main{flex:1;padding:0;width:100%}.app-footer{background-color:var(--background-secondary);padding:1rem 2rem;text-align:center;color:var(--text-secondary);border-top:1px solid var(--border)}.home{text-align:center}.home h2{margin-bottom:1rem;color:var(--primary)}.home p{font-size:1.2rem;margin-bottom:2rem;color:var(--text)}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:3rem}.feature-card{background-color:#1a1a1a;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:2rem;transition:transform .3s,box-shadow .3s;text-decoration:none;color:inherit;display:block;cursor:pointer}.feature-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #4caf5033}.feature-card h3{margin-bottom:.5rem;font-size:1.5rem}.feature-card p{color:#ffffffb3}@media(max-width:768px){.app-header{padding:1rem}.header-content{margin-bottom:.75rem}.app-header h1{font-size:1.5rem}.user-avatar-button{width:40px;height:40px;font-size:.9rem}.app-header nav{gap:.5rem;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.app-header nav::-webkit-scrollbar{display:none}.app-header nav a{padding:.5rem;font-size:.9rem;flex-direction:column;gap:.25rem;min-width:60px}.app-header nav a .nav-icon{width:24px;height:24px}.app-header nav a .nav-text{font-size:.7rem;text-align:center}.user-menu-button{padding:.5rem .75rem;font-size:.85rem}}@media(max-width:480px){.app-header{padding:.75rem}.header-content{margin-bottom:.5rem}.app-header h1{font-size:1.25rem}.user-avatar-button{width:36px;height:36px;font-size:.85rem}.app-header nav{gap:.25rem;justify-content:space-around;width:100%}.app-header nav a{padding:.5rem .25rem;font-size:.65rem;flex:1;text-align:center;min-height:50px;display:flex;align-items:center;flex-direction:column;gap:.25rem;min-width:unset}.app-header nav a .nav-icon{width:22px;height:22px}.app-header nav a .nav-text{font-size:.65rem;line-height:1}.nav-user{width:100%;margin-left:0;margin-top:.5rem;justify-content:center}.user-menu-button{padding:.6rem 1rem;min-height:44px;width:100%;justify-content:center}.app-main{padding:0}.app-footer{padding:1rem;font-size:.8rem}.user-menu{left:.5rem;right:.5rem;min-width:auto}}.admin-page{min-height:100vh;background-color:var(--md-sys-color-surface);padding:var(--md-sys-spacing-6)}.admin-container{max-width:1200px;margin:0 auto}.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{max-width:900px;margin:0 auto;padding:var(--md-sys-spacing-6)}.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:100vh;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:var(--md-sys-spacing-4)}.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{padding:var(--md-sys-spacing-2);width:100%;max-width:100%;background-color:var(--md-sys-color-surface);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}.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}.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-1);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:var(--md-sys-elevation-1);overflow:hidden;overflow-y:auto}.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-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}.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}.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);box-shadow:var(--md-sys-elevation-2)}.calendar-page .form-actions .md-button-filled:disabled{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{max-width:1000px;margin:0 auto;padding:var(--md-sys-spacing-6);background-color:var(--md-sys-color-surface);position:relative}.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)}.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}.md-button-filled:hover{box-shadow:var(--md-sys-elevation-2)}.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)}.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)}.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}.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}.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{max-width:1400px;margin:0 auto;padding:var(--md-sys-spacing-6);background-color:var(--md-sys-color-surface)}.home-controls{display:flex;justify-content:flex-end;margin-bottom:var(--md-sys-spacing-4)}.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);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);display:flex;align-items:center;gap:var(--md-sys-spacing-2)}.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{position:relative;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);z-index:10;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);font-size:24px;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--md-sys-shape-corner-full);transition:all .2s}.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)}.no-feeds{text-align:center;color:var(--md-sys-color-on-surface-variant);padding:var(--md-sys-spacing-6);font-size:var(--md-sys-typescale-body-medium-size)}.home-preview-panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--md-sys-spacing-4)}.preview-panel{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);transition:all .2s}.preview-panel:hover{box-shadow:var(--md-sys-elevation-2)}.preview-header{display:flex;justify-content:space-between;align-items:center;padding:var(--md-sys-spacing-4);background-color:var(--md-sys-color-surface-container);border-bottom:1px solid var(--md-sys-color-outline-variant)}.preview-header h3{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}.view-all-link{font-size:var(--md-sys-typescale-label-large-size);color:var(--md-sys-color-primary);text-decoration:none;transition:color .2s;font-weight:var(--md-sys-typescale-label-large-weight)}.view-all-link:hover{color:var(--md-sys-color-primary);text-decoration:underline}.preview-loading,.preview-empty{text-align:center;color:var(--md-sys-color-on-surface-variant);padding:var(--md-sys-spacing-8);font-size:var(--md-sys-typescale-body-medium-size)}.event-preview-list{list-style:none;padding:var(--md-sys-spacing-2);margin:0}.event-preview-item{display:flex;gap:var(--md-sys-spacing-3);padding:var(--md-sys-spacing-3);margin-bottom:var(--md-sys-spacing-2);background-color:var(--md-sys-color-surface-container);border-radius:var(--md-sys-shape-corner-medium);transition:all .2s;cursor:pointer}.event-preview-item:hover{background-color:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-1)}.event-color-bar{width:4px;border-radius:var(--md-sys-shape-corner-full);flex-shrink:0}.event-preview-content{flex:1;min-width:0}.event-preview-title{font-weight:var(--md-sys-typescale-body-large-weight);font-size:var(--md-sys-typescale-body-large-size);color:var(--md-sys-color-on-surface);margin-bottom:var(--md-sys-spacing-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-preview-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-preview-location{font-size:var(--md-sys-typescale-body-small-size);color:var(--md-sys-color-on-surface-variant);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.home{padding:var(--md-sys-spacing-4)}.home-preview-panels{grid-template-columns:1fr;gap:var(--md-sys-spacing-3)}.preview-panel{min-width:0;width:100%}.preview-header{padding:var(--md-sys-spacing-3)}.preview-header h3{font-size:var(--md-sys-typescale-title-medium-size)}.event-preview-item{padding:var(--md-sys-spacing-2);min-width:0}.event-preview-content{min-width:0;overflow:hidden}.feed-filter-toggle{font-size:var(--md-sys-typescale-label-medium-size);padding:var(--md-sys-spacing-2) var(--md-sys-spacing-4)}}.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%}.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-list{max-height:300px;overflow-y:auto;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;min-height:0}.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}.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);box-shadow:var(--md-sys-elevation-2)}.menu-page .modal-footer .md-button-filled:disabled{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-content{max-width:100%;max-height:100vh;border-radius:0}.menu-page .recipe-item{flex-direction:column;gap:var(--md-sys-spacing-2)}.menu-page .recipe-thumb{width:100%;height:120px}}.menu-container{padding:var(--md-sys-spacing-6);max-width:1400px;margin:0 auto;background-color:var(--md-sys-color-surface)}.menu-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)}.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)}.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)}.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 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}}.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{min-height:100vh;background-color:var(--md-sys-color-surface);padding:var(--md-sys-spacing-6)}.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-search{margin-bottom:var(--md-sys-spacing-4)}.recipes-search form{display:flex;gap:var(--md-sys-spacing-2);max-width:600px}.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-6)}.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-fill,minmax(300px,1fr));gap:var(--md-sys-spacing-4)}.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 var(--md-sys-color-outline-variant);display:flex;flex-direction:column}.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-4);display:flex;flex-direction:column;gap:var(--md-sys-spacing-2);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}.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:2;-webkit-box-orient:vertical}.recipe-meta{display:flex;flex-wrap:wrap;gap:var(--md-sys-spacing-3);margin-top:auto;padding-top:var(--md-sys-spacing-2)}.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-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}.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{min-height:100vh;background-color:var(--md-sys-color-surface);padding:0}.shopping-container{max-width:800px;margin:0 auto;padding:var(--md-sys-spacing-6);display:flex;flex-direction:column;gap:var(--md-sys-spacing-4)}.add-item-form{position:sticky;top:0;z-index:10;background-color:var(--md-sys-color-surface);padding:var(--md-sys-spacing-4) 0;margin-bottom:var(--md-sys-spacing-2)}.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)}.shopping-item{display:flex;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);position:relative;min-height:56px}.shopping-item:hover{background-color:var(--md-sys-color-surface-container-high);box-shadow:var(--md-sys-elevation-1)}.shopping-item.completed{opacity:.6}.shopping-item.drag-over{border-color:var(--md-sys-color-primary);background-color:var(--md-sys-color-surface-container-highest)}.shopping-item.swiped{transform:translate(-80px);transition:transform .3s ease-out}.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{flex:1;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)}.edit-mode{flex: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}.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:-80px;top:0;bottom:0;width:80px;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}.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){.shopping-container{padding:var(--md-sys-spacing-4)}.delete-btn-desktop{display:none}.shopping-item{padding:var(--md-sys-spacing-2) var(--md-sys-spacing-3)}}@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{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}.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-0)}.md-button-filled:hover{box-shadow:var(--md-sys-elevation-1)}.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)}.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:all .2s}.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)}.md-card-outlined{background-color:var(--md-sys-color-surface);border:1px solid var(--md-sys-color-outline-variant)}.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: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}.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)}: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}
