:root{--primary-50:#f0f4fa;--primary-100:#dce5f2;--primary-200:#bdcee5;--primary-300:#93b1d5;--primary-400:#618cc1;--primary-500:#1a3460;--primary-600:#14284b;--primary-700:#0f1f3a;--primary-800:#0b162b;--primary-900:#070e1b;--accent-50:#fff5f4;--accent-100:#ffe7e4;--accent-200:#ffcfca;--accent-300:#ffa9a0;--accent-400:#ff7e70;--accent-500:#f35e50;--accent-600:#d3493c;--success-50:#ecfdf5;--success-100:#d1fae5;--success-400:#34d399;--success-500:#10b981;--success-600:#059669;--warning-50:#fffcf5;--warning-100:#fef0db;--warning-400:#f7cd8d;--warning-500:#f3bc6f;--warning-600:#d99f4f;--rose-50:#fff5f6;--rose-100:#fdeef0;--rose-400:#fca7b1;--rose-500:#f9c5cb;--rose-600:#dfa2aa;--danger-50:#fef2f2;--danger-400:#f87171;--danger-500:#ef4444;--neutral-50:#fafafa;--neutral-100:#f5f5f5;--neutral-200:#e5e5e5;--neutral-300:#d4d4d4;--neutral-400:#a3a3a3;--neutral-500:#737373;--neutral-600:#525252;--neutral-700:#404040;--neutral-800:#262626;--neutral-900:#171717;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--border-light:#e2e8f0;--border-medium:#cbd5e1;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--shadow-glow:0 0 20px #6366f126;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--font-family:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs:.75rem;--font-sm:.875rem;--font-base:1rem;--font-lg:1.125rem;--font-xl:1.25rem;--font-2xl:1.5rem;--font-3xl:1.875rem;--font-4xl:2.25rem;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);color:var(--text-primary);background:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;line-height:1.6;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}img,video{max-width:100%;height:auto;display:block}button{cursor:pointer;font-family:inherit;font-size:inherit;background:0 0;border:none}input,textarea,select{font-family:inherit;font-size:inherit}a{color:inherit;text-decoration:none}ul,ol{list-style:none}.container{width:100%;max-width:480px;padding:0 var(--space-4);margin:0 auto}.page-wrapper{background:var(--bg-secondary);flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex;position:relative}.page-content{flex:1;padding-bottom:5.5rem;overflow-y:auto}.card{background:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--space-4);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:transform var(--transition-fast), box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.card-glass{-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:var(--space-4);background:#ffffffb3;border:1px solid #ffffff4d}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-sm);transition:all var(--transition-fast);white-space:nowrap;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";pointer-events:none;background:linear-gradient(#ffffff26 0%,#fff0 100%);position:absolute;inset:0}.btn-primary{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));color:#fff;box-shadow:0 2px 8px #6366f159}.btn-primary:hover{background:linear-gradient(135deg, var(--primary-400), var(--primary-500));transform:translateY(-1px);box-shadow:0 4px 12px #6366f173}.btn-primary:active{transform:translateY(0);box-shadow:0 1px 4px #6366f14d}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--border-medium)}.btn-accent{background:linear-gradient(135deg, var(--accent-400), var(--accent-500));color:#fff;box-shadow:0 2px 8px #f9731659}.btn-accent:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f9731673}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon{border-radius:var(--radius-full);justify-content:center;align-items:center;width:2.5rem;height:2.5rem;padding:0;display:flex}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--font-base);border-radius:var(--radius-xl)}.btn-full{width:100%}.form-label{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-2);font-weight:600;display:block}.form-input{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--border-light);border-radius:var(--radius-lg);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-base);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none}.form-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #6366f11a}.form-input::placeholder{color:var(--text-tertiary)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23737373' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:2.5rem}.badge{align-items:center;gap:var(--space-1);padding:.125rem var(--space-2);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600;line-height:1.5;display:inline-flex}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-success{background:var(--success-100);color:var(--success-600)}.badge-warning{background:var(--warning-50);color:var(--warning-500)}.badge-accent{background:var(--accent-100);color:var(--accent-600)}.badge-danger{background:var(--danger-50);color:var(--danger-500)}.avatar{border-radius:var(--radius-full);width:2.5rem;height:2.5rem;font-weight:700;font-size:var(--font-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-sm{width:2rem;height:2rem;font-size:var(--font-xs)}.avatar-lg{width:3.5rem;height:3.5rem;font-size:var(--font-lg)}.avatar-xl{width:5rem;height:5rem;font-size:var(--font-2xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideInBottomSheet{0%{transform:translate(-50%,100%)}to{transform:translate(-50%)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes ripple{to{opacity:0;transform:scale(4)}}.animate-fade-in{animation:fadeIn var(--transition-base) forwards}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) forwards}.animate-slide-in-up{animation:slideInUp var(--transition-slow) forwards}.animate-scale-in{animation:scaleIn var(--transition-spring) forwards}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}.toast-container{top:var(--space-4);z-index:9999;gap:var(--space-2);flex-direction:column;width:calc(100% - 2rem);max-width:460px;display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-lg);align-items:center;gap:var(--space-3);animation:fadeInDown var(--transition-spring) forwards;border-left:3px solid var(--primary-500);display:flex}.toast-success{border-left-color:var(--success-500)}.toast-warning{border-left-color:var(--warning-500)}.toast-error{border-left-color:var(--danger-500)}.gradient-primary{background:linear-gradient(135deg, var(--primary-500) 0%, var(--primary-800) 100%)}.gradient-warm{background:linear-gradient(135deg, var(--accent-500) 0%, var(--warning-500) 100%)}.gradient-hero{background:linear-gradient(135deg, var(--primary-500) 0%, var(--accent-500) 100%)}.gradient-mesh{background:radial-gradient(at 40% 20%, #fac6cc59 0px, transparent 50%), radial-gradient(at 80% 0%, #f3bd6d40 0px, transparent 50%), radial-gradient(at 0% 50%, #fac6cc33 0px, transparent 50%), var(--bg-secondary)}.status-dot{border-radius:var(--radius-full);width:8px;height:8px;display:inline-block}.status-dot-online{background:var(--success-500);box-shadow:0 0 6px #10b98180}.status-dot-offline{background:var(--neutral-300)}.empty-state{padding:var(--space-12) var(--space-4);text-align:center;color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state svg{margin-bottom:var(--space-4);opacity:.4}.empty-state h3{color:var(--text-secondary);margin-bottom:var(--space-2)}.bottom-sheet-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0006;animation:.2s forwards fadeIn;position:fixed;inset:0}.bottom-sheet{background:var(--bg-primary);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;z-index:101;width:100%;max-width:480px;animation:slideInBottomSheet var(--transition-slow) forwards;max-height:85dvh;position:fixed;bottom:0;left:50%;overflow-y:auto;transform:translate(-50%,100%)}.bottom-sheet-handle{border-radius:var(--radius-full);background:var(--neutral-300);width:36px;height:4px;margin:var(--space-3) auto var(--space-4)}.skeleton{background:linear-gradient(90deg, var(--neutral-100) 25%, var(--neutral-200) 50%, var(--neutral-100) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}@media (width>=481px){.page-wrapper{border-left:1px solid var(--border-light);border-right:1px solid var(--border-light);box-shadow:var(--shadow-xl)}body{background:linear-gradient(135deg,#e0e7ff 0%,#f8fafc 50%,#ede9fe 100%)}}.report-schedule-timeline{border-top:1px dashed var(--border-light);margin-top:1.25rem;padding-top:1.25rem}.report-schedule-timeline h4{font-size:var(--font-sm);color:var(--primary-500);align-items:center;gap:.5rem;margin-bottom:1rem;font-weight:700;display:flex}.timeline-container{border-left:2px dashed var(--warning-200);flex-direction:column;gap:1rem;margin-left:.5rem;padding-left:1.5rem;display:flex;position:relative}.timeline-item{flex-direction:column;display:flex;position:relative}.timeline-dot{background-color:var(--accent-500);width:10px;height:10px;box-shadow:0 0 0 2px var(--warning-400);z-index:2;transition:transform var(--transition-fast) ease;border:2px solid #fff;border-radius:50%;position:absolute;top:8px;left:calc(-1.5rem - 6px)}.timeline-item:hover .timeline-dot{transform:scale(1.3)}.timeline-content-box{background-color:var(--warning-50);border-radius:var(--radius-lg);border-left:4px solid var(--warning-500);box-shadow:var(--shadow-xs);transition:transform var(--transition-fast) ease, box-shadow var(--transition-fast) ease;flex-direction:column;gap:.25rem;padding:.75rem 1rem;display:flex}.timeline-content-box:hover{box-shadow:var(--shadow-sm);transform:translate(4px)}.timeline-time{font-size:var(--font-xs);color:var(--accent-500);letter-spacing:.05em;font-weight:700}.timeline-activity{font-size:var(--font-sm);color:var(--primary-700);font-weight:600;line-height:1.4}@media (width<=480px){.report-schedule-timeline{margin-top:1rem;padding-top:1rem}.timeline-container{gap:.85rem;margin-left:.25rem;padding-left:1.25rem}.timeline-dot{width:8px;height:8px;top:6px;left:calc(-1.25rem - 5px)}.timeline-content-box{border-radius:var(--radius-md);padding:.5rem .75rem}.timeline-time{font-size:10px}.timeline-activity{font-size:12px}}.toast-icon{flex-shrink:0;align-items:center;display:flex}.toast-icon-success{color:var(--success-500)}.toast-icon-warning{color:var(--warning-500)}.toast-icon-error{color:var(--danger-500)}.toast-icon-info{color:var(--primary-500)}.toast-message{font-size:var(--font-sm);color:var(--text-primary);flex:1;font-weight:500}.toast-close{padding:var(--space-1);border-radius:var(--radius-full);color:var(--text-tertiary);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.toast-close:hover{background:var(--neutral-100);color:var(--text-primary)}.bottom-nav{-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-light);width:100%;max-width:480px;padding:var(--space-2) 0;padding-bottom:calc(var(--space-2) + env(safe-area-inset-bottom,0px));z-index:50;background:#ffffffeb;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-nav-item{padding:var(--space-1) var(--space-3);color:var(--text-tertiary);transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:2px;display:flex;position:relative}.bottom-nav-item.active{color:var(--primary-600)}.bottom-nav-item:hover{color:var(--primary-500)}.bottom-nav-icon-wrapper{justify-content:center;align-items:center;width:2rem;height:2rem;display:flex;position:relative}.bottom-nav-indicator{border-radius:var(--radius-full);background:var(--primary-500);width:4px;height:4px;animation:.2s forwards scaleIn;position:absolute;bottom:-4px;left:50%;transform:translate(-50%)}.bottom-nav-badge{background:var(--danger-500);color:#fff;border-radius:var(--radius-full);min-width:16px;height:16px;animation:scaleIn var(--transition-spring) forwards;justify-content:center;align-items:center;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-2px;right:-6px}.bottom-nav-label{font-size:10px;font-weight:600;line-height:1}.login-page{background:linear-gradient(135deg,#fafbfd 0%,#fff6f7 50%,#fffdf6 100%);justify-content:center;align-items:center;min-height:100dvh;display:flex;position:relative;overflow:hidden}.login-bg{pointer-events:none;position:absolute;inset:0;overflow:hidden}.login-bg-circle{filter:blur(60px);opacity:.25;border-radius:50%;position:absolute}.login-bg-circle-1{background:var(--primary-300);width:300px;height:300px;animation:6s ease-in-out infinite float;top:-80px;right:-60px}.login-bg-circle-2{background:var(--accent-300);width:200px;height:200px;animation:8s ease-in-out infinite reverse float;bottom:10%;left:-40px}.login-bg-circle-3{background:var(--rose-400);width:150px;height:150px;animation:7s ease-in-out 1s infinite float;top:40%;right:-30px}.login-content{z-index:1;width:100%;max-width:420px;padding:var(--space-6);position:relative}.login-brand{text-align:center;margin-bottom:var(--space-6)}.login-logo{margin-bottom:var(--space-4);justify-content:center;display:flex}.login-logo-icon{border-radius:var(--radius-2xl);background:linear-gradient(135deg, var(--primary-500) 0%, var(--accent-500) 100%);color:#fff;justify-content:center;align-items:center;width:72px;height:72px;animation:4s ease-in-out infinite float;display:flex;box-shadow:0 8px 32px #1a346026}.login-title{font-size:var(--font-3xl);color:var(--primary-500);letter-spacing:-.02em;margin-bottom:var(--space-2);font-weight:800}.login-subtitle{font-size:var(--font-sm);color:var(--text-secondary);max-width:280px;margin:0 auto;line-height:1.5}.login-features{gap:var(--space-2);margin-bottom:var(--space-8);justify-content:center;display:flex}.login-feature-pill{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);color:var(--primary-500);font-size:var(--font-xs);background:#1a34600d;border:1px solid #1a346014;font-weight:600;display:inline-flex}.login-section{-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-2xl);padding:var(--space-6);background:#ffffffbf;border:1px solid #1a346014;box-shadow:0 10px 30px #1a34600f}.login-section-header{margin-bottom:var(--space-4)}.login-back-btn{color:var(--text-secondary);font-size:var(--font-sm);margin-bottom:var(--space-2);transition:color var(--transition-fast);font-weight:500}.login-back-btn:hover{color:var(--primary-500)}.login-section-title{font-size:var(--font-lg);color:var(--primary-500);margin-bottom:var(--space-4);font-weight:700}.login-roles{gap:var(--space-3);flex-direction:column;display:flex}.login-role-card{align-items:center;gap:var(--space-4);padding:var(--space-4);border:1px solid var(--border-light);border-radius:var(--radius-xl);transition:all var(--transition-fast);text-align:left;background:#fff;display:flex}.login-role-card:hover{background:var(--bg-secondary);border-color:var(--primary-200);transform:translate(4px)}.login-role-icon{border-radius:var(--radius-xl);flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.login-role-info{flex:1}.login-role-info h3{font-size:var(--font-base);color:var(--text-primary);margin-bottom:2px;font-weight:700}.login-role-info p{font-size:var(--font-xs);color:var(--text-secondary);line-height:1.4}.login-role-arrow{color:var(--text-tertiary);transition:transform var(--transition-fast);flex-shrink:0}.login-role-card:hover .login-role-arrow{color:var(--text-secondary);transform:translate(4px)}.login-users{gap:var(--space-2);margin-bottom:var(--space-4);flex-direction:column;display:flex}.login-user-card{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1.5px solid var(--border-light);border-radius:var(--radius-lg);transition:all var(--transition-fast);text-align:left;background:#fff;display:flex}.login-user-card:hover{background:var(--bg-secondary)}.login-user-card.selected{border-color:var(--primary-400);background:#1a346033}.login-user-info{flex:1}.login-user-info h4{font-size:var(--font-sm);color:var(--text-primary);font-weight:600}.login-user-info p{font-size:var(--font-xs);color:var(--text-secondary)}.login-user-check{border-radius:var(--radius-full);border:2px solid var(--border-medium);width:22px;height:22px;color:var(--text-primary);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.login-user-check.checked{background:var(--primary-500);border-color:var(--primary-500);color:#fff;animation:.2s forwards scaleIn}.login-submit{opacity:.5;pointer-events:none;transition:all var(--transition-fast)}.login-submit.ready{opacity:1;pointer-events:all}.login-footer{text-align:center;font-size:var(--font-xs);color:var(--text-tertiary);margin-top:var(--space-8)}.login-form{gap:var(--space-4);flex-direction:column;display:flex}.login-form-group{gap:var(--space-2);flex-direction:column;display:flex}.login-form-label{align-items:center;gap:var(--space-2);font-size:var(--font-sm);color:var(--text-secondary);font-weight:600;display:flex}.login-form-input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--font-base);transition:all var(--transition-fast);background:#fff}.login-form-input::placeholder{color:var(--text-tertiary)}.login-form-input:focus{border-color:var(--primary-400);background:#fff;outline:none;box-shadow:0 0 0 3px #1a34601a}.login-password-wrapper{position:relative}.login-password-wrapper .login-form-input{padding-right:48px}.login-password-toggle{color:var(--text-tertiary);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-password-toggle:hover{color:var(--primary-500)}.login-error{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--danger-500);font-size:var(--font-sm);background:#ef44441a;border:1px solid #ef444433;display:flex}.login-loading{justify-content:center;align-items:center;gap:var(--space-2);display:flex}.admin-card{margin-top:var(--space-2);border:1px dashed var(--border-medium)}.teacher-header{position:relative;overflow:hidden}.teacher-header-bg{background:linear-gradient(135deg, var(--primary-500) 0%, var(--primary-600) 60%, var(--accent-500) 100%);border-radius:0 0 var(--radius-2xl) var(--radius-2xl);position:absolute;inset:0}.teacher-header-content{padding:var(--space-6) var(--space-4) var(--space-8);color:#fff;position:relative}.teacher-header-top{margin-bottom:var(--space-1);justify-content:space-between;align-items:flex-start;display:flex}.teacher-greeting{font-size:var(--font-sm);opacity:.8;font-weight:500}.teacher-name{font-size:var(--font-2xl);letter-spacing:-.02em;font-weight:800}.teacher-notif-btn{border-radius:var(--radius-full);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;width:40px;height:40px;transition:background var(--transition-fast);background:#ffffff26;justify-content:center;align-items:center;display:flex;position:relative}.teacher-notif-btn:hover{background:#ffffff40}.teacher-notif-dot{border-radius:var(--radius-full);background:var(--accent-400);border:2px solid var(--primary-600);width:8px;height:8px;position:absolute;top:8px;right:8px}.teacher-header-actions{align-items:center;gap:var(--space-2);display:flex}.teacher-logout-btn{border-radius:var(--radius-full);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;width:40px;height:40px;transition:background var(--transition-fast);background:#ffffff26;justify-content:center;align-items:center;display:flex}.teacher-logout-btn:hover{background:#ef444466}.teacher-date{font-size:var(--font-sm);opacity:.7;margin-bottom:var(--space-2)}.teacher-class-badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-full);font-size:var(--font-xs);background:#ffffff26;font-weight:600;display:inline-flex}.teacher-section{margin-top:var(--space-5)}.teacher-section-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.teacher-section-header h2{font-size:var(--font-base);align-items:center;gap:var(--space-2);color:var(--text-primary);font-weight:700;display:flex}.teacher-see-all{font-size:var(--font-xs);color:var(--primary-500);transition:color var(--transition-fast);align-items:center;gap:2px;font-weight:600;display:flex}.teacher-see-all:hover{color:var(--primary-600)}.teacher-quick-actions{gap:var(--space-3);margin-top:calc(-1 * var(--space-6));z-index:2;grid-template-columns:repeat(3,1fr);display:grid;position:relative}.teacher-quick-action{align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-2);background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);transition:all var(--transition-fast);border:1px solid var(--border-light);flex-direction:column;display:flex}.teacher-quick-action:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.teacher-quick-action:active{transform:translateY(0)}.teacher-quick-icon{border-radius:var(--radius-lg);justify-content:center;align-items:center;width:44px;height:44px;display:flex}.teacher-quick-label{font-size:var(--font-xs);color:var(--text-primary);font-weight:700}.teacher-quick-desc{color:var(--text-tertiary);font-size:10px;font-weight:500}.teacher-stats{gap:var(--space-3);grid-template-columns:repeat(3,1fr);display:grid}.teacher-stat-card{gap:var(--space-2);padding:var(--space-3);background:var(--bg-primary);border-radius:var(--radius-xl);border:1px solid var(--border-light);flex-direction:column;display:flex}.teacher-stat-icon{border-radius:var(--radius-lg);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.teacher-stat-value{font-size:var(--font-xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:800}.teacher-stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:600}.children-search-wrap{margin-bottom:var(--space-4);position:relative}.children-search-icon{color:var(--text-tertiary);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.children-search-input{border:1.5px solid var(--border-light);border-radius:var(--radius-full);background:var(--bg-primary);width:100%;font-size:var(--font-sm);color:var(--text-primary);box-sizing:border-box;padding:11px 40px;transition:border-color .2s,box-shadow .2s}.children-search-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100);outline:none}.children-search-input::placeholder{color:var(--text-tertiary)}.children-search-clear{background:var(--border-light);width:22px;height:22px;color:var(--text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .2s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.children-search-clear:hover{background:var(--border-medium)}.children-laporan-alert{color:#b45309;border-radius:var(--radius-full);background:#fef3c7;border:1px solid #fcd34d;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:600;display:flex}.children-group{margin-bottom:var(--space-4)}.children-group-label{margin-bottom:var(--space-2);border-bottom:1.5px solid var(--border-light);justify-content:space-between;align-items:center;padding:6px 4px;display:flex}.children-group-label span:first-child{color:var(--primary-600);text-transform:uppercase;letter-spacing:.06em;font-size:13px;font-weight:700}.children-group-count{color:var(--text-tertiary);font-size:11px;font-weight:500}.children-grid{gap:var(--space-3);grid-template-columns:repeat(2,1fr);display:grid}.child-grid-card{background:var(--bg-primary);border:1.5px solid var(--border-light);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-3) var(--space-3);cursor:pointer;text-align:center;flex-direction:column;align-items:center;gap:6px;transition:all .18s;display:flex;position:relative;overflow:hidden}.child-grid-card:hover{border-color:var(--primary-300);transform:translateY(-2px);box-shadow:0 4px 16px #1a34601f}.child-grid-card:active{transform:translateY(0)}.child-grid-avatar{border-radius:var(--radius-full);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:22px;font-weight:800;display:flex;overflow:hidden}.child-grid-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.child-grid-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:13px;font-weight:700;line-height:1.2;overflow:hidden}.child-grid-class{color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:11px;font-weight:500;overflow:hidden}.child-grid-status{flex-wrap:wrap;justify-content:center;align-items:center;gap:5px;margin-top:2px;display:flex}.child-status-ok{color:#16a34a;border-radius:var(--radius-full);background:#dcfce7;align-items:center;gap:3px;padding:2px 7px;font-size:10px;font-weight:600;display:inline-flex}.child-status-missing{color:#b45309;border-radius:var(--radius-full);background:#fef3c7;align-items:center;gap:3px;padding:2px 7px;font-size:10px;font-weight:600;display:inline-flex}.child-status-moment{color:var(--primary-600);background:var(--primary-100);border-radius:var(--radius-full);padding:2px 7px;font-size:10px;font-weight:600}.child-grid-draft{color:#fff;border-radius:var(--radius-full);background:#f59e0b;padding:2px 6px;font-size:10px;font-weight:700;position:absolute;top:8px;right:8px}.children-empty{text-align:center;color:var(--text-tertiary);padding:32px 16px;font-size:14px}.teacher-children-list{gap:var(--space-3);flex-direction:column;display:flex}.teacher-child-card{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-primary);border-radius:var(--radius-xl);border:1px solid var(--border-light);display:flex}.teacher-child-action{border-radius:var(--radius-full);width:32px;height:32px;color:var(--text-tertiary);background:var(--bg-secondary);justify-content:center;align-items:center;display:flex}@media (width<=480px){.teacher-header-content{padding:var(--space-5) var(--space-4) var(--space-6)}.teacher-name{font-size:var(--font-xl)}.teacher-quick-actions{margin-top:calc(-1 * var(--space-5));gap:8px}.teacher-quick-action{border-radius:var(--radius-lg);gap:var(--space-1);padding:12px 6px}.teacher-quick-icon{width:38px;height:38px}.teacher-quick-icon svg{width:18px;height:18px}.teacher-quick-label{text-align:center;font-size:11px;line-height:1.2}.teacher-quick-desc{font-size:9px}.teacher-stats{gap:8px}.teacher-stat-card{padding:10px var(--space-2);border-radius:var(--radius-lg)}.teacher-stat-icon{width:32px;height:32px}.teacher-stat-icon svg{width:16px;height:16px}.teacher-stat-value{font-size:16px}.teacher-stat-label{font-size:9px}.child-grid-avatar{width:46px;height:46px;font-size:18px}.child-grid-name{font-size:12px}.children-grid{gap:var(--space-2)}.draft-pending-banner{padding:12px}}.teacher-child-card{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-primary);border-radius:var(--radius-xl);border:1px solid var(--border-light);transition:all var(--transition-fast);display:flex}.teacher-child-card:hover{box-shadow:var(--shadow-md)}.teacher-child-info{flex:1}.teacher-child-info h3{font-size:var(--font-sm);color:var(--text-primary);margin-bottom:2px;font-weight:700}.teacher-child-info p{font-size:var(--font-xs);color:var(--text-tertiary);margin-bottom:var(--space-1)}.teacher-child-badges{gap:var(--space-1);flex-wrap:wrap;display:flex}.teacher-child-action{border-radius:var(--radius-full);width:32px;height:32px;color:var(--text-tertiary);background:var(--bg-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.teacher-child-action:hover{background:var(--primary-100);color:var(--primary-600)}.draft-pending-banner{border-radius:var(--radius-xl);padding:var(--space-4);margin-top:var(--space-1);background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1.5px solid #fcd34d}.draft-pending-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.draft-cloud-icon{color:#f59e0b;flex-shrink:0}.draft-pending-title{font-size:var(--font-sm);color:#92400e;font-weight:700}.draft-pending-children{gap:var(--space-2);flex-direction:column;display:flex}.draft-child-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);text-align:left;width:100%;transition:all var(--transition-fast);background:#fff;border:1px solid #fde68a;display:flex}.draft-child-btn:hover{background:#fef9c3;border-color:#fcd34d}.draft-child-avatar{border-radius:var(--radius-full);color:#fff;width:28px;height:28px;font-weight:700;font-size:var(--font-xs);flex-shrink:0;justify-content:center;align-items:center;display:flex}.draft-child-name{font-size:var(--font-sm);color:var(--text-primary);flex:1;font-weight:600}.draft-child-count{font-size:var(--font-xs);color:#fff;border-radius:var(--radius-full);text-align:center;background:#f59e0b;min-width:20px;padding:2px 8px;font-weight:700}.teacher-activity-list{gap:var(--space-2);flex-direction:column;display:flex}.teacher-activity-item{align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-light);display:flex}.teacher-activity-emoji{font-size:var(--font-xl);text-align:center;flex-shrink:0;width:36px}.teacher-activity-content{flex:1;min-width:0}.teacher-activity-title{font-size:var(--font-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.teacher-activity-time{font-size:var(--font-xs);color:var(--text-tertiary)}@media (width<=480px){.teacher-header-content{padding:var(--space-5) var(--space-4) var(--space-6)}.teacher-name{font-size:var(--font-xl)}.teacher-quick-actions{margin-top:calc(-1 * var(--space-5));gap:8px}.teacher-quick-action{border-radius:var(--radius-lg);gap:var(--space-1);padding:12px 6px}.teacher-quick-icon{width:38px;height:38px}.teacher-quick-icon svg{width:18px;height:18px}.teacher-quick-label{text-align:center;font-size:11px;line-height:1.2}.teacher-quick-desc{font-size:9px}.teacher-stats{gap:8px}.teacher-stat-card{padding:10px var(--space-2);border-radius:var(--radius-lg)}.teacher-stat-icon{width:32px;height:32px}.teacher-stat-icon svg{width:16px;height:16px}.teacher-stat-value{font-size:16px}.teacher-stat-label{font-size:9px}.teacher-child-card{padding:var(--space-3) 12px;border-radius:var(--radius-lg)}.avatar.avatar-lg{width:48px;height:48px;font-size:18px}.teacher-child-info h3{font-size:var(--font-sm)}.teacher-child-info p{font-size:11px}.draft-pending-banner{padding:12px}}@media (width<=380px){.teacher-quick-actions{gap:6px}.teacher-quick-action{padding:10px 4px}.teacher-quick-label{font-size:10px}.teacher-quick-desc{display:none}.teacher-stats{gap:6px}.teacher-stat-card{padding:8px 4px}.teacher-stat-value{font-size:14px}}.moments-header{align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-primary);border-bottom:1px solid var(--border-light);z-index:10;display:flex;position:sticky;top:0}.moments-header h1{font-size:var(--font-lg);flex:1;font-weight:700}.moments-timeline{gap:var(--space-4);padding:var(--space-4) 0;flex-direction:column;display:flex}.moment-card{background:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--space-4);border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.moment-card-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.moment-card-meta{flex:1}.moment-card-meta h3{font-size:var(--font-sm);font-weight:700}.moment-card-time{align-items:center;gap:var(--space-2);font-size:var(--font-xs);color:var(--text-tertiary);margin-top:2px;display:flex}.moment-card-media{gap:var(--space-2);margin-bottom:var(--space-3);border-radius:var(--radius-lg);grid-template-columns:repeat(auto-fill,minmax(120px,1fr));display:grid;overflow:hidden}.moment-media-item{object-fit:cover;border-radius:var(--radius-lg);width:100%;height:160px}.moment-card-title{font-size:var(--font-sm);color:var(--text-primary);margin-bottom:var(--space-1);font-weight:700}.moment-card-desc{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.6}.moment-card-footer{align-items:center;gap:var(--space-4);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-light);display:flex}.moment-like-btn{align-items:center;gap:var(--space-1);color:var(--text-tertiary);font-size:var(--font-sm);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);transition:all var(--transition-fast);font-weight:600;display:flex}.moment-like-btn:hover{background:var(--danger-50);color:var(--danger-500)}.moment-form{padding:0 var(--space-5) var(--space-6)}.moment-form-header{margin-bottom:var(--space-5);justify-content:space-between;align-items:center;display:flex}.moment-form-header h2{font-size:var(--font-lg);align-items:center;gap:var(--space-2);font-weight:700;display:flex}.moment-child-chips{gap:var(--space-2);flex-wrap:wrap;display:flex}.moment-child-chip{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);border:1.5px solid var(--border-light);font-size:var(--font-sm);background:var(--bg-primary);transition:all var(--transition-fast);color:var(--text-secondary);font-weight:600;display:flex}.moment-child-chip:hover{border-color:var(--border-medium)}.moment-child-chip.selected{border-color:var(--chip-color);background:color-mix(in srgb, var(--chip-color) 8%, white);color:var(--text-primary)}.moment-chip-avatar{border-radius:var(--radius-full);color:#fff;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;font-weight:700;display:flex}.moment-type-grid{gap:var(--space-2);grid-template-columns:repeat(2,1fr);display:grid}.moment-type-chip{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);border:1.5px solid var(--border-light);font-size:var(--font-sm);background:var(--bg-primary);transition:all var(--transition-fast);color:var(--text-secondary);font-weight:500;display:flex}.moment-type-chip:hover{border-color:var(--primary-300)}.moment-type-chip.selected{border-color:var(--primary-500);background:var(--primary-50);color:var(--primary-700);font-weight:600}.moment-media-upload{gap:var(--space-2);flex-wrap:wrap;display:flex}.moment-media-preview{border-radius:var(--radius-lg);width:80px;height:80px;position:relative;overflow:hidden}.moment-media-preview img,.moment-media-preview video{object-fit:cover;width:100%;height:100%}.moment-media-remove{border-radius:var(--radius-full);color:#fff;background:#0009;justify-content:center;align-items:center;width:20px;height:20px;display:flex;position:absolute;top:4px;right:4px}.moment-media-add{border-radius:var(--radius-lg);border:2px dashed var(--border-medium);justify-content:center;align-items:center;gap:var(--space-1);width:80px;height:80px;color:var(--text-tertiary);font-size:var(--font-xs);transition:all var(--transition-fast);flex-direction:column;font-weight:600;display:flex}.moment-media-add:hover{border-color:var(--primary-400);color:var(--primary-500);background:var(--primary-50)}@media (width<=480px){.moments-header{padding:12px}.moments-header h1{font-size:16px}.moments-header .btn{padding:8px 12px;font-size:12px}.moment-form{padding:0 var(--space-4) var(--space-4)}.moment-form-header{margin-bottom:var(--space-4)}.moment-form-header h2{font-size:16px}.moment-child-chips{gap:6px}.moment-child-chip{padding:6px 10px;font-size:12px}.moment-type-grid{grid-template-columns:repeat(2,1fr);gap:6px}.moment-type-chip{gap:6px;padding:8px;font-size:12px}.moment-media-upload{gap:8px}.moment-media-preview,.moment-media-add{width:68px;height:68px}.moment-media-add span{font-size:9px}}@media (width<=360px){.moment-type-grid{grid-template-columns:1fr}}.reports-page{background-color:var(--bg-secondary);min-height:100dvh;padding-bottom:5.5rem}.reports-header{padding:var(--space-3) var(--space-4);background:var(--bg-primary);border-bottom:1px solid var(--border-light);z-index:10;align-items:center;gap:var(--space-2);display:flex;position:sticky;top:0}.reports-header .text-xl{font-size:var(--font-lg);color:var(--text-primary);font-weight:700}.reports-header .text-sm{font-size:var(--font-xs);color:var(--text-secondary)}.reports-content{padding:var(--space-4);gap:var(--space-4);flex-direction:column;display:flex}.stats-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm)}.stats-info{align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-2);display:flex}.stats-value{font-size:var(--text-2xl);color:var(--text-primary);font-weight:700}.stats-label{font-size:var(--text-sm);color:var(--text-secondary)}.progress-bar{background-color:var(--border-light);border-radius:var(--radius-full);height:8px;overflow:hidden}.progress-fill{background-color:var(--primary-500);border-radius:var(--radius-full);height:100%;transition:width .5s ease-out}.section-title{font-size:var(--text-base);color:var(--text-primary);margin-bottom:var(--space-2);font-weight:600}.children-grid{gap:var(--space-3);flex-direction:column;display:flex}.child-report-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-3);align-items:center;gap:var(--space-3);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex}.child-report-card:active{transform:scale(.98)}.child-avatar{border-radius:var(--radius-full);color:#fff;width:48px;height:48px;font-weight:600;font-size:var(--text-lg);justify-content:center;align-items:center;display:flex}.child-info{flex:1}.child-name{color:var(--text-primary);margin-bottom:4px;font-weight:600}.status-badge{font-size:var(--text-xs);border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-weight:500;display:inline-flex}.status-badge.success{background-color:var(--success-50);color:var(--success-600)}.status-badge.pending{background-color:var(--warning-50);color:var(--warning-600)}.form-section{background:var(--bg-secondary);padding:var(--space-4);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.form-section.row{gap:var(--space-4);display:flex}.flex-1{flex:1}.form-section-title{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-3);font-weight:600;display:flex}.form-group{margin-bottom:var(--space-3)}.form-group:last-child{margin-bottom:0}.form-group label{font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-1);display:block}.form-select,.form-textarea{width:100%;padding:var(--space-3);border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-primary);font-family:inherit;font-size:var(--text-sm);color:var(--text-primary)}.form-select:focus,.form-textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 2px var(--primary-100);outline:none}.form-textarea{resize:vertical;min-height:80px}.counter-input{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);align-items:center;display:flex;overflow:hidden}.counter-input button{padding:var(--space-2);font-size:var(--text-lg);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex:1}.counter-input button:active{background:var(--bg-secondary)}.counter-input span{text-align:center;color:var(--text-primary);flex:2;font-weight:600}.sheet-header{padding:0 var(--space-4) var(--space-3);justify-content:space-between;align-items:flex-start;display:flex}.sheet-title{font-size:var(--font-lg);color:var(--text-primary);font-weight:700}.sheet-subtitle{font-size:var(--font-sm);color:var(--text-secondary);margin-top:2px}.sheet-content{padding:0 var(--space-4);max-height:calc(85dvh - 140px);overflow-y:auto}.sheet-footer{padding:var(--space-4);border-top:1px solid var(--border-light);background:var(--bg-primary);position:sticky;bottom:0}.btn-icon.primary{background:var(--primary-100);color:var(--primary-600)}.btn-icon.text-secondary{color:var(--text-secondary)}.btn-icon.btn-edit{background:var(--primary-50);color:var(--primary-600);border-radius:var(--radius-md)}.btn-icon.btn-danger{background:var(--danger-50);color:var(--danger-500);border-radius:var(--radius-md)}.font-bold{font-weight:700}.text-secondary{color:var(--text-secondary)}@media (width<=480px){.reports-header,.stats-card{padding:12px}.child-report-card{gap:10px;padding:10px}.child-avatar{width:40px;height:40px;font-size:14px}.child-name{margin-bottom:2px;font-size:14px}.sheet-header{padding:0 var(--space-3) var(--space-2)}.sheet-title{font-size:16px}.sheet-content{padding:0 var(--space-3);max-height:calc(85dvh - 120px)}.form-section{margin-bottom:12px;padding:12px}.form-section.row{gap:8px}.form-section-title{margin-bottom:8px;font-size:12px}.form-group label{margin-bottom:2px;font-size:10px}.form-select,.form-textarea{padding:8px;font-size:13px}.counter-input button{padding:4px;font-size:16px}.counter-input span{font-size:13px}.sheet-footer{padding:12px}}@media (width<=400px){.form-section.row{flex-direction:column;gap:12px}}.schedule-editor{gap:var(--space-2);flex-direction:column;display:flex}.schedule-row{align-items:center;gap:var(--space-2);margin-bottom:4px;display:flex}.schedule-time-input{width:110px;padding:var(--space-2);border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-primary);font-size:var(--text-sm);color:var(--text-primary)}.schedule-activity-input{padding:var(--space-2);border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-primary);font-size:var(--text-sm);color:var(--text-primary);flex:1}.schedule-time-input:focus,.schedule-activity-input:focus{border-color:var(--primary-500);outline:none}.btn-remove-schedule{background:var(--danger-50);color:var(--danger-500);border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;width:32px;height:32px;transition:background .2s;display:flex}.btn-remove-schedule:hover{background:var(--danger-100)}@media (width<=480px){.schedule-time-input{width:90px;padding:6px;font-size:12px}.schedule-activity-input{padding:6px;font-size:12px}.btn-remove-schedule{width:28px;height:28px}}.child-dashboard{background:#f8fafc;min-height:100vh;padding-bottom:80px}.child-dashboard-error{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:80vh;display:flex}.child-dashboard-header{color:#fff;padding:20px;position:relative}.back-button{cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:absolute;top:20px;left:20px}.child-header-info{align-items:center;gap:16px;padding-left:50px;display:flex}.child-avatar-large{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:24px;font-weight:700;display:flex;overflow:hidden}.child-avatar-large img{object-fit:cover;width:100%;height:100%}.child-header-details h1{margin:0;font-size:20px;font-weight:700}.child-header-details p{opacity:.8;margin:4px 0 0;font-size:14px}.parent-info-card{background:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin:12px 16px;padding:12px 20px;display:flex;box-shadow:0 1px 3px #0000001a}.parent-info{align-items:center;gap:12px;display:flex}.parent-avatar-small{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-weight:600;display:flex;overflow:hidden}.parent-avatar-small img{object-fit:cover;width:100%;height:100%}.parent-label{color:#64748b;margin:0;font-size:12px}.parent-name{color:#1e293b;margin:2px 0 0;font-size:14px;font-weight:600}.action-buttons{gap:12px;margin-bottom:16px;padding:0 16px;display:flex}.action-btn{cursor:pointer;border:none;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:12px 8px;font-size:12px;font-weight:500;transition:all .2s;display:flex}.action-btn.primary{background:var(--primary-100);color:var(--primary-500)}.action-btn.secondary{color:#3b82f6;background:#dbeafe}.action-btn.draft{color:#d97706;background:#fef3c7}.action-btn.publish{color:#16a34a;background:#dcfce7}.action-btn:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.gallery-section{padding:0 16px}.gallery-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.gallery-header h2{color:#1e293b;margin:0;font-size:16px;font-weight:600}.gallery-count{color:#64748b;font-size:13px}.gallery-empty{text-align:center;background:#fff;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:48px 20px;display:flex}.gallery-empty p{color:#64748b;margin:12px 0 0;font-size:16px;font-weight:500}.gallery-empty-sub{color:#94a3b8!important;font-size:13px!important}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.gallery-item{background:#fff;border-radius:12px;position:relative;overflow:hidden;box-shadow:0 1px 3px #0000001a}.gallery-image-container,.gallery-video-container{aspect-ratio:4/3;position:relative;overflow:hidden}.gallery-image-container img,.gallery-video-container video{object-fit:cover;width:100%;height:100%}.video-indicator{color:#fff;background:#00000080;border-radius:6px;padding:4px 6px;position:absolute;top:8px;right:8px}.gallery-item-info{padding:10px}.gallery-caption{color:#1e293b;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 6px;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.gallery-meta{justify-content:space-between;align-items:center;display:flex}.gallery-time{color:#94a3b8;align-items:center;gap:4px;font-size:11px;display:flex}.gallery-actions{align-items:center;gap:8px;display:flex}.gallery-likes{color:#f43f5e;align-items:center;gap:4px;font-size:12px;display:flex}.gallery-action-btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.gallery-action-btn.publish{color:#16a34a;background:#dcfce7}.gallery-action-btn.delete{color:#dc2626;background:#fee2e2}.gallery-action-btn.edit{color:#475569;background:#f1f5f9;width:auto;padding:0 8px;font-size:11px}.draft-badge{color:#fff;background:#00000080;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:11px;display:flex;position:absolute;top:8px;left:8px}.upload-modal-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.upload-modal{background:#fff;border-radius:16px;width:100%;max-width:400px;max-height:80vh;overflow-y:auto}.upload-modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.upload-modal-header h3{margin:0;font-size:18px;font-weight:600}.close-btn{cursor:pointer;color:#64748b;background:0 0;border:none}.upload-modal-content{padding:20px}.upload-area{text-align:center;cursor:pointer;border:2px dashed #d1d5db;border-radius:12px;padding:40px 20px;transition:all .2s}.upload-area:hover{border-color:var(--primary-500);background:var(--primary-50)}.upload-area p{color:#374151;margin:12px 0 0;font-size:14px}.upload-hint{color:#94a3b8!important;font-size:12px!important}.upload-preview{text-align:center}.upload-preview img,.upload-preview video{border-radius:8px;max-width:100%;max-height:200px}.change-file-btn{cursor:pointer;background:#f1f5f9;border:none;border-radius:8px;margin-top:12px;padding:8px 16px;font-size:13px}.upload-form{margin-top:16px}.upload-form label{margin-bottom:6px;font-size:14px;font-weight:500;display:block}.upload-form textarea{resize:none;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px;font-size:14px}.upload-modal-actions{border-top:1px solid #e2e8f0;gap:12px;padding:16px 20px;display:flex}.upload-modal-actions .btn{flex:1;justify-content:center;align-items:center;gap:8px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.teacher-child-tabs{background:#fff;border-radius:12px;gap:4px;margin:12px 16px;padding:6px;display:flex;box-shadow:0 1px 3px #0000000d}.child-tab-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px 6px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.child-tab-btn.active{color:#1e293b;background:#f1f5f9}.tab-actions-header{justify-content:flex-end;margin-bottom:16px;padding:0 16px;display:flex}.tab-actions-header .btn{background:linear-gradient(135deg, var(--primary-500), var(--accent-500));color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:600;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 6px -1px #1a346033}.tab-actions-header .btn:hover{transform:translateY(-1px);box-shadow:0 10px 15px -3px #1a34604d}.child-moments-timeline{flex-direction:column;gap:16px;padding:0 16px;display:flex}.child-moment-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:16px;box-shadow:0 1px 3px #0000000d}.child-moment-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.child-moment-card-header .badge{letter-spacing:.025em;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600}.child-moment-card-time{color:#94a3b8;font-size:12px}.child-moment-card-title{color:#1e293b;margin:0 0 6px;font-size:16px;font-weight:700}.child-moment-card-desc{color:#475569;margin:0 0 12px;font-size:14px;line-height:1.5}.child-moment-media-previews{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px;display:grid}.child-moment-media-item{aspect-ratio:4/3;background:#f8fafc;border-radius:10px;overflow:hidden}.child-moment-media-item img,.child-moment-media-item video{object-fit:cover;width:100%;height:100%}.child-moment-card-footer{border-top:1px solid #f8fafc;align-items:center;padding-top:12px;display:flex}.child-moment-likes{color:#f43f5e;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.child-reports-list{flex-direction:column;gap:16px;padding:0 16px;display:flex}.child-report-card-detail{background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:16px;box-shadow:0 1px 3px #0000000d}.child-report-card-header{border-bottom:1px solid #f8fafc;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;display:flex}.child-report-card-header h3{color:#1e293b;margin:0;font-size:15px;font-weight:700}.child-report-card-date{color:#64748b;font-size:12px;font-weight:500}.report-grid-items{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px;display:grid}.report-grid-item{background:#f8fafc;border-radius:10px;flex-direction:column;gap:2px;padding:8px 12px;display:flex}.report-grid-item .label{color:#64748b;text-transform:uppercase;font-size:11px;font-weight:600}.report-grid-item .value{color:#1e293b;font-size:13px;font-weight:600}.child-report-section{margin-top:12px}.child-report-section h4{color:#64748b;margin:0 0 4px;font-size:12px;font-weight:600}.child-report-section p{color:#334155;background:#f8fafc;border-radius:10px;margin:0;padding:8px 12px;font-size:13px;line-height:1.5}@media (width<=480px){.child-dashboard-header{padding:16px}.back-button{width:36px;height:36px;top:16px;left:12px}.child-header-info{gap:12px;padding-left:36px}.child-avatar-large{width:50px;height:50px;font-size:20px}.child-header-details h1{font-size:17px}.child-header-details p{font-size:12px}.parent-info-card{border-radius:10px;margin:8px 12px;padding:10px 14px}.parent-avatar-small{width:32px;height:32px}.parent-name{font-size:13px}.teacher-child-tabs{margin:8px 12px;padding:4px}.child-tab-btn{gap:4px;padding:8px 4px;font-size:11px}.child-tab-btn svg{width:14px;height:14px}.action-buttons{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px;padding:0 12px;display:grid}.action-btn{border-radius:10px;flex-direction:row;flex:none;justify-content:center;align-items:center;gap:6px;width:100%;padding:10px 6px;font-size:11px}.action-btn svg{width:16px;height:16px}.gallery-section{padding:0 12px}.gallery-grid{gap:8px}.gallery-meta{flex-direction:column;align-items:stretch;gap:8px}.gallery-time{font-size:10px}.gallery-actions{justify-content:flex-end;gap:6px;width:100%}.gallery-action-btn{border-radius:6px;flex:1;width:auto;height:26px;font-size:11px}.gallery-action-btn.edit{padding:0 6px;font-size:10px}.child-moments-timeline{gap:12px;padding:0 12px}.child-moment-card{border-radius:12px;padding:12px}.child-moment-card-title{font-size:14px}.child-moment-card-desc{margin-bottom:8px;font-size:12px}.child-moment-media-item{border-radius:8px}.child-reports-list{gap:12px;padding:0 12px}.child-report-card-detail{border-radius:12px;padding:12px}.report-grid-items{gap:8px;margin-bottom:12px}.report-grid-item{border-radius:8px;padding:6px 10px}.report-grid-item .label{font-size:9px}.report-grid-item .value{font-size:12px}.child-report-section p{border-radius:8px;padding:6px 10px;font-size:12px}}.child-dashboard{transition:background-color var(--transition-slow) ease}.child-dashboard.tab-active-gallery{background-color:#f4f7fc}.child-dashboard.tab-active-moments{background-color:#fff6f7}.child-dashboard.tab-active-reports{background-color:#fffdf5}.child-tab-btn{transition:all var(--transition-fast) ease}.tab-active-gallery .child-tab-btn.active{box-shadow:0 4px 12px #1a346014;background:var(--primary-100)!important;color:var(--primary-500)!important}.tab-active-moments .child-tab-btn.active{box-shadow:0 4px 12px #f9c5cb26;background:var(--rose-100)!important;color:var(--rose-600)!important}.tab-active-reports .child-tab-btn.active{box-shadow:0 4px 12px #f3bc6f26;background:var(--warning-100)!important;color:var(--warning-600)!important}.messages-page{background-color:var(--bg-secondary);min-height:100dvh}.messages-header{padding:var(--space-4);background:var(--bg-primary);border-bottom:1px solid var(--border-light);z-index:10;position:sticky;top:0}.messages-header-top{align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.messages-header-top h1{font-size:var(--font-lg);font-weight:700}.search-bar{position:relative}.search-icon{left:var(--space-3);color:var(--text-tertiary);position:absolute;top:50%;transform:translateY(-50%)}.search-input{width:100%;padding:var(--space-3);padding-left:calc(var(--space-4) + 24px);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-full);font-size:var(--text-sm);transition:all .2s}.search-input:focus{background:var(--bg-primary);border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100);outline:none}.messages-list{background:var(--bg-primary)}.chat-item{padding:var(--space-4);gap:var(--space-3);border-bottom:1px solid var(--border-light);cursor:pointer;transition:background-color .2s;display:flex}.chat-item:active{background-color:var(--bg-secondary)}.chat-avatar{border-radius:var(--radius-full);color:#fff;width:56px;height:56px;font-weight:600;font-size:var(--text-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.chat-info{flex:1;min-width:0}.chat-info-top{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.chat-name{color:var(--text-primary);font-weight:600;font-size:var(--text-base);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.chat-time{font-size:var(--text-xs);color:var(--text-secondary)}.chat-info-bottom{justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.chat-last-msg{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.chat-last-msg.unread{color:var(--text-primary);font-weight:600}.unread-badge{background:var(--primary-500);color:#fff;border-radius:var(--radius-full);text-align:center;min-width:20px;padding:2px 6px;font-size:11px;font-weight:700}.chat-child-name{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:4px}.empty-state{padding:var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-icon-wrapper{background:var(--bg-secondary);border-radius:var(--radius-full);width:80px;height:80px;margin-bottom:var(--space-4);justify-content:center;align-items:center;display:flex}.empty-text{color:var(--text-secondary);font-weight:500}.chat-detail-page{background-color:var(--bg-secondary);flex-direction:column;height:100dvh;display:flex}.chat-header{padding:var(--space-3) var(--space-4);background:var(--bg-primary);border-bottom:1px solid var(--border-light);align-items:center;gap:var(--space-3);z-index:10;display:flex}.chat-header-info{align-items:center;gap:var(--space-3);flex:1;display:flex}.chat-avatar.small{width:40px;height:40px;font-size:var(--text-sm)}.chat-name{font-weight:600;font-size:var(--text-base);color:var(--text-primary)}.chat-subtitle{font-size:var(--text-xs);color:var(--text-secondary)}.chat-messages{padding:var(--space-4);gap:var(--space-2);flex-direction:column;flex:1;display:flex;overflow-y:auto}.message-group{flex-direction:column;display:flex}.message-date{background:var(--border-light);color:var(--text-secondary);font-size:var(--text-xs);border-radius:var(--radius-full);margin:var(--space-4) 0;align-self:center;padding:4px 12px}.message-wrapper{margin-bottom:var(--space-2);max-width:85%;display:flex}.message-wrapper.mine{align-self:flex-end}.message-wrapper.theirs{align-self:flex-start}.message-bubble{border-radius:18px;padding:10px 14px;position:relative}.message-wrapper.mine .message-bubble{background:var(--primary-500);color:#fff;border-bottom-right-radius:4px}.message-wrapper.theirs .message-bubble{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-light);border-bottom-left-radius:4px}.message-text{font-size:var(--text-sm);margin-bottom:2px;line-height:1.4}.message-time{text-align:right;opacity:.8;font-size:10px;display:block}.message-wrapper.mine .message-time{color:#fffc}.message-wrapper.theirs .message-time{color:var(--text-tertiary)}.chat-input-area{background:var(--bg-primary);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-light);align-items:center;gap:var(--space-2);display:flex}.chat-input-form{background:var(--bg-secondary);border-radius:var(--radius-full);padding:4px;padding-left:var(--space-4);flex:1;align-items:center;display:flex}.chat-input{padding:var(--space-2) 0;font-size:var(--text-sm);background:0 0;border:none;flex:1}.chat-input:focus{outline:none}.btn-send{background:var(--primary-500);color:#fff;border-radius:var(--radius-full);cursor:pointer;border:none;justify-content:center;align-items:center;width:36px;height:36px;transition:transform .2s;display:flex}.btn-send:not(:disabled):active{transform:scale(.9)}.btn-send:disabled{background:var(--border-light);color:var(--text-tertiary);cursor:not-allowed}.attachment-preview-bar{border-top:1px solid var(--warning-200,#f7cd8d);background:#fff8e1;align-items:center;gap:10px;min-height:56px;padding:8px 16px;animation:.2s fadeInUp;display:flex}.attachment-preview-thumb{object-fit:cover;border:1px solid var(--border-light);border-radius:8px;flex-shrink:0;width:44px;height:44px}.attachment-preview-doc-icon{background:var(--primary-100);width:44px;height:44px;color:var(--primary-500);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.attachment-preview-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;overflow:hidden}.attachment-preview-cancel{color:#ef4444;cursor:pointer;background:#fee2e2;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;transition:background .2s;display:flex}.attachment-preview-cancel:hover{background:#fca5a5}.message-attachment{margin-bottom:6px}.message-attachment-image{object-fit:cover;cursor:pointer;border-radius:10px;max-width:220px;max-height:220px;transition:opacity .2s;display:block}.message-attachment-image:hover{opacity:.9}.message-attachment-doc{color:inherit;background:#ffffff26;border:1px solid #ffffff4d;border-radius:10px;align-items:center;gap:8px;max-width:220px;padding:8px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:background .2s;display:flex}.message-attachment-doc:hover{background:#ffffff40}.message-attachment-doc span{white-space:nowrap;text-overflow:ellipsis;max-width:160px;overflow:hidden}.message-wrapper.theirs .message-attachment-doc{background:var(--bg-secondary);border-color:var(--border-light);color:var(--primary-500)}.chat-empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:60px 20px;display:flex}.chat-empty-state p:first-child{color:var(--text-secondary);font-size:15px;font-weight:600}.chat-empty-state p:last-child{color:var(--text-tertiary);font-size:13px}.spin{animation:.8s linear infinite spin}.parent-dashboard{background:#f8fafc;min-height:100vh;padding-bottom:80px}.parent-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:80vh;padding:20px;display:flex}.parent-empty h2{color:#1e293b;margin:0;font-size:20px}.parent-empty p{color:#64748b;margin:0}.parent-header{background:linear-gradient(135deg, var(--accent-500), var(--warning-500));color:#fff;padding:20px}.parent-header-top{justify-content:space-between;align-items:flex-start;display:flex}.parent-greeting h1{opacity:.9;margin:0;font-size:16px;font-weight:400}.parent-greeting h2{margin:4px 0 0;font-size:22px;font-weight:700}.logout-btn{cursor:pointer;color:#fff;background:#fff3;border:none;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.child-selector{gap:12px;margin-top:16px;padding-bottom:4px;display:flex;overflow-x:auto}.child-tab{cursor:pointer;color:#fff;white-space:nowrap;background:#ffffff26;border:2px solid #0000;border-radius:30px;align-items:center;gap:8px;padding:8px 16px 8px 8px;font-weight:500;transition:all .2s;display:flex}.child-tab.active{background:#ffffff40;border-color:#fff}.child-tab-avatar{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:600;display:flex;overflow:hidden}.child-tab-avatar img{object-fit:cover;width:100%;height:100%}.child-info-card{z-index:1;background:#fff;border-left:4px solid;border-radius:12px;justify-content:space-between;align-items:center;margin:-10px 16px 16px;padding:16px;display:flex;position:relative;box-shadow:0 2px 8px #0000001a}.child-info{align-items:center;gap:12px;display:flex}.child-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;font-weight:700;display:flex;overflow:hidden}.child-avatar img{object-fit:cover;width:100%;height:100%}.child-info h3{color:#1e293b;margin:0;font-size:16px;font-weight:600}.child-info p{color:#64748b;margin:4px 0 0;font-size:13px}.parent-tabs{background:#fff;border-radius:12px;gap:4px;margin:0 16px 16px;padding:6px;display:flex;box-shadow:0 1px 3px #0000000d}.parent-tab{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.parent-tab.active{color:#1e293b;background:#f1f5f9}.parent-content{padding:0 16px}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-header h2{color:#1e293b;margin:0;font-size:16px;font-weight:600}.count-badge{color:#64748b;background:#f1f5f9;border-radius:20px;padding:4px 10px;font-size:12px}.empty-state{text-align:center;background:#fff;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.empty-state p{color:#64748b;margin:12px 0 0;font-size:15px;font-weight:500}.empty-sub{color:#94a3b8!important;font-size:13px!important}.media-grid{grid-template-columns:1fr;gap:16px;display:grid}.media-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.media-container{aspect-ratio:16/10;background:#f1f5f9;position:relative;overflow:hidden}.media-container img,.media-container video{object-fit:cover;width:100%;height:100%}.video-play-icon{color:#fff;background:#0003;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.media-info{padding:12px}.media-caption{color:#1e293b;margin:0 0 8px;font-size:14px;line-height:1.4}.media-footer{justify-content:space-between;align-items:center;display:flex}.media-time{color:#94a3b8;align-items:center;gap:4px;font-size:12px;display:flex}.like-btn{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:20px;align-items:center;gap:4px;padding:6px 12px;font-size:13px;transition:all .2s;display:flex}.like-btn.liked{color:#f43f5e;background:#fff1f2}.like-btn:hover{transform:scale(1.05)}.moments-list{flex-direction:column;gap:12px;display:flex}.moment-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 3px #0000001a}.moment-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.moment-type{border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.moment-time{color:#94a3b8;font-size:12px}.moment-title{color:#1e293b;margin:0 0 6px;font-size:15px;font-weight:600}.moment-desc{color:#475569;margin:0 0 12px;font-size:14px;line-height:1.5}.moment-media-previews{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:10px;margin-bottom:12px;display:grid}.moment-media-item{aspect-ratio:4/3;background:#f8fafc;border:1px solid #f1f5f9;border-radius:10px;overflow:hidden}.moment-media-item img,.moment-media-item video{object-fit:cover;width:100%;height:100%}.moment-footer{justify-content:flex-end;display:flex}.reports-list{flex-direction:column;gap:12px;display:flex}.report-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.report-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:12px 16px}.report-header h3{color:#1e293b;margin:0;font-size:15px;font-weight:600}.report-date{color:#64748b;font-size:12px}.report-body{padding:16px}.report-item{margin-bottom:12px}.report-item:last-child{margin-bottom:0}.report-item h4{color:var(--primary-500);margin:0 0 4px;font-size:13px;font-weight:600}.report-item p{color:#475569;margin:0;font-size:14px;line-height:1.5}@media (width<=480px){.parent-header{padding:16px 16px 12px}.parent-greeting h1{font-size:14px}.parent-greeting h2{font-size:18px}.logout-btn{border-radius:8px;width:36px;height:36px}.child-selector{margin-top:12px}.child-tab{border-width:1.5px;border-radius:20px;padding:6px 12px 6px 6px;font-size:12px}.child-tab-avatar{width:24px;height:24px;font-size:11px}.child-info-card{border-radius:10px;flex-direction:row;align-items:center;gap:12px;margin:-8px 12px 12px;padding:12px 14px}.child-info{gap:8px}.child-avatar{width:40px;height:40px;font-size:16px}.child-info h3{font-size:14px}.child-info p{margin-top:2px;font-size:11px}.child-info-card .btn-outline{white-space:nowrap;border-radius:8px;padding:8px 10px;font-size:11px}.parent-tabs{border-radius:10px;margin:0 12px 12px;padding:4px}.parent-tab{gap:4px;padding:8px;font-size:12px}.parent-tab svg{width:14px;height:14px}.parent-content{padding:0 12px}.section-header h2{font-size:14px}.count-badge{padding:2px 8px;font-size:10px}.media-grid{gap:12px}.media-card{border-radius:10px}.media-info{padding:10px}.media-caption{margin-bottom:6px;font-size:13px}.moment-card{border-radius:10px;padding:12px}.moment-title{font-size:14px}.moment-desc{margin-bottom:8px;font-size:13px}.report-card{border-radius:10px}.report-header{padding:10px 12px}.report-header h3{font-size:14px}.report-body{padding:12px}.report-item h4{font-size:12px}.report-item p{font-size:13px}}@media (width<=380px){.child-info-card{flex-direction:column;align-items:stretch;gap:12px}.child-info-card .btn-outline{text-align:center;justify-content:center;width:100%}}.parent-media-actions{align-items:center;gap:8px;display:flex}.share-btn,.delete-btn-parent{border-radius:var(--radius-full);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.share-btn{color:#16a34a;background:#f0fdf4}.share-btn:hover{background:#dcfce7;transform:scale(1.05)}.delete-btn-parent{color:#ef4444;background:#fef2f2}.delete-btn-parent:hover{background:#fee2e2;transform:scale(1.05)}@media (width<=480px){.parent-media-actions{gap:6px}.share-btn,.delete-btn-parent{width:28px;height:28px}.share-btn svg,.delete-btn-parent svg{width:12px;height:12px}}.parent-dashboard{transition:background-color var(--transition-slow) ease}.parent-dashboard.tab-active-gallery{background-color:#f4f7fc}.parent-dashboard.tab-active-moments{background-color:#fff6f7}.parent-dashboard.tab-active-reports{background-color:#fffdf5}.parent-tab{transition:all var(--transition-fast) ease}.tab-active-gallery .parent-tab.active{box-shadow:0 4px 12px #1a346014;background:var(--primary-100)!important;color:var(--primary-500)!important}.tab-active-moments .parent-tab.active{box-shadow:0 4px 12px #f9c5cb26;background:var(--rose-100)!important;color:var(--rose-600)!important}.tab-active-reports .parent-tab.active{box-shadow:0 4px 12px #f3bc6f26;background:var(--warning-100)!important;color:var(--warning-600)!important}.admin-page{background:#f8fafc;max-width:1200px;min-height:100vh;margin:0 auto;padding:20px}.admin-header{background:#fff;border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:20px 24px;display:flex;box-shadow:0 1px 3px #0000001a}.admin-header-left{align-items:center;gap:12px;display:flex}.admin-header-left h1{color:#1e293b;margin:0;font-size:20px;font-weight:700}.admin-header-left p{color:#64748b;margin:0;font-size:14px}.admin-stats{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px;display:grid}.admin-stat-card{background:#fff;border-radius:12px;align-items:center;gap:16px;padding:20px;display:flex;box-shadow:0 1px 3px #0000001a}.admin-stat-card h3{color:#1e293b;margin:0;font-size:28px;font-weight:700}.admin-stat-card p{color:#64748b;margin:0;font-size:14px}.admin-toolbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.admin-search{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex:1;align-items:center;gap:8px;max-width:400px;padding:10px 16px;display:flex}.admin-search input{border:none;outline:none;width:100%;font-size:14px}.admin-add-form{background:#fff;border-radius:12px;margin-bottom:20px;padding:24px;box-shadow:0 1px 3px #0000001a}.admin-add-form h3{margin:0 0 16px;font-size:18px;font-weight:600}.form-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#374151;font-size:14px;font-weight:500}.form-group input,.form-group select{border:1px solid #d1d5db;border-radius:8px;padding:10px 12px;font-size:14px}.form-actions{gap:12px;display:flex}.admin-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.admin-table{border-collapse:collapse;width:100%}.admin-table th{text-align:left;color:#64748b;text-transform:uppercase;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:12px 16px;font-size:13px;font-weight:600}.admin-table td{border-bottom:1px solid #f1f5f9;padding:14px 16px;font-size:14px}.role-badge{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:500}.role-teacher{background:var(--primary-100);color:var(--primary-500)}.role-parent{background:var(--accent-100);color:var(--accent-600)}.status-toggle{cursor:pointer;border:none;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;display:flex}.status-toggle.active{color:#16a34a;background:#dcfce7}.status-toggle.inactive{color:#dc2626;background:#fee2e2}.btn-icon{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.btn-danger{color:#dc2626;background:#fee2e2}.btn-danger:hover{background:#fecaca}.admin-section{background:#fff;border-radius:16px;margin-bottom:24px;padding:24px;box-shadow:0 1px 3px #0000001a}.admin-section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.admin-section-header h2{color:#1e293b;margin:0;font-size:18px;font-weight:700}.child-photo-cell{border:2px solid #e2e8f0;border-radius:50%;width:40px;height:40px;overflow:hidden}.child-photo-cell img{object-fit:cover;width:100%;height:100%}.btn-edit{color:#3b82f6;background:#dbeafe;margin-right:8px}.btn-edit:hover{background:#bfdbfe}.admin-footer{text-align:center;color:#94a3b8;padding:20px;font-size:13px}@media (width<=768px){.admin-page{padding:12px 10px}.admin-header{flex-direction:row;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px}.admin-header-left{gap:8px}.admin-header-left h1{font-size:16px}.admin-header-left p{font-size:11px}.admin-header .btn{gap:4px;padding:8px 12px;font-size:12px}.admin-stats{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.admin-stat-card{text-align:center;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:12px 6px}.admin-stat-card svg{width:20px;height:20px}.admin-stat-card h3{font-size:16px;line-height:1.1}.admin-stat-card p{white-space:nowrap;font-size:9px;font-weight:500}.admin-toolbar{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:16px}.admin-search{max-width:100%;padding:8px 12px}.form-row{grid-template-columns:1fr;gap:12px;margin-bottom:12px}.admin-add-form{border-radius:12px;margin-bottom:16px;padding:16px}.admin-add-form h3{margin-bottom:12px;font-size:15px}.form-group input,.form-group select{padding:8px 10px;font-size:13px}.form-actions{gap:8px;margin-top:4px}.form-actions .btn{flex:1;padding:10px;font-size:13px}.admin-section{border-radius:12px;margin-bottom:16px;padding:14px}.admin-section-header{flex-direction:row;justify-content:space-between;align-items:center;gap:8px;margin-bottom:14px}.admin-section-header h2{font-size:15px}.admin-section-header .btn{gap:4px;padding:8px 12px;font-size:12px}.admin-table-container{-webkit-overflow-scrolling:touch;border:1px solid #f1f5f9;border-radius:8px;overflow-x:auto}.admin-table th,.admin-table td{padding:10px var(--space-3);white-space:nowrap;font-size:12px}.btn-icon{width:28px;height:28px}.status-toggle{gap:4px;padding:4px 8px;font-size:11px}}.admin-section{transition:all var(--transition-base) ease;border-left:5px solid #0000}.admin-section-accounts{border-left-color:var(--primary-500)!important;background-color:#f4f7fc!important}.admin-section-parents{border-left-color:var(--accent-500)!important;background-color:#fff6f5!important}.admin-section-teachers{border-left-color:var(--rose-500)!important;background-color:#fff6f7!important}.admin-section-children{border-left-color:var(--warning-500)!important;background-color:#fffdf5!important}
