@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";.auth-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;width:100%}.auth-deco{position:relative;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;padding:3rem;overflow:hidden;border-right:1px solid var(--border)}.auth-deco-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 60% at 80% 20%,rgba(34,211,238,.1),transparent 60%),radial-gradient(ellipse 60% 60% at 20% 80%,rgba(16,185,129,.08),transparent 60%);pointer-events:none}.auth-deco-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.25;pointer-events:none;animation:floatOrb 8s ease-in-out infinite}.auth-deco-orb-1{width:300px;height:300px;background:var(--brand);top:-80px;right:-60px;animation-delay:0s}.auth-deco-orb-2{width:220px;height:220px;background:var(--accent);bottom:-60px;left:-40px;animation-delay:-4s}@keyframes floatOrb{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}.auth-deco-content{position:relative;z-index:1;max-width:420px}.auth-deco-logo{display:inline-flex;align-items:center;gap:.75rem;text-decoration:none;margin-bottom:2.5rem}.auth-deco-logo-icon{font-size:1.6rem;width:48px;height:48px;background:var(--grad-brand);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center}.auth-deco-logo-text{font-size:1.05rem;font-weight:800;letter-spacing:-.02em;background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-deco-content h1{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;color:var(--text);line-height:1.2;margin-bottom:1rem;letter-spacing:-.025em}.auth-deco-content h1 .highlight{background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-deco-desc{color:var(--text-muted);font-size:.95rem;line-height:1.7;margin-bottom:2rem}.auth-features{display:flex;flex-direction:column;gap:.75rem}.auth-feature{display:flex;align-items:center;gap:.875rem;padding:.75rem 1rem;background:#ffffff08;border:1px solid var(--border);border-radius:var(--r-lg);font-size:.875rem;color:var(--text-muted);transition:background var(--tr),border-color var(--tr)}.auth-feature:hover{background:#ffffff0d;border-color:var(--border-light)}.auth-feature-icon{font-size:1.15rem;width:36px;height:36px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0}.auth-panel{display:flex;align-items:center;justify-content:center;padding:2.5rem;background:var(--bg-base)}.auth-form-wrap{width:100%;max-width:400px}.auth-form-header{margin-bottom:2rem}.auth-form-header h2{font-size:1.65rem;font-weight:800;letter-spacing:-.025em;margin-bottom:.4rem;color:var(--text)}.auth-form-header p{color:var(--text-muted);font-size:.9rem;margin:0}.auth-error{display:none;align-items:flex-start;gap:.65rem;padding:.85rem 1rem;background:var(--danger-bg);border:1px solid rgba(239,68,68,.25);border-radius:var(--r-lg);color:var(--danger);font-size:.875rem;font-weight:500;margin-bottom:1.25rem;animation:slideDown .2s ease}.auth-error.visible{display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.auth-form{display:flex;flex-direction:column;gap:1.1rem;margin-bottom:1.5rem}.auth-form .form-group{display:flex;flex-direction:column;gap:.4rem}.auth-form label{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.auth-form input{padding:.75em 1em;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);color:var(--text);font-size:.95rem;transition:border-color var(--tr),box-shadow var(--tr)}.auth-form input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #22d3ee1f;background:var(--bg-card)}.auth-submit{width:100%;padding:.85em;font-size:.95rem;font-weight:700;position:relative;overflow:hidden}.auth-submit .spinner{display:none;width:16px;height:16px;border:2px solid rgba(0,0,0,.2);border-top-color:#060a10;border-radius:50%;animation:spin .7s linear infinite}.auth-submit.loading .spinner{display:block}.auth-submit.loading .btn-text{opacity:.5}@keyframes spin{to{transform:rotate(360deg)}}.auth-footer-links{text-align:center;font-size:.875rem;color:var(--text-muted)}.auth-footer-links a{color:var(--brand);font-weight:600}@media (max-width: 900px){.auth-page{grid-template-columns:1fr}.auth-deco{display:none}.auth-panel{min-height:100vh;min-height:100dvh}}@media (max-width: 480px){.auth-panel{align-items:flex-start;padding:2rem 1rem}.auth-form-header{margin-bottom:1.5rem}}.home-wrap{width:100%;max-width:1100px;padding:2rem 2rem 4rem;display:flex;flex-direction:column;gap:2.5rem}.home-hero{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-2xl);padding:2.25rem 2rem;overflow:hidden;box-shadow:var(--shadow-sm)}.home-hero-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 80% at 90% 20%,rgba(34,211,238,.08),transparent 60%),radial-gradient(ellipse 50% 60% at 5% 80%,rgba(16,185,129,.06),transparent 60%);pointer-events:none}.home-hero-body{position:relative;display:flex;align-items:center;gap:1.25rem;min-width:0}.home-hero-body>div{min-width:0}.home-avatar{width:56px;height:56px;border-radius:50%;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;color:#060a10;flex-shrink:0;box-shadow:0 4px 16px #22d3ee4d}.home-greeting{font-size:clamp(1.3rem,3vw,1.75rem);margin-bottom:.25rem}.home-name{background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;overflow-wrap:anywhere}.home-hero .home-hero-body~p{position:relative;margin:0;color:var(--text-muted);font-size:.9rem}.home-hero-actions{position:absolute;top:1.25rem;right:1.75rem;display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}.home-date{font-size:.75rem;color:var(--text-subtle);text-transform:capitalize;letter-spacing:.02em}.home-tv-btn{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text-subtle);border-radius:8px;padding:.3rem .75rem;font-size:.8rem;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.home-tv-btn:hover{background:#ffffff1f;color:var(--text)}.home-section-hd{display:flex;align-items:center;gap:.75rem;margin-bottom:1.1rem}.home-section-hd h2{margin:0;font-size:1rem;font-weight:700;color:var(--text)}.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem}.hcard{display:flex;align-items:center;gap:.875rem;padding:1rem 1.125rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);text-decoration:none;color:var(--text);transition:background var(--tr),border-color var(--tr),transform var(--tr),box-shadow var(--tr);position:relative;overflow:hidden}.hcard:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad-brand);opacity:0;transition:opacity var(--tr)}.hcard:hover{background:var(--bg-elevated);border-color:#22d3ee40;transform:translateY(-2px);box-shadow:var(--shadow-md)}.hcard:hover:before{opacity:1}.hcard-icon{font-size:1.5rem;width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-lg);background:var(--bg-elevated);border:1px solid var(--border);flex-shrink:0;transition:transform var(--tr)}.hcard:hover .hcard-icon{transform:scale(1.1) rotate(-4deg)}.hcard-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.hcard-title{font-size:.9rem;font-weight:700;color:var(--text)}.hcard-desc{font-size:.76rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hcard-arrow{color:var(--text-subtle);font-size:.9rem;flex-shrink:0;transition:transform var(--tr),color var(--tr)}.hcard:hover .hcard-arrow{transform:translate(3px);color:var(--brand)}.hcard--disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.hcard-badge-soon{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.2em .55em;border-radius:var(--r-md, 6px);background:#8b949e26;color:var(--text-subtle);flex-shrink:0}.hcard--blue .hcard-icon{background:#58a6ff1a;border-color:#58a6ff33}.hcard--cyan .hcard-icon{background:#22d3ee1a;border-color:#22d3ee33}.hcard--teal .hcard-icon{background:#10b9811a;border-color:#10b98133}.hcard--purple .hcard-icon{background:#a78bfa1a;border-color:#a78bfa33}.hcard--orange .hcard-icon{background:#fb923c1a;border-color:#fb923c33}.hcard--green .hcard-icon{background:#10b9811a;border-color:#10b98133}.hcard--yellow .hcard-icon{background:#f59e0b1a;border-color:#f59e0b33}.hcard--pink .hcard-icon{background:#f472b61a;border-color:#f472b633}.hcard--gray .hcard-icon{background:#8b949e1a;border-color:#8b949e33}.home-about{display:flex;align-items:flex-start;gap:1.25rem;padding:1.75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-2xl);background-image:radial-gradient(ellipse 40% 80% at 100% 50%,rgba(16,185,129,.05),transparent 60%)}.home-about-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#10b9811a;border:1px solid rgba(16,185,129,.2);border-radius:var(--r-lg);flex-shrink:0}.home-about h2{font-size:1rem;margin-bottom:.4rem}.home-about p{color:var(--text-muted);font-size:.875rem;line-height:1.7}@media (max-width: 768px){.home-wrap{padding:1.25rem 1rem 3rem;gap:2rem}.home-hero{padding:1.5rem 1.25rem}.home-hero-body{align-items:flex-start;padding-right:0}.home-hero-actions{position:relative;top:auto;right:auto;align-items:flex-start;margin-top:1rem}.home-date{display:none}.home-avatar{width:44px;height:44px;font-size:1.1rem}.home-grid{grid-template-columns:1fr 1fr}.hcard{padding:.875rem}}@media (max-width: 480px){.home-grid{grid-template-columns:1fr}.home-hero-body,.home-about{flex-direction:column}.hcard-desc{white-space:normal}}.planning-hub{width:100%;padding:2rem 2rem 4rem;max-width:700px}.planning-hub h1{margin-bottom:.4rem}.planning-hub>p{margin-bottom:2rem}.planning-cards{display:flex;flex-direction:column;gap:1rem}.planning-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem 1.75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-2xl);text-decoration:none;color:var(--text);transition:background var(--tr),border-color var(--tr),transform var(--tr),box-shadow var(--tr)}.planning-card:hover{background:var(--bg-elevated);border-color:#22d3ee40;transform:translateY(-2px);box-shadow:var(--shadow-md)}.planning-card-icon{font-size:1.75rem;width:56px;height:56px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--brand-bg);border:1px solid rgba(34,211,238,.2);border-radius:var(--r-xl)}.planning-card-body{flex:1}.planning-card-title{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.25rem}.planning-card-desc{font-size:.82rem;color:var(--text-muted)}.planning-card-arrow{color:var(--brand);font-size:1.25rem;flex-shrink:0;transition:transform var(--tr)}.planning-card:hover .planning-card-arrow{transform:translate(4px)}@media (max-width: 768px){.planning-hub{padding:1.25rem 1rem 3rem}}@media (max-width: 480px){.planning-card{align-items:flex-start;gap:1rem;padding:1.1rem}.planning-card-icon{width:46px;height:46px;font-size:1.4rem}}.planifier-wrap{width:100%;padding:2rem 2rem 4rem;max-width:1100px}.planifier-wrap h1{margin-bottom:1.5rem}.week-selector-form{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl)}.week-selector-form label{color:var(--text-muted);font-size:.82rem;font-weight:600}.week-selector-form input{width:auto;flex:1;min-width:150px;max-width:200px}.table-wrapper{overflow-x:auto}.planning-table{width:100%;border-collapse:collapse;font-size:.875rem;background:var(--bg-card);border-radius:var(--r-xl);overflow:hidden}.planning-table th{padding:.875rem 1rem;text-align:left;background:var(--bg-elevated);color:var(--text-muted);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.planning-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-light);vertical-align:top;color:var(--text)}.planning-table tr:last-child td{border-bottom:none}.planning-table tbody tr:hover{background:var(--bg-hover)}.meal-cell{min-height:48px;cursor:pointer;border-radius:var(--r-lg);padding:.4rem .5rem;transition:background var(--tr)}.meal-cell:hover{background:var(--bg-hover)}.meal-cell--filled .meal-main{font-weight:600;font-size:.84rem;color:var(--text)}.meal-cell--filled .meal-side{font-size:.78rem;color:var(--text-muted);margin-top:.15rem}.meal-cell--filled .meal-dessert{font-size:.78rem;color:var(--text-subtle);font-style:italic;margin-top:.1rem}.meal-cell--absent,.meal-cell--fasting{display:flex;align-items:center;gap:.35rem;opacity:.7}.meal-status-icon{font-size:1rem}.meal-status-label{font-size:.8rem;color:var(--text-muted);font-weight:600}.meal-cell--empty{min-height:48px}.btn-new-meal{background:transparent;border:1px dashed var(--border-light);color:var(--text-subtle);box-shadow:none;font-size:.78rem;padding:.3em .7em}.btn-new-meal:hover{border-color:var(--brand);color:var(--brand);transform:none;filter:none;box-shadow:none}.edit-area{display:flex;flex-direction:column;gap:.45rem}.edit-area .main-input,.edit-area .side-input,.edit-area .dessert-input,.edit-area .meal-type-select,.edit-area .status-select{padding:.5em .75em;font-size:.82rem}.edit-actions{display:flex;gap:.5rem}.btn-add{font-size:.78rem;padding:.35em .75em}.btn-cancel{font-size:.78rem;padding:.35em .75em;background:transparent;color:var(--text-muted);border-color:var(--border);box-shadow:none}.btn-cancel:hover{background:var(--bg-hover);transform:none;filter:none;box-shadow:none}@media (max-width: 768px){.planifier-wrap{padding:1.25rem 1rem 3rem}.week-selector-form{align-items:stretch}.week-selector-form input{max-width:none}.planning-table th:nth-child(2){display:none}.planning-table td:nth-child(2){display:none}}@media (max-width: 640px){.table-wrapper{overflow:visible;border:none;border-radius:0}.planning-table,.planning-table tbody,.planning-table tr,.planning-table td{display:block;width:100%}.planning-table{background:transparent}.planning-table thead{display:none}.planning-table tr{margin-bottom:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden}.planning-table td{padding:.85rem 1rem}.planning-table td:first-child{background:var(--bg-elevated);color:var(--text);font-weight:800}.planning-table td:nth-child(3):before,.planning-table td:nth-child(4):before{display:block;margin-bottom:.45rem;color:var(--text-muted);font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.planning-table td:nth-child(3):before{content:"Midi"}.planning-table td:nth-child(4):before{content:"Soir"}.edit-actions{flex-wrap:wrap}.edit-actions button{flex:1 1 120px}}@media (max-width: 420px){.week-selector-form{flex-direction:column}.week-selector-form input,.week-selector-form button{width:100%}}.shopping-error{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;background:var(--danger-bg, #fee2e2);color:var(--danger, #dc2626);border:1px solid var(--danger, #dc2626);border-radius:var(--r-lg, .5rem);font-size:.875rem}.shopping-error-close{background:transparent;border:none;color:inherit;cursor:pointer;font-size:.85rem;padding:0 .25rem;box-shadow:none;flex-shrink:0}.shopping-wrap{width:100%;padding:2rem 2rem 4rem;max-width:800px;display:flex;flex-direction:column;gap:1.75rem}.shopping-wrap h1{margin-bottom:0}.shopping-actions{display:flex;gap:.75rem;flex-wrap:wrap}.prelist-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.25rem 1.5rem}.prelist-section h2{font-size:.95rem;margin-bottom:1rem}.prelist-items{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem;max-height:260px;overflow-y:auto}.prelist-items li label{display:flex;align-items:center;gap:.75rem;padding:.6rem .875rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;font-size:.875rem;color:var(--text);font-weight:500;transition:background var(--tr);text-transform:none;letter-spacing:0}.prelist-items li label:hover{background:var(--bg-hover)}.prelist-items li input[type=checkbox]{accent-color:var(--brand);width:15px;height:15px}.add-item-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.25rem 1.5rem}.add-item-section h2{font-size:.95rem;margin-bottom:1rem}.add-item-form{display:flex;gap:.75rem;flex-wrap:wrap}.add-item-form input{flex:1;min-width:160px}.add-item-form input:first-of-type{flex:2}.list-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden}.list-section h2{font-size:.95rem;padding:1rem 1.5rem .75rem;border-bottom:1px solid var(--border);margin:0}#shopping-list{list-style:none}#shopping-list li{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.5rem;border-bottom:1px solid var(--border-light);transition:background var(--tr);gap:.75rem}#shopping-list li:last-child{border-bottom:none}#shopping-list li:hover{background:var(--bg-hover)}#shopping-list li label{display:flex;align-items:center;gap:.75rem;cursor:pointer;flex:1;font-size:.9rem;color:var(--text);font-weight:500;text-transform:none;letter-spacing:0;min-width:0;overflow-wrap:anywhere}#shopping-list li input[type=checkbox]{accent-color:var(--brand);width:15px;height:15px;flex-shrink:0}#shopping-list li.checked label{color:var(--text-subtle);text-decoration:line-through}.delete-btn{background:transparent;border:none;color:var(--text-subtle);font-size:.85rem;padding:.25rem .4rem;border-radius:var(--r-sm);cursor:pointer;box-shadow:none;flex-shrink:0;transition:color var(--tr),background var(--tr)}.delete-btn:hover{color:var(--danger);background:var(--danger-bg);transform:none;filter:none;box-shadow:none}.list-section .empty{padding:2.5rem 1rem}@media (max-width: 768px){.shopping-wrap{padding:1.25rem 1rem 3rem}.shopping-actions .btn{flex:1 1 100%}.prelist-section,.add-item-section{padding:1rem}.add-item-form{flex-direction:column}.add-item-form input{flex:1;min-width:unset}.add-item-form button{width:100%}#shopping-list li{padding:.85rem 1rem;align-items:flex-start}}.scanner-wrap{width:100%;padding:2rem 2rem 4rem;max-width:640px;display:flex;flex-direction:column;gap:1.5rem}.scanner-wrap h1{margin-bottom:0}.mode-row{display:flex;gap:.75rem}.mode-row .btn{flex:1}.mode-row .btn.active{background:var(--grad-brand);color:#060a10}.mode-row .btn:not(.active){background:transparent;color:var(--text-muted);border-color:var(--border);box-shadow:none}.mode-row .btn:not(.active):hover{background:var(--bg-hover);transform:none;filter:none;box-shadow:none}.video-section{display:flex;flex-direction:column;align-items:center;gap:.875rem}.scanner-video{width:100%;max-width:480px;border-radius:var(--r-xl);background:#000;border:1px solid var(--border);aspect-ratio:4/3;object-fit:cover}.barcode-form{display:flex;gap:.75rem}.barcode-form input{flex:1}.product-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.product-form h2{font-size:.95rem;margin-bottom:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-group.checkbox label{flex-direction:row;align-items:center;gap:.5rem;text-transform:none;font-size:.875rem;font-weight:500;cursor:pointer}.form-group.checkbox input[type=checkbox]{accent-color:var(--brand);width:15px;height:15px}.lots-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.25rem 1.5rem}.lots-section h2{font-size:.95rem;margin-bottom:1rem}.lots-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.lot-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.625rem .875rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);font-size:.85rem;color:var(--text-muted)}@media (max-width: 768px){.scanner-wrap{padding:1.25rem 1rem 3rem}.form-row{grid-template-columns:1fr}.barcode-form{flex-direction:column}.barcode-form button{width:100%}.product-form,.lots-section{padding:1rem}}@media (max-width: 420px){.mode-row{flex-direction:column}.lot-item{align-items:flex-start;flex-direction:column}}.storage-wrap{width:100%;padding:2rem 2rem 4rem;max-width:900px}.storage-wrap h1{margin-bottom:.4rem}.storage-wrap>p{margin-bottom:2rem}.storage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.storage-card{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem 1.5rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-2xl);text-decoration:none;color:var(--text);position:relative;overflow:hidden;transition:background var(--tr),border-color var(--tr),transform var(--tr),box-shadow var(--tr)}.storage-card:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-brand);opacity:0;transition:opacity var(--tr);border-radius:var(--r-2xl) var(--r-2xl) 0 0}.storage-card:hover{background:var(--bg-elevated);border-color:#22d3ee40;transform:translateY(-3px);box-shadow:var(--shadow-md)}.storage-card:hover:after{opacity:1}.storage-card-icon{font-size:2rem;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl)}.storage-card-title{font-size:1rem;font-weight:700;color:var(--text)}.storage-card-desc{font-size:.82rem;color:var(--text-muted);line-height:1.5;flex:1}.storage-card-soon{opacity:.5;pointer-events:none}.storage-card-soon .storage-card-icon{filter:grayscale(1)}.storage-soon-tag{display:inline-flex;font-size:.68rem;font-weight:700;letter-spacing:.05em;color:var(--text-subtle);text-transform:uppercase;padding:.15em .5em;background:var(--bg-elevated);border:1px solid var(--border);border-radius:999px}@media (max-width: 768px){.storage-wrap{padding:1.25rem 1rem 3rem}.storage-grid{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.storage-grid{grid-template-columns:1fr}}.fridge-wrap{width:100%;padding:2rem 2rem 4rem;max-width:1000px}.fridge-header{margin-bottom:1.5rem}.fridge-header h1{margin-bottom:1rem}.fridge-header h1 .pill{font-size:.75rem;vertical-align:middle;margin-left:.5rem}.toolbar{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.toolbar input[type=search]{flex:1;min-width:200px;max-width:360px}#fridge-list{display:flex;flex-direction:column;gap:.75rem}.product-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;transition:border-color var(--tr)}.product-card:hover{border-color:var(--border-light)}.product-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;cursor:pointer;transition:background var(--tr)}.product-header:hover{background:var(--bg-hover)}.product-name{font-size:.9rem;font-weight:600;color:var(--text);flex:1;min-width:0;overflow-wrap:anywhere}.product-brand{font-size:.75rem;color:var(--text-subtle);background:var(--bg-elevated);border:1px solid var(--border);border-radius:999px;padding:.1em .6em}.product-lots{border-top:1px solid var(--border-light);padding:.75rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.lot-row{display:flex;align-items:center;gap:.875rem;padding:.625rem .875rem;background:var(--bg-elevated);border-radius:var(--r-lg);border:1px solid var(--border);font-size:.82rem;color:var(--text-muted);flex-wrap:wrap}.lot-row.expired{border-color:#ef44444d;background:#ef44440f}.lot-row.near-expiry{border-color:#f59e0b4d;background:#f59e0b0f}.lot-row.expired .lot-dlc{color:var(--danger);font-weight:700}.lot-row.near-expiry .lot-dlc{color:var(--warning);font-weight:700}.badge-frozen{display:inline-flex;align-items:center;gap:.3em;padding:.15em .6em;background:#3b82f61f;color:#60a5fa;border:1px solid rgba(59,130,246,.25);border-radius:999px;font-size:.72rem;font-weight:700}.product-card .product-lots{display:none}.product-card.open .product-lots{display:flex}#message-box{margin-bottom:1.25rem}@media (max-width: 768px){.fridge-wrap{padding:1.25rem 1rem 3rem}.toolbar{flex-direction:column;align-items:stretch}.toolbar input[type=search]{min-width:0;max-width:100%}.toolbar .btn{width:100%}.product-header{flex-wrap:wrap}.product-lots{padding:.75rem 1rem}.lot-row{align-items:stretch}.lot-row button{width:100%}}@media (max-width: 420px){.fridge-header h1 .pill{display:inline-flex;margin:.5rem 0 0}}.vitahome-wrap{width:100%;padding:2rem 2rem 4rem;max-width:1100px;display:flex;flex-direction:column;gap:2rem}.vitahome-header{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}.vitahome-header h1{margin:0;flex:1}.vitahome-datetime{text-align:right}.vitahome-datetime .vh-date{font-size:.82rem;color:var(--text-muted)}.vitahome-datetime .vh-time{font-size:1.3rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.weather-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-2xl);padding:1.75rem 2rem;background-image:radial-gradient(ellipse 60% 80% at 90% 50%,rgba(34,211,238,.06),transparent 60%);display:flex;align-items:center;gap:2rem;flex-wrap:wrap}.weather-main{display:flex;align-items:center;gap:1.25rem;min-width:0}.weather-icon{font-size:3rem;line-height:1}.weather-temp{font-size:2.5rem;font-weight:800;color:var(--brand);line-height:1}.weather-desc{font-size:.9rem;color:var(--text-muted);margin-top:.2rem}.weather-city{font-size:.78rem;color:var(--text-subtle)}.weather-details{display:flex;gap:1.5rem;flex-wrap:wrap;margin-left:auto}.weather-details>div{display:flex;flex-direction:column;gap:.2rem;align-items:center}.weather-details span:first-child{font-size:.75rem;color:var(--text-subtle)}.weather-details span:last-child{font-size:.9rem;font-weight:600;color:var(--text-muted)}.zones-section h2{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:1rem}.zone-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.875rem}.zone-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}.zone-card h3{font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0}.zone-temp{font-size:2rem;font-weight:800;color:var(--brand);line-height:1}.zone-humidity{font-size:.82rem;color:var(--text-muted)}.zone-comfort{font-size:.75rem;color:var(--success)}.zone-unavailable{font-size:.82rem;color:var(--text-subtle);font-style:italic;padding:.5rem 0}@media (max-width: 768px){.vitahome-wrap{padding:1.25rem 1rem 3rem}.vitahome-header{align-items:flex-start}.vitahome-datetime{width:100%;text-align:left}.weather-card{flex-direction:column;align-items:stretch;padding:1.25rem}.weather-main{flex-wrap:wrap}.weather-details{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));width:100%;margin-left:0;gap:1rem}}@media (max-width: 420px){.weather-details,.zone-cards{grid-template-columns:1fr}}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px}.stat-brand:before{background:var(--grad-brand)}.stat-accent:before{background:linear-gradient(90deg,#10b981,#34d399)}.stat-purple:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.stat-danger:before{background:linear-gradient(90deg,#ef4444,#f87171)}.stat-icon{font-size:1.5rem;flex-shrink:0}.stat-body{min-width:0}.stat-value{font-size:1.75rem;font-weight:800;color:var(--text);line-height:1}.stat-label{font-size:.78rem;color:var(--text-muted);margin-top:.25rem}.roles-grid{display:flex;flex-wrap:wrap;gap:.75rem}.role-stat{display:flex;align-items:center;gap:.6rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:.5rem 1rem}.role-count{font-weight:700;font-size:1rem;color:var(--text)}.actions-grid{display:flex;flex-direction:column;gap:.75rem}.action-link{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);text-decoration:none;color:inherit;transition:all var(--tr)}.action-link:hover{border-color:var(--brand);background:var(--bg-hover)}.action-icon{font-size:1.25rem;flex-shrink:0}.action-body{flex:1;min-width:0}.action-label{font-weight:600;font-size:.9rem;color:var(--text)}.action-desc{font-size:.78rem;color:var(--text-muted);margin-top:.2rem}.action-arrow{color:var(--text-subtle);font-size:1rem;transition:transform var(--tr)}.action-link:hover .action-arrow{transform:translate(4px);color:var(--brand)}.skeleton-sm{display:inline-block;width:2.5rem;height:1.5rem;border-radius:var(--r-md);background:linear-gradient(90deg,var(--bg-elevated) 0%,var(--bg-hover) 50%,var(--bg-elevated) 100%);background-size:200% 100%;animation:shimmer 1.4s infinite}@keyframes shimmer{to{background-position:-200% 0}}@media (max-width: 900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 500px){.stats-grid{grid-template-columns:1fr}.stat-card{padding:1rem}.action-link{align-items:flex-start;padding:1rem}}.users-toolbar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.users-search{flex:1;min-width:200px;max-width:360px}.role-filters{display:flex;gap:.5rem;flex-wrap:wrap}.users-list{display:flex;flex-direction:column;gap:.75rem}.user-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;transition:border-color var(--tr)}.user-row:hover{border-color:var(--border-light)}.user-row.editing{border-color:#22d3ee4d;background:#22d3ee05}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--grad-brand);color:#000;font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-info{flex:1;min-width:160px;overflow-wrap:anywhere}.user-name{font-weight:600;font-size:.9rem;color:var(--text)}.user-email{font-size:.78rem;color:var(--text-muted);margin-top:.15rem}.user-phone{font-size:.75rem;color:var(--text-subtle);margin-top:.1rem}.user-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.user-perms{display:flex;gap:.35rem;flex-wrap:wrap;width:100%;padding-top:.5rem}.user-actions{display:flex;gap:.5rem;flex-shrink:0}.user-edit-form{width:100%}@media (max-width: 600px){.users-search{max-width:100%}.users-toolbar{flex-direction:column;align-items:stretch}.user-row{align-items:flex-start;padding:1rem}.user-info{min-width:0}.user-actions{width:100%}.user-actions button{flex:1}}.logs-toolbar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}.pill-log.active.pill-warn{background:#f59e0b1f;color:#fbbf24;border-color:#f59e0b4d}.pill-log.active.pill-error{background:#ef44441f;color:#f87171;border-color:#ef44444d}.pill-log.active.pill-info{background:#3b82f61f;color:#60a5fa;border-color:#3b82f64d}.logs-timeline{display:flex;flex-direction:column;gap:.5rem}.log-entry{display:flex;align-items:flex-start;gap:1rem;padding:.875rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);font-size:.82rem;border-left-width:3px}.log-entry.log-error{border-left-color:#ef4444;background:#ef44440a}.log-entry.log-warn{border-left-color:#f59e0b;background:#f59e0b0a}.log-entry.log-info{border-left-color:#3b82f6;background:#3b82f60a}.log-left{display:flex;flex-direction:column;gap:.25rem;flex-shrink:0;width:80px}.log-level-badge{display:inline-block;padding:.1em .5em;border-radius:999px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;text-align:center}.level-error{background:#ef444426;color:#f87171}.level-warn{background:#f59e0b26;color:#fbbf24}.level-info{background:#3b82f626;color:#60a5fa}.log-time{color:var(--text-subtle);font-size:.7rem;font-variant-numeric:tabular-nums}.log-body{flex:1;min-width:0}.log-message{color:var(--text);line-height:1.4}.log-detail{color:var(--text-muted);font-size:.75rem;margin-top:.2rem;font-family:var(--font-mono);overflow-wrap:anywhere}.log-uid{color:var(--text-subtle);font-size:.72rem;margin-top:.15rem}@media (max-width: 600px){.logs-toolbar .pill{flex:1 1 auto}.log-entry{flex-direction:column;gap:.35rem}.log-left{flex-direction:row;align-items:center;width:auto}}.admin-wrap{width:100%;padding:2rem 2rem 4rem;max-width:1100px}.admin-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:2rem}.admin-page-header h1{margin:0}.admin-subtitle{color:var(--text-muted);font-size:.85rem;margin-top:.25rem}.admin-forbidden{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.forbidden-icon{font-size:3rem;margin-bottom:1rem}.admin-forbidden h2{margin-bottom:.5rem;color:var(--text)}.section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:1rem}.admin-section{margin-bottom:2rem}.alert{padding:.75rem 1rem;border-radius:var(--r-lg);font-size:.85rem;margin-bottom:1rem}.alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.alert-success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#34d399}.loading-row,.empty-row{padding:2rem;text-align:center;color:var(--text-subtle);font-size:.875rem}.pill{padding:.3em .9em;border-radius:999px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);font-size:.78rem;font-weight:600;cursor:pointer;transition:all var(--tr)}.pill:hover,.pill.active{background:var(--brand-bg);color:var(--brand);border-color:#22d3ee4d}.role-badge{display:inline-block;padding:.15em .7em;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.role-site_admin{background:#ef44441f;color:#f87171;border:1px solid rgba(239,68,68,.25)}.role-family_admin{background:#f59e0b1f;color:#fbbf24;border:1px solid rgba(245,158,11,.25)}.role-family_user,.role-user{background:#10b9811f;color:#34d399;border:1px solid rgba(16,185,129,.25)}.family-pill{display:inline-block;padding:.15em .6em;border-radius:999px;font-size:.72rem;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.inactive-pill{display:inline-block;padding:.15em .6em;border-radius:999px;font-size:.72rem;background:#ef44441a;color:#f87171;border:1px solid rgba(239,68,68,.25)}.admin-form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.5rem;margin-bottom:1.5rem}.form-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.form-card-header h3{margin:0;font-size:.95rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:0}.form-group label{font-size:.78rem;font-weight:600;color:var(--text-muted)}.form-actions{display:flex;gap:.75rem;margin-top:1.25rem}.perms-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.perm-check{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--text-muted);cursor:pointer;padding:.25em .6em;border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-elevated);transition:all var(--tr)}.perm-check:hover{border-color:var(--brand);color:var(--brand)}.perm-check input{accent-color:var(--brand)}.perm-tag{display:inline-block;padding:.1em .5em;border-radius:var(--r-md);font-size:.7rem;background:var(--brand-bg);color:var(--brand);border:1px solid rgba(34,211,238,.2)}.btn-icon{background:none;border:none;color:var(--text-subtle);cursor:pointer;font-size:1rem;padding:.25rem;border-radius:var(--r-md);transition:color var(--tr)}.btn-icon:hover{color:var(--text)}.btn-sm{padding:.35em .85em;font-size:.78rem}.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border);box-shadow:none}.btn-ghost:hover{background:var(--bg-hover);transform:none;filter:none;box-shadow:none}.btn-danger{background:#ef44441f;color:#f87171;border-color:#ef444440;box-shadow:none}.btn-danger:hover{background:#ef444433;transform:none;filter:none;box-shadow:none}@media (max-width: 768px){.admin-wrap{padding:1.25rem 1rem 3rem}.admin-page-header{flex-direction:column;align-items:stretch;gap:.75rem;margin-bottom:1.25rem}.admin-form-card{padding:1rem}.form-card-header{align-items:flex-start;flex-direction:column;gap:.75rem}.form-row{grid-template-columns:1fr}.form-actions{flex-wrap:wrap}}@media (max-width: 480px){.form-actions{flex-direction:column}.form-actions button{width:100%}}.settings-section{margin-bottom:2rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.5rem}.env-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem}.env-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg)}.env-key{font-size:.8rem;color:var(--text-muted);font-weight:600;font-family:var(--font-mono)}.env-val{font-family:var(--font-mono);font-size:.78rem;color:var(--brand);background:var(--brand-bg);padding:.2em .5em;border-radius:var(--r-sm);overflow-wrap:anywhere}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.service-card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg)}.service-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent);flex-shrink:0}.service-name{font-weight:600;font-size:.875rem;color:var(--text)}.service-port{font-size:.75rem;color:var(--text-subtle);font-family:var(--font-mono)}.checklist{display:flex;flex-direction:column;gap:.5rem}.check-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);font-size:.875rem;color:var(--text-muted)}.check-ok{border-left:3px solid #10b981}.check-warn{border-left:3px solid #f59e0b}.check-icon{font-weight:700;flex-shrink:0;width:1rem;text-align:center}.check-ok .check-icon{color:#10b981}.check-warn .check-icon{color:#f59e0b}@media (max-width: 600px){.settings-section{padding:1rem}.env-grid,.services-grid{grid-template-columns:1fr}.env-row{align-items:flex-start;flex-direction:column;gap:.35rem}}.wx-wrap{width:100%;padding:2rem 2rem 4rem;max-width:1100px;display:flex;flex-direction:column;gap:1.75rem}.wx-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.wx-header h1{margin:0}.wx-subtitle{color:var(--text-muted);font-size:.85rem;margin-top:.25rem}.wx-search-wrap{position:relative;width:100%;max-width:480px}.wx-search-box{display:flex;align-items:center;gap:.6rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:0 1rem;transition:border-color var(--tr),box-shadow var(--tr)}.wx-search-box:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px #22d3ee1a}.wx-search-icon{font-size:.9rem;color:var(--text-subtle);flex-shrink:0}.wx-search-spin{font-size:.85rem;flex-shrink:0}.wx-search-input{flex:1;background:transparent;border:none;padding:.7em 0;font-size:.9rem;color:var(--text);outline:none;box-shadow:none}.wx-search-input:focus{box-shadow:none;border-color:transparent;background:transparent}.wx-suggestions{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--r-xl);box-shadow:var(--shadow-md);z-index:100;list-style:none;overflow:hidden}.wx-suggestion-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem 1.1rem;cursor:pointer;transition:background var(--tr);border-bottom:1px solid var(--border)}.wx-suggestion-item:last-child{border-bottom:none}.wx-suggestion-item:hover{background:var(--bg-hover)}.wx-sugg-name{font-weight:600;font-size:.875rem;color:var(--text)}.wx-sugg-meta{font-size:.76rem;color:var(--text-muted);text-align:right}.wx-empty{text-align:center;padding:4rem 2rem}.wx-empty-icon{font-size:3rem;margin-bottom:1rem}.wx-empty p{margin-bottom:.25rem;color:var(--text-muted)}.wx-empty-hint{font-size:.8rem;color:var(--text-subtle)}.wx-skeleton-wrap{display:flex;flex-direction:column;gap:1.25rem}.wx-skeleton-hero{height:240px;border-radius:var(--r-2xl)}.wx-skeleton-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.wx-skeleton-card{height:90px;border-radius:var(--r-xl)}.wx-hero{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-2xl);padding:2rem;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1.75rem}.wx-hero-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 70% at 95% 0%,rgba(34,211,238,.1),transparent 55%),radial-gradient(ellipse 50% 60% at 0% 100%,rgba(16,185,129,.07),transparent 55%);pointer-events:none}.wx-hero-main{position:relative;display:flex;align-items:center;gap:1.75rem}.wx-hero-icon{font-size:4rem;width:96px;height:96px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-2xl);flex-shrink:0;box-shadow:var(--shadow-sm)}.wx-temp-big{font-size:clamp(3rem,8vw,4.5rem);font-weight:800;line-height:1;background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.25rem}.wx-temp-label{font-size:1.05rem;font-weight:600;color:var(--text);margin-bottom:.2rem}.wx-temp-feels{font-size:.85rem;color:var(--text-muted)}.wx-hero-stats{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.wx-stat{display:flex;align-items:center;gap:.65rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);padding:.75rem 1rem}.wx-stat-icon{font-size:1.1rem;flex-shrink:0}.wx-stat-body{display:flex;flex-direction:column;gap:.1rem;min-width:0}.wx-stat-label{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.wx-stat-value{font-size:.9rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.wx-uv-badge{padding:.1em .55em;border-radius:999px;font-size:.68rem;font-weight:700}.uv-low{background:#10b98126;color:#34d399}.uv-mod{background:#f59e0b26;color:#fbbf24}.uv-high{background:#ef444426;color:#f87171}.uv-vhigh{background:#ef444440;color:#ef4444}.uv-extreme{background:#8b000040;color:#f44}.wx-section{display:flex;flex-direction:column;gap:.875rem}.wx-section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.wx-hourly-scroll{display:flex;gap:.6rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:thin}.wx-hourly-scroll::-webkit-scrollbar{height:4px}.wx-hourly-scroll::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:99px}.wx-hour-card{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.75rem .875rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);min-width:72px;flex-shrink:0;transition:background var(--tr),border-color var(--tr)}.wx-hour-card:hover{background:var(--bg-elevated);border-color:#22d3ee33}.wx-hour-time{font-size:.72rem;color:var(--text-muted);font-weight:600}.wx-hour-icon{font-size:1.25rem}.wx-hour-temp{font-size:.9rem;font-weight:700;color:var(--text)}.wx-hour-rain{font-size:.68rem;color:#60a5fa}.wx-daily-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.6rem}.wx-day-card{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:1rem .5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);text-align:center;min-width:0;transition:background var(--tr),border-color var(--tr),transform var(--tr)}.wx-day-card:hover{background:var(--bg-elevated);border-color:#22d3ee33;transform:translateY(-2px)}.wx-day-today{border-color:#22d3ee59;background:#22d3ee0a}.wx-day-name{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.wx-day-icon{font-size:1.6rem;margin:.1rem 0}.wx-day-label{font-size:.68rem;color:var(--text-muted);line-height:1.2;min-height:1.6em}.wx-day-temps{display:flex;align-items:baseline;gap:.25rem}.wx-day-max{font-size:.95rem;font-weight:800;color:var(--text)}.wx-day-sep{font-size:.75rem;color:var(--text-subtle)}.wx-day-min{font-size:.82rem;font-weight:600;color:var(--text-muted)}.wx-day-rain{font-size:.68rem;color:#60a5fa}@media (max-width: 900px){.wx-hero-stats{grid-template-columns:repeat(2,1fr)}.wx-daily-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.wx-wrap{padding:1.25rem 1rem 3rem;gap:1.25rem}.wx-header{flex-direction:column;align-items:stretch}.wx-header .btn{align-self:flex-start}.wx-hero{padding:1.25rem}.wx-hero-icon{width:68px;height:68px;font-size:2.5rem}.wx-skeleton-row{grid-template-columns:repeat(2,1fr)}}@media (max-width: 560px){.wx-hero-main{flex-direction:column;align-items:flex-start;gap:1rem}.wx-hero-stats{grid-template-columns:1fr 1fr}.wx-daily-grid{grid-template-columns:repeat(3,1fr)}.wx-suggestion-item{align-items:flex-start;flex-direction:column;gap:.15rem}.wx-sugg-meta{text-align:left}}@media (max-width: 380px){.wx-hero-stats{grid-template-columns:1fr}.wx-daily-grid{grid-template-columns:repeat(2,1fr)}}.tv-launch{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#060f1c,#091520 55%,#05101a);cursor:pointer;-webkit-user-select:none;user-select:none}.tv-launch-inner{display:flex;flex-direction:column;align-items:center;gap:1rem;animation:tv-launch-pulse 2.4s ease-in-out infinite}@keyframes tv-launch-pulse{0%,to{opacity:.75;transform:scale(1)}50%{opacity:1;transform:scale(1.03)}}.tv-launch-brand{font-size:1.6rem;font-weight:800;color:#dde6f073;letter-spacing:.12em;text-transform:uppercase}.tv-launch-brand span{color:#22d3ee}.tv-launch-icon{font-size:clamp(3rem,8vw,6rem)}.tv-launch-title{font-size:clamp(1.6rem,4vw,3rem);font-weight:700;color:#dde6f0}.tv-launch-sub{font-size:clamp(.9rem,2vw,1.2rem);color:#dde6f073}.tv-wakelock-dot{color:#4ade80;margin-right:.6rem;font-size:.65rem;vertical-align:middle}.tv-root *,.tv-root *:before,.tv-root *:after{box-sizing:border-box;margin:0;padding:0}.tv-root{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;overflow:hidden;font-family:Segoe UI,system-ui,-apple-system,sans-serif;transition:background 1.2s,color 1.2s}.tv-day{--c-bg: #07111f;--c-text: #dde6f0;--c-muted: rgba(221,230,240,.55);--c-subtle: rgba(221,230,240,.22);--c-card: rgba(255,255,255,.04);--c-border: rgba(255,255,255,.07);--c-accent: #22d3ee;--c-glow: rgba(34,211,238,.12);background:linear-gradient(145deg,#060f1c,#091520 55%,#05101a);color:var(--c-text)}.tv-night{--c-bg: #010107;--c-text: #7a8895;--c-muted: rgba(122,136,149,.45);--c-subtle: rgba(122,136,149,.2);--c-card: rgba(255,255,255,.02);--c-border: rgba(255,255,255,.04);--c-accent: #d97706;--c-glow: rgba(217,119,6,.08);background:#010107;color:var(--c-text)}.tv-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;pointer-events:none;z-index:50;transition:opacity .6s ease}.tv-glow{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;background:radial-gradient(ellipse 55% 45% at 12% 15%,var(--c-glow),transparent 60%),radial-gradient(ellipse 40% 35% at 88% 80%,rgba(129,140,248,.05),transparent 60%);transition:background 1.2s}.tv-header{position:relative;z-index:100;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem;padding:.9rem 2.5rem;border-bottom:1px solid var(--c-border);background:#00000040;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex-shrink:0}.tv-brand{font-size:1rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:var(--c-muted)}.tv-brand span{color:var(--c-accent)}.tv-clock-wrap{display:flex;flex-direction:column;align-items:center;gap:.05rem}.tv-clock{display:flex;align-items:baseline;gap:.15em;line-height:1}.tv-hm{font-size:clamp(3.2rem,7vw,6rem);font-weight:800;letter-spacing:.04em;font-variant-numeric:tabular-nums;color:var(--c-text);text-shadow:0 0 60px var(--c-glow),0 0 20px var(--c-glow);transition:text-shadow 1.2s}.tv-ss{font-size:clamp(1.5rem,3vw,2.6rem);font-weight:300;color:var(--c-muted);font-variant-numeric:tabular-nums}.tv-date{font-size:clamp(.8rem,1.4vw,1.05rem);color:var(--c-muted);text-transform:capitalize;letter-spacing:.04em}.tv-hdr-right{display:flex;align-items:center;gap:1rem;justify-content:flex-end}.tv-wx-pill{display:flex;align-items:center;gap:.35rem;background:var(--c-card);border:1px solid var(--c-border);border-radius:14px;padding:.4rem 1rem}.tv-wx-pill span:first-child{font-size:1.6rem}.tv-wx-t{font-size:1.6rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--c-text)}.tv-controls{display:flex;align-items:center;gap:.5rem}.tv-bright{display:flex;align-items:center;gap:.4rem;color:var(--c-muted);font-size:1rem;cursor:pointer}.tv-bright input[type=range]{width:80px;accent-color:var(--c-accent);cursor:pointer}.tv-btn{background:var(--c-card);border:1px solid var(--c-border);color:var(--c-muted);width:2.5rem;height:2.5rem;border-radius:10px;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s,color .2s}.tv-btn:hover{background:#ffffff1a;border-color:var(--c-accent);color:var(--c-text)}.tv-btn.on{border-color:var(--c-accent);color:var(--c-accent)}.tv-main{position:relative;z-index:10;flex:1;display:grid;grid-template-columns:1fr 1.3fr .85fr;gap:1.1rem;padding:1.1rem 2.5rem;min-height:0;overflow:hidden}.tv-card{background:var(--c-card);border:1px solid var(--c-border);border-radius:22px;padding:1.35rem 1.6rem;display:flex;flex-direction:column;gap:.9rem;overflow:hidden;position:relative}.tv-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:22px;background:linear-gradient(160deg,rgba(255,255,255,.04) 0%,transparent 45%);pointer-events:none}.tv-card:before{content:"";position:absolute;top:0;left:1.5rem;right:1.5rem;height:2px;background:var(--c-accent);border-radius:0 0 2px 2px;opacity:0;transition:opacity .3s}.tv-card:hover:before{opacity:.5}.tv-card-hd{display:flex;align-items:center;gap:.55rem;padding-bottom:.7rem;border-bottom:1px solid var(--c-border);flex-shrink:0;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--c-muted)}.tv-card-hd span:first-child{font-size:1.1rem}.tv-meals{display:flex;flex-direction:column;gap:.6rem;flex:1;overflow:hidden}.tv-meal{padding:.7rem .9rem;border-radius:14px;border:1px solid transparent;transition:background .4s,border-color .4s}.tv-meal-active{background:linear-gradient(135deg,#22d3ee12,#22d3ee08);border-color:#22d3ee2e}.tv-night .tv-meal-active{background:linear-gradient(135deg,#d9770612,#d9770608);border-color:#d9770626}.tv-meal-label{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--c-muted);text-transform:uppercase;letter-spacing:.07em;font-weight:600;margin-bottom:.3rem}.tv-meal-icon{font-size:.95rem}.tv-now-pill{background:var(--c-accent);color:#000;font-size:.6rem;font-weight:800;padding:.15em .55em;border-radius:20px;letter-spacing:.05em}.tv-meal-name{font-size:clamp(1.1rem,2.3vw,1.85rem);font-weight:700;color:var(--c-text);line-height:1.25}.tv-sensors{display:flex;flex-direction:column;gap:.85rem;flex:1;overflow:hidden}.tv-sensor{display:flex;flex-direction:column;gap:.3rem}.tv-sensor-top{display:flex;justify-content:space-between;align-items:center}.tv-sensor-name{font-size:clamp(.9rem,1.6vw,1.15rem);color:var(--c-muted);font-weight:500}.tv-sensor-hum{font-size:.78rem;color:var(--c-subtle)}.tv-sensor-bottom{display:flex;align-items:center;gap:.8rem}.tv-bar-track{flex:1;height:7px;background:#ffffff14;border-radius:99px;overflow:hidden}.tv-bar-fill{height:100%;border-radius:99px;transition:width 1.2s ease,background 1.2s ease;box-shadow:0 0 10px currentColor}.tv-sensor-val{font-size:clamp(1.15rem,2.2vw,1.75rem);font-weight:700;font-variant-numeric:tabular-nums;min-width:5.5rem;text-align:right;transition:color 1.2s}.tv-sensor-pending{opacity:.45}.tv-sensor-wait{font-size:1.1rem;color:var(--c-subtle)}.tv-aside{display:flex;flex-direction:column;gap:1.1rem}.tv-card-weather{flex:1}.tv-card-shop{flex:0 0 auto}.tv-weather{display:flex;flex-direction:column;gap:.4rem;flex:1;justify-content:center}.tv-weather-temp{font-size:clamp(2.8rem,5.5vw,5rem);font-weight:800;line-height:1;font-variant-numeric:tabular-nums;color:var(--c-text);text-shadow:0 0 40px var(--c-glow)}.tv-weather-desc{font-size:clamp(.85rem,1.5vw,1.1rem);color:var(--c-muted);text-transform:capitalize}.tv-weather-extras{display:flex;gap:1rem;font-size:.85rem;color:var(--c-subtle);margin-top:.2rem}.tv-shop{display:flex;align-items:center;justify-content:center;padding:.4rem 0}.tv-shop-ok{display:flex;align-items:center;gap:.5rem;color:var(--c-muted);font-size:clamp(.9rem,1.4vw,1.05rem)}.tv-check{color:#34d399;font-size:clamp(1.4rem,2.5vw,2rem);font-weight:700}.tv-shop-count{display:flex;align-items:baseline;gap:.5rem}.tv-shop-n{font-size:clamp(2.2rem,4.5vw,4rem);font-weight:800;color:var(--c-accent);font-variant-numeric:tabular-nums;line-height:1}.tv-shop-count>span:last-child{font-size:clamp(.85rem,1.4vw,1rem);color:var(--c-muted);line-height:1.3}.tv-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;flex:1;opacity:.3;font-size:clamp(.85rem,1.3vw,1rem)}.tv-empty span:first-child{font-size:2rem}.tv-footer{position:relative;z-index:10;text-align:right;font-size:.7rem;color:var(--c-subtle);padding:.35rem 2.5rem;flex-shrink:0}@media (min-width: 1920px){.tv-header{padding:1rem 3.5rem}.tv-main{padding:1.4rem 3.5rem;gap:1.5rem}.tv-footer{padding:.5rem 3.5rem}.tv-card{padding:1.75rem 2rem}}:fullscreen .tv-root,:-webkit-full-screen .tv-root{overflow:hidden}.vinteli-wrap{width:100%;max-width:900px;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.vinteli-hero{display:flex;align-items:center;gap:1.25rem}.vinteli-hero-icon{font-size:3rem;line-height:1}.vinteli-hero h1{margin:0 0 .25rem;font-size:2rem}.vinteli-hero p{margin:0;opacity:.7}.vinteli-card{background:var(--surface, #1e293b);border:1px solid var(--border, rgba(255,255,255,.08));border-radius:14px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;min-width:0}.vinteli-card h2{margin:0;font-size:1.1rem}.vinteli-card-hd{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.vinteli-stats{display:flex;gap:2rem;flex-wrap:wrap}.vstat{display:flex;flex-direction:column}.vstat-value{font-size:1.8rem;font-weight:700;line-height:1}.vstat-label{font-size:.8rem;opacity:.55;margin-top:.2rem}.vinteli-controls{display:flex;align-items:center;flex-wrap:wrap;gap:1rem}.vinteli-controls label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;opacity:.7}.vinteli-controls input[type=date]{background:var(--input-bg, rgba(255,255,255,.06));border:1px solid var(--border, rgba(255,255,255,.1));color:inherit;border-radius:8px;padding:.4rem .7rem;font-size:.95rem}.vinteli-moments{display:flex;gap:.5rem;flex-wrap:wrap}.vbtn{border:1px solid var(--border, rgba(255,255,255,.12));border-radius:8px;padding:.45rem 1rem;font-size:.9rem;cursor:pointer;transition:all .15s;white-space:nowrap}.vbtn--primary{background:#6366f1;color:#fff;border-color:#6366f1}.vbtn--primary:hover:not(:disabled){background:#4f46e5}.vbtn--ghost{background:transparent;color:inherit}.vbtn--ghost:hover:not(:disabled){background:#ffffff0f}.vbtn--toggle{background:transparent;color:inherit;opacity:.6}.vbtn--toggle.active{background:#6366f133;border-color:#6366f1;opacity:1}.vbtn:disabled{opacity:.4;cursor:not-allowed}.vinteli-week{display:grid;grid-template-columns:repeat(7,1fr);gap:.75rem}@media (max-width: 768px){.vinteli-wrap{padding:1.25rem 1rem 3rem}.vinteli-hero{align-items:flex-start}.vinteli-controls{align-items:stretch;flex-direction:column}.vinteli-moments .vbtn{flex:1 1 44%}.vinteli-week{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.vinteli-card{padding:1rem}.vinteli-hero{flex-direction:column}.vinteli-stats{gap:1rem}.vinteli-moments{flex-direction:column}.vinteli-moments .vbtn,.vinteli-regen .vbtn{width:100%}.vinteli-week{grid-template-columns:1fr}}.vinteli-day{display:flex;flex-direction:column;gap:.5rem}.vinteli-day-label{display:flex;flex-direction:column;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:.4rem;margin-bottom:.1rem}.vinteli-day-name{font-weight:600;font-size:.95rem}.vinteli-day-date{font-size:.75rem;opacity:.5}.vinteli-slot{background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:.5rem .6rem;display:flex;flex-direction:column;gap:.2rem}.vinteli-slot--empty{opacity:.4}.vinteli-slot-moment{font-size:.7rem;opacity:.55}.vinteli-slot-meal{font-size:.9rem;font-weight:600}.vinteli-slot-reason{font-size:.7rem;opacity:.5;font-style:italic}.vinteli-regen{display:flex;justify-content:center}.vinteli-msg{padding:.8rem 1.2rem;border-radius:10px;font-size:.95rem}.vinteli-msg--success{background:#4ade801f;border:1px solid rgba(74,222,128,.3);color:#4ade80}.vinteli-msg--error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#ef4444}.vinteli-muted{opacity:.45;font-size:.9rem;margin:0}:root{--bg-base: #080c12;--bg-surface: #0f1520;--bg-card: #111827;--bg-elevated: #1a2235;--bg-hover: rgba(255,255,255,.04);--glass-bg: rgba(15, 21, 32, .75);--glass-border:rgba(255,255,255,.07);--border: #1e2a3a;--border-light:#253040;--border-focus:#22d3ee;--text: #e8edf5;--text-muted: #7b8fa6;--text-subtle: #4a5a6e;--brand: #22d3ee;--brand-dark: #0ea5c9;--brand-glow: rgba(34,211,238,.2);--brand-bg: rgba(34,211,238,.08);--accent: #10b981;--accent-glow: rgba(16,185,129,.2);--accent-bg: rgba(16,185,129,.08);--success: #10b981;--success-bg: rgba(16,185,129,.1);--warning: #f59e0b;--warning-bg: rgba(245,158,11,.1);--danger: #ef4444;--danger-bg: rgba(239,68,68,.1);--info: #3b82f6;--info-bg: rgba(59,130,246,.1);--grad-brand: linear-gradient(135deg, #22d3ee 0%, #10b981 100%);--grad-card: linear-gradient(135deg, rgba(34,211,238,.05) 0%, transparent 60%);--grad-bg: radial-gradient(ellipse 80% 50% at 80% -10%, rgba(34,211,238,.07), transparent), radial-gradient(ellipse 60% 50% at -10% 100%, rgba(16,185,129,.06), transparent), var(--bg-base);--shadow-xs: 0 1px 3px rgba(0,0,0,.4);--shadow-sm: 0 2px 10px rgba(0,0,0,.5);--shadow-md: 0 6px 24px rgba(0,0,0,.5);--shadow-lg: 0 16px 48px rgba(0,0,0,.6);--shadow-glow: 0 0 24px rgba(34,211,238,.15);--r-xs: .25rem;--r-sm: .4rem;--r: .6rem;--r-lg: .875rem;--r-xl: 1.125rem;--r-2xl: 1.5rem;--gap-xs: .375rem;--gap-sm: .625rem;--gap: 1rem;--gap-lg: 1.5rem;--gap-xl: 2rem;--gap-2xl:3rem;--font: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--sidebar-w: 64px;--sidebar-w-open: 240px;--tr: .15s ease;--tr-slow: .28s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;height:100%;width:100%;overflow-x:hidden}body{min-height:100%;width:100%;overflow-x:hidden;background:var(--bg-base);background:var(--grad-bg);background-attachment:fixed;color:var(--text);font-family:var(--font);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;width:100%;min-width:0;display:flex}main{flex:1;width:100%;min-width:0}img,svg,video,canvas{max-width:100%}h1,h2,h3,h4,h5,h6{color:var(--text);font-weight:700;line-height:1.3;letter-spacing:-.015em}h1{font-size:clamp(1.5rem,3.5vw,2.1rem)}h2{font-size:clamp(1.15rem,2.5vw,1.55rem)}h3{font-size:1.05rem}h4{font-size:.95rem}p{color:var(--text-muted);line-height:1.75;margin-bottom:.875rem}a{color:var(--brand);text-decoration:none;transition:color var(--tr),opacity var(--tr)}a:hover{color:#67e8f9}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45em;padding:.6em 1.2em;font-family:var(--font);font-size:.875rem;font-weight:600;line-height:1;border-radius:var(--r-lg);border:1px solid transparent;cursor:pointer;min-width:0;max-width:100%;min-height:42px;white-space:nowrap;text-decoration:none;transition:all var(--tr);-webkit-user-select:none;user-select:none;background:var(--grad-brand);color:#060a10;box-shadow:0 2px 12px #22d3ee40}button:hover:not(:disabled),.btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 20px #22d3ee59}button:active:not(:disabled),.btn:active:not(:disabled){transform:none}button:disabled,.btn:disabled{opacity:.45;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--brand);border-color:var(--border-light);box-shadow:none}.btn-secondary:hover:not(:disabled){background:var(--brand-bg);border-color:var(--brand);box-shadow:none}.btn-ghost{background:transparent;color:var(--text-muted);border-color:transparent;box-shadow:none}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text);box-shadow:none;transform:none;filter:none}.btn-danger{background:var(--danger);color:#fff;border-color:transparent;box-shadow:0 2px 12px #ef444440}.btn-danger:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 4px 20px #ef444459}.btn-sm{font-size:.78rem;padding:.35em .75em;border-radius:var(--r)}.btn-icon{padding:.5em;border-radius:var(--r);background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border);box-shadow:none}.btn-icon:hover{background:var(--bg-hover);color:var(--text);transform:none;box-shadow:none;filter:none}.form-group{display:flex;flex-direction:column;gap:.4rem}label{font-size:.8rem;font-weight:600;color:var(--text-muted);letter-spacing:.02em}input,select,textarea{width:100%;min-width:0;padding:.65em .9em;font-family:var(--font);font-size:.9rem;color:var(--text);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);outline:none;transition:border-color var(--tr),box-shadow var(--tr),background var(--tr);-webkit-appearance:none;-moz-appearance:none;appearance:none}input::placeholder,textarea::placeholder{color:var(--text-subtle)}input:focus,select:focus,textarea:focus{border-color:var(--brand);background:var(--bg-card);box-shadow:0 0 0 3px #22d3ee1f}input[type=search]::-webkit-search-cancel-button{display:none}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.375rem 1.5rem;box-shadow:var(--shadow-sm)}.card-glass{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-xl);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);box-shadow:var(--shadow-sm)}.badge{display:inline-flex;align-items:center;gap:.3em;padding:.2em .6em;font-size:.72rem;font-weight:700;border-radius:999px;letter-spacing:.03em}.badge-brand{background:var(--brand-bg);color:var(--brand)}.badge-green{background:var(--success-bg);color:var(--success)}.badge-warn{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.pill{display:inline-flex;align-items:center;padding:.15em .65em;font-size:.78rem;font-weight:600;border-radius:999px;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.alert{display:flex;align-items:flex-start;gap:.65rem;padding:.85rem 1.1rem;border-radius:var(--r-lg);font-size:.875rem;font-weight:500;margin-bottom:1rem}.alert.success{background:var(--success-bg);color:var(--success);border:1px solid rgba(16,185,129,.25)}.alert.error{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.25)}.alert.warning{background:var(--warning-bg);color:var(--warning);border:1px solid rgba(245,158,11,.25)}.alert.info{background:var(--info-bg);color:var(--info);border:1px solid rgba(59,130,246,.25)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9000;padding:1rem}.modal{background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--r-2xl);padding:2rem;max-width:420px;width:100%;box-shadow:var(--shadow-lg);animation:modalIn .22s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal p{margin:0 0 1.5rem;color:var(--text);font-size:1rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--r);color:transparent}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-text,.empty{color:var(--text-muted);text-align:center;padding:3rem 1rem;font-size:.9rem}.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;background:var(--bg-elevated);color:var(--text);padding:.5rem .9rem;border-radius:var(--r);border:1px solid var(--border-focus);z-index:9999}.page-wrap{padding:2rem 2rem 4rem;width:100%;max-width:1200px;min-width:0}@media (max-width: 768px){body{background-attachment:scroll}button,.btn{min-height:44px;white-space:normal;text-align:center}.sidebar-tv,.sidebar-logout{min-height:0;white-space:nowrap}.card,.card-glass{padding:1rem;border-radius:var(--r-lg)}.modal{padding:1.25rem;border-radius:var(--r-xl)}.modal-actions{flex-direction:column}.modal-actions button{width:100%}.page-wrap{padding:1.25rem 1rem 3rem}}.table-wrapper{overflow-x:auto;border-radius:var(--r-xl);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:.875rem}th{background:var(--bg-elevated);color:var(--text-muted);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}td{padding:.85rem 1rem;border-bottom:1px solid var(--border-light);color:var(--text);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--bg-hover)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-subtle)}.app-shell{display:flex;min-height:100vh;width:100%;min-width:0}.app-content{flex:1;display:flex;flex-direction:column;min-width:0;width:calc(100% - var(--sidebar-w));margin-left:var(--sidebar-w)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:#080c12f5;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:1000;transition:width .26s cubic-bezier(.4,0,.2,1);overflow:hidden}@media (min-width: 769px){.sidebar:hover{width:var(--sidebar-w-open)}}.sidebar-logo{display:flex;align-items:center;gap:.875rem;padding:1.1rem 1rem;text-decoration:none;border-bottom:1px solid var(--border);min-height:62px;overflow:hidden;flex-shrink:0}.sidebar-logo img{width:30px;height:30px;flex-shrink:0}.sidebar-logo-text{font-size:.95rem;font-weight:800;letter-spacing:-.02em;background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;opacity:0;transition:opacity .2s ease}@media (min-width: 769px){.sidebar:hover .sidebar-logo-text{opacity:1}}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:.5rem 0}.sidebar-nav::-webkit-scrollbar{display:none}.nav-section-label{display:block;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text-subtle);padding:.75rem 1.1rem .2rem;white-space:nowrap;overflow:hidden;opacity:0;transition:opacity .2s ease}@media (min-width: 769px){.sidebar:hover .nav-section-label{opacity:1}}.nav-item{display:flex;align-items:center;gap:.875rem;padding:.625rem 1rem;margin:.1rem .5rem;border-radius:var(--r-lg);color:var(--text-muted);font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;background:transparent;border:none;width:calc(100% - 1rem);text-align:left;font-family:var(--font);white-space:nowrap;transition:background var(--tr),color var(--tr);overflow:hidden}.nav-item:hover{background:var(--bg-hover);color:var(--text);transform:none;box-shadow:none;filter:none}.nav-item.active{background:var(--brand-bg);color:var(--brand);border:1px solid rgba(34,211,238,.15)}.nav-icon{font-size:1rem;line-height:1;flex-shrink:0;width:20px;display:flex;align-items:center;justify-content:center}.nav-label{opacity:0;transition:opacity .2s ease;flex:1;overflow:hidden;text-overflow:ellipsis}@media (min-width: 769px){.sidebar:hover .nav-label{opacity:1}}.nav-divider{height:1px;background:var(--border);margin:.4rem .75rem}.nav-sub{display:none;padding:0 0 .25rem}@media (min-width: 769px){.sidebar:hover .nav-sub{display:block}}.nav-sub .nav-item{padding-left:2.75rem;font-size:.82rem;color:var(--text-subtle)}.sidebar-footer{padding:.75rem;border-top:1px solid var(--border);flex-shrink:0}.sidebar-user{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:var(--r-lg);overflow:hidden}.sidebar-avatar{width:30px;height:30px;border-radius:50%;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:800;color:#060a10;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0;overflow:hidden;opacity:0;transition:opacity .2s ease}@media (min-width: 769px){.sidebar:hover .sidebar-user-info{opacity:1}}.sidebar-user-name{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.68rem;color:var(--text-subtle)}.sidebar-tv{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--r-sm);background:transparent;border:none;color:var(--text-subtle);cursor:pointer;flex-shrink:0;box-shadow:none;opacity:0;transition:opacity .2s ease,color var(--tr),background var(--tr);font-size:.85rem}@media (min-width: 769px){.sidebar:hover .sidebar-tv{opacity:1}}.sidebar-tv:hover{color:var(--accent);background:#6366f11f}@media (max-width: 768px){.sidebar.mobile-open .sidebar-tv{opacity:1}}.sidebar-logout{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--r-sm);background:transparent;border:none;color:var(--text-subtle);cursor:pointer;flex-shrink:0;box-shadow:none;opacity:0;transition:opacity .2s ease,color var(--tr),background var(--tr);font-size:.85rem}@media (min-width: 769px){.sidebar:hover .sidebar-logout{opacity:1}}.sidebar-logout:hover{color:var(--danger);background:var(--danger-bg);transform:none;filter:none;box-shadow:none}@media (max-width: 768px){.app-shell{flex-direction:column}.app-content{margin-left:0;width:100%;min-height:calc(100vh - 54px)}.sidebar{left:0;width:min(var(--sidebar-w-open),calc(100vw - 48px));max-width:86vw;transform:translate(-100%);transition:transform .26s cubic-bezier(.4,0,.2,1);will-change:transform}.sidebar.mobile-open{transform:translate(0)}.sidebar.mobile-open .sidebar-logo-text,.sidebar.mobile-open .nav-label,.sidebar.mobile-open .nav-section-label,.sidebar.mobile-open .sidebar-user-info,.sidebar.mobile-open .sidebar-logout{opacity:1}.sidebar.mobile-open .nav-sub{display:block}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:999}.sidebar-overlay.visible{display:block}.mobile-topbar{display:flex;align-items:center;justify-content:space-between;width:100%;padding:calc(env(safe-area-inset-top,0px) + .35rem) 1rem .35rem;min-height:54px;background:#080c12f0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:998;flex-shrink:0}.mobile-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;min-width:0}.mobile-logo img{width:26px;height:26px}.mobile-logo span{font-size:.92rem;font-weight:800;background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-menu-btn{display:flex;flex-direction:column;gap:4px;padding:.5rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;box-shadow:none;transition:border-color var(--tr)}.mobile-menu-btn span{display:block;width:18px;height:1.5px;background:var(--text-muted);border-radius:2px;transition:all .22s}.mobile-menu-btn:hover{border-color:var(--brand);transform:none;filter:none;box-shadow:none}.mobile-menu-btn.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}.mobile-menu-btn.active span:nth-child(2){opacity:0}.mobile-menu-btn.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}}@media (min-width: 769px){.mobile-topbar{display:none}}
