*{margin:0;padding:0;box-sizing:border-box}body{font-family:-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:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:#333}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fffffff2;padding:1.5rem 2rem;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.app-header h1{font-size:1.8rem;color:#667eea;font-weight:600}.user-info{display:flex;align-items:center;gap:1rem}.app-main{flex:1;padding:2rem;max-width:900px;width:100%;margin:0 auto}.auth-container{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:400px;margin:2rem auto}.auth-container h2{margin-bottom:.5rem;color:#333;font-size:1.8rem}.subtitle{color:#666;margin-bottom:1.5rem;font-size:.9rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#555;font-weight:500}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group textarea{resize:vertical;min-height:80px}.form-hint{display:block;margin-top:.25rem;font-size:.85rem;color:#666;font-style:italic}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s;font-family:inherit}.btn-primary{background:#667eea;color:#fff;width:100%}.btn-primary:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-success{background:#28a745;color:#fff}.btn-success:hover{background:#218838}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn-small{padding:.5rem 1rem;font-size:.9rem}.error{background:#f8d7da;color:#721c24;padding:.75rem;border-radius:6px;margin-bottom:1rem;border:1px solid #f5c6cb}.success{background:#d4edda;color:#155724;padding:.75rem;border-radius:6px;margin-bottom:1rem;border:1px solid #c3e6cb}.switch-auth{margin-top:1.5rem;text-align:center;color:#666}.link-btn{background:none;border:none;color:#667eea;cursor:pointer;text-decoration:underline;font-size:inherit;font-family:inherit}.link-btn:hover{color:#5568d3}.tabs{display:flex;gap:.5rem;margin-bottom:2rem;background:#fff;padding:.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.tab{flex:1;padding:.75rem 1.5rem;border:none;background:transparent;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s;color:#666}.tab:hover{background:#f0f0f0}.tab.active{background:#667eea;color:#fff}.tab-content{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 20px #0000001a}.wishlist-container,.family-list-container{width:100%}.wishlist-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.wishlist-container h2,.family-list-container h2{margin-bottom:.5rem;color:#333}.year-selector{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.year-selector label{font-weight:500;color:#555;margin:0}.year-select{padding:.5rem .75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;font-family:inherit;background:#fff;color:#333;cursor:pointer;transition:border-color .3s}.year-select:focus{outline:none;border-color:#667eea}.wishlist-form{margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #f0f0f0}.wishlist-items h3{margin-bottom:1rem;color:#555}.grouped-gifts{display:flex;flex-direction:column;gap:2rem}.requester-group{background:#f8f9fa;border-radius:8px;padding:1.5rem;border:2px solid #e9ecef}.requester-header{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #dee2e6;display:flex;align-items:center;gap:.5rem;font-size:1.2rem;color:#333}.requester-count{font-size:.9rem;color:#666;font-weight:400}.gift-list{list-style:none}.gift-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;margin-bottom:1rem;background:#f8f9fa;border-radius:8px;border:2px solid #e9ecef;transition:all .3s;gap:1rem}.gift-item:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.gift-item.purchased{background:#d4edda;border-color:#c3e6cb;opacity:.8}.gift-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.gift-link{color:#667eea;text-decoration:none;font-weight:500;font-size:1.1rem;display:block;margin-bottom:.25rem}.gift-link:hover{text-decoration:underline;color:#5568d3}.gift-description{color:#666;font-size:.9rem;margin:.5rem 0;line-height:1.5;font-style:italic}.gift-meta{font-size:.85rem;color:#666;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.requester-name{font-weight:600;color:#667eea}.meta-separator{color:#999;margin:0 .25rem}.purchased-badge{color:#28a745;font-weight:500}.purchased-label{color:#28a745;font-weight:500;font-size:.9rem}.gift-actions{margin-left:1rem;display:flex;gap:.5rem;flex-shrink:0}.edit-form{width:100%}.edit-actions{display:flex;gap:.5rem;margin-top:1rem}.edit-actions .btn{flex:1}.empty-state{text-align:center;color:#666;padding:3rem;font-size:1.1rem}.loading{text-align:center;color:#667eea;padding:1rem;font-style:italic}.btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.app-header{flex-direction:column;gap:1rem;text-align:center}.app-main{padding:1rem}.wishlist-header{flex-direction:column;align-items:flex-start}.year-selector{width:100%}.year-select{flex:1}.gift-item{flex-direction:column;align-items:flex-start;gap:1rem}.gift-actions{margin-left:0;width:100%}.gift-actions .btn{width:100%}.edit-actions{flex-direction:column}.edit-actions .btn{width:100%}}
