.layout{display:flex;min-height:100vh}.sidebar{display:none;flex-direction:column;width:var(--sidebar-width);background:var(--color-white);border-right:1px solid var(--color-border);padding:var(--space-lg);position:fixed;top:0;left:0;height:100vh;z-index:100}.sidebar-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border)}.sidebar-header h2{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--color-earth)}.sidebar-icon{font-size:1.5rem}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-xs);flex:1}.sidebar-link{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--color-text-light);font-size:var(--text-sm);font-weight:500;transition:all .2s;text-decoration:none}.sidebar-link:hover{background:var(--color-cream);color:var(--color-text)}.sidebar-link.active{background:var(--color-cream-dark);color:var(--color-earth-dark);font-weight:600}.sidebar-link .nav-icon{font-size:1.2rem;width:28px;text-align:center}.sidebar-logout{margin-top:auto;padding:var(--space-sm) var(--space-md);background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;transition:all .2s}.sidebar-logout:hover{background:var(--color-cream);color:var(--color-text);border-color:var(--color-sand)}.main-content{flex:1;padding:var(--space-lg);padding-bottom:calc(var(--bottomnav-height) + var(--space-xl));max-width:900px;margin:0 auto;width:100%}.bottom-nav{display:flex;align-items:center;justify-content:space-around;position:fixed;bottom:0;left:0;right:0;height:var(--bottomnav-height);background:var(--color-white);border-top:1px solid var(--color-border);z-index:100;padding:var(--space-xs) 0}.bottom-link{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--color-text-muted);font-size:var(--text-xs);text-decoration:none;padding:var(--space-xs);border-radius:var(--radius-sm);transition:color .2s;min-width:48px}.bottom-link .nav-icon{font-size:1.25rem}.bottom-link .nav-label{font-size:.65rem;font-weight:500}.bottom-link.active{color:var(--color-earth)}.bottom-link.active .nav-label{font-weight:700}@media (min-width: 768px){.sidebar{display:flex}.main-content{margin-left:var(--sidebar-width);padding:var(--space-xl) var(--space-2xl);padding-bottom:var(--space-2xl)}.bottom-nav{display:none}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-lg);background:linear-gradient(135deg,var(--color-cream) 0%,var(--color-rose) 100%)}.login-card{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--space-2xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-icon{font-size:3rem;display:block;margin-bottom:var(--space-sm)}.login-header h1{font-family:var(--font-heading);font-size:var(--text-3xl);color:var(--color-earth);margin-bottom:var(--space-xs)}.login-subtitle{color:var(--color-text-muted);font-size:var(--text-sm)}.login-form{display:flex;flex-direction:column;gap:var(--space-md)}.login-btn{width:100%;padding:var(--space-md);font-size:var(--text-base);margin-top:var(--space-sm)}.login-error{color:var(--color-warning);font-size:var(--text-sm);text-align:center;padding:var(--space-sm);background:#fff5ee;border-radius:var(--radius-sm)}.login-success{color:var(--color-sage-dark);font-size:var(--text-sm);text-align:center;padding:var(--space-sm);background:#f0f5ee;border-radius:var(--radius-sm)}.login-toggle{display:block;width:100%;margin-top:var(--space-lg);background:none;border:none;color:var(--color-earth);font-size:var(--text-sm);cursor:pointer;text-align:center}.login-toggle:hover{color:var(--color-earth-dark);text-decoration:underline}.dashboard{padding-bottom:var(--space-lg)}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--space-md);color:var(--color-text-light)}.dashboard-loading .spinner{width:28px;height:28px}.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;gap:var(--space-lg);text-align:center;color:var(--color-text-light);padding:var(--space-xl)}.dashboard-header{margin-bottom:var(--space-lg)}.dashboard-saludo{font-family:var(--font-heading);font-size:var(--text-3xl);color:var(--color-earth);font-weight:600;line-height:1.2}.dashboard-fecha{color:var(--color-text-muted);font-size:var(--text-sm);margin-top:var(--space-xs);text-transform:capitalize}.dashboard-frase{background:var(--color-cream-dark);border-radius:var(--radius-md);padding:var(--space-lg) var(--space-xl);margin-bottom:var(--space-xl);text-align:center}.dashboard-frase p{font-family:var(--font-heading);font-style:italic;font-size:var(--text-lg);color:var(--color-text-light);line-height:1.6}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.dashboard-card{display:flex;flex-direction:column;align-items:flex-start;background:var(--color-white);border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);text-decoration:none;color:inherit;transition:box-shadow .2s ease,transform .2s ease}.dashboard-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);color:inherit}.dashboard-card-icon{font-size:1.5rem;margin-bottom:var(--space-sm)}.dashboard-card-titulo{font-family:var(--font-heading);font-size:var(--text-base);color:var(--color-text);font-weight:600;margin-bottom:var(--space-xs)}.dashboard-card-valor{font-size:var(--text-sm);color:var(--color-sage-dark);font-weight:600}.dashboard-card-detalle{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.dashboard-card-pendiente{font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.4}@media (min-width: 768px){.dashboard-saludo{font-size:var(--text-3xl)}.dashboard-frase{padding:var(--space-xl) var(--space-2xl)}.dashboard-frase p{font-size:var(--text-xl)}.dashboard-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.dashboard-card{padding:var(--space-lg) var(--space-xl)}.dashboard-card-icon{font-size:1.75rem}.dashboard-card-titulo{font-size:var(--text-lg)}.dashboard-card-valor{font-size:var(--text-base)}.dashboard-card-pendiente{font-size:var(--text-sm)}}.registro-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--space-md);color:var(--color-text-light)}.spinner-lg{width:32px;height:32px;border-width:3px}.registro-page{max-width:720px;margin:0 auto;padding-bottom:var(--space-2xl)}.registro-header{margin-bottom:var(--space-lg)}.registro-header h1{font-family:var(--font-heading);color:var(--color-earth);font-size:var(--text-2xl);margin-bottom:var(--space-xs)}.registro-subtitle{color:var(--color-text-muted);font-size:var(--text-sm)}.registro-fecha-selector{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);background:var(--color-white);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);overflow:hidden}.registro-fecha-selector label{font-size:var(--text-sm);font-weight:600;color:var(--color-text-light);white-space:nowrap}.fecha-input{max-width:200px;min-width:0;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.registro-mensaje{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-md);text-align:center}.registro-mensaje-error{background:#fff8f0;color:var(--color-warning);border:1px solid rgba(212,165,116,.3)}.registro-mensaje-exito{background:#f0f5ee;color:var(--color-sage-dark);border:1px solid rgba(143,168,137,.3)}.registro-form{display:flex;flex-direction:column;gap:var(--space-lg)}.registro-seccion{background:var(--color-white);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.registro-seccion:hover{box-shadow:var(--shadow-md)}.seccion-titulo{display:flex;align-items:center;gap:var(--space-sm);font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.seccion-icono{font-size:1.2rem}.input-con-unidad{display:flex;align-items:center;gap:var(--space-sm)}.input-con-unidad input{max-width:140px}.input-unidad{font-size:var(--text-sm);color:var(--color-text-muted);white-space:nowrap}.form-row{display:flex;gap:var(--space-md)}.form-row .form-group{flex:1;min-width:0}.registro-seccion textarea{resize:vertical;min-height:100px;line-height:1.5}.registro-checkboxes{display:flex;flex-direction:column;gap:var(--space-md)}.checkbox-label{display:flex;align-items:center;gap:var(--space-md);cursor:pointer;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:background-color .2s;-webkit-user-select:none;user-select:none}.checkbox-label:hover{background:var(--color-cream)}.checkbox-label input[type=checkbox]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.checkbox-custom{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;min-width:22px;border:2px solid var(--color-sand-dark);border-radius:6px;background:var(--color-white);transition:all .2s ease}.checkbox-custom:after{content:"";display:block;width:6px;height:10px;border:solid var(--color-white);border-width:0 2.5px 2.5px 0;transform:rotate(45deg) scale(0);transition:transform .15s ease;margin-top:-2px}.checkbox-label input[type=checkbox]:checked+.checkbox-custom{background:var(--color-sage-dark);border-color:var(--color-sage-dark)}.checkbox-label input[type=checkbox]:checked+.checkbox-custom:after{transform:rotate(45deg) scale(1)}.checkbox-label input[type=checkbox]:focus-visible+.checkbox-custom{outline:2px solid var(--color-earth);outline-offset:2px}.checkbox-texto{font-size:var(--text-base);color:var(--color-text)}.registro-guardar{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--text-base);border-radius:var(--radius-sm);margin-top:var(--space-sm)}.registro-guardar:disabled{opacity:.7;cursor:not-allowed}.registro-historial{margin-top:var(--space-2xl)}.registro-historial h2{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--color-earth);margin-bottom:var(--space-md)}.historial-tabla{background:var(--color-white);border-radius:var(--radius-md);border:1px solid var(--color-border);overflow:hidden;box-shadow:var(--shadow-sm)}.historial-cabecera{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;padding:var(--space-sm) var(--space-md);background:var(--color-cream-dark);font-size:var(--text-xs);font-weight:700;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.05em}.historial-fila{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:background-color .15s;border-bottom:1px solid var(--color-border)}.historial-fila:last-child{border-bottom:none}.historial-fila:hover{background:var(--color-cream)!important}.fila-par{background:var(--color-white)}.fila-impar{background:var(--color-cream)}.historial-fecha{font-weight:600;color:var(--color-earth)}@media (max-width: 600px){.registro-page{padding-left:var(--space-xs);padding-right:var(--space-xs)}.registro-seccion{padding:var(--space-md)}.form-row{flex-direction:column;gap:0}.input-con-unidad input{max-width:120px}.historial-tabla{overflow-x:auto}.historial-cabecera,.historial-fila{min-width:500px}.registro-fecha-selector{flex-direction:column;align-items:stretch;gap:var(--space-sm);padding:var(--space-md)}.fecha-input{max-width:100%;width:100%;box-sizing:border-box}}@media (min-width: 601px){.registro-header h1{font-size:var(--text-3xl)}}.ejercicio-page{padding-bottom:var(--space-lg)}.ejercicio-header{margin-bottom:var(--space-xl)}.ejercicio-header h1{font-family:var(--font-heading);font-size:var(--text-2xl);color:var(--color-earth);margin-bottom:var(--space-xs)}.semana-nav{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-xl);padding:var(--space-sm) 0}.semana-label{font-weight:600;font-size:var(--text-base);color:var(--color-text);text-align:center;text-transform:capitalize}.semana-btn{white-space:nowrap;font-size:var(--text-sm)}.ejercicio-error{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);background:#fff5ee;color:var(--color-warning);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-lg);font-size:var(--text-sm)}.ejercicio-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-2xl) 0;color:var(--color-text-muted)}.dias-grid{display:flex;flex-direction:column;gap:var(--space-md)}.dia-card{background:var(--color-white);border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:box-shadow .2s ease,border-color .2s ease}.dia-card:hover{box-shadow:var(--shadow-md)}.dia-card.dia-hoy{background:var(--color-cream);border-color:var(--color-sand);box-shadow:var(--shadow-md)}.dia-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.dia-hoy .dia-header{border-bottom-color:var(--color-sand)}.dia-nombre{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);display:flex;align-items:center;gap:var(--space-sm)}.badge-hoy{display:inline-block;background:var(--color-sage);color:var(--color-white);font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;padding:2px 8px;border-radius:var(--radius-full);letter-spacing:.02em}.dia-fecha{font-size:var(--text-sm);color:var(--color-text-muted);text-transform:capitalize}.dia-vacio{color:var(--color-text-muted);font-size:var(--text-sm);font-style:italic;padding:var(--space-sm) 0}.ejercicios-lista{list-style:none;display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.ejercicio-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-sm);border-radius:var(--radius-sm);transition:background-color .15s ease}.ejercicio-item:hover{background:var(--color-cream)}.dia-hoy .ejercicio-item:hover{background:var(--color-cream-dark)}.ejercicio-check{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;flex:1;min-width:0}.ejercicio-check input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.checkmark{display:flex;align-items:center;justify-content:center;width:20px;height:20px;min-width:20px;border:2px solid var(--color-sand-dark);border-radius:4px;background:var(--color-white);transition:all .2s ease}.checkmark:after{content:"";display:none;width:5px;height:10px;border:solid var(--color-white);border-width:0 2px 2px 0;transform:rotate(45deg);margin-bottom:2px}.ejercicio-check input[type=checkbox]:checked~.checkmark{background:var(--color-sage);border-color:var(--color-sage)}.ejercicio-check input[type=checkbox]:checked~.checkmark:after{display:block}.ejercicio-check input[type=checkbox]:focus-visible~.checkmark{outline:2px solid var(--color-earth);outline-offset:2px}.ejercicio-nombre{font-size:var(--text-base);color:var(--color-text);transition:all .2s ease;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ejercicio-item.completado .ejercicio-nombre{text-decoration:line-through;color:var(--color-text-muted)}.ejercicio-item.completado .checkmark{background:var(--color-sage);border-color:var(--color-sage)}.btn-eliminar{display:flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;border-radius:var(--radius-full);background:none;color:var(--color-text-muted);font-size:var(--text-lg);line-height:1;opacity:0;transition:all .15s ease;cursor:pointer}.ejercicio-item:hover .btn-eliminar{opacity:1}.btn-eliminar:hover{background:var(--color-rose);color:var(--color-rose-dark)}.agregar-ejercicio{display:flex;gap:var(--space-sm);align-items:center}.agregar-ejercicio input{flex:1;padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-white)}.dia-hoy .agregar-ejercicio input{background:var(--color-white);border-color:var(--color-sand)}.agregar-ejercicio input:focus{outline:none;border-color:var(--color-earth)}.btn-agregar{white-space:nowrap;flex-shrink:0}.spinner-sm{width:14px;height:14px;border-width:2px}@media (min-width: 768px){.ejercicio-header h1{font-size:var(--text-3xl)}.dias-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}.dia-card:last-child:nth-child(odd){grid-column:1 / -1}.btn-eliminar{opacity:0}.ejercicio-item:hover .btn-eliminar{opacity:1}}@media (min-width: 1024px){.dias-grid{grid-template-columns:repeat(3,1fr)}.dia-card:last-child:nth-child(odd){grid-column:auto}}@media (max-width: 767px){.btn-eliminar{opacity:.6}.semana-nav{flex-wrap:wrap;justify-content:center}.semana-label{order:-1;width:100%;text-align:center;margin-bottom:var(--space-xs)}}.medicamentos{padding-bottom:var(--space-lg)}.med-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--space-md);color:var(--color-text-light)}.med-loading .spinner{width:28px;height:28px}.med-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;gap:var(--space-lg);text-align:center;color:var(--color-text-light);padding:var(--space-xl)}.med-aviso{background:#fff5ee;color:var(--color-warning);font-size:var(--text-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-lg);text-align:center}.med-header{margin-bottom:var(--space-xl)}.med-header h1{font-family:var(--font-heading);font-size:var(--text-3xl);color:var(--color-earth);font-weight:600;line-height:1.2}.med-fecha{color:var(--color-text-muted);font-size:var(--text-sm);margin-top:var(--space-xs);text-transform:capitalize}.med-seccion{margin-bottom:var(--space-2xl)}.med-seccion-titulo{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--color-text);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.med-vacio{color:var(--color-text-muted);font-size:var(--text-sm);font-style:italic;padding:var(--space-md) 0}.med-resumen{font-size:var(--text-sm);color:var(--color-text-light);margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-cream-dark);border-radius:var(--radius-sm)}.med-resumen strong{color:var(--color-earth);font-weight:700}.med-checklist{list-style:none;display:flex;flex-direction:column;gap:var(--space-xs)}.med-checklist-item{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-md);transition:background .2s ease,opacity .2s ease}.med-checklist-item--tomado{background:var(--color-cream);opacity:.7}.med-checklist-label{display:flex;align-items:center;gap:var(--space-md);cursor:pointer;-webkit-user-select:none;user-select:none}.med-checkbox{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.med-checkbox-custom{flex-shrink:0;width:22px;height:22px;border:2px solid var(--color-sand-dark);border-radius:6px;background:var(--color-white);transition:all .2s ease;position:relative}.med-checkbox-custom:after{content:"";position:absolute;top:3px;left:6px;width:6px;height:10px;border:solid var(--color-white);border-width:0 2px 2px 0;transform:rotate(45deg);opacity:0;transition:opacity .15s ease}.med-checkbox:checked+.med-checkbox-custom{background:var(--color-sage);border-color:var(--color-sage-dark)}.med-checkbox:checked+.med-checkbox-custom:after{opacity:1}.med-checkbox:focus-visible+.med-checkbox-custom{outline:2px solid var(--color-earth);outline-offset:2px}.med-checklist-info{display:flex;flex-direction:column;gap:2px;min-width:0}.med-checklist-nombre{font-size:var(--text-base);font-weight:600;color:var(--color-text);transition:color .2s ease}.med-checklist-item--tomado .med-checklist-nombre{color:var(--color-text-light)}.med-checklist-horario{font-size:var(--text-xs);color:var(--color-text-muted)}.med-form-card{margin-bottom:var(--space-lg)}.med-form-titulo{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-md)}.med-form{display:flex;flex-direction:column}.med-form-error{color:var(--color-warning);font-size:var(--text-sm);text-align:center;padding:var(--space-sm);background:#fff5ee;border-radius:var(--radius-sm);margin-bottom:var(--space-md)}.med-form-btn{align-self:flex-start;min-width:120px}.med-lista{list-style:none;display:flex;flex-direction:column;gap:var(--space-xs)}.med-lista-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-md);transition:box-shadow .2s ease}.med-lista-item:hover{box-shadow:var(--shadow-sm)}.med-lista-info{display:flex;flex-direction:column;gap:2px;min-width:0}.med-lista-nombre{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.med-lista-horario{font-size:var(--text-xs);color:var(--color-text-muted)}@media (min-width: 768px){.med-header h1{font-size:var(--text-3xl)}.med-seccion-titulo{font-size:var(--text-2xl)}.med-form{flex-direction:row;flex-wrap:wrap;gap:var(--space-md);align-items:flex-end}.med-form .form-group{flex:1;min-width:180px;margin-bottom:0}.med-form-btn{align-self:flex-end;margin-bottom:0}.med-form-error{width:100%}.med-checklist-item,.med-lista-item{padding:var(--space-md) var(--space-lg)}}.medidas-page{padding-bottom:var(--space-xl)}.medidas-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--space-md);color:var(--color-text-light)}.medidas-loading .spinner{width:28px;height:28px}.medidas-header{margin-bottom:var(--space-xl)}.medidas-header h1{font-family:var(--font-heading);font-size:var(--text-2xl);color:var(--color-earth);font-weight:600;line-height:1.2}.medidas-subtitle{color:var(--color-text-muted);font-size:var(--text-sm);margin-top:var(--space-xs)}.medidas-mensaje{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-md);text-align:center}.medidas-mensaje-error{background:#fff5ee;color:var(--color-warning)}.medidas-mensaje-exito{background:#f0f5ee;color:var(--color-sage-dark)}.medidas-seccion-chart,.medidas-seccion-form,.medidas-seccion-historial{margin-bottom:var(--space-xl)}.medidas-seccion-chart h2,.medidas-seccion-form h2,.medidas-seccion-historial h2{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--color-text);margin-bottom:var(--space-md)}.medidas-chart-card{background:var(--color-white);border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.medidas-chart-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.medidas-chart-svg{width:100%;min-width:400px;height:auto;display:block}.chart-grid-line{stroke:var(--color-border);stroke-width:.5;stroke-dasharray:4 3}.chart-axis-label{font-family:var(--font-body);font-size:11px;fill:var(--color-text-muted)}.chart-axis-unit{font-family:var(--font-body);font-size:11px;fill:var(--color-text-light);font-weight:600}.chart-line{stroke:var(--color-sage-dark);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.chart-area{fill:var(--color-sage);opacity:.15}.chart-point{fill:var(--color-sage-dark);stroke:var(--color-white);stroke-width:2;cursor:pointer;transition:r .2s ease}.chart-point:hover{r:7}.chart-point-inner{fill:var(--color-white);pointer-events:none}.medidas-chart-vacio{text-align:center;padding:var(--space-xl);color:var(--color-text-muted);font-size:var(--text-sm)}.medidas-form{padding:var(--space-lg)}.medidas-fecha-group{margin-bottom:var(--space-lg)}.medidas-fecha-group input{max-width:220px}.medidas-form-grid{display:grid;grid-template-columns:1fr;gap:var(--space-sm) var(--space-md)}.medidas-form .input-con-unidad{position:relative;display:flex;align-items:center}.medidas-form .input-con-unidad input{padding-right:3rem}.medidas-form .input-con-unidad .input-unidad{position:absolute;right:var(--space-md);color:var(--color-text-muted);font-size:var(--text-sm);pointer-events:none}.medidas-guardar{width:100%;padding:var(--space-md);font-size:var(--text-base);margin-top:var(--space-lg)}.medidas-historial-lista{display:flex;flex-direction:column;gap:var(--space-md)}.medidas-historial-card{padding:var(--space-lg);transition:box-shadow .2s ease}.medidas-historial-card:hover{box-shadow:var(--shadow-md)}.medidas-historial-fecha{font-family:var(--font-heading);font-size:var(--text-base);font-weight:600;color:var(--color-earth);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.medidas-historial-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm) var(--space-md)}.medidas-historial-item{display:flex;flex-direction:column;gap:2px;padding:var(--space-xs) 0}.medidas-historial-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.medidas-historial-valor{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.medidas-vacio{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--color-text-light)}.medidas-vacio p:first-child{font-size:var(--text-lg);margin-bottom:var(--space-sm)}@media (min-width: 640px){.medidas-form-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-md) var(--space-lg)}.medidas-historial-grid{grid-template-columns:repeat(3,1fr)}.medidas-guardar{width:auto;min-width:200px;align-self:flex-start}.medidas-form{display:flex;flex-direction:column}}@media (min-width: 768px){.medidas-header h1{font-size:var(--text-3xl)}.medidas-subtitle{font-size:var(--text-base)}.medidas-form,.medidas-chart-card{padding:var(--space-xl)}.medidas-historial-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-md) var(--space-lg)}.medidas-historial-valor{font-size:var(--text-lg)}}@media (min-width: 1024px){.medidas-form-grid,.medidas-historial-grid{grid-template-columns:repeat(3,1fr)}}.metas-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--space-md);color:var(--color-text-light)}.metas-page{max-width:720px;margin:0 auto;padding-bottom:var(--space-2xl)}.metas-header{margin-bottom:var(--space-lg)}.metas-header h1{font-family:var(--font-heading);color:var(--color-earth);font-size:var(--text-2xl);margin-bottom:var(--space-xs)}.metas-subtitle{color:var(--color-text-muted);font-size:var(--text-sm)}.metas-mensaje{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-md)}.metas-mensaje-error{background:#fff8f0;color:var(--color-warning);border:1px solid rgba(212,165,116,.3)}.metas-mensaje-cerrar{background:none;border:none;font-size:var(--text-lg);color:inherit;opacity:.6;padding:0 var(--space-xs);line-height:1;cursor:pointer;transition:opacity .2s}.metas-mensaje-cerrar:hover{opacity:1}.metas-form{margin-bottom:var(--space-xl)}.metas-form-titulo{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.metas-form textarea{resize:vertical;min-height:80px;line-height:1.5}.metas-fecha-input{max-width:220px;min-width:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.metas-btn-agregar{width:100%;padding:var(--space-sm) var(--space-lg);margin-top:var(--space-xs)}.metas-btn-agregar:disabled{opacity:.6;cursor:not-allowed}.metas-tabs{display:flex;gap:var(--space-xs);margin-bottom:var(--space-lg);border-bottom:2px solid var(--color-border)}.metas-tab{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);font-weight:600;color:var(--color-text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .2s,border-color .2s}.metas-tab:hover{color:var(--color-text-light)}.metas-tab-activa{color:var(--color-earth);border-bottom-color:var(--color-earth)}.metas-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;background:var(--color-cream-dark);color:var(--color-text-light)}.metas-tab-activa .metas-tab-badge{background:var(--color-earth);color:var(--color-white)}.metas-seccion{min-height:120px}.metas-vacio{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-2xl) var(--space-lg);background:var(--color-white);border-radius:var(--radius-md);border:1px dashed var(--color-border)}.metas-vacio-titulo{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text-light);margin-bottom:var(--space-sm)}.metas-vacio-texto{font-size:var(--text-sm);color:var(--color-text-muted);max-width:320px;line-height:1.5}.metas-lista{display:flex;flex-direction:column;gap:var(--space-md)}.meta-card{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);background:var(--color-white);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--color-border);border-left:4px solid var(--color-earth);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.meta-card:hover{box-shadow:var(--shadow-md)}.meta-card-contenido{flex:1;min-width:0}.meta-card-descripcion{font-size:var(--text-base);color:var(--color-text);line-height:1.5;margin-bottom:var(--space-sm);word-wrap:break-word}.meta-card-detalles{display:flex;flex-wrap:wrap;gap:var(--space-sm) var(--space-md)}.meta-card-fecha,.meta-card-dias{font-size:var(--text-xs);color:var(--color-text-muted)}.meta-card-fecha{color:var(--color-text-light)}.meta-card-acciones{display:flex;flex-direction:column;gap:var(--space-xs);flex-shrink:0}.reportes-lista{display:flex;flex-direction:column;gap:var(--space-md)}.reporte-card{background:linear-gradient(135deg,var(--color-cream) 0%,#FDF2F0 100%);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid rgba(242,209,209,.5);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.reporte-card:hover{box-shadow:var(--shadow-md)}.reporte-card-descripcion{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);font-weight:600;margin-bottom:var(--space-md);line-height:1.4}.reporte-card-fechas{display:flex;flex-direction:column;gap:var(--space-xs);font-size:var(--text-sm);color:var(--color-text-light);margin-bottom:var(--space-sm)}.reporte-card-dias{font-size:var(--text-sm);color:var(--color-earth);font-weight:600;margin-bottom:var(--space-md)}.reporte-card-frase{font-family:var(--font-heading);font-style:italic;font-size:var(--text-base);color:var(--color-text-light);line-height:1.6;padding-top:var(--space-sm);border-top:1px solid rgba(232,213,183,.5)}.celebracion-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#4a372866;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:var(--space-md);animation:overlayFadeIn .3s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.celebracion-card{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--space-xl) var(--space-xl);max-width:440px;width:100%;text-align:center;box-shadow:var(--shadow-lg);animation:cardSlideUp .4s ease}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.celebracion-titulo{font-family:var(--font-heading);font-size:var(--text-2xl);color:var(--color-earth);font-weight:600;margin-bottom:var(--space-md)}.celebracion-descripcion{font-size:var(--text-base);color:var(--color-text);line-height:1.5;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}.celebracion-detalles{display:flex;flex-direction:column;gap:var(--space-xs);font-size:var(--text-sm);color:var(--color-text-light);margin-bottom:var(--space-lg)}.celebracion-dias{font-weight:600;color:var(--color-earth);font-size:var(--text-base);margin-top:var(--space-xs)}.celebracion-frase{font-family:var(--font-heading);font-style:italic;font-size:var(--text-lg);color:var(--color-text-light);line-height:1.6;margin-bottom:var(--space-xl);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,var(--color-cream) 0%,#FDF2F0 100%);border-radius:var(--radius-sm)}.celebracion-cerrar{width:100%;padding:var(--space-sm) var(--space-lg)}@media (max-width: 600px){.metas-page{padding-left:var(--space-xs);padding-right:var(--space-xs)}.meta-card{flex-direction:column;gap:var(--space-sm)}.meta-card-acciones{flex-direction:row;width:100%}.meta-card-acciones .btn{flex:1}.metas-tab{flex:1;justify-content:center;padding:var(--space-sm) var(--space-md)}.metas-fecha-input{max-width:100%;width:100%;box-sizing:border-box}.celebracion-card{padding:var(--space-lg)}.celebracion-frase{font-size:var(--text-base);padding:var(--space-sm) var(--space-md)}.reporte-card-fechas{font-size:var(--text-xs)}}@media (min-width: 601px){.metas-header h1{font-size:var(--text-3xl)}.metas-btn-agregar{width:auto;align-self:flex-start}.metas-form{display:flex;flex-direction:column}.celebracion-card{padding:var(--space-2xl)}.reporte-card-fechas{flex-direction:row;gap:var(--space-lg)}}.habitos-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--space-md);color:var(--color-text-light)}.habitos-loading .spinner-lg{width:32px;height:32px;border-width:3px}.habitos-page{max-width:720px;margin:0 auto;padding-bottom:var(--space-2xl)}.habitos-header{margin-bottom:var(--space-lg)}.habitos-header h1{font-family:var(--font-heading);color:var(--color-earth);font-size:var(--text-2xl);margin-bottom:var(--space-xs)}.habitos-subtitle{color:var(--color-text-muted);font-size:var(--text-sm)}.habitos-mensaje{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-md);text-align:center}.habitos-mensaje-error{background:#fff8f0;color:var(--color-warning);border:1px solid rgba(212,165,116,.3)}.habitos-mensaje-exito{background:#f0f5ee;color:var(--color-sage-dark);border:1px solid rgba(143,168,137,.3)}.habitos-form{display:flex;gap:var(--space-sm);margin-bottom:var(--space-xl);background:var(--color-white);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);align-items:center}.habitos-input{flex:1;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);font-family:var(--font-body);color:var(--color-text);background:var(--color-cream);transition:border-color .2s;outline:none;min-width:0}.habitos-input::placeholder{color:var(--color-text-muted)}.habitos-input:focus{border-color:var(--color-sage);background:var(--color-white)}.habitos-btn-agregar{white-space:nowrap;padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);border-radius:var(--radius-sm);flex-shrink:0}.habitos-btn-agregar:disabled{opacity:.6;cursor:not-allowed}.habitos-vacio{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--color-text-light)}.habitos-vacio p{font-size:var(--text-base);margin-bottom:var(--space-sm)}.habitos-vacio-hint{font-size:var(--text-sm);color:var(--color-text-muted)}.habitos-lista{display:flex;flex-direction:column;gap:var(--space-lg)}.habito-card{background:var(--color-white);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.habito-card:hover{box-shadow:var(--shadow-md)}.habito-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-md)}.habito-nombre{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text);font-weight:600;line-height:1.3}.habito-btn-archivar{background:none;border:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--text-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;white-space:nowrap;font-family:var(--font-body);flex-shrink:0}.habito-btn-archivar:hover{border-color:var(--color-sand-dark);color:var(--color-text-light);background:var(--color-cream)}.habito-rachas{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-md);font-size:var(--text-sm)}.habito-racha-actual{color:var(--color-sage-dark);font-weight:600}.habito-racha-inactiva{color:var(--color-text-muted);font-style:italic}.habito-mejor-racha{color:var(--color-text-light)}.habito-progreso{margin-bottom:var(--space-lg)}.habito-barra-fondo{width:100%;height:8px;background:var(--color-cream-dark);border-radius:var(--radius-full);overflow:hidden}.habito-barra-relleno{height:100%;background:var(--color-sage);border-radius:var(--radius-full);transition:width .4s ease;min-width:0}.habito-progreso-texto{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-xs)}.habito-consolidado{font-size:var(--text-sm);color:var(--color-sage-dark);background:#f0f5ee;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-top:var(--space-sm);text-align:center;font-weight:500;border:1px solid rgba(143,168,137,.2)}.calendario-mini{border-top:1px solid var(--color-border);padding-top:var(--space-md)}.calendario-titulo{font-size:var(--text-sm);color:var(--color-text-light);font-weight:600;margin-bottom:var(--space-sm);text-transform:capitalize}.calendario-cabecera{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--space-xs)}.calendario-dia-header{text-align:center;font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600;padding:2px 0}.calendario-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.calendario-celda{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;max-width:36px;margin:0 auto;font-size:var(--text-xs);color:var(--color-text);border-radius:var(--radius-full);transition:all .15s ease;-webkit-user-select:none;user-select:none;position:relative}.calendario-celda-vacia{visibility:hidden}.calendario-celda-futuro{color:var(--color-text-muted);opacity:.4}.calendario-celda-completado{background:var(--color-sage);color:var(--color-white);font-weight:600}.calendario-celda-hoy{border:2px solid var(--color-earth);font-weight:700}.calendario-celda-hoy.calendario-celda-completado{border-color:var(--color-sage-dark)}.calendario-celda-clickable{cursor:pointer}.calendario-celda-clickable:hover{transform:scale(1.15);box-shadow:var(--shadow-sm)}.calendario-celda-clickable:active{transform:scale(.95)}@media (max-width: 600px){.habitos-page{padding-left:var(--space-xs);padding-right:var(--space-xs)}.habitos-form{flex-direction:column;padding:var(--space-md);gap:var(--space-sm)}.habitos-input{width:100%}.habitos-btn-agregar{width:100%;text-align:center}.habito-card{padding:var(--space-md)}.habito-nombre{font-size:var(--text-base)}.habito-rachas{flex-direction:column;gap:var(--space-xs)}.calendario-celda{max-width:32px;font-size:.65rem}.calendario-dia-header{font-size:.65rem}}@media (min-width: 601px){.habitos-header h1{font-size:var(--text-3xl)}.calendario-celda{max-width:40px}.habito-card{padding:var(--space-lg) var(--space-xl)}}:root{--color-cream: #FDF6EC;--color-cream-dark: #F5EBD8;--color-sand: #E8D5B7;--color-sand-dark: #C9AD85;--color-rose: #F2D1D1;--color-rose-dark: #D4A5A5;--color-earth: #A67B5B;--color-earth-dark: #8B6142;--color-sage: #B5C4B1;--color-sage-dark: #8FA889;--color-white: #FFFFFF;--color-text: #4A3728;--color-text-light: #7D6B5D;--color-text-muted: #A89888;--color-border: #E8DDD0;--color-success: #8FA889;--color-warning: #D4A574;--color-bg: #FDF6EC;--font-heading: "Cormorant Garamond", Georgia, serif;--font-body: "Nunito", "Segoe UI", sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(74, 55, 40, .06);--shadow-md: 0 4px 12px rgba(74, 55, 40, .08);--shadow-lg: 0 8px 24px rgba(74, 55, 40, .1);--sidebar-width: 260px;--bottomnav-height: 70px;--header-height: 60px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--color-text);background-color:var(--color-bg);line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.3;color:var(--color-text)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}a{color:var(--color-earth);text-decoration:none}a:hover{color:var(--color-earth-dark)}button{font-family:var(--font-body);cursor:pointer;border:none;outline:none}input,textarea,select{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);background:var(--color-white);transition:border-color .2s;width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-earth)}input[type=date]{-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:0;max-width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;transition:all .2s ease}.btn-primary{background:var(--color-earth);color:var(--color-white)}.btn-primary:hover{background:var(--color-earth-dark)}.btn-secondary{background:var(--color-cream-dark);color:var(--color-text)}.btn-secondary:hover{background:var(--color-sand)}.btn-ghost{background:transparent;color:var(--color-text-light)}.btn-ghost:hover{background:var(--color-cream-dark)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--text-xs)}.card{background:var(--color-white);border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.form-group label{font-size:var(--text-sm);font-weight:600;color:var(--color-text-light)}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-sand);border-top-color:var(--color-earth);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-md);color:var(--color-text-light)}.text-muted{color:var(--color-text-muted)}.text-center{text-align:center}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-sand);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-sand-dark)}
