:root{--primary: #2563eb;--primary-light: #eff6ff;--bg-color: #ffffff;--text-main: #1e293b;--text-muted: #64748b;--border-color: #f1f5f9;--card-bg: #ffffff;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body{font-family:Outfit,sans-serif;background-color:var(--bg-color);color:var(--text-main);line-height:1.5;overflow-x:hidden;min-height:100vh}#root{display:flex;flex-direction:column;min-height:100vh;max-width:500px;margin:0 auto;position:relative}h1,h2,h3{font-weight:700;letter-spacing:-.02em}button{cursor:pointer;border:none;background:none;font-family:inherit}input{font-family:inherit;font-size:16px}.glass{background:rgba(255,255,255,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.header{padding:16px 20px;position:sticky;top:0;z-index:100;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px}.header-top,.header-bottom{display:flex;justify-content:space-between;align-items:center}.header-actions{display:flex;gap:8px}.icon-btn{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .2s}.icon-btn.active{background:var(--primary-light);color:var(--primary)}.header h1{font-size:20px;color:var(--primary);display:flex;align-items:center;gap:12px}.brand-group{display:flex;flex-direction:column;cursor:pointer}.brand-name{font-size:18px;line-height:1}.current-family-badge{font-size:10px;background:var(--text-main);color:#fff;padding:2px 6px;border-radius:6px;width:fit-content;display:flex;align-items:center;gap:2px;margin-top:2px;text-transform:uppercase;letter-spacing:.05em}.family-selector-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.family-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f8fafc;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer}.family-item.active{background:var(--primary-light);border-color:var(--primary)}.fam-info{display:flex;align-items:center;gap:12px}.fam-name{display:block;font-weight:700;font-size:14px}.fam-id{font-size:11px;color:var(--text-muted)}.add-family-section{padding:16px;background:#f1f5f9;border-radius:var(--radius-md)}.add-family-section h4{font-size:12px;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px}.add-fam-input{display:flex;gap:8px;margin-bottom:8px}.add-fam-input input{flex:1;padding:8px 12px;border-radius:8px;border:1px solid var(--border-color);font-size:14px}.btn-add-fam{background:var(--primary);color:#fff;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600}.add-fam-divider{text-align:center;font-size:11px;color:var(--text-muted);margin:8px 0}.week-selector{display:flex;align-items:center;gap:8px;background:var(--primary-light);padding:4px 8px;border-radius:12px}.week-label{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:80px}.week-label span{font-size:13px;font-weight:600;color:var(--primary)}.week-counter{font-size:11px!important;font-weight:700!important;color:var(--primary);opacity:.6;margin-top:-2px}.icon-btn-small{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:white;border:1px solid var(--border-color);transition:all .2s}.icon-btn-small.delete{color:#ef4444;background:#fef2f2}.icon-btn-small:hover{background:var(--primary-light);color:var(--primary)}.icon-btn-small.delete:hover{background:#fee2e2;color:#b91c1c}.fam-actions{display:flex;align-items:center;gap:6px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:70px;display:flex;justify-content:space-around;align-items:center;padding:0 10px 15px;z-index:100;border-top:1px solid var(--border-color);border-radius:24px 24px 0 0}.bottom-nav button{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-muted);font-size:10px;font-weight:600;transition:all .3s;padding:8px;border-radius:12px}.bottom-nav button.active{color:var(--primary);background:var(--primary-light)}.menu-view{padding:10px;display:flex;flex-direction:column;gap:16px}.menu-header-actions{display:flex;justify-content:center;margin-bottom:10px}.ai-gen-btn{background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border:none;padding:12px 24px;border-radius:12px;font-weight:700;display:flex;align-items:center;gap:10px;box-shadow:0 4px 15px #6366f14d;transition:transform .2s}.ai-gen-btn:active{transform:scale(.95)}.day-card{padding:16px;border-radius:16px}.day-title{font-size:16px;font-weight:800;color:var(--primary);margin-bottom:12px;border-bottom:2px solid var(--primary-light);padding-bottom:4px}.meal-inputs{display:flex;flex-direction:column;gap:12px}.meal-field{display:flex;flex-direction:column;gap:4px}.meal-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase}.meal-field input{background:white;border:1px solid var(--border-color);padding:10px 14px;border-radius:10px;font-size:14px}.meal-field.cena{margin-top:8px;padding-top:8px;border-top:1px dashed var(--border-color)}.meal-field.cena input{background:var(--primary-light);border-color:transparent}.recipes-view{padding:16px;display:flex;flex-direction:column;gap:20px}.recipes-header{display:flex;gap:12px;align-items:center}.search-box{flex:1;display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:12px;color:var(--text-muted)}.search-box input{border:none;background:transparent;width:100%;outline:none;font-size:14px}.add-recipe-btn{width:44px;height:44px;background:var(--primary);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.recipe-card{border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:transform .2s}.recipe-card:active{transform:scale(.98)}.recipe-card h3{font-size:16px;font-weight:700;color:var(--primary);margin-bottom:4px}.recipe-excerpt{font-size:12px;color:var(--text-muted);line-height:1.4}.recipe-card-footer{margin-top:auto;display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--primary);opacity:.8}.recipe-modal{max-width:600px}.recipe-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase}.form-group input,.form-group textarea{padding:12px;border-radius:10px;border:1px solid var(--border-color);font-size:14px;background:#f8fafc}.recipe-footer{justify-content:space-between!important}.btn-save-recipe{flex:1;background:var(--primary);color:#fff;padding:12px;border-radius:12px;font-weight:700}.btn-delete-recipe{background:#fee2e2;color:#ef4444;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.recipe-import-tool{display:flex;gap:8px;background:#f1f5f9;padding:8px;border-radius:12px;margin-bottom:20px;border:1px dashed var(--primary)}.recipe-import-tool input{flex:1;background:transparent;border:none;font-size:13px;outline:none;padding:4px 8px}.recipe-import-tool button{background:var(--primary);color:#fff;border-radius:8px;padding:8px 16px;display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700}.week-label svg{color:var(--primary);opacity:.7}.week-btn{padding:4px;color:var(--primary);display:flex;align-items:center;justify-content:center}.magic-btn{background:var(--primary);color:#fff;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:transform .2s,background .2s}.magic-btn:active{transform:scale(.9);background:#1d4ed8}.category-group{margin:12px 16px 20px;animation:fadeIn .4s ease-out}.category-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-left:4px}.category-icon{font-size:20px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:10px}.category-title{font-size:16px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.items-container{display:flex;flex-direction:column;gap:8px}.item-card-wrapper{position:relative;overflow:hidden;border-radius:var(--radius-md);margin-bottom:8px}.swipe-bg{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-radius:var(--radius-md);z-index:0}.item-card{background:var(--card-bg);padding:14px 16px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1;touch-action:pan-y}.item-card:active{transform:scale(.98)}.item-info{display:flex;align-items:center;gap:12px}.item-name{font-weight:500;font-size:16px}.checkbox-container{width:24px;height:24px;border:2px solid var(--border-color);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.checkbox-container.checked{background-color:var(--primary);border-color:var(--primary)}.add-item-area{position:fixed;bottom:70px;left:0;right:0;padding:12px 20px 16px;border-top:1px solid var(--border-color);max-width:500px;margin:0 auto;z-index:90;display:flex;flex-direction:column;gap:12px;background:white}.menu-table-container{border-radius:16px;margin-top:12px;border:1px solid var(--border-color);background:white;box-shadow:var(--shadow-sm)}.menu-table-header{display:grid;grid-template-columns:60px 1fr 1fr;background:linear-gradient(to right,#2563eb,#1e40af);color:#fff;font-weight:800;font-size:11px;text-transform:uppercase;padding:14px 0;text-align:center;position:sticky;top:76px;z-index:80;letter-spacing:.1em;box-shadow:0 4px 6px -1px #0000001a}.menu-table-row{display:grid;grid-template-columns:60px 1fr 1fr;border-bottom:1px solid #edf2f7;background:white}.menu-table-row:last-child{border-bottom:none}.cell-day{display:flex;align-items:center;justify-content:center;background:#f1f5f9;font-weight:800;font-size:11px;color:#475569;border-right:1px solid #e2e8f0}.menu-table-row.active .cell-day{background:#dbeafe;color:#2563eb}.cell-meal{display:flex;flex-direction:column;padding:8px 4px;gap:4px;border-right:1px solid #edf2f7}.cell-meal:last-child{border-right:none}.cell-meal input{width:100%;border:none;background:transparent;padding:2px 8px;font-size:13px;outline:none;color:var(--text-main);transition:background .2s;border-radius:4px}.cell-meal input:focus{background:#f8fafc}.m-p1{font-weight:600}.m-p2{font-weight:500}.m-postre{color:#64748b;font-style:italic;font-size:11px!important;margin-top:2px;border-top:1px dashed #e2e8f0!important;padding-top:4px!important}.input-wrapper{display:flex;gap:10px;background:#f8fafc;padding:6px;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.item-input{flex:1;border:none;background:transparent;padding:8px 12px;outline:none}.add-button{background:var(--primary);color:#fff;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .2s;box-shadow:var(--shadow-md);flex-shrink:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(15,23,42,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-end;justify-content:center}.modal-content{width:100%;max-width:500px;background:white;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:85vh;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom,20px)}.modal-header{padding:24px 20px;border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:20px;margin-bottom:4px;color:var(--text-main)}.modal-header p{font-size:14px;color:var(--text-muted)}.modal-body{flex:1;overflow-y:auto;padding:10px 16px}.suggestion-list{display:flex;flex-direction:column;gap:10px}.suggestion-item{display:flex;align-items:center;justify-content:space-between;padding:14px;background:#f8fafc;border-radius:var(--radius-md);border:2px solid transparent;transition:all .2s;cursor:pointer}.suggestion-item.selected{background:var(--primary-light);border-color:var(--primary)}.cat-icon{font-size:20px;margin-right:12px}.sug-name{font-weight:600;font-size:15px}.checkbox-circle{width:24px;height:24px;border:2px solid #cbd5e1;border-radius:50%;display:flex;align-items:center;justify-content:center}.checkbox-circle.checked{background:var(--primary);border-color:var(--primary)}.modal-footer{padding:20px;display:flex;gap:12px;border-top:1px solid var(--border-color)}.btn-cancel{flex:1;padding:14px;background:#f1f5f9;color:var(--text-muted);border-radius:var(--radius-md);font-weight:600}.btn-confirm{flex:2;padding:14px;background:var(--primary);color:#fff;border-radius:var(--radius-md);font-weight:600;box-shadow:var(--shadow-md)}.btn-confirm:disabled{opacity:.5;cursor:not-allowed}.add-button:active{transform:scale(.9)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.checking-animation{animation:checkOff .4s forwards ease-in}@keyframes checkOff{0%{transform:translate(0);opacity:1}to{transform:translate(100px);opacity:0}}.completed-section{margin:32px 16px;padding-top:10px;border-top:2px dashed var(--border-color)}.history-toggle{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:none;border:none;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase}.history-toggle:hover{color:var(--primary);background:#f1f5f9;border-radius:var(--radius-md)}.completed-list{display:flex;flex-direction:column;gap:6px;margin-top:12px}.completed-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#f8fafc;border-radius:10px;opacity:.7}.completed-item span{font-size:14px;text-decoration:line-through;color:var(--text-muted)}.completed-item button{color:var(--primary);padding:4px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.3}.auth-container{margin:60px 24px;padding:32px 24px;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;text-align:center;animation:fadeIn .5s ease-out}.auth-header h2{font-size:24px;margin-top:20px;margin-bottom:8px}.auth-header p{font-size:14px;color:var(--text-muted);margin-bottom:32px}.auth-form{width:100%;display:flex;flex-direction:column;gap:16px}.input-wrapper{display:flex;align-items:center;gap:12px;max-width:600px;margin:0 auto}.voice-btn{background:#f1f5f9;color:var(--primary);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}.voice-btn.listening{background:#fee2e2;color:#ef4444;animation:pulse 1.5s infinite}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #ef444466}70%{transform:scale(1.1);box-shadow:0 0 0 10px #ef444400}to{transform:scale(1);box-shadow:0 0 #ef444400}}.item-input{flex:1;padding:14px 20px;border-radius:var(--radius-md);border:1px solid var(--border-color);font-size:16px;outline:none;transition:all .2s}.input-group{display:flex;align-items:center;gap:12px;background:#f8fafc;padding:14px 16px;border-radius:var(--radius-md);border:1px solid var(--border-color)}.input-group input{border:none;background:transparent;width:100%;outline:none}.btn-primary{background:var(--primary);color:#fff;padding:16px;border-radius:var(--radius-md);font-weight:700;margin-top:12px;box-shadow:var(--shadow-md)}.auth-footer{margin-top:24px;font-size:14px;color:var(--primary);font-weight:600;cursor:pointer}.admin-panel{padding:20px;margin:16px;border-radius:var(--radius-lg)}.panel-header{display:flex;align-items:center;gap:10px;margin-bottom:24px;color:var(--primary)}.family-code-box{background:var(--primary-light);padding:16px;border-radius:var(--radius-md);margin-bottom:32px;text-align:center}.invite-code{display:block;font-size:32px;font-weight:800;color:var(--primary);letter-spacing:.1em;margin:8px 0;cursor:pointer}.btn-share-invite{margin:12px auto;display:flex;align-items:center;justify-content:center;gap:8px;background:white;color:var(--primary);border:2px solid var(--primary);padding:8px 16px;border-radius:10px;font-weight:600;font-size:13px;transition:all .2s}.btn-share-invite:hover{background:var(--primary);color:#fff}.user-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.user-stat-card{background:white;padding:16px;border-radius:var(--radius-md);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.user-main-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.delete-user-btn{background:#fee2e2;color:#ef4444;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.delete-user-btn:hover{background:#fecaca;transform:scale(1.05)}.user-main{display:flex;align-items:center;gap:12px;margin-bottom:12px}.user-avatar{width:40px;height:40px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.user-info{display:flex;flex-direction:column}.user-email{font-weight:600;font-size:14px}.user-role{font-size:12px;color:var(--text-muted)}.user-metrics{display:flex;gap:16px;padding-top:12px;border-top:1px solid var(--border-color)}.metric{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.loading{display:flex;flex-direction:column;height:100vh;width:100vw;align-items:center;justify-content:center;font-weight:600;color:var(--primary);text-align:center;padding:20px;background:white;position:fixed;top:0;left:0;z-index:1000}.spin{animation:spin 2s linear infinite;margin-bottom:20px;color:var(--primary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.version-tag{text-align:center;font-size:10px;color:var(--text-muted);opacity:.5;margin-top:20px;letter-spacing:1px}.btn-secondary{background:white;color:var(--text-muted);border:1px solid var(--border-color);padding:10px 20px;border-radius:var(--radius-md);font-size:14px;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f8fafc;color:var(--text-main)}.admin-danger-zone{margin-top:32px;padding:20px;background:#fff1f2;border:1px solid #fecaca;border-radius:var(--radius-md)}.admin-danger-zone h4{color:#991b1b;font-size:14px;margin-bottom:12px;text-transform:uppercase}.btn-danger-outline{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:1px solid #ef4444;color:#ef4444;border-radius:10px;font-weight:700;font-size:14px;transition:all .2s}.btn-danger-outline:hover{background:#ef4444;color:#fff}.legal-checkbox{display:flex;align-items:flex-start;gap:10px;margin:18px 0;font-size:13px;color:var(--text-muted);line-height:1.4}.legal-checkbox input[type=checkbox]{width:18px;height:18px;margin-top:2px;cursor:pointer;accent-color:var(--primary)}.link-text{color:var(--primary);font-weight:700;text-decoration:underline;text-underline-offset:3px;cursor:pointer}.legal-modal{width:90%!important;max-width:450px!important;padding:24px!important;border-radius:var(--radius-lg)!important}.legal-body{margin:20px 0;display:flex;flex-direction:column;gap:16px;font-size:14px;line-height:1.6;color:var(--text-main)}.legal-body p{padding-bottom:8px;border-bottom:1px solid var(--border-color)}.legal-body p strong{color:var(--primary);display:block;margin-bottom:4px}
