.group-list-container{min-height:100vh;padding:2rem 1rem;display:flex;flex-direction:column;align-items:center}.group-list-header{text-align:center;color:#fff;margin-bottom:3rem}.group-list-header h1{font-size:2.5rem;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.group-list-header p{font-size:1.1rem;opacity:.9}.excuse-button{background:linear-gradient(135deg,#ff9800,#f57c00);border:none;color:#fff;padding:1rem 2rem;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003;margin-bottom:2rem;align-self:center}.excuse-button:hover{transform:scale(1.05);box-shadow:0 6px 20px #ff980066}.excuse-button:active{transform:scale(.98)}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1.5rem;width:100%;max-width:800px}.appointment-card{width:100%;max-width:800px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:1.5rem;color:#fff;box-shadow:0 8px 24px #00000040;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);margin-bottom:1.5rem}.appointment-title h2{margin:0 0 .25rem;font-size:1.25rem}.appointment-title p{margin:0 0 1rem;opacity:.85}.appointment-form{display:grid;gap:.75rem;grid-template-columns:1fr auto;align-items:start}.appointment-label{grid-column:1 / -1;font-weight:600;opacity:.9}.appointment-options{display:flex;flex-wrap:wrap;gap:.5rem}.option-pill{display:inline-flex;align-items:center;gap:.5rem;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:.45rem .9rem;color:#fff;cursor:pointer;transition:transform .15s ease,border-color .15s ease}.option-pill input{accent-color:#4caf50}.option-pill:hover{transform:translateY(-1px);border-color:#ffffff59}.appointment-button{background:linear-gradient(135deg,#4caf50,#2e7d32);border:none;color:#fff;padding:.7rem 1.5rem;border-radius:12px;font-weight:700;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.appointment-button:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:none}.appointment-button:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 6px 18px #4caf5066}.appointment-footer{display:flex;gap:1rem;align-items:center;margin-top:.75rem;flex-wrap:wrap}.helper-text{font-size:.95rem;opacity:.85}.status-message{padding:.4rem .75rem;border-radius:10px;font-weight:700}.status-message.success{background:#4caf5026;color:#b2f5ea;border:1px solid rgba(76,175,80,.35)}.status-message.error{background:#f4433626;color:#ffcdd2;border:1px solid rgba(244,67,54,.35)}.group-card{background:#fff;border:none;border-radius:20px;padding:2rem 1.5rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003;display:flex;flex-direction:column;align-items:center;gap:1rem;min-height:180px;justify-content:center}.group-card.empty-state{border:2px dashed rgba(0,0,0,.1);background:#fffc;color:#444;text-align:center}.group-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000004d}.group-card:active{transform:translateY(-2px)}.group-icon{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700}.group-name{font-size:1.2rem;font-weight:600;color:#333;text-align:center}.loading-spinner,.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#fff;text-align:center}.error-message h2{margin-bottom:1rem}.error-message p{margin-bottom:1.5rem;opacity:.9}.retry-button{background:#fff;color:#667eea;border:none;padding:.75rem 2rem;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.retry-button:hover{transform:scale(1.05);box-shadow:0 4px 15px #0003}@media (max-width: 768px){.groups-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.appointment-form{grid-template-columns:1fr}.group-card{padding:1.5rem 1rem;min-height:150px}.group-list-header h1{font-size:2rem}}.member-swipe-container{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.swipe-header{display:flex;justify-content:space-between;align-items:center;color:#fff;margin-bottom:2rem;padding:0 .5rem}.back-button{background:#fff3;border:none;color:#fff;padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-size:1rem;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-button:hover{background:#ffffff4d;transform:scale(1.05)}.swipe-header h2{font-size:1.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.progress{background:#fff3;padding:.5rem 1rem;border-radius:20px;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cards-container{flex:1;display:flex;justify-content:center;align-items:center;position:relative;margin:2rem 0;min-height:400px}.member-card{position:absolute;width:90%;max-width:400px;height:500px;background:#fff;border-radius:25px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:grab;-webkit-user-select:none;user-select:none;transition:transform .3s ease,opacity .3s ease;overflow:hidden}.member-card:active{cursor:grabbing}.card-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem;text-align:center}.appointment-card{margin-top:20px}.member-avatar{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;box-shadow:0 5px 20px #0003}.member-name{font-size:2rem;color:#333;margin:0}.member-group{font-size:1.2rem;color:#666;margin:0;padding:.5rem 1.5rem;background:#f0f0f0;border-radius:20px}.swipe-indicator{position:absolute;top:50%;transform:translateY(-50%);font-size:2rem;font-weight:700;padding:1rem 2rem;border-radius:15px;border:4px solid;background:#ffffffe6;z-index:10;animation:pulse .3s ease}.swipe-yes{right:20px;color:#4caf50;border-color:#4caf50}.swipe-no{left:20px;color:#f44336;border-color:#f44336}@keyframes pulse{0%{transform:translateY(-50%) scale(.8);opacity:0}to{transform:translateY(-50%) scale(1);opacity:1}}.swipe-right{transform:translate(100vw) rotate(30deg)!important}.swipe-left{transform:translate(-100vw) rotate(-30deg)!important}.action-buttons{display:flex;justify-content:center;gap:2rem;margin:2rem 0;padding:0 1rem}.action-button{flex:1;max-width:200px;padding:1.2rem 2rem;border:none;border-radius:50px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003;color:#fff}.absent-button{background:linear-gradient(135deg,#f44336,#d32f2f)}.absent-button:hover{transform:scale(1.05);box-shadow:0 6px 20px #f4433666}.absent-button:active{transform:scale(.98)}.present-button{background:linear-gradient(135deg,#4caf50,#388e3c)}.present-button:hover{transform:scale(1.05);box-shadow:0 6px 20px #4caf5066}.present-button:active{transform:scale(.98)}.swipe-hint{text-align:center;color:#fff;opacity:.8;font-size:.9rem;margin-bottom:1rem}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#fff;text-align:center}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.member-card{height:450px;width:95%}.member-avatar{width:100px;height:100px;font-size:2.5rem}.member-name{font-size:1.5rem}.action-buttons{gap:1rem}.action-button{padding:1rem 1.5rem;font-size:1rem}.swipe-header h2{font-size:1.2rem}}*{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;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}
