.sync-status{position:relative;display:inline-block}.sync-status-indicator{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:12px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);font-size:12px;font-weight:500;transition:all .2s ease}.sync-status-indicator:hover{background:#ffffff26}.sync-status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.sync-status-dot.offline{background-color:#ff6b6b}.sync-status-dot.syncing{background-color:#4ecdc4}.sync-status-dot.pending{background-color:#ffa726}.sync-status-dot.synced{background-color:#66bb6a}.sync-status-indicator.clickable{cursor:pointer}.sync-status-indicator.default{cursor:default}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.sync-status-text{color:#fff;white-space:nowrap}.sync-button{background:none;border:none;color:#fff;cursor:pointer;font-size:14px;padding:2px;border-radius:4px;transition:background .2s ease}.sync-button:hover{background:#ffffff1a}.sync-button:active{transform:rotate(180deg);transition:transform .3s ease}.sync-status-details{position:absolute;top:100%;right:0;margin-top:8px;padding:12px;background:#000000e6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:8px;border:1px solid rgba(255,255,255,.1);min-width:200px;z-index:1000;box-shadow:0 8px 32px #0000004d}.sync-detail{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sync-detail:last-child{margin-bottom:0}.sync-detail-label{color:#ffffffb3;font-size:12px}.sync-detail-value{color:#fff;font-size:12px;font-weight:500}@media (max-width: 768px){.sync-status-details{right:auto;left:0;min-width:180px}.sync-status-indicator{font-size:11px;padding:3px 6px}}.app-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.header{text-align:center;margin-bottom:24px;color:#fff}.header h1{font-size:28px;font-weight:700;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.header p{font-size:16px;margin:8px 0 0;opacity:.9}.family-info{margin-top:12px;padding:8px 16px;background:#ffffff1a;border-radius:20px;display:inline-block}.family-name{font-weight:600;margin-right:12px}.family-members{font-size:14px;opacity:.8}.nav-tabs{display:flex;background:#ffffff1a;border-radius:12px;padding:4px;margin-bottom:24px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow-x:auto}.nav-tab{flex:1;min-width:80px;padding:12px 8px;text-align:center;border-radius:8px;cursor:pointer;transition:all .3s ease;color:#fff;font-weight:500;border:none;background:transparent;font-size:12px}.nav-tab.active{background:#fff3;box-shadow:0 2px 8px #0000001a}.nav-tab:hover{background:#ffffff26}.tab-content{background:#fffffff2;border-radius:16px;padding:24px;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-height:400px;animation:fadeIn .3s ease-in-out}.loading{text-align:center;padding:40px;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error{background:#fee;color:#c33;padding:20px;border-radius:12px;text-align:center;border:1px solid #fcc}.retry-button{background:#667eea;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;margin-top:16px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:32px}.kpi-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:12px;text-align:center;box-shadow:0 4px 16px #0000001a}.kpi-value{font-size:24px;font-weight:700;margin-bottom:4px}.kpi-label{font-size:14px;opacity:.9}.section{margin-bottom:32px}.section h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#333}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{margin:0}.add-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:transform .2s ease}.add-button:hover{transform:translateY(-2px)}.accounts-list{display:flex;flex-direction:column;gap:12px}.account-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;padding:16px;display:flex;justify-content:space-between;align-items:center;transition:box-shadow .2s ease}.account-card:hover{box-shadow:0 2px 8px #0000001a}.account-info{flex:1}.account-name{font-weight:600;color:#333;margin-bottom:4px}.account-type{font-size:12px;color:#6c757d}.account-balance{font-size:18px;font-weight:700;color:#667eea}.goals-list{display:flex;flex-direction:column;gap:16px}.goal-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;padding:20px;display:flex;justify-content:space-between;align-items:center;transition:box-shadow .2s ease}.goal-card:hover{box-shadow:0 2px 8px #0000001a}.goal-info{flex:1}.goal-name{font-weight:600;color:#333;margin-bottom:4px}.goal-description{font-size:14px;color:#6c757d;margin-bottom:12px}.goal-progress{margin-top:8px}.progress-bar{width:100%;height:8px;background:#e1e5e9;border-radius:4px;overflow:hidden;margin-bottom:4px}.progress-fill{height:100%;background:linear-gradient(90deg,#4ecdc4,#44a08d);transition:width .3s ease;width:0%}.progress-text{font-size:12px;color:#6c757d}.goal-percent{font-size:20px;font-weight:700;color:#667eea;margin-left:16px}.shopping-lists{display:flex;flex-direction:column;gap:16px}.shopping-list-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;padding:20px;transition:box-shadow .2s ease}.shopping-list-card:hover{box-shadow:0 2px 8px #0000001a}.list-info{margin-bottom:12px}.list-name{font-weight:600;color:#333;margin-bottom:4px}.list-stats{font-size:14px;color:#6c757d;margin-bottom:4px}.list-total{font-size:16px;font-weight:600;color:#667eea}.list-progress{margin-top:8px}.family-tab{text-align:center}.family-info-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:32px;border-radius:16px;margin-bottom:24px}.family-info-card h3{margin:0 0 16px;font-size:24px}.family-stats{display:flex;justify-content:center;gap:32px}.stat{text-align:center}.stat-value{display:block;font-size:20px;font-weight:700;margin-bottom:4px}.stat-label{font-size:14px;opacity:.8}.family-actions{display:flex;flex-direction:column;gap:12px}.action-button{background:#fff;color:#667eea;border:2px solid #667eea;padding:16px 24px;border-radius:12px;cursor:pointer;font-weight:600;transition:all .2s ease}.action-button:hover{background:#667eea;color:#fff}.no-family{padding:40px 20px}.no-family h3{margin:0 0 16px;font-size:24px;color:#333}.no-family p{color:#6c757d;margin-bottom:32px;line-height:1.6}.family-options{display:flex;flex-direction:column;gap:16px;max-width:300px;margin:0 auto}.option-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 24px;border-radius:12px;cursor:pointer;font-weight:600;font-size:16px;transition:transform .2s ease}.option-button:hover{transform:translateY(-2px)}.create-form{background:#f8f9fa;border:1px solid #e1e5e9;border-radius:12px;padding:24px;margin-bottom:24px}.create-form h4{margin:0 0 20px;color:#333}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .3s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:12px;justify-content:flex-end}.save-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;transition:transform .2s ease}.save-button:hover{transform:translateY(-2px)}.cancel-button{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;transition:transform .2s ease}.cancel-button:hover{transform:translateY(-2px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.app-container{padding:12px}.tab-content{padding:16px}.dashboard-grid{grid-template-columns:1fr}.kpi-card{padding:16px}.kpi-value{font-size:20px}.nav-tabs{overflow-x:auto}.nav-tab{min-width:70px;font-size:11px;padding:10px 6px}.section-header{flex-direction:column;gap:12px;align-items:stretch}.family-stats{flex-direction:column;gap:16px}.form-actions{flex-direction:column}}.payments-tab{padding:20px}.payment-card{background:#fff;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center}.payment-info{flex:1}.payment-name{font-weight:600;font-size:16px;color:#2c3e50;margin-bottom:4px}.payment-description{font-size:14px;color:#7f8c8d;margin-bottom:8px}.payment-details{display:flex;gap:16px;margin-bottom:4px}.payment-amount{font-weight:600;color:#e74c3c}.payment-frequency{font-size:14px;color:#7f8c8d}.payment-due{font-size:14px;color:#f39c12}.payment-actions{display:flex;gap:8px}.pay-button{background:#27ae60;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;cursor:pointer;transition:background-color .2s}.pay-button:hover{background:#229954}
