*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#1f2937;background-color:#f9fafb;padding-bottom:env(safe-area-inset-bottom,0);overflow-x:hidden}html{overflow-x:hidden}.text-blue-500{color:#3b82f6}.text-dark{color:#1f2937}.icon-inline{display:inline;vertical-align:middle}.mr-1{margin-right:4px}.ml-3{margin-left:12px}.pt-4{padding-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.italic{font-style:italic}.w-1-2{width:50%}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.grid-auto-200{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.row-between{display:flex;align-items:center;justify-content:space-between}.wrap{flex-wrap:wrap}.gap-2{gap:8px}.btn-xs{padding:5px 10px;font-size:12px}.btn-compact{padding:6px 10px}.min-h-screen{min-height:100vh}.login-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:20px}.login-card{max-width:400px;width:100%;background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:32px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:32px}.login-icon{width:48px;height:48px;color:#10b981;margin:0 auto 16px}.login-title{font-size:28px;font-weight:800;color:#1f2937;margin-bottom:8px}.login-subtitle{font-size:14px;color:#6b7280}.login-form{display:flex;flex-direction:column;gap:20px}.password-field{margin-bottom:4px}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-icon{position:absolute;left:12px;width:20px;height:20px;color:#9ca3af;z-index:1}.password-input{width:100%;padding:12px 44px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:all .2s ease;background:#fff}.password-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.password-toggle{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:#9ca3af;padding:4px;border-radius:4px;transition:color .2s}.password-toggle:hover{color:#6b7280}.error-message{color:#ef4444;font-size:14px;text-align:center;padding:8px 12px;background:#fef2f2;border-radius:6px;border:1px solid #fecaca}.login-button{width:100%;padding:12px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-height:48px}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.login-button:disabled{opacity:.7;cursor:not-allowed}.spinner{width:20px;height:20px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.spinner-inline{width:16px;height:16px;border-width:2px;border-top-color:#fff;display:inline-block;vertical-align:middle;margin-right:8px}.loading-overlay{position:fixed;inset:0;background:#fff9;display:flex;align-items:center;justify-content:center;z-index:1000}.loading-overlay .spinner{width:36px;height:36px;border-width:3px;border-top-color:#3b82f6}.toast-container{position:fixed;left:50%;transform:translate(-50%);bottom:16px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:1100;width:100%;max-width:640px;padding:0 12px}.toast{min-width:240px;max-width:420px;padding:10px 12px;border-radius:8px;color:#111827;background:#fff;border:1px solid #e5e7eb;box-shadow:0 4px 12px #00000014;font-size:14px}.toast.success{border-color:#bbf7d0;background:#ecfdf5;color:#065f46}.toast.error{border-color:#fecaca;background:#fef2f2;color:#991b1b}.toast.info{border-color:#bfdbfe;background:#eff6ff;color:#1e3a8a}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 640px){.toast-container{bottom:calc(84px + env(safe-area-inset-bottom,0));max-width:100vw}.toast{max-width:min(92vw,520px)}}.update-banner{position:fixed;left:50%;transform:translate(-50%);bottom:16px;background:#111827;color:#fff;border-radius:10px;padding:8px 12px;box-shadow:0 6px 16px #0000002e;z-index:1200;display:flex;align-items:center;gap:10px}.update-banner .btn-update{background:#10b981;color:#fff;border:none;border-radius:6px;padding:6px 10px;cursor:pointer;font-size:13px}@media (max-width: 640px){.update-banner{bottom:calc(84px + env(safe-area-inset-bottom,0))}}.login-hint{text-align:center;margin-top:16px;color:#6b7280;font-size:12px}header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.header-left{display:flex;align-items:center;gap:12px}.header-left h1{font-size:24px;font-weight:700;margin:0}.header-left p{font-size:14px;opacity:.9;margin:0}.logout-button{padding:8px 16px;background:#ef4444e6;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.logout-button:hover{background:#dc2626;transform:translateY(-1px)}nav{background:#fff;border-bottom:1px solid #e5e7eb;padding:15px 0;margin-bottom:30px;position:sticky;top:0;z-index:40}.nav-buttons{display:flex;gap:12px;flex-wrap:wrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.nav-button{display:flex;align-items:center;gap:8px;padding:12px 16px;border:2px solid #e5e7eb;background:#fff;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:#374151;min-height:44px}.nav-button:hover{background:#f3f4f6;border-color:#9ca3af;transform:translateY(-1px)}.nav-button.active{background:#3b82f6;color:#fff;border-color:#3b82f6;box-shadow:0 4px 6px #3b82f633}.container{max-width:1200px;margin:0 auto;padding:0 20px}.card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px;border:1px solid #f3f4f6}.card h2,.card h3{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:20px;font-weight:600;color:#1f2937}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.form-grid-6{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}@media (max-width: 768px){.form-grid,.form-grid-5,.form-grid-6{grid-template-columns:1fr}.nav-buttons{justify-content:center}.header-content{text-align:center}}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151;font-size:14px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:all .2s;background:#fff;min-height:44px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:80px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;transition:all .2s;margin-right:8px;text-decoration:none;background:#3b82f6;color:#fff;min-height:44px}.btn-nav{min-height:36px;padding:6px 10px}.btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.btn-secondary{background:#6b7280}.btn-secondary:hover{background:#4b5563;box-shadow:0 4px 8px #6b72804d}.btn-success{background:#10b981}.btn-success:hover{background:#059669;box-shadow:0 4px 8px #10b9814d}.btn-warning{background:#f59e0b}.btn-warning:hover{background:#d97706;box-shadow:0 4px 8px #f59e0b4d}.btn-danger{background:#ef4444}.btn-danger:hover{background:#dc2626;box-shadow:0 4px 8px #ef44444d}.space-y-6>*+*{margin-top:24px}.space-y-3>*+*{margin-top:12px}.space-y-4>*+*{margin-top:16px}.chart-container{width:100%;height:300px;margin-top:16px}.entry{background:#f9fafb;border-radius:8px;padding:16px;border:1px solid #e5e7eb;transition:all .2s;margin-bottom:8px}.entry:hover{box-shadow:0 2px 4px #0000000d;border-color:#d1d5db}.entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}.meal-badge{display:inline-block;color:#fff;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.entry-info{display:flex;flex-wrap:wrap;gap:16px;font-size:14px;color:#6b7280}.entry-info span{display:flex;align-items:center;gap:4px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px}.summary-item{text-align:center;padding:16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.summary-value{font-size:28px;font-weight:700;margin-bottom:4px}.summary-value.blue{color:#3b82f6}.summary-value.green{color:#10b981}.summary-value.purple{color:#8b5cf6}.summary-value.yellow{color:#f59e0b}.summary-label{font-size:12px;color:#6b7280;text-transform:uppercase;font-weight:500;letter-spacing:.5px}.meal-list{display:flex;flex-direction:column;gap:8px}.meal-item{display:flex;align-items:center;flex-wrap:wrap;gap:12px;padding:12px;background:#fff;border-radius:8px;border:1px solid #e5e7eb;font-size:14px;transition:all .2s}.meal-item:hover{border-color:#d1d5db;box-shadow:0 1px 3px #0000000d}.meal-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.meal-color-desayuno{background:#ff6b6b}.meal-color-almuerzo{background:#4be0d6}.meal-color-merienda{background:#45b7d1}.meal-color-cena{background:#8b5cf6}.meal-color-capricho{background:#feca57}.text-gray-800{color:#374151}.meal-time{font-weight:600;color:#374151;min-width:50px;font-family:Monaco,Menlo,monospace}.meal-description{flex:1;color:#6b7280}.meal-calories{font-weight:600;color:#1f2937;background:#f3f4f6;padding:2px 8px;border-radius:4px;font-size:12px}.weight-change{font-size:12px;padding:2px 8px;border-radius:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.weight-gain{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.weight-loss{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.weight-total{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.text-center{text-align:center}.text-sm{font-size:14px}.text-lg{font-size:18px}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-green-500{color:#10b981}.text-red-500{color:#ef4444}.text-gray-500{color:#6b7280}.py-8{padding-top:32px;padding-bottom:32px}@media (max-width: 640px){header{display:none}nav{display:none}.container{padding:0 8px}.card{font-size:17px}.card h2,.card h3{font-size:20px}.card .text-sm{font-size:15px}.card{padding:16px}.entry-header{flex-direction:column;align-items:flex-start;gap:12px}.entry{padding:12px}.entry-actions{display:flex;gap:8px}.btn-nav .btn-label{display:none}.summary-grid{grid-template-columns:repeat(2,1fr)}.chart-container{height:250px}.btn{display:flex;width:100%;margin-right:0;margin-bottom:10px;justify-content:center}.btn.btn-nav{width:auto;margin-bottom:0;min-height:36px;height:36px;padding:6px;border-radius:8px}.nav-buttons{gap:8px;flex-wrap:nowrap}.nav-button{flex:0 0 auto;font-size:14px;padding:10px 12px}.login-card{padding:24px}.login-title{font-size:24px}main.container{padding-bottom:80px;padding-top:16px}.entry{padding:12px;position:relative}.entry-actions{display:flex;gap:8px;position:absolute;top:8px;right:8px}.entry-actions .btn .btn-label{display:none}.entry-actions .btn svg{margin:0}.entry-header{padding-right:72px}.entry-info{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}}.bottom-nav{position:fixed;left:0;right:0;bottom:0;padding:8px 8px calc(8px + env(safe-area-inset-bottom,0));background:#fff;border-top:1px solid #e5e7eb;display:none;z-index:60}.bottom-nav .bar{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.bottom-nav button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 6px;border:1px solid #e5e7eb;background:#fff;border-radius:10px;color:#374151;font-size:11px;min-height:44px}.bottom-nav button.active{background:#eef2ff;border-color:#c7d2fe;color:#1d4ed8}@media (max-width: 640px){.bottom-nav{display:block}}@media (max-width: 640px){.hide-on-mobile{display:none!important}.show-on-mobile{display:block!important}.suggest-row{flex-direction:column;align-items:stretch;gap:8px}}.show-on-mobile{display:none}.fab-install{position:fixed;right:16px;bottom:calc(72px + env(safe-area-inset-bottom,0));z-index:70}.loading{opacity:.6;pointer-events:none}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.toggle{display:inline-flex;align-items:center;gap:10px;cursor:pointer}.toggle input{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;display:inline-block;width:42px;height:24px;background:#e5e7eb;border:1px solid #d1d5db;border-radius:9999px;transition:background .2s ease,border-color .2s ease;margin-right:10px}.toggle-slider:after{content:"";position:absolute;top:50%;left:3px;width:18px;height:18px;transform:translateY(-50%);background:#fff;border-radius:9999px;box-shadow:0 1px 3px #00000026;transition:transform .2s ease}.toggle input:checked+.toggle-slider{background:#10b981;border-color:#10b981}.toggle input:checked+.toggle-slider:after{transform:translate(18px,-50%)}.toggle input:focus-visible+.toggle-slider{outline:2px solid #3b82f6;outline-offset:2px}.toggle-label{font-size:14px;color:#374151}@media (max-width: 640px){.toggle-slider{width:38px;height:22px}.toggle-slider:after{width:16px;height:16px;left:3px}.toggle input:checked+.toggle-slider:after{transform:translate(17px,-50%)}.toggle-label{font-size:13px}}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{width:100%;max-width:560px;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;overflow:hidden}.modal-header{font-weight:700;padding:16px 20px;border-bottom:1px solid #e5e7eb}.modal-body{padding:16px 20px;max-height:60vh;overflow-y:auto}.modal-actions{padding:12px 20px 20px}
