.landing-page{-webkit-overflow-scrolling:touch;background:#fff;min-height:100vh;overflow-y:auto}.landing-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid var(--gray-200);left:0;position:fixed;right:0;top:0;z-index:100}.landing-nav .container{align-items:center;display:flex;height:72px;justify-content:space-between}.nav-brand{align-items:center;display:flex;gap:var(--space-3)}.nav-logo{font-size:var(--text-2xl)}.nav-title{color:var(--gray-900);font-family:var(--font-display);font-size:var(--text-xl);font-weight:800}.nav-links{align-items:center;display:flex;gap:var(--space-8)}.nav-links a:not(.btn){color:var(--gray-600);font-weight:500;transition:color var(--transition-fast)}.nav-links a:not(.btn):hover{color:var(--primary-600)}.nav-auth{gap:8px}.nav-auth,.nav-auth .btn{align-items:center;display:flex}.nav-auth .btn{border-radius:8px;box-sizing:border-box;font-size:14px;font-weight:600;height:40px;justify-content:center;padding:0 16px;white-space:nowrap}.nav-auth .btn-outline{background:#fff;border:2px solid var(--gray-300);color:var(--gray-700)}.nav-auth .btn-outline:hover{background:#fff;border-color:var(--primary-500);color:var(--primary-500)}.nav-auth .btn-primary{background:var(--primary-500);border:2px solid var(--primary-500);color:#fff}.nav-auth .btn-primary:hover{background:var(--primary-600);border-color:var(--primary-600)}.hero{align-items:center;background:linear-gradient(135deg,var(--primary-50) 0,var(--gray-50) 100%);display:flex;min-height:100vh;padding:140px 0 80px}.hero .container{grid-gap:var(--space-16);align-items:center;display:grid;gap:var(--space-16);grid-template-columns:1fr 1fr}.hero-badge{align-items:center;background:#fff;border-radius:var(--radius-full);box-shadow:var(--shadow-sm);color:var(--primary-600);display:inline-flex;font-size:var(--text-sm);font-weight:500;gap:var(--space-2);padding:var(--space-2) var(--space-4)}.hero-badge,.hero-title{margin-bottom:var(--space-6)}.hero-title{font-size:var(--text-4xl);line-height:1.2}.hero-highlight{color:var(--primary-500);display:block}.hero-description{color:var(--gray-600);font-size:var(--text-lg);max-width:540px}.hero-cta,.hero-description{margin-bottom:var(--space-8)}.hero-cta{display:flex;gap:var(--space-4)}.hero-cta .btn-primary{padding:var(--space-3) var(--space-8);width:fit-content}.hero-trust{gap:var(--space-6)}.trust-item{align-items:center;color:var(--gray-600);display:flex;font-size:var(--text-sm);gap:var(--space-2)}.trust-icon{color:var(--success-500);font-weight:700}.hero-visual{align-items:center;display:flex;justify-content:center;position:relative}.hero-card{background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);padding:var(--space-6);width:280px}.parent-card{transform:translate(-20px,-30px);z-index:2}.child-card{transform:translate(20px,30px);z-index:1}.card-header{align-items:center;display:flex;gap:var(--space-3)}.card-icon{font-size:var(--text-xl)}.card-label{color:var(--gray-700);font-weight:600}.card-content{display:flex;flex-direction:column;gap:var(--space-3)}.activity-item{color:var(--gray-600);font-size:var(--text-sm);gap:var(--space-3)}.status-dot{border-radius:50%;height:8px;width:8px}.status-dot.safe{background:var(--success-500)}.consent-badge{background:var(--success-100);border-radius:var(--radius-lg);color:var(--success-500);display:flex;gap:var(--space-2);padding:var(--space-3)}.consent-text{color:var(--gray-500);font-size:var(--text-xs);margin:0;text-align:center}.features,.how-it-works,.testimonials{padding:100px 0}.section-header{flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-12);text-align:center;width:100%}.section-title{color:var(--gray-900);display:block;font-size:var(--text-3xl);font-weight:700;margin-bottom:0;width:100%}.section-subtitle{color:var(--gray-600);font-size:var(--text-lg);line-height:1.6;margin:0 auto;max-width:600px}.features-grid{grid-gap:var(--space-8);display:grid;gap:var(--space-8);grid-template-columns:repeat(3,1fr)}.feature-card{background:var(--gray-50);border-radius:var(--radius-xl);padding:var(--space-8);transition:all var(--transition-base)}.feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.feature-icon{font-size:var(--text-3xl);margin-bottom:var(--space-4)}.feature-title{font-size:var(--text-lg);margin-bottom:var(--space-3)}.feature-description{color:var(--gray-600);font-size:var(--text-base);margin:0}.how-it-works{background:linear-gradient(180deg,var(--gray-50) 0,#fff 100%)}.how-it-works .container{align-items:center;display:flex;flex-direction:column}.section-badge{align-items:center;background:var(--primary-100);border-radius:var(--radius-full);color:var(--primary-700);display:inline-flex;font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-2);padding:var(--space-2) var(--space-4)}.steps{grid-gap:var(--space-8);display:grid;gap:var(--space-8);grid-template-columns:repeat(4,1fr);width:100%}.step{flex-direction:column;text-align:center}.step,.step-number{align-items:center;display:flex}.step-number{background:var(--primary-500);border-radius:50%;color:#fff;flex-shrink:0;font-size:var(--text-2xl);font-weight:700;height:60px;justify-content:center;margin:0 auto var(--space-6);width:60px}.step-content{width:100%}.step-content h3{font-size:var(--text-lg);margin-bottom:var(--space-2);white-space:nowrap}.step-content p{color:var(--gray-600);font-size:var(--text-base);margin:0}.testimonials-grid{grid-gap:var(--space-8);display:grid;gap:var(--space-8);grid-template-columns:repeat(3,1fr)}.testimonial-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:var(--space-8);position:relative}.testimonial-quote{color:var(--primary-200);font-size:60px;left:20px;line-height:1;position:absolute;top:20px}.testimonial-text{color:var(--gray-700);font-size:var(--text-base);margin-bottom:var(--space-6);position:relative;z-index:1}.testimonial-author{display:flex;flex-direction:column;gap:var(--space-1)}.testimonial-author strong{color:var(--gray-900)}.testimonial-author span{color:var(--gray-500);font-size:var(--text-sm)}.pricing-section{background:linear-gradient(180deg,#fff 0,var(--gray-50) 100%);padding:100px 0}.pricing-section .section-header{margin-bottom:var(--space-12)}.pricing-card{background:#fff;border:2px solid var(--primary-500);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);margin:0 auto var(--space-12);max-width:450px;padding:var(--space-10);position:relative}.pricing-badge{background:var(--primary-500);border-radius:var(--radius-full);color:#fff;font-size:var(--text-sm);font-weight:600;left:50%;padding:var(--space-1) var(--space-4);position:absolute;top:-12px;transform:translateX(-50%)}.pricing-header{border-bottom:1px solid var(--gray-100);margin-bottom:var(--space-8);padding-bottom:var(--space-6);text-align:center}.pricing-name{color:var(--gray-700);font-size:var(--text-xl);font-weight:600;margin-bottom:var(--space-4)}.pricing-price{align-items:baseline;display:flex;gap:var(--space-1);justify-content:center;margin-bottom:var(--space-2)}.pricing-price .currency{color:var(--gray-900);font-size:var(--text-2xl);font-weight:600}.pricing-price .amount{color:var(--gray-900);font-size:var(--text-5xl);font-weight:800;line-height:1}.pricing-price .period{color:var(--gray-500);font-size:var(--text-lg)}.pricing-equivalent{color:var(--gray-500);font-size:var(--text-sm);margin:0}.pricing-features{margin-bottom:var(--space-8)}.pricing-feature{align-items:center;color:var(--gray-700);display:flex;font-size:var(--text-base);gap:var(--space-3);padding:var(--space-3) 0}.feature-check{color:var(--success-500);flex-shrink:0;font-weight:700}.pricing-cta{text-align:center}.btn-full{justify-content:center;width:100%}.pricing-guarantee{color:var(--gray-500);font-size:var(--text-sm);margin-bottom:0;margin-top:var(--space-3)}.pricing-comparison{margin:0 auto;max-width:600px;text-align:center}.pricing-comparison h4{color:var(--gray-600);font-size:var(--text-lg);font-weight:500;margin-bottom:var(--space-6)}.comparison-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(2,1fr);margin-bottom:var(--space-6)}.comparison-item{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);display:flex;justify-content:space-between;padding:var(--space-3) var(--space-4)}.comparison-item.us{background:var(--primary-50);border-color:var(--primary-500)}.competitor-name{color:var(--gray-700);font-weight:500}.competitor-price{color:var(--gray-600);font-weight:600}.comparison-item.us .competitor-name{color:var(--primary-700);font-weight:700}.comparison-item.us .competitor-price{color:var(--primary-600);font-weight:700}.comparison-note{color:var(--gray-600);font-size:var(--text-sm);line-height:1.6;margin:0 auto;max-width:500px}.comparison-note strong{color:var(--primary-600)}.cta-section{background:var(--primary-500);color:#fff;padding:100px 0;text-align:center}.cta-content h2{color:#fff;font-size:var(--text-3xl);margin-bottom:var(--space-4)}.cta-content p{font-size:var(--text-lg);margin-bottom:var(--space-8);opacity:.9}.cta-content .btn-primary{background:#fff;color:var(--primary-500)}.cta-content .btn-primary:hover{background:var(--gray-100)}.landing-footer{background:var(--gray-900);color:var(--gray-400);padding:80px 0 40px}.footer-grid{grid-gap:var(--space-12);display:grid;gap:var(--space-12);grid-template-columns:2fr 1fr 1fr 1fr;margin-bottom:var(--space-12)}.footer-logo{align-items:center;color:#fff;display:inline-flex;font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;gap:var(--space-3);margin-bottom:var(--space-4)}.footer-brand p{font-size:var(--text-base);line-height:1.6;margin:0}.footer-links{display:flex;flex-direction:column;gap:var(--space-3)}.footer-links h4{color:#fff;font-size:var(--text-base);margin-bottom:var(--space-2)}.footer-links a{color:var(--gray-400);font-size:var(--text-sm);transition:color var(--transition-fast)}.footer-links a:hover{color:#fff}.footer-bottom{align-items:center;border-top:1px solid var(--gray-800);display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:space-between;padding-top:var(--space-8);text-align:center}.footer-bottom p{font-size:var(--text-sm);margin:0}.footer-lang{align-items:center;display:inline-flex;gap:8px}.footer-lang,.footer-lang select{color:inherit;font-size:var(--text-sm)}.footer-lang select{background:#ffffff14;border:1px solid #ffffff40;border-radius:8px;cursor:pointer;padding:6px 10px}.footer-lang select:focus{outline:2px solid #60a5fa;outline:2px solid var(--primary-400,#60a5fa);outline-offset:1px}.footer-lang select option{color:#1e293b}@media (max-width:1024px){.hero .container{gap:var(--space-12);grid-template-columns:1fr;text-align:center}.hero-description{margin-left:auto;margin-right:auto}.hero-cta,.hero-trust{justify-content:center}.hero-visual{order:-1}.features-grid,.footer-grid,.steps,.testimonials-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.nav-links{display:none}.features-grid,.footer-grid,.steps,.testimonials-grid{grid-template-columns:1fr}.hero-title{font-size:var(--text-3xl)}.hero-trust{flex-direction:column;gap:var(--space-3)}.how-it-works{padding:60px 0}.how-it-works .section-header{gap:var(--space-2);margin-bottom:var(--space-8)}.section-badge{font-size:var(--text-xs);padding:var(--space-1) var(--space-3)}.how-it-works .section-title{font-size:var(--text-2xl)}.how-it-works .section-subtitle{font-size:var(--text-base);padding:0 var(--space-4)}.pricing-section{padding:60px 0}.pricing-card{margin:0 var(--space-4) var(--space-8);padding:var(--space-6)}.pricing-price .amount{font-size:var(--text-4xl)}.comparison-grid{grid-template-columns:1fr}.steps{gap:var(--space-6)}.step{align-items:flex-start;flex-direction:row;gap:var(--space-4);text-align:left}.step-number{font-size:var(--text-xl);height:48px;margin:0;width:48px}.step-content h3{font-size:var(--text-base);margin-bottom:var(--space-1)}.step-content p{font-size:var(--text-sm)}.nav-auth{gap:6px}.nav-auth .btn{font-size:13px;height:36px;padding:0 12px}}@media (max-width:480px){.nav-auth .btn{font-size:12px;height:32px;padding:0 10px}}.password-strength-meter{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin:8px 0 16px;padding:12px}.strength-bar{display:flex;gap:4px;margin-bottom:8px}.strength-segment{border-radius:3px;flex:1 1;height:6px;transition:background-color .3s ease}.strength-info{align-items:center;display:flex;font-size:13px;justify-content:space-between;margin-bottom:8px}.strength-label{font-weight:600}.strength-score{color:#6b7280}.strength-requirements{list-style:none;margin:8px 0 0;padding:0}.requirement-item{align-items:flex-start;color:#dc2626;display:flex;font-size:12px;gap:6px;line-height:1.4;margin-bottom:4px}.requirement-icon{flex-shrink:0;font-size:10px;margin-top:2px}.strength-success{align-items:center;color:#16a34a;display:flex;font-size:13px;font-weight:500;gap:6px}.success-icon{font-size:14px}.password-change-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.password-change-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:480px;overflow-y:auto;width:100%}.modal-header{border-bottom:1px solid #e5e7eb;padding:24px 24px 16px}.modal-header h2{font-size:24px;font-weight:700;margin:0 0 8px}.security-notice{background:#fef2f2;border-left:4px solid #dc2626;border-radius:8px;color:#dc2626;font-size:14px;font-weight:500;margin:0;padding:12px}.password-requirements-info{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:16px 24px}.password-requirements-info h4{color:#374151;font-size:14px;font-weight:600;margin:0 0 12px}.password-requirements-info ul{color:#6b7280;font-size:13px;margin:0;padding-left:20px}.password-requirements-info li{margin-bottom:6px}.password-change-form{padding:24px}.form-input{border:1px solid #d1d5db;border-radius:8px;font-size:14px;padding:12px 16px;transition:border-color .2s,box-shadow .2s;width:100%}.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-input:disabled{background:#f3f4f6;cursor:not-allowed}.form-hint{color:#6b7280;display:block;font-size:12px;margin-top:6px}.form-hint code{background:#f3f4f6;border-radius:4px;color:#2563eb;font-family:monospace;font-weight:600;padding:2px 6px}.form-error{color:#dc2626;display:block;font-size:12px;margin-top:6px}.btn{font-size:16px;padding:14px 24px}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-primary:disabled{background:#93c5fd}.modal-footer{padding:16px 24px 24px;text-align:center}.security-tip{color:#6b7280;font-size:13px;font-style:italic;margin:0}.security-tip strong{color:#374151}.password-change-modal{animation:slideIn .3s ease-out}@media (max-width:480px){.password-change-overlay{padding:0}.password-change-modal{border-radius:0;max-height:100vh}}.auth-page{-webkit-overflow-scrolling:touch;align-items:center;background:linear-gradient(135deg,var(--primary-50) 0,var(--gray-50) 100%);display:flex;flex-direction:column;justify-content:flex-start;min-height:100%;overflow-x:hidden;overflow-y:auto;padding:var(--space-8) var(--space-8) calc(var(--space-8) + 60px)}.auth-container{max-width:440px;width:100%}.auth-card{background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);padding:var(--space-10)}.auth-header{margin-bottom:var(--space-8);text-align:center}.auth-logo{align-items:center;color:var(--gray-900);display:inline-flex;font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;gap:var(--space-2);margin-bottom:var(--space-6);text-decoration:none}.auth-header h1{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.auth-header p{color:var(--gray-600);margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--space-5)}.form-options{justify-content:space-between}.checkbox-label,.form-options{align-items:center;display:flex;font-size:var(--text-sm)}.checkbox-label{color:var(--gray-700);cursor:pointer;gap:var(--space-2)}.checkbox-label input[type=checkbox]{accent-color:var(--primary-500);height:18px;width:18px}.checkbox-label a{color:var(--primary-600);text-decoration:underline}.forgot-link{color:var(--primary-600);font-weight:500}.forgot-link:hover{text-decoration:underline}.form-hint{color:var(--gray-500);font-size:var(--text-xs);margin-bottom:0}.checkbox-group .form-error,.form-hint{margin-top:var(--space-2)}.auth-footer{border-top:1px solid var(--gray-200);margin-top:var(--space-8);padding-top:var(--space-6);text-align:center}.auth-footer p{color:var(--gray-600);margin:0 0 var(--space-2) 0}.auth-footer a{color:var(--primary-600);font-weight:600}.auth-footer a:hover{text-decoration:underline}.auth-links{margin-top:var(--space-6);text-align:center}.auth-links a{color:var(--gray-600);font-size:var(--text-sm)}.auth-links a:hover{color:var(--primary-600)}.demo-notice{background:var(--primary-50);border-radius:var(--radius-lg);margin-top:var(--space-6);padding:var(--space-4);text-align:center}.demo-notice p{color:var(--gray-600);font-size:var(--text-sm);margin:0 0 var(--space-2) 0}.demo-notice code{background:#fff;border-radius:var(--radius-md);color:var(--primary-600);font-size:var(--text-sm);padding:var(--space-1) var(--space-3)}.child-registration-info{padding:var(--space-4);text-align:center}.child-registration-info .info-icon{font-size:64px;margin-bottom:var(--space-4)}.child-registration-info h2{color:var(--gray-800);font-size:var(--text-xl);margin-bottom:var(--space-3)}.child-registration-info>p{color:var(--gray-600);font-size:var(--text-base);margin-bottom:var(--space-6)}.steps-list{background:var(--primary-50);border-radius:var(--radius-xl);margin-bottom:var(--space-6);padding:var(--space-6);text-align:left}.steps-list h3{color:var(--gray-800);font-size:var(--text-base);margin:0 0 var(--space-4) 0}.steps-list ol{color:var(--gray-700);margin:0;padding-left:var(--space-5)}.steps-list li{line-height:1.5;margin-bottom:var(--space-3)}.steps-list li:last-child{margin-bottom:0}.action-buttons{gap:var(--space-4);justify-content:center}.security-alert{align-items:flex-start;border-radius:var(--radius-lg);display:flex;font-size:var(--text-sm);gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-4)}.security-alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.security-alert-warning{background:#fffbeb;border:1px solid #fcd34d;color:#d97706}.security-icon{flex-shrink:0;font-size:var(--text-xl)}.security-alert strong{display:block;font-weight:600;margin-bottom:var(--space-1)}.security-alert p{line-height:1.5;margin:0}@media (max-width:640px){.auth-page{padding:var(--space-4)}.auth-card{padding:var(--space-6)}.action-buttons{flex-direction:column}.action-buttons .btn{width:100%}}.error-icon,.loading-spinner,.success-icon{font-size:48px;margin-bottom:var(--space-4)}.auth-content{text-align:center}.info-box{margin:var(--space-6) 0;text-align:left}.info-box h4{font-size:var(--text-sm);font-weight:600;letter-spacing:.05em;text-transform:uppercase}.info-box ol{color:var(--gray-600);font-size:var(--text-sm);margin:0;padding-left:var(--space-5)}.info-box li{line-height:1.5}.info-box li:last-child{margin-bottom:0}.help-text{color:var(--gray-500);font-size:var(--text-sm);margin:var(--space-4) 0}.link-button{background:none;border:none;color:var(--primary-600);cursor:pointer;font-weight:500;padding:0;text-decoration:underline}.link-button:hover{color:var(--primary-700)}.redirect-text{color:var(--gray-500);margin-bottom:var(--space-4)}.password-requirements{background:var(--gray-50);border-radius:var(--radius-lg);margin:var(--space-4) 0;padding:var(--space-4);text-align:left}.password-requirements h4{color:var(--gray-700);font-size:var(--text-sm);margin:0 0 var(--space-3) 0}.password-requirements ul{list-style:none;margin:0;padding:0}.password-requirements li{align-items:center;color:var(--gray-500);display:flex;font-size:var(--text-sm);gap:var(--space-2);margin-bottom:var(--space-2)}.password-requirements li.met{color:var(--success-600)}.password-requirements li.met:before{color:var(--success-500);content:"✓";font-weight:700}.password-requirements li:not(.met):before{color:var(--gray-300);content:"○"}.reset-link-box{background:linear-gradient(135deg,var(--primary-50) 0,var(--primary-100) 100%);border:2px solid var(--primary-200);border-radius:var(--radius-lg);margin:var(--space-6) 0;padding:var(--space-6);text-align:left}.reset-link-box label{color:var(--primary-800);display:block;font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-3)}.reset-link-container{display:flex;gap:var(--space-3);margin-bottom:var(--space-3)}.reset-link-input{background:#fff;border:1px solid var(--primary-300);border-radius:var(--radius-md);color:var(--primary-700);flex:1 1;font-size:var(--text-sm);padding:var(--space-3) var(--space-4);word-break:break-all}.reset-link-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f61a;outline:none}.link-hint{color:var(--primary-600);font-size:var(--text-sm);margin:0}.info-box.success{background:#f0fdf4;border-color:#86efac}.info-box.success h4{color:#166534}.info-box.warning{background:#fffbeb;border-color:#fcd34d}.info-box.warning h4{color:#92400e}.info-box.info{background:#eff6ff;border-color:#93c5fd}.info-box.info p{color:#1e40af;margin:0}.password-group{position:relative}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper .form-input{padding-right:var(--space-12);width:100%}.password-toggle,.password-toggle-btn{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;font-size:var(--text-lg);justify-content:center;opacity:.6;padding:var(--space-1);position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);transition:opacity .2s ease;z-index:1}.password-toggle-btn:hover,.password-toggle:hover{opacity:1}.password-toggle-btn:focus,.password-toggle:focus{opacity:1;outline:none}.age-modal-overlay{align-items:center;background:#0f172a8c;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:2100}.age-modal{background:#fff;border-radius:18px;box-shadow:0 12px 48px #00000040;display:flex;flex-direction:column;max-height:92vh;max-width:460px;overflow:hidden;width:100%}.age-modal-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:16px 20px}.age-modal-header h2{color:#0f172a;font-size:18px;font-weight:800;margin:0}.age-modal-close{background:#f1f5f9;border:none;border-radius:50%;color:#475569;cursor:pointer;font-size:14px;height:32px;width:32px}.age-modal-body{flex:1 1 auto;overflow-y:auto;padding:20px}.age-modal-center{align-items:center;display:flex;flex-direction:column;gap:14px;padding:36px 20px;text-align:center}.age-intro-icon{font-size:42px;margin:0 0 8px;text-align:center}.age-modal-body h3{font-size:17px;font-weight:700;margin:0 0 12px;text-align:center}.age-intro-copy{color:#475569;font-size:14px;line-height:1.55;margin:0 0 14px;text-align:center}.age-intro-bullets{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0 0 14px;padding:0}.age-intro-bullets li{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;color:#334155;font-size:13px;padding:10px 12px}.age-intro-provider{color:#94a3b8;font-size:11px;margin:0 0 12px;text-align:center}.age-intro-provider code{background:#f1f5f9;border-radius:4px;padding:1px 6px}.age-modal-actions{display:flex;gap:10px;margin-top:18px}.age-modal-actions button{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-size:14px;font-weight:700;padding:12px 16px}.age-modal-actions .btn-primary{background:linear-gradient(135deg,#4a90d9,#6366f1);color:#fff}.age-modal-actions .btn-primary:disabled{cursor:not-allowed;opacity:.5}.age-modal-actions .btn-secondary{background:#f1f5f9;color:#334155}.age-camera-frame{aspect-ratio:1/1;background:#0f172a;border-radius:18px;overflow:hidden;position:relative;width:100%}.age-camera-video{height:100%;object-fit:cover;transform:scaleX(-1);width:100%}.age-camera-guide{border:3px dashed #ffffffa6;border-radius:50%;inset:0;margin:14%;pointer-events:none;position:absolute}.age-camera-tip{color:#475569;font-size:13px;margin:12px 0 0;text-align:center}.age-spinner{animation:age-spin .9s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#4a90d9;height:48px;width:48px}@keyframes age-spin{to{transform:rotate(1turn)}}.age-result{border-radius:14px;padding:16px;text-align:center}.age-result.pass{background:#dcfce7;color:#166534}.age-result.fail{background:#fef3c7;color:#92400e}.age-result-icon{font-size:36px;margin-bottom:6px}.age-result-detail{font-size:14px;margin:6px 0}.age-result-meta{font-size:11px;margin:0;opacity:.75}.age-error-icon{font-size:36px}.age-error-msg{color:#b91c1c;font-size:14px;margin:0;text-align:center}.role-selection{align-items:center;background:linear-gradient(135deg,var(--primary-50) 0,var(--gray-50) 100%);display:flex;justify-content:center;min-height:100vh;padding:var(--space-8)}.role-selection-container{max-width:1200px;width:100%}.role-selection-header{margin-bottom:var(--space-12);text-align:center}.back-link{color:var(--gray-600);display:inline-block;font-weight:500;margin-bottom:var(--space-6)}.back-link:hover{color:var(--primary-600)}.role-selection-header h1{font-size:var(--text-3xl);margin-bottom:var(--space-3)}.role-selection-header p{color:var(--gray-600);font-size:var(--text-lg);margin:0}.role-cards{grid-gap:var(--space-8);display:grid;gap:var(--space-8);grid-template-columns:repeat(3,1fr);margin-bottom:var(--space-12)}.role-card{background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-md);color:inherit;display:flex;flex-direction:column;padding:var(--space-8);text-decoration:none;transition:all var(--transition-base)}.role-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-8px)}.role-icon{font-size:48px;margin-bottom:var(--space-4)}.role-card h2{color:var(--gray-900);font-size:var(--text-2xl);margin-bottom:var(--space-3)}.role-card>p{color:var(--gray-600);font-size:var(--text-base);line-height:1.6;margin-bottom:var(--space-6)}.role-features{flex-grow:1;list-style:none;margin:0 0 var(--space-6) 0;padding:0}.role-features li{color:var(--gray-700);font-size:var(--text-sm);padding:var(--space-2) 0}.role-cta{background:var(--primary-500);border-radius:var(--radius-lg);color:#fff;display:inline-block;font-weight:600;padding:var(--space-4) var(--space-6);text-align:center;transition:background var(--transition-fast)}.role-card:hover .role-cta{background:var(--primary-600)}.admin-card{opacity:.8}.admin-card .role-cta{background:var(--gray-600)}.admin-card:hover .role-cta{background:var(--gray-700)}.role-selection-footer{text-align:center}.role-selection-footer p{color:var(--gray-600);margin-bottom:var(--space-3)}.login-links{align-items:center;display:flex;gap:var(--space-4);justify-content:center}.login-links a{color:var(--primary-600);font-weight:500}.login-links a:hover{text-decoration:underline}.login-links span{color:var(--gray-400)}@media (max-width:1024px){.role-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.role-cards{grid-template-columns:1fr}}.back-button{align-items:center;background:#fff;border:none;border-radius:50%;box-shadow:0 2px 8px #00000026;color:#334155;cursor:pointer;display:flex;height:44px;justify-content:center;left:16px;position:fixed;top:16px;transition:all .2s ease;width:44px;z-index:1000}.back-button:hover{background:#f1f5f9;transform:scale(1.05)}.back-button:active{transform:scale(.95)}.back-button svg{height:20px;width:20px}.layout-child .back-button,.layout-parent .back-button{left:20px;position:absolute;top:20px}@media (max-width:768px){.back-button{height:40px;left:12px;top:12px;width:40px}.back-button svg{height:18px;width:18px}}@supports (padding-top:env(safe-area-inset-top)){.back-button{top:max(16px,env(safe-area-inset-top))}}.bottom-nav{background:#fff;border-top:1px solid #e2e8f0;bottom:0;display:none;height:64px;left:0;padding-bottom:env(safe-area-inset-bottom,0);position:fixed;right:0;z-index:1000}.bottom-nav-item{align-items:center;color:#64748b;display:flex;flex:1 1;flex-direction:column;gap:4px;justify-content:center;padding:8px 4px;text-decoration:none;transition:all .2s ease}.bottom-nav-item.active{color:#4a90d9}.bottom-nav-item:active{opacity:.7}.bottom-nav-icon{font-size:24px;line-height:1}.bottom-nav-label{font-size:11px;font-weight:500}@media (max-width:1024px){.bottom-nav{display:flex}.main-content{padding-bottom:calc(64px + env(safe-area-inset-bottom, 20px))!important}.sidebar{display:none}.dashboard-layout .main-content{margin-left:0!important;width:100%!important}}@supports (padding-bottom:env(safe-area-inset-bottom)){.bottom-nav{height:calc(64px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom)}}.child-theme .bottom-nav{background:#f8fafc;border-top-color:#e9d5ff}.child-theme .bottom-nav-item.active{color:#8b5cf6}.bottom-nav-item.active:before{background:#4a90d9;border-radius:0 0 3px 3px;content:"";height:3px;position:absolute;top:0;width:40px}.child-theme .bottom-nav-item.active:before{background:#8b5cf6}.bottom-nav-item{position:relative}.dashboard-layout{background:var(--gray-50);display:flex;min-height:100vh}.sidebar{background:#fff;border-right:1px solid var(--gray-200);bottom:0;display:flex;flex-direction:column;height:100vh;left:0;min-width:280px;overflow-y:auto;position:fixed;top:0;width:280px;z-index:100}.sidebar-header{border-bottom:1px solid var(--gray-200);padding:var(--space-6)}.sidebar-brand{align-items:center;display:flex;gap:var(--space-3);margin-bottom:var(--space-6);text-decoration:none}.brand-logo{font-size:var(--text-2xl)}.brand-text{color:var(--gray-900);font-family:var(--font-display);font-size:var(--text-xl);font-weight:800}.user-preview{background:var(--gray-50);border-radius:var(--radius-lg);gap:var(--space-3);padding:var(--space-3)}.user-avatar,.user-preview{align-items:center;display:flex}.user-avatar{background:var(--primary-500);border-radius:50%;color:#fff;font-size:var(--text-lg);font-weight:600;height:40px;justify-content:center;width:40px}.child-theme .user-avatar{background:var(--child-primary)}.admin-theme .user-avatar{background:var(--gray-700)}.user-info{display:flex;flex-direction:column}.user-name{font-size:var(--text-sm)}.user-role{color:var(--gray-500);text-transform:capitalize}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:var(--space-1);padding:var(--space-4)}.sidebar-link{align-items:center;border-radius:var(--radius-lg);color:var(--gray-600);display:flex;font-weight:500;gap:var(--space-3);padding:var(--space-3) var(--space-4);text-decoration:none;transition:all var(--transition-fast)}.sidebar-link:hover{background:var(--gray-100);color:var(--gray-900)}.sidebar-link.active{background:var(--primary-50);color:var(--primary-600)}.child-theme .sidebar-link.active{background:#f3e8ff;color:var(--child-primary)}.nav-icon{font-size:var(--text-lg)}.nav-label{font-size:var(--text-sm)}.sidebar-footer{border-top:1px solid var(--gray-200);padding:var(--space-4)}.logout-btn{align-items:center;color:var(--gray-600);display:flex;font-weight:500;gap:var(--space-2);justify-content:center;padding:var(--space-3);transition:all var(--transition-fast);width:100%}.logout-btn:hover{background:var(--error-100);color:var(--error-500)}.main-content{box-sizing:border-box;flex:1 1;margin-left:280px;min-height:100vh;padding:var(--space-8);padding-top:calc(var(--space-8) + 60px);position:relative;width:calc(100% - 280px)}.child-theme .sidebar{border-right-color:#e9d5ff}.child-theme .brand-text{color:var(--child-primary)}.admin-theme .sidebar{background:var(--gray-900);border-right-color:var(--gray-800)}.admin-theme .brand-text,.admin-theme .sidebar-brand{color:#fff}.admin-theme .user-preview{background:var(--gray-800)}.admin-theme .user-name{color:#fff}.admin-theme .sidebar-link{color:var(--gray-400)}.admin-theme .sidebar-link:hover{background:var(--gray-800);color:#fff}.admin-theme .sidebar-link.active{background:var(--primary-900);color:#fff}.admin-theme .logout-btn{color:var(--gray-400)}.admin-theme .logout-btn:hover{background:var(--error-500);color:#fff}.admin-theme .sidebar-footer{border-top-color:var(--gray-800)}@media (max-width:1024px){.sidebar{display:none}.main-content{margin-left:0!important;padding:var(--space-4);padding-bottom:84px;padding-top:calc(var(--space-4) + 60px);width:100%!important}}@media (max-width:640px){.main-content{padding:var(--space-4);padding-bottom:84px;padding-top:calc(var(--space-4) + 60px)}}.legal-page{background:var(--gray-50);min-height:100vh;padding:var(--space-8)}.legal-container{background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);margin:0 auto;max-width:900px;overflow:hidden}.legal-header{background:linear-gradient(135deg,var(--primary-500) 0,var(--primary-700) 100%);color:#fff;padding:var(--space-10);text-align:center}.legal-header h1{color:#fff;font-size:var(--text-3xl);margin:0 0 var(--space-3) 0}.legal-header p{font-size:var(--text-lg);margin:0;opacity:.9}.legal-content{padding:var(--space-10)}.legal-content section{margin-bottom:var(--space-8)}.legal-content section:last-child{margin-bottom:0}.legal-content h2{border-bottom:2px solid var(--primary-100);color:var(--gray-900);font-size:var(--text-xl);margin:0 0 var(--space-4) 0;padding-bottom:var(--space-3)}.legal-content h3{color:var(--gray-800);font-size:var(--text-lg);margin:var(--space-6) 0 var(--space-3) 0}.legal-content p{color:var(--gray-700);font-size:var(--text-base);line-height:1.7;margin-bottom:var(--space-4)}.legal-content ol,.legal-content ul{margin:0 0 var(--space-4) 0;padding-left:var(--space-6)}.legal-content li{color:var(--gray-700);line-height:1.6;margin-bottom:var(--space-2)}.legal-content a{color:var(--primary-600);font-weight:500;text-decoration:underline}.legal-content a:hover{color:var(--primary-700)}.legal-content strong{color:var(--gray-900);font-weight:600}@media (max-width:768px){.legal-page{padding:var(--space-4)}.legal-header{padding:var(--space-6)}.legal-header h1{font-size:var(--text-2xl)}.legal-content{padding:var(--space-6)}}.preorder-page{-webkit-font-smoothing:antialiased;background:linear-gradient(180deg,#f4f8fb,#fff 30%);color:#1a2540;min-height:100vh}.preorder-page .container{margin:0 auto;max-width:1100px;padding:0 24px}.preorder-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:50}.preorder-nav .container{align-items:center;display:flex;height:68px;justify-content:space-between}.preorder-nav .nav-brand{align-items:center;color:inherit;display:flex;gap:10px;text-decoration:none}.preorder-nav .nav-title{font-size:18px;font-weight:700}.preorder-nav .btn{flex:0 0 auto;width:auto}.preorder-page .btn{align-items:center;border:1px solid #0000;border-radius:10px;cursor:pointer;display:inline-flex;font-size:15px;font-weight:600;justify-content:center;padding:12px 22px;text-decoration:none;transition:transform .05s ease,box-shadow .15s ease,background .15s ease}.preorder-page .btn:active{transform:translateY(1px)}.preorder-page .btn[disabled]{cursor:not-allowed;opacity:.6}.preorder-page .btn-primary{background:#4a90d9;color:#fff}.preorder-page .btn-primary:hover:not([disabled]){background:#357abd;box-shadow:0 6px 18px #4a90d940}.preorder-page .btn-outline{background:#fff;border-color:#cbd5e1;color:#1a2540}.preorder-page .btn-outline:hover:not([disabled]){border-color:#4a90d9;color:#357abd}.preorder-page .btn-block{width:100%}.preorder-success{padding:32px 0 0}.success-card{background:linear-gradient(135deg,#e6f4ea,#f0f9ff);border:1px solid #a7dbc0;border-radius:16px;box-shadow:0 6px 20px #2f855a1f;padding:28px}.success-card--neutral{background:#fef7e6;border-color:#facc15;box-shadow:none}.success-eyebrow{color:#2f855a;font-size:13px;font-weight:700;letter-spacing:.04em;margin-bottom:8px;text-transform:uppercase}.success-card h2{font-size:22px;font-weight:800;margin:0 0 8px}.success-card p{color:#1a2540;line-height:1.5;margin:0 0 12px}.share-block{margin-top:16px}.share-prompt{color:#465872;font-size:14px;margin:0 0 10px}.share-row{align-items:stretch;display:flex;flex-wrap:wrap;gap:8px}.share-row input{background:#fff;border:1px solid #cbd5e1;border-radius:10px;flex:1 1 240px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:14px;min-width:0;padding:12px 14px}.preorder-hero{padding:80px 0 48px;text-align:center}.preorder-hero h1{font-size:clamp(32px,5vw,52px);font-weight:800;line-height:1.1;margin:16px auto;max-width:820px}.hero-badge{background:#e8f2fb;border:1px solid #b7daf6;border-radius:999px;color:#1e40af;display:inline-block;font-size:13px;font-weight:600;padding:6px 14px}.hero-sub{color:#465872;font-size:18px;line-height:1.6;margin:0 auto;max-width:680px}.hero-trust{color:#2f855a;display:flex;flex-wrap:wrap;font-size:14px;font-weight:500;gap:14px 28px;justify-content:center;margin-top:28px}.preorder-tiers{padding:64px 0}.preorder-faq h2,.preorder-tiers h2,.preorder-waitlist h2{font-size:clamp(24px,3vw,34px);font-weight:800;margin:0 0 8px;text-align:center}.section-sub{color:#465872;margin:0 auto 32px;max-width:540px;text-align:center}.alert{border-radius:10px;font-size:14px;margin:0 auto 24px;max-width:560px;padding:12px 16px;text-align:center}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.tier-grid{grid-gap:20px;align-items:stretch;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.tier-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 1px 2px #0f172a0a;display:flex;flex-direction:column;padding:28px 24px;position:relative}.tier-card--highlight{border-color:#4a90d9;box-shadow:0 12px 32px #4a90d92e;transform:translateY(-4px)}.tier-badge{background:#4a90d9;border-radius:999px;color:#fff;font-size:12px;font-weight:700;letter-spacing:.02em;padding:4px 10px;position:absolute;right:20px;top:-12px}.tier-card h3{font-size:20px;font-weight:700;margin:0 0 8px}.tier-price{align-items:baseline;display:flex;gap:6px;margin-bottom:4px}.price-amount{color:#1a2540;font-size:36px;font-weight:800}.price-suffix{color:#6b7280;font-size:14px}.tier-cap{color:#b45309;font-size:12px;font-weight:600;letter-spacing:.04em;margin-bottom:12px;text-transform:uppercase}.tier-blurb{color:#465872;font-size:14px;line-height:1.5;margin:0 0 16px}.tier-perks{flex-grow:1;list-style:none;margin:0 0 20px;padding:0}.tier-perks li{color:#1a2540;font-size:14px;padding:6px 0 6px 22px;position:relative}.tier-perks li:before{color:#2f855a;content:"✓";font-weight:700;left:0;position:absolute;top:6px}.tier-actions{display:flex;flex-direction:column;gap:10px}.preorder-waitlist{background:#f4f8fb;padding:64px 0;text-align:center}.preorder-waitlist>.container>p{color:#465872;margin:0 auto 24px;max-width:480px}.waitlist-form{display:flex;gap:10px;margin:0 auto;max-width:460px}.waitlist-form input{background:#fff;border:1px solid #cbd5e1;border-radius:10px;flex:1 1;font-size:15px;padding:12px 16px}.waitlist-form input:focus{border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d933;outline:none}.waitlist-success{color:#2f855a;font-weight:600}.waitlist-error{color:#b91c1c;font-size:14px;margin-top:12px}.preorder-faq{padding:64px 0}.preorder-faq dl{margin:32px auto 0;max-width:760px}.faq-item{border-bottom:1px solid #e2e8f0;padding:20px 0}.faq-item dt{font-size:17px;font-weight:700;margin-bottom:8px}.faq-item dd{color:#465872;line-height:1.6;margin:0}.preorder-footer{background:#1a2540;color:#cbd5e1;font-size:13px;padding:28px 0}.preorder-footer .container{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.preorder-footer nav{display:flex;gap:20px}.preorder-footer a{color:#cbd5e1;text-decoration:none}.preorder-footer a:hover{color:#fff}@media (max-width:640px){.preorder-hero{padding:56px 0 32px}.waitlist-form{flex-direction:column}.tier-card--highlight{transform:none}}.create-child-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.create-child-modal{background:#fff;border-radius:16px;max-height:90vh;max-width:450px;overflow-y:auto;width:100%}.success-modal{max-width:500px}.modal-header{padding:20px 24px}.close-btn{font-size:28px;height:40px;transition:background .2s;width:40px}.close-btn:hover{background:#f1f5f9}.create-child-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:6px}.form-group input{border:2px solid #e2e8f0;border-radius:10px;box-sizing:border-box;font-size:16px;padding:12px 16px;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#4a90d9;outline:none}.form-group .error{color:#ef4444;display:block;font-size:13px;margin-top:4px}.form-actions{display:flex;gap:12px;margin-top:24px}.form-actions .btn{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:12px 20px;transition:all .2s}.btn-primary:hover{background:#2563eb}.success-content{padding:24px}.login-details{background:#f0fdf4;border:2px solid #86efac;border-radius:12px;margin-bottom:20px;padding:20px}.login-details h3{color:#166534;font-size:1.1rem;margin:0 0 16px}.detail-item{align-items:center;border-bottom:1px dashed #bbf7d0;display:flex;justify-content:space-between;padding:10px 0}.detail-item:last-child{border-bottom:none}.detail-item label{color:#374151;font-weight:600}.detail-value{background:#fff;border-radius:6px;font-family:monospace;font-size:14px;padding:6px 12px}.action-buttons{display:flex;gap:12px;margin-bottom:24px}.action-buttons .btn{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:14px 20px}.instructions{background:#eff6ff;border-radius:12px;padding:16px 20px}.instructions h4{color:#1e40af;margin:0 0 12px}.instructions ol{color:#334155;margin:0;padding-left:20px}.instructions li{line-height:1.5;margin-bottom:8px}@media (max-width:480px){.create-child-modal{margin:10px}.create-child-form,.success-content{padding:16px}}.geofence-overlay{inset:0;padding:0;position:fixed;z-index:1000}.geofence-modal,.geofence-overlay{background:#fff;display:flex;flex-direction:column}.geofence-modal{border-radius:0;height:100%;max-height:none;max-width:none;overflow:hidden;width:100%}.geofence-modal-wide{max-width:none}.geofence-modal .modal-header{flex-shrink:0}.geofence-modal .geofence-content{-webkit-overflow-scrolling:touch;flex:1 1 auto;overflow-y:auto;padding:14px}.modal-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:18px 20px;position:sticky;top:0;z-index:10}.modal-header h2{color:#1e293b;font-size:1.1rem}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;font-size:26px;height:38px;justify-content:center;width:38px}.geofence-content{padding:20px}.gf-map-cage{background:#e2e8f0;border-radius:10px;contain:layout paint;isolation:isolate;margin-bottom:6px;overflow:hidden;position:relative;width:100%;z-index:0}.gf-map-cage .leaflet-container{height:100%!important;touch-action:none!important;width:100%!important}.gf-map-loading{align-items:center;background:#f1f5f9;color:#64748b;display:flex;font-size:14px;height:100%;justify-content:center;width:100%}.map-fallback-row{padding:8px 0 4px;text-align:center}.map-fallback-btn{background:#4a90d9;border-radius:8px;color:#fff;display:inline-block;font-size:14px;font-weight:600;padding:10px 16px;text-decoration:none}.map-fallback-btn:active{background:#3a7bc8}.map-fallback-btn-secondary{background:#64748b}.map-fallback-btn-secondary:active{background:#475569}.map-fallback-empty{background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;color:#78350f;font-size:13px;line-height:1.4;margin:8px 12px;padding:12px;text-align:center}.gf-map-cage .leaflet-container{touch-action:pan-y!important}.map-hint{color:#4a90d9}.child-location-hint,.map-hint{background:#fff;font-size:12px;padding:4px 0;text-align:center}.child-location-hint{color:#22c55e}.gf-form-wrap{position:relative;z-index:20}.gf-form-title{color:#1e293b;font-size:1rem;font-weight:700;margin:0 0 16px}.gf-field{margin-bottom:18px}.gf-label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.gf-input{appearance:none;background:#fff;border:2px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;display:block;font-family:inherit;font-size:16px;height:48px;line-height:48px;outline:none;padding:0 14px;pointer-events:auto;touch-action:auto;transform:none;width:100%}.gf-input:focus{border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d92e}.gf-search-btn-full{-webkit-tap-highlight-color:rgba(0,0,0,0);background:#4a90d9;border:none;border-radius:10px;box-sizing:border-box;color:#fff;cursor:pointer;display:block;font-size:17px;font-weight:700;height:52px;letter-spacing:.3px;padding:0;touch-action:manipulation;user-select:none;-webkit-user-select:none;width:100%}.gf-search-btn-full:disabled{opacity:.55}.gf-search-btn-full:active{background:#3a7bc8}.gf-results{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 2px 8px #0000000f;margin-top:10px;overflow:hidden}.gf-results-title{background:#eff6ff;border-bottom:1px solid #e2e8f0;color:#4a90d9;font-size:13px;font-weight:600;margin:0;padding:10px 14px}.gf-results-list{-webkit-overflow-scrolling:touch;list-style:none;margin:0;max-height:260px;overflow-y:auto;padding:0}.gf-result-item{align-items:flex-start;background:#fff;border:none;border-bottom:1px solid #f1f5f9;color:#1e293b;cursor:pointer;display:flex;font-family:inherit;font-size:14px;gap:8px;line-height:1.4;padding:12px 14px;text-align:left;width:100%}.gf-result-item:active{background:#f0f9ff}.gf-result-item.centroid{background:#f0fdf4}.gf-result-item.centroid:active{background:#dcfce7}.gf-result-badge{background:#22c55e;border-radius:12px;color:#fff;flex-shrink:0;font-size:10px;font-weight:700;margin-top:1px;padding:3px 7px;text-transform:uppercase}.gf-result-text{flex:1 1;word-break:break-word}.gf-results-hint{background:#f8fafc;border-top:1px solid #f1f5f9;color:#64748b;font-size:12px;line-height:1.5;margin:0;padding:10px 14px}.gf-actions-top{margin:8px 0 16px}.gf-resolved{color:#22c55e;font-size:12px;line-height:1.4;margin:6px 0 0}.gf-range{appearance:none;background:#e2e8f0;border-radius:3px;display:block;height:6px;margin:6px 0;outline:none;width:100%}.gf-range::-webkit-slider-thumb{-webkit-appearance:none;background:#4a90d9;border-radius:50%;cursor:pointer;height:24px;width:24px}.gf-hint{color:#64748b;display:block;font-size:12px;margin-top:2px}.gf-checkbox-row{margin-bottom:8px}.gf-checkbox-label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:10px}.gf-checkbox-label input[type=checkbox]{accent-color:#4a90d9;cursor:pointer;height:20px;width:20px}.gf-actions{background:#fff;border-top:1px solid #e5e7eb;bottom:0;box-shadow:0 -4px 12px #0000000f;display:flex;gap:12px;margin-left:-14px;margin-right:-14px;margin-top:20px;padding:14px;position:sticky;z-index:50}.gf-actions .btn{border-radius:10px;flex:1 1;font-size:15px;font-weight:700;height:50px}.gf-actions .btn-primary{background:#4a90d9;border:none;color:#fff}.gf-actions .btn-primary:active{background:#3a7bc8}.gf-actions .btn-secondary{background:#f1f5f9;border:1px solid #cbd5e1;color:#475569}.geofences-list{margin-bottom:20px}.geofences-list h3{color:#374151;font-size:1rem;margin:0 0 14px}.empty-geofences{background:#f8fafc;border:2px dashed #cbd5e1;border-radius:12px;padding:28px;text-align:center}.empty-icon{margin-bottom:10px}.empty-geofences p{color:#475569;font-weight:500;margin:0 0 6px}.empty-geofences small{color:#64748b}.geofence-items{display:flex;flex-direction:column;gap:10px}.geofence-item{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;display:flex;justify-content:space-between;padding:14px}.geofence-item.active{background:#f0fdf4;border-color:#22c55e}.geofence-item.paused{background:#fffbeb;border-color:#f59e0b}.geofence-header{align-items:center;display:flex;gap:10px;margin-bottom:4px}.geofence-header h4{color:#1e293b;font-size:1rem;margin:0}.status-badge{border-radius:20px;font-size:10px;font-weight:700;padding:2px 8px;text-transform:uppercase}.status-badge.active{background:#22c55e;color:#fff}.status-badge.paused{background:#f59e0b;color:#fff}.geofence-address{color:#64748b;font-size:12px;margin:2px 0}.geofence-radius{color:#94a3b8;font-size:11px;margin:2px 0}.apply-all-badge{background:#4a90d9;border-radius:4px;color:#fff;display:inline-block;font-size:10px;margin-top:4px;padding:2px 8px}.geofence-actions{display:flex;gap:8px}.geofence-actions button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:15px;height:36px;justify-content:center;width:36px}.toggle-btn{background:#e0e7ff}.edit-btn{background:#f3f4f6}.delete-btn{background:#fee2e2}.add-geofence-btn{margin-bottom:18px;padding:14px;width:100%}.geofence-info-section{background:#eff6ff;border-radius:12px;padding:16px}.geofence-info-section h4{color:#1e40af;font-size:14px;margin:0 0 10px}.geofence-info-section ul{color:#334155;font-size:13px;margin:0;padding-left:18px}.geofence-info-section li{margin-bottom:5px}@media (max-width:480px){.geofence-content{padding:14px}.geofence-item{align-items:flex-start;flex-direction:column;gap:10px}.geofence-actions{justify-content:flex-end;width:100%}}.journey-overlay{align-items:stretch;background:#00000080;display:flex;inset:0;justify-content:center;padding:0;position:fixed;z-index:1000}.journey-modal{background:#fff;display:flex;flex-direction:column;height:100%;overflow:hidden;width:100%}.journey-header{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:14px 16px}.journey-header h2{color:#1e293b;font-size:1.1rem;margin:0}.journey-content{-webkit-overflow-scrolling:touch;flex:1 1 auto;overflow-y:auto;padding:14px}.jm-add-btn{font-size:16px;height:50px;margin-bottom:16px;width:100%}.jm-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:20px;padding:16px}.jm-form h3{font-size:1rem;margin:0 0 12px}.jm-label{color:#374151;display:block;font-size:14px;font-weight:600;margin:12px 0 6px}.jm-input{appearance:none;background:#fff;border:2px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;display:block;font-size:16px;height:48px;padding:0 14px;width:100%}.jm-input:focus{border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d92e;outline:none}select.jm-input{background-image:url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%278%27 viewBox=%270 0 12 8%27><path d=%27M1 1l5 5 5-5%27 stroke=%27%23475569%27 stroke-width=%272%27 fill=%27none%27/></svg>");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.jm-range{margin:6px 0;width:100%}.jm-hint{color:#64748b;display:block;font-size:12px;margin-top:4px}.jm-actions{display:flex;gap:12px;margin-top:16px}.jm-actions .btn{border-radius:10px;flex:1 1;font-size:15px;font-weight:700;height:48px}.jm-list h3{color:#374151;font-size:1rem;margin:6px 0 14px}.jm-empty{background:#f8fafc;border:2px dashed #cbd5e1;border-radius:10px;color:#64748b;padding:24px;text-align:center}.jm-item{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;gap:12px;margin-bottom:10px;padding:14px}.jm-item.pending{border-left:4px solid #f59e0b}.jm-item.arrived{background:#eff6ff;border-left:4px solid #4a90d9}.jm-item.acknowledged{background:#f0fdf4;border-left:4px solid #22c55e}.jm-item.cancelled{border-left:4px solid #94a3b8;opacity:.7}.jm-item-main{flex:1 1;min-width:0}.jm-item-title{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:6px}.jm-item-title strong{color:#1e293b}.jm-status{border-radius:12px;font-size:11px;font-weight:700;padding:3px 8px;text-transform:uppercase}.jm-status.pending{background:#fef3c7;color:#92400e}.jm-status.arrived{background:#dbeafe;color:#1e40af}.jm-status.acknowledged{background:#dcfce7;color:#166534}.jm-status.cancelled{background:#f1f5f9;color:#475569}.jm-item-meta{color:#475569;display:flex;flex-wrap:wrap;font-size:12px;gap:10px;margin-bottom:4px}.jm-item-times{color:#94a3b8;font-size:11px}.jm-item-actions{display:flex;flex-direction:column;flex-shrink:0;gap:6px}.btn-tiny{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;color:#475569;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px}.btn-tiny.danger{background:#fee2e2;border-color:#fca5a5;color:#b91c1c}.parent-dashboard{box-sizing:border-box;max-width:100%;overflow-x:hidden;width:100%}.parent-theme{background-color:var(--gray-100);background-color:var(--parent-slate-100,var(--gray-100));min-height:100vh;overflow-x:hidden}.parent-theme .dashboard-header{align-items:center;background:#fff;border-bottom:1px solid var(--gray-200);box-shadow:0 1px 3px #00000014;box-sizing:border-box;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px 16px;position:sticky;top:0;width:100%;z-index:100}.parent-theme .dashboard-header h1{color:var(--gray-800);font-size:16px;font-weight:700;margin:0 0 2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.parent-theme .dashboard-header p{color:var(--gray-500);font-size:12px;margin:0}.header-content{align-items:center;display:flex;flex-direction:column;gap:8px;min-width:0;width:100%}.user-info{min-width:0;text-align:center;width:100%}.family-name{align-items:center;color:var(--gray-500);display:inline-flex;font-size:12px;font-weight:500;gap:6px;justify-content:center}.family-name:before{background:var(--success-500);border-radius:50%;content:"";flex-shrink:0;height:7px;width:7px}.logout-btn{align-self:center;font-size:13px;padding:6px 16px;white-space:nowrap}.dashboard-content{box-sizing:border-box;overflow-x:hidden;padding:12px 12px 80px;width:100%}.quick-actions-row{margin-bottom:16px}.quick-action-btn{align-items:flex-start;background:linear-gradient(135deg,#4a90d9,#6366f1);border:none;border-radius:14px;box-shadow:0 4px 12px #4a90d940;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-size:16px;font-weight:700;padding:14px 18px;text-align:left;transition:transform .15s,box-shadow .15s;width:100%}.quick-action-btn:active{box-shadow:0 2px 6px #4a90d959;transform:scale(.98)}.quick-action-sub{display:block;font-size:12px;font-weight:500;margin-top:4px;opacity:.92}.section-header{gap:8px;margin-bottom:12px}.section-header h2{color:var(--gray-800);flex:1 1;font-size:15px;font-weight:700;margin:0;min-width:0}.children-section{margin-bottom:16px;width:100%}.add-child-btn{background:var(--primary-500);border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:13px;font-weight:600;padding:6px 12px;white-space:nowrap}.add-child-btn:hover{background:var(--primary-600)}.children-list{display:flex;flex-direction:column;gap:10px;width:100%}.child-card{align-items:stretch;border:1px solid var(--gray-200);border-radius:12px;box-shadow:0 1px 3px #00000014;box-sizing:border-box;gap:12px;padding:14px;width:100%}.child-info{align-items:center;cursor:pointer;display:flex;gap:12px;width:100%}.child-avatar{background:linear-gradient(135deg,var(--primary-500) 0,var(--info-500) 100%);border-radius:10px;font-size:18px;height:44px;width:44px}.child-details{gap:2px;min-width:0}.child-details h3{color:var(--gray-800);font-size:14px;font-weight:700;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.child-details p{color:var(--gray-500);font-size:12px;margin:0}.consent-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:11px;font-weight:600;gap:3px;padding:2px 8px;white-space:nowrap}.consent-badge.pending{background:var(--warning-100);border-radius:6px;color:#b45309;height:auto;width:auto}.consent-badge.given{background:var(--success-100);color:#15803d}.location-badge{border-radius:6px;font-size:11px;font-weight:500;padding:2px 6px}.location-badge.active{background:var(--info-100);color:var(--primary-700)}.child-actions{align-items:center;gap:8px;justify-content:space-between;padding-top:10px;width:100%}.child-actions .find-location-btn{flex:1 1;justify-content:center;min-width:0}.parent-dashboard .geofence-btn,.parent-dashboard .location-toggle-btn{align-items:center;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:8px;cursor:pointer;display:flex;flex:0 0 32px;font-size:14px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.find-location-btn{align-items:center;background:var(--primary-500);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;gap:6px;height:40px;padding:0 16px;transition:background .2s}.find-location-btn:hover{background:var(--primary-600)}.find-location-btn:active{background:var(--primary-700)}.geofence-btn:hover,.location-toggle-btn:hover{background:var(--primary-500);border-color:var(--primary-500);color:#fff}.location-toggle-btn.active{background:var(--success-500);border-color:var(--success-500);color:#fff}.remove-child-btn{align-items:center;background:var(--gray-100);border:none;border:1px solid var(--gray-200);border-radius:8px;color:var(--gray-500);cursor:pointer;display:flex;flex:0 0 28px;font-size:18px;height:28px;justify-content:center;line-height:1;transition:all .2s ease;width:28px}.remove-child-btn:hover{background:var(--error-500);border-color:var(--error-500);color:#fff}.empty-children{background:#fff;border:2px dashed var(--gray-200);border-radius:12px;box-shadow:0 1px 3px #00000014;padding:32px 16px;text-align:center}.empty-icon{font-size:40px;margin-bottom:12px;opacity:.6}.empty-children h3{color:var(--gray-600);font-size:15px;font-weight:600;margin:0 0 8px}.empty-children p{color:var(--gray-500);font-size:13px;margin:0 0 16px}.activity-section{margin-bottom:16px}.activity-actions{display:flex;flex-shrink:0;gap:6px}.activity-actions .btn,.btn-sm{background:#fff;border:1px solid var(--gray-200);border-radius:8px;color:var(--gray-600);cursor:pointer;font-size:12px;font-weight:500;padding:5px 10px;transition:all .2s ease;white-space:nowrap}.activity-actions .btn:hover,.btn-sm:hover{border-color:var(--primary-500);color:var(--primary-500)}.activity-item{align-items:center;border:1px solid var(--gray-200);border-left:3px solid #0000;border-radius:10px;box-shadow:0 1px 3px #0000000f;box-sizing:border-box;cursor:pointer;gap:10px;padding:10px 12px;transition:all .2s ease;width:100%}.activity-item:hover{box-shadow:0 2px 6px #0000001a}.activity-icon{background:var(--gray-100);border-radius:8px;font-size:16px;height:36px;width:36px}.activity-text{font-weight:500;margin:0 0 2px}.activity-meta,.activity-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-meta{color:var(--gray-500);font-size:11px}.activity-status{align-items:center;display:flex;flex-shrink:0;font-size:14px;height:20px;justify-content:center;width:20px}.empty-activity{border:2px dashed var(--gray-200);border-radius:12px;box-shadow:0 1px 3px #00000014;padding:32px 16px}.test-mode-banner{align-items:center;background:linear-gradient(135deg,var(--warning-100) 0,#fde68a 100%);border:1px solid var(--warning-500);border-radius:10px;box-sizing:border-box;display:flex;gap:8px;margin-bottom:12px;padding:10px 12px;width:100%}.test-mode-banner span:nth-child(2){color:#92400e;flex:1 1;font-size:12px;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pulse-dot{animation:pulse 2s infinite;border-radius:50%;height:8px;width:8px}.pulse-dot,.stop-test-btn{background:var(--error-500);flex-shrink:0}.stop-test-btn{border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:11px;font-weight:600;padding:5px 10px}.test-mode-overlay{align-items:center;background:#0f172a99;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:1000}.test-mode-popup{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-width:360px;padding:20px;width:100%}.test-mode-popup h3{color:var(--gray-800);font-size:16px;font-weight:700;margin:0 0 12px}.test-mode-popup p{color:var(--gray-600);font-size:13px;margin:0 0 12px}.duration-selector{margin:12px 0}.duration-selector label{color:var(--gray-700);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.duration-selector select{background:#fff;border:2px solid var(--gray-200);border-radius:8px;font-size:14px;padding:10px;width:100%}.popup-actions{display:flex;gap:10px;margin-top:16px}.popup-actions .btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:10px}.popup-actions .btn-secondary{background:var(--gray-100);border:1px solid var(--gray-200);color:var(--gray-600)}.popup-actions .btn-primary{background:var(--primary-500);color:#fff}.tips-section{margin-bottom:16px}.tips-section h2{color:var(--gray-800);font-size:15px;font-weight:700;margin:0 0 10px}.tips-grid{display:flex;flex-direction:column;gap:8px}.tip-card{align-items:flex-start;background:#fff;border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 1px 3px #0000000f;display:flex;gap:10px;padding:12px}.tip-icon{flex-shrink:0;font-size:20px}.tip-card p{color:var(--gray-600);font-size:13px;line-height:1.5;margin:0}.parent-dashboard .dashboard-grid{display:flex;flex-direction:column;gap:12px}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-card{border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 1px 3px #0000000f;padding:12px}.stat-value{color:var(--gray-800);font-size:22px;margin-bottom:2px}.stat-label{font-weight:600;letter-spacing:.05em}.parent-dashboard>*{animation:slideInUp .3s ease-out forwards}.test-mode-panel{margin-bottom:12px}.test-btn{border:2px solid var(--primary-500);color:var(--primary-500);font-size:13px;padding:8px 14px}.test-mode-info{align-items:center;background:var(--warning-100);border:1px solid var(--warning-500);border-radius:8px;display:flex;gap:10px;margin-bottom:12px;padding:10px 12px}.child-management{margin:0 auto;max-width:1400px;width:100%}.children-list{margin-bottom:var(--space-8)}.children-list h2{font-size:var(--text-xl);margin-bottom:var(--space-4)}.children-grid{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.child-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-6)}.child-header{border-bottom:1px solid var(--gray-100);gap:var(--space-4);padding-bottom:var(--space-4)}.child-avatar{align-items:center;background:linear-gradient(135deg,var(--child-primary) 0,var(--child-secondary) 100%);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:var(--text-xl);font-weight:700;height:56px;justify-content:center;width:56px}.child-info{flex:1 1;min-width:0}.child-info h3{color:var(--gray-900);font-size:var(--text-lg);margin:0 0 var(--space-1) 0}.child-age{color:var(--gray-500);font-size:var(--text-sm)}.consent-status{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;padding:var(--space-2) var(--space-3);white-space:nowrap}.consent-status.active{background:var(--success-100);color:var(--success-500)}.consent-status.inactive{background:var(--gray-100);color:var(--gray-500)}.child-details{display:flex;flex-direction:column;gap:var(--space-3)}.detail-row{border-bottom:1px solid var(--gray-50);font-size:var(--text-sm);padding:var(--space-2) 0}.detail-row:last-child{border-bottom:none}.detail-label{font-weight:500}.child-actions{border-top:1px solid var(--gray-100);display:flex;gap:var(--space-3);padding-top:var(--space-4)}.child-actions .btn{justify-content:center;width:100%}.waiting-consent{background:var(--warning-50);border-radius:var(--radius-lg);color:var(--warning-500);font-size:var(--text-sm);font-weight:500;padding:var(--space-3);text-align:center;width:100%}.pending-invitations{margin-bottom:var(--space-8)}.pending-invitations h2{font-size:var(--text-xl);margin-bottom:var(--space-4)}.invitations-list{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.invitation-card{align-items:center;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);display:flex;gap:var(--space-6);padding:var(--space-6)}.invitation-info{flex:1 1}.invitation-info h4{font-size:var(--text-lg);margin:0 0 var(--space-2) 0}.invitation-info p{color:var(--gray-600);font-size:var(--text-sm);margin:0}.invitation-expires{color:var(--warning-500)!important;font-weight:500;margin-top:var(--space-2)!important}.invitation-code-section{align-items:center;display:flex;flex-direction:column;gap:var(--space-2)}.invitation-code{background:var(--gray-100);border-radius:var(--radius-lg);color:var(--gray-800);font-size:var(--text-xl);font-weight:700;letter-spacing:.1em;padding:var(--space-2) var(--space-4)}.invitation-qr{flex-shrink:0}.modal-content{max-height:90vh;overflow-y:auto}.modal-content form{padding:var(--space-6)}.consent-notice{background:var(--primary-50);border-radius:var(--radius-lg);margin-bottom:var(--space-6);padding:var(--space-4)}.consent-notice h4{color:var(--primary-700);font-size:var(--text-base);margin:0 0 var(--space-2) 0}.consent-notice p{color:var(--gray-600);font-size:var(--text-sm);margin:0}.invitation-result{padding:var(--space-6)}.success-message{margin-bottom:var(--space-6);text-align:center}.success-icon{display:block;font-size:var(--text-4xl);margin-bottom:var(--space-3)}.success-message h3{font-size:var(--text-xl);margin:0 0 var(--space-2) 0}.success-message p{color:var(--gray-600);margin:0}.invitation-details{display:flex;gap:var(--space-6);margin-bottom:var(--space-6)}.qr-container{flex-shrink:0;text-align:center}.qr-container svg{border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.qr-hint{color:var(--gray-500);font-size:var(--text-xs);margin-top:var(--space-2)}.code-container{display:flex;flex:1 1;flex-direction:column;gap:var(--space-3)}.code-container label{color:var(--gray-700);font-size:var(--text-sm);font-weight:600}.code-box{align-items:center;display:flex;gap:var(--space-3)}.code-box code{background:var(--gray-100);border-radius:var(--radius-lg);color:var(--gray-800);flex:1 1;font-size:var(--text-2xl);font-weight:700;letter-spacing:.15em;padding:var(--space-3) var(--space-4);text-align:center}.code-hint{color:var(--gray-500);font-size:var(--text-xs);margin:0}.code-hint code{background:var(--gray-100);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2)}.invitation-instructions{background:var(--gray-50);border-radius:var(--radius-lg);margin-bottom:var(--space-6);padding:var(--space-4)}.invitation-instructions h4{font-size:var(--text-base);margin:0 0 var(--space-3) 0}.invitation-instructions ol{color:var(--gray-600);font-size:var(--text-sm);margin:0;padding-left:var(--space-5)}.invitation-instructions li{margin-bottom:var(--space-2)}.empty-state{margin:0 auto;max-width:600px}.empty-state h3{font-size:var(--text-xl);margin:0 0 var(--space-2) 0}@media (max-width:768px){.page-header{align-items:flex-start;flex-direction:column;gap:var(--space-4)}.invitation-card{text-align:center}.invitation-card,.invitation-details{flex-direction:column}.children-grid,.invitations-list{grid-template-columns:1fr}}.child-profile{background:#f0f4f8;max-width:100%;min-height:100vh;overflow-x:hidden;padding:12px 12px 90px;width:100%}.loading-state{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:200px}.spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-top-color:#4a90d9;height:32px;width:32px}.profile-header{background:#fff;border-radius:16px;box-shadow:0 1px 4px #00000014;margin-bottom:12px;padding:16px}.profile-header-content{display:flex;flex-direction:column;gap:14px}.child-identity{align-items:center;display:flex;gap:14px}.profile-avatar{background:linear-gradient(135deg,#4a90d9,#357abd);font-size:20px;height:52px;min-width:52px;width:52px}.profile-info{flex:1 1;min-width:0}.profile-info h1{color:#1e293b;font-size:17px;font-weight:700;margin:0 0 3px}.profile-info h1,.profile-meta{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-meta{color:#64748b;font-size:12px;margin:0 0 8px}.profile-badges{display:flex;flex-wrap:wrap;gap:5px}.badge{border-radius:20px;font-size:11px;font-weight:600;padding:3px 9px;white-space:nowrap}.badge-success{background:#dcfce7;color:#166534}.badge-warning{background:#fef3c7;color:#92400e}.badge-error{background:#fee2e2;color:#dc2626}.badge-info{background:#dbeafe;color:#1e40af}.profile-actions{display:flex;flex-direction:column;gap:8px}.btn{align-items:center;border-radius:10px;display:flex;font-weight:600;justify-content:center;padding:11px 16px;transition:background .2s;white-space:nowrap;width:100%}.btn-primary{background:#4a90d9}.btn-primary:hover{background:#357abd}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#f1f5f9;color:#334155}.btn-secondary:hover{background:#e2e8f0}.child-profile .location-toggle-btn{cursor:pointer;display:flex;margin:0;width:100%}.child-profile .location-toggle-btn input{display:none}.child-profile .toggle-label{background:#f1f5f9;border-radius:10px;color:#334155;display:block;flex:1 1;font-size:14px;font-weight:600;padding:11px 16px;text-align:center;transition:background .2s;white-space:nowrap}.child-profile .location-toggle-btn input:checked+.toggle-label{background:#dbeafe;color:#1e40af}.stats-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:12px}.stat-card{background:#fff;border-radius:12px;border-top:3px solid #4a90d9;box-shadow:0 1px 4px #00000012;padding:16px 12px;text-align:center}.stat-card.warning{border-top-color:#f59e0b}.stat-card.danger{border-top-color:#ef4444}.stat-card.info{border-top-color:#8b5cf6}.stat-value{color:#1e293b;display:block;font-size:28px;font-weight:700;line-height:1}.stat-label{color:#64748b;display:block;font-size:11px;letter-spacing:.3px;margin-top:5px;text-transform:uppercase}.profile-tabs{-webkit-overflow-scrolling:touch;background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000012;display:flex;gap:0;margin-bottom:12px;overflow-x:auto;scrollbar-width:none}.profile-tabs::-webkit-scrollbar{display:none}.tab-btn{border-radius:12px;color:#64748b;flex-shrink:0;font-size:13px;padding:12px 16px;white-space:nowrap}.tab-btn:active{background:#f1f5f9}.tab-btn.active{background:#4a90d9;color:#fff;font-weight:600}.tab-content{border-radius:16px;box-shadow:0 1px 4px #00000012;overflow-x:hidden;padding:16px}.child-profile .overview-grid{display:flex!important;flex-direction:column!important;gap:12px}.child-profile .overview-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:block!important;padding:16px;width:100%}.child-profile .overview-card h3{border-bottom:1px solid #e2e8f0;color:#1e293b;display:block;font-size:14px;font-weight:700;margin:0 0 14px;padding-bottom:10px;width:100%}.mini-activity-list{background:#fff;border:1px solid #e2e8f0;border-radius:10px;display:flex;flex-direction:column;gap:0;overflow:hidden}.mini-activity-item{align-items:flex-start;background:#fff;border-bottom:1px solid #f1f5f9;cursor:pointer;display:flex;gap:10px;padding:12px;transition:background .15s}.mini-activity-item:last-child{border-bottom:none}.mini-activity-item:active{background:#f8fafc}.mini-activity-item.warning{border-left:3px solid #f59e0b}.mini-activity-item.blocked{border-left:3px solid #ef4444}.mini-activity-item.info{border-left:3px solid #3b82f6}.activity-icon{font-size:18px;line-height:1.4}.activity-text{color:#334155;flex:1 1;font-size:13px;line-height:1.4;min-width:0;overflow-wrap:break-word;word-break:break-word}.activity-time{color:#94a3b8;flex-shrink:0;font-size:11px;padding-top:2px;white-space:nowrap}.view-all-btn{background:#0000;border:1px dashed #cbd5e1;border-radius:8px;color:#4a90d9;cursor:pointer;font-size:13px;font-weight:600;margin-top:10px;padding:11px;width:100%}.view-all-btn:active{background:#f1f5f9}.info-list{gap:0}.info-item,.info-list{display:flex;flex-direction:column}.info-item{border-bottom:1px solid #e2e8f0;gap:3px;padding:11px 0}.info-item:last-child{border-bottom:none}.info-label{color:#94a3b8;font-size:11px;font-weight:600;letter-spacing:.4px;text-transform:uppercase}.info-value{color:#1e293b;font-size:14px;overflow-wrap:break-word;word-break:break-word}.status-active{color:#16a34a}.status-pending{color:#ca8a04}.empty-text{color:#94a3b8;font-size:13px;padding:20px 0;text-align:center}.st-help{color:#64748b;font-size:13px;line-height:1.5;margin:0 0 14px}.st-row{flex-direction:column}.st-inputs,.st-row{display:flex;gap:10px;width:100%}.st-field{display:flex;flex:1 1;flex-direction:column;gap:5px;min-width:0}.st-field label{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.st-field input{-moz-appearance:textfield;background:#fff;border:1px solid #e2e8f0;border-radius:10px;color:#1e293b;font-size:20px;font-weight:700;padding:12px 8px;text-align:center;width:100%}.st-field input::-webkit-inner-spin-button,.st-field input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.st-field input:focus{border-color:#4a90d9;outline:none}.st-save{background:#4a90d9;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;height:46px;padding:0;width:100%}.st-save:disabled{cursor:not-allowed;opacity:.6}.st-toast{background:#ecfdf5;border-radius:8px;color:#047857;font-size:13px;font-weight:500;margin-top:10px;padding:9px 12px}.activity-section{width:100%}.activity-list{gap:8px}.activity-card{align-items:flex-start;background:#f8fafc;border:1px solid #e2e8f0;border-left-width:4px;border-radius:12px;cursor:pointer;display:flex;gap:12px;padding:14px 12px;transition:background .15s}.activity-card:active{background:#f1f5f9}.activity-card.warning{border-left-color:#f59e0b}.activity-card.blocked{border-left-color:#ef4444}.activity-card.info{border-left-color:#3b82f6}.activity-card.new{background:#eff6ff}.activity-card-icon{align-items:center;background:#fff;border-radius:9px;box-shadow:0 1px 3px #00000014;display:flex;flex-shrink:0;font-size:18px;height:36px;justify-content:center;width:36px}.activity-card-content{flex:1 1;min-width:0}.activity-card-text{color:#334155;font-size:13px;line-height:1.45;margin:0 0 7px;overflow-wrap:break-word;word-break:break-word}.activity-card-meta{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.type-badge{border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.3px;padding:2px 8px;text-transform:uppercase}.type-badge.warning{background:#fef3c7;color:#92400e}.type-badge.blocked{background:#fee2e2;color:#dc2626}.type-badge.info{background:#dbeafe;color:#1e40af}.activity-card-app{color:#64748b;font-size:11px}.activity-card-time{color:#94a3b8;font-size:11px}.new-indicator{color:#3b82f6;flex-shrink:0;font-size:14px}.patterns-section{width:100%}.patterns-list{gap:10px}.pattern-card{align-items:flex-start;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;gap:12px;padding:14px}.pattern-icon{align-items:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:10px;display:flex;flex-shrink:0;font-size:18px;height:40px;justify-content:center;width:40px}.pattern-content{flex:1 1;min-width:0}.pattern-content h4{color:#1e293b;font-size:14px;font-weight:600;margin:0 0 5px;overflow-wrap:break-word}.pattern-confidence{color:#64748b;font-size:12px;margin:0 0 3px}.pattern-time{color:#94a3b8;font-size:11px}.location-section,.location-status-card{width:100%}.location-status-card h3{color:#1e293b;font-size:15px;font-weight:700;margin:0 0 14px}.location-status{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;gap:12px;margin-bottom:14px;padding:14px}.location-status.active{background:#dcfce7;border-color:#bbf7d0}.location-status.disabled{background:#fee2e2;border-color:#fecaca}.status-icon{font-size:22px}.status-text{color:#1e293b;font-size:14px;font-weight:600}.location-details{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:14px;padding:14px}.location-coordinate{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;gap:12px;justify-content:space-between;padding:8px 0}.location-coordinate:last-child{border-bottom:none}.coord-label{color:#64748b;flex-shrink:0;font-size:13px}.coord-value{color:#334155;font-family:monospace;font-size:13px;font-weight:600;text-align:right}.location-updated{border-top:1px solid #e2e8f0;color:#94a3b8;font-size:12px;margin-top:10px;padding-top:10px}.location-actions{display:flex;flex-direction:column;gap:10px}.empty-state{padding:48px 20px}.empty-icon{font-size:44px;margin-bottom:14px}.empty-state h3{color:#334155;font-size:16px;font-weight:700;margin:0 0 6px}.empty-state p{color:#64748b;font-size:13px;line-height:1.5}.modal-overlay{align-items:flex-end;animation:fadeIn .2s ease;background:#0f172a80;z-index:2000}.modal-content{animation:slideUp .25s cubic-bezier(.22,1,.36,1);border-radius:20px 20px 0 0;box-shadow:0 -8px 32px #00000026;display:flex;flex-direction:column;max-height:92vh;padding-bottom:env(safe-area-inset-bottom,0)}.modal-content .modal-header{flex-shrink:0}.modal-content .event-modal-body{-webkit-overflow-scrolling:touch;flex:1 1 auto;overflow-y:auto;overscroll-behavior:contain;padding-bottom:24px}.modal-content:before{background:#cbd5e1;border-radius:2px;content:"";display:block;height:4px;margin:12px auto 0;width:40px}.modal-header{border-bottom:1px solid #f1f5f9;gap:12px;padding:14px 16px}.event-modal-header{flex:1 1;gap:12px;min-width:0}.event-modal-icon{border-radius:10px;flex-shrink:0;font-size:20px;height:40px;width:40px}.event-modal-icon.warning{background:#fef3c7}.event-modal-icon.blocked{background:#fee2e2}.event-modal-icon.info{background:#dbeafe}.event-modal-header h2{color:#1e293b;font-size:16px;font-weight:700;margin:0 0 3px}.event-modal-type{border-radius:4px;display:inline-block;font-size:10px;padding:2px 8px;text-transform:uppercase}.event-modal-type.warning{background:#fef3c7;color:#92400e}.event-modal-type.blocked{background:#fee2e2;color:#dc2626}.event-modal-type.info{background:#dbeafe;color:#1e40af}.modal-close{background:#f1f5f9;border:none;border-radius:8px;cursor:pointer;flex-shrink:0;font-size:16px;height:34px;width:34px}.modal-close:active{background:#e2e8f0}.event-modal-body{-webkit-overflow-scrolling:touch;max-height:calc(92vh - 110px);overflow-y:auto;padding:16px}.event-detail-section{margin-bottom:16px}.event-detail-section h4{color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:.5px;margin:0 0 8px}.event-detail-section p{color:#334155;font-size:14px;line-height:1.55;overflow-wrap:break-word}.event-detail-grid{grid-gap:8px;gap:8px;grid-template-columns:1fr 1fr;margin-bottom:16px}.event-detail-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;gap:4px;padding:10px 12px}.detail-label{color:#94a3b8;font-size:10px;font-weight:600;letter-spacing:.5px}.detail-value{color:#1e293b;font-size:13px;overflow-wrap:break-word}.detail-value.severity-high{color:#dc2626}.detail-value.severity-medium{color:#ea580c}.detail-value.severity-low{color:#16a34a}.detail-value.status-new{color:#dc2626}.detail-value.status-viewed{color:#ea580c}.detail-value.status-resolved{color:#16a34a}.event-resolution{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:12px;padding:14px}.event-resolution h4{color:#1e293b;font-size:13px;font-weight:700;margin:0 0 10px}.form-textarea{background:#fff;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;margin-bottom:10px;padding:11px 12px;width:100%}.form-textarea:focus{border-color:#4a90d9;outline:none}.event-resolution-display{background:#dcfce7;border:1px solid #bbf7d0;border-radius:12px;padding:14px}.event-resolution-display h4{color:#166534;font-size:13px;font-weight:700;margin:0 0 6px}.event-resolution-display p{color:#166534;font-size:13px;margin:0 0 6px;overflow-wrap:break-word}.resolution-time{color:#16a34a;font-size:11px}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.language-selector{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:var(--space-6);padding:var(--space-6)}.language-selector h3{color:var(--gray-800);font-size:var(--text-lg);margin:0 0 var(--space-2) 0}.language-desc{color:var(--gray-600);font-size:var(--text-sm);margin:0 0 var(--space-4) 0}.language-options{display:flex;flex-wrap:wrap;gap:var(--space-3)}.language-option{align-items:center;background:var(--gray-50);border:2px solid var(--gray-200);border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:var(--space-3);min-width:140px;padding:var(--space-4) var(--space-5);transition:all .2s ease}.language-option:hover{background:var(--gray-100);border-color:var(--gray-300)}.language-option.active{background:var(--primary-50);border-color:var(--primary-500)}.language-flag{font-size:var(--text-2xl)}.language-name{color:var(--gray-800);flex:1 1;font-size:var(--text-base);font-weight:500}.language-option.active .language-name{color:var(--primary-700)}.language-check{color:var(--primary-500);font-size:var(--text-lg);font-weight:700}@media (max-width:640px){.language-selector{padding:var(--space-4)}.language-options{flex-direction:column}.language-option{justify-content:flex-start;width:100%}}.settings-page{margin:0 auto;max-width:1200px}.settings-grid{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(2,1fr)}.settings-card{overflow:hidden}.settings-card .card-header{border-bottom:1px solid var(--gray-100);padding:var(--space-6)}.settings-card .card-header h3{font-size:var(--text-lg);margin:0}.setting-item,.settings-list{padding:var(--space-4)}.setting-item{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between}.setting-item:last-child{border-bottom:none}.setting-info{display:flex;flex-direction:column;gap:var(--space-1)}.setting-name{color:var(--gray-800);font-weight:600}.setting-desc{color:var(--gray-500);font-size:var(--text-sm)}.setting-select{min-width:200px;width:auto}.toggle-switch{display:inline-block;height:28px;position:relative;width:52px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background:var(--gray-300);border-radius:var(--radius-full);cursor:pointer;inset:0;position:absolute;transition:background var(--transition-fast)}.toggle-slider:before{background:#fff;border-radius:50%;bottom:3px;box-shadow:var(--shadow-sm);content:"";height:22px;left:3px;position:absolute;transition:transform var(--transition-fast);width:22px}.toggle-switch input:checked+.toggle-slider{background:var(--primary-500)}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(24px)}.keywords-card{grid-column:span 2}.keywords-section{border-bottom:1px solid var(--gray-100);padding:var(--space-6)}.keywords-section:last-child{border-bottom:none}.keywords-section h4{font-size:var(--text-base);margin:0 0 var(--space-2) 0}.section-desc{color:var(--gray-500);font-size:var(--text-sm);margin:0 0 var(--space-4) 0}.keyword-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.keyword-tag{align-items:center;display:inline-flex;gap:var(--space-1)}.keyword-tag.blocked{background:var(--error-100);color:var(--error-500)}.keyword-tag.warning{background:var(--warning-100);color:var(--warning-500)}.keyword-tag.custom{background:var(--primary-100);color:var(--primary-600)}.remove-keyword{align-items:center;background:#0000001a;border-radius:50%;color:currentColor;cursor:pointer;display:flex;font-size:10px;height:18px;justify-content:center;transition:all var(--transition-fast);width:18px}.remove-keyword:hover{background:#0003}.add-keyword-form{display:flex;gap:var(--space-3);margin-bottom:var(--space-4)}.add-keyword-form .form-input{flex:1 1}.add-keyword-form .form-select{width:140px}.info-box{border-bottom:1px solid var(--gray-100);padding:var(--space-6)}.info-box:last-child{border-bottom:none}.info-box h4{margin:0 0 var(--space-3) 0}.info-box p{line-height:1.6}.info-box li{margin-bottom:var(--space-2)}.info-box.privacy{background:linear-gradient(135deg,var(--primary-50) 0,#fff 100%)}@media (max-width:1024px){.settings-grid{grid-template-columns:1fr}.keywords-card{grid-column:span 1}}@media (max-width:640px){.setting-item{align-items:flex-start;flex-direction:column;gap:var(--space-3)}.setting-select{width:100%}.add-keyword-form{flex-direction:column}.add-keyword-form .form-select{width:100%}}.reports-page{margin:0 auto;max-width:1400px}.report-generator{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:var(--space-8);padding:var(--space-6)}.report-generator h3{font-size:var(--text-lg);margin:0 0 var(--space-4) 0}.generator-form{grid-gap:var(--space-4);align-items:flex-end;display:grid;gap:var(--space-4);grid-template-columns:repeat(4,1fr)}.generator-form .form-group{margin:0}.generator-form .btn{height:46px}.reports-list h3{font-size:var(--text-xl);margin:0 0 var(--space-4) 0}.reports-grid{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(380px,1fr));margin-bottom:var(--space-8)}.report-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden}.report-header{align-items:center;background:var(--primary-50);display:flex;gap:var(--space-4);padding:var(--space-6)}.report-icon{font-size:var(--text-2xl)}.report-info h4{font-size:var(--text-base);margin:0 0 var(--space-1) 0}.report-type{color:var(--primary-600);font-weight:600;letter-spacing:.05em;text-transform:uppercase}.report-date,.report-type{display:block;font-size:var(--text-xs)}.report-date{color:var(--gray-500);margin-top:var(--space-1)}.report-summary{border-bottom:1px solid var(--gray-100);display:grid;grid-template-columns:repeat(3,1fr);padding:var(--space-4)}.summary-item{padding:var(--space-3);text-align:center}.summary-item:not(:last-child){border-right:1px solid var(--gray-100)}.summary-value{color:var(--primary-500);display:block;font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-1)}.summary-value.warning{color:var(--warning-500)}.summary-value.error{color:var(--error-500)}.summary-label{color:var(--gray-500);font-size:var(--text-xs);text-transform:uppercase}.report-prompts{background:var(--success-50);border-bottom:1px solid var(--gray-100);padding:var(--space-4)}.report-prompts h5{color:var(--success-700);font-size:var(--text-sm);margin:0 0 var(--space-3) 0}.report-prompts ul{color:var(--gray-700);font-size:var(--text-sm);margin:0;padding-left:var(--space-4)}.report-prompts li{margin-bottom:var(--space-2)}.report-actions{display:flex;gap:var(--space-2);padding:var(--space-4)}.report-actions .btn{flex:1 1}.stats-overview{margin-top:var(--space-8)}.stats-overview h3{font-size:var(--text-xl);margin:0 0 var(--space-4) 0}.stats-children{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.child-stat-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-6)}.child-stat-header{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-4)}.child-stat-header .child-avatar{align-items:center;background:var(--primary-500);border-radius:50%;color:#fff;display:flex;font-weight:600;height:40px;justify-content:center;width:40px}.child-stat-header span{color:var(--gray-800);font-weight:600}.child-stat-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(3,1fr)}.child-stat{text-align:center}.child-stat .stat-num{color:var(--primary-500);display:block;font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-1)}.child-stat .stat-num.warning{color:var(--warning-500)}.child-stat .stat-num.error{color:var(--error-500)}.child-stat .stat-label{color:var(--gray-500);font-size:var(--text-xs);text-transform:uppercase}@media (max-width:1024px){.generator-form{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.generator-form{grid-template-columns:1fr}.generator-form .btn{width:100%}.reports-grid,.stats-children{grid-template-columns:1fr}.report-actions{flex-direction:column}}.alerts-page{margin:0 auto;max-width:1400px}.ai-reason{font-size:12px;margin:6px 0;padding:7px 10px}.ai-badge{font-size:12px;font-weight:700}.new-alerts-badge{align-items:center;display:flex}.patterns-section{margin-bottom:var(--space-8)}.patterns-section h3{font-size:var(--text-lg);margin:0 0 var(--space-4) 0}.patterns-list{display:flex;flex-direction:column;gap:var(--space-4)}.pattern-alert{background:linear-gradient(135deg,var(--warning-50) 0,#fff 100%);border:1px solid var(--warning-200);gap:var(--space-4);padding:var(--space-5)}.pattern-alert,.pattern-alert-icon{align-items:center;border-radius:var(--radius-xl);display:flex}.pattern-alert-icon{background:var(--warning-100);flex-shrink:0;font-size:var(--text-2xl);height:56px;justify-content:center;width:56px}.pattern-alert-content{flex:1 1}.pattern-alert-content h4{color:var(--gray-800);font-size:var(--text-base);margin:0 0 var(--space-2) 0}.pattern-alert-content p{color:var(--gray-600);font-size:var(--text-sm);margin:0 0 var(--space-2) 0}.pattern-time{color:var(--gray-500);font-size:var(--text-xs)}.pattern-alert-actions{flex-shrink:0}.alerts-filters{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-6)}.filter-btn{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-full);color:var(--gray-600);cursor:pointer;font-size:var(--text-sm);font-weight:500;padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.filter-btn:hover{border-color:var(--primary-300);color:var(--primary-600)}.filter-btn.active{background:var(--primary-500);border-color:var(--primary-500);color:#fff}.events-list{display:flex;flex-direction:column;gap:var(--space-3)}.event-card{align-items:center;background:#fff;border-left:4px solid #0000;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);cursor:pointer;display:flex;gap:var(--space-4);padding:var(--space-5);transition:all var(--transition-fast)}.event-card:hover{box-shadow:var(--shadow-md);transform:translateX(4px)}.event-card.new{background:var(--primary-50);border-left-color:var(--primary-500)}.event-card.warning{border-left-color:var(--warning-500)}.event-card.blocked{background:var(--error-50);border-left-color:var(--error-500)}.event-card.info{border-left-color:var(--info-500)}.event-type-icon{align-items:center;border-radius:var(--radius-lg);display:flex;flex-shrink:0;font-size:var(--text-xl);height:48px;justify-content:center;width:48px}.event-type-icon.warning{background:var(--warning-100)}.event-type-icon.blocked{background:var(--error-100)}.event-type-icon.info{background:var(--info-100)}.event-details{flex:1 1;min-width:0}.event-header{align-items:center;display:flex;gap:var(--space-3);margin-bottom:var(--space-2)}.event-header h4{color:var(--gray-800);font-size:var(--text-base);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.new-badge{background:var(--primary-500);border-radius:var(--radius-full);color:#fff;flex-shrink:0;font-size:var(--text-xs);font-weight:600;padding:var(--space-1) var(--space-2);text-transform:uppercase}.event-meta{color:var(--gray-500);display:flex;font-size:var(--text-sm);gap:var(--space-4)}.child-name{color:var(--primary-600);font-weight:500}.event-app{background:var(--gray-100);border-radius:var(--radius-sm);font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}.event-arrow{color:var(--gray-400)}.event-modal{max-width:600px}.event-modal-header{align-items:center;display:flex;gap:var(--space-4)}.event-modal-icon{align-items:center;border-radius:var(--radius-xl);display:flex;font-size:var(--text-2xl);height:56px;justify-content:center;width:56px}.event-modal-icon.warning{background:var(--warning-100)}.event-modal-icon.blocked{background:var(--error-100)}.event-modal-icon.info{background:var(--info-100)}.event-modal-header h2{font-size:var(--text-xl);margin:0}.event-modal-type{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;padding:var(--space-1) var(--space-2)}.event-modal-type.warning{background:var(--warning-100);color:var(--warning-600)}.event-modal-type.blocked{background:var(--error-100);color:var(--error-600)}.event-modal-type.info{background:var(--info-100);color:var(--info-600)}.event-modal-body{padding:var(--space-6)}.event-detail-section{margin-bottom:var(--space-6)}.event-detail-section h4{color:var(--gray-500);font-size:var(--text-sm);letter-spacing:.05em;margin:0 0 var(--space-2) 0;text-transform:uppercase}.event-detail-section p{color:var(--gray-800);font-size:var(--text-base);line-height:1.6;margin:0}.event-detail-grid{grid-gap:var(--space-4);background:var(--gray-50);border-radius:var(--radius-lg);display:grid;gap:var(--space-4);grid-template-columns:repeat(2,1fr);margin-bottom:var(--space-6);padding:var(--space-4)}.event-detail-item{display:flex;flex-direction:column;gap:var(--space-1)}.detail-label{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase}.detail-value{font-weight:600}.detail-value.severity-high{color:var(--error-500)}.detail-value.severity-medium{color:var(--warning-500)}.detail-value.severity-low{color:var(--success-500)}.detail-value.status-new{color:var(--primary-500)}.detail-value.status-resolved{color:var(--success-500)}.event-resolution{border-top:1px solid var(--gray-200);margin-top:var(--space-6);padding-top:var(--space-6)}.event-resolution h4{color:var(--gray-500);font-size:var(--text-sm);letter-spacing:.05em;margin:0 0 var(--space-3) 0;text-transform:uppercase}.event-resolution textarea{margin-bottom:var(--space-4)}.event-resolution-display{background:var(--success-50);border-radius:var(--radius-lg);margin-top:var(--space-6);padding:var(--space-4)}.event-resolution-display h4{color:var(--success-700);font-size:var(--text-sm);margin:0 0 var(--space-2) 0}.event-resolution-display p{color:var(--gray-700);font-size:var(--text-base);margin:0 0 var(--space-2) 0}.resolution-time{color:var(--gray-500);font-size:var(--text-xs)}.empty-state{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-12)}.empty-state h4{font-size:var(--text-xl);margin:0 0 var(--space-2) 0}.empty-state p{color:var(--gray-600);margin:0}@media (max-width:768px){.pattern-alert{align-items:flex-start;flex-direction:column}.event-detail-grid{grid-template-columns:1fr}.event-meta{flex-wrap:wrap}}.parent-support{margin:0 auto;max-width:1400px}.page-header{margin-bottom:var(--space-8)}.page-header h1{color:var(--gray-800)}.page-header p{font-size:var(--text-lg)}.emergency-banner{margin-bottom:var(--space-8);padding:var(--space-6)}.parent-emergency{background:linear-gradient(135deg,#dc2626,#b91c1c)}.emergency-banner h3,.emergency-banner p{color:#fff}.support-grid{grid-gap:var(--space-8);gap:var(--space-8)}@media (max-width:1024px){.support-grid{grid-template-columns:1fr}}.support-card{padding:var(--space-6)}.card-header{border-bottom:1px solid var(--gray-200);margin-bottom:var(--space-6)}.card-header h2{color:var(--gray-800);font-size:var(--text-xl);margin:0 0 var(--space-2) 0}.card-header p{color:var(--gray-600);font-size:var(--text-base);margin:0}.form-label{color:var(--gray-700);display:block;font-size:var(--text-sm);font-weight:500;margin-bottom:var(--space-2)}.form-input,.form-select,.form-textarea{border:2px solid var(--gray-200);border-radius:var(--radius-lg);box-sizing:border-box;font-size:var(--text-base);padding:var(--space-3) var(--space-4);transition:border-color .2s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-500);outline:none}.form-textarea{font-family:inherit;resize:vertical}.resources-list{display:flex;flex-direction:column;gap:var(--space-5)}.resource-item{background:var(--primary-50);border-left:4px solid var(--primary-500);border-radius:var(--radius-lg)}.resource-item h4{color:var(--gray-800);font-size:var(--text-lg)}.resource-contact{flex-wrap:wrap}.resource-link{background:var(--primary-500);border-radius:var(--radius-md);gap:var(--space-2);padding:var(--space-2) var(--space-4);transition:background .2s}.resource-link:hover{background:var(--primary-600)}.faqs-section{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-6)}.faqs-section h2{color:var(--gray-800);margin:0 0 var(--space-6) 0}.faq-item{border:1px solid var(--gray-200);border-radius:var(--radius-lg)}.faq-question{background:var(--gray-50);gap:var(--space-3);padding:var(--space-4)}.faq-question:before{color:var(--primary-500);content:"▶";font-size:var(--text-xs);transition:transform .2s}.faq-item[open] .faq-question:before{transform:rotate(90deg)}.faq-answer{background:#fff;padding:var(--space-4)}.communication-section{margin-bottom:var(--space-8)}.communication-card{align-items:flex-start;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;border-radius:var(--radius-xl);display:flex;gap:var(--space-5);padding:var(--space-6)}.communication-icon{flex-shrink:0;font-size:var(--text-4xl)}.communication-card h3{color:#065f46;font-size:var(--text-lg);margin:0 0 var(--space-2) 0}.communication-card p{color:#047857;line-height:1.6;margin:0 0 var(--space-4) 0}.tips-list{color:#047857;margin:0;padding-left:var(--space-5)}.tips-list li{margin-bottom:var(--space-2)}.tips-list li:last-child{margin-bottom:0}.btn-lg{font-size:var(--text-base);padding:var(--space-4) var(--space-6)}@media (max-width:640px){.page-header h1{font-size:var(--text-xl)}.support-card{padding:var(--space-4)}.emergency-banner{text-align:center}.communication-card,.emergency-banner,.resource-contact{flex-direction:column}.communication-card{text-align:center}}.screen-time-page{margin:0 auto;max-width:760px}.screen-time-loading{color:var(--gray-500);font-size:var(--text-sm);padding:var(--space-8);text-align:center}.screen-time-list{display:flex;flex-direction:column;gap:var(--space-3);list-style:none;margin:0;padding:0}.screen-time-row{grid-gap:var(--space-4);align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);display:grid;gap:var(--space-4);grid-template-columns:1fr auto auto;padding:var(--space-4) var(--space-5);transition:box-shadow var(--transition-fast)}.screen-time-row:hover{box-shadow:var(--shadow-md)}.screen-time-row__name{color:var(--gray-800);font-size:var(--text-base);font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.screen-time-row__inputs{display:flex;gap:var(--space-2)}.screen-time-input{align-items:center;display:inline-flex;position:relative}.screen-time-input input{background:#fff;border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);font-size:var(--text-base);padding:var(--space-2) 38px var(--space-2) var(--space-3);text-align:right;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:84px}.screen-time-input input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100);outline:none}.screen-time-input input::-webkit-inner-spin-button,.screen-time-input input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.screen-time-input input[type=number]{-moz-appearance:textfield}.screen-time-input__suffix{color:var(--gray-500);font-size:var(--text-xs);font-weight:500;letter-spacing:.05em;pointer-events:none;position:absolute;right:var(--space-3);text-transform:uppercase}.screen-time-row__save{justify-content:center;min-width:88px}@media (max-width:640px){.screen-time-row{gap:var(--space-3);grid-template-columns:1fr}.screen-time-row__inputs{justify-content:flex-start}.screen-time-row__save{width:100%}}.permission-modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.permission-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:450px;overflow-y:auto;padding:24px;width:100%}.permission-header{margin-bottom:24px;text-align:center}.permission-header h2{color:#1f2937;font-size:1.5rem;margin-bottom:8px}.permission-header p{color:#6b7280;font-size:.95rem}.permission-list{margin-bottom:24px}.permission-item{transition:all .2s}.permission-item.warning{background:#fef3c7;border-color:#f59e0b}.permission-icon{font-size:28px}.permission-actions{display:flex;flex-direction:column;gap:12px}.permission-actions .btn{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;padding:14px 24px;transition:all .2s}.permission-actions .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.permission-actions .btn-primary:hover{box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.permission-actions .btn-secondary{background:#f3f4f6;color:#4b5563}.permission-actions .btn-secondary:hover{background:#e5e7eb}.permission-actions .btn-text{background:#0000;color:#9ca3af}.permission-note{background:#fffbeb;border-radius:8px;margin-top:16px;padding:12px;text-align:center}.permission-note p{color:#92400e;font-size:.85rem;margin:0}.permission-checking{align-items:center;background:#fffffff2;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.permission-checking p{color:#6b7280;margin-top:16px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#667eea;height:48px;width:48px}@media (prefers-color-scheme:dark){.permission-modal{background:#1f2937}.permission-header h2{color:#f9fafb}.permission-header p{color:#9ca3af}.permission-item{background:#374151}.permission-item.granted{background:#10b98133}.permission-item.denied{background:#f8717133}.permission-info h3{color:#f9fafb}.permission-info p{color:#9ca3af}.permission-actions .btn-secondary{background:#374151;color:#d1d5db}.permission-checking{background:#1f2937f2}.permission-checking p{color:#9ca3af}}.native-monitoring-modal-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.native-monitoring-modal{background:#fff;border-radius:16px;max-height:90vh;max-width:450px;overflow-y:auto;padding:24px;width:100%}.modal-header{margin-bottom:20px;text-align:center}.modal-header h2{color:#1f2937;font-size:1.5rem;margin-bottom:8px}.modal-header p{color:#6b7280;font-size:.95rem}.permission-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.permission-item{align-items:center;background:#f9fafb;border:2px solid #0000;border-radius:12px;display:flex;padding:16px}.permission-item.granted{background:#d1fae5;border-color:#10b981}.permission-item.denied{background:#fef2f2;border-color:#f87171}.permission-icon{font-size:24px;margin-right:16px}.permission-info{flex:1 1}.permission-info h3{color:#1f2937;font-size:1rem;margin-bottom:4px}.permission-info p{color:#6b7280;font-size:.85rem}.permission-status{font-size:24px}.keyword-info{background:#f3f4f6;border-radius:12px;margin-bottom:20px;padding:16px}.keyword-info h4{color:#4b5563;font-size:.9rem;margin-bottom:12px}.keyword-tags{gap:8px}.tag{border-radius:20px;font-size:.85rem;font-weight:500;padding:6px 12px}.tag.blocked{background:#fecaca;color:#dc2626}.tag.warning{background:#fde68a;color:#d97706}.modal-actions{flex-direction:column;gap:12px;margin-bottom:16px}.modal-actions .btn{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;padding:14px 24px;transition:all .2s}.modal-actions .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-actions .btn-primary:hover{box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.modal-actions .btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.modal-actions .btn-secondary{background:#f3f4f6;color:#4b5563}.privacy-note{background:#e0f2fe;border-radius:8px;padding:16px;text-align:center}.privacy-note p{color:#0369a1;font-size:.85rem;margin:4px 0}.native-monitoring-active{padding:16px}.monitoring-status-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000001a;display:flex;gap:16px;margin-bottom:16px;padding:24px}.monitoring-status-card.active{border-left:4px solid #10b981}.status-icon{font-size:48px}.status-content h3{color:#1f2937;font-size:1.2rem;margin-bottom:8px}.status-content p{color:#6b7280;font-size:.9rem;margin-bottom:12px}.monitoring-features{list-style:none;margin:0;padding:0}.monitoring-features li{color:#4b5563;font-size:.9rem;padding:6px 0}.monitoring-actions{display:flex;gap:12px;justify-content:center}.monitoring-actions .btn{border:none;border-radius:8px;cursor:pointer;font-size:.9rem;padding:10px 20px}.monitoring-actions .btn-secondary{background:#f3f4f6;color:#4b5563}.monitoring-actions .btn-text{background:#0000;color:#9ca3af}.native-monitoring-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px}.spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#667eea;height:40px;width:40px}.native-monitoring-toggle{padding:16px;text-align:center}.native-monitoring-toggle .btn-outline{background:#0000;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .2s}.native-monitoring-toggle .btn-outline:hover{background:#667eea;color:#fff}@media (prefers-color-scheme:dark){.native-monitoring-modal{background:#1f2937}.modal-header h2{color:#f9fafb}.modal-header p{color:#9ca3af}.permission-item{background:#374151}.permission-item.granted{background:#10b98133}.permission-item.denied{background:#f8717133}.permission-info h3{color:#f9fafb}.permission-info p{color:#9ca3af}.keyword-info{background:#374151}.keyword-info h4{color:#d1d5db}.modal-actions .btn-secondary{background:#374151;color:#d1d5db}.monitoring-status-card{background:#374151}.status-content h3{color:#f9fafb}.status-content p{color:#9ca3af}.monitoring-features li{color:#d1d5db}}.child-theme .child-dashboard{margin:0 auto;max-width:1000px;padding:var(--space-4)}.child-theme{background:linear-gradient(135deg,var(--child-world-bg-start) 0,var(--child-world-bg-end) 100%);background-attachment:fixed;min-height:100vh}.child-theme:before{animation:float 6s ease-in-out infinite;background:radial-gradient(circle,#fff6 0,#0000 70%);height:200px;right:5%;top:10%;width:200px}.child-theme:after,.child-theme:before{border-radius:50%;content:"";pointer-events:none;position:fixed;z-index:0}.child-theme:after{animation:float 8s ease-in-out infinite reverse;background:radial-gradient(circle,#ec489926 0,#0000 70%);bottom:20%;height:150px;left:3%;width:150px}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}.child-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-8);position:relative;z-index:1}.logout-btn{background:var(--gray-200);border:none;border-radius:var(--radius-lg);color:var(--gray-700);cursor:pointer;font-size:var(--text-sm);padding:var(--space-2) var(--space-4);transition:all .2s ease}.logout-btn:hover{background:var(--gray-300);transform:translateY(-2px)}.child-welcome h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--child-world-primary) 0,var(--child-world-secondary) 100%);-webkit-background-clip:text;background-clip:text;font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--space-2)}.child-welcome p{color:var(--gray-600);font-size:var(--text-lg);margin:0}.consent-prompt-banner,.location-status-banner,.monitoring-status-banner,.welcome-banner{align-items:flex-start;border-radius:var(--radius-child-lg);box-shadow:var(--shadow-child-soft);display:flex;gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-6);position:relative;transition:all .3s ease;z-index:1}.consent-prompt-banner:hover,.location-status-banner:hover,.monitoring-status-banner:hover,.welcome-banner:hover{box-shadow:var(--shadow-child-float);transform:translateY(-2px)}.welcome-banner{background:linear-gradient(135deg,#fef3c7,#fde68a 50%,#fcd34d);border:3px solid #f59e0b}.warning-banner{background:linear-gradient(135deg,#fee2e2,#fecaca 50%,#fca5a5);border:3px solid #ef4444}.consent-prompt-banner{background:linear-gradient(135deg,#dbeafe,#bfdbfe 50%,#93c5fd);border:3px solid #3b82f6}.monitoring-status-banner{background:linear-gradient(135deg,#d1fae5,#a7f3d0 50%,#6ee7b7);border:3px solid #10b981}.location-status-banner{background:linear-gradient(135deg,#eff6ff,#dbeafe 50%,#c4b5fd);border:3px solid #8b5cf6}.banner-icon{animation:gentle-bounce 2s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));flex-shrink:0;font-size:var(--text-4xl)}@keyframes gentle-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.banner-content{flex:1 1}.banner-content h3{color:var(--gray-800);font-size:var(--text-lg);font-weight:700;margin:0 0 var(--space-2) 0}.banner-content p{color:var(--gray-700);font-size:var(--text-base);margin:0 0 var(--space-2) 0}.consent-explanation{color:var(--gray-600)!important;font-size:var(--text-sm)!important;margin-bottom:var(--space-4)!important}.give-consent-btn{border-radius:var(--radius-child-md);font-size:var(--text-base);margin-top:var(--space-2);padding:var(--space-3) var(--space-6);transition:all .2s ease}.give-consent-btn:hover{box-shadow:0 4px 12px #3b82f64d;transform:translateY(-2px)}.btn-sm{font-size:var(--text-sm);padding:var(--space-2) var(--space-4)}.status-cards{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-8);position:relative;z-index:1}@media (max-width:1024px){.status-cards{grid-template-columns:repeat(2,1fr)}}.status-card{align-items:center;background:#fff;border:2px solid #0000;border-radius:var(--radius-child-lg);box-shadow:var(--shadow-child-soft);display:flex;gap:var(--space-4);padding:var(--space-6);transition:all .4s cubic-bezier(.34,1.56,.64,1)}.status-card:hover{box-shadow:var(--shadow-child-float);transform:translateY(-8px) scale(1.02)}.status-card:first-child:hover{border-color:var(--child-world-card-1)}.status-card:nth-child(2):hover{border-color:var(--child-world-card-2)}.status-card:nth-child(3):hover{border-color:var(--child-world-card-3)}.status-card:nth-child(4):hover{border-color:var(--child-world-card-4)}.status-icon{align-items:center;border-radius:var(--radius-child-md);display:flex;font-size:var(--text-3xl);height:64px;justify-content:center;transition:all .3s ease;width:64px}.status-card:hover .status-icon{transform:scale(1.1) rotate(5deg)}.status-card:first-child .status-icon{background:linear-gradient(135deg,#fef3c7,#fcd34d)}.status-card:nth-child(2) .status-icon{background:linear-gradient(135deg,#dcfce7,#86efac)}.status-card:nth-child(3) .status-icon{background:linear-gradient(135deg,#fce7f3,#f9a8d4)}.status-card:nth-child(4) .status-icon{background:linear-gradient(135deg,#e0e7ff,#a5b4fc)}.status-info{display:flex;flex-direction:column}.status-value{color:var(--gray-800);font-size:var(--text-xl);font-weight:800}.status-label{color:var(--gray-500);font-size:var(--text-sm)}.monitoring-info{background:#fff;border:2px solid #8b5cf61a;border-radius:var(--radius-child-lg);box-shadow:var(--shadow-child-soft);margin-bottom:var(--space-8);padding:var(--space-8);position:relative;z-index:1}.monitoring-info h2{align-items:center;color:var(--child-world-primary);display:flex;font-size:var(--text-xl);font-weight:700;gap:var(--space-3);margin:0 0 var(--space-6) 0}.monitoring-grid{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(3,1fr);margin-bottom:var(--space-6)}@media (max-width:1024px){.monitoring-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.monitoring-grid{grid-template-columns:1fr}}.monitoring-item{border-radius:var(--radius-child-md);padding:var(--space-4);text-align:center;transition:all .3s ease}.monitoring-item:hover{background:#8b5cf60d;transform:translateY(-4px)}.monitoring-icon{align-items:center;border-radius:50%;box-shadow:var(--shadow-child-soft);display:flex;font-size:var(--text-4xl);height:80px;justify-content:center;margin:0 auto var(--space-4);transition:all .3s ease;width:80px}.monitoring-item:first-child .monitoring-icon{background:linear-gradient(135deg,#fce7f3,#f9a8d4)}.monitoring-item:nth-child(2) .monitoring-icon{background:linear-gradient(135deg,#dbeafe,#93c5fd)}.monitoring-item:nth-child(3) .monitoring-icon{background:linear-gradient(135deg,#fef3c7,#fcd34d)}.monitoring-item:hover .monitoring-icon{box-shadow:var(--shadow-child-glow);transform:scale(1.1) rotate(10deg)}.monitoring-item h3{color:var(--gray-800);font-size:var(--text-lg);font-weight:700;margin:0 0 var(--space-2) 0}.monitoring-item p{color:var(--gray-600);font-size:var(--text-sm);line-height:1.6;margin:0}.monitoring-note{background:linear-gradient(135deg,var(--child-world-card-4) 0,#fff 100%);border:2px solid #8b5cf633;border-radius:var(--radius-child-md);margin-top:var(--space-6);padding:var(--space-5)}.monitoring-note p{color:var(--gray-700);font-size:var(--text-sm);margin:0}.quick-actions-section{margin-bottom:var(--space-8);position:relative;z-index:1}.quick-actions-section h2{color:var(--child-world-primary);font-size:var(--text-xl);font-weight:700;margin:0 0 var(--space-6) 0}.quick-actions-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(3,1fr)}@media (max-width:1024px){.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.quick-actions-grid{grid-template-columns:1fr}}.action-card{background:#fff;border:3px solid #0000;border-radius:var(--radius-child-lg);box-shadow:var(--shadow-child-soft);color:inherit;overflow:hidden;padding:var(--space-8) var(--space-6);position:relative;text-align:center;text-decoration:none;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.action-card:before{background:linear-gradient(90deg,var(--child-world-primary),var(--child-world-secondary));content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.action-card:hover{border-color:#8b5cf633;box-shadow:var(--shadow-child-float);transform:translateY(-8px) scale(1.02)}.action-card:hover:before{transform:scaleX(1)}.action-icon{align-items:center;border-radius:50%;display:flex;font-size:var(--text-4xl);height:80px;justify-content:center;margin:0 auto var(--space-5);transition:all .3s ease;width:80px}.action-card:first-child .action-icon{background:linear-gradient(135deg,#dcfce7,#86efac)}.action-card:nth-child(2) .action-icon{background:linear-gradient(135deg,#dbeafe,#93c5fd)}.action-card:nth-child(3) .action-icon{background:linear-gradient(135deg,#fce7f3,#f9a8d4)}.action-card:hover .action-icon{transform:scale(1.15) rotate(-5deg)}.action-card h3{color:var(--gray-800);font-size:var(--text-lg);font-weight:700;margin:0 0 var(--space-2) 0}.action-card p{color:var(--gray-600);font-size:var(--text-sm);margin:0}.privacy-promise{background:linear-gradient(135deg,var(--child-world-primary) 0,var(--child-world-secondary) 100%);border-radius:var(--radius-child-lg);box-shadow:var(--shadow-child-glow);color:#fff;overflow:hidden;padding:var(--space-8);position:relative;z-index:1}.privacy-promise:before{background:radial-gradient(circle,#ffffff1a 0,#0000 70%);border-radius:50%;content:"";height:300px;position:absolute;right:-20%;top:-50%;width:300px}.privacy-promise h2{align-items:center;display:flex;font-size:var(--text-xl);font-weight:700;gap:var(--space-3);margin:0 0 var(--space-6) 0}.promise-list{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(2,1fr)}@media (max-width:640px){.promise-list{grid-template-columns:1fr}}.promise-item{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-radius:var(--radius-child-md);display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);transition:all .3s ease}.promise-item:hover{background:#ffffff40;transform:translateX(5px)}.promise-icon{align-items:center;background:#ffffff4d;border-radius:50%;display:flex;flex-shrink:0;font-weight:700;height:32px;justify-content:center;width:32px}.promise-icon,.promise-item span:not(.promise-icon){font-size:var(--text-base)}.test-mode-panel{animation:slideIn .3s ease-out;border-radius:var(--radius-child-lg);position:relative;transition:all .3s ease;z-index:1}.test-mode-panel:hover{box-shadow:var(--shadow-child-soft);transform:translateY(-2px)}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.test-btn{background:#fff;border:2px solid #4a90d9;border-radius:8px;color:#4a90d9;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s}.test-btn:hover{background:#4a90d9;color:#fff}.test-btn:active{transform:scale(.98)}.child-dashboard>*{animation:slideInUp .5s ease-out forwards}.child-dashboard>:first-child{animation-delay:0s}.child-dashboard>:nth-child(2){animation-delay:.1s}.child-dashboard>:nth-child(3){animation-delay:.2s}.child-dashboard>:nth-child(4){animation-delay:.3s}.child-dashboard>:nth-child(5){animation-delay:.4s}.child-dashboard>:nth-child(6){animation-delay:.5s}.child-dashboard>:nth-child(7){animation-delay:.6s}@media (max-width:1024px){.monitoring-grid,.quick-actions-grid,.status-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.child-header{align-items:flex-start;flex-direction:column;gap:var(--space-4)}.monitoring-grid,.promise-list,.quick-actions-grid,.status-cards{grid-template-columns:1fr}.child-welcome h1{font-size:var(--text-2xl)}.action-card,.status-card{padding:var(--space-5)}}.geofence-consent-section{margin-bottom:24px}.geofence-consent-section h3{color:#1e293b;font-size:18px;margin:0 0 12px}.consent-intro{color:#64748b;font-size:14px;line-height:1.5;margin-bottom:16px}.consent-status-card{align-items:flex-start;background:#f0fdf4;border:2px solid #22c55e;border-radius:12px;gap:12px;padding:16px}.consent-status-card .status-icon{flex-shrink:0;font-size:24px}.consent-status-card h4{color:#166534;font-size:16px;margin:0 0 4px}.consent-status-card p{color:#166534;font-size:13px;margin:0}.consent-requests{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.consent-request-card{background:#eff6ff;border:2px solid #3b82f6;border-radius:12px;padding:16px}.request-header{align-items:center;display:flex;gap:8px;margin-bottom:8px}.request-icon{font-size:20px}.request-header h4{color:#1e40af;font-size:16px;margin:0}.request-description{color:#334155;font-size:14px;line-height:1.5;margin:0 0 16px}.request-actions{display:flex;gap:12px}.request-actions .btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:12px 16px;transition:all .2s}.btn-decline{background:#f1f5f9;color:#64748b}.btn-decline:hover{background:#e2e8f0}.btn-accept{background:#3b82f6;color:#fff}.btn-accept:hover{background:#2563eb}.consent-info{background:#f8fafc;border-radius:12px;padding:16px}.consent-info h5{color:#374151;font-size:14px;margin:0 0 12px}.consent-info ul{color:#64748b;font-size:13px;margin:0;padding-left:20px}.consent-info li{margin-bottom:6px}.consent-info li:last-child{margin-bottom:0}.consent-page{margin:0 auto;max-width:900px}.consent-page .page-header{margin-bottom:var(--space-8)}.consent-page .page-header h1{color:var(--child-primary);font-size:var(--text-2xl);margin-bottom:var(--space-2)}.consent-page .page-header p{color:var(--gray-600);margin:0}.consent-status-card{align-items:center;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);display:flex;gap:var(--space-6);margin-bottom:var(--space-8);padding:var(--space-8)}.consent-status-card.active{background:linear-gradient(135deg,var(--success-50) 0,#fff 100%);border:2px solid var(--success-200)}.consent-status-card.inactive{background:linear-gradient(135deg,var(--warning-50) 0,#fff 100%);border:2px solid var(--warning-200)}.status-icon-large{font-size:64px;line-height:1}.status-details h2{font-size:var(--text-xl);margin:0 0 var(--space-2) 0}.status-details p{color:var(--gray-600);margin:0}.transparency-section{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:var(--space-8);padding:var(--space-8)}.transparency-section h2{font-size:var(--text-xl);margin:0 0 var(--space-6) 0}.transparency-grid{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(2,1fr)}.transparency-card{background:var(--success-50);border-radius:var(--radius-xl);padding:var(--space-6)}.transparency-card.private{background:var(--primary-50)}.transparency-card h3{color:var(--success-700);font-size:var(--text-lg);margin:0 0 var(--space-4) 0}.transparency-card.private h3{color:var(--primary-700)}.transparency-card ul{color:var(--gray-700);margin:0;padding-left:var(--space-5)}.transparency-card li{line-height:1.5;margin-bottom:var(--space-2)}.keywords-section{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:var(--space-8);padding:var(--space-8)}.keywords-section h2{font-size:var(--text-xl);margin:0 0 var(--space-2) 0}.section-intro{color:var(--gray-600);margin:0 0 var(--space-6) 0}.keywords-display{display:flex;flex-direction:column;gap:var(--space-6)}.keyword-category h4{color:var(--gray-700);font-size:var(--text-sm);margin:0 0 var(--space-3) 0}.keyword-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.keyword-tags.warning .keyword-tag{background:var(--warning-100);color:var(--warning-700)}.keyword-tags.blocked .keyword-tag{background:var(--error-100);color:var(--error-700)}.keyword-tag{border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;padding:var(--space-2) var(--space-3)}.rights-section{background:linear-gradient(135deg,var(--child-primary) 0,var(--child-secondary) 100%);border-radius:var(--radius-xl);color:#fff;margin-bottom:var(--space-8);padding:var(--space-8)}.rights-section h2{font-size:var(--text-xl);margin:0 0 var(--space-6) 0}.rights-list{flex-direction:column}.right-item,.rights-list{display:flex;gap:var(--space-4)}.right-item{align-items:flex-start;background:#ffffff1a;border-radius:var(--radius-lg);padding:var(--space-4)}.right-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;flex-shrink:0;font-size:var(--text-sm);font-weight:700;height:28px;justify-content:center;width:28px}.right-item h4{font-size:var(--text-base);margin:0 0 var(--space-1) 0}.right-item p{font-size:var(--text-sm);margin:0;opacity:.9}.consent-action{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-8)}.consent-form{display:flex;flex-direction:column;gap:var(--space-6)}.consent-checkbox{align-items:flex-start;background:var(--gray-50);border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:var(--space-3);padding:var(--space-4);transition:all var(--transition-fast)}.consent-checkbox:hover{background:var(--gray-100)}.consent-checkbox input{accent-color:var(--success-500);height:20px;margin-top:2px;width:20px}.consent-checkbox span{color:var(--gray-700);font-size:var(--text-base);line-height:1.5}.consent-form .btn-success{background:var(--success-500);color:#fff;padding:var(--space-4) var(--space-8)}.consent-form .btn-success:disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.consent-form .btn-success{transition:opacity .2s ease}.withdraw-info{text-align:center}.withdraw-info h3{font-size:var(--text-xl);margin:0 0 var(--space-3) 0}.withdraw-info p{color:var(--gray-600);margin:0 0 var(--space-6) 0;margin-left:auto;margin-right:auto;max-width:500px}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:var(--space-4);position:fixed;z-index:1000}.modal-content{background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);max-width:500px;overflow:hidden;width:100%}.modal-header{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;padding:var(--space-6)}.modal-header h2{font-size:var(--text-xl);margin:0}.modal-close{align-items:center;background:var(--gray-100);border-radius:50%;color:var(--gray-500);display:flex;height:36px;justify-content:center;transition:all var(--transition-fast);width:36px}.modal-close:hover{background:var(--gray-200);color:var(--gray-700)}.modal-body{padding:var(--space-6)}.withdraw-warning{align-items:flex-start;background:var(--warning-50);border-radius:var(--radius-lg);display:flex;gap:var(--space-4);margin-bottom:var(--space-4);padding:var(--space-4)}.warning-icon{flex-shrink:0;font-size:var(--text-2xl)}.withdraw-warning p{color:var(--gray-700);font-size:var(--text-sm);margin:0}@media (max-width:768px){.transparency-grid{grid-template-columns:1fr}.consent-status-card{flex-direction:column;text-align:center}.rights-list{gap:var(--space-3)}}.my-activity{margin:0 auto;max-width:900px}.my-activity .page-header{margin-bottom:var(--space-6)}.my-activity .page-header h1{color:var(--child-primary);font-size:var(--text-2xl);margin-bottom:var(--space-2)}.my-activity .page-header p{color:var(--gray-600);margin:0}.activity-stats{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-6)}.activity-stat-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-5);text-align:center}.stat-number{color:var(--child-world-primary);display:block;font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--space-1)}.activity-stat-card.warning .stat-number{color:var(--warning-500)}.activity-stat-card.success .stat-number{color:var(--success-500)}.activity-stat-card.info .stat-number{color:var(--info-500)}.stat-desc{color:var(--gray-500);font-size:var(--text-xs)}.privacy-notice{align-items:center;background:linear-gradient(135deg,var(--child-primary) 0,var(--child-secondary) 100%);border-radius:var(--radius-xl);color:#fff;display:flex;gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-5)}.notice-icon{flex-shrink:0;font-size:var(--text-3xl)}.privacy-notice p{font-size:var(--text-sm);line-height:1.6;margin:0}.activity-filters{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-6)}.activity-filters .filter-btn{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-full);color:var(--gray-600);cursor:pointer;font-size:var(--text-sm);font-weight:500;padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.activity-filters .filter-btn:hover{border-color:var(--child-primary);color:var(--child-primary)}.activity-filters .filter-btn.active{background:var(--child-primary);border-color:var(--child-primary);color:#fff}.activity-list{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-8)}.activity-item{align-items:flex-start;background:#fff;border-left:4px solid var(--gray-300);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);display:flex;gap:var(--space-4);padding:var(--space-5);transition:all var(--transition-fast)}.activity-item:hover{box-shadow:var(--shadow-md)}.activity-item.warning{background:var(--warning-50);border-left-color:var(--warning-500)}.activity-item.blocked{background:var(--error-50);border-left-color:var(--error-500)}.activity-item.info{background:var(--info-50);border-left-color:var(--info-500)}.activity-icon{align-items:center;background:#fff;border-radius:var(--radius-lg);display:flex;flex-shrink:0;font-size:var(--text-xl);height:44px;justify-content:center;width:44px}.activity-content{flex:1 1;min-width:0}.activity-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-2)}.activity-type{border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:700;padding:var(--space-1) var(--space-2)}.activity-type.warning{background:var(--warning-100);color:var(--warning-700)}.activity-type.blocked{background:var(--error-100);color:var(--error-700)}.activity-type.info{background:var(--info-100);color:var(--info-700)}.activity-time{color:var(--gray-500);font-size:var(--text-xs)}.activity-text{color:var(--gray-800);font-size:var(--text-base);line-height:1.5;margin:0 0 var(--space-3) 0}.activity-meta{align-items:center;display:flex;gap:var(--space-3)}.activity-app{background:var(--gray-200);color:var(--gray-700)}.activity-app,.resolved-badge{border-radius:var(--radius-sm);font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}.resolved-badge{background:var(--success-100);color:var(--success-700);font-weight:600}.empty-activity{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-12);text-align:center}.empty-icon{font-size:var(--text-4xl);margin-bottom:var(--space-4)}.empty-activity h3{font-size:var(--text-xl);margin:0 0 var(--space-2) 0}.empty-activity p{color:var(--gray-600);margin:0}.data-info{background:var(--gray-100);border-radius:var(--radius-xl);padding:var(--space-6)}.data-info h4{color:var(--gray-800);font-size:var(--text-base);margin:0 0 var(--space-3) 0}.data-info ul{color:var(--gray-600);font-size:var(--text-sm);margin:0;padding-left:var(--space-5)}.data-info li{margin-bottom:var(--space-2)}@media (max-width:768px){.activity-stats{grid-template-columns:repeat(2,1fr)}.privacy-notice{flex-direction:column;text-align:center}}@media (max-width:480px){.activity-stats{grid-template-columns:1fr}}.ai-reason{align-items:flex-start;background:#f4f0ff;border-left:3px solid #7c5cff;border-radius:6px;display:flex;font-size:13px;gap:8px;margin:8px 0;padding:8px 10px}.ai-badge{color:#7c5cff;flex-shrink:0;font-weight:600}.ai-reason-text{color:#333;line-height:1.4}.child-settings-page{margin:0 auto;max-width:800px}.page-header{margin-bottom:var(--space-6)}.page-header h1{color:var(--child-primary);font-size:var(--text-2xl);margin-bottom:var(--space-2)}.page-header p{color:var(--gray-600);margin:0}.settings-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:var(--space-6);padding:var(--space-6)}.card-header{border-bottom:1px solid var(--gray-100);margin-bottom:var(--space-4);padding-bottom:var(--space-4)}.card-header h3{color:var(--gray-800);font-size:var(--text-lg);margin:0}.info-box{background:var(--gray-50);border-radius:var(--radius-lg);padding:var(--space-4)}.info-box h4{color:var(--gray-800);font-size:var(--text-base);margin:0 0 var(--space-2) 0}.info-box p{margin:0 0 var(--space-3) 0}.info-box p,.info-box ul{color:var(--gray-600);font-size:var(--text-sm)}.info-box ul{margin:0;padding-left:var(--space-5)}.info-box li{margin-bottom:var(--space-1)}.info-box.privacy{background:var(--success-50);border:1px solid var(--success-200)}.info-box.privacy h4{color:var(--success-700)}.app-info{display:flex;flex-direction:column;gap:var(--space-3)}.info-row{border-bottom:1px solid var(--gray-100);padding:var(--space-3) 0}.info-row:last-child{border-bottom:none}.info-label{color:var(--gray-600)}.info-label,.info-value{font-size:var(--text-sm)}@media (max-width:640px){.settings-card{padding:var(--space-4)}}.support-page{margin:0 auto;max-width:1100px}.support-page .page-header{margin-bottom:var(--space-6)}.support-page .page-header h1{color:var(--child-primary);font-size:var(--text-2xl);margin-bottom:var(--space-2)}.support-page .page-header p{color:var(--gray-600);margin:0}.emergency-banner{align-items:center;background:linear-gradient(135deg,#dc2626,#b91c1c);border:3px solid #991b1b;border-radius:var(--radius-xl);box-shadow:0 8px 25px #dc262666;color:#fff;display:flex;gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-5)}.emergency-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));flex-shrink:0;font-size:var(--text-4xl)}.emergency-banner h3{font-size:var(--text-xl);font-weight:700;letter-spacing:.5px;margin:0 0 var(--space-2) 0;text-shadow:0 1px 3px #0000004d}.emergency-banner p{font-size:var(--text-base);font-weight:600;margin:0;text-shadow:0 1px 2px #0000004d}.support-grid{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:1fr 1fr;margin-bottom:var(--space-8)}.support-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden}.support-card .card-header{border-bottom:1px solid var(--gray-100);padding:var(--space-6)}.support-card .card-header h2{font-size:var(--text-lg);margin:0 0 var(--space-2) 0}.support-card .card-header p{color:var(--gray-600);font-size:var(--text-sm);margin:0}.support-form{display:flex;flex-direction:column;gap:var(--space-5);padding:var(--space-6)}.resource-item,.resources-list{padding:var(--space-4)}.resource-item{border-bottom:1px solid var(--gray-100)}.resource-item:last-child{border-bottom:none}.resource-item h4{color:var(--child-primary);font-size:var(--text-base);margin:0 0 var(--space-2) 0}.resource-item>p{color:var(--gray-600);font-size:var(--text-sm);margin:0 0 var(--space-3) 0}.resource-contact{display:flex;gap:var(--space-3);margin-bottom:var(--space-2)}.resource-link{align-items:center;background:var(--child-primary);border-radius:var(--radius-lg);color:#fff;display:inline-flex;font-size:var(--text-sm);font-weight:500;gap:var(--space-1);padding:var(--space-2) var(--space-3);text-decoration:none;transition:opacity var(--transition-fast)}.resource-link:hover{color:#fff;opacity:.9}.resource-hours{color:var(--gray-500);font-size:var(--text-xs)}.faqs-section{margin-bottom:var(--space-8)}.faqs-section h2{font-size:var(--text-xl);margin:0 0 var(--space-4) 0}.faqs-list{display:flex;flex-direction:column;gap:var(--space-3)}.faq-item{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.faq-question{align-items:center;color:var(--gray-800);cursor:pointer;display:flex;font-weight:600;justify-content:space-between;list-style:none;padding:var(--space-5)}.faq-question::-webkit-details-marker{display:none}.faq-question:after{color:var(--child-primary);content:"+";font-size:var(--text-xl)}.faq-item[open] .faq-question:after{content:"−"}.faq-answer{color:var(--gray-600);line-height:1.6;margin:0;padding:0 var(--space-5) var(--space-5)}.parents-section{margin-bottom:var(--space-8)}.parents-card{align-items:center;background:linear-gradient(135deg,var(--success-50) 0,#fff 100%);border:2px solid var(--success-200);border-radius:var(--radius-xl);display:flex;gap:var(--space-6);padding:var(--space-6)}.parents-icon{flex-shrink:0;font-size:48px}.parents-card h3{color:var(--success-700);font-size:var(--text-lg);margin:0 0 var(--space-2) 0}.parents-card p{color:var(--gray-600);line-height:1.6;margin:0}@media (max-width:768px){.support-grid{grid-template-columns:1fr}.emergency-banner,.parents-card{flex-direction:column;text-align:center}.resource-contact{flex-direction:column}}.arrival-overlay{align-items:center;animation:arrivalFadeIn .4s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#22c55e26;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:2000}@keyframes arrivalFadeIn{0%{opacity:0}to{opacity:1}}.arrival-modal{animation:arrivalScale .5s cubic-bezier(.34,1.56,.64,1);background:#fff;border:3px solid #22c55e;border-radius:24px;box-shadow:0 20px 50px #00000040;max-width:420px;padding:32px 24px;text-align:center;width:100%}@keyframes arrivalScale{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.arrival-icon{animation:arrivalBounce 1s ease infinite alternate;font-size:64px;margin-bottom:8px}@keyframes arrivalBounce{0%{transform:translateY(0)}to{transform:translateY(-8px)}}.arrival-modal h2{color:#166534;font-size:28px;font-weight:800;margin:0 0 6px}.arrival-destination{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#475569;font-size:14px;margin:0 0 20px;padding:8px 12px;word-break:break-word}.arrival-instruction{color:#334155;font-size:15px;line-height:1.5;margin:0 0 20px}.arrival-btn{-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:14px;box-shadow:0 4px 12px #22c55e59;color:#fff;cursor:pointer;display:block;font-size:17px;font-weight:700;height:60px;letter-spacing:.3px;margin-bottom:14px;touch-action:manipulation;width:100%}.arrival-btn:active{background:linear-gradient(135deg,#16a34a,#15803d);transform:scale(.98)}.arrival-btn:disabled{cursor:not-allowed;opacity:.6}.arrival-fineprint{color:#64748b;font-size:12px;margin:0}.admin-dashboard{margin:0 auto;max-width:1400px}.admin-header{margin-bottom:var(--space-8)}.admin-header h1{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.admin-header p{color:var(--gray-600);margin:0}.admin-stats{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-8)}.admin-stat-card{background:#fff;box-shadow:var(--shadow-md);gap:var(--space-4);padding:var(--space-6)}.admin-stat-card,.stat-icon{align-items:center;border-radius:var(--radius-xl);display:flex}.stat-icon{font-size:var(--text-2xl);height:56px;justify-content:center;width:56px}.stat-icon.users{background:var(--primary-100)}.stat-icon.parents{background:var(--info-100)}.stat-icon.children{background:var(--success-100)}.stat-icon.active{background:var(--warning-100)}.stat-info{display:flex;flex-direction:column}.stat-value{color:var(--gray-900);font-size:var(--text-2xl);font-weight:800}.stat-label{color:var(--gray-500);font-size:var(--text-sm)}.admin-charts{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(2,1fr);margin-bottom:var(--space-8)}.chart-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-6)}.chart-card h3{font-size:var(--text-lg);margin:0 0 var(--space-6) 0}.distribution-chart{display:flex;flex-direction:column;gap:var(--space-4)}.chart-bar{border-radius:var(--radius-lg);display:flex;height:40px;overflow:hidden}.bar-segment{align-items:center;color:#fff;display:flex;font-size:var(--text-xs);font-weight:600;justify-content:center;transition:width var(--transition-slow)}.bar-segment.parents{background:var(--info-500)}.bar-segment.children{background:var(--success-500)}.chart-legend{display:flex;gap:var(--space-6)}.legend-item{align-items:center;color:var(--gray-600);display:flex;font-size:var(--text-sm);gap:var(--space-2)}.legend-dot{border-radius:50%;height:12px;width:12px}.legend-dot.parents{background:var(--info-500)}.legend-dot.children{background:var(--success-500)}.consent-rate{gap:var(--space-8)}.consent-rate,.rate-circle{align-items:center;display:flex}.rate-circle{background:conic-gradient(var(--success-500) 0 75%,var(--gray-200) 75% 100%);background:conic-gradient(var(--success-500) 0 var(--consent-percent,75%),var(--gray-200) var(--consent-percent,75%) 100%);border-radius:50%;flex-direction:column;height:120px;justify-content:center;position:relative;width:120px}.rate-circle:before{background:#fff;border-radius:50%;content:"";height:90px;position:absolute;width:90px}.rate-value{color:var(--gray-900);font-size:var(--text-2xl);font-weight:800;position:relative}.rate-label{color:var(--gray-500);font-size:var(--text-xs);position:relative}.rate-details{display:flex;flex-direction:column;gap:var(--space-3)}.rate-item{align-items:center;color:var(--gray-600);display:flex;font-size:var(--text-sm);gap:var(--space-2)}.rate-dot{border-radius:50%;height:10px;width:10px}.rate-dot.active{background:var(--success-500)}.rate-dot.inactive{background:var(--gray-300)}.recent-users{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:var(--space-8);padding:var(--space-6)}.recent-users h3{font-size:var(--text-lg);margin:0 0 var(--space-4) 0}.users-table{display:flex;flex-direction:column}.table-header{background:var(--gray-50);border-radius:var(--radius-lg);color:var(--gray-500);font-size:var(--text-xs);font-weight:600;letter-spacing:.05em;padding:var(--space-3) var(--space-4);text-transform:uppercase}.table-header,.table-row{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:2fr 1fr 2fr 1fr}.table-row{align-items:center;border-bottom:1px solid var(--gray-100);color:var(--gray-700);font-size:var(--text-sm);padding:var(--space-4)}.table-row:last-child{border-bottom:none}.user-role{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;padding:var(--space-1) var(--space-2);text-align:center;text-transform:uppercase}.user-role.parent{background:var(--info-100);color:var(--info-700)}.user-role.child{background:var(--success-100);color:var(--success-700)}.user-role.admin{background:var(--warning-100);color:var(--warning-700)}.system-status{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-6)}.system-status h3{font-size:var(--text-lg);margin:0 0 var(--space-4) 0}.status-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(4,1fr)}.status-item{background:var(--gray-50);border-radius:var(--radius-lg);gap:var(--space-3);padding:var(--space-4)}.status-indicator{border-radius:50%;height:10px;width:10px}.status-indicator.online{background:var(--success-500);box-shadow:0 0 0 4px var(--success-100)}.status-name{color:var(--gray-700);font-size:var(--text-sm);font-weight:500}.status-state{color:var(--success-600);font-size:var(--text-xs);font-weight:600;margin-left:auto}@media (max-width:1200px){.admin-stats{grid-template-columns:repeat(2,1fr)}.admin-charts{grid-template-columns:1fr}.status-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.admin-stats,.status-grid{grid-template-columns:1fr}.table-header,.table-row{grid-template-columns:1fr 1fr}.user-date,.user-email{display:none}}.user-management{margin:0 auto;max-width:1400px}.user-management .page-header{margin-bottom:var(--space-6)}.user-management .page-header h1{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.user-management .page-header p{color:var(--gray-600);margin:0}.filters-bar{display:flex;gap:var(--space-4);margin-bottom:var(--space-6)}.search-box{flex:1 1}.search-box .form-input{width:100%}.filters-bar .form-select{width:200px}.users-table-container{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:var(--space-6);overflow:hidden}.admin-table{border-collapse:collapse;width:100%}.admin-table th{background:var(--gray-50);border-bottom:1px solid var(--gray-200);color:var(--gray-500);font-size:var(--text-xs);font-weight:600;letter-spacing:.05em;text-align:left;text-transform:uppercase}.admin-table td,.admin-table th{padding:var(--space-4) var(--space-6)}.admin-table td{border-bottom:1px solid var(--gray-100)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover{background:var(--gray-50)}.user-cell{align-items:center;display:flex;gap:var(--space-3)}.user-cell .user-avatar{align-items:center;background:var(--primary-500);border-radius:50%;color:#fff;display:flex;font-size:var(--text-base);font-weight:600;height:40px;justify-content:center;width:40px}.user-details{display:flex;flex-direction:column}.user-name{color:var(--gray-900);font-weight:600}.user-email{color:var(--gray-500);font-size:var(--text-sm)}.role-badge{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;padding:var(--space-1) var(--space-3);text-transform:uppercase}.role-badge.parent{background:var(--info-100);color:var(--info-700)}.role-badge.child{background:var(--success-100);color:var(--success-700)}.role-badge.admin{background:var(--warning-100);color:var(--warning-700)}.status-badge{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;padding:var(--space-1) var(--space-3)}.status-badge.active{background:var(--success-100);color:var(--success-700)}.status-badge.inactive{background:var(--gray-100);color:var(--gray-600)}.pagination{align-items:center;display:flex;justify-content:space-between}.results-info{color:var(--gray-600);font-size:var(--text-sm)}.user-modal{max-width:500px}.user-profile{border-bottom:1px solid var(--gray-200);gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-6)}.profile-avatar,.user-profile{align-items:center;display:flex}.profile-avatar{background:var(--primary-500);border-radius:50%;color:#fff;font-size:var(--text-3xl);font-weight:700;height:80px;justify-content:center;width:80px}.profile-info h3{font-size:var(--text-xl);margin:0 0 var(--space-2) 0}.profile-details{display:flex;flex-direction:column;gap:var(--space-4)}.detail-row{align-items:center;display:flex;justify-content:space-between}.detail-label{color:var(--gray-500);font-size:var(--text-sm)}.detail-value{color:var(--gray-800);font-size:var(--text-sm);font-weight:500}.detail-value.success{color:var(--success-500)}.detail-value.warning{color:var(--warning-500)}.modal-actions{border-top:1px solid var(--gray-100);display:flex;gap:var(--space-3);justify-content:flex-end}.create-user-form,.modal-actions{padding:var(--space-6)}.create-user-form .form-group{margin-bottom:var(--space-4)}.create-user-form label{color:var(--gray-700);display:block;font-size:var(--text-sm);font-weight:500;margin-bottom:var(--space-2)}.create-user-form .form-input,.create-user-form .form-select{border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--text-base);padding:var(--space-3);width:100%}.create-user-form .form-input:focus,.create-user-form .form-select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #4a90d91a;outline:none}.create-user-form .form-error{color:var(--error-500);display:block;font-size:var(--text-sm);margin-top:var(--space-1)}.create-user-form .checkbox-group{align-items:center;display:flex}.create-user-form .checkbox-label{align-items:center;cursor:pointer;display:flex;gap:var(--space-2)}.create-user-form .checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.reset-info{background:var(--warning-50);border:1px solid var(--warning-200);color:var(--warning-800);margin-bottom:var(--space-6);padding:var(--space-4)}.btn-warning,.reset-info{border-radius:var(--radius-md)}.btn-warning{background:var(--warning-500);border:none;color:#fff;cursor:pointer;font-weight:500;padding:var(--space-2) var(--space-4);transition:all .2s}.btn-warning:hover{background:var(--warning-600)}.btn-warning:disabled{cursor:not-allowed;opacity:.6}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:space-between}@media (max-width:768px){.filters-bar{flex-direction:column}.filters-bar .form-select{width:100%}.admin-table td,.admin-table th{padding:var(--space-3)}.user-email{display:none}.page-header{align-items:flex-start}.modal-actions,.page-header{flex-direction:column}.modal-actions .btn{width:100%}}.support-tickets{margin:0 auto;max-width:1400px}.support-tickets .page-header{margin-bottom:var(--space-6)}.support-tickets .page-header h1{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.support-tickets .page-header p{color:var(--gray-600);margin:0}.ticket-stats{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-6)}.ticket-stat{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-5);text-align:center}.stat-count{color:var(--primary-500);display:block;font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--space-1)}.stat-name{color:var(--gray-500);font-size:var(--text-sm);text-transform:uppercase}.ticket-filters{display:flex;gap:var(--space-2);margin-bottom:var(--space-6)}.ticket-filters .filter-btn{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-full);color:var(--gray-600);cursor:pointer;font-size:var(--text-sm);font-weight:500;padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.ticket-filters .filter-btn:hover{border-color:var(--primary-300)}.ticket-filters .filter-btn.active{background:var(--primary-500);border-color:var(--primary-500);color:#fff}.tickets-list{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.ticket-card{background:#fff;border-left:4px solid var(--gray-300);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);cursor:pointer;padding:var(--space-5);transition:all var(--transition-fast)}.ticket-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.ticket-card.open{border-left-color:var(--warning-500)}.ticket-card.in-progress{border-left-color:var(--info-500)}.ticket-card.resolved{border-left-color:var(--success-500);opacity:.8}.ticket-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-3)}.ticket-id{color:var(--gray-500);font-family:monospace;font-size:var(--text-xs);font-weight:600}.ticket-badges{display:flex;gap:var(--space-2)}.ticket-subject{color:var(--gray-800);font-size:var(--text-base);margin:0 0 var(--space-2) 0}.ticket-preview{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--gray-600);display:-webkit-box;font-size:var(--text-sm);margin:0 0 var(--space-4) 0;overflow:hidden}.ticket-footer{color:var(--gray-500);font-size:var(--text-sm);justify-content:space-between}.ticket-footer,.ticket-user{align-items:center;display:flex}.ticket-user{gap:var(--space-2)}.user-icon{font-size:var(--text-base)}.ticket-modal{display:flex;flex-direction:column;max-height:90vh;max-width:700px}.ticket-modal .modal-header{flex-shrink:0}.ticket-modal .modal-header h2{font-size:var(--text-lg);margin-top:var(--space-2)}.ticket-detail-body{flex:1 1;overflow-y:auto;padding:var(--space-6)}.ticket-info{background:var(--gray-50);border-radius:var(--radius-lg);margin-bottom:var(--space-6);padding:var(--space-4)}.info-row{display:flex;font-size:var(--text-sm);justify-content:space-between;padding:var(--space-2) 0}.info-label{color:var(--gray-500)}.info-value{color:var(--gray-800);font-weight:500}.status-select{border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--text-sm);padding:var(--space-1) var(--space-3)}.ticket-messages{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}.message{border-radius:var(--radius-lg);padding:var(--space-4)}.message.original{background:var(--gray-100)}.message.support{background:var(--primary-50);margin-left:var(--space-8)}.message.user{background:var(--gray-100);margin-right:var(--space-8)}.message-header{display:flex;font-size:var(--text-sm);justify-content:space-between;margin-bottom:var(--space-2)}.message-from{color:var(--gray-800);font-weight:600}.message-time{color:var(--gray-500)}.message-text{color:var(--gray-700);line-height:1.6;margin:0}.reply-form{border-top:1px solid var(--gray-200);padding-top:var(--space-4)}.reply-form textarea{margin-bottom:var(--space-3)}.reply-form button{width:100%}@media (max-width:768px){.ticket-stats{grid-template-columns:repeat(2,1fr)}.tickets-list{grid-template-columns:1fr}.ticket-filters{flex-wrap:wrap}}.security-dashboard{margin:0 auto;max-width:1400px;padding:24px}.security-dashboard.loading{color:#6b7280;padding:60px;text-align:center}.dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.dashboard-header h1{color:#1f2937;font-size:28px;font-weight:700;margin:0}.header-actions{display:flex;gap:12px}.security-overview{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:24px}.overview-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;gap:16px;padding:20px}.card-icon,.overview-card{align-items:center;display:flex}.card-icon{background:#f3f4f6;border-radius:12px;font-size:32px;height:56px;justify-content:center;width:56px}.card-content h3{color:#6b7280;font-size:14px;font-weight:500;margin:0 0 4px}.metric{color:#1f2937;font-size:28px;font-weight:700}.card-content small{color:#9ca3af;display:block;font-size:12px}.status{border-radius:20px;font-size:14px;font-weight:600;padding:4px 12px}.status.secure{background:#dcfce7;color:#16a34a}.status.at-risk,.status.compromised{background:#fee2e2;color:#dc2626}.threat-badge{border-radius:20px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.tab-navigation{border-bottom:2px solid #e5e7eb;display:flex;gap:8px;margin-bottom:24px;padding-bottom:2px}.tab-btn{background:#0000;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-weight:500;margin-bottom:-2px;padding:12px 20px;transition:all .2s}.tab-btn:hover{color:#374151}.tab-btn.active{border-bottom-color:#2563eb;color:#2563eb}.tab-content{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.section-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:24px}.section-card{background:#f9fafb;border-radius:12px;padding:20px}.section-card h3{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 16px}.status-list{display:flex;flex-direction:column;gap:12px}.status-item{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:8px 0}.status-item:last-child{border-bottom:none}.status-item .active{color:#16a34a;font-weight:500}.status-item .inactive{color:#6b7280}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.section-header h3{font-size:18px;font-weight:600;margin:0}.empty-state{color:#6b7280;padding:60px 20px;text-align:center}.empty-icon{display:block;font-size:48px;margin-bottom:16px}.alerts-list{display:flex;flex-direction:column;gap:16px}.alert-card{background:#f9fafb;border-left:4px solid;border-radius:12px;padding:20px}.alert-card.critical{background:#fef2f2;border-left-color:#dc2626}.alert-card.high{background:#fff7ed;border-left-color:#ea580c}.alert-card.medium{background:#fefce8;border-left-color:#ca8a04}.alert-card.low{background:#f0fdf4;border-left-color:#16a34a}.alert-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.severity-badge{border-radius:20px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px}.alert-time{color:#6b7280;font-size:12px}.alert-card h4{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 12px}.alert-details{margin-bottom:16px}.alert-details p{color:#4b5563;font-size:14px;margin:4px 0}.data-table{border-collapse:collapse;font-size:14px;width:100%}.data-table td,.data-table th{border-bottom:1px solid #e5e7eb;padding:12px;text-align:left}.data-table th{color:#374151;font-weight:600}.data-table th,.data-table tr:hover{background:#f9fafb}.event-type{background:#e0e7ff;border-radius:4px;color:#3730a3;display:inline-block;font-size:12px;font-weight:500;padding:4px 8px}.details-cell pre{color:#6b7280;font-size:12px;margin:0;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logs-table-wrapper{max-height:600px;overflow:auto}.time-range-select{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px}.compliance-status{display:flex;flex-direction:column;gap:16px}.compliance-status .status-item{background:#fff;border-radius:8px;display:flex;justify-content:space-between;padding:12px}.status-label{color:#374151;font-weight:500}.status-value{color:#6b7280}.compliance-actions{margin-top:24px}.mobile-security-section .status-list{background:#fff;border-radius:8px;padding:16px}.btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover{background:#e5e7eb}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover{background:#b91c1c}.btn-sm{font-size:12px;padding:6px 12px}@media (max-width:768px){.security-dashboard{padding:16px}.dashboard-header{align-items:flex-start;flex-direction:column;gap:16px}.security-overview{grid-template-columns:1fr}.tab-navigation{overflow-x:auto;white-space:nowrap}.section-grid{grid-template-columns:1fr}.data-table{font-size:12px}.data-table td,.data-table th{padding:8px}}.e2e-dashboard{background:#f1f5f9;color:#1e293b;font-size:14px;min-height:100vh;padding:20px}.e2e-dash-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:20px}.e2e-dash-header h1{font-size:22px;font-weight:800;margin:0 0 4px}.e2e-dash-header p{color:#64748b;font-size:13px;margin:0}.e2e-dash-home{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#334155;font-weight:600;padding:8px 14px;text-decoration:none}.e2e-dash-grid{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:280px 1fr}@media (max-width:900px){.e2e-dash-grid{grid-template-columns:1fr}}.e2e-suite-panel{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;padding:16px;position:sticky;top:20px}.e2e-suite-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.e2e-suite-head h2{font-size:15px;font-weight:700;margin:0}.e2e-suite-actions{display:flex;gap:6px}.e2e-suite-actions button{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;padding:4px 10px}.e2e-suite-actions button:hover{background:#e2e8f0}.e2e-suite-list{display:flex;flex-direction:column;gap:4px;list-style:none;margin:0 0 16px;padding:0}.e2e-suite-list label{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:8px 10px}.e2e-suite-list label:hover{background:#f8fafc;border-color:#e2e8f0}.e2e-suite-list input[type=checkbox]{accent-color:#4a90d9;height:16px;width:16px}.e2e-suite-name{flex:1 1;font-weight:500}.e2e-suite-id{background:#f1f5f9;border-radius:4px;color:#94a3b8;font-size:11px;padding:2px 6px}.e2e-run-cta{background:linear-gradient(135deg,#4a90d9,#6366f1);border:none;border-radius:10px;box-shadow:0 1px 3px #6366f14d;color:#fff;cursor:pointer;font-size:15px;font-weight:700;padding:12px 16px;width:100%}.e2e-run-cta:disabled{cursor:not-allowed;opacity:.5}.e2e-results-panel{display:flex;flex-direction:column;gap:16px}.e2e-summary-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(5,1fr)}@media (max-width:700px){.e2e-summary-row{grid-template-columns:repeat(2,1fr)}}.e2e-summary-card{background:#fff;border-radius:10px;box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;gap:2px;padding:12px;text-align:center}.e2e-summary-card .num{color:#1e293b;font-size:22px;font-weight:800}.e2e-summary-card .lbl{color:#64748b;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.e2e-summary-card.pass .num{color:#15803d}.e2e-summary-card.fail .num{color:#b91c1c}.e2e-progress-bar{background:#fee2e2;border-radius:4px;height:8px;overflow:hidden}.e2e-progress-fill{background:linear-gradient(90deg,#22c55e,#15803d);height:100%;transition:width .3s ease}.e2e-tabs{align-items:center;background:#fff;border-radius:10px;box-shadow:0 1px 3px #00000014;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;padding:8px}.e2e-export-actions,.e2e-filter-tabs{display:flex;gap:6px}.e2e-export-actions button,.e2e-filter-tabs button{background:#f1f5f9;border:1px solid #0000;border-radius:6px;color:#475569;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px}.e2e-filter-tabs button.active{background:#4a90d9;color:#fff}.e2e-export-actions button:disabled{cursor:not-allowed;opacity:.5}.e2e-results-list{background:#fff;border-radius:10px;box-shadow:0 1px 3px #00000014;max-height:480px;overflow-y:auto;padding:8px}.e2e-result-row{grid-gap:10px;align-items:center;border-bottom:1px solid #f1f5f9;border-radius:6px;display:grid;gap:10px;grid-template-columns:24px 1fr auto;padding:8px 10px}.e2e-result-row:last-child{border-bottom:none}.e2e-result-row.failed{background:#fef2f2}.e2e-result-icon{font-size:14px}.e2e-result-name{font-weight:500;word-break:break-word}.e2e-result-time{font-feature-settings:"tnum";color:#94a3b8;font-size:11px;font-variant-numeric:tabular-nums}.e2e-result-error{background:#fff;border:1px solid #fecaca;border-radius:6px;grid-column:1/-1;margin-top:6px;padding:6px}.e2e-result-error summary{color:#b91c1c;cursor:pointer;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.e2e-result-error pre{color:#475569;font-size:11px;margin:8px 0 0;max-height:200px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}.e2e-empty{color:#94a3b8;font-size:13px;padding:32px}.e2e-empty.small{font-size:12px;padding:16px}.e2e-log-panel{background:#fff;border-radius:10px;box-shadow:0 1px 3px #00000014;padding:12px 14px}.e2e-log-panel h3{color:#475569;font-size:13px;font-weight:700;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.e2e-log-stream{background:#0f172a;border-radius:8px;color:#e2e8f0;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12px;height:240px;line-height:1.5;overflow-y:auto;padding:10px 12px}.e2e-log-line{grid-gap:10px;display:grid;gap:10px;grid-template-columns:80px 1fr;padding:1px 0}.e2e-log-time{color:#64748b}.e2e-log-line.lvl-warn .e2e-log-msg{color:#fbbf24}.e2e-log-line.lvl-error .e2e-log-msg{color:#f87171}:root{--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--primary-300:#93c5fd;--primary-400:#60a5fa;--primary-500:#4a90d9;--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--primary-900:#1e3a8a;--success-500:#22c55e;--success-100:#dcfce7;--warning-500:#f59e0b;--warning-100:#fef3c7;--error-500:#ef4444;--error-100:#fee2e2;--info-500:#3b82f6;--info-100:#dbeafe;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--child-primary:#8b5cf6;--child-secondary:#ec4899;--child-accent:#f59e0b;--child-safe:#10b981;--child-world-bg-start:#e0f2fe;--child-world-bg-end:#f3e8ff;--child-world-card-1:#fef3c7;--child-world-card-2:#dcfce7;--child-world-card-3:#fce7f3;--child-world-card-4:#e0e7ff;--child-world-accent:#f59e0b;--child-world-safe:#10b981;--child-world-primary:#8b5cf6;--child-world-secondary:#ec4899;--shadow-child-soft:0 8px 32px #8b5cf626;--shadow-child-float:0 12px 40px #8b5cf633,0 4px 12px #0000000d;--shadow-child-glow:0 0 30px #8b5cf64d;--radius-child-sm:12px;--radius-child-md:20px;--radius-child-lg:28px;--radius-child-xl:36px;--parent-slate-50:#f8fafc;--parent-slate-100:#f1f5f9;--parent-slate-200:#e2e8f0;--parent-slate-300:#cbd5e1;--parent-slate-400:#94a3b8;--parent-slate-500:#64748b;--parent-slate-600:#475569;--parent-slate-700:#334155;--parent-slate-800:#1e293b;--parent-slate-900:#0f172a;--parent-primary:#3b82f6;--parent-primary-light:#60a5fa;--parent-primary-dark:#2563eb;--parent-success:#10b981;--parent-warning:#f59e0b;--parent-danger:#ef4444;--parent-info:#6366f1;--glass-bg:#fffc;--glass-border:#ffffff4d;--glass-shadow:0 8px 32px #00000014;--shadow-parent-sm:0 1px 2px 0 #00000008;--shadow-parent-md:0 4px 6px -1px #0000000d,0 2px 4px -2px #0000000d;--shadow-parent-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #00000008;--shadow-parent-xl:0 20px 25px -5px #00000014,0 8px 10px -6px #00000005;--radius-parent-sm:6px;--radius-parent-md:10px;--radius-parent-lg:14px;--radius-parent-xl:18px;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-display:"Nunito",var(--font-sans);--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--radius-sm:0.25rem;--radius-md:0.375rem;--radius-lg:0.5rem;--radius-xl:0.75rem;--radius-2xl:1rem;--radius-full:9999px;--transition-fast:150ms ease-in-out;--transition-base:200ms ease-in-out;--transition-slow:300ms ease-in-out;--z-dropdown:100;--z-sticky:200;--z-modal:300;--z-popover:400;--z-toast:500}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;background-color:#f8fafc;background-color:var(--gray-50);color:#1e293b;color:var(--gray-800);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-sans);font-size:1rem;font-size:var(--text-base);line-height:1.5;touch-action:pan-y pan-x;-webkit-user-select:none;user-select:none}#root,body,html{height:100%;width:100%}code,pre{white-space:pre-wrap;word-break:break-word}.admin-theme,.child-dashboard,.child-profile,.child-theme,.parent-dashboard,.parent-theme{-webkit-overflow-scrolling:touch;min-height:100%;overflow-x:hidden;overflow-y:auto}h1,h2,h3,h4,h5,h6{color:#0f172a;color:var(--gray-900);font-family:Nunito,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-display);font-weight:700;line-height:1.2}h1{font-size:2.25rem;font-size:var(--text-4xl)}h2{font-size:1.875rem;font-size:var(--text-3xl)}h3{font-size:1.5rem;font-size:var(--text-2xl)}h4{font-size:1.25rem;font-size:var(--text-xl)}h5{font-size:1.125rem;font-size:var(--text-lg)}h6{font-size:1rem;font-size:var(--text-base)}p{margin-bottom:1rem;margin-bottom:var(--space-4)}a{color:#2563eb;color:var(--primary-600);text-decoration:none;transition:color .15s ease-in-out;transition:color var(--transition-fast)}a:hover{color:#1d4ed8;color:var(--primary-700)}button,input,select,textarea{font-family:inherit;font-size:inherit}button{background:none;border:none;cursor:pointer}img{height:auto;max-width:100%}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}:focus-visible{outline:2px solid #4a90d9;outline:2px solid var(--primary-500);outline-offset:2px}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f5f9;background:var(--gray-100)}::-webkit-scrollbar-thumb{background:#94a3b8;background:var(--gray-400);border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#64748b;background:var(--gray-500)}::selection{background:#bfdbfe;background:var(--primary-200);color:#1e3a8a;color:var(--primary-900)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.container{margin:0 auto;max-width:1280px;padding:0 1rem;padding:0 var(--space-4);width:100%}@media (min-width:640px){.container{padding:0 1.5rem;padding:0 var(--space-6)}}@media (min-width:1024px){.container{padding:0 2rem;padding:0 var(--space-8)}}.animate-fade-in{animation:fadeIn .2s ease-in-out;animation:fadeIn var(--transition-base)}.animate-slide-up{animation:slideInUp .3s ease-in-out;animation:slideInUp var(--transition-slow)}@media print{.no-print{display:none!important}}html{overscroll-behavior:none}[contenteditable],input,textarea{user-select:text;-webkit-user-select:text}*{scroll-behavior:smooth}.btn,a,button{-webkit-touch-callout:none}*,.btn,a,button{touch-action:manipulation}@supports (padding-top:env(safe-area-inset-top)){.safe-area-top{padding-top:env(safe-area-inset-top)}.safe-area-bottom{padding-bottom:env(safe-area-inset-bottom)}.safe-area-left{padding-left:env(safe-area-inset-left)}.safe-area-right{padding-right:env(safe-area-inset-right)}}@media (max-width:640px){body{font-size:16px}#root{min-height:100vh;min-height:100dvh}}.hide-scrollbar::-webkit-scrollbar{display:none}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}body .modal-overlay{z-index:2000}body .modal-content{display:flex;flex-direction:column;overflow:hidden}body .modal-header{flex-shrink:0}body .event-modal-body{overflow-y:auto}.cs-page-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:space-between;margin-bottom:var(--space-6)}.cs-page-header__text{flex:1 1;min-width:0}.cs-page-header__title{color:var(--gray-900);font-size:var(--text-2xl);font-weight:700;line-height:1.2;margin:0 0 var(--space-1) 0}.cs-page-header__subtitle{color:var(--gray-600);font-size:var(--text-sm);margin:0}.cs-page-header__actions{align-items:center;display:flex;flex-shrink:0;gap:var(--space-2)}.child-theme .cs-page-header__title{color:var(--child-world-primary)}@media (max-width:640px){.cs-page-header__title{font-size:var(--text-xl)}}.cs-empty-state{background:#fff;border:1px dashed var(--gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-10) var(--space-6);text-align:center}.cs-empty-state__icon{display:block;font-size:48px;line-height:1;margin-bottom:var(--space-4);opacity:.7}.cs-empty-state__title{color:var(--gray-800);font-size:var(--text-lg);font-weight:600;margin:0 0 var(--space-2) 0}.cs-empty-state__desc{color:var(--gray-600);font-size:var(--text-sm);margin:0 0 var(--space-4) 0;margin-left:auto;margin-right:auto;max-width:480px}.cs-empty-state__action{display:flex;gap:var(--space-2);justify-content:center;margin-top:var(--space-4)}.child-theme .cs-empty-state{background:#ffffffd9;border-color:#8b5cf640;border-radius:var(--radius-child-lg)}.cs-filter-pills{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-5)}.cs-filter-pill{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-full);color:var(--gray-600);cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:500;gap:var(--space-2);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast);white-space:nowrap}.cs-filter-pill:hover{border-color:var(--primary-300);color:var(--primary-600)}.cs-filter-pill.is-active{background:var(--primary-500);border-color:var(--primary-500);color:#fff}.cs-filter-pill__count{align-items:center;background:var(--gray-100);border-radius:var(--radius-full);color:var(--gray-700);display:inline-flex;font-size:var(--text-xs);font-weight:600;height:18px;justify-content:center;min-width:20px;padding:0 6px}.cs-filter-pill.is-active .cs-filter-pill__count{background:#ffffff40;color:#fff}.child-theme .cs-filter-pill:hover{border-color:var(--child-world-primary);color:var(--child-world-primary)}.child-theme .cs-filter-pill.is-active{background:var(--child-world-primary);border-color:var(--child-world-primary)}.e2e-toggle-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:50%;bottom:20px;box-shadow:0 4px 12px #6366f166;cursor:pointer;font-size:24px;height:50px;left:20px;position:fixed;transition:all .3s ease;width:50px;z-index:9999}.e2e-toggle-btn:hover{box-shadow:0 6px 20px #6366f180;transform:scale(1.1)}.e2e-panel{background:#fff;border:1px solid #e5e7eb;border-radius:16px;bottom:80px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;left:20px;max-height:600px;overflow:hidden;position:fixed;width:450px;z-index:9998}.e2e-header{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;justify-content:space-between;padding:16px 20px}.e2e-header h3{font-size:16px;font-weight:600;margin:0}.e2e-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;height:28px;justify-content:center;transition:all .2s;width:28px}.e2e-close:hover{background:#ffffff4d}.e2e-controls{border-bottom:1px solid #e5e7eb;display:flex;gap:10px;padding:16px 20px}.e2e-clear-btn,.e2e-run-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-weight:600;padding:10px 16px;transition:all .2s}.e2e-run-btn{background:#10b981;color:#fff}.e2e-run-btn:hover:not(:disabled){background:#059669}.e2e-run-btn:disabled{background:#9ca3af;cursor:not-allowed}.e2e-clear-btn{background:#f3f4f6;color:#374151}.e2e-clear-btn:hover:not(:disabled){background:#e5e7eb}.e2e-report-actions{background:#fef3c7;border-bottom:1px solid #f59e0b;display:flex;gap:8px;padding:12px 20px}.e2e-report-btn{background:#f59e0b;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:10px 16px;transition:all .2s}.e2e-report-btn:hover{background:#d97706}.e2e-report-btn.secondary{background:#fff;border:2px solid #f59e0b;color:#f59e0b}.e2e-report-btn.secondary:hover{background:#fef3c7}.e2e-summary{border-bottom:1px solid #e5e7eb;padding:12px 20px}.e2e-summary.all-passed{background:#d1fae5}.e2e-summary.has-failures{background:#fee2e2}.e2e-stats{display:flex;font-weight:600;gap:20px}.e2e-total{color:#6b7280}.e2e-passed{color:#059669}.e2e-failed{color:#dc2626}.e2e-duration{color:#6b7280;font-size:12px;margin-top:8px}.e2e-logs{background:#f9fafb;flex:1 1;font-family:Monaco,Menlo,monospace;font-size:12px;line-height:1.6;max-height:300px;overflow-y:auto;padding:16px 20px}.e2e-empty{color:#9ca3af;padding:40px 20px;text-align:center}.e2e-log-line{border-bottom:1px solid #f3f4f6;padding:4px 0;white-space:pre-wrap;word-break:break-word}.e2e-log-line.log-pass{color:#059669;font-weight:600}.e2e-log-line.log-fail{color:#dc2626;font-weight:600}.e2e-log-line.log-suite{color:#6366f1;font-weight:600;margin-top:8px}.e2e-log-line.log-summary{border-top:2px solid #e5e7eb;color:#1f2937;font-weight:700;margin-top:8px;padding-top:8px}.e2e-failures{background:#fee2e2;border-top:1px solid #fecaca;max-height:150px;overflow-y:auto;padding:16px 20px}.e2e-failures h4{color:#dc2626;font-size:14px;margin:0 0 12px}.e2e-failure-item{background:#fff;border-left:3px solid #dc2626;border-radius:8px;margin-bottom:12px;padding:10px}.e2e-failure-item strong{color:#1f2937;display:block;margin-bottom:4px}.e2e-failure-item span{color:#6b7280;font-size:12px}.e2e-error-msg{color:#dc2626;font-family:monospace;font-size:13px;margin-top:6px}.e2e-stack-trace{margin-top:10px}.e2e-stack-trace summary{color:#6b7280;cursor:pointer;font-size:12px;-webkit-user-select:none;user-select:none}.e2e-stack-trace pre{background:#1f2937;border-radius:6px;color:#e5e7eb;font-size:11px;margin-top:8px;max-height:150px;overflow-x:auto;overflow-y:auto;padding:12px}.e2e-failure-banner{align-items:center;background:#fee2e2;border-top:2px solid #ef4444;color:#dc2626;display:flex;font-weight:600;justify-content:space-between;padding:12px 20px}.e2e-failure-banner button{background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:8px 16px}.e2e-failure-banner button:hover{background:#b91c1c}@media (max-width:640px){.e2e-panel{left:10px;max-height:70vh;right:10px;width:auto}}
/*# sourceMappingURL=main.a7918f9d.css.map*/