.auth-container{min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{background:white;border-radius:1rem;box-shadow:0 10px 40px #0000001a;padding:3rem 2rem;max-width:400px;width:100%}.auth-card h1{text-align:center;color:#333;margin-bottom:.5rem;font-size:2rem}.auth-subtitle{text-align:center;color:#666;margin-bottom:2rem;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;color:#333;margin-bottom:.5rem;font-size:.95rem}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:.5rem;font-size:1rem;transition:border-color .3s}.form-group small{color:#999;font-size:.85rem;margin-top:.25rem}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:.5rem;font-size:.95rem;margin-bottom:1rem;border-left:4px solid #c33}.btn-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;padding:.75rem;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:2rem;color:#666;font-size:.95rem}.auth-footer a{color:#667eea;text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}@media (max-width: 480px){.auth-card{padding:2rem 1rem}.auth-card h1{font-size:1.5rem}}.inicio-container{max-width:1000px;margin:0 auto;padding:2rem}.inicio-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:2rem;border-radius:1rem;margin-bottom:2rem;text-align:center}.inicio-header h1{margin:0;font-size:2rem;margin-bottom:.5rem}.inicio-header p{margin:0;opacity:.9;font-size:.95rem}.motivational-card{background:linear-gradient(135deg,#ffd89b 0%,#19547b 100%);color:#fff;padding:2rem;border-radius:1rem;margin-bottom:2rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:1rem;min-height:100px}.motivational-icon{font-size:2.5rem}.motivational-card p{margin:0;font-size:1.1rem;font-weight:500}.progress-section{background:white;padding:2rem;border-radius:1rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.progress-section h2{margin:0 0 1.5rem;color:#333;font-size:1.2rem}.progress-item{display:flex;flex-direction:column}.progress-item label{color:#666;margin-bottom:.5rem;font-weight:500}.progress-bar-container{margin-bottom:.5rem}.progress-bar{width:100%;height:8px;background-color:#e0e0e0;border-radius:10px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea 0%,#764ba2 100%);transition:width .3s ease}.progress-text{color:#999;font-size:.9rem}.stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:white;padding:1.5rem;border-radius:1rem;text-align:center;box-shadow:0 2px 8px #0000001a}.stat-number{font-size:2rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.stat-label{color:#999;font-size:.9rem}.action-section{background:white;padding:2rem;border-radius:1rem;text-align:center;box-shadow:0 2px 8px #0000001a}.action-section h3{margin:0 0 .5rem;color:#333;font-size:1.1rem}.action-section p{margin:0 0 1.5rem;color:#999;font-size:.95rem}.btn-action{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;padding:.75rem 2rem;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.no-familia{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:2rem}.no-familia-card{background:white;padding:3rem 2rem;border-radius:1rem;text-align:center;box-shadow:0 5px 20px #0000001a;max-width:400px}.no-familia-card h2{margin:0 0 1rem;color:#333;font-size:1.5rem}.no-familia-card p{margin:0 0 2rem;color:#999}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:white;padding:2rem;border-radius:1rem;max-width:400px;width:90%;box-shadow:0 10px 40px #0003}.modal-content h3{margin:0 0 1.5rem;color:#333}.modal-content input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:.5rem;font-size:1rem;margin-bottom:1.5rem;box-sizing:border-box}.modal-content input:focus{outline:none;border-color:#667eea}.modal-buttons{display:flex;gap:1rem}@media (max-width: 768px){.inicio-container{padding:1rem}.motivational-card{flex-direction:column;text-align:center}.stats-container{grid-template-columns:1fr 1fr}}.familia-container{max-width:1000px;margin:0 auto;padding:2rem}.familia-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:2rem;border-radius:1rem;margin-bottom:2rem;text-align:center}.familia-header h1{margin:0 0 .5rem;font-size:1.8rem}.familia-header p{margin:0;opacity:.9}.miembros-section{margin-bottom:3rem}.miembros-section h2{color:#333;margin-bottom:1.5rem;font-size:1.3rem}.miembros-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1.5rem;margin-bottom:2rem}.miembro-card{background:white;padding:1.5rem;border-radius:1rem;text-align:center;box-shadow:0 2px 8px #0000001a;border:2px solid #f0f0f0;transition:transform .2s,box-shadow .2s}.miembro-card:hover{transform:translateY(-5px);box-shadow:0 5px 15px #00000026}.miembro-avatar{font-size:3rem;margin-bottom:.5rem}.miembro-card h3{margin:.5rem 0;color:#333;font-size:1.1rem}.miembro-rol{color:#999;font-size:.85rem;margin:0 0 1rem;text-transform:capitalize}.miembro-puntos{display:flex;align-items:baseline;justify-content:center;gap:.25rem;padding:.75rem;background:linear-gradient(135deg,#ffd89b 0%,#19547b 100%);border-radius:.5rem;color:#fff;margin-bottom:.5rem}.puntos-label{font-size:1.8rem;font-weight:700}.puntos-text{font-size:.9rem}.invitation-section{background:white;padding:2rem;border-radius:1rem;box-shadow:0 2px 8px #0000001a}.invitation-section h2{color:#333;margin:0 0 .5rem;font-size:1.2rem}.invitation-section p{color:#999;margin:0 0 1.5rem}.codigo-container{display:flex;gap:1rem;align-items:center}.codigo-display{flex:1;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:1rem;border-radius:.5rem;font-size:1.5rem;font-weight:700;text-align:center;letter-spacing:2px;font-family:Courier New,monospace}.btn-mostrar-codigo{padding:.75rem 1.5rem;background:#f0f0f0;border:1px solid #ddd;border-radius:.5rem;cursor:pointer;font-weight:600;transition:background-color .2s}.btn-mostrar-codigo:hover{background-color:#e0e0e0}.btn-copiar{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-weight:600;transition:transform .2s}.btn-copiar:hover{transform:scale(1.05)}@media (max-width: 768px){.miembros-grid{grid-template-columns:repeat(2,1fr)}.codigo-container{flex-direction:column}.codigo-container button{width:100%}}.tareas-container{max-width:1000px;margin:0 auto;padding:2rem}.tareas-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:2rem;border-radius:1rem;margin-bottom:2rem;text-align:center}.tareas-header h1{margin:0 0 .5rem;font-size:1.8rem}.tareas-header p{margin:0;opacity:.9}.tareas-content{background:white;padding:2rem;border-radius:1rem;box-shadow:0 2px 8px #0000001a}.tareas-content h2{color:#333;margin:0 0 1.5rem;font-size:1.2rem}.tareas-list{margin-bottom:2rem}.tarea-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f9f9f9;border-radius:.5rem;margin-bottom:.75rem;transition:background-color .2s}.tarea-item:hover{background-color:#f0f0f0}.tarea-checkbox{width:24px;height:24px;cursor:pointer;accent-color:#667eea}.tarea-info{flex:1}.tarea-info h3{margin:0 0 .25rem;color:#333;font-size:1rem}.tarea-horario{margin:0;color:#999;font-size:.85rem}.tarea-puntos{background:linear-gradient(135deg,#ffd89b 0%,#19547b 100%);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem}.no-tareas{text-align:center;color:#999;padding:2rem}.loading{text-align:center;padding:4rem 2rem;color:#999}@media (max-width: 768px){.tareas-container{padding:1rem}.tarea-item{flex-direction:column;align-items:flex-start}.tarea-puntos{width:100%;text-align:center}}.calendario-container{max-width:1000px;margin:0 auto;padding:2rem}.calendario-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:2rem;border-radius:1rem;margin-bottom:2rem;text-align:center}.calendario-header h1{margin:0 0 .5rem;font-size:1.8rem}.calendario-header p{margin:0;opacity:.9}.calendario-content{background:white;padding:2rem;border-radius:1rem;box-shadow:0 2px 8px #0000001a}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.calendar-header button{background:#f0f0f0;border:none;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:1.2rem;transition:background-color .2s}.calendar-header button:hover{background-color:#e0e0e0}.calendar-header h2{margin:0;color:#333;font-size:1.3rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:2rem}.weekday-header{text-align:center;font-weight:600;color:#667eea;padding:.5rem;background:#f9f9f9;border-radius:.5rem}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#f9f9f9;border-radius:.5rem;border:2px solid #f0f0f0;position:relative;cursor:pointer;transition:all .2s}.calendar-day:not(.empty):hover{background-color:#f0f0f0;border-color:#667eea}.calendar-day.today{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;font-weight:700;border-color:transparent}.calendar-day.empty{background:transparent;border:none}.day-number{font-weight:600;color:#333}.tareas-hoy{margin-top:2rem;padding-top:2rem;border-top:1px solid #eee}.tareas-hoy h3{color:#333;margin:0 0 1rem;font-size:1.1rem}.tareas-dia-list{display:flex;flex-direction:column;gap:.75rem}.tarea-dia-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f9f9f9;border-radius:.5rem}.tarea-dia-item input{width:20px;height:20px;cursor:pointer;accent-color:#667eea}.tarea-dia-item span:nth-child(2){flex:1;color:#333}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.status-badge.completada{background-color:#e8f5e9;color:#2e7d32}.status-badge.pendiente{background-color:#fff3e0;color:#e65100}@media (max-width: 768px){.calendario-container{padding:1rem}.calendar-grid{gap:.25rem}.calendar-day{font-size:.85rem}}.premios-container{max-width:1000px;margin:0 auto;padding:2rem}.premios-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:2rem;border-radius:1rem;margin-bottom:2rem;text-align:center}.premios-header h1{margin:0 0 .5rem;font-size:1.8rem}.premios-header p{margin:0;opacity:.9}.mis-puntos{display:flex;justify-content:center;margin-bottom:2rem}.puntos-display{background:linear-gradient(135deg,#ffd89b 0%,#19547b 100%);color:#fff;padding:2rem;border-radius:1rem;text-align:center;min-width:250px;box-shadow:0 5px 15px #0000001a}.puntos-numero{display:block;font-size:3rem;font-weight:700;margin-bottom:.5rem}.puntos-etiqueta{display:block;font-size:1rem;opacity:.95}.premios-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.premio-card{background:white;padding:1.5rem;border-radius:1rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.premio-card:hover{transform:translateY(-5px);box-shadow:0 5px 15px #00000026}.premio-icono{font-size:3rem;text-align:center;margin-bottom:1rem}.premio-card h3{margin:0 0 .5rem;color:#333;font-size:1.1rem}.premio-descripcion{color:#999;font-size:.9rem;margin:0 0 1rem;min-height:40px}.premio-puntos-req{margin-bottom:1rem}.puntos-bar{width:100%;height:6px;background-color:#e0e0e0;border-radius:10px;overflow:hidden;margin-bottom:.5rem}.puntos-bar-fill{height:100%;background:linear-gradient(90deg,#667eea 0%,#764ba2 100%);transition:width .3s ease}.premio-puntos-req span{display:block;color:#999;font-size:.85rem;text-align:center}.btn-canjear{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-canjear:hover:not(.disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.btn-canjear.disabled{opacity:.5;cursor:not-allowed}.premios-otros{background:white;padding:2rem;border-radius:1rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.premios-otros h3{margin:0 0 1rem;color:#333}.constancia-item{margin-bottom:1.5rem}.constancia-item p{margin:0 0 .5rem;color:#333;font-size:.95rem}.constancia-progress{margin-bottom:.5rem}.constancia-bar{display:block;height:8px;background-color:#e0e0e0;border-radius:10px;overflow:hidden}.constancia-bar{background:linear-gradient(90deg,#4caf50 0%,#81c784 100%)}.constancia-item span{display:block;color:#999;font-size:.85rem}.btn-action{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-action:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}@media (max-width: 768px){.premios-container{padding:1rem}.premios-list{grid-template-columns:1fr}}.perfil-container{max-width:1000px;margin:0 auto;padding:2rem}.perfil-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:2rem;border-radius:1rem;margin-bottom:2rem;text-align:center}.perfil-header h1{margin:0;font-size:1.8rem}.perfil-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.perfil-card{background:white;padding:2rem;border-radius:1rem;box-shadow:0 2px 8px #0000001a;text-align:center}.perfil-avatar-section{margin-bottom:1.5rem}.perfil-avatar-large{font-size:4rem;margin-bottom:1rem;display:block}.perfil-avatar-section input{padding:.5rem;border:1px solid #ddd;border-radius:.5rem;font-size:1.5rem;text-align:center;width:100%;box-sizing:border-box}.perfil-card h2{margin:0 0 .5rem;color:#333;font-size:1.5rem}.perfil-email{color:#999;margin:0 0 1.5rem}.perfil-edit{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;text-align:left}.form-group label{color:#666;font-weight:600;margin-bottom:.5rem}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:.5rem;font-size:1rem}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.edit-buttons{display:flex;gap:1rem;margin-top:1rem}.btn-cancel{flex:1;padding:.75rem;border:1px solid #ddd;background:white;border-radius:.5rem;cursor:pointer;font-weight:600;transition:background-color .2s}.btn-cancel:hover{background-color:#f5f5f5}.btn-action{flex:1;padding:.75rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-weight:600;transition:transform .2s}.btn-action:hover{transform:translateY(-2px)}.btn-editar{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-weight:600;margin-bottom:1rem;transition:transform .2s}.btn-editar:hover{transform:translateY(-2px)}.accesos-rapidos,.configuracion{background:white;padding:2rem;border-radius:1rem;box-shadow:0 2px 8px #0000001a;text-align:left}.accesos-rapidos h3,.configuracion h3{margin:0 0 1.5rem;color:#333;font-size:1.1rem}.links-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.links-list li a{display:block;padding:.75rem 1rem;background:#f9f9f9;border-radius:.5rem;color:#667eea;text-decoration:none;font-weight:500;transition:background-color .2s}.links-list li a:hover{background-color:#f0f0f0}.btn-logout{width:100%;padding:.75rem;background:#ff6b6b;color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-weight:600;transition:background-color .2s}.btn-logout:hover{background-color:#ff5252}@media (max-width: 768px){.perfil-container{padding:1rem}.perfil-content{grid-template-columns:1fr}}.navbar{background:linear-gradient(135deg,#5c4fe2 0%,#6b5ae8 100%);box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100}.navbar-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}.navbar-logo{font-size:1.5rem;font-weight:700;color:#fff}.navbar-logo a{color:#fff;text-decoration:none}.nav-menu{display:flex;list-style:none;gap:.5rem;margin:0;padding:0;flex-wrap:wrap}.nav-item{position:relative}.nav-link{color:#ffffffe6;text-decoration:none;font-size:.9rem;padding:.5rem 1rem;border-radius:.5rem;transition:all .3s ease;white-space:nowrap}.nav-link:hover{background-color:#fff3;color:#fff}.logout-btn{background-color:#ff6b6b;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:.5rem;cursor:pointer;font-weight:500;transition:background-color .3s ease}.logout-btn:hover{background-color:#ff5252}@media (max-width: 768px){.navbar-container{padding:1rem;flex-direction:column;gap:1rem}.nav-menu{width:100%;justify-content:center}.logout-btn{width:100%}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:#f5f5f5;color:#333;line-height:1.6}html,body,#root{height:100%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}
