:root{--primary: #dc143c;--primary-light: #fff1f2;--success: #ecfdf5;--success-text: #059669;--text-main: #111827;--text-muted: #6b7280;--bg-body: #f9fafb;--card-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06)}body{font-family:Outfit,sans-serif;background-color:var(--bg-body);color:var(--text-main);margin:0;padding:0;display:flex;flex-direction:column;min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.header{text-align:center;padding:40px 20px}.header h1{font-size:32px;font-weight:700;margin-bottom:8px}.header p{color:var(--text-muted);font-size:16px}.main-container{max-width:1100px;margin:0 auto 60px;display:flex;flex-direction:row;gap:30px;width:100%;padding:0 20px;box-sizing:border-box}.sidebar{width:280px;flex-shrink:0}.step-item{background:#fff;border-radius:12px;padding:16px 20px;margin-bottom:12px;display:flex;align-items:center;gap:15px;cursor:pointer;transition:all .3s ease;border:1px solid transparent;box-shadow:var(--card-shadow)}.step-item.active{background:var(--primary);color:#fff}.step-item.completed{background:var(--success);color:var(--success-text)}.step-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;color:var(--text-muted);font-size:16px}.step-item.active .step-icon{background:#fff3;color:#fff}.step-item.completed .step-icon{background:#fff;color:var(--success-text)}.step-label{font-weight:600;font-size:15px}.content-card{flex-grow:1;background:#fff;border-radius:24px;padding:40px;box-shadow:var(--card-shadow);position:relative;min-height:500px}.view-section{display:none;animation:fadeIn .4s ease}.view-section.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px}.section-header h2{margin:0;font-size:24px;font-weight:700}.recap-info{text-align:right}.recap-label{font-size:10px;font-weight:700;color:#9ca3af;text-transform:uppercase}.recap-value{color:var(--primary);font-weight:600}@media(max-width:768px){.section-header{flex-direction:column;gap:10px;align-items:flex-start}.recap-info{text-align:left}}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.day-name{text-align:center;font-size:12px;font-weight:600;color:var(--text-muted);padding-bottom:10px}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s;background:#f9fafb}.calendar-day:hover:not(.disabled){background:var(--primary-light);color:var(--primary)}.calendar-day.selected{background:var(--primary);color:#fff}.calendar-day.disabled{color:#d1d5db;cursor:not-allowed;background:#fcfcfc}.calendar-day.today{position:relative}.calendar-day.today:after{content:"";position:absolute;bottom:4px;width:4px;height:4px;border-radius:50%;background:var(--primary)}.rooms-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-height:480px;overflow-y:auto;padding-right:10px}.room-card{border:1px solid #e5e7eb;border-radius:16px;padding:24px;cursor:pointer;transition:all .3s;display:flex;flex-direction:column;gap:12px;position:relative}.room-card:hover{border-color:var(--primary);box-shadow:0 10px 15px -3px #0000000d}.room-card.selected{border-color:var(--primary);background:var(--primary-light)}.room-meta{display:flex;justify-content:space-between;align-items:flex-start}.room-icon-box{width:44px;height:44px;background:#f3f4f6;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--text-muted)}.room-card.selected .room-icon-box{background:#fff;color:var(--primary)}.room-capacity{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:5px}.room-title{font-size:18px;font-weight:700;margin:0}.room-desc{font-size:14px;color:var(--text-muted);margin:0;line-height:1.5}.room-pricing{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.price-tag{background:var(--primary-light);color:var(--primary);padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600}.duration-section{margin-bottom:40px}.section-title{font-size:18px;font-weight:700;color:var(--text-main);margin-bottom:20px;display:flex;align-items:center;gap:10px}.section-title i{color:var(--primary)}.bloc-options{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:30px}.bloc-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:24px;text-align:center;cursor:pointer;transition:all .3s ease;position:relative}.bloc-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 10px 25px -5px #dc143c26}.bloc-card.selected{border-color:var(--primary);background:var(--primary-light);transform:translateY(-2px);box-shadow:0 10px 25px -5px #dc143c33}.bloc-icon{font-size:32px;margin-bottom:12px}.bloc-title{font-size:18px;font-weight:700;color:var(--text-main);margin-bottom:8px}.bloc-duration{font-size:14px;color:var(--text-muted);margin-bottom:12px}.bloc-price{font-size:20px;font-weight:700;color:var(--primary)}.slots-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-height:380px;overflow-y:auto;padding-right:10px}.slot-btn{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px;font-weight:600;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s;min-height:90px}.slot-time{font-size:14px;font-weight:600}.slot-price{font-size:16px;font-weight:700;color:var(--primary)}.slot-type{font-size:11px;color:var(--text-muted);font-weight:500}.slot-btn:hover:not(.disabled){border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.slot-btn.selected{background:var(--primary);color:#fff;border-color:var(--primary);position:relative}.slot-btn.selected:after{content:"✓";position:absolute;top:5px;right:5px;background:#fff;color:var(--primary);width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.slot-btn.disabled{opacity:.5;cursor:not-allowed;background:#f3f4f6;border-style:dashed}.slot-btn.loading-slot{opacity:.5;cursor:wait;position:relative}.slot-btn.loading-slot:after{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin:-8px 0 0 -8px;border:2px solid var(--primary);border-radius:50%;border-top-color:transparent;animation:spin 1s linear infinite}.booked-badge{font-size:.65rem;background:#fee2e2;color:#ef4444;padding:2px 6px;border-radius:4px;margin-left:auto;font-weight:500;white-space:nowrap}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.full-width{grid-column:span 2}label{font-size:14px;font-weight:600;color:var(--text-main)}input,select,textarea{padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-family:inherit;font-size:15px;background:#f9fafb;transition:border .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);background:#fff}.recap-badge{background:var(--primary-light);color:var(--primary);padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase}.btn-row{margin-top:40px;display:flex;justify-content:space-between}.btn{padding:14px 28px;border-radius:12px;font-weight:600;font-size:15px;cursor:pointer;border:1px solid transparent;display:flex;align-items:center;gap:10px;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-outline{background:#fff;border-color:#e5e7eb;color:var(--text-muted)}.btn-outline:hover{background:#f9fafb}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;background:#d1d5db;color:#9ca3af}.success-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.success-modal{background:#fff;padding:40px;border-radius:24px;text-align:center;max-width:400px}@media(max-width:768px){.main-container{flex-direction:column;gap:20px}.sidebar{width:100%;display:flex;gap:10px;overflow-x:auto;padding-bottom:5px;scrollbar-width:none}.sidebar::-webkit-scrollbar{display:none}.step-item{padding:10px 15px;margin-bottom:0;flex:1;min-width:max-content;white-space:nowrap;gap:10px}.step-icon{width:28px;height:28px;font-size:12px}.header{padding:30px 15px}.header h1{font-size:26px}.content-card{padding:24px;border-radius:16px}.rooms-grid{grid-template-columns:1fr}.bloc-options{grid-template-columns:1fr;gap:15px}.slots-grid,.form-grid{grid-template-columns:1fr}.full-width{grid-column:span 1}.btn-row{flex-direction:column-reverse;gap:12px}.btn{width:100%;justify-content:center}.view-section h2{font-size:20px}.section-title{font-size:16px}.bloc-card{padding:20px}.bloc-icon{font-size:28px}.bloc-title{font-size:16px}.bloc-price{font-size:18px}}@media(max-width:480px){.sidebar{gap:8px}.step-item{padding:10px 15px}.step-label{font-size:13px}.step-icon{display:none}}
