*{box-sizing:border-box;margin:0;padding:0}.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}.skip-link{background:#3b82f6;background:var(--color-primary,#3b82f6);border-radius:0 0 4px 0;color:#fff;font-weight:600;left:0;padding:8px 16px;position:absolute;text-decoration:none;top:-40px;z-index:10000}.skip-link:focus{top:0}:focus-visible{outline:2px solid #3b82f6;outline:2px solid var(--color-primary,#3b82f6);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}:root{--color-primary-50:#eef2ff;--color-primary-100:#e0e7ff;--color-primary-200:#c7d2fe;--color-primary-300:#a5b4fc;--color-primary-400:#818cf8;--color-primary-500:#6366f1;--color-primary-600:#4f46e5;--color-primary-700:#4338ca;--color-primary-800:#3730a3;--color-primary-900:#312e81;--color-success-50:#f0fdf4;--color-success-100:#dcfce7;--color-success-200:#bbf7d0;--color-success-300:#86efac;--color-success-400:#4ade80;--color-success-500:#22c55e;--color-success-600:#16a34a;--color-success-700:#15803d;--color-success-800:#166534;--color-success-900:#14532d;--color-error-50:#fef2f2;--color-error-100:#fee2e2;--color-error-200:#fecaca;--color-error-300:#fca5a5;--color-error-400:#f87171;--color-error-500:#ef4444;--color-error-600:#dc2626;--color-error-700:#b91c1c;--color-error-800:#991b1b;--color-error-900:#7f1d1d;--color-warning-50:#fefce8;--color-warning-100:#fef9c3;--color-warning-200:#fef08a;--color-warning-300:#fde047;--color-warning-400:#facc15;--color-warning-500:#eab308;--color-warning-600:#ca8a04;--color-warning-700:#a16207;--color-warning-800:#854d0e;--color-warning-900:#713f12;--color-info-50:#eff6ff;--color-info-100:#dbeafe;--color-info-200:#bfdbfe;--color-info-300:#93c5fd;--color-info-400:#60a5fa;--color-info-500:#3b82f6;--color-info-600:#2563eb;--color-info-700:#1d4ed8;--color-info-800:#1e40af;--color-info-900:#1e3a8a;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-400:#9ca3af;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--bg-primary:#fff;--bg-secondary:var(--color-gray-50);--bg-tertiary:var(--color-gray-100);--bg-inverse:var(--color-gray-900);--text-primary:var(--color-gray-800);--text-secondary:var(--color-gray-500);--text-muted:var(--color-gray-400);--text-inverse:#fff;--border-light:var(--color-gray-200);--border-color:var(--color-gray-200);--border-dark:var(--color-gray-400);--card-bg:#fff;--card-border:var(--color-gray-200);--card-shadow:0 1px 3px #0000001a;--input-bg:#fff;--input-border:var(--color-gray-300);--input-focus-border:var(--color-primary-600);--input-placeholder:var(--color-gray-400);--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #0000001a,0 1px 2px #0000000f;--shadow-md:0 4px 6px #0000001a,0 2px 4px #0000000f;--shadow-lg:0 10px 15px #0000001a,0 4px 6px #0000000d;--shadow-xl:0 20px 25px #0000001a,0 10px 10px #0000000a;--shadow:#0000001a;--theme-primary:var(--color-primary-600);--theme-primary-hover:var(--color-primary-700);--theme-primary-light:var(--color-primary-100);--theme-secondary:var(--color-primary-400);--theme-accent:var(--color-primary-500);--theme-background:var(--color-gray-50);--theme-text:var(--color-gray-800);--status-success:var(--color-success-600);--status-success-light:var(--color-success-50);--status-success-bg:var(--color-success-100);--status-error:var(--color-error-500);--status-error-light:var(--color-error-50);--status-error-bg:var(--color-error-100);--status-warning:var(--color-warning-500);--status-warning-light:var(--color-warning-50);--status-warning-bg:var(--color-warning-100);--status-pending:var(--color-warning-100);--status-info:var(--color-info-500);--status-info-light:var(--color-info-50);--hover-bg:var(--color-gray-100);--active-bg:var(--color-gray-200);--focus-ring:0 0 0 3px #4f46e54d;--gradient-primary:linear-gradient(135deg,var(--color-primary-500) 0%,var(--color-primary-700) 100%);--gradient-brand:linear-gradient(135deg,#667eea,#764ba2);--gradient-brand-alt:linear-gradient(135deg,#4c1d95,#5b21b6);--gradient-success:linear-gradient(90deg,#10b981,#059669);--gradient-gold:linear-gradient(90deg,#fbbf24,#f59e0b);--gradient-start:#667eea;--gradient-end:#764ba2;--spacing-0:0;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:0.75rem;--spacing-lg:1rem;--spacing-xl:1.25rem;--spacing-2xl:1.5rem;--spacing-3xl:2rem;--radius-none:0;--radius-sm:0.25rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-3xl:2rem;--radius-full:9999px;--font-family-base:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-family-mono:source-code-pro,Menlo,Monaco,Consolas,"Courier New",monospace;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--transition-fast:150ms ease;--transition-base:200ms ease;--transition-medium:300ms ease;--transition-slow:500ms ease;--z-dropdown:100;--z-sticky:200;--z-fixed:300;--z-modal-backdrop:400;--z-modal:500;--z-popover:600;--z-tooltip:700;--z-notification:800;--shimmer:#ffffff4d;--overlay-bg:#00000080;--badge-bg:var(--color-error-500);--progress-bg:var(--color-gray-200)}body.dark-mode{--bg-primary:var(--color-gray-900);--bg-secondary:var(--color-gray-800);--bg-tertiary:var(--color-gray-700);--bg-inverse:#fff;--text-primary:var(--color-gray-50);--text-secondary:var(--color-gray-300);--text-muted:var(--color-gray-400);--text-inverse:var(--color-gray-900);--border-light:var(--color-gray-700);--border-color:var(--color-gray-600);--border-dark:var(--color-gray-500);--card-bg:var(--color-gray-800);--card-border:var(--color-gray-700);--card-shadow:0 1px 3px #0000004d;--input-bg:var(--color-gray-800);--input-border:var(--color-gray-600);--input-focus-border:var(--color-primary-400);--input-placeholder:var(--color-gray-500);--shadow:#00000080;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 6px #0000004d;--shadow-lg:0 10px 15px #0000004d;--theme-primary:var(--color-primary-400);--theme-primary-hover:var(--color-primary-300);--theme-primary-light:var(--color-primary-900);--theme-background:var(--color-gray-900);--theme-text:var(--color-gray-50);--hover-bg:var(--color-gray-700);--active-bg:var(--color-gray-600);--focus-ring:0 0 0 3px #818cf866;--status-success:var(--color-success-400);--status-success-light:#10b98133;--status-success-bg:#10b98126;--status-error:var(--color-error-400);--status-error-light:#ef444433;--status-error-bg:#ef444426;--status-warning:var(--color-warning-400);--status-warning-light:#f59e0b33;--status-warning-bg:#f59e0b26;--status-pending:#f59e0b33;--status-info:var(--color-info-400);--status-info-light:#3b82f633;--gradient-brand:linear-gradient(135deg,#4c1d95,#5b21b6);--gradient-start:#4c1d95;--gradient-end:#5b21b6;--shimmer:#ffffff1a;--overlay-bg:#000c;--badge-bg:var(--color-primary-500);--progress-bg:var(--color-gray-700)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;background-color:var(--bg-secondary);color:#1f2937;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background-color .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{padding:0 20px}.btn{border:none;border-radius:.75rem;border-radius:var(--radius-lg);cursor:pointer;display:inline-block;font-size:16px;font-weight:600;padding:.75rem 1.5rem;padding:var(--spacing-md) var(--spacing-2xl);text-align:center;text-decoration:none;transition:all var(--transition-base)}.btn:active{transform:scale(.98)}.btn-primary{background:#4f46e5;background:var(--color-primary-600);color:#fff;transition:all .3s ease;transition:all var(--transition-medium)}.btn-primary:hover{background:#4338ca;background:var(--color-primary-700);box-shadow:0 4px 12px #4f46e566;transform:translateY(-2px)}.btn-primary:active{box-shadow:0 2px 6px #4f46e54d;transform:translateY(0)}.btn-secondary{background:#e5e7eb;background:var(--border-color);color:#1f2937;color:var(--text-primary)}.btn-secondary:hover{background:#d1d5db;background:var(--color-gray-300)}.btn-success{background:#16a34a;background:var(--color-success-600);color:#fff;transition:all .3s ease;transition:all var(--transition-medium)}.btn-success:hover{background:#15803d;background:var(--color-success-700);box-shadow:0 4px 12px #10b98166;transform:translateY(-2px)}.btn-success:active{box-shadow:0 2px 6px #10b9814d;transform:translateY(0)}.btn-danger{background:#ef4444;background:var(--color-error-500);color:#fff;transition:all .3s ease;transition:all var(--transition-medium)}.btn-danger:hover{background:#dc2626;background:var(--color-error-600);box-shadow:0 4px 12px #ef444466;transform:translateY(-2px)}.btn-danger:active{box-shadow:0 2px 6px #ef44444d;transform:translateY(0)}.btn-large{border-radius:1rem;border-radius:var(--radius-xl);font-size:18px;min-height:60px;padding:18px 2rem;padding:18px var(--spacing-3xl)}.card{background:#fff;border-radius:1rem;box-shadow:0 1px 3px #0000001a;box-shadow:0 1px 3px var(--shadow);padding:1.5rem;padding:var(--spacing-2xl);transition:all .3s ease;transition:all var(--transition-medium)}.card:hover{box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--shadow);transform:translateY(-2px)}.app-controls{align-items:center;bottom:1.25rem;bottom:var(--spacing-xl);display:flex;gap:.75rem;position:fixed;right:1.25rem;right:var(--spacing-xl);z-index:1000}.dark-mode-toggle{align-items:center;background:#fff;background:var(--card-bg);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:50%;box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--shadow);cursor:pointer;display:flex;font-size:24px;height:56px;justify-content:center;transition:all .3s ease;transition:all var(--transition-medium);width:56px}.dark-mode-toggle:hover{box-shadow:0 6px 20px #0000001a;box-shadow:0 6px 20px var(--shadow);transform:scale(1.1) rotate(20deg)}.dark-mode-toggle:active{transform:scale(.95)}.input{background:#fff;background:var(--card-bg);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:.75rem;border-radius:var(--radius-lg);color:#1f2937;color:var(--text-primary);font-size:16px;outline:none;padding:.75rem 1rem;padding:var(--spacing-md) var(--spacing-lg);transition:border-color .2s ease;transition:border-color var(--transition-base);width:100%}.input:focus{border-color:#4f46e5;border-color:var(--color-primary-600)}.label{color:#1f2937;color:var(--text-primary);display:block;font-weight:600;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.form-group{margin-bottom:1.25rem;margin-bottom:var(--spacing-xl)}.error{color:#ef4444;color:var(--color-error-500)}.error,.success{font-size:14px;margin-top:.5rem;margin-top:var(--spacing-sm)}.success{color:#16a34a;color:var(--color-success-600)}.spinner{animation:spin 1s linear infinite;border:3px solid #f3f4f6;border-top:3px solid #4f46e5;border:3px solid var(--color-gray-100);border-radius:50%;border-top-color:var(--color-primary-600);height:40px;margin:40px auto;width:40px}body.dark-mode{.status-pending{background:#854d0e!important;border:1px solid #ca8a04!important;color:#fef3c7!important}.status-approved,.status-completed{background:#065f46!important;border:1px solid #10b981!important;color:#d1fae5!important}.status-error,.status-rejected{background:#991b1b!important;border:1px solid #ef4444!important;color:#fee2e2!important}.approval-card,.goal-card,.kid-card,.reward-card,.task-card{border:1px solid #e5e7eb!important;border:1px solid var(--border-color)!important}.empty-state{color:#6b7280!important;color:var(--text-secondary)!important}.modal-overlay{background:#000c!important}.kid-avatar{border:3px solid #e5e7eb!important;border:3px solid var(--border-color)!important}.error-box{background:#991b1b!important;border-color:#ef4444!important;color:#fee2e2!important}.success{color:#86efac!important}.error{color:#fca5a5!important}.spinner{border-color:#e5e7eb!important;border-color:var(--border-color)!important;border-top-color:#818cf8!important}}[data-theme=dark]{--color-primary:#60a5fa;--color-primary-dark:#3b82f6;--color-primary-light:#93c5fd;--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-hover:#475569;--card-bg:#1e293b;--card-bg-elevated:#334155;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-tertiary:#64748b;--text-disabled:#475569;--border-color:#334155;--border-color-light:#475569;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px #0006;--shadow-lg:0 10px 15px #00000080;--color-success:#22c55e;--color-success-bg:#22c55e26;--color-error:#ef4444;--color-error-bg:#ef444426;--color-warning:#f59e0b;--color-warning-bg:#f59e0b26;--color-info:#3b82f6;--color-info-bg:#3b82f626}[data-theme=dark] .calendar-view{background:var(--card-bg);border-color:var(--border-color)}[data-theme=dark] .calendar-day-headers{background:var(--bg-tertiary)}[data-theme=dark] .day-header{color:var(--text-secondary)}[data-theme=dark] .calendar-day{border-color:var(--border-color)}[data-theme=dark] .calendar-day.other-month{background:var(--bg-primary)}[data-theme=dark] .calendar-day.today{background:#3b82f61a}[data-theme=dark] .calendar-day.today .day-number{background:var(--color-primary)}[data-theme=dark] .calendar-day:hover{background:var(--bg-tertiary)}[data-theme=dark] .day-number{color:var(--text-primary)}[data-theme=dark] .calendar-legend{border-color:var(--border-color)}[data-theme=dark] .global-search .search-input{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .global-search .search-input::placeholder{color:var(--text-tertiary)}[data-theme=dark] .search-results{background:var(--card-bg);border-color:var(--border-color);box-shadow:var(--shadow-lg)}[data-theme=dark] .result-section{border-color:var(--border-color)}[data-theme=dark] .result-item.selected,[data-theme=dark] .result-item:hover{background:var(--bg-tertiary)}[data-theme=dark] .result-title{color:var(--text-primary)}[data-theme=dark] .skeleton{--skeleton-base:#334155;--skeleton-highlight:#475569}[data-theme=dark] .skeleton-card,[data-theme=dark] .template-selector{background:var(--card-bg);border-color:var(--border-color)}[data-theme=dark] .template-selector-header{border-color:var(--border-color)}[data-theme=dark] .template-selector-header h2{color:var(--text-primary)}[data-theme=dark] .template-search{border-color:var(--border-color)}[data-theme=dark] .template-search-input{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .category-card{background:var(--bg-tertiary);border-color:#0000}[data-theme=dark] .category-card:hover{background:var(--bg-hover);border-color:var(--color-primary)}[data-theme=dark] .category-name{color:var(--text-primary)}[data-theme=dark] .template-card{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .template-card:hover{border-color:var(--color-primary)}[data-theme=dark] .template-title{color:var(--text-primary)}[data-theme=dark] .template-selector-footer{background:var(--bg-primary);border-color:var(--border-color)}[data-theme=dark] .notification-prompt{background:var(--card-bg);border-color:var(--border-color)}[data-theme=dark] .prompt-title{color:var(--text-primary)}[data-theme=dark] .prompt-description{color:var(--text-secondary)}[data-theme=dark] .language-selector-btn{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .language-selector-btn:hover{background:var(--bg-hover)}[data-theme=dark] .language-dropdown{background:var(--card-bg);border-color:var(--border-color)}[data-theme=dark] .language-option{color:var(--text-primary)}[data-theme=dark] .language-option:hover{background:var(--bg-tertiary)}[data-theme=dark] .language-option.active{background:#3b82f633}[data-theme=dark] .offline-banner.offline{background:linear-gradient(135deg,#b91c1c,#991b1b)}[data-theme=dark] .offline-banner.reconnected{background:linear-gradient(135deg,#15803d,#166534)}[data-theme=dark] .swipeable-card{background:var(--card-bg)}[data-theme=dark] .deleted-tasks-header h3{color:var(--text-primary)}[data-theme=dark] .deleted-task-card{background:var(--card-bg);border-color:var(--border-color)}[data-theme=dark] .deleted-task-card:hover{border-color:var(--color-primary)}[data-theme=dark] .deleted-task-title{color:var(--text-primary)}[data-theme=dark] .deleted-tasks-footer{border-color:var(--border-color)}[data-theme=dark] .empty-state p{color:var(--text-primary)}[data-theme=dark] .modal-content{background:var(--card-bg);border-color:var(--border-color)}[data-theme=dark] .modal-header{border-color:var(--border-color)}[data-theme=dark] .modal-header h2{color:var(--text-primary)}[data-theme=dark] .input,[data-theme=dark] .select,[data-theme=dark] textarea{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .input:focus,[data-theme=dark] .select:focus,[data-theme=dark] textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #60a5fa33}[data-theme=dark] .input::placeholder{color:var(--text-tertiary)}[data-theme=dark] .label{color:var(--text-secondary)}[data-theme=dark] .btn-secondary{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .btn-secondary:hover{background:var(--bg-hover)}[data-theme=dark] .dashboard-header{background:var(--bg-secondary);border-color:var(--border-color)}[data-theme=dark] .header-subtitle,[data-theme=dark] .nav-btn{color:var(--text-secondary)}[data-theme=dark] .nav-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}[data-theme=dark] .nav-btn.active{background:var(--color-primary);color:#fff}[data-theme=dark] .card,[data-theme=dark] .goal-card,[data-theme=dark] .kid-card,[data-theme=dark] .reward-card,[data-theme=dark] .task-card{background:var(--card-bg);border-color:var(--border-color)}[data-theme=dark] .card:hover,[data-theme=dark] .task-card:hover{border-color:var(--color-primary)}[data-theme=dark] .task-type-badge{background:var(--bg-tertiary);color:var(--text-secondary)}[data-theme=dark] .task-type-badge.recurring{background:#60a5fa33;color:var(--color-primary)}[data-theme=dark] .nav-badge{background:var(--color-error)}[data-theme=dark] .settings-section{background:var(--card-bg);border-color:var(--border-color)}[data-theme=dark] .section-title{color:var(--text-primary)}[data-theme=dark] ::-webkit-scrollbar{height:8px;width:8px}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--bg-secondary)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:4px}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}@keyframes popIn{0%{opacity:0;transform:scale(.5)}70%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}@keyframes slideInFromBottom{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes celebrate{0%{transform:scale(1)}25%{transform:scale(1.2) rotate(-5deg)}50%{transform:scale(1.2) rotate(5deg)}75%{transform:scale(1.1) rotate(-3deg)}to{transform:scale(1) rotate(0deg)}}@keyframes glow{0%,to{box-shadow:0 0 5px #3b82f680}50%{box-shadow:0 0 20px #3b82f6cc}}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.animate-fade-in-up{animation:fadeInUp .4s ease-out forwards}.animate-fade-in-down{animation:fadeInDown .4s ease-out forwards}.animate-scale-in{animation:scaleIn .3s ease-out forwards}.animate-pop-in{animation:popIn .4s ease-out forwards}.animate-bounce{animation:bounce .6s ease-out}.animate-shake{animation:shake .5s ease-out}.animate-pulse{animation:pulse 1.5s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-slide-in-right{animation:slideInFromRight .3s ease-out forwards}.animate-slide-in-left{animation:slideInFromLeft .3s ease-out forwards}.animate-slide-in-bottom{animation:slideInFromBottom .3s ease-out forwards}.animate-celebrate{animation:celebrate .6s ease-out}.animate-glow{animation:glow 2s ease-in-out infinite}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.stagger-7{animation-delay:.35s}.stagger-8{animation-delay:.4s}.transition-fast{transition:all .15s ease}.transition-normal{transition:all .25s ease}.transition-slow{transition:all .4s ease}.transition-colors{transition:color .2s ease,background-color .2s ease,border-color .2s ease}.transition-transform{transition:transform .2s ease}.transition-opacity{transition:opacity .2s ease}.transition-shadow{transition:box-shadow .2s ease}.hover-lift{transition:transform .2s ease,box-shadow .2s ease}.hover-lift:hover{box-shadow:0 10px 20px #0000001a;transform:translateY(-4px)}.hover-scale{transition:transform .2s ease}.hover-scale:hover{transform:scale(1.02)}.hover-glow:hover{box-shadow:0 0 15px #3b82f666}.hover-bright:hover{filter:brightness(1.1)}.modal-overlay{animation:fadeIn .2s ease-out}.modal-content{animation:scaleIn .3s ease-out}.goal-card,.kid-card,.reward-card,.task-card{animation:fadeInUp .4s ease-out;animation-fill-mode:both}.task-grid .task-card:first-child{animation-delay:0s}.task-grid .task-card:nth-child(2){animation-delay:.05s}.task-grid .task-card:nth-child(3){animation-delay:.1s}.task-grid .task-card:nth-child(4){animation-delay:.15s}.task-grid .task-card:nth-child(5){animation-delay:.2s}.task-grid .task-card:nth-child(6){animation-delay:.25s}.btn{transition:all .2s ease}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.nav-btn{position:relative;transition:all .2s ease}.nav-btn:after{background:#3b82f6;background:var(--color-primary,#3b82f6);bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:all .2s ease;width:0}.nav-btn.active:after,.nav-btn:hover:after{width:80%}.nav-badge{animation:pulse 2s ease-in-out infinite}.input,.select,textarea{transition:border-color .2s ease,box-shadow .2s ease}.dropdown-menu,.language-dropdown,.search-results{animation:fadeInDown .2s ease-out}.notification,.toast{animation:slideInFromRight .3s ease-out}@keyframes checkmark{0%{stroke-dashoffset:100}to{stroke-dashoffset:0}}.success-checkmark path{stroke-dasharray:100;animation:checkmark .5s ease-out forwards}@keyframes loadingDots{0%,20%{opacity:0}50%{opacity:1}to{opacity:0}}.loading-dots span:first-child{animation:loadingDots 1.4s 0s infinite}.loading-dots span:nth-child(2){animation:loadingDots 1.4s .2s infinite}.loading-dots span:nth-child(3){animation:loadingDots 1.4s .4s infinite}.calendar-day{transition:background-color .15s ease,transform .15s ease}.calendar-day:hover{transform:scale(1.02)}.page-enter{opacity:0;transform:translateY(10px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}.page-exit{opacity:1}.page-exit-active{opacity:0;transition:opacity .2s ease}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.hover-lift:hover,.hover-scale:hover{transform:none}}@media (max-width:768px){.dashboard-nav{background:#fff;background:var(--card-bg,#fff);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);bottom:0;box-shadow:0 -2px 10px #0000001a;display:flex;justify-content:space-around;left:0;padding:.5rem;position:fixed;right:0;z-index:100}.dashboard-nav .nav-btn{flex-direction:column;font-size:.65rem;gap:.25rem;min-width:50px;padding:.5rem .25rem}.dashboard-nav .nav-btn:before{font-size:1.25rem}.dashboard-nav .nav-btn[class*=tasks]:before{content:"📋"}.dashboard-nav .nav-btn[class*=approvals]:before{content:"✅"}.dashboard-nav .nav-btn[class*=kids]:before{content:"👧"}.dashboard-nav .nav-btn[class*=goals]:before{content:"🎯"}.dashboard-nav .nav-btn[class*=rewards]:before{content:"🎁"}.dashboard-nav .nav-btn[class*=calendar]:before{content:"📅"}.dashboard-nav .nav-btn[class*=settings]:before{content:"⚙️"}.dashboard-main{padding-bottom:80px}.dashboard-header{padding:1rem}.dashboard-header .header-content{align-items:stretch;flex-direction:column;gap:1rem}.dashboard-header .header-left h1{font-size:1.25rem}.dashboard-header .header-center{margin:0;max-width:100%}.dashboard-header .header-right{justify-content:space-between}}@media (max-width:768px){@media (max-width:480px){.header-subtitle{display:none}}}@media (max-width:768px){.app-controls{bottom:auto;right:.75rem;top:.75rem}.app-controls .dark-mode-toggle{font-size:20px;height:44px;width:44px}.app-controls .language-selector-btn{padding:.375rem .5rem}.goal-card,.kid-card,.reward-card,.task-card{padding:1rem}.goal-grid,.reward-grid,.task-grid{gap:.75rem;grid-template-columns:1fr}.card-actions{flex-direction:column;gap:.5rem}.card-actions .btn{justify-content:center;width:100%}.form-row{flex-direction:column;gap:1rem}.form-group{width:100%}.input,.select,textarea{font-size:16px;padding:.875rem 1rem}.btn{font-size:1rem;padding:.875rem 1.5rem}.modal-actions{flex-direction:column;gap:.75rem}.modal-actions .btn{width:100%}.modal-overlay{align-items:flex-end;padding:0}.modal-content{border-radius:1rem 1rem 0 0;margin:0;max-height:90vh;max-width:100%}.modal-header{background:#fff;background:var(--card-bg,#fff);padding:1rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.modal-body{overflow-y:auto}.calendar-view,.modal-body{padding:1rem}.calendar-header{flex-direction:column;gap:1rem}.calendar-actions,.calendar-nav{justify-content:space-between;width:100%}.calendar-day{min-height:60px;padding:.25rem}.day-number{font-size:.75rem}.day-items{display:none}.calendar-day.has-items:after{background:#3b82f6;background:var(--color-primary,#3b82f6);border-radius:50%;bottom:4px;content:"";height:6px;left:50%;position:absolute;transform:translateX(-50%);width:6px}.global-search{max-width:100%}.search-shortcut{display:none}.search-results{left:1rem;max-height:calc(100vh - 150px);position:fixed;right:1rem;top:70px}.settings-section{margin-bottom:1rem;padding:1rem}.section-title{font-size:1rem}.settings-grid{grid-template-columns:1fr}.deleted-tasks-header{align-items:flex-start;flex-direction:column}.deleted-task-card{flex-direction:column}.deleted-task-actions,.deleted-task-actions .btn{width:100%}.template-selector{border-radius:1rem 1rem 0 0;max-height:95vh}.category-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)}.category-card{padding:1rem}.category-icon{font-size:1.5rem}.category-name{font-size:.75rem}.table-responsive{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.data-table{min-width:600px}.mobile-card-table{display:block}.mobile-card-table thead{display:none}.mobile-card-table tr{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;display:block;margin-bottom:1rem;padding:1rem}.mobile-card-table td{border:none;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;padding:.5rem 0}.mobile-card-table td:last-child{border-bottom:none}.mobile-card-table td:before{color:#6b7280;color:var(--text-secondary,#6b7280);content:attr(data-label);font-weight:600}.notification-prompt-overlay{bottom:70px;left:1rem;right:1rem}.notification-prompt{max-width:100%}.offline-banner{bottom:70px}}@media (hover:none) and (pointer:coarse){.btn,.input,.nav-btn,.select{min-height:44px}.hover-lift:hover,.hover-scale:hover{transform:none}.btn:active,.card:active,.nav-btn:active{opacity:.8;transform:scale(.98)}.swipeable-card-container:after{bottom:100%;color:#9ca3af;color:var(--text-tertiary,#9ca3af);content:"← Swipe →";font-size:.65rem;left:50%;opacity:0;padding:.25rem;position:absolute;transform:translateX(-50%);transition:opacity .2s}.swipeable-card-container:first-child:after{animation:fadeOut 2s 3s forwards;opacity:1}}@media (max-width:768px) and (orientation:landscape){.modal-content{max-height:95vh}.dashboard-nav{border-right:1px solid #e5e7eb;border-right:1px solid var(--border-color,#e5e7eb);border-top:none;bottom:0;flex-direction:column;left:0;padding:1rem .5rem;right:auto;top:0;width:auto}.dashboard-main{padding-bottom:0;padding-left:70px}}@media (max-width:375px){.dashboard-header .header-left h1{font-size:1.1rem}.dashboard-nav .nav-btn{font-size:.6rem;min-width:40px;padding:.375rem .125rem}.btn{font-size:.875rem;padding:.75rem 1rem}.modal-content{max-height:95vh}}@supports (padding-bottom:env(safe-area-inset-bottom)){.dashboard-nav{padding-bottom:calc(.5rem + env(safe-area-inset-bottom))}.modal-content{padding-bottom:env(safe-area-inset-bottom)}.notification-prompt-overlay,.offline-banner{bottom:calc(70px + env(safe-area-inset-bottom))}}.skeleton{animation:skeleton-shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%);background:linear-gradient(90deg,var(--skeleton-base,#e5e7eb) 25%,var(--skeleton-highlight,#f3f4f6) 50%,var(--skeleton-base,#e5e7eb) 75%);background-size:200% 100%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}[data-theme=dark] .skeleton{--skeleton-base:#374151;--skeleton-highlight:#4b5563}.skeleton-card{background:#fff;background:var(--card-background,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;padding:1.25rem}[data-theme=dark] .skeleton-card{--card-background:#1f2937;--border-color:#374151}.skeleton-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.skeleton-card-meta{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.skeleton-card-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;gap:.5rem;padding-top:1rem}.skeleton-task-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.skeleton-kid-card{min-width:280px}.skeleton-kid-header{align-items:center;display:flex;margin-bottom:1rem}.skeleton-kid-stats{margin-top:1rem}.skeleton-kids-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.skeleton-approval-item{margin-bottom:1rem}.skeleton-approval-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.skeleton-approval-actions{display:flex;gap:.75rem;margin-top:1rem}.skeleton-approvals-list{display:flex;flex-direction:column;gap:1rem}.skeleton-dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem;padding:1rem 0}.skeleton-stats-card{min-width:150px}.skeleton-table-row{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;gap:1rem;padding:1rem 0}.skeleton-page{padding:1rem 0}.skeleton-page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.skeleton-text{width:100%}@media (max-width:768px){.skeleton-kids-grid,.skeleton-task-grid{grid-template-columns:1fr}.skeleton-dashboard-header{align-items:flex-start;flex-direction:column;gap:1rem}}.global-search{max-width:400px;position:relative;width:100%}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-icon{font-size:1rem;left:12px;opacity:.6;pointer-events:none;position:absolute}.search-input{background:#fff;background:var(--input-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;color:#1f2937;color:var(--text-primary,#1f2937);font-size:.875rem;padding:.625rem 3rem .625rem 2.5rem;transition:all .2s ease;width:100%}.search-input:focus{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6);box-shadow:0 0 0 3px #3b82f61a;outline:none}.search-input::placeholder{color:#9ca3af;color:var(--text-secondary,#9ca3af)}.search-shortcut{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:4px;color:#9ca3af;color:var(--text-secondary,#9ca3af);font-size:.7rem;font-weight:500;padding:2px 6px;position:absolute;right:12px}.search-results{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;box-shadow:0 10px 40px #00000026;left:0;max-height:400px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.no-results{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;padding:1.5rem;text-align:center}.result-section{padding:.5rem 0}.result-section:not(:last-child){border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb)}.result-section-header{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;font-size:.75rem;font-weight:600;gap:.5rem;letter-spacing:.05em;padding:.5rem 1rem;text-transform:uppercase}.section-icon{font-size:.875rem}.result-item{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:.75rem 1rem;transition:background .15s ease}.result-item.selected,.result-item:hover{background:#f3f4f6;background:var(--bg-hover,#f3f4f6)}.result-title{color:#1f2937;color:var(--text-primary,#1f2937);font-size:.875rem;font-weight:500}.result-meta{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem}[data-theme=dark] .search-input{--input-bg:#374151;--border-color:#4b5563;--text-primary:#f3f4f6}[data-theme=dark] .search-shortcut{--bg-secondary:#4b5563;--border-color:#6b7280}[data-theme=dark] .search-results{--card-bg:#1f2937;--border-color:#374151}[data-theme=dark] .result-item.selected,[data-theme=dark] .result-item:hover{--bg-hover:#374151}@media (max-width:768px){.global-search{max-width:100%}.search-shortcut{display:none}.search-input{padding-right:1rem}.search-results{max-height:300px}}.offline-banner{animation:slideUp .3s ease-out;bottom:0;left:0;padding:.75rem 1rem;position:fixed;right:0;z-index:9999}.offline-banner.offline{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.offline-banner.reconnected{animation:slideUp .3s ease-out,fadeOut .5s ease-out 2.5s forwards;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.offline-banner-content{align-items:center;display:flex;gap:.75rem;justify-content:center;margin:0 auto;max-width:1200px}.offline-icon{font-size:1.25rem}.offline-text{font-size:.875rem;font-weight:500}@media (max-width:480px){.offline-banner{padding:.625rem .75rem}.offline-text{font-size:.8rem}}.notification-prompt-overlay{animation:slideIn .3s ease-out;bottom:20px;position:fixed;right:20px;z-index:9998}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.notification-prompt{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:16px;box-shadow:0 10px 40px #00000026;max-width:340px;padding:1.5rem;text-align:center}.prompt-icon{font-size:3rem;margin-bottom:.75rem}.prompt-title{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.prompt-description{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;line-height:1.5;margin-bottom:1.25rem}.prompt-actions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.prompt-actions .btn{justify-content:center;width:100%}.prompt-dismiss{background:none;border:none;color:#9ca3af;color:var(--text-secondary,#9ca3af);cursor:pointer;font-size:.75rem;padding:.25rem;text-decoration:underline}.prompt-dismiss:hover{color:#6b7280;color:var(--text-primary,#6b7280)}[data-theme=dark] .notification-prompt{--card-bg:#1f2937;--border-color:#374151}@media (max-width:480px){.notification-prompt-overlay{bottom:10px;left:10px;right:10px}.notification-prompt{max-width:100%}}.swipeable-card-container{border-radius:12px;overflow:hidden;position:relative}.swipeable-card{background:#fff;background:var(--card-bg,#fff);position:relative;touch-action:pan-y;-webkit-user-select:none;user-select:none;z-index:2}.swipeable-card.dragging{cursor:grabbing}.swipe-action{align-items:center;bottom:0;display:flex;position:absolute;top:0;transition:opacity .15s ease;width:100%;z-index:1}.swipe-action-left{justify-content:flex-start;left:0;padding-left:1.5rem}.swipe-action-right{justify-content:flex-end;padding-right:1.5rem;right:0}.swipe-action-content{align-items:center;color:#fff;display:flex;font-size:1.5rem;font-weight:600;gap:.5rem}@keyframes swipeHint{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.swipeable-card.show-hint{animation:swipeHint 1s ease-in-out}[data-theme=dark] .swipeable-card{--card-bg:#1f2937}@media (hover:none) and (pointer:coarse){.swipeable-card:active{opacity:.95}}@media (hover:hover) and (pointer:fine){.swipeable-card{touch-action:auto}}.template-selector-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.template-selector{animation:slideUp .3s ease-out;background:#fff;background:var(--card-bg,#fff);border-radius:16px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;max-height:85vh;max-width:700px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.template-selector-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.template-selector-header h2{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.25rem;font-weight:700;margin:0}.template-selector-header .close-btn{background:none;border:none;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;font-size:1.5rem;line-height:1;padding:.25rem}.template-search{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);padding:1rem 1.5rem}.template-search-input{background:#f9fafb;background:var(--input-bg,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;font-size:.875rem;padding:.75rem 1rem;width:100%}.template-search-input:focus{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6);box-shadow:0 0 0 3px #3b82f61a;outline:none}.template-categories{flex:1 1;overflow-y:auto;padding:1.5rem}.template-hint{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;margin-bottom:1rem;text-align:center}.category-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.category-card{align-items:center;background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:2px solid #0000;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;padding:1.25rem;transition:all .2s ease}.category-card:hover{background:#eff6ff;background:var(--bg-hover,#eff6ff);border-color:#3b82f6;border-color:var(--color-primary,#3b82f6);transform:translateY(-2px)}.category-icon{font-size:2rem}.category-name{color:#1f2937;color:var(--text-primary,#1f2937);font-size:.875rem;font-weight:600}.category-count{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem}.template-list-container{flex:1 1;overflow-y:auto;padding:1rem 1.5rem}.back-btn{background:none;border:none;color:#3b82f6;color:var(--color-primary,#3b82f6);cursor:pointer;font-size:.875rem;margin-bottom:1rem;padding:.5rem 0}.back-btn:hover{text-decoration:underline}.template-list{display:flex;flex-direction:column;gap:.75rem}.template-card{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:10px;cursor:pointer;padding:1rem;transition:all .2s ease}.template-card:hover{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6);box-shadow:0 4px 12px #0000001a}.template-card-header{margin-bottom:.5rem}.template-category-badge{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase}.template-title{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1rem;font-weight:600;margin:0 0 .25rem}.template-description{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.8rem;line-height:1.4;margin:0 0 .75rem}.template-footer{align-items:center;display:flex;justify-content:space-between}.template-reward{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem}.use-template-btn{background:#3b82f6;background:var(--color-primary,#3b82f6);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.75rem;font-weight:600;padding:.375rem .75rem;transition:background .2s ease}.use-template-btn:hover{background:#2563eb;background:var(--color-primary-dark,#2563eb)}.no-templates{color:#6b7280;color:var(--text-secondary,#6b7280);padding:2rem;text-align:center}.no-templates p{margin-bottom:1rem}.template-selector-footer{align-items:center;background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-radius:0 0 16px 16px;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;padding:1rem 1.5rem}.footer-hint{color:#9ca3af;color:var(--text-secondary,#9ca3af);font-size:.75rem}[data-theme=dark] .template-selector{--card-bg:#1f2937;--border-color:#374151}[data-theme=dark] .category-card{--bg-secondary:#374151}[data-theme=dark] .category-card:hover{--bg-hover:#1e3a5f}[data-theme=dark] .template-card{--bg-secondary:#374151}[data-theme=dark] .template-search-input{--input-bg:#374151}[data-theme=dark] .template-selector-footer{--bg-secondary:#111827}@media (max-width:600px){.template-selector{border-radius:16px 16px 0 0;margin-top:auto;max-height:95vh}.category-grid{grid-template-columns:repeat(2,1fr)}.template-selector-footer{flex-direction:column;gap:.75rem}.footer-hint{order:-1}}.calendar-view{background:#fff;background:var(--card-bg,#fff);border-radius:12px;box-shadow:0 1px 3px #0000001a;box-shadow:var(--shadow-sm,0 1px 3px #0000001a);padding:1.5rem}.calendar-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:1.5rem}.calendar-header,.calendar-nav{align-items:center;display:flex;gap:1rem}.calendar-nav .nav-btn{align-items:center;background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.calendar-nav .nav-btn:hover{background:#e5e7eb;background:var(--bg-hover,#e5e7eb)}.calendar-title{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.25rem;font-weight:700;margin:0;min-width:180px;text-align:center}.calendar-actions{align-items:center;display:flex;gap:.75rem}.view-toggle{border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;display:flex;overflow:hidden}.toggle-btn{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:none;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;font-size:.8rem;padding:.5rem .75rem;transition:all .2s ease}.toggle-btn:first-child{border-right:1px solid #e5e7eb;border-right:1px solid var(--border-color,#e5e7eb)}.toggle-btn.active{background:#3b82f6;background:var(--color-primary,#3b82f6);color:#fff}.toggle-btn:hover:not(.active){background:#e5e7eb;background:var(--bg-hover,#e5e7eb)}.calendar-grid{border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;overflow:hidden}.calendar-day-headers{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:grid;grid-template-columns:repeat(7,1fr)}.day-header{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem;font-weight:600;padding:.75rem .5rem;text-align:center;text-transform:uppercase}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);border-right:1px solid #e5e7eb;border-right:1px solid var(--border-color,#e5e7eb);cursor:pointer;min-height:100px;padding:.5rem;position:relative;transition:background .2s ease}.calendar-day:nth-child(7n){border-right:none}.calendar-day:nth-last-child(-n+7){border-bottom:none}.calendar-day:hover{background:#f3f4f6;background:var(--bg-hover,#f3f4f6)}.calendar-day.other-month{background:#f9fafb;background:var(--bg-secondary,#f9fafb)}.calendar-day.other-month .day-number{color:#d1d5db;color:var(--text-disabled,#d1d5db)}.calendar-day.today{background:#3b82f60d}.calendar-day.today .day-number{align-items:center;background:#3b82f6;background:var(--color-primary,#3b82f6);border-radius:50%;color:#fff;display:flex;height:28px;justify-content:center;width:28px}.calendar-day.selected{background:#3b82f61a;box-shadow:inset 0 0 0 2px #3b82f6;box-shadow:inset 0 0 0 2px var(--color-primary,#3b82f6)}.day-number{align-items:center;color:#1f2937;color:var(--text-primary,#1f2937);display:inline-flex;font-size:.875rem;font-weight:500;justify-content:center;min-height:28px;min-width:28px}.day-items{display:flex;flex-direction:column;gap:2px;margin-top:.25rem}.day-item{align-items:center;border-radius:4px;cursor:pointer;display:flex;font-size:.65rem;gap:4px;overflow:hidden;padding:2px 4px;text-overflow:ellipsis;white-space:nowrap}.day-item.task-item{background:#3b82f61a;color:#3b82f6;color:var(--color-primary,#3b82f6)}.day-item.task-item.completed{background:#22c55e1a;color:#16a34a;text-decoration:line-through}.day-item.goal-item{background:#f59e0b1a;color:#d97706}.day-item:hover{opacity:.8}.item-dot{border-radius:50%;flex-shrink:0;height:6px;width:6px}.task-dot{background:#3b82f6;background:var(--color-primary,#3b82f6)}.goal-dot{background:#f59e0b}.item-title{overflow:hidden;text-overflow:ellipsis}.more-items{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.6rem;padding:2px 4px}.calendar-legend{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;gap:1.5rem;justify-content:center;margin-top:1rem;padding-top:1rem}.legend-item{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;font-size:.75rem;gap:.5rem}.legend-dot{border-radius:50%;height:10px;width:10px}[data-theme=dark] .calendar-view{--card-bg:#1f2937;--border-color:#374151;--bg-secondary:#111827;--bg-hover:#374151}[data-theme=dark] .calendar-nav .nav-btn{background:#374151;border-color:#4b5563}[data-theme=dark] .calendar-day.other-month{background:#111827}[data-theme=dark] .calendar-day.other-month .day-number{color:#4b5563}@media (max-width:768px){.calendar-view{padding:1rem}.calendar-header{align-items:stretch;flex-direction:column}.calendar-actions,.calendar-nav{justify-content:space-between}.calendar-day{min-height:70px;padding:.25rem}.day-number{font-size:.75rem;min-height:24px;min-width:24px}.calendar-day.today .day-number{height:24px;width:24px}.day-items{display:none}.calendar-day.has-items:after{background:#3b82f6;background:var(--color-primary,#3b82f6);border-radius:50%;bottom:4px;content:"";height:6px;left:50%;position:absolute;transform:translateX(-50%);width:6px}.day-header{font-size:.65rem;padding:.5rem .25rem}}@media (max-width:480px){.toggle-btn{font-size:.7rem;padding:.375rem .5rem}.calendar-title{font-size:1rem;min-width:auto}}.language-selector{position:relative}.language-selector-btn{align-items:center;background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;color:#1f2937;color:var(--text-primary,#1f2937);cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem .75rem;transition:all .2s ease}.language-selector-btn:hover{background:#e5e7eb;background:var(--bg-hover,#e5e7eb)}.lang-flag{font-size:1.125rem;line-height:1}.lang-name{font-weight:500}.lang-arrow{font-size:.625rem;margin-left:.25rem;transition:transform .2s ease}.lang-arrow.open{transform:rotate(180deg)}.language-dropdown{animation:dropdownFadeIn .2s ease;background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:160px;overflow:hidden;position:absolute;right:0;top:calc(100% + 4px);z-index:100}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.language-option{align-items:center;background:none;border:none;color:#1f2937;color:var(--text-primary,#1f2937);cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:background .15s ease;width:100%}.language-option:hover{background:#f3f4f6;background:var(--bg-hover,#f3f4f6)}.language-option.active{background:#3b82f61a}.lang-check,.language-option.active{color:#3b82f6;color:var(--color-primary,#3b82f6)}.lang-check{margin-left:auto}.language-selector.compact .language-selector-btn{padding:.375rem .5rem}.language-selector.compact .lang-name{display:none}[data-theme=dark] .language-selector-btn{background:#374151;border-color:#4b5563}[data-theme=dark] .language-selector-btn:hover{background:#4b5563}[data-theme=dark] .language-dropdown{background:#1f2937;border-color:#374151}[data-theme=dark] .language-option:hover{background:#374151}@media (max-width:480px){.language-selector .lang-name{display:none}.language-dropdown{min-width:140px}}.App{background:var(--bg-secondary);color:var(--text-primary);min-height:100vh}.container{margin:0 auto;max-width:1200px;padding:0 var(--spacing-6)}.card{background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--spacing-6);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}@media (max-width:768px){.container{padding:0 var(--spacing-4)}.btn{font-size:var(--font-size-sm);padding:var(--spacing-3) var(--spacing-5)}.btn-large{font-size:var(--font-size-base);min-height:56px;padding:var(--spacing-4) var(--spacing-6)}.card{border-radius:var(--radius-lg);padding:var(--spacing-5)}}@media (max-width:480px){.container{padding:0 var(--spacing-3)}.btn{width:100%}}.page-loader{align-items:center;background:var(--bg-secondary);display:flex;justify-content:center;min-height:100vh}.page-loader .spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-top-color:#3b82f6;border:4px solid var(--border-color,#e5e7eb);border-radius:50%;border-top-color:var(--color-primary,#3b82f6);height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.auth-container{align-items:center;background:var(--gradient-brand);display:flex;justify-content:center;min-height:100vh;padding:var(--spacing-5)}.auth-card{background:var(--card-bg);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);max-width:480px;padding:var(--spacing-12);width:100%}.auth-title{color:var(--text-primary);font-size:var(--font-size-4xl);font-weight:700;margin-bottom:var(--spacing-2);text-align:center}.auth-subtitle{color:var(--text-secondary);font-size:var(--font-size-base);margin-bottom:var(--spacing-8);text-align:center}.error-box{background:var(--status-error-light);border:2px solid var(--color-error-500);border-radius:var(--radius-lg);color:var(--color-error-600);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--spacing-5);padding:var(--spacing-3) var(--spacing-4)}body.dark-mode .error-box{background:var(--status-error-bg);border-color:var(--color-error-400);color:var(--color-error-300)}.auth-footer{color:var(--text-secondary);margin-top:var(--spacing-6);text-align:center}.auth-footer a{color:var(--theme-primary);font-weight:600;text-decoration:none;transition:color var(--transition-fast)}.auth-footer a:hover{color:var(--theme-primary-hover);text-decoration:underline}.role-buttons{grid-gap:var(--spacing-3);display:grid;gap:var(--spacing-3);grid-template-columns:1fr 1fr}.role-btn{background:var(--card-bg);border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;font-size:var(--font-size-base);font-weight:600;padding:var(--spacing-4);transition:all var(--transition-base)}.role-btn:hover{background:var(--bg-secondary)}.role-btn.active,.role-btn:hover{border-color:var(--theme-primary)}.role-btn.active{background:var(--theme-primary);color:#fff}body.dark-mode .role-btn.active,body.dark-mode .role-btn:hover{border-color:var(--color-primary-300)}body.dark-mode .role-btn.active{background:var(--color-primary-400);color:var(--color-gray-900)}.divider{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--font-size-sm);font-weight:500;margin:var(--spacing-6) 0;text-align:center}.divider:after,.divider:before{border-bottom:1px solid var(--border-color);content:"";flex:1 1}.divider span{padding:0 var(--spacing-4)}.btn-google{align-items:center;background:#fff;border:1px solid var(--color-gray-300);color:var(--color-gray-700);display:flex;font-weight:500;justify-content:center;transition:all var(--transition-base)}.btn-google:hover{background:var(--color-gray-50);border-color:var(--color-gray-400);box-shadow:var(--shadow-sm)}.btn-google:active{background:var(--color-gray-100);border-color:var(--color-gray-500)}.btn-google:disabled{background:var(--color-gray-50);border-color:var(--color-gray-200);color:var(--color-gray-400);cursor:not-allowed}body.dark-mode .btn-google{background:var(--color-gray-800);border-color:var(--color-gray-600);color:var(--color-gray-100)}body.dark-mode .btn-google:hover{background:var(--color-gray-700);border-color:var(--color-gray-500)}@media (max-width:480px){.auth-card{padding:var(--spacing-8) var(--spacing-6)}.auth-title{font-size:var(--font-size-3xl)}}
/*# sourceMappingURL=main.0beba3c9.css.map*/