.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background:linear-gradient(135deg,var(--sage-light) 0%,var(--white) 50%,var(--cream) 100%)}.login-card{background:var(--white);border-radius:20px;box-shadow:0 10px 40px var(--shadow);padding:50px 40px;max-width:450px;width:100%;border:1px solid var(--border)}.login-header{text-align:center;margin-bottom:40px}.login-header h1{font-size:2rem;color:var(--sage-dark);margin-bottom:10px;font-weight:600}.login-form{display:flex;flex-direction:column;gap:25px}.form-group label{color:var(--text-dark);font-weight:500;font-size:.95rem}.form-group input{padding:14px 16px;border:2px solid var(--border);border-radius:10px;font-size:1rem;transition:all .3s ease;background:var(--off-white)}.form-group input:focus{outline:none;border-color:var(--sage-green);background:var(--white);box-shadow:0 0 0 3px #9caf881a}.error-message{background:#c7685d1a;color:var(--error);padding:12px 16px;border-radius:10px;border-left:4px solid var(--error);font-size:.9rem}.login-button{padding:16px;background:linear-gradient(135deg,var(--sage-green) 0%,var(--sage-dark) 100%);color:var(--white);border:none;border-radius:10px;font-size:1.1rem;font-weight:600;transition:all .3s ease;margin-top:10px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px var(--shadow)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;margin-top:30px;padding-top:25px;border-top:1px solid var(--border)}.footer-text{color:var(--text-light);font-size:.9rem}@media (max-width: 500px){.login-card{padding:40px 30px}.login-header h1{font-size:1.6rem}.wedding-icon{font-size:3rem}}.invite-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group input,.form-group textarea{padding:12px 14px;border:2px solid var(--border);border-radius:8px;font-size:1rem;transition:all .3s ease;background:var(--off-white)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--sage-green);background:var(--white);box-shadow:0 0 0 3px #9caf881a}.form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.checkbox-group{justify-content:center}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;padding:12px;background:var(--off-white);border:2px solid var(--border);border-radius:8px;transition:all .3s ease}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--sage-green)}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:10px;padding-top:20px;border-top:1px solid var(--border)}.cancel-button,.submit-button{padding:12px 28px;border-radius:8px;font-size:1rem;font-weight:600;transition:all .3s ease}.cancel-button{background:var(--off-white);color:var(--text-dark);border:2px solid var(--border)}.cancel-button:hover{background:var(--white);border-color:var(--text-light)}.submit-button{background:linear-gradient(135deg,var(--sage-green) 0%,var(--sage-dark) 100%);color:var(--white);border:none}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px var(--shadow)}@media (max-width: 768px){.form-row{grid-template-columns:1fr;gap:15px}.form-actions{flex-direction:column-reverse}.cancel-button,.submit-button{width:100%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:var(--white);border-radius:15px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 50px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:25px 30px;border-bottom:2px solid var(--sage-light)}.modal-header h2{color:var(--sage-dark);font-size:1.5rem;margin:0}.close-button{background:none;border:none;font-size:1.8rem;color:var(--text-light);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-button:hover{background:#c7685d1a;color:var(--error)}.modal-body{padding:30px;text-align:center}.invite-info{margin-bottom:25px}.invite-info h3{color:var(--sage-dark);font-size:1.3rem;margin-bottom:10px}.sub-info{color:var(--text-light);font-size:1rem;margin-bottom:10px}.url-info{font-size:.85rem;color:var(--text-light);word-break:break-all;background:var(--off-white);padding:10px;border-radius:8px}.qr-code-container{background:var(--white);padding:20px;border-radius:15px;border:2px solid var(--sage-light);display:inline-block;margin:20px 0}.qr-code-image{max-width:300px;width:100%;height:auto;display:block}.modal-actions{display:flex;gap:15px;justify-content:center;margin:25px 0;flex-wrap:wrap}.download-button,.copy-button{padding:12px 24px;border-radius:10px;font-weight:600;font-size:1rem;border:none;cursor:pointer;transition:all .3s ease}.download-button{background:linear-gradient(135deg,var(--sage-green) 0%,var(--sage-dark) 100%);color:var(--white)}.download-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px var(--shadow)}.copy-button{background:var(--off-white);color:var(--text-dark);border:2px solid var(--border)}.copy-button:hover{background:var(--white);border-color:var(--sage-green)}.instructions{background:var(--cream);padding:20px;border-radius:10px;margin-top:20px;border-left:4px solid var(--sage-green)}.instructions p{margin:8px 0;font-size:.95rem;color:var(--text-dark);text-align:left}@media (max-width: 600px){.modal-content{margin:20px}.modal-header,.modal-body{padding:20px}.modal-actions{flex-direction:column}.download-button,.copy-button{width:100%}}.invite-list{background:var(--white);border-radius:15px;padding:30px;box-shadow:0 5px 25px var(--shadow);border:1px solid var(--border)}.list-header{margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid var(--sage-light)}.list-header h2{color:var(--sage-dark);font-size:1.5rem}.table-container{overflow-x:auto}.invite-table{width:100%;border-collapse:collapse}.invite-table thead{background:linear-gradient(135deg,var(--sage-light) 0%,var(--sage-green) 100%)}.invite-table th{padding:15px 12px;text-align:left;color:var(--white);font-weight:600;font-size:.95rem;white-space:nowrap}.invite-table tbody tr{border-bottom:1px solid var(--border);transition:background .2s ease}.invite-table tbody tr:hover{background:var(--off-white)}.invite-table tbody tr:last-child{border-bottom:none}.invite-table td{padding:16px 12px;font-size:.95rem;color:var(--text-dark)}.name-cell{font-weight:600;color:var(--sage-dark)}.contact-cell{font-size:.85rem}.contact-info{margin:4px 0;color:var(--text-light)}.center-cell{text-align:center}.comment-cell{max-width:200px}.comment-cell span:not(.no-data){display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-light);font-size:.9rem}.badge{display:inline-block;padding:4px 12px;background:var(--sage-light);color:var(--sage-dark);border-radius:12px;font-weight:600;font-size:.9rem}.badge-success{display:inline-block;padding:4px 12px;background:#7a8f6f33;color:var(--success);border-radius:12px;font-weight:600;font-size:.9rem}.badge-neutral{display:inline-block;padding:4px 12px;background:var(--off-white);color:var(--text-light);border-radius:12px;font-weight:600;font-size:.9rem}.badge-confirmed{display:inline-block;padding:4px 12px;background:#4caf5033;color:#2e7d32;border-radius:12px;font-weight:600;font-size:.9rem}.badge-pending{display:inline-block;padding:4px 12px;background:#ff980033;color:#e65100;border-radius:12px;font-weight:600;font-size:.9rem}.badge-warning{display:inline-block;padding:4px 12px;background:#f4433633;color:#c62828;border-radius:12px;font-weight:600;font-size:.9rem}.no-data{color:var(--text-light);opacity:.5}.actions-cell{text-align:center;white-space:nowrap}.qr-button,.edit-button,.delete-button{background:none;border:none;font-size:1.3rem;padding:6px 10px;margin:0 4px;border-radius:6px;transition:all .2s ease;cursor:pointer}.qr-button:hover{background:#6495ed33;transform:scale(1.1)}.edit-button:hover{background:#9caf8833;transform:scale(1.1)}.delete-button:hover{background:#c7685d33;transform:scale(1.1)}.empty-state{text-align:center;padding:60px 20px;background:var(--white);border-radius:15px;border:2px dashed var(--border)}.empty-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.empty-state h3{color:var(--text-dark);margin-bottom:10px}.empty-state p{color:var(--text-light)}@media (max-width: 1200px){.invite-table{font-size:.9rem}.invite-table th,.invite-table td{padding:12px 8px}.comment-cell{max-width:150px}}.foyer-row{background:#9caf881a}.foyer-row td{font-weight:600}.toggle-button{background:none;border:none;cursor:pointer;margin-right:8px;font-size:1rem;padding:4px 8px;border-radius:4px;transition:background .2s ease}.toggle-button:hover{background:#9caf8833}.membre-row{background:#9caf880d}.membre-row td{font-size:.9rem;color:var(--text-light);padding-top:10px;padding-bottom:10px}.membre-indent{padding-left:35px!important}.badge-small{display:inline-block;padding:2px 8px;background:var(--sage-light);color:var(--sage-dark);border-radius:10px;font-weight:500;font-size:.8rem}.edit-button-small{background:none;border:none;font-size:1rem;padding:4px 6px;margin:0 2px;border-radius:4px;transition:all .2s ease;cursor:pointer}.edit-button-small:hover{background:#9caf8833;transform:scale(1.1)}@media (max-width: 768px){.invite-list{padding:20px 15px}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.invite-table{min-width:800px}}.stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:25px;margin-bottom:40px}.stat-card{background:linear-gradient(135deg,var(--white) 0%,var(--cream) 100%);border-radius:15px;padding:30px;display:flex;align-items:center;gap:20px;box-shadow:0 5px 20px var(--shadow);border:1px solid var(--border);transition:all .3s ease}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px var(--shadow)}.stat-icon{font-size:3rem;background:linear-gradient(135deg,var(--sage-light) 0%,var(--sage-green) 100%);width:70px;height:70px;border-radius:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{flex:1}.stat-value{font-size:2.5rem;font-weight:700;color:var(--sage-dark);line-height:1;margin-bottom:5px}.stat-label{font-size:1rem;color:var(--text-light);font-weight:500}@media (max-width: 768px){.stats-container{grid-template-columns:1fr;gap:15px}.stat-card{padding:20px}.stat-icon{font-size:2.5rem;width:60px;height:60px}.stat-value{font-size:2rem}}.dashboard{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{background:linear-gradient(135deg,var(--sage-green) 0%,var(--sage-dark) 100%);color:var(--white);padding:30px 20px;box-shadow:0 4px 20px var(--shadow)}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:20px}.header-title h1{font-size:2rem;margin-bottom:5px;font-weight:600}.welcome{font-size:1rem;opacity:.95}.logout-button{padding:10px 24px;background:#fff3;color:var(--white);border:2px solid var(--white);border-radius:8px;font-weight:600;transition:all .3s ease}.logout-button:hover{background:var(--white);color:var(--sage-dark);transform:translateY(-2px)}.dashboard-main{flex:1;padding:40px 20px}.dashboard-container{max-width:1400px;margin:0 auto}.actions-section{margin:30px 0;display:flex;justify-content:center}.add-button{padding:16px 32px;background:linear-gradient(135deg,var(--sage-green) 0%,var(--sage-dark) 100%);color:var(--white);border:none;border-radius:12px;font-size:1.1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px var(--shadow)}.add-button:hover{transform:translateY(-3px);box-shadow:0 6px 25px var(--shadow)}.form-section{background:var(--white);border-radius:15px;padding:30px;margin:30px 0;box-shadow:0 5px 25px var(--shadow);border:1px solid var(--border)}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid var(--sage-light)}.form-header h2{color:var(--sage-dark);font-size:1.5rem}.cancel-icon-button{background:none;border:none;font-size:1.5rem;color:var(--text-light);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.cancel-icon-button:hover{background:#c7685d1a;color:var(--error)}.dashboard-footer{background:var(--sage-dark);color:var(--white);padding:20px;text-align:center;margin-top:auto}.dashboard-footer p{font-size:.95rem;opacity:.9}@media (max-width: 768px){.header-content{flex-direction:column;text-align:center}.header-title h1{font-size:1.5rem}.dashboard-main{padding:20px 15px}.form-section{padding:20px}}.confirmation-page{min-height:100vh;background:linear-gradient(135deg,var(--sage-light) 0%,var(--white) 50%,var(--cream) 100%);display:flex;justify-content:center;align-items:center;padding:20px}.confirmation-card{background:var(--white);border-radius:20px;box-shadow:0 10px 40px var(--shadow);padding:50px 40px;max-width:600px;width:100%;border:1px solid var(--border)}.header{text-align:center;margin-bottom:40px}.wedding-icon{font-size:4rem;margin-bottom:20px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.header h1{font-size:2rem;color:var(--sage-dark);margin-bottom:10px;font-weight:600}.subtitle{color:var(--text-light);font-size:1rem}.invite-details{margin-bottom:30px}.invite-details h2{color:var(--sage-dark);font-size:1.4rem;margin-bottom:15px}.message{color:var(--text-dark);line-height:1.6;margin-bottom:15px}.info-box{background:var(--sage-light);padding:15px;border-radius:10px;color:var(--sage-dark);font-size:.95rem}.already-confirmed{background:#7a8f6f1a;border-left:4px solid var(--success);padding:15px;border-radius:8px;margin-bottom:25px}.already-confirmed p{margin:5px 0;color:var(--success);font-weight:600}.already-confirmed .small{font-size:.85rem;font-weight:400;color:var(--text-light)}.confirmation-form{display:flex;flex-direction:column;gap:25px}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{color:var(--text-dark);font-weight:600;font-size:.95rem}.radio-group-label{margin-bottom:5px}.radio-options{display:flex;flex-direction:column;gap:12px}.radio-option{display:flex;align-items:center;padding:15px 20px;background:var(--off-white);border:2px solid var(--border);border-radius:10px;cursor:pointer;transition:all .3s ease}.radio-option:hover{border-color:var(--sage-green);background:var(--white)}.radio-option.selected{border-color:var(--sage-green);background:#9caf881a}.radio-option input[type=radio]{margin-right:12px;width:20px;height:20px;cursor:pointer;accent-color:var(--sage-green)}.radio-label{font-size:1rem;color:var(--text-dark);font-weight:500}.checkbox-label{display:flex;align-items:center;padding:15px 20px;background:var(--off-white);border:2px solid var(--border);border-radius:10px;cursor:pointer;transition:all .3s ease}.checkbox-label:hover{border-color:var(--sage-green);background:var(--white)}.checkbox-label input[type=checkbox]{margin-right:12px;width:20px;height:20px;cursor:pointer;accent-color:var(--sage-green)}.checkbox-label span{font-size:1rem;color:var(--text-dark);font-weight:500}textarea{padding:14px 16px;border:2px solid var(--border);border-radius:10px;font-size:1rem;font-family:inherit;resize:vertical;min-height:80px;transition:all .3s ease;background:var(--off-white)}textarea:focus{outline:none;border-color:var(--sage-green);background:var(--white);box-shadow:0 0 0 3px #9caf881a}.submit-button{padding:16px;background:linear-gradient(135deg,var(--sage-green) 0%,var(--sage-dark) 100%);color:var(--white);border:none;border-radius:10px;font-size:1.1rem;font-weight:600;transition:all .3s ease;margin-top:10px;cursor:pointer}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px var(--shadow)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.footer{text-align:center;margin-top:30px;padding-top:25px;border-top:1px solid var(--border)}.footer p{color:var(--text-light);font-size:.9rem}.success-container,.error-container{text-align:center;background:var(--white);border-radius:20px;padding:60px 40px;max-width:500px;box-shadow:0 10px 40px var(--shadow)}.success-icon,.error-icon{font-size:5rem;margin-bottom:20px;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-container h1,.error-container h2{color:var(--sage-dark);font-size:2rem;margin-bottom:15px}.success-container h2{color:var(--text-dark);font-size:1.3rem;margin-bottom:25px;font-weight:400}.success-details{background:var(--cream);padding:20px;border-radius:10px;margin:25px 0}.success-details p{margin:8px 0;font-size:1rem}.confirmed{color:var(--success);font-weight:600}.declined{color:var(--error);font-weight:600}.footer-message{color:var(--sage-dark);font-size:1.1rem;margin-top:20px}@media (max-width: 600px){.confirmation-card,.success-container,.error-container{padding:40px 30px}.header h1{font-size:1.6rem}.wedding-icon{font-size:3rem}.radio-option,.checkbox-label{padding:12px 15px}}.app{min-height:100vh}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;gap:20px}.spinner{width:50px;height:50px;border:4px solid var(--sage-light);border-top:4px solid var(--sage-green);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:var(--text-light);font-size:1.1rem}*{margin:0;padding:0;box-sizing:border-box}:root{--sage-green: #9caf88;--sage-dark: #7a8f6f;--sage-light: #c8d5bb;--white: #ffffff;--off-white: #fafafa;--cream: #f8f6f3;--text-dark: #2c3e2c;--text-light: #5a6b5a;--border: #e0e5dd;--shadow: rgba(156, 175, 136, .15);--error: #c7685d;--success: #7a8f6f}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,var(--cream) 0%,var(--white) 100%);color:var(--text-dark);line-height:1.6;min-height:100vh}#root{min-height:100vh}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--off-white)}::-webkit-scrollbar-thumb{background:var(--sage-light);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--sage-green)}
