@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&display=swap";.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#3a9d9b,#5bc0be,#9575cd)}.auth-card{background:#fff;border-radius:24px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 16px 48px #00000026}.auth-header{text-align:center;margin-bottom:1.5rem}.auth-header h1{font-size:1.85rem;color:var(--color-primary);margin:0;display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:800}.auth-header h1 .piggypad-logo{animation:bounce 2s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.auth-header p{color:var(--color-gray-500);margin:.5rem 0 0;font-size:1rem;font-weight:600}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group label{font-weight:700;color:var(--color-gray-700);font-size:.9rem}.form-group input,.form-group select{padding:.875rem 1rem;border:2px solid var(--color-gray-200);border-radius:12px;font-size:1rem;font-family:inherit;transition:all .2s ease;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #3a9d9b26}.form-group input::placeholder{color:var(--color-gray-400)}.btn{padding:.875rem 1.5rem;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #3a9d9b4d}.auth-form .btn-primary{margin-top:.5rem}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 6px 16px #3a9d9b66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:#fff;color:var(--color-primary);border:2px solid var(--color-primary);box-shadow:0 2px 8px #3a9d9b26}.btn-secondary:hover:not(:disabled){background:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #3a9d9b4d}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-large{padding:1rem 1.75rem;font-size:1.05rem}.btn-google{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem;background:#fff;border:2px solid var(--color-gray-200);border-radius:12px;color:var(--color-gray-700);font-weight:700;transition:all .2s ease}.btn-google:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-300);transform:translateY(-2px)}.btn-google:active:not(:disabled){transform:translateY(0)}.btn-google:disabled{opacity:.6;cursor:not-allowed}.btn-google svg{width:20px;height:20px}.auth-divider{display:flex;align-items:center;gap:1rem;margin:.5rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:2px;background:var(--color-gray-200);border-radius:1px}.auth-divider span{color:var(--color-gray-400);font-size:.85rem;font-weight:600}.auth-link{text-align:center;margin-top:1.25rem;color:var(--color-gray-600)}.auth-link a{color:var(--color-primary);text-decoration:none;font-weight:700;transition:color .2s ease}.auth-link a:hover{color:var(--color-primary-dark);text-decoration:underline}.error-message{background:#e5737326;color:var(--color-danger);padding:.875rem;border-radius:12px;font-size:.9rem;border:2px solid rgba(229,115,115,.3);font-weight:600}.role-selector{display:flex;gap:.875rem}.role-option{flex:1;padding:1.25rem;border:3px solid var(--color-gray-200);border-radius:16px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:center}.role-option:hover{border-color:var(--color-primary-light);background:var(--color-gray-50);transform:translateY(-2px)}.role-option.selected{border-color:var(--color-primary);background:var(--color-primary);color:#fff;transform:scale(1.02)}.role-option.selected .role-label{color:#fff}.role-icon{font-size:2.5rem;display:block;margin-bottom:.5rem}.role-label{font-weight:700;color:var(--color-gray-700);font-size:1rem}@media (max-width: 500px){.auth-card{padding:1.5rem;border-radius:16px}.auth-header h1{font-size:1.5rem}.role-selector{flex-direction:column}}.navigation{background:var(--color-primary);box-shadow:0 2px 12px #3a9d9b4d;position:sticky;top:0;z-index:1000}.nav-container{max-width:1300px;margin:0 auto;padding:.875rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;position:relative}.nav-logo{display:flex;align-items:center;gap:.5rem;text-decoration:none;font-size:1.25rem;font-weight:700;color:#fff;transition:opacity .2s ease}.nav-logo:hover{opacity:.9}.nav-logo-icon{font-size:1.75rem;animation:wiggle 2s ease-in-out infinite}.nav-logo .piggypad-logo{animation:wiggle 2s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}@keyframes wiggle{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.nav-logo-text{display:none}@media (min-width: 768px){.nav-logo-text{display:inline}}.nav-links{display:flex;gap:.25rem;flex:1;justify-content:center;flex-wrap:wrap}.nav-hamburger{display:none;flex-direction:column;justify-content:space-around;width:2rem;height:2rem;background:transparent;border:none;cursor:pointer;padding:0;z-index:10}.nav-hamburger span{width:2rem;height:.25rem;background:#fff;border-radius:10px;transition:all .3s linear;position:relative;transform-origin:1px}.nav-hamburger:hover span{background:#fffc}.nav-link{padding:.5rem 1.25rem;border-radius:10px;text-decoration:none;color:#ffffffe6;font-weight:600;transition:all .2s ease;white-space:nowrap;font-size:.95rem}.nav-link:hover{background:#fff3;color:#fff}.nav-link.active{background:#fff;color:var(--color-primary);font-weight:700;box-shadow:0 2px 8px #0000001a}.nav-user{display:flex;align-items:center;gap:.75rem}.nav-user-badge{font-size:1.5rem}.nav-user-email{color:#ffffffe6;font-size:.85rem;display:none}@media (min-width: 1024px){.nav-user-email{display:inline}}.nav-settings-btn{display:flex;align-items:center;justify-content:center;padding:.5rem 1.25rem;border-radius:10px;background:#fff3;color:#fff;text-decoration:none;transition:all .2s ease;border:2px solid rgba(255,255,255,.3)}.nav-settings-btn:hover{background:#ffffff4d;transform:rotate(15deg)}.nav-settings-btn.active{background:#fff;color:var(--color-primary);border-color:#fff}.nav-settings-btn svg{width:24px;height:24px}.nav-logout-btn{padding:.5rem 1.25rem;border:none;border-radius:10px;background:#fff3;color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;font-size:.85rem;border:2px solid rgba(255,255,255,.3)}.nav-logout-btn:hover{background:#ffffff4d}@media (max-width: 767px){.nav-container{padding:.625rem 1rem;flex-wrap:nowrap}.nav-hamburger{display:flex;order:2}.nav-hamburger.open span:first-child{transform:rotate(45deg)}.nav-hamburger.open span:nth-child(2){opacity:0;transform:translate(20px)}.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg)}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--color-primary);box-shadow:0 4px 12px #0003;padding:1rem;gap:.5rem;z-index:999;animation:slideDown .3s ease-out;border-top:1px solid rgba(255,255,255,.1)}.nav-links.open{display:flex}.nav-link{padding:.875rem 1rem;font-size:1rem;width:100%;text-align:left;border-radius:8px}.nav-link:hover{background:#ffffff26}.nav-link.active{background:#fff;color:var(--color-primary)}.nav-user{order:3;gap:.5rem}.nav-user-email{display:none}.nav-settings-btn{padding:.5rem;min-width:2.5rem}.nav-logout-btn{padding:.5rem .75rem;font-size:.8rem}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 768px) and (max-width: 1023px){.nav-container{padding:.75rem 1.5rem}.nav-links{gap:.2rem}.nav-link{padding:.5rem 1rem;font-size:.9rem}}.piggy-bank-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:var(--shadow-card);transition:all .2s ease;border:2px solid var(--color-gray-200);text-decoration:none;display:block;position:relative;overflow:hidden}.piggy-bank-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-info))}.piggy-bank-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary-light)}.piggy-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.piggy-avatar{font-size:2.5rem;width:65px;height:65px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffe4b8,#ffcf80);border-radius:50%;border:3px solid #FFB347;box-shadow:0 4px 12px #ffb3474d}.piggy-info{flex:1}.piggy-name{font-size:1.3rem;font-weight:700;color:var(--color-gray-800);margin:0}.piggy-label{color:var(--color-primary);font-size:.9rem;margin:.25rem 0 0;font-weight:600}.piggy-balance{text-align:center;padding:1.25rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-radius:14px;margin-bottom:1.25rem}.balance-label{color:#ffffffe6;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.balance-value{font-size:clamp(1.5rem,5vw,1.85rem);font-weight:800;color:#fff!important;word-break:break-word;display:block;text-shadow:0 2px 8px rgba(0,0,0,.2);-webkit-text-fill-color:#ffffff!important}.piggy-actions{display:flex;gap:.75rem}.btn-action{flex:1;padding:.75rem;border:none;border-radius:10px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .2s ease;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:.375rem}.btn-add{background:var(--color-success);color:#fff;box-shadow:0 4px 12px #4caf6e4d}.btn-add:hover{background:var(--color-success-light);transform:translateY(-2px);box-shadow:0 6px 16px #4caf6e66}.btn-spend{background:var(--color-warning);color:#fff;box-shadow:0 4px 12px #f5a6234d}.btn-spend:hover{background:var(--color-warning-light);transform:translateY(-2px);box-shadow:0 6px 16px #f5a62366}.own-badge{position:absolute;top:0;right:0;background:var(--color-accent);color:#fff;padding:.35rem 1rem;border-radius:0 0 0 14px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px}@media (max-width: 500px){.piggy-header{flex-direction:column;text-align:center}.balance-value{font-size:1.3rem}.piggy-actions{flex-direction:column}}.balance-display{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 50%,var(--color-info) 100%);border-radius:24px;padding:2.5rem;margin-bottom:2rem;box-shadow:0 8px 24px #3a9d9b40;text-align:center;position:relative;overflow:hidden}.balance-display:before{content:"";position:absolute;top:-50%;right:-20%;width:50%;height:150%;background:#ffffff1a;border-radius:50%;pointer-events:none}.balance-content{position:relative;z-index:1}.balance-main{margin-bottom:1.5rem}.balance-title{color:#ffffffe6;font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem;display:block}.balance-total,.balance-amount-large{font-size:3.5rem;font-weight:800;color:#fff;margin:0;display:block;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.15)}.balance-subtitle{color:#ffffffd9;font-size:1rem;margin-top:.5rem;font-weight:600}.balance-display .balance-stats{display:flex;justify-content:center;align-items:center;gap:2.5rem;margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid rgba(255,255,255,.2)}.balance-display .stat-item{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.375rem;min-width:110px}.balance-display .stat-icon{font-size:2rem;display:block;margin-bottom:.25rem}.balance-display .stat-value{font-size:1.65rem;font-weight:800;color:#fff!important;-webkit-text-fill-color:#ffffff!important;display:block;line-height:1.2;margin:.25rem 0;background:none!important;-webkit-background-clip:unset!important;background-clip:unset!important}.balance-display .stat-label{font-size:.8rem;color:#ffffffe6!important;-webkit-text-fill-color:rgba(255,255,255,.9)!important;font-weight:700;text-transform:uppercase;letter-spacing:.5px;display:block;margin-top:.125rem;background:none!important;-webkit-background-clip:unset!important;background-clip:unset!important}.balance-display .stat-divider{width:2px;height:55px;background:#ffffff40;border-radius:2px}@media (max-width: 768px){.balance-display{padding:2rem 1.5rem;border-radius:20px}.balance-total,.balance-amount-large{font-size:2.5rem}.balance-display .balance-stats{flex-direction:column;gap:1.25rem;align-items:center}.balance-display .stat-divider{width:60px;height:2px}.balance-display .stat-item{min-width:auto;width:100%}.balance-display .stat-value{font-size:1.5rem;color:#fff!important;-webkit-text-fill-color:#ffffff!important}}.invitation-banner{background:var(--color-primary);color:#fff;padding:1.25rem 1.5rem;margin-bottom:1.5rem;border-radius:10px;box-shadow:var(--shadow-md)}.banner-content{display:flex;align-items:center;gap:1.25rem;max-width:1100px;margin:0 auto}.banner-icon{font-size:2.5rem}.banner-text{flex:1}.banner-text h3{margin:0 0 .375rem;font-size:1.2rem;font-weight:600}.banner-text p{margin:0;opacity:.9;font-size:.95rem}.banner-actions{display:flex;gap:.75rem}.banner-actions .btn{white-space:nowrap;padding:.75rem 1.25rem;border-radius:8px;font-weight:600}.pending-invitations{margin-top:1.5rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:var(--shadow-card);border:1px solid var(--color-gray-200)}.pending-invitations h3{margin:0 0 1.25rem;color:var(--color-gray-800);font-size:1.2rem;font-weight:600}.invitations-list{display:flex;flex-direction:column;gap:.875rem}.invitation-card{padding:1rem;border:1px solid var(--color-gray-200);border-radius:8px;background:var(--color-gray-50);transition:all .2s ease}.invitation-card:hover{border-color:var(--color-gray-300);transform:translate(2px)}.invitation-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.625rem}.invitation-info{flex:1}.invitation-code{font-family:Courier New,monospace;font-weight:700;font-size:1.05rem;color:var(--color-primary);margin-bottom:.125rem;letter-spacing:1px}.invitation-email{color:var(--color-gray-800);font-size:.9rem;margin-bottom:.125rem;font-weight:500}.invitation-role{color:var(--color-gray-500);font-size:.85rem}.status-badge{padding:.25rem .625rem;border-radius:6px;font-size:.8rem;font-weight:600}.status-pending{background:var(--color-warning);color:#fff}.status-accepted{background:var(--color-success);color:#fff}.status-declined{background:var(--color-danger);color:#fff}.status-expired{background:var(--color-gray-300);color:var(--color-gray-600)}.invitation-actions{display:flex;gap:.375rem;margin-top:.625rem}.invitation-meta{display:flex;gap:.875rem;margin-top:.625rem;padding-top:.625rem;border-top:1px solid var(--color-gray-200)}.invitation-meta small{color:var(--color-gray-500);font-size:.8rem}.invite-success{text-align:center;padding:1.25rem}.success-icon{font-size:4rem;margin-bottom:.875rem}.invite-success h3{margin:0 0 .375rem;color:var(--color-gray-800);font-size:1.25rem;font-weight:600}.invite-link-container{display:flex;gap:.5rem;margin:1.25rem 0}.invite-link-input{flex:1;padding:.875rem;border:1px solid var(--color-gray-300);border-radius:8px;font-family:Courier New,monospace;font-size:.9rem;background:var(--color-gray-50);color:var(--color-gray-700)}.invite-code-display{margin:1.25rem 0;padding:1rem;background:var(--color-gray-50);border-radius:8px;border:1px solid var(--color-gray-200)}.invite-code-display p{margin:0 0 .375rem;color:var(--color-gray-700);font-weight:500}.invite-code{font-family:Courier New,monospace;font-size:1.5rem;font-weight:700;color:var(--color-primary);padding:.625rem 1rem;background:#fff;border-radius:8px;display:inline-block;border:1px solid var(--color-gray-200);letter-spacing:2px}.invite-email-note{margin-top:.875rem;padding:.875rem;background:#5b6b7c1a;border-radius:8px;color:var(--color-primary);font-size:.9rem;font-weight:500;border:1px solid rgba(91,107,124,.2)}.join-family-container{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:2rem}.join-family-card{max-width:480px;width:100%;background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);padding:2.5rem;text-align:center;border:1px solid var(--color-gray-200)}.join-family-header{margin-bottom:1.75rem}.join-icon{font-size:4rem;margin-bottom:.875rem}.join-family-header h1{margin:0;color:var(--color-gray-800);font-size:1.75rem;font-weight:600}.join-family-content{text-align:left}.invitation-message{text-align:center;color:var(--color-gray-500);margin-bottom:.375rem;font-size:1rem}.family-name{text-align:center;color:var(--color-primary);margin:.375rem 0;font-size:1.75rem;font-weight:600}.invitation-role{text-align:center;color:var(--color-gray-500);margin-bottom:1.75rem;font-weight:500}.join-family-actions{display:flex;flex-direction:column;gap:.875rem;margin-top:1.75rem}.join-family-error{text-align:center;padding:2.5rem;max-width:480px;margin:0 auto}.join-family-error h2{color:var(--color-danger);margin-bottom:.875rem;font-size:1.25rem}@media (max-width: 768px){.banner-content{flex-direction:column;text-align:center}.banner-actions{width:100%;flex-direction:column}.invite-link-container{flex-direction:column}.invitation-header{flex-direction:column;gap:.375rem}}.loading-container p{font-size:1.1rem;margin-top:1rem;font-weight:600;color:var(--color-primary)}.dashboard-container{min-height:calc(100vh - 70px);background:var(--bg-cream);padding:2rem}.dashboard-header{text-align:center;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:16px;border:2px solid var(--color-primary-light);box-shadow:var(--shadow-card)}.dashboard-header h1{font-size:2rem;color:var(--color-primary);margin:0;font-weight:800}.dashboard-header p{font-size:1.1rem;color:var(--color-gray-500);margin:.5rem 0 0;font-weight:600}.dashboard-content{max-width:1300px;margin:0 auto}.dashboard-placeholder{text-align:center;padding:2rem;background:#fff;border-radius:16px;color:var(--color-gray-600);font-size:1rem;box-shadow:var(--shadow-card);border:2px dashed var(--color-gray-300)}.empty-dashboard{text-align:center;padding:3rem 2rem;background:#fff;border-radius:16px;box-shadow:var(--shadow-card);border:2px dashed var(--color-primary-light);display:flex;flex-direction:column;align-items:center;gap:.5rem}.empty-dashboard-icon{font-size:4rem;margin-bottom:.5rem;animation:float 3s ease-in-out infinite}.empty-dashboard h2{color:var(--color-primary);font-size:1.75rem;margin:0;font-weight:800}.empty-dashboard-description{color:var(--color-gray-600);font-size:1.1rem;margin:.5rem 0 1.5rem;max-width:450px;line-height:1.5}.empty-dashboard-hint{color:var(--color-gray-500);font-size:.9rem;margin-top:1rem;padding:.75rem 1.25rem;background:var(--color-gray-50);border-radius:8px;border:1px solid var(--color-gray-200)}.empty-dashboard p{color:var(--color-gray-600);font-size:1.1rem;margin:0 0 1.5rem}.section-title{color:var(--color-gray-800);font-size:1.5rem;margin:0 0 1.25rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.piggy-banks-section{margin-bottom:2rem}.piggy-banks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.quick-actions{margin-top:2rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.action-card{background:#fff;border:2px solid var(--color-gray-200);border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.action-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary)}.action-card:nth-child(1){border-top:4px solid var(--color-success)}.action-card:nth-child(2){border-top:4px solid var(--color-warning)}.action-card:nth-child(3){border-top:4px solid var(--color-info)}.action-card:nth-child(4){border-top:4px solid var(--color-accent)}.action-icon{font-size:2.5rem;transition:transform .2s ease}.action-card:hover .action-icon{transform:scale(1.15)}.action-text{color:var(--color-gray-700);font-size:1rem;font-weight:700}@media (max-width: 768px){.dashboard-container{padding:1rem}.dashboard-header h1{font-size:1.5rem}.dashboard-header p{font-size:1rem}}.btn-add-member{width:100%;padding:1rem;border:2px dashed var(--color-gray-300);border-radius:8px;background:var(--color-gray-50);color:var(--color-gray-700);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-add-member:hover{background:var(--color-gray-100);border-color:var(--color-gray-400)}.add-member-form{padding:1.25rem 0}.add-member-form h3{margin:0 0 1.25rem;color:var(--color-gray-800);font-size:1.25rem;font-weight:600;text-align:center}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:600;color:var(--color-gray-700);font-size:.9rem}.form-group input,.form-group select{padding:.875rem;border:1px solid var(--color-gray-300);border-radius:8px;font-size:1rem;font-family:inherit;transition:all .2s ease;background:#fff}.avatar-option{width:48px;height:48px;border:2px solid var(--color-gray-200);border-radius:50%;background:var(--color-gray-50);font-size:1.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.avatar-option.selected{border-color:var(--color-primary);background:var(--color-primary)}.form-actions{display:flex;gap:.75rem;margin-top:1.25rem}.form-actions .btn{flex:1;padding:.875rem;border-radius:8px;font-size:.95rem}@media (max-width: 500px){.form-row{grid-template-columns:1fr}.avatar-option{width:42px;height:42px;font-size:1.3rem}.form-actions{flex-direction:column}}.setup-container{min-height:calc(100vh - 70px);background:var(--bg-primary);padding:2.5rem 2rem;display:flex;justify-content:center;align-items:flex-start}.setup-card{background:#fff;border-radius:12px;padding:2.5rem;max-width:650px;width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--color-gray-200)}.setup-header{text-align:center;margin-bottom:2rem}.setup-header h1{color:var(--color-gray-800);font-size:1.75rem;margin:0;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem}.setup-header p{color:var(--color-gray-500);font-size:1rem;margin:.5rem 0 0}.setup-steps{display:flex;justify-content:center;gap:1.25rem;margin-bottom:2rem}.step{display:flex;flex-direction:column;align-items:center;gap:.375rem}.step-number{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;transition:all .2s ease}.step.active .step-number{background:var(--color-primary);color:#fff}.step.completed .step-number{background:var(--color-success);color:#fff}.step:not(.active):not(.completed) .step-number{background:var(--color-gray-200);color:var(--color-gray-500)}.step-label{font-size:.85rem;color:var(--color-gray-500);font-weight:500}.step.active .step-label{color:var(--color-gray-800);font-weight:600}.setup-form{display:flex;flex-direction:column;gap:1.25rem}.form-group label{font-weight:600;color:var(--color-gray-700);font-size:.95rem;margin-bottom:.375rem;display:block}.btn{padding:.875rem 1.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary,.setup-actions .btn-secondary{background:#fff!important;color:var(--color-primary)!important;border:2px solid var(--color-primary)!important}.btn-secondary:hover,.setup-actions .btn-secondary:hover{background:var(--color-primary)!important;color:#fff!important;transform:translateY(-1px)}.btn-large{padding:1rem 2rem;font-size:1.05rem}.members-list{margin:1.25rem 0;display:flex;flex-direction:column;gap:.625rem}.member-item{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;background:var(--color-gray-50);border-radius:8px;border:1px solid var(--color-gray-200)}.member-info{display:flex;align-items:center;gap:.875rem}.member-avatar{font-size:1.5rem;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);border-radius:50%;border:1px solid var(--color-gray-200)}.member-details{display:flex;flex-direction:column}.member-name{font-weight:600;color:var(--color-gray-800);font-size:1rem}.member-meta{color:var(--color-gray-500);font-size:.85rem}.btn-remove{width:32px;height:32px;border-radius:50%;border:none;background:var(--color-danger);color:#fff;font-size:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-remove:hover{background:#a85850;transform:scale(1.05)}.setup-actions{display:flex;gap:.875rem;margin-top:.875rem}.setup-actions .btn{flex:1}@media (max-width: 600px){.setup-card{padding:1.75rem 1.5rem;border-radius:10px}.setup-header h1{font-size:1.5rem}.setup-steps{gap:.875rem}.step-number{width:36px;height:36px;font-size:1rem}.step-label{font-size:.75rem}.setup-actions{flex-direction:column}}.transaction-history{display:flex;flex-direction:column;gap:.875rem}.transaction-item{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border-radius:16px;border:2px solid var(--color-gray-200);transition:all .2s ease;position:relative;box-shadow:var(--shadow-sm)}.transaction-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;border-radius:16px 0 0 16px}.transaction-item.add:before{background:var(--color-success)}.transaction-item.spend:before{background:var(--color-warning)}.transaction-item:hover{transform:translate(4px);box-shadow:var(--shadow-md);border-color:var(--color-gray-300)}.transaction-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;border-radius:14px;transition:transform .2s ease}.transaction-item.add .transaction-icon{background:#4caf6e26}.transaction-item.spend .transaction-icon{background:#f5a62326}.transaction-item:hover .transaction-icon{transform:scale(1.1)}.transaction-details{flex:1}.transaction-header-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}.transaction-category{font-weight:700;color:var(--color-gray-800);font-size:1.05rem}.transaction-amount{font-weight:800;font-size:1.15rem;padding:.4rem .875rem;border-radius:10px}.transaction-amount.add{color:#fff;background:var(--color-success);box-shadow:0 4px 12px #4caf6e4d}.transaction-amount.spend{color:#fff;background:var(--color-warning);box-shadow:0 4px 12px #f5a6234d}.transaction-member{color:var(--color-primary);font-size:.9rem;margin-top:.25rem;font-weight:600}.transaction-note{color:var(--color-gray-500);font-size:.85rem;margin-top:.25rem;font-style:italic}.transaction-date{color:var(--color-gray-400);font-size:.8rem;margin-top:.35rem;font-weight:600}.transaction-delete{width:40px;height:40px;border:none;border-radius:12px;background:var(--color-danger);color:#fff;font-size:1.1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #e573734d}.transaction-delete:hover{background:#ef8a84;transform:scale(1.1)}.empty-transactions{text-align:center;padding:3rem 2rem;background:#fff;border-radius:16px;border:2px dashed var(--color-gray-300);box-shadow:var(--shadow-card);color:var(--color-gray-600);font-size:1rem;font-weight:600}.empty-transactions:before{content:"📝";display:block;font-size:3.5rem;margin-bottom:1rem}@media (max-width: 500px){.transaction-item{flex-wrap:wrap}.transaction-header-row{flex-direction:column;align-items:flex-start;gap:.375rem}.transaction-amount{font-size:1rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#3a9d9b4d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:24px;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:1.75rem 1.5rem 1.5rem;text-align:center;position:relative;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-radius:24px 24px 0 0;color:#fff}.modal-header h2{margin:0;font-size:1.4rem;font-weight:700}.modal-header p{margin:.25rem 0 0;opacity:.9;font-size:.95rem;font-weight:600}.modal-close{position:absolute;top:.875rem;right:.875rem;background:#fff3;border:none;font-size:1.25rem;width:36px;height:36px;border-radius:50%;cursor:pointer;color:#fff;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#ffffff4d}.modal-form{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.modal-form .form-group{display:flex;flex-direction:column;gap:.375rem}.modal-form label{font-weight:700;color:var(--color-gray-700);font-size:.9rem}.modal-form input,.modal-form select,.modal-form textarea{padding:.875rem;border:2px solid var(--color-gray-200);border-radius:12px;font-size:1rem;font-family:inherit;transition:all .2s ease;background:#fff}.modal-form input:focus,.modal-form select:focus,.modal-form textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #3a9d9b26}.modal-form input::placeholder,.modal-form textarea::placeholder{color:var(--color-gray-400)}.modal-form textarea{resize:vertical;min-height:70px}.icon-selector{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.icon-option{display:flex;align-items:center;justify-content:center;width:44px;height:44px;font-size:1.5rem;border:2px solid var(--color-gray-200);border-radius:10px;background:var(--color-gray-50);cursor:pointer;transition:all .2s ease}.icon-option:hover{border-color:var(--color-gray-400);background:#fff;transform:scale(1.05)}.icon-option.selected{border-color:var(--color-primary);background:#3a9d9b26;box-shadow:0 0 0 3px #3a9d9b33;transform:scale(1.05)}.modal-actions{display:flex;gap:.75rem;margin-top:.5rem}.modal-actions .btn{flex:1;padding:.875rem;border-radius:12px}.btn-success{background:var(--color-success);color:#fff;border:none;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:0 4px 12px #4caf6e4d}.btn-success:hover:not(:disabled){background:var(--color-success-light);transform:translateY(-2px);box-shadow:0 6px 16px #4caf6e66}.btn-warning{background:var(--color-warning);color:#fff;border:none;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:0 4px 12px #f5a6234d}.btn-warning:hover:not(:disabled){background:var(--color-warning-light);transform:translateY(-2px);box-shadow:0 6px 16px #f5a62366}.modal-actions .btn-secondary{background:#eeece8!important;color:#4a4844!important;border:2px solid #E0DDD8!important;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit}.modal-actions .btn-secondary:hover:not(:disabled){background:#e0ddd8!important;border-color:#bdbab4!important}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.support-modal{max-width:500px}.support-header{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.support-success{padding:2.5rem 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.support-success-icon{font-size:3.5rem;animation:bounceIn .5s ease-out}@keyframes bounceIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.support-success h3{margin:0;font-size:1.5rem;color:var(--color-primary)}.support-success p{margin:0;color:var(--color-gray-600);line-height:1.6;max-width:320px}.support-success .btn{margin-top:.5rem;min-width:140px}.issue-type-selector{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.issue-type-option{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:2px solid var(--color-gray-200);border-radius:10px;background:var(--color-gray-50);cursor:pointer;transition:all .2s ease;font-family:inherit;font-size:.875rem}.issue-type-option:hover{border-color:var(--color-gray-400);background:#fff}.issue-type-option.selected{border-color:#6366f1;background:#6366f11a;color:#6366f1}.issue-type-emoji{font-size:1.1rem}.issue-type-label{font-weight:600}.support-submit-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;display:flex;align-items:center;justify-content:center;gap:.5rem}.support-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#4f46e5,#7c3aed)!important;transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.btn-icon{font-size:1.1rem}.support-section{background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border:2px solid rgba(99,102,241,.3)}.support-section .settings-section-title{color:#6366f1}.support-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;color:#fff;font-size:1.1rem;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #6366f14d}.support-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #6366f166}.support-button-icon{font-size:1.5rem}.support-description{color:var(--color-gray-600);margin:0 0 1rem;font-size:.95rem;line-height:1.5}.confirm-delete-modal{max-width:380px}.confirm-delete-header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);text-align:center;padding-bottom:1rem}.confirm-delete-icon{font-size:2rem;margin-bottom:.25rem;opacity:.9}.confirm-delete-body{padding:1.5rem;text-align:center}.confirm-delete-message{color:var(--color-gray-600);font-size:.95rem;line-height:1.5;margin:0 0 1rem}.confirm-delete-item{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:10px;padding:.75rem 1rem;margin-bottom:1rem}.confirm-delete-item .item-label{font-weight:600;color:var(--color-gray-700);font-size:1rem}.confirm-delete-warning{color:var(--color-gray-500);font-size:.85rem;font-weight:500;margin:0;font-style:italic}.confirm-delete-actions{padding:0 1.5rem 1.5rem}.btn-danger{background:#e57373;color:#fff;border:none;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:0 2px 8px #e5737340;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-danger:hover:not(:disabled){background:#ef5350;transform:translateY(-1px);box-shadow:0 4px 12px #e5737359}.btn-danger:disabled{opacity:.6;cursor:not-allowed;transform:none!important}@media (max-width: 500px){.modal-content{border-radius:16px}.modal-header{border-radius:16px 16px 0 0;padding:1.25rem}.modal-header h2{font-size:1.25rem}.modal-form{padding:1.25rem}.modal-actions,.issue-type-selector{flex-direction:column}.issue-type-option{width:100%;justify-content:center}.confirm-delete-modal{max-width:92%}.confirm-delete-body{padding:1.25rem}.confirm-delete-actions{padding:0 1.25rem 1.25rem}.confirm-delete-item .item-label{font-size:.95rem}}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-cream);color:var(--color-gray-700)}.loading-spinner{font-size:4rem;animation:bounce 1.5s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{font-size:1.1rem;margin-top:1rem;font-weight:700;color:var(--color-primary)}.empty-state{text-align:center;padding:2.5rem 2rem;background:#fff;border-radius:16px;color:var(--color-gray-600);font-size:1rem;box-shadow:var(--shadow-card);border:2px dashed var(--color-primary-light)}.empty-state:before{content:"🐷";display:block;font-size:3.5rem;margin-bottom:.75rem}.page-container{min-height:calc(100vh - 70px);background:var(--bg-cream);padding:2rem}.page-header{text-align:center;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:16px;border:2px solid var(--color-primary-light);box-shadow:var(--shadow-card)}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.page-header h1{font-size:2rem;color:var(--color-primary);margin:0;font-weight:800}.page-header p{font-size:1.1rem;color:var(--color-gray-500);margin:.5rem 0 0;font-weight:600}.page-content{max-width:1300px;margin:0 auto}.page-placeholder{text-align:center;padding:2rem;background:#fff;border-radius:16px;color:var(--color-gray-600);font-size:1rem;box-shadow:var(--shadow-card);border:2px dashed var(--color-gray-300)}@media (max-width: 768px){.page-container{padding:1rem}.page-header h1{font-size:1.5rem}.page-header p{font-size:1rem}.page-placeholder{padding:1.5rem 1rem;font-size:.95rem}}.transaction-controls{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-card);display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;border:1px solid var(--color-gray-200)}.member-selector{display:flex;align-items:center;gap:.875rem;flex:1;min-width:220px}.member-selector label{font-weight:600;color:var(--color-gray-700);white-space:nowrap;font-size:.95rem}.member-selector select{flex:1;padding:.875rem;border:1px solid var(--color-gray-300);border-radius:8px;font-size:1rem;font-family:inherit;cursor:pointer;transition:all .2s ease;background:#fff;color:var(--color-gray-700);font-weight:500}.member-selector select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #5b6b7c1a}.transaction-buttons{display:flex;gap:.75rem}.transaction-buttons .btn{padding:.875rem 1.5rem;white-space:nowrap;font-size:.95rem;border-radius:8px}.date-filter-section{background:#fff;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-card);border:1px solid var(--color-gray-200)}.date-filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.date-filter-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-gray-700)}.date-filter-toggle{display:flex;align-items:center}.toggle-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:var(--color-gray-600)}.toggle-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.toggle-text{-webkit-user-select:none;user-select:none}.date-filter-controls{display:flex;align-items:flex-end;gap:1rem;flex-wrap:wrap;padding:1rem;background:var(--color-gray-50);border-radius:8px;margin-bottom:.75rem}.date-input-group{display:flex;flex-direction:column;gap:.375rem;flex:1;min-width:140px}.date-input-group label{font-size:.85rem;font-weight:500;color:var(--color-gray-600)}.date-input-group input[type=date]{padding:.625rem .75rem;border:1px solid var(--color-gray-300);border-radius:6px;font-size:.95rem;font-family:inherit;color:var(--color-gray-700);background:#fff;transition:all .2s ease}.date-input-group input[type=date]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #5b6b7c1a}.date-filter-actions{display:flex;gap:.5rem;flex-shrink:0}.btn-sm{padding:.5rem .875rem!important;font-size:.85rem!important}.btn-outline{background:transparent;border:1px solid var(--color-gray-300);color:var(--color-gray-600)}.btn-outline:hover{background:var(--color-gray-100);border-color:var(--color-gray-400)}.filter-summary{font-size:.9rem;color:var(--color-gray-600);padding-top:.5rem;border-top:1px solid var(--color-gray-100)}.filter-summary strong{color:var(--color-gray-800)}.transactions-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-card);border:1px solid var(--color-gray-200)}.transactions-section h2{color:var(--color-gray-800);font-size:1.25rem;margin:0 0 1.25rem;font-weight:600}@media (max-width: 768px){.transaction-controls{flex-direction:column;align-items:stretch}.member-selector{flex-direction:column;align-items:stretch;min-width:100%}.transaction-buttons{flex-direction:column}.transaction-buttons .btn{width:100%}.date-filter-header{flex-direction:column;align-items:flex-start}.date-filter-controls{flex-direction:column;align-items:stretch}.date-input-group{min-width:100%}.date-filter-actions{flex-direction:column;width:100%}.date-filter-actions .btn{width:100%;justify-content:center}}.goal-progress{margin:.875rem 0}.progress-header{display:flex;align-items:baseline;gap:.35rem;margin-bottom:.5rem}.progress-saved{font-size:1.1rem;font-weight:700;color:var(--color-primary)}.progress-target{font-size:.9rem;color:var(--color-gray-500);font-weight:600}.progress-bar-container{background:var(--color-gray-100);border-radius:12px;height:24px;overflow:hidden;position:relative;border:2px solid var(--color-gray-200)}.progress-bar-fill{height:100%;border-radius:10px;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;min-width:fit-content}.progress-bar-fill .progress-percentage{font-size:.75rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.goal-completed-badge{display:inline-block;background:var(--color-success);color:#fff;padding:.35rem .75rem;border-radius:8px;font-size:.85rem;font-weight:700;margin-top:.5rem}.goal-progress-container{margin:.875rem 0}.progress-bar-wrapper{background:var(--color-gray-100);border-radius:12px;height:24px;overflow:hidden;position:relative;border:2px solid var(--color-gray-200)}.progress-bar{height:100%;border-radius:10px;transition:width .5s ease;position:relative}.progress-bar.low{background:linear-gradient(90deg,#ff6b7a,#ff8a9b)}.progress-bar.medium{background:linear-gradient(90deg,#f5a623,#ffb74d)}.progress-bar.high,.progress-bar.complete{background:linear-gradient(90deg,#4caf6e,#7ed99d)}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem}.progress-percentage{font-size:1.1rem;font-weight:800;color:var(--color-primary)}.progress-text{font-size:.85rem;color:var(--color-gray-500);font-weight:600}.progress-milestone{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--color-success);font-weight:700}.goals-list{display:flex;flex-direction:column;gap:1.25rem}.goal-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:var(--shadow-card);transition:all .2s ease;border:2px solid var(--color-gray-200);position:relative;overflow:hidden}.goal-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-info) 0%,var(--color-accent) 100%)}.goal-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.goal-card.completed{background:#4caf6e0d;border-color:#4caf6e4d}.goal-card.completed:before{background:linear-gradient(90deg,var(--color-success) 0%,var(--color-success-light) 100%)}.goal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.875rem}.goal-info{flex:1}.goal-icon{font-size:2rem;margin-right:.75rem}.goal-name{font-size:1.25rem;font-weight:700;color:var(--color-gray-800);margin:0;display:flex;align-items:center;gap:.5rem}.goal-member{display:flex;align-items:center;gap:.35rem;color:var(--color-gray-600);font-size:.85rem;margin:.25rem 0 0;font-weight:600}.member-avatar{font-size:1rem}.goal-description{color:var(--color-gray-500);font-size:.9rem;margin:.375rem 0 0;font-weight:600}.goal-amounts{display:flex;align-items:baseline;gap:.5rem;margin-top:.625rem}.goal-current{font-size:1.4rem;font-weight:800;color:var(--color-primary)}.goal-target{font-size:1rem;color:var(--color-gray-500);font-weight:600}.goal-badge{padding:.35rem .875rem;border-radius:8px;font-size:.8rem;font-weight:700}.goal-badge.completed{background:var(--color-success);color:#fff}.goal-badge.in-progress{background:var(--color-warning);color:#fff}.goal-actions{display:flex;gap:.625rem;margin-top:1rem}.goal-actions .btn{padding:.625rem 1rem;border-radius:10px;font-size:.9rem}.btn-contribute{background:var(--color-success);color:#fff;border:none;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #4caf6e4d}.btn-contribute:hover{background:var(--color-success-light);transform:translateY(-2px)}.btn-delete-goal{background:var(--color-danger);color:#fff;border:none;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #e573734d}.btn-delete-goal:hover{background:#ef8a84;transform:translateY(-2px)}.goal-delete{background:transparent;border:none;font-size:1.5rem;color:var(--color-gray-400);cursor:pointer;padding:.25rem;line-height:1;transition:color .2s ease}.goal-delete:hover{color:var(--color-danger)}.goal-stats{display:flex;justify-content:space-between;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-gray-200)}.goal-stats .stat{display:flex;flex-direction:column;gap:.25rem}.goal-stats .stat-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-gray-500)}.goal-stats .stat-value{font-size:1.25rem;font-weight:800;color:var(--color-gray-800)}.celebration{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;display:flex;justify-content:space-around;align-items:center}.confetti{font-size:1.5rem;animation:float 2s ease-in-out infinite}.confetti:nth-child(2){animation-delay:.3s}.confetti:nth-child(3){animation-delay:.6s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.goals-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.25rem;margin-bottom:1.5rem;background:#fff;padding:1.5rem 2rem;border-radius:16px;border:2px solid var(--color-gray-200);box-shadow:var(--shadow-card)}.goals-controls .btn{padding:.75rem 1.5rem;font-size:.95rem;border-radius:10px}.goals-summary{display:flex;gap:1.5rem;flex-wrap:wrap}.summary-item{display:flex;flex-direction:column}.summary-label{font-size:.8rem;color:var(--color-gray-500);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:1.5rem;font-weight:800;color:var(--color-primary)}.goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.empty-goals{text-align:center;padding:3rem 2rem;background:#fff;border-radius:16px;border:2px dashed var(--color-info);box-shadow:var(--shadow-card)}.empty-goals:before{content:"🎯";display:block;font-size:4rem;margin-bottom:1rem}.empty-goals p{color:var(--color-info);font-size:1.15rem;margin:0;font-weight:700}@media (max-width: 768px){.goals-controls{flex-direction:column;align-items:stretch;text-align:center}.goals-summary{justify-content:center}.goals-controls .btn{width:100%}.goals-grid{grid-template-columns:1fr}}.allowance-manager{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-card);border:1px solid var(--color-gray-200)}.allowance-manager h3{color:var(--color-gray-800);font-size:1.25rem;margin:0 0 1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.allowance-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.875rem}.schedule-row{margin-top:.5rem;padding-top:.75rem;border-top:1px dashed var(--color-gray-200)}.schedule-row:empty{display:none;margin:0;padding:0;border:none}.allowance-form .form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.allowance-form .btn{padding:.75rem 1.25rem;border-radius:8px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease}.allowance-form .btn-primary{background:var(--color-primary);color:#fff;border:none}.allowance-form .btn-primary:hover{background:var(--color-primary-dark, #2d8a88);transform:translateY(-1px)}.allowance-form .btn-secondary{background:#fff;color:var(--color-gray-700);border:2px solid var(--color-gray-300)}.allowance-form .btn-secondary:hover{background:var(--color-gray-100);border-color:var(--color-gray-400)}.form-group label{font-weight:600;color:var(--color-gray-700);font-size:.9rem;margin-bottom:.375rem;display:block}.form-group input,.form-group select{width:100%;padding:.875rem;border:1px solid var(--color-gray-300);border-radius:8px;font-size:1rem;font-family:inherit;transition:all .2s ease;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #5b6b7c1a}.schedule-toggle{display:flex;gap:.5rem;flex-wrap:wrap}.btn-toggle{padding:.625rem 1rem;border:1px solid var(--color-gray-300);border-radius:6px;background:#fff;color:var(--color-gray-700);font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-toggle:hover{border-color:var(--color-gray-400)}.btn-toggle.active{border-color:var(--color-success);background:var(--color-success);color:#fff}.btn-delete-small{padding:.5rem .875rem;border:none;border-radius:6px;background:var(--color-danger);color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;font-size:.85rem}.btn-delete-small:hover{background:#a85850}.allowance-list{margin-top:1.5rem}.allowance-list h4{color:var(--color-gray-800);font-size:1.05rem;margin:0 0 .875rem;font-weight:600}.allowance-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--color-gray-50);border-radius:8px;margin-bottom:.625rem;border:1px solid var(--color-gray-200);transition:all .2s ease}.allowance-item:hover{transform:translate(2px);border-color:var(--color-gray-300)}.allowance-info{display:flex;align-items:center;gap:.875rem}.allowance-avatar{font-size:1.5rem;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);border-radius:50%;border:1px solid var(--color-gray-200)}.allowance-details{display:flex;flex-direction:column}.allowance-name{font-weight:600;color:var(--color-gray-800);font-size:1rem}.allowance-schedule{color:var(--color-gray-500);font-size:.85rem}.allowance-amount{font-size:1.15rem;font-weight:700;color:var(--color-success);margin-right:.875rem}.allowances-list{margin-top:1.5rem}.empty-allowances{text-align:center;padding:2rem;color:var(--color-gray-500);font-style:italic}.allowance-card{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--color-gray-50);border-radius:10px;margin-bottom:.75rem;border:1px solid var(--color-gray-200);transition:all .2s ease}.allowance-card:hover{transform:translate(3px);border-color:var(--color-gray-300);box-shadow:0 2px 8px #0000000d}.allowance-card.active{border-left:4px solid var(--color-success)}.allowance-card.inactive{opacity:.7;border-left:4px solid var(--color-gray-400)}.allowance-card h3{margin:0 0 .25rem;font-size:1.1rem}.allowance-actions{display:flex;gap:.5rem;align-items:center}.allowance-frequency{color:var(--color-gray-600);font-size:.9rem}@media (max-width: 600px){.allowance-item{flex-direction:column;gap:.875rem;text-align:center}.allowance-info{flex-direction:column}.allowance-card{flex-direction:column;gap:1rem;text-align:center}.allowance-card .allowance-info{flex-direction:column;align-items:center}.allowance-card .allowance-details{align-items:center}.allowance-actions{width:100%;justify-content:center}.schedule-row{grid-template-columns:1fr}}.allowances-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.allowance-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:var(--shadow-card);border:2px solid var(--color-gray-200);transition:all .2s ease;position:relative;overflow:hidden}.allowance-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-success) 0%,var(--color-warning) 100%)}.allowance-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-success-light)}.allowance-header{display:flex;align-items:center;gap:.875rem;margin-bottom:1rem}.allowance-avatar{font-size:2.25rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:50%;border:3px solid var(--color-success-light)}.allowance-info h3{margin:0;font-size:1.2rem;font-weight:700;color:var(--color-gray-800)}.allowance-info p{margin:.125rem 0 0;color:var(--color-gray-500);font-size:.85rem;font-weight:600}.allowance-details{background:var(--color-gray-50);border-radius:12px;padding:1rem;margin-bottom:1rem;border:1px solid var(--color-gray-200)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0}.detail-row:not(:last-child){border-bottom:1px solid var(--color-gray-200)}.detail-label{color:var(--color-gray-500);font-size:.85rem;font-weight:600}.detail-value{color:var(--color-gray-800);font-weight:700;font-size:1rem}.detail-value.amount{color:var(--color-success);font-size:1.2rem;font-weight:800}.allowance-status{display:flex;align-items:center;gap:.625rem;padding:.75rem;border-radius:10px;margin-bottom:1rem}.allowance-status.active{background:#4caf6e1a;border:1px solid rgba(76,175,110,.25)}.allowance-status.inactive{background:#e573731a;border:1px solid rgba(229,115,115,.25)}.status-indicator{width:10px;height:10px;border-radius:50%}.status-indicator.active{background:var(--color-success);box-shadow:0 0 8px #4caf6e80}.status-indicator.inactive{background:var(--color-danger)}.status-text{font-weight:700;font-size:.9rem}.status-text.active{color:var(--color-success)}.status-text.inactive{color:var(--color-danger)}.allowance-actions{display:flex;gap:.625rem}.allowance-actions .btn{flex:1;padding:.75rem;border-radius:10px}@media (max-width: 768px){.allowances-grid{grid-template-columns:1fr}.allowance-actions{flex-direction:column}}.chart-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-card);border:1px solid var(--color-gray-200);margin-bottom:1.5rem}.chart-title{color:var(--color-gray-800);font-size:1.15rem;margin:0 0 1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.chart-wrapper{height:280px;position:relative}.custom-tooltip{background:#fff!important;border:1px solid var(--color-gray-300)!important;border-radius:8px!important;padding:.875rem!important;box-shadow:var(--shadow-md)!important}.tooltip-label{font-weight:600;color:var(--color-gray-800);margin-bottom:.375rem}.tooltip-value{color:var(--color-gray-600);font-weight:500}.category-breakdown{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.875rem;margin-top:1.25rem}.category-item{background:var(--color-gray-50);border-radius:8px;padding:1rem;text-align:center;border:1px solid var(--color-gray-200);transition:all .2s ease}.category-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.category-icon{font-size:1.75rem;margin-bottom:.375rem}.category-name{font-size:.85rem;color:var(--color-gray-500);font-weight:500;margin-bottom:.125rem}.category-amount{font-size:1.05rem;font-weight:700;color:var(--color-gray-800)}.category-percentage{font-size:.8rem;color:var(--color-gray-400);font-weight:500}.chart-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:1.25rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.375rem}.legend-color{width:12px;height:12px;border-radius:3px}.legend-label{font-size:.9rem;color:var(--color-gray-700);font-weight:500}.chart-empty{text-align:center;padding:2.5rem;color:var(--color-gray-500)}.chart-empty:before{content:"📈";display:block;font-size:2.5rem;margin-bottom:.75rem;opacity:.5}@media (max-width: 768px){.chart-wrapper{height:240px}.category-breakdown{grid-template-columns:repeat(2,1fr)}}.reports-filters-section{background:#fff;border-radius:12px;padding:1.5rem 2rem;margin-bottom:2rem;border:1px solid var(--color-gray-200);box-shadow:var(--shadow-card);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.filter-row{display:flex;gap:1.5rem;flex-wrap:wrap}.filter-item{display:flex;flex-direction:column;gap:.375rem}.filter-item label{font-size:.8rem;font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px}.filter-item select{padding:.625rem 2rem .625rem .875rem;border:1px solid var(--color-gray-300);border-radius:8px;font-size:.95rem;font-family:inherit;cursor:pointer;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235A5650' d='M6 8L1 3h10z'/%3E%3C/svg%3E") no-repeat right .75rem center;color:var(--color-gray-700);font-weight:500;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:160px}.filter-item select:hover{border-color:var(--color-primary)}.filter-item select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #5b6b7c1a}.filter-date-range{display:flex;align-items:center}.date-badge{display:inline-flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:var(--color-gray-100);border-radius:20px;font-size:.9rem;font-weight:500;color:var(--color-gray-700)}.transaction-count{background:var(--color-primary);color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600}.reports-section{margin-bottom:2rem}.section-header{margin-bottom:1rem}.section-header h2{font-size:1.25rem;font-weight:600;color:var(--color-gray-800);margin:0;display:flex;align-items:center;gap:.5rem}.reports-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1.25rem;border:1px solid var(--color-gray-200);box-shadow:var(--shadow-card);transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card.primary{border-left:4px solid var(--color-primary)}.stat-card.success{border-left:4px solid var(--color-success)}.stat-card.warning{border-left:4px solid var(--color-warning)}.stat-card.danger{border-left:4px solid var(--color-danger)}.stat-icon-wrapper{font-size:2rem;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);border-radius:12px;flex-shrink:0}.stat-details{display:flex;flex-direction:column;gap:.25rem;min-width:0}.stat-label{font-size:.8rem;font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-gray-800);line-height:1.2}.stat-value.income{color:var(--color-success)}.stat-value.spending{color:var(--color-danger)}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.insight-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:flex-start;gap:1rem;border:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm);transition:transform .2s ease}.insight-card:hover{transform:translateY(-2px)}.insight-icon{font-size:1.75rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);border-radius:10px;flex-shrink:0}.insight-content{display:flex;flex-direction:column;gap:.25rem;min-width:0}.insight-label{font-size:.75rem;font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px}.insight-value{font-size:1.35rem;font-weight:700;color:var(--color-gray-800);line-height:1.2}.insight-value.positive{color:var(--color-success)}.insight-value.negative{color:var(--color-danger)}.insight-description{font-size:.85rem;color:var(--color-gray-500);margin-top:.25rem}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.chart-card{background:#fff;border-radius:12px;border:1px solid var(--color-gray-200);box-shadow:var(--shadow-card);overflow:hidden;transition:all .2s ease}.chart-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.chart-card .chart-container{border:none;box-shadow:none;margin-bottom:0;border-radius:0}.balances-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.member-balance-card{background:#fff;border-radius:12px;padding:1.25rem;border:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.member-balance-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.member-header{display:flex;align-items:center;gap:.875rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-gray-100)}.member-avatar{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);border-radius:10px;flex-shrink:0}.member-info h4{margin:0;font-size:1.05rem;font-weight:600;color:var(--color-gray-800)}.member-role{font-size:.8rem;color:var(--color-gray-500);text-transform:capitalize}.member-balance{display:flex;flex-direction:column;align-items:center;padding:1rem;background:var(--color-gray-50);border-radius:10px;margin-bottom:1rem}.balance-label{font-size:.75rem;font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.balance-amount{font-size:1.5rem;font-weight:700;color:var(--color-gray-800)}.member-stats{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.mini-stat{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:var(--color-gray-50);border-radius:8px}.mini-label{font-size:.7rem;font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.3px}.mini-value{font-size:1rem;font-weight:600;margin-top:.125rem}.mini-value.income{color:var(--color-success)}.mini-value.spending{color:var(--color-danger)}.reports-section .empty-state{margin-top:1rem}@media (max-width: 768px){.reports-filters-section{flex-direction:column;align-items:stretch;padding:1rem}.filter-row{flex-direction:column;gap:1rem;width:100%}.filter-item{width:100%}.filter-item select{width:100%;min-width:unset}.filter-date-range{justify-content:center}.reports-stats-grid{grid-template-columns:1fr}.stat-card{padding:1rem}.stat-icon-wrapper{width:44px;height:44px;font-size:1.5rem}.stat-value{font-size:1.25rem}.insights-grid,.charts-grid,.balances-grid{grid-template-columns:1fr}.member-balance-card{padding:1rem}.section-header h2{font-size:1.1rem}}@media (max-width: 480px){.date-badge{flex-direction:column;gap:.375rem;text-align:center;padding:.625rem 1rem}.transaction-count{margin:0}.insight-card{padding:1rem}.insight-icon{width:40px;height:40px;font-size:1.35rem}.insight-value{font-size:1.15rem}.balance-amount{font-size:1.35rem}}.family-member-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:var(--shadow-card);transition:all .2s ease;border:2px solid var(--color-gray-200);position:relative;overflow:hidden}.family-member-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-info) 0%,var(--color-accent) 100%)}.family-member-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-info)}.member-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.member-avatar-large{font-size:2.5rem;width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:50%;border:3px solid var(--color-success-light)}.member-details{flex:1;display:flex;flex-direction:column;gap:.125rem}.member-details h3{margin:0;color:var(--color-gray-800);font-size:1.3rem;font-weight:700}.member-age{color:var(--color-gray-500);font-size:.9rem;margin:0;font-weight:600}.member-role-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .75rem;border-radius:8px;font-size:.75rem;font-weight:700;margin-top:.375rem;width:fit-content}.member-role-badge.parent{background:var(--color-info);color:#fff}.member-role-badge.child{background:var(--color-warning);color:#fff}.member-balance{display:flex;flex-direction:column;align-items:center;padding:1.25rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-radius:14px;margin-bottom:1rem}.balance-label{color:#ffffffe6;font-size:.75rem;margin-bottom:.25rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.balance-amount{color:#fff;font-size:1.85rem;font-weight:800}.member-actions{display:flex;gap:.625rem}.member-actions .btn{flex:1}.btn-sm{padding:.5rem 1rem;font-size:.9rem}.btn-edit{background:var(--color-info);color:#fff;border:none;border-radius:10px;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:0 4px 12px #9575cd4d}.btn-edit:hover{background:var(--color-info-light);transform:translateY(-2px)}.btn-delete{background:var(--color-danger);color:#fff;border:none;border-radius:10px;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:0 4px 12px #e573734d}.btn-delete:hover{background:#ef8a84;transform:translateY(-2px)}@media (max-width: 500px){.member-card-header{flex-direction:column;text-align:center}.member-details h3{font-size:1.2rem}.balance-amount{font-size:1.5rem}.member-role-badge{margin:.375rem auto 0}}.edit-member-modal{max-width:520px}.edit-member-form{padding:2rem!important;gap:1.5rem!important}.edit-member-form .form-row{display:grid;grid-template-columns:2fr 1fr;gap:1rem}.edit-member-form .form-group{margin-bottom:0}.edit-member-form label{font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-gray-500);margin-bottom:.5rem;display:block}.edit-member-form input,.edit-member-form select{padding:1rem 1.25rem;font-size:1.1rem;border-radius:14px;border:2px solid var(--color-gray-200);background:var(--color-gray-50);transition:all .2s ease}.edit-member-form input:focus,.edit-member-form select:focus{background:#fff;border-color:var(--color-primary);box-shadow:0 0 0 4px #3a9d9b1f}.edit-member-form .error-message{background:#ef44441a;color:#dc2626;padding:.875rem 1rem;border-radius:10px;font-size:.9rem;font-weight:500;border:1px solid rgba(239,68,68,.2)}.avatar-group{background:var(--color-gray-50);padding:1.25rem;border-radius:16px;border:2px solid var(--color-gray-100)}.avatar-group label{margin-bottom:1rem!important}.edit-avatar-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:.5rem;max-height:220px;overflow-y:auto;padding:.25rem}.edit-avatar-option{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:#fff;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 3px #0000000d}.edit-avatar-option:hover{transform:scale(1.1);box-shadow:0 4px 12px #0000001a;z-index:1}.edit-avatar-option.selected{background:var(--color-primary);border-color:var(--color-primary);transform:scale(1.15);box-shadow:0 4px 16px #3a9d9b66}.edit-member-form .modal-actions{margin-top:.5rem;padding-top:1.5rem;border-top:2px solid var(--color-gray-100)}.edit-member-form .btn{padding:1rem 1.5rem;font-size:1rem;font-weight:600}.edit-member-form .btn-primary{background:linear-gradient(135deg,#2a7d7b,#3a9d9b);color:#fff;border:none;box-shadow:0 4px 12px #2a7d7b66}.edit-member-form .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#1f6b69,#2a7d7b);transform:translateY(-2px);box-shadow:0 6px 20px #2a7d7b80}.edit-avatar-grid::-webkit-scrollbar{width:6px}.edit-avatar-grid::-webkit-scrollbar-track{background:var(--color-gray-100);border-radius:3px}.edit-avatar-grid::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:3px}.edit-avatar-grid::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}@media (max-width: 500px){.edit-member-modal{max-width:100%;margin:.5rem}.edit-member-form{padding:1.25rem!important;gap:1.25rem!important}.edit-member-form .form-row{grid-template-columns:1fr}.edit-avatar-grid{grid-template-columns:repeat(6,1fr);max-height:180px}.edit-avatar-option{font-size:1.3rem}}.family-setup-section{display:flex;justify-content:center;align-items:flex-start;padding:2rem 0}.family-setup-section .setup-card{background:#fff;border-radius:16px;padding:2.5rem;max-width:650px;width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--color-gray-200)}.family-setup-section .setup-header{text-align:center;margin-bottom:2rem}.family-setup-section .setup-header h1{color:var(--color-gray-800);font-size:1.75rem;margin:0;font-weight:600}.family-setup-section .setup-header p{color:var(--color-gray-500);font-size:1rem;margin:.5rem 0 0}.family-setup-section .error-message{background:#fef2f2;color:#dc2626;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.family-actions{margin-bottom:1.5rem;display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.family-actions .btn{padding:.875rem 1.75rem;font-size:1rem;border-radius:8px;min-width:180px;background:#fff;color:var(--color-primary);border:2px solid var(--color-primary);box-shadow:0 2px 8px #3a9d9b1a}.family-actions .btn:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #3a9d9b40}.add-member-section{max-width:650px;margin:0 auto 1.5rem;padding:2rem;background:#fff;border-radius:12px;box-shadow:var(--shadow-card);border:1px solid var(--color-gray-200)}.add-member-section .btn-secondary{background:var(--color-gray-50);color:var(--color-gray-700);border:2px solid var(--color-gray-300);font-weight:600}.add-member-section .btn-secondary:hover:not(:disabled){background:var(--color-gray-100);color:var(--color-gray-800);border-color:var(--color-gray-400);transform:translateY(-2px)}.family-members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;animation:fadeIn .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;padding:3rem 2rem;background:#fff;border-radius:12px;box-shadow:var(--shadow-card);border:2px dashed var(--color-gray-300)}.empty-state p{color:var(--color-gray-600);font-size:1.1rem;margin:0;font-weight:500}@media (max-width: 768px){.family-members-grid{grid-template-columns:1fr}.add-member-section{padding:1.25rem}.family-actions{flex-direction:column;align-items:center}.family-actions .btn{width:100%;max-width:280px}}.landing-page{min-height:100vh;background:linear-gradient(135deg,#3a9d9b,#5bc0be,#9575cd);position:relative;overflow:hidden}.landing-page:before{content:"";position:absolute;top:-50%;right:-20%;width:60%;height:100%;background:#ff6b7a26;border-radius:50%;pointer-events:none}.landing-page:after{content:"";position:absolute;bottom:-30%;left:-10%;width:50%;height:80%;background:#f5a6231a;border-radius:50%;pointer-events:none}.hero-section{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;position:relative;z-index:1}.hero-content{max-width:700px}.hero-icon{font-size:7rem;margin-bottom:1.5rem;animation:bounce 2s ease-in-out infinite;filter:drop-shadow(0 8px 16px rgba(0,0,0,.2))}.hero-logo{margin-bottom:1rem;animation:bounce 2s ease-in-out infinite;filter:drop-shadow(0 8px 16px rgba(0,0,0,.2))}.hero-logo svg{max-width:100%;height:auto}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.hero-title{font-size:3.5rem;font-weight:800;color:#fff;margin:0;letter-spacing:-.5px;text-shadow:0 2px 8px rgba(0,0,0,.2)}.hero-subtitle{font-size:1.35rem;color:#fffffff2;margin:1rem 0 2rem;font-weight:600;line-height:1.6}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{padding:.875rem 1.75rem;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem}.btn-large{padding:1rem 2.5rem;font-size:1.1rem}.btn-primary{background:#fff;color:var(--color-primary);box-shadow:0 4px 12px #00000026}.btn-primary:hover{background:#fff9f0;transform:translateY(-3px);box-shadow:0 6px 20px #0003}.btn-secondary{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.5)}.btn-secondary:hover{background:#ffffff4d;transform:translateY(-3px)}.features-section{padding:4rem 2rem;background:#ffffff1a;position:relative;z-index:1}.features-title{text-align:center;font-size:2.5rem;color:#fff;margin:0 0 2.5rem;font-weight:800}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;max-width:1100px;margin:0 auto}.feature-card{background:#fffffff2;border-radius:20px;padding:2rem;text-align:center;box-shadow:0 8px 24px #0000001a;transition:all .3s ease}.feature-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #00000026}.feature-icon{font-size:4rem;margin-bottom:1rem;display:block}.feature-title{font-size:1.4rem;font-weight:700;color:var(--color-gray-800);margin:0 0 .75rem}.feature-description{color:var(--color-gray-600);font-size:1rem;line-height:1.6;margin:0}.landing-footer{background:#0003;color:#fff;padding:2rem;text-align:center;position:relative;z-index:1}.footer-content{max-width:600px;margin:0 auto}.footer-logo{font-size:2.5rem;margin-bottom:.5rem;display:flex;justify-content:center}.footer-logo svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.footer-text{font-size:.95rem;opacity:.9;margin:0}@media (max-width: 768px){.hero-title{font-size:2.25rem}.hero-subtitle{font-size:1.1rem}.hero-icon{font-size:5rem}.hero-logo svg{max-width:240px}.hero-buttons{flex-direction:column;width:100%;max-width:280px}.btn-large{width:100%;justify-content:center}.features-title{font-size:1.75rem}}.settings-container{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.settings-section{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 12px #0000000f;border:2px solid var(--color-primary-light)}.settings-section-title{font-size:1.5rem;color:var(--color-primary);margin:0 0 1.5rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.settings-form{display:flex;flex-direction:column;gap:1.25rem}.settings-form .form-group{display:flex;flex-direction:column;gap:.375rem}.settings-form .form-group label{font-weight:700;color:var(--color-gray-700);font-size:.9rem}.settings-form .form-group input{padding:.875rem 1rem;border:2px solid var(--color-gray-200);border-radius:12px;font-size:1rem;font-family:inherit;transition:all .2s ease;background:#fff}.settings-form .form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #3a9d9b26}.settings-form .form-group input.disabled-input{background:var(--color-gray-100);color:var(--color-gray-600);cursor:not-allowed}.settings-form .form-group input::placeholder{color:var(--color-gray-400)}.avatar-selector{display:flex;flex-wrap:wrap;gap:.625rem;margin-top:.25rem}.avatar-option{width:48px;height:48px;border:2px solid var(--color-gray-200);border-radius:50%;background:var(--color-gray-50);font-size:1.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:0;font-family:inherit}.avatar-option:hover{border-color:var(--color-gray-400);transform:scale(1.05)}.avatar-option.selected{border-color:var(--color-primary);background:var(--color-primary);transform:scale(1.1)}.success-message{background:#4caf6e26;color:var(--color-success);padding:.875rem;border-radius:12px;font-size:.9rem;border:2px solid rgba(76,175,110,.3);font-weight:600}.info-message{background:#9575cd26;color:var(--color-info);padding:1rem;border-radius:12px;font-size:.95rem;border:2px solid rgba(149,117,205,.3);font-weight:600;line-height:1.6}.language-selector{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.5rem}.language-option{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border:2px solid var(--color-gray-200);border-radius:12px;background:var(--color-gray-50);cursor:pointer;transition:all .2s ease;font-family:inherit;min-width:140px}.language-option:hover{border-color:var(--color-primary-light);background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.language-option.selected{border-color:var(--color-primary);background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #3a9d9b4d}.language-flag{font-size:1.5rem}.language-name{font-size:1rem;font-weight:600}.currency-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;margin-top:.5rem}.currency-option{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;border:2px solid var(--color-gray-200);border-radius:12px;background:var(--color-gray-50);cursor:pointer;transition:all .2s ease;font-family:inherit}.currency-option:hover{border-color:var(--color-primary-light);background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.currency-option.selected{border-color:var(--color-primary);background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #3a9d9b4d}.currency-flag{font-size:1.25rem}.currency-symbol{font-size:1.1rem;font-weight:700;min-width:1.5rem;text-align:center}.currency-name{font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.settings-section-description{color:var(--color-gray-600);margin:-1rem 0 1.5rem;font-size:.95rem}.settings-font-size{margin-top:.5rem}.settings-form .btn-secondary{background:var(--color-info);color:#fff;border:none;font-weight:700;margin-top:1rem;box-shadow:0 4px 12px #9575cd4d}.settings-form .btn-secondary:hover{background:#7e57c2;color:#fff;transform:translateY(-2px);box-shadow:0 6px 16px #9575cd66}.a11y-toggles-group{display:flex;flex-direction:column;gap:0;margin-top:.5rem}.a11y-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-bottom:1px solid var(--color-gray-200)}.a11y-toggle-row:last-child{border-bottom:none}.a11y-toggle-info{display:flex;flex-direction:column;gap:.25rem;flex:1;padding-right:1rem}.a11y-toggle-info .a11y-toggle-label{font-weight:600;color:var(--color-gray-800);font-size:1rem}.a11y-toggle-description{font-size:.85rem;color:var(--color-gray-500);line-height:1.4}@media (max-width: 768px){.settings-container{gap:1.5rem}.settings-section{padding:1.5rem;border-radius:12px}.settings-section-title{font-size:1.25rem}.avatar-option{width:42px;height:42px;font-size:1.3rem}.language-selector{flex-direction:column}.language-option{min-width:unset;width:100%;justify-content:center}.currency-selector{grid-template-columns:1fr}.currency-option{justify-content:flex-start}.a11y-toggle-row{flex-direction:column;align-items:flex-start;gap:.75rem}.a11y-toggle-info{padding-right:0}.settings-font-size{flex-wrap:wrap}.settings-font-size .a11y-font-size-btn{flex:1 1 45%}}.email-verification-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.email-verification-card{background:#fff;border-radius:1.5rem;padding:3rem;max-width:480px;width:100%;box-shadow:0 20px 60px #00000026;text-align:center}.email-verification-icon{font-size:4rem;margin-bottom:1.5rem;animation:bounce 2s ease-in-out infinite}@media (prefers-reduced-motion: reduce){.email-verification-icon{animation:none}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.email-verification-card h1{color:#333;font-size:1.75rem;margin-bottom:.5rem;font-weight:700}.email-verification-card h2{color:#666;font-size:1.1rem;font-weight:400;margin-bottom:2rem}.email-address{background:linear-gradient(135deg,#f5f7fa,#e4e8eb);padding:1rem 1.5rem;border-radius:.75rem;margin:1.5rem 0;font-weight:600;color:#4a5568;word-break:break-all}.email-verification-instructions{color:#666;line-height:1.6;margin-bottom:2rem;font-size:.95rem}.verification-status{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background:#f0f9ff;border-radius:.75rem;margin-bottom:1.5rem;color:#0369a1;font-size:.9rem}.verification-status.success{background:#f0fdf4;color:#166534}.status-spinner{width:18px;height:18px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}@media (prefers-reduced-motion: reduce){.status-spinner{animation:none;border-top-color:currentColor;opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}.resend-button{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:.75rem;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-bottom:1rem}.resend-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.resend-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.resend-button:focus-visible{outline:3px solid #667eea;outline-offset:2px}.resend-message{padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1rem;font-size:.9rem}.resend-message.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.resend-message.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.spam-notice{color:#888;font-size:.85rem;margin-bottom:1.5rem}.sign-out-section{border-top:1px solid #e5e7eb;padding-top:1.5rem;margin-top:1rem}.sign-out-section p{color:#666;font-size:.9rem;margin-bottom:.75rem}.sign-out-link{color:#667eea;font-weight:600;text-decoration:none;cursor:pointer;background:none;border:none;font-size:.95rem;padding:0}.sign-out-link:hover{text-decoration:underline}.sign-out-link:focus-visible{outline:2px solid #667eea;outline-offset:2px;border-radius:2px}.high-contrast .email-verification-container{background:#000}.high-contrast .email-verification-card{background:#000;border:3px solid #fff}.high-contrast .email-verification-card h1,.high-contrast .email-verification-card h2,.high-contrast .email-address,.high-contrast .email-verification-instructions,.high-contrast .spam-notice,.high-contrast .sign-out-section p{color:#fff}.high-contrast .email-address{background:#333;border:2px solid #fff}.high-contrast .verification-status{background:#333;border:2px solid currentColor}.high-contrast .resend-button{background:#fff;color:#000;border:2px solid #fff}.high-contrast .resend-button:hover:not(:disabled){background:#000;color:#fff}.high-contrast .sign-out-link{color:#fff;text-decoration:underline}.high-contrast .resend-message.success{background:#030;color:#0f0;border-color:#0f0}.high-contrast .resend-message.error{background:#300;color:red;border-color:red}.large-targets .resend-button{padding:1.25rem 2rem;font-size:1.1rem;min-height:56px}.large-targets .sign-out-link{padding:.5rem;display:inline-block}[dir=rtl] .email-verification-card{text-align:center}@media (max-width: 480px){.email-verification-container{padding:1rem}.email-verification-card{padding:2rem 1.5rem}.email-verification-icon{font-size:3rem}.email-verification-card h1{font-size:1.5rem}}*{box-sizing:border-box}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-gray-100);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}::selection{background:#5b6b7c33;color:var(--color-gray-800)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}html{scroll-behavior:smooth}body{font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-gray-700);line-height:1.6}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-gray-800)}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-dark)}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}*{-webkit-tap-highlight-color:transparent}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.01)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-slide-up{animation:slideUp .3s ease-out}.animate-float{animation:float 3s ease-in-out infinite}.animate-scale-in{animation:scale-in .3s ease-out}.animate-slide-in-right{animation:slide-in-right .3s ease-out}:root{--a11y-font-scale: 1;--a11y-base-font-size: calc(16px * var(--a11y-font-scale));--a11y-spacing-scale: 1;--a11y-min-target-size: 44px;--a11y-focus-outline-width: 3px;--a11y-focus-outline-color: #005fcc;--a11y-focus-outline-offset: 2px;--a11y-hc-text: #000000;--a11y-hc-background: #ffffff;--a11y-hc-link: #0000EE;--a11y-hc-link-visited: #551A8B;--a11y-hc-border: #000000;--a11y-hc-focus: #ff6600;--a11y-animation-duration: .3s;--a11y-letter-spacing: normal;--a11y-word-spacing: normal;--a11y-line-height: 1.5}[data-font-size=small]{--a11y-font-scale: .875;--a11y-spacing-scale: .9}[data-font-size=medium]{--a11y-font-scale: 1;--a11y-spacing-scale: 1}[data-font-size=large]{--a11y-font-scale: 1.25;--a11y-spacing-scale: 1.15}[data-font-size=xlarge]{--a11y-font-scale: 1.5;--a11y-spacing-scale: 1.3}html{font-size:var(--a11y-base-font-size)}[data-high-contrast=true]{--text-primary: var(--a11y-hc-text) !important;--text-secondary: var(--a11y-hc-text) !important;--background-primary: var(--a11y-hc-background) !important;--background-secondary: #f0f0f0 !important;--border-color: var(--a11y-hc-border) !important;--a11y-focus-outline-color: var(--a11y-hc-focus)}[data-high-contrast=true] body{background-color:var(--a11y-hc-background)!important;color:var(--a11y-hc-text)!important}[data-high-contrast=true] a{color:var(--a11y-hc-link)!important;text-decoration:underline!important}[data-high-contrast=true] a:visited{color:var(--a11y-hc-link-visited)!important}[data-high-contrast=true] button,[data-high-contrast=true] .btn{border:2px solid var(--a11y-hc-border)!important;background-color:var(--a11y-hc-background)!important;color:var(--a11y-hc-text)!important}[data-high-contrast=true] button:hover,[data-high-contrast=true] .btn:hover{background-color:var(--a11y-hc-text)!important;color:var(--a11y-hc-background)!important}[data-high-contrast=true] input,[data-high-contrast=true] select,[data-high-contrast=true] textarea{border:2px solid var(--a11y-hc-border)!important;background-color:var(--a11y-hc-background)!important;color:var(--a11y-hc-text)!important}[data-high-contrast=true] .card,[data-high-contrast=true] .modal-content{border:2px solid var(--a11y-hc-border)!important;background-color:var(--a11y-hc-background)!important}[data-reduced-motion=true],[data-reduced-motion=true] *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}@font-face{font-family:OpenDyslexic;src:url(https://cdn.jsdelivr.net/npm/open-dyslexic@1.0.3/OpenDyslexic-Regular.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:OpenDyslexic;src:url(https://cdn.jsdelivr.net/npm/open-dyslexic@1.0.3/OpenDyslexic-Bold.otf) format("opentype");font-weight:700;font-style:normal;font-display:swap}[data-dyslexia-font=true]{--a11y-letter-spacing: .12em;--a11y-word-spacing: .16em;--a11y-line-height: 1.8}[data-dyslexia-font=true] body,[data-dyslexia-font=true] input,[data-dyslexia-font=true] select,[data-dyslexia-font=true] textarea,[data-dyslexia-font=true] button{font-family:OpenDyslexic,Arial,sans-serif!important;letter-spacing:var(--a11y-letter-spacing)!important;word-spacing:var(--a11y-word-spacing)!important;line-height:var(--a11y-line-height)!important;text-align:left!important}[data-dyslexia-font=true][dir=rtl] body,[data-dyslexia-font=true][dir=rtl] input,[data-dyslexia-font=true][dir=rtl] select,[data-dyslexia-font=true][dir=rtl] textarea,[data-dyslexia-font=true][dir=rtl] button{text-align:right!important}[data-simplified-ui=true] .non-essential,[data-simplified-ui=true] .decorative{display:none!important}[data-simplified-ui=true] .card{box-shadow:none!important;border:2px solid #ccc!important}[data-simplified-ui=true] .btn{font-weight:700!important;padding:1rem 1.5rem!important}[data-large-targets=true] button,[data-large-targets=true] .btn,[data-large-targets=true] a,[data-large-targets=true] input[type=checkbox],[data-large-targets=true] input[type=radio],[data-large-targets=true] select{min-height:var(--a11y-min-target-size)!important;min-width:var(--a11y-min-target-size)!important;padding:calc(.75rem * var(--a11y-spacing-scale)) calc(1.25rem * var(--a11y-spacing-scale))!important}[data-large-targets=true] .nav-link{padding:1rem 1.5rem!important}*:focus{outline:var(--a11y-focus-outline-width) solid var(--a11y-focus-outline-color);outline-offset:var(--a11y-focus-outline-offset)}*:focus:not(:focus-visible){outline:none}*:focus-visible{outline:var(--a11y-focus-outline-width) solid var(--a11y-focus-outline-color);outline-offset:var(--a11y-focus-outline-offset)}[data-high-contrast=true] *:focus-visible{outline:4px solid var(--a11y-hc-focus)!important;outline-offset:3px!important}.skip-link{position:absolute;top:-100px;left:50%;transform:translate(-50%);background-color:#1a1a2e;color:#fff;padding:1rem 2rem;text-decoration:none;font-weight:700;z-index:10000;border-radius:0 0 8px 8px;transition:top .2s ease}.skip-link:focus{top:0;outline:3px solid #ffd700;outline-offset:2px}[dir=rtl] .skip-link{left:auto;right:50%;transform:translate(50%)}.sr-only,.visually-hidden{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.live-region{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.a11y-floating-btn{position:fixed;bottom:24px;right:24px;width:72px;height:72px;border-radius:50%;background:#06c;color:#fff;border:4px solid #ffffff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px #0066cc80,0 0 0 4px #06c3;z-index:9999;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.a11y-floating-btn:hover{transform:scale(1.1);background:#0052a3;box-shadow:0 8px 28px #06c9,0 0 0 6px #0066cc4d}.a11y-floating-btn:focus-visible{outline:4px solid #FFD700;outline-offset:4px;background:#0052a3}.a11y-floating-btn svg{width:36px;height:36px}.a11y-floating-btn:before{content:"";position:absolute;top:-8px;left:-8px;right:-8px;bottom:-8px;border-radius:50%;border:3px solid #0066CC;animation:a11y-pulse 2s ease-in-out infinite;opacity:0}@keyframes a11y-pulse{0%,to{transform:scale(1);opacity:0}50%{transform:scale(1.1);opacity:.4}}[dir=rtl] .a11y-floating-btn{right:auto;left:24px}[data-high-contrast=true] .a11y-floating-btn{background:#000;color:#fff;border:4px solid #FFD700;box-shadow:0 0 0 4px #000}[data-high-contrast=true] .a11y-floating-btn:hover,[data-high-contrast=true] .a11y-floating-btn:focus-visible{background:gold;color:#000}[data-high-contrast=true] .a11y-floating-btn:before{border-color:gold}.a11y-quick-panel{position:fixed;bottom:110px;right:24px;width:340px;max-width:calc(100vw - 48px);background:#fff;border-radius:20px;box-shadow:0 12px 48px #00000040;z-index:9998;overflow:hidden;border:2px solid #e0e0e0}[dir=rtl] .a11y-quick-panel{right:auto;left:24px}.a11y-quick-panel-header{background:#06c;color:#fff;padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.a11y-quick-panel-header h3{margin:0;font-size:1rem;font-weight:600}.a11y-quick-panel-close{background:none;border:none;color:#fff;cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center}.a11y-quick-panel-close:hover{background:#fff3}.a11y-quick-panel-body{padding:1rem 1.25rem}.a11y-setting-group{margin-bottom:1.25rem}.a11y-setting-group:last-child{margin-bottom:0}.a11y-setting-label{display:block;font-weight:600;margin-bottom:.5rem;color:#333;font-size:.875rem}.a11y-font-size-buttons{display:flex;gap:.5rem}.a11y-font-size-btn{flex:1;padding:.75rem;border:3px solid #d0d0d0;background:#fff;border-radius:12px;cursor:pointer;font-weight:600;transition:all .2s ease;min-height:52px}.a11y-font-size-btn:hover{border-color:#06c;background:#f0f7ff}.a11y-font-size-btn:focus-visible{outline:3px solid #FFD700;outline-offset:2px}.a11y-font-size-btn.active{border-color:#06c;background:#06c;color:#fff}.a11y-font-size-btn span{display:block}.a11y-font-size-btn .size-small{font-size:.75rem}.a11y-font-size-btn .size-medium{font-size:.875rem}.a11y-font-size-btn .size-large{font-size:1rem}.a11y-font-size-btn .size-xlarge{font-size:1.125rem}.a11y-toggle{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-bottom:1px solid #e8e8e8}.a11y-toggle:last-child{border-bottom:none}.a11y-toggle-label{font-size:1rem;color:#222;font-weight:500}.a11y-toggle-switch{position:relative;width:56px;height:32px;background:#b0b0b0;border-radius:16px;cursor:pointer;transition:background .2s ease;border:2px solid transparent;padding:0;flex-shrink:0}.a11y-toggle-switch:focus-visible{outline:3px solid #FFD700;outline-offset:2px}.a11y-toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:26px;height:26px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 2px 6px #00000040}.a11y-toggle-switch.active{background:#06c}.a11y-toggle-switch.active:after{transform:translate(22px)}[dir=rtl] .a11y-toggle-switch:after{left:auto;right:3px}[dir=rtl] .a11y-toggle-switch.active:after{transform:translate(-22px)}.a11y-more-settings{display:block;text-align:center;padding:1rem;background:#f0f7ff;color:#06c;text-decoration:none;font-weight:700;font-size:1rem;border-top:2px solid #d0e4ff;transition:background .2s ease,color .2s ease}.a11y-more-settings:hover{background:#06c;color:#fff}.a11y-more-settings:focus-visible{outline:3px solid #FFD700;outline-offset:-3px}[data-high-contrast=true] .a11y-quick-panel{border:4px solid var(--a11y-hc-border);background:var(--a11y-hc-background)}[data-high-contrast=true] .a11y-quick-panel-header{background:var(--a11y-hc-text);border-bottom:4px solid #FFD700}[data-high-contrast=true] .a11y-font-size-btn{border-width:3px;border-color:var(--a11y-hc-border)}[data-high-contrast=true] .a11y-font-size-btn.active{background:var(--a11y-hc-text);color:var(--a11y-hc-background)}[data-high-contrast=true] .a11y-toggle-switch{border:3px solid var(--a11y-hc-border);background:#666}[data-high-contrast=true] .a11y-toggle-switch.active{background:var(--a11y-hc-text);border-color:gold}[data-high-contrast=true] .a11y-more-settings{background:var(--a11y-hc-text);color:var(--a11y-hc-background);border-top-color:gold}[data-high-contrast=true] .a11y-more-settings:hover{background:gold;color:var(--a11y-hc-text)}@media (prefers-contrast: more){:root:not([data-high-contrast=false]){--a11y-hc-text: #000000;--a11y-hc-background: #ffffff}}@media print{.a11y-floating-btn,.a11y-quick-panel,.skip-link{display:none!important}}@media (max-width: 480px){.a11y-quick-panel{bottom:100px;right:12px;left:12px;width:auto}[dir=rtl] .a11y-quick-panel{right:12px;left:12px}.a11y-floating-btn{bottom:16px;right:16px;width:64px;height:64px;border-width:3px}.a11y-floating-btn svg{width:32px;height:32px}[dir=rtl] .a11y-floating-btn{right:auto;left:16px}}[data-large-targets=true] .a11y-floating-btn{width:84px;height:84px}[data-large-targets=true] .a11y-floating-btn svg{width:42px;height:42px}[data-large-targets=true] .a11y-quick-panel{bottom:120px}:root{--color-primary: #3A9D9B;--color-primary-light: #5BC0BE;--color-primary-dark: #2C7A7A;--color-success: #4CAF6E;--color-success-light: #7ED99D;--color-warning: #F5A623;--color-warning-light: #FFB74D;--color-accent: #FF6B7A;--color-accent-light: #FF8A9B;--color-info: #9575CD;--color-info-light: #B39DDB;--color-danger: #E57373;--color-gray-50: #FAFAF8;--color-gray-100: #F5F5F2;--color-gray-200: #EEECE8;--color-gray-300: #E0DDD8;--color-gray-400: #BDBAB4;--color-gray-500: #8E8B84;--color-gray-600: #6B6862;--color-gray-700: #4A4844;--color-gray-800: #33312E;--color-gray-900: #1F1E1C;--bg-primary: #FDFCFA;--bg-cream: #FFF9F0;--bg-card: #FFFFFF;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .05);--shadow-md: 0 4px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 6px 16px rgba(0, 0, 0, .1);--shadow-card: 0 4px 12px rgba(0, 0, 0, .06)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-cream);min-height:100vh;color:var(--color-gray-800)}h1,h2,h3,h4,h5,h6{font-family:Nunito,sans-serif;font-weight:700;color:var(--color-gray-800)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{width:100%;min-height:100vh}
