.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card{background:#fff;border-radius:1rem;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.login-title{font-size:1.5rem;color:#333;text-align:center;margin-bottom:.25rem}.login-subtitle{text-align:center;color:#888;margin-bottom:1.5rem}.login-message{text-align:center;color:#555;line-height:1.6;margin-bottom:1.5rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-field label{display:block;font-size:.875rem;font-weight:600;color:#555;margin-bottom:.25rem}.login-field input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:.5rem;font-size:1rem;transition:border-color .2s;box-sizing:border-box}.login-field input:focus{outline:none;border-color:#667eea}.login-btn{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#e53e3e;font-size:.875rem;text-align:center;margin:0}.login-toggle{text-align:center;margin-top:1rem;color:#888;font-size:.875rem}.login-toggle-btn{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;font-size:.875rem}.login-toggle-btn:hover{text-decoration:underline}.logout-btn{display:flex;align-items:center;gap:.4rem;padding:.4rem .9rem;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:.5rem;cursor:pointer;font-size:.8rem;font-weight:500;transition:background .2s;white-space:nowrap}.logout-btn:hover{background:#ffffff40}.child-picker{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:2rem 1rem}.picker-title{font-size:1.8rem;font-weight:700;color:#4a4a6a;margin-bottom:2.5rem;text-align:center}.picker-cards{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.picker-card{display:flex;flex-direction:column;align-items:center;gap:.6rem;background:#fff;border:3px solid transparent;border-radius:1.25rem;padding:1.5rem 2rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #667eea1f;min-width:150px;position:relative}.picker-card:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 28px #667eea40}.picker-avatar{width:90px;height:90px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:700;color:#fff;flex-shrink:0}.picker-avatar img{width:100%;height:100%;object-fit:cover}.picker-name{font-size:1.1rem;font-weight:700;color:#333}.picker-lives{display:flex;gap:2px;font-size:.9rem}.life-empty{opacity:.2}.picker-lock{position:absolute;top:8px;right:10px;font-size:.85rem;opacity:.5}.picker-empty{color:#999;text-align:center;font-size:1rem;margin-top:1rem}.pin-screen{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:320px;position:relative}.pin-back-btn{align-self:flex-start;background:none;border:none;color:#667eea;font-size:.95rem;cursor:pointer;padding:.25rem 0;font-weight:600;margin-bottom:.5rem}.pin-back-btn:hover{text-decoration:underline}.pin-avatar-wrap{width:80px;height:80px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;margin-bottom:.25rem}.pin-avatar-img{width:100%;height:100%;object-fit:cover}.pin-avatar-initial{font-size:2rem;font-weight:700;color:#fff}.pin-name{font-size:1.4rem;font-weight:700;color:#333;margin:0}.pin-label{color:#888;font-size:.9rem;margin:0}.pin-dots{display:flex;gap:1rem;margin:.5rem 0;transition:all .2s}.pin-dots.pin-error{animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.pin-dot{width:18px;height:18px;border-radius:50%;border:2px solid #667eea;background:transparent;transition:background .15s}.pin-dot.filled{background:#667eea}.pin-wrong{color:#e53e3e;font-size:.85rem;margin:0}.pin-keypad{display:grid;grid-template-columns:repeat(3,72px);gap:.6rem;margin-top:.75rem}.pin-key{width:72px;height:72px;border-radius:50%;border:none;background:#fff;font-size:1.5rem;font-weight:600;color:#333;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:all .1s;display:flex;align-items:center;justify-content:center}.pin-key:hover{background:#f0f0ff;box-shadow:0 3px 12px #667eea33}.pin-key:active{transform:scale(.93)}.pin-key-empty{background:transparent;box-shadow:none;cursor:default}.pin-key-empty:hover{background:transparent;box-shadow:none}.pin-key-del{background:#fff0f0;color:#e53e3e}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.75rem 1.5rem;box-shadow:var(--shadow-lg);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem}.header-left{display:flex;align-items:center;gap:.75rem}.header-logo{font-size:1.75rem;line-height:1}.header-title-block{display:flex;flex-direction:column;line-height:1.2}.header-title{font-size:1.2rem;font-weight:700;letter-spacing:.01em}.header-subtitle{font-size:.7rem;opacity:.75;font-weight:400;letter-spacing:.03em;text-transform:uppercase}.header-center{display:flex;justify-content:center}.header-right{display:flex;align-items:center;gap:.75rem;justify-content:flex-end}.header-user{display:flex;align-items:center;gap:.5rem}.user-avatar{width:32px;height:32px;border-radius:50%;background:#ffffff40;border:2px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;flex-shrink:0}.user-email{font-size:.78rem;opacity:.85;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.print-routine-btn{white-space:nowrap}.app-title{font-size:2rem;margin-bottom:1rem;text-align:center}.app-main{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.view-selector{display:flex;flex-direction:column;gap:1rem;align-items:center}.view-toggle{display:flex;gap:.5rem;background:#fff3;padding:.25rem;border-radius:.5rem}.toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.5rem;border:none;background:transparent;color:#fff;cursor:pointer;border-radius:.375rem;font-size:1rem;transition:all .2s}.toggle-btn:hover{background:#ffffff1a}.toggle-btn.active{background:#fff;color:#667eea;font-weight:600}.child-selector{display:flex;align-items:center;gap:1rem}.child-selector label{font-weight:500}.child-selector select{padding:.5rem 1rem;border:2px solid rgba(255,255,255,.3);border-radius:.375rem;background:#ffffffe6;color:var(--text-primary);font-size:1rem;cursor:pointer}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--secondary);color:#fff}.btn-secondary:hover{background:#475569}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#d97706}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:.375rem;transition:all .2s}.icon-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.icon-btn.danger:hover{background:#fee2e2;color:var(--danger)}.parent-dashboard{background:var(--bg-secondary);border-radius:1rem;padding:2rem;box-shadow:var(--shadow)}.dashboard-header{margin-bottom:2rem;text-align:center}.dashboard-header h1{font-size:2rem;margin-bottom:.5rem}.dashboard-header p{color:var(--text-secondary)}.tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid var(--border)}.tab{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;font-size:1rem;font-weight:500;transition:all .2s;margin-bottom:-2px}.tab:hover{color:var(--text-primary);background:var(--bg-primary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header h2{font-size:1.5rem}.form-card{background:var(--bg-primary);padding:1.5rem;border-radius:.75rem;margin-bottom:2rem;border:1px solid var(--border)}.form-card h3{margin-bottom:1.5rem;font-size:1.25rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.625rem;border:1px solid var(--border);border-radius:.375rem;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.checkbox-group{display:flex;flex-direction:column;gap:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.children-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.child-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem;box-shadow:var(--shadow);position:relative}.child-avatar{display:flex;justify-content:center;margin-bottom:1rem}.child-avatar img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--primary);box-shadow:var(--shadow)}.child-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.child-header h3{font-size:1.25rem}.child-actions{display:flex;gap:.5rem}.child-stats{display:flex;gap:1.5rem;margin-bottom:1rem}.stat{display:flex;align-items:center;gap:.5rem;font-weight:500}.icon-heart{color:var(--danger)}.icon-trophy{color:var(--warning)}.pending-banner{background:#dbeafe;border-left:4px solid var(--primary);padding:1rem;border-radius:.5rem;display:flex;align-items:flex-start;gap:.75rem;color:#1e40af;margin-bottom:1rem}.pending-banner svg{flex-shrink:0;margin-top:.25rem}.pending-info{flex:1}.pending-info>span{display:block;margin-bottom:.5rem}.pending-levels{display:flex;flex-direction:column;gap:.25rem}.pending-level-badge{display:inline-block;background:#3b82f626;padding:.25rem .5rem;border-radius:.25rem;font-size:.875rem;font-weight:500}.punishment-badge{background:#fee2e2;color:var(--danger);padding:.5rem;border-radius:.375rem;font-size:.875rem;font-weight:500;margin-bottom:1rem}.punishments-list{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.punishment-item{display:flex;align-items:center;padding:.75rem;background:var(--bg-secondary);border-radius:.5rem;margin-bottom:.5rem;cursor:grab;transition:all .2s ease;border:2px solid transparent}.punishment-item:hover{border-color:var(--primary);background:var(--bg-primary)}.punishment-item.dragging{opacity:.5;border-color:var(--primary);background:#3b82f61a}.punishment-item.drag-over{position:relative}.punishment-item.drag-over:before{content:"";position:absolute;top:-4px;left:0;right:0;height:4px;background:var(--primary);border-radius:2px;box-shadow:0 0 8px #3b82f699}.punishment-item:active{cursor:grabbing}.drag-handle{display:flex;align-items:center;justify-content:center;padding:.25rem;margin-right:.75rem;color:var(--text-secondary);cursor:grab}.drag-handle:hover{color:var(--primary)}.drag-handle:active{cursor:grabbing}.punishment-info{flex:1;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.punishment-level{font-weight:600;color:var(--text-primary)}.punishment-desc{color:var(--text-secondary)}.punishment-duration{font-size:.875rem;color:var(--text-secondary);font-style:italic}.punishments-list strong{display:block;margin-bottom:.5rem}.punishments-list ul{list-style:none;padding-left:0}.punishments-list li{padding:.25rem 0;color:var(--text-secondary)}.punishments-list li:before{content:"• ";color:var(--primary);font-weight:700;margin-right:.5rem}.tasks-list{display:flex;flex-direction:column;gap:1rem}.task-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem;box-shadow:var(--shadow)}.task-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.task-header h3{font-size:1.125rem}.task-actions{display:flex;gap:.5rem}.task-description{color:var(--text-secondary);margin-bottom:1rem}.task-meta{display:flex;gap:1rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:.375rem;color:var(--text-secondary);font-size:.875rem}.badge{padding:.25rem .75rem;background:var(--bg-primary);border-radius:9999px;font-size:.875rem;font-weight:500;color:var(--primary)}.task-assigned{font-size:.875rem;color:var(--text-secondary)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.info-banner{background:#dbeafe;color:#1e40af;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem}.children-life-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.life-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem;box-shadow:var(--shadow)}.life-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.life-header h3{font-size:1.25rem}.lives-display{display:flex;gap:.5rem}.heart-full{color:var(--danger)}.heart-empty{color:#cbd5e1}.warning-banner{display:flex;align-items:center;gap:.75rem;background:#fef3c7;color:#92400e;padding:1rem;border-radius:.5rem;margin-bottom:1rem}.active-punishment{background:#fee2e2;border-left:4px solid var(--danger);padding:1.5rem;border-radius:.5rem;margin-bottom:1rem}.punishment-actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.punishment-actions .btn{flex:1;min-width:200px}.life-actions-standalone{margin-bottom:1rem}.life-actions-standalone .btn{width:100%}.punishment-header{display:flex;align-items:center;gap:.5rem;color:var(--danger);margin-bottom:.5rem}.punishment-text{color:var(--text-primary);margin-bottom:1rem;font-weight:500}.life-actions{display:flex;flex-direction:column;gap:1rem}.punishment-selector h4{margin-bottom:.75rem;font-size:1rem}.punishment-options{display:flex;flex-direction:column;gap:.5rem}.available-punishments{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);font-size:.875rem}.available-punishments strong{display:block;margin-bottom:.5rem}.available-punishments ul{list-style:none;padding-left:0}.available-punishments li{padding:.25rem 0;color:var(--text-secondary)}.child-dashboard{background:var(--bg-secondary);border-radius:1rem;padding:2rem;box-shadow:var(--shadow)}.child-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border);flex-wrap:wrap;gap:1.5rem}.child-welcome h1{font-size:2rem;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.child-welcome p{color:var(--text-secondary)}.child-header-right{display:flex;align-items:center;gap:2rem}.child-stats-bar{display:flex;gap:2rem;align-items:center}.stat-item{display:flex;align-items:center;gap:.75rem}.stat-item .lives{display:flex;gap:.25rem}.stat-value{display:flex;flex-direction:column}.points{font-size:1.5rem;font-weight:700;color:var(--warning)}.stat-label{font-size:.875rem;color:var(--text-secondary)}.trophy-icon{color:var(--warning)}.active-punishments-container{margin-bottom:1rem}.active-punishments-title{color:var(--danger);margin-bottom:.75rem;font-size:1rem}.active-punishment{background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid var(--danger);border-radius:.75rem;padding:1rem;margin-bottom:.75rem}.clear-single-btn{margin-top:.75rem;width:100%}.btn-outline-success{background:transparent;border:2px solid var(--success);color:var(--success)}.btn-outline-success:hover{background:var(--success);color:#fff}.punishment-alert{background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid var(--danger);border-radius:1rem;padding:1rem;color:#991b1b;margin-bottom:1rem;box-shadow:0 4px 12px #dc262626;overflow:hidden}.punishment-alert-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid rgba(220,38,38,.2)}.punishment-alert-header svg{flex-shrink:0;margin-top:.25rem}.punishment-alert-header strong{display:block;font-size:1.25rem;margin-bottom:.5rem;color:#7f1d1d}.punishment-alert-header p{font-size:1rem;color:#991b1b;margin:0}.countdown-timer-child{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:#fff;border-radius:.75rem;margin-bottom:1.5rem;border:2px solid rgba(220,38,38,.2);box-shadow:0 2px 8px #dc26261a}.countdown-timer-child svg{flex-shrink:0;color:#dc2626}.countdown-details{display:flex;flex-direction:column;gap:.5rem;flex:1}.countdown-label{font-size:.875rem;color:#991b1b;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.countdown-value{font-size:2rem;font-weight:700;color:#dc2626;line-height:1}.punishment-time-grid .punishment-info-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.75rem;background:#ffffff80;text-align:center;color:#7f1d1d;font-size:.75rem;box-sizing:border-box;margin:0;border:none;box-shadow:none}.punishment-time-grid>*:nth-child(3){border-radius:0 0 0 .5rem}.punishment-time-grid>*:nth-child(4){border-radius:0 0 .5rem}.punishment-info-card span{font-weight:500;color:#991b1b}.punishment-info-card strong{font-weight:600;color:#7f1d1d}.warning-alert{display:flex;align-items:center;gap:1rem;background:#fef3c7;color:#92400e;padding:1.5rem;border-radius:.75rem;margin-bottom:2rem;border:2px solid var(--warning)}.warning-alert strong{display:block;font-size:1.125rem;margin-bottom:.25rem}.tasks-section{display:flex;flex-direction:column;gap:2rem}.task-group{display:flex;flex-direction:column;gap:1rem}.section-title{font-size:1.5rem;margin-bottom:.5rem}.tasks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.task-card-child{background:var(--bg-primary);border:2px solid var(--border);border-radius:1rem;padding:1.5rem;box-shadow:var(--shadow);transition:all .2s}.task-card-child:hover{box-shadow:var(--shadow-lg)}.task-card-child.completed{background:#f0fdf4;border-color:var(--success)}.task-card-child.failed{background:#fef2f2;border-color:#ef4444}.failed-task-wrapper{display:flex;flex-direction:column;gap:.5rem}.btn-dismiss{display:flex;align-items:center;justify-content:center;gap:.25rem;background:#f3f4f6;color:#6b7280;border:1px solid #d1d5db;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:all .2s}.btn-dismiss:hover{background:#e5e7eb;color:#374151}.task-timer-row{display:flex;justify-content:center;padding:.75rem 0 0;border-top:1px solid var(--border);margin-top:.5rem}.task-failed-status{display:flex;flex-direction:column;align-items:center;gap:.5rem}.task-failed-status .failed-icon{color:#ef4444}.task-failed-status .failed-text{color:#ef4444;font-weight:600;font-size:.875rem}.task-completed-status{display:flex;flex-direction:column;align-items:center;gap:.5rem}.task-completed-status .success-icon{color:#10b981}.task-completed-status .success-text{color:#10b981;font-weight:600;font-size:.875rem}.upcoming-tasks{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:1rem;padding:1.5rem;margin-top:1rem}.upcoming-subtitle{color:#6b7280;font-size:.875rem;margin-bottom:1rem}.task-content{display:flex;justify-content:space-between;gap:1.5rem;margin-bottom:1rem}.task-info{flex:1}.task-info h3{font-size:1.25rem;margin-bottom:.5rem}.task-desc{color:var(--text-secondary);font-size:.875rem;margin-bottom:.75rem}.task-date{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.875rem;margin-bottom:.5rem}.task-date svg{color:#667eea}.task-points{display:flex;align-items:center;gap:.5rem;color:var(--warning);font-weight:600;margin-bottom:.5rem}.task-notes{background:#dbeafe;padding:.75rem;border-radius:.5rem;font-size:.875rem;margin-top:.75rem}.task-timer{display:flex;flex-direction:column;align-items:stretch;gap:.5rem;width:100%}.task-timer.completed{color:var(--success)}.timer-display{display:flex;flex-direction:row;align-items:center;gap:.5rem;font-weight:600;white-space:nowrap}.time-text{font-size:.875rem;min-width:140px;text-align:center}.check-icon{color:var(--success)}.completed-text{color:var(--success);font-weight:600}.thermometer{display:flex;flex-direction:row;align-items:center;gap:0;width:100%;margin-top:.5rem}.thermometer-bg{flex:1;height:12px;background:#e2e8f0;border-radius:6px;position:relative;overflow:hidden}.thermometer-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:6px;position:absolute;left:0;top:0}.thermometer-bulb{width:32px;height:32px;border-radius:50%;transition:background-color .3s ease}.task-actions{display:flex;flex-direction:column;gap:1rem;padding-top:1rem;border-top:1px solid var(--border)}.note-input textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;font-family:inherit;font-size:.875rem;resize:vertical}.action-buttons{display:flex;gap:.75rem;flex-wrap:wrap}.completion-note{background:#f0fdf4;padding:.75rem;border-radius:.5rem;font-size:.875rem;margin-top:1rem;border:1px solid var(--success)}.empty-state-child{text-align:center;padding:4rem 2rem}.empty-state-child h2{font-size:2rem;margin-bottom:.5rem}.empty-state-child p{color:var(--text-secondary);font-size:1.125rem}.success-state{text-align:center;padding:3rem 2rem;background:linear-gradient(135deg,#d4fc79,#96e6a1);border-radius:1rem}.success-state h2{font-size:2rem;margin-bottom:.5rem;color:#065f46}.success-state p{font-size:1.125rem;color:#047857;margin-bottom:1rem}.points-earned{font-size:1.5rem;font-weight:700;color:#065f46}.error-state{text-align:center;padding:3rem 2rem;color:var(--text-secondary)}.avatar-upload{margin-top:.5rem}.avatar-upload-box{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;border:2px dashed var(--border);border-radius:.75rem;background:var(--bg-primary);cursor:pointer;transition:all .2s}.avatar-upload-box:hover{border-color:var(--primary);background:#3b82f60d}.avatar-upload-box svg{color:var(--text-secondary);margin-bottom:.5rem}.avatar-upload-box p{margin:.5rem 0 .25rem;font-weight:500;color:var(--text-primary)}.upload-hint{font-size:.875rem;color:var(--text-secondary)}.avatar-preview-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.avatar-preview{width:150px;height:150px;border-radius:50%;object-fit:cover;border:3px solid var(--primary);box-shadow:var(--shadow)}.avatar-remove{display:flex;align-items:center;gap:.5rem}.countdown-timer{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#3b82f61a;border-radius:.5rem;margin:.75rem 0;color:var(--primary);font-weight:500}.countdown-text{font-size:.875rem}.countdown-text strong{color:var(--primary);font-size:1rem}.punishment-duration{font-size:.75rem;color:var(--text-secondary);font-style:italic;margin-left:.5rem}.form-hint{font-size:.875rem;color:var(--warning);margin:-.5rem 0 1rem;padding:.5rem;background:#fbbf241a;border-radius:.375rem;display:flex;align-items:center;gap:.5rem}.pending-punishment-alert{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:1rem;padding:1.5rem;margin-bottom:1.5rem}.pending-punishments-section{margin-bottom:1.5rem}.pending-punishments-section .section-title{color:#b45309;margin-bottom:1rem}.pending-punishment-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-bottom:1rem}.pending-punishment-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:.75rem;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.punishment-card-header{display:flex;align-items:center;gap:.5rem;color:#b45309}.punishment-card-header .alert-icon{color:#f59e0b}.punishment-card-description{font-weight:500;color:#92400e;margin:0}.punishment-card-duration{display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:#b45309;margin:0}.pending-punishment-card .start-punishment-btn{margin-top:auto;width:100%}.pending-punishment-card.waiting{opacity:.7;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-color:#9ca3af}.pending-punishment-card.waiting .punishment-card-header{color:#6b7280}.pending-punishment-card.waiting .alert-icon{color:#9ca3af}.pending-punishment-card.waiting .punishment-card-description{color:#6b7280}.instance-badge{background:#0000001a;padding:.125rem .375rem;border-radius:.25rem;font-size:.75rem;margin-left:.5rem}.active-badge{background:var(--danger);color:#fff;padding:.125rem .5rem;border-radius:.25rem;font-size:.625rem;font-weight:700;margin-left:.5rem;animation:pulse-badge 1.5s ease-in-out infinite}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.7}}.pending-punishment-card.level-active{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:var(--danger);opacity:1}.pending-punishment-card.level-active .punishment-card-header,.pending-punishment-card.level-active .alert-icon{color:var(--danger)}.active-countdown{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#dc26261a;border-radius:.5rem;color:var(--danger);font-size:.875rem}.punishment-time-grid{display:flex;flex-wrap:wrap;gap:4px;box-sizing:border-box}.punishment-time-grid>*{box-sizing:border-box;width:calc(50% - 2px);margin:0;flex-shrink:0;flex-grow:0}.punishment-time-grid .countdown-timer-child{display:flex;flex-direction:column;align-items:center;justify-content:center;height:160px;background:#fff;border-radius:.5rem 0 0;padding:.75rem;margin:0;border:none;box-shadow:none;gap:.25rem}.punishment-time-grid .grid-clock-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;background:#fff;border-radius:0 .5rem 0 0;padding:.75rem;height:160px;margin:0;border:none;box-shadow:none}.end-time-label{font-size:.75rem;color:var(--danger);font-weight:600;text-transform:uppercase}.end-clock-face{position:relative;width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,#fff,#fef2f2);border:2px solid var(--danger);box-shadow:0 2px 8px #dc262633}.end-clock-number{position:absolute;font-size:.625rem;font-weight:600;color:var(--danger);transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none}.end-clock-hand{position:absolute;bottom:50%;left:50%;transform-origin:bottom center;border-radius:2px}.end-hour-hand{width:3px;height:18px;margin-left:-1.5px;background:#991b1b;z-index:3}.end-minute-hand{width:2px;height:24px;margin-left:-1px;background:#dc2626;z-index:4}.end-clock-center{position:absolute;top:50%;left:50%;width:6px;height:6px;background:var(--danger);border-radius:50%;transform:translate(-50%,-50%);z-index:6}.end-time-digital{font-size:.875rem;font-weight:700;color:var(--danger)}.waiting-status{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#0000000d;border-radius:.5rem;color:#6b7280;font-size:.875rem;margin-top:auto}.active-punishments-section{margin-bottom:1.5rem}.active-punishments-section .section-title{color:var(--danger);margin-bottom:1rem}.active-punishment-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.analog-clock{display:flex;flex-direction:column;align-items:center;gap:.5rem}.clock-face{position:relative;width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#fff,#f3f4f6);border:4px solid var(--primary);box-shadow:0 4px 12px #0000001a,inset 0 2px 4px #0000000d}.hour-number{position:absolute;font-size:.875rem;font-weight:600;color:var(--text-primary);transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none}.clock-hand{position:absolute;bottom:50%;left:50%;transform-origin:bottom center;background:var(--text-primary);border-radius:2px}.hour-hand{width:4px;height:30px;margin-left:-2px;background:#1f2937;z-index:3}.minute-hand{width:3px;height:42px;margin-left:-1.5px;background:#374151;z-index:4}.second-hand{width:2px;height:48px;margin-left:-1px;background:var(--danger);z-index:5}.clock-center{position:absolute;top:50%;left:50%;width:12px;height:12px;background:var(--primary);border-radius:50%;transform:translate(-50%,-50%);z-index:6;box-shadow:0 2px 4px #0003}.digital-time{font-size:.875rem;font-weight:600;color:var(--text-primary);background:var(--bg-secondary);padding:.25rem .75rem;border-radius:.5rem;border:1px solid var(--border)}.task-time-display{display:flex;flex-direction:row;align-items:center;gap:.5rem}.clock-container{display:flex;flex-direction:column;align-items:center;gap:.25rem}.task-clock{display:flex;justify-content:center;align-items:center}.digital-time{font-size:.75rem;font-weight:600;color:#3b82f6;background:#eff6ff;padding:.15rem .4rem;border-radius:4px;text-align:center}.task-clock-face{position:relative;width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#fff,#f9fafb);border:3px solid var(--primary);box-shadow:0 2px 8px #0000001a}.task-clock-number{position:absolute;font-size:.75rem;font-weight:600;color:var(--text-primary);transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none}.task-clock-hand{position:absolute;bottom:50%;left:50%;transform-origin:bottom center;background:var(--text-primary);border-radius:2px}.task-hour-hand{width:3px;height:20px;margin-left:-1.5px;background:#1f2937;z-index:3}.task-minute-hand{width:2px;height:28px;margin-left:-1px;background:#374151;z-index:4}.task-clock-center{position:absolute;top:50%;left:50%;width:8px;height:8px;background:var(--primary);border-radius:50%;transform:translate(-50%,-50%);z-index:6;box-shadow:0 1px 3px #0003}.punishment-info-text{font-size:.875rem;color:var(--text-secondary);font-style:italic;margin:0}.pending-punishment-alert .alert-content{display:flex;gap:1.5rem;align-items:flex-start;margin-bottom:1.5rem}.pending-punishment-alert .alert-icon{color:var(--warning);flex-shrink:0}.pending-punishment-alert .alert-text{flex:1}.pending-punishment-alert .alert-text strong{display:block;font-size:1.25rem;color:#92400e;margin-bottom:.75rem}.pending-punishment-alert .punishment-description{font-size:1.125rem;font-weight:600;color:#78350f;margin-bottom:.5rem}.pending-punishment-alert .punishment-duration-info{font-size:.875rem;color:#92400e;margin-bottom:.5rem}.pending-punishment-alert .punishment-info{font-size:.875rem;color:#78350f;font-style:italic}.start-punishment-btn{width:100%;font-size:1.125rem;padding:1rem 2rem;display:flex;align-items:center;justify-content:center;gap:.75rem;font-weight:600;transition:all .2s}.start-punishment-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #fbbf2466}.image-cropper-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.cropper-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cropper-container{position:relative;background:var(--bg-secondary);border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.cropper-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border)}.cropper-header h3{margin:0;font-size:1.25rem;font-weight:600}.cropper-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.crop-area{position:relative;width:100%;height:400px;background:#000}.cropper-controls{padding:1.5rem;background:var(--bg-primary);border-top:1px solid var(--border)}.zoom-controls{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.zoom-slider{flex:1;height:6px;border-radius:3px;background:var(--border);outline:none;-webkit-appearance:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary);cursor:pointer;box-shadow:0 2px 4px #0003}.zoom-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary);cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.zoom-label{text-align:center;font-size:.875rem;color:var(--text-secondary);font-weight:500}.cropper-actions{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid var(--border);background:var(--bg-primary)}.cropper-actions .btn{flex:1}@media (max-width: 768px){.crop-area{height:300px}.cropper-container{max-height:95vh}}@media (max-width: 768px){.app-main,.parent-dashboard,.child-dashboard{padding:1rem}.children-grid,.tasks-grid,.children-life-grid{grid-template-columns:1fr}.child-header{flex-direction:column;align-items:flex-start}.child-stats-bar{width:100%;justify-content:space-between}.form-row{grid-template-columns:1fr}.tabs{overflow-x:auto}.tab{white-space:nowrap}}.roster-manager{background:#f9fafb;border:2px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;margin-top:1rem}.roster-header h3{margin:0 0 .5rem;color:#1f2937;font-size:1.25rem}.roster-description{color:#6b7280;font-size:.875rem;margin:0 0 1.5rem}.roster-slots{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.roster-slot-card{display:flex;align-items:center;gap:1rem;background:#fff;padding:1rem;border-radius:.5rem;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.roster-slot-time{display:flex;align-items:center;gap:.5rem;color:#667eea}.roster-slot-child{display:flex;align-items:center;gap:.5rem;flex:1}.roster-slot-child label{font-size:.875rem;color:#6b7280;font-weight:500}.time-input{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;font-family:inherit}.time-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.child-select{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background:#fff;cursor:pointer;flex:1}.child-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-icon-danger{background:transparent;border:none;color:#ef4444;padding:.5rem;border-radius:.375rem;cursor:pointer;transition:all .2s}.btn-icon-danger:hover{background:#fee2e2;color:#dc2626}.roster-add-slot{display:flex;gap:.75rem;align-items:center;padding:1rem;background:#fff;border-radius:.5rem;border:2px dashed #d1d5db}.roster-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:#9ca3af;text-align:center}.roster-empty svg{margin-bottom:1rem;opacity:.5}.roster-empty p{margin:.25rem 0}.roster-empty .text-muted{font-size:.875rem;color:#d1d5db}.roster-days-section{margin-bottom:1.5rem;padding:1rem;background:#fff;border-radius:.5rem;border:1px solid #e5e7eb}.roster-days-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.75rem}.roster-days-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.day-checkbox-label{display:flex;align-items:center;gap:.5rem;padding:.5rem;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;transition:all .2s;background:#fff}.day-checkbox-label:hover{background:#f9fafb;border-color:#667eea}.day-checkbox-label input[type=checkbox]{cursor:pointer}.day-checkbox-label input[type=checkbox]:checked+span{font-weight:600;color:#667eea}.day-checkbox-label span{font-size:.875rem;color:#6b7280}.advanced-roster-manager{background:#f9fafb;border:2px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;margin-top:1rem}.roster-week-controls{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#fff;border-radius:.5rem;border:1px solid #e5e7eb}.roster-week-controls .form-group{flex:1;margin:0}.roster-week-controls label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.week-select{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background:#fff;cursor:pointer}.week-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.roster-day-tabs{display:flex;gap:.5rem;margin-bottom:1rem;padding:.5rem;background:#fff;border-radius:.5rem;border:1px solid #e5e7eb;overflow-x:auto}.day-tab{position:relative;padding:.75rem 1.25rem;border:1px solid #e5e7eb;border-radius:.375rem;background:#fff;color:#6b7280;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.day-tab:hover{background:#f9fafb;border-color:#667eea}.day-tab.active{background:#667eea;color:#fff;border-color:#667eea}.day-tab .slot-count{display:inline-block;margin-left:.5rem;padding:.125rem .5rem;background:#fff3;border-radius:9999px;font-size:.75rem;font-weight:600}.day-tab.active .slot-count{background:#ffffff4d}.roster-day-content{background:#fff;border-radius:.5rem;padding:1.5rem;border:1px solid #e5e7eb}.roster-day-content h4{margin:0 0 1rem;color:#1f2937;font-size:1.125rem}.roster-empty-day{text-align:center;padding:2rem;color:#9ca3af}.roster-empty-day p{margin:.25rem 0}.roster-empty-day .text-muted{font-size:.875rem;color:#d1d5db}.label-with-info{display:flex;align-items:center;gap:.5rem}.info-icon-btn{background:transparent;border:none;color:#667eea;padding:.25rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.info-icon-btn:hover{background:#667eea1a;color:#5568d3}.info-popup{position:relative;background:#fff;border:2px solid #667eea;border-radius:.5rem;padding:1.5rem;margin-top:1rem;box-shadow:0 4px 12px #667eea26;max-width:600px}.info-popup h4{margin:0 0 1rem;color:#667eea;font-size:1.125rem}.info-popup-close{position:absolute;top:.5rem;right:.5rem;background:transparent;border:none;font-size:1.5rem;color:#9ca3af;cursor:pointer;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.info-popup-close:hover{background:#f3f4f6;color:#4b5563}.info-section{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.info-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.info-section strong{display:block;color:#374151;margin-bottom:.25rem;font-size:.9375rem}.info-section p{margin:.25rem 0;color:#6b7280;font-size:.875rem}.info-example{font-style:italic;color:#9ca3af;font-size:.8125rem;margin-top:.5rem}.info-tip{background:#fef3c7;border:1px solid #fbbf24;border-radius:.375rem;padding:.75rem;margin-top:1rem}.info-tip strong{color:#92400e;display:block;margin-bottom:.25rem}.info-tip{color:#78350f;font-size:.875rem;line-height:1.5}.points-history-section{margin-top:2rem;padding-top:2rem;border-top:2px solid var(--border)}.points-history-section .header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.points-history-section h2{margin:0}.points-history-list{display:grid;gap:1rem}.child-points-history{background:#fff;border-radius:.75rem;padding:1rem;border:1px solid var(--border)}.child-points-history h4{margin:0 0 .75rem;color:var(--primary)}.history-items{display:flex;flex-direction:column;gap:.5rem}.history-item{display:flex;justify-content:space-between;padding:.5rem;background:#f9fafb;border-radius:.5rem}.history-month{color:#374151}.history-points{font-weight:600;color:var(--success)}.empty-history{color:#6b7280;text-align:center;padding:2rem}.history-item.current-month{background:#ecfdf5;border:1px solid var(--success)}.school-punchin-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:1rem;padding:1.5rem;margin-bottom:1.5rem;color:#fff}.school-punchin-card.checked-in{background:linear-gradient(135deg,#10b981,#059669)}.punchin-header{display:flex;align-items:center;gap:1rem}.punchin-header h3{margin:0;font-size:1.25rem}.punchin-header .school-icon{flex-shrink:0}.checkin-time{display:flex;align-items:center;gap:.25rem;opacity:.9;font-size:.875rem;margin-top:.25rem}.punchin-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:2rem;background:#fff3;border:2px dashed rgba(255,255,255,.5);border-radius:.75rem;color:#fff;font-size:1.25rem;font-weight:600;cursor:pointer;transition:all .2s}.punchin-button:hover{background:#ffffff4d;border-color:#fffc;transform:scale(1.02)}.punchin-form{background:#fff;border-radius:.75rem;padding:1.5rem;color:#374151}.punchin-form h3{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;color:#667eea}.punchin-form .form-group{margin-bottom:1rem}.punchin-form label{display:flex;align-items:center;gap:.5rem;font-weight:500;margin-bottom:.5rem;color:#4b5563}.punchin-form textarea,.punchin-form input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9375rem;resize:vertical}.punchin-form textarea:focus,.punchin-form input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.punchin-form .form-row{display:grid;grid-template-columns:1fr 2fr;gap:1rem}.punchin-form .form-actions{display:flex;gap:.75rem;margin-top:1.5rem}.punchin-notes{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.3)}.punchin-notes .note-item{display:flex;gap:.75rem;padding:.75rem;background:#ffffff26;border-radius:.5rem;margin-bottom:.5rem}.punchin-notes .note-item.highlight{background:#ffffff40;border:1px solid rgba(255,255,255,.4)}.punchin-notes .note-item strong{display:block;margin-bottom:.25rem}.punchin-notes .note-item p{margin:0;opacity:.9;font-size:.9375rem}.subjects-grid,.homework-subjects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem}.subject-checkbox,.homework-subject-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#f3f4f6;border:2px solid transparent;border-radius:.5rem;cursor:pointer;transition:all .2s}.subject-checkbox:hover,.homework-subject-checkbox:hover{background:#e5e7eb}.subject-checkbox.selected,.homework-subject-checkbox.selected{background:#dbeafe;border-color:var(--primary)}.subject-checkbox input,.homework-subject-checkbox input{display:none}.subject-icon{font-size:1.125rem}.subject-name{font-size:.875rem;font-weight:500}.form-hint{font-size:.8125rem;color:#6b7280;margin:0 0 .75rem}.homework-subjects-display{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.subject-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;background:#ffffff4d;border-radius:1rem;font-size:.875rem}.money-entries-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.btn-add-entry{display:flex;align-items:center;gap:.25rem;padding:.375rem .75rem;background:var(--primary);color:#fff;border:none;border-radius:.375rem;font-size:.8125rem;cursor:pointer;transition:background .2s}.btn-add-entry:hover{background:var(--primary-dark)}.money-entry-row{margin-bottom:.5rem}.money-entry-fields{display:grid;grid-template-columns:80px 1fr 130px auto;gap:.5rem;align-items:center}.money-amount{text-align:right}.money-date{font-size:.875rem}.btn-remove-entry{display:flex;align-items:center;justify-content:center;padding:.5rem;background:#fee2e2;color:#dc2626;border:none;border-radius:.375rem;cursor:pointer;transition:background .2s}.btn-remove-entry:hover{background:#fecaca}@media (max-width: 600px){.money-entry-fields{grid-template-columns:1fr 1fr;gap:.5rem}.money-amount{grid-column:1}.money-reason{grid-column:2}.money-date{grid-column:1 / 2}.btn-remove-entry{grid-column:2;justify-self:end}}.print-routine-btn{display:inline-flex;align-items:center;gap:.4rem;margin-top:.75rem;padding:.5rem 1.2rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:.5rem;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .2s}.print-routine-btn:hover{background:#ffffff59}.printable-routine-wrapper{min-height:100vh;background:#f0f2f5}.print-controls{position:sticky;top:0;z-index:100;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;box-shadow:0 2px 8px #00000026}.print-back-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1.2rem;border-radius:.5rem;cursor:pointer;font-size:.95rem;font-weight:600;transition:background .2s}.print-back-btn:hover{background:#ffffff59}.print-options{display:flex;align-items:center;gap:1.2rem}.print-options label{color:#fff;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.print-options input[type=date],.print-options select{padding:.4rem .6rem;border-radius:.4rem;border:1px solid rgba(255,255,255,.3);background:#ffffffe6;font-size:.9rem}.print-btn{background:#fff;color:#667eea;border:none;padding:.6rem 1.5rem;border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:700;transition:transform .15s,box-shadow .15s}.print-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003}.printable-content{max-width:800px;margin:2rem auto;padding:0 1rem}.print-page{background:#fff;padding:2.5rem;border-radius:.75rem;box-shadow:0 1px 6px #00000014;margin-bottom:2rem;page-break-after:always}.print-main-title{font-size:1.8rem;text-align:center;margin-bottom:.25rem;color:#1a1a2e}.print-date-range{text-align:center;color:#666;font-size:.95rem;margin-bottom:1.5rem}.print-section{margin-bottom:1.5rem}.print-section h2{font-size:1.3rem;color:#2d3748;border-bottom:2px solid #667eea;padding-bottom:.4rem;margin-bottom:1rem}.print-section h3{font-size:1.05rem;color:#4a5568;margin-bottom:.3rem}.routine-block{margin-bottom:1rem;padding-left:.5rem;border-left:3px solid #e2e8f0;padding:.4rem .8rem}.routine-block h3{margin-bottom:.3rem;font-size:1rem;color:#2d3748}.routine-block ul{margin:.2rem 0 .3rem 1.2rem;padding:0}.routine-block li{font-size:.9rem;color:#4a5568;line-height:1.5}.routine-note{font-size:.85rem;color:#718096;font-style:italic;margin:.2rem 0}.daily-tasks-list{margin:.3rem 0 .5rem 1.5rem;padding:0}.daily-tasks-list li{font-size:.95rem;color:#2d3748;line-height:1.6;font-weight:500}.day-cards-grid{display:flex;flex-direction:column;gap:1.5rem}.day-card{border:2px solid #e2e8f0;border-radius:1rem;overflow:hidden;background:#fff}.day-card--weekend{border-color:#667eea}.day-card__header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.7rem 1.2rem;text-align:center}.day-card--weekend .day-card__header{background:linear-gradient(135deg,#f093fb,#f5576c)}.day-card__date{font-size:1.1rem;font-weight:700;letter-spacing:.02em}.day-card__timeline{padding:.8rem 1rem .5rem;position:relative}.day-card__timeline:before{content:"";position:absolute;left:3.8rem;top:1.2rem;bottom:.8rem;width:2px;background:#e2e8f0}.tl-item{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.6rem;position:relative}.tl-time{width:2.5rem;font-size:.85rem;font-weight:800;color:#4a5568;text-align:right;padding-top:.15rem;flex-shrink:0}.tl-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;margin-top:.2rem;z-index:1;border:2px solid white;box-shadow:0 0 0 2px currentColor}.tl-item--green .tl-dot{background:#48bb78;color:#48bb78}.tl-item--blue .tl-dot{background:#4299e1;color:#4299e1}.tl-item--orange .tl-dot{background:#ed8936;color:#ed8936}.tl-item--purple .tl-dot{background:#9f7aea;color:#9f7aea}.tl-item--gray .tl-dot{background:#a0aec0;color:#a0aec0}.tl-content{flex:1;min-width:0}.tl-title{font-size:.95rem;font-weight:700;color:#2d3748;line-height:1.3}.tl-item--green .tl-title{color:#276749}.tl-item--blue .tl-title{color:#2b6cb0}.tl-item--orange .tl-title{color:#c05621}.tl-item--purple .tl-title{color:#6b46c1}.tl-item--gray .tl-title{color:#4a5568}.tl-details{font-size:.8rem;color:#718096;margin-top:.1rem}.tl-chores{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.35rem}.tl-chore-tag{display:inline-flex;align-items:center;gap:.3rem;background:#fff7ed;border:1px solid #fed7aa;border-radius:.4rem;padding:.2rem .5rem;font-size:.78rem}.tl-chore-tag--parent{background:#f0fdf4;border-color:#bbf7d0}.tl-chore-name{color:#78716c;font-weight:500}.tl-chore-person{font-weight:800;font-size:.82rem}.tl-person-columns{display:flex;gap:.4rem;flex-wrap:nowrap}.tl-person-col{flex:1;min-width:0;border:1px solid #e2e8f0;border-radius:.5rem;overflow:hidden}.tl-person-col__header{text-align:center;font-weight:800;font-size:.82rem;padding:.25rem .3rem;background:#f7fafc;border-bottom:1px solid #e2e8f0}.tl-person-col__task{font-size:.75rem;color:#4a5568;padding:.2rem .4rem;border-bottom:1px solid #f0f0f0;text-align:center;line-height:1.3}.tl-person-col__task:last-child{border-bottom:none}.day-card__daily{background:#f7fafc;border-top:1px solid #e2e8f0;padding:.5rem 1rem;font-size:.78rem;color:#4a5568;text-align:center}.print-page--cards{background:transparent;box-shadow:none;padding:0}.print-page--cards .print-main-title{background:#fff;padding:1rem;border-radius:.75rem;margin-bottom:1.5rem;box-shadow:0 1px 6px #00000014}.rotation-table{width:100%;border-collapse:collapse;font-size:.85rem;margin-top:.5rem}.rotation-table th{background:#667eea;color:#fff;padding:.5rem .4rem;text-align:center;font-weight:700;font-size:.8rem}.rotation-table td{padding:.45rem .4rem;text-align:center;border-bottom:1px solid #e2e8f0;font-size:.85rem}.rotation-table .date-cell{font-weight:600;color:#2d3748;white-space:nowrap}.rotation-table .day-cell{color:#718096;font-size:.8rem}.rotation-table .weekend-row{background:#f7f7fb}.rotation-table .weekend-row .date-cell,.rotation-table .weekend-row .day-cell{color:#667eea;font-weight:700}.person-eliseo{color:#d63031;font-weight:600}.person-zeia{color:#0984e3;font-weight:600}.person-eliza{color:#6c5ce7;font-weight:600}.person-maria{color:#00b894;font-weight:600}.person-josef{color:#e17055;font-weight:600}.rotation-legend{margin-top:1.5rem}.legend-columns{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.legend-columns h4{font-size:.95rem;color:#2d3748;margin-bottom:.4rem}.legend-columns p{font-size:.85rem;color:#4a5568;margin:.15rem 0}@media print{body *{visibility:hidden}.printable-routine-wrapper,.printable-routine-wrapper *{visibility:visible}.printable-routine-wrapper{position:absolute;top:0;left:0;width:100%;background:#fff}.no-print{display:none!important}.printable-content{max-width:100%;margin:0;padding:0}.print-page{box-shadow:none;border-radius:0;padding:1.5cm;margin:0;page-break-after:always}.print-page:last-child{page-break-after:auto}.print-page--cards{padding:.8cm 1cm}.day-card{border:2px solid #ccc!important;-webkit-print-color-adjust:exact;print-color-adjust:exact;page-break-inside:avoid}.day-card__header{background:#444!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.day-card--weekend .day-card__header{background:#9b59b6!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.tl-item--green .tl-dot{background:#48bb78!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.tl-item--blue .tl-dot{background:#4299e1!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.tl-item--orange .tl-dot{background:#ed8936!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.tl-item--purple .tl-dot{background:#9f7aea!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.tl-item--gray .tl-dot{background:#a0aec0!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.day-card__timeline:before{background:#ccc!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.tl-chore-tag{background:#fff7ed!important;border-color:#fed7aa!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.tl-chore-tag--parent{background:#f0fdf4!important;border-color:#bbf7d0!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.day-card__daily{background:#f7fafc!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.rotation-table th{background:#333!important;color:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.weekend-row{background:#f0f0f0!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.person-eliseo{color:#c0392b!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.person-zeia{color:#2980b9!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.person-eliza{color:#8e44ad!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.person-maria{color:#27ae60!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.person-josef{color:#d35400!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}@page{size:A4;margin:0}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #3b82f6;--primary-dark: #2563eb;--secondary: #64748b;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border: #e2e8f0;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary)}#root{min-height:100vh}
