* { box-sizing:border-box }
html, body { padding:0; margin:0; scroll-behavior:smooth; overflow-x:hidden; }
body { font-family:'Manrope', sans-serif; font-size:1.15vw; color:#ddd; background:#000; }

.swal2-container { z-index:99999 !important; }
.swal2-popup { background:#141414; box-shadow:0 0 30px 10px rgba(255,255,255,0.1); border-radius:30px; }
.swal2-title { color:#fff; }
.swal2-content { color:#aaa; }
.swal2-styled.swal2-confirm { background-color:#0423c9; }

.font_cormo { font-family: 'Cormorant', serif; }
.font_work { font-family: 'Manrope', sans-serif; }
.maxw { width:90%; max-width:1300px; margin:0 auto; }

p { margin:0 0 1.5em }
a { transition:all 350ms ease-out; }
.btn, a.btn { background:#0000f6; color:#fff !important; font-weight:bold; font-size:27px; padding:0 90px; line-height:100px; border-radius:15px; display:inline-block; text-decoration:none; box-shadow: 0 0 20px 3px rgb(5 2 246 / 73%); }
@media(hover: hover) and (pointer: fine) {
  .btn:hover, a.btn:hover { background:#0000ab; box-shadow:0 0 30px 8px rgba(5,2,246,0.5); }
}

/*! SCROLL ANIMATIONS - ON SCROLLING */
.initScroll .scrollzoom { <?=scale("0.5")?> opacity:0 }
.initScroll .scrollleft { <?=translateX("100%")?> }
.initScroll .scrollright { <?=translateX("-100%")?> }
.initScroll .scrollleft2 { <?=translateX("20%")?> opacity:0; }
.initScroll .scrollright2 { <?=translateX("-20%")?> opacity:0; }
.initScroll .scrolltop2 { <?=translateY("100px")?> opacity:0; }
.initScroll .scrollbottom2 { <?=translateY("-150px")?> opacity:0; }
.initScroll .scrollfade { opacity:0; <?=translateY("50px")?> }
.parallax2 { position:absolute; top:0; left:0; width:100%; height:100vh; pointer-events:none; }
/*! SCROLL ANIMATIONS - ONE TIME */
.initScroll .scrollfade2 { opacity:0; <?=translateY("50px")?> <?=transition("all 700ms ease-out")?> }
.initScroll .scrollfade2.show { opacity:1; <?=translateY("0")?> }
.initScroll .scrollexpand2 { <?=transform("scaleX(0)")?> }
.initScroll .scrollexpand2.show { <?=transform("scaleX(1)")?> }



#topBar { background:#141414; color:#ddd; text-align:center; height:44px; line-height:44px; font-size:16px; font-weight:normal; text-decoration:underline; }

#header { background:#000; padding:20px 80px 35px; position:relative; }
#header h1 { font-family: 'Hoefler Text', serif; margin:0; line-height:1em; font-size:clamp(27px, 2.2vw, 40px); color:#fff; font-weight:bold; }
#header h2, #header h2 a { color:#ccc; font-size:clamp(12px, 0.85vw, 15px); margin:0; font-weight:100; letter-spacing:-0.05em }

#menu { position:absolute; top:50%; right:80px; transform:translateY(-50%); }
#menu a { color:rgba(255,255,255,0.6); font-size:20px; display:inline-block; margin:0 0 0 40px; text-decoration:none; }
#menu a.select { color:#fff }
@media(hover: hover) and (pointer: fine) {
  #menu a:hover { color:#fff }
}
#menu a.btn { line-height:72px; padding:0 35px; border-radius:36px; }


.separe { background:#424242; max-width:1500px; width:90%; margin:150px auto; height:1px; }

#accueil { position:relative; background:#000; overflow:visible; z-index:1; }
/* espaces0 au-dessus du hero (pas de background → vidéo visible à travers) */
#espaces0 { position:relative; z-index:2; }
/* Autres sections : au-dessus de tout, avec fond noir */
#accueil ~ .separe, #accueil ~ h2, #accueil ~ br,
#accueil ~ p.maxw, #accueil ~ div.maxw,
#services, #matosChoice, #matos, #tarifs, #footer {
  position:relative; z-index:2; background:#000;
}
#accueil video { position:absolute; top:0; left:0; width:100%; height:auto; min-height:100%; object-fit:cover; opacity:0; transition:opacity 0.8s ease; z-index:0; }
#accueil video.ready { opacity:1; }
#accueil:after { position:absolute; top:0; left:0; width:100%; height:100%; content:""; z-index:1; }
#accueil2 { position:relative; z-index:2; padding:135px 0 180px; }
#accueil3 { max-width:890px; width:90%; background:rgb(0 0 0 / 40%); color:#ccc; padding:40px 60px 60px; border-radius:50px; font-weight:100; overflow: hidden; backdrop-filter: blur(10px); }
#accueil2 .new { background:rgba(255,255,255,0.08); color:#fff; border:1px solid rgba(255,255,255,0.2); padding:0 35px; border-radius:20px; line-height:35px; font-weight:bold; display:inline-block; margin:0 0 20px; }
#accueil3 h1 { color:#fff; font-size:50px; margin:0 0 30px; }
#accueil3 .btn { border-radius:20px; text-align:center; font-size:30px; padding:0 110px; line-height:90px; }



#espaces { padding:140px 0 0; position:relative; overflow-x:auto; white-space:nowrap; /*scroll-snap-type:x mandatory; -webkit-scroll-snap-type:x mandatory; scroll-behavior:smooth; -webkit-scroll-behavior:smooth;*/ }
#espaces.no { /*scroll-behavior:initial; -webkit-scroll-behavior:initial;*/ }
#espaces:before, #espaces:after { width:25vw; height:100px; display:inline-block; content:""; }
#espaces .espace { display:inline-flex; flex-direction:column; max-width:882px; width:50%; margin:0 5%; white-space:normal; vertical-align:top; /*scroll-snap-align:center; -webkit-scroll-snap-align:center;*/ opacity:0.2; transition:all 300ms ease-out; background: color(srgb 0.0784 0.0784 0.0784); padding: 40px; border-radius: 30px;}
#espaces .espace, #espaces .espace.select { opacity:1 }
#espaces .espace .img { padding-top:64%; position:relative; background:#eee; border-radius:30px; overflow:hidden; }
#espaces .espace img { width:100%; position:absolute; top:0; left:0; height:100%; object-fit:cover; }
#espaces .espace .progress { position:relative; height:4px; border-radius:2px; background:#393939; margin:42px 0 50px; display:block; }
#espaces .espace .progress2 { position:absolute; top:0; left:0; height:100%; background:#0000fe; box-shadow: 0 0 20px 3px rgb(5 2 246 / 73%); border-radius:2px; }
#espaces .espace h2 { font-size:45px; color:#fff; margin:0 0 50px; }
#espaces .espace p { line-height:1.5em; flex-grow:1; }
#espaces0 .left, #espaces0 .right { position:absolute; top:calc(140px + 40px + 16vw); right:45px; width:100px; height:100px; border-radius:50%; background:#ebebeb url(images/flc_right.png) no-repeat center center; box-shadow:0 0 10px rgba(0,0,0,0.2); cursor:pointer; transition:all 300ms ease-out; filter:invert(1); box-shadow:0 0 16px 4px #00000052; }
#espaces0 .left { background-image:url(images/flc_left.png); right:auto; left:45px; }

@media(hover: hover) and (pointer: fine) {
  #espaces0 .left:hover, #espaces0 .right:hover { width:80px; height:80px; margin-top:10px; }
}

#espaces::-webkit-scrollbar-track { border:0 }
#espaces::-webkit-scrollbar {	width: 0; height:0; border:0 }
#espaces::-webkit-scrollbar-button{ border:0;width:0;height:0 }


.sectionTitle { text-align:center; font-size:50px; color:#fff; margin:0 auto 40px; }

#services { display: flex; flex-direction: row; flex-wrap: wrap; justify-content: space-between; }
#services .service { display:flex; flex-direction: row; flex-wrap: nowrap; align-items: center; width:48%; margin:0 0 30px; border:1px solid #141414; background:#141414; border-radius:25px; padding:2.5vw; font-size:20px; transition:all 350ms ease; }
#services .service:hover { box-shadow:0 0 20px 5px rgba(5,2,246,0.15); }
#services .service svg { height:54px; width:48px; margin-right:2vw; vertical-align:middle; display:inline-block; }
#services .service svg path, #services .service svg circle { fill:#0000ff; }
#services .service svg.clim path { stroke:#0000ff; }
#services .service strong { color:#fff }


#matosChoice { max-width:900px; display: grid ; position: relative; padding: 28px 20px; margin: 0 auto 20px; border: 1px solid #666; border-radius: 30px; grid-template-columns: repeat(5, 1fr); gap: 20px; }
#matosChoice .back { position: absolute; background: #0000fe; width: 25%; top: 10px; left: 10px; z-index: 0; border-radius: 20px; box-shadow: 0 0 25px 8px #0000fea3; transition:all 350ms ease-out; }
#matosChoice .txt { display: flex ; flex-direction: column; align-content: center; align-items: center; justify-content: flex-start; color: #fff; font-size: 12px; cursor:pointer;  transition:all 350ms ease-out; opacity:0.5; position:relative; z-index:1; }
#matosChoice strong { font-size: 17px; display: block; margin: 5px auto 3px;  transition:all 350ms ease-out; }
#matosChoice img { transition:all 350ms ease-out; }
#matosChoice .old { text-decoration:line-through; }
#matosChoice .select { opacity:1; }


#matos { display: flex; flex-direction: row; flex-wrap: wrap; justify-content: space-between; }
#matos .service { width:48%; margin:0 0 30px; border:0; background:#131313; border-radius:25px; padding:2.5vw 110px 2.5vw 2.5vw; font-size:20px; opacity:0.7; position:relative; transition:all 350ms ease-out; order:2; }
#matos .service.select { background:#141414;opacity:1; }
#matos .service:after { content:""; transition:all 350ms ease-out; transform:translateY(-50%); opacity:0; position:absolute; top:50%; right:20px; background:url(images/ico_select.png) no-repeat center center / contain; width:80px; height:80px; }
#matos .service.select:after { opacity:1; transform:translateY(-50%); }
#matos .service.inclus { opacity:1; background:#141414 }
#matos .service .prix { display:table; line-height:25px; font-size:0.6em; margin:3px 0 0; padding:0 7px; border-radius:20px; background:#323232; color:#fff; }
#matos .service.inclus .prix { opacity:1; background:#0502ff; color:#fff;  }
#matos .service svg { height:54px; width:48px; margin-right:2vw; vertical-align:middle; display:inline-block; }
#matos .service svg path, #matos .service svg circle { fill:#0000ff; }
#matos .service svg.clim path { stroke:#0000ff; }
#matos .service strong { color:#fff }
#matosGradient { display:none; }
#matosToggle { display:none; }
.matosNote { margin:0 auto 30px; font-size:0.8em; text-align:center; color:#666; }


#equipe { text-align:center; }
#equipe h2 { font-size:50px; color:#141414; margin:0 0 10px; }
#equipe h2 strong { color:#0000f6; text-decoration:underline; }
#equipe u { color:#aaa; display:block; margin:0 0 90px; }
#equipe u a { color:#aaa; font-weight:normal; color:#333 }
#equipe2 { font-size:0; overflow-x:auto; white-space:nowrap; padding:0; margin:0 0 80px; /*scroll-snap-type:x mandatory; scroll-behavior:smooth;*/ }
#equipe2 .equipe { display:inline-block; margin:0 72px; color:#141414; font-weight:bold; font-size:30px; text-align:center; /*scroll-snap-align:center;*/ }
#equipe2 .equipe .img { width:190px; height:190px; position:relative; border-radius:50%; overflow:hidden; background:#0000f6; margin:0 0 44px; }
#equipe2 .equipe img { display:block; width:100%; height:100%; mix-blend-mode: luminosity; }
#equipe .btn { line-height:100px; padding:0 175px; font-size:30px; border-radius:20px; }

#equipe2::-webkit-scrollbar-track { border:0 }
#equipe2::-webkit-scrollbar {	width: 0; height:0; border:0 }
#equipe2::-webkit-scrollbar-button{ border:0;width:0;height:0 }








.tarifTitle { margin-bottom:15px !important; }
#tarifs { text-align:center; }
#tarifs .tarif { width:680px; margin:0 40px; background:#141414; border-radius:50px; box-shadow:0 0 10px rgba(0,0,0,0.1); padding:75px 60px 55px; text-align:left; display:inline-block; vertical-align:top; }
#tarifs .tarif h2 { text-align:center; color:#fff; font-size:50px; margin:0 0 30px; }
#tarifs .tarif .img { margin:0 auto 38px; width:80%; border-radius:20px; overflow:hidden }
#tarifs .tarif .img img { width:100%; display:block; }
#tarifs .choice { height:66px; line-height:66px; font-weight:bold; font-size:0; position:relative; display:block; margin:0 0 50px; }
#tarifs .choice:before { content:""; background:#0000fe; position:absolute; top:6px; left:6px; right:50%; bottom:6px; transition:all 350ms ease-out; border-radius:33px; }
#tarifs .choice .left, #tarifs .choice .right { width:50%; display:inline-block; font-size:17px; position:relative; text-align:center; cursor:pointer; transition:all 350ms ease-out; }
#tarifs .choice:after { content:""; position:absolute; top:0; left:0; right:0; bottom:0; border:1px solid #5e5e5e; border-radius:33px; pointer-events:none; }
#tarifs .choice .left { color:#fff; }
#tarifs .choice .right { color:#a3a3a3; }
#tarifs .choice[data-choice='right'] .left { color:#a3a3a3; }
#tarifs .choice[data-choice='right'] .right { color:#fff; }
#tarifs .choice[data-choice='right']:before { right:6px; left:50%; }
#tarifs .price { font-size:50px; color:#fff; font-weight:bold; text-align:center; }
#tarifs .price .before { color:#ccc; text-decoration:line-through }
#tarifs .price .sup { font-size:30px; margin-top:-20px; display:inline-block; vertical-align:super; }
#tarifs .list { margin:60px 0; line-height:2.5em; font-weight:200; font-size:25px; line-height:1.2em; }
#tarifs .list .line { text-indent: -60px; margin-left: 60px; margin-bottom: 24px; }
#tarifs .list a { color:#aaa }
#tarifs .list .disable { font-style:italic }
#tarifs .list .check { width:32px; height:32px; margin:0 20px 0 0; display:inline-block; border:1px solid #aaa; border-radius:50%; position:relative; vertical-align:middle; }
#tarifs .list .check:before { content:""; position:absolute; top:0; left:0; width:100%; height:100%; background:url(images/check.jpg) no-repeat center center / 50%; filter:invert(1); }
#tarifs .list .disable .check:before { display:none; }
#tarifs p { color:#141414; font-size:25px; text-align:center; font-weight:bold; margin:38px 0 0 }
#tarifs p em { font-size:18px; font-weight:normal; color:#666 }
#tarifs .btn { width:100%; text-align:center }
#tarifs .price .partir { display: block; font-size: 16px; font-weight: normal; color: #888; }
.tarifNote { font-size:0.6em; }



.openResa, .openResa body, .openPanier, .openPanier body { overflow:hidden; }
.openResa body, .openPanier body { position:fixed; width:100%; }
#reserver { position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.8); z-index:50; opacity:0; pointer-events:none; transition:all 350ms ease-out 200ms; font-size:20px; user-select:none; }
.openResa #reserver { opacity:1; pointer-events:auto; transition:all 350ms ease-out 0ms; }
#reserver .close { position:absolute; top:40px; left:50%; background:#fff; transform:translateX(-50%); cursor:pointer; border-radius:50%; width:70px; height:70px; color:#141414; font-size:33px; line-height:72px; text-align:center; z-index:5; }
#reserver2 { position:absolute; top:50%; left:50%; max-height:90vh; overflow:hidden; max-width:960px; width:90%; opacity:0; background:#141414; padding:50px 40px; border-radius:50px; transform:translate(-50%,-50%); margin-top:50px; transition:all 350ms ease-out 0ms; text-align:center; display:flex; flex-direction:column; }
#reserver #step1, #reserver #step2, #reserver #step3 { flex:1 1 auto; flex-direction:column; min-height:0; overflow:hidden; }
#reserver #step1.stepActive, #reserver #step2.stepActive, #reserver #step3.stepActive { display:flex !important; }
#reserver .stepContent { flex:1 1 auto; overflow-y:auto; overflow-x:hidden; min-height:0; padding-bottom:10px; }
#reserver .footerBar { flex-shrink:0; border-top:1px solid #222; padding-top:16px; margin-top:0; }
#reserver .stepContent::-webkit-scrollbar { width:5px; }
#reserver .stepContent::-webkit-scrollbar-track { background:transparent; }
#reserver .stepContent::-webkit-scrollbar-thumb { background:#333; border-radius:3px; }
.openResa #reserver2 { margin-top:30px; opacity:1; transition:all 350ms ease-out 200ms; }
#reserver #steps:before { content: ""; position: absolute; top: 50%; left: 10px; right: 10px; height: 2px; background: #333333; z-index: -1; margin-top: -1px; } #reserver #steps { position: relative; display: table; margin-left: auto; margin-right: auto; }
#reserver h1 { margin:0; color:#fff; font-family: 'Hoefler Text', serif; font-size:20px; flex-shrink:0; }
#reserver h2 { margin:0 0 30px; color:#cacaca; font-family: 'Cormorant', serif; font-size:15px; flex-shrink:0; }
#reserver #steps { margin:0 0 44px; flex-shrink:0; }
#reserver #steps:before { content: ""; position: absolute; top: 50%; left: 10px; right: 10px; height: 2px; background: #333333; z-index: -1; margin-top: -1px; } #reserver #steps { position: relative; display: table; margin-left: auto; margin-right: auto; }
#reserver #steps span { display:inline-block;background:#333;color:#ccc;font-size:16px;font-weight:bold;width:25px;height:25px;line-height:25px;border-radius:50%;margin:0 9px; }
#reserver #steps span.one { background:#0502f6;color:#fff;cursor:pointer; }
#reserver #steps.two span.two { background:#0502f6;color:#fff;cursor:pointer; }
#reserver #steps.three span.two,#reserver #steps.three span.three { background:#0502f6;color:#fff;cursor:pointer; }
#reserver #steps.four span.two,#reserver #steps.four span.three,#reserver #steps.four span.four { background:#0502f6;color:#fff;cursor:pointer; }
/* V2 avec 5 étapes */
#reserver #steps.five span.two,#reserver #steps.five span.three,#reserver #steps.five span.four,#reserver #steps.five span.five { background:#0502f6;color:#fff;cursor:pointer; }
#reserver #steps.steps5 span { margin:0 6px; }
/* V3 avec 2 étapes */
#reserver #steps.steps2 span { margin:0 9px; }
/* V3 avec 3 étapes */
#reserver #steps.steps3 span { margin:0 9px; }
#reserver input, #reserver textarea { padding:0 30px; height:100px; background:#000;color:#fff; border:1px solid #333; border-radius:20px; text-align:center; font-size:30px; color:#fff; font-family: 'Manrope', sans-serif; width:520px; outline:none; margin:20px 0 35px; font-weight:bold; }
#reserver input[type=checkbox] { width: 20px; height: 20px; margin: 0; }
#reserver textarea { height:276px; padding:30px; resize:none; text-align:left; }
::placeholder { color:#666666 }
#nbBureau { margin-bottom:92px; }
#nbBureau input { width:290px; height:102px; margin:20px 32px 0; font-weight:bold; font-size:45px; color:#fff; vertical-align:top; pointer-events:none; }
#nbBureau .moins, #nbBureau .plus { width:82px; height:82px; line-height:82px; border-radius:50%; background:#141414; color:#fff; font-size:45px; display:inline-block; user-select:none; cursor:pointer; vertical-align:top; margin:23px 0 0; }
#nbBureau .moins.disable, #nbBureau .plus.disable { opacity:0.1; pointer-events:none; }
@media(hover: hover) and (pointer: fine) {
  #nbBureau .moins:hover, #nbBureau .plus:hover { background:#0000ff; }
}
#reserver .btn { width:100%; }
#step4 .btn { background:#0000f6 }
#step4 img { margin:30px auto 40px; }

.btnPack { display:block;background:#111;color:#fff;padding:12px 16px;margin:10px 0;border-radius:8px;cursor:pointer;border:1px solid #444;transition:background 0.3s; }
.btnPack:hover { background:#222; }
.btnPack input { margin-right:8px; }
.detailMatos { background:#1e1e1e;padding:10px 20px;margin:0 0 10px;border-left:3px solid #0000f5;font-size:0.9em; }
.detailMatos label { display:block;margin-bottom:6px; }
#optionsMatos { position:relative; max-height: 54vh; overflow: auto; }
#optionsMatos .btnPack { position:relative;padding:16px 120px 16px 60px;background:#111;border:1px solid #444;border-radius:8px;margin:10px 0;cursor:pointer;color:#fff;font-size:16px;display:flex;align-items:center;font-weight:normal;transition:background 0.3s;gap:20px;}
#optionsMatos .btnPack:hover { background:#1a1a1a; }
#optionsMatos input[type="radio"] { position:absolute;left:-9999px; }
#optionsMatos .btnPack::before { content:"";position:absolute;left:15px;top:50%;transform:translateY(-50%);width:30px;height:30px;background:#333;border-radius:50%;transition:background 0.3s; }
#optionsMatos .btnPack.select::before { background:#0000f6; }
#optionsMatos .btnPack.select::after { content: "✓"; font-size: 18px; color: #fff; position: absolute; left: 31px; top: 50%; transform: translate(-50%, -50%) scale(1); transition: transform 0.2s ease-in-out; width: 28px; text-align: center; }
#optionsMatos .btnPack:not(.select)::after { transform:scale(0); }
#optionsMatos .prix { font-size:0.9em;color:#ccc; }
#optionsMatos .prix .old { text-decoration:line-through;color:#777;margin-right:6px; }
#optionsMatos .prix:before { content: ' — '; margin-right: 20px; }
#optionsMatos .btnPack .flc { position: absolute; right: 20px; top: 50%; transform: translateY(-50%); }
#optionsMatos .btnPack .flc:after { content: "détail >"; font-size: 12px; }
#optionsMatos .btnPack.select .flc:after { content: ''; }

#reserver .detailMatos { text-align:left;font-size:13px; }
#reserver input.carteCheck { width:20px;height:20px;margin:0 10px 0 0; }

/* V1 : styles date/heure séparés */
#dateHeureRow { display:flex; gap:20px; justify-content:center; margin-bottom:0; }
#dateArrivee, #heureArrivee { text-align:center; }
#dateArrivee input, #heureArrivee select { width:150px; height:70px; margin:20px 0 35px; }
#dateArrivee input { width:250px; }
#heureArrivee select { background:#000; color:#fff; border:1px solid #333; border-radius:20px; text-align:center; font-size:22px; font-family:'Manrope',sans-serif; font-weight:bold; cursor:pointer; appearance:none; -webkit-appearance:none; padding:0 20px; }

#tarifHoraire { margin:0 0 30px; font-size:12px; font-style:italic; min-height:50px; }
#tarifHoraire a.btnAppliquerHeure { display:inline-block; background:#0502f6; color:#fff !important; padding:8px 18px; border-radius:20px; text-decoration:none; cursor:pointer; font-size:12px; font-weight:bold; transition:all 200ms ease; margin-top:10px; }
#tarifHoraire a.btnAppliquerHeure:hover { background:#3d3aff; transform:scale(1.05); }

/* V1 : ajustement nbBureau */
#step1 #nbBureau { margin-bottom:12px; }

/* V2 : styles multi-jours */
#joursOnglets { display:flex; justify-content:center; gap:0; margin-bottom:0; flex-wrap:wrap; align-items:flex-end; }
#joursOnglets .jourTab { background:#1a1a1a; color:#999; padding:10px 14px 12px; border-radius:12px 12px 0 0; font-size:13px; cursor:pointer; position:relative; text-align:center; min-width:70px; border:2px solid #333; border-bottom:none; margin:0 2px; }
#joursOnglets .jourTab.active { background:#0a0a0a; color:#fff; border-color:#444; z-index:2; }
#joursOnglets .jourTab .jourNum { display:inline-block; font-weight:bold; font-size:14px; }
#joursOnglets .jourTab .jourDate { display:block; font-size:12px; color:#666; margin-top:1px; }
#joursOnglets .jourTab .jourHeures { display:inline-block; font-size:14px; margin:0 0 0 5px; background:#fff; color:#000 !important; border-radius:13px; width:22px; height:22px; line-height:22px; font-size:12px; text-align:center; }
#joursOnglets .jourTab.active .jourDate { color:#888; }
#joursOnglets .jourTab .removeJour { display:none; position:absolute; top:-6px; right:-6px; background:#ff4444; color:#fff; width:18px; height:18px; line-height:16px; border-radius:50%; font-size:12px; text-align:center; }
#joursOnglets .jourTab:hover .removeJour { display:block; }
#joursOnglets .jourTabAdd { background:#1a1a1a; color:#666; padding:10px 14px 12px; border-radius:12px; font-size:12px; cursor:pointer; border:2px dashed #333; margin:0 2px 12px 11px; }
#joursOnglets .jourTabAdd:hover { border-color:#0502f6; color:#0502f6; }
#joursOnglets .jourTabAdd.hidden { display:none; }

#joursContainers { background:#0a0a0a; border:2px solid #444; border-radius:16px; padding:25px 20px 55px; margin-bottom:30px; position:relative; }
#joursContainers #nbBureau { margin-bottom:12px; }

#totalEncart { position:absolute; bottom:-22px; left:50%; transform:translateX(-50%); background:#fff; border-radius:30px; padding:12px 25px; box-shadow:0 4px 20px rgba(0,0,0,0.4); z-index:10; display:inline-flex; align-items:center; gap:20px; white-space:nowrap; }
#totalEncart .totalNbJours { font-size:22px; font-weight:bold; color:#000; }
#totalEncart .totalSep { color:#ccc; font-size:20px; }
#totalEncart .totalPrix { font-size:22px; font-weight:bold; color:#0502f6; }
#totalEncart .totalLabel { display:block; font-size:10px; color:#999; text-transform:uppercase; margin-top:2px; }

.jourAvertissement { text-align:center; font-size:13px; margin:0; min-height:50px; }
.jourAvertissement .erreur { color:#ff6666; display:block; margin-bottom:0; }
.jourAvertissement .btnAppliquerHeure { display:inline-block; background:#0502f6; color:#fff; padding:8px 18px; border-radius:20px; text-decoration:none; cursor:pointer; font-size:12px; font-weight:bold; transition:all 200ms ease; position:relative; top:-10px; }
.jourAvertissement .btnAppliquerHeure:hover { background:#3d3aff; transform:scale(1.05); }

#horairesInfo { text-align:center; font-size:13px; color:#888; margin:75px 0 15px; }
#horairesInfo strong { color:#fff; }

.jourContainer { display:none; }
.jourContainer.active { display:block; }

/* V2 : styles step2 — packFilters style matosChoice */
#packFilters { position:relative; display:grid; grid-template-columns:repeat(5, 1fr); gap:12px; padding:18px 14px; margin:30px 0 0; border:1px solid #444; border-radius:20px; }
#packFilters .pfBack { position:absolute; background:#0000fe; width:20%; top:8px; left:8px; bottom:8px; z-index:0; border-radius:14px; box-shadow:0 0 20px 6px rgba(0,0,246,0.5); transition:all 350ms ease-out; }
.packFilter { position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; justify-content:flex-start; color:#fff; font-size:11px; cursor:pointer; transition:all 350ms ease-out; opacity:0.5; text-align:center; padding:4px 2px; }
.packFilter:hover { opacity:0.8; }
.packFilter.select { opacity:1; }
.packFilter .pfIco { width:28px; height:28px; display:block; margin:0 auto 4px; transition:all 350ms ease-out; }
.packFilter .packName { display:block; font-size:13px; font-weight:bold; margin:0 0 2px; white-space:nowrap; }
.packFilter .packLine { display:block; font-size:10px; color:rgba(255,255,255,0.7); white-space:nowrap; }
.packFilter .pfOld { text-decoration:line-through; opacity:0.6; margin-right:2px; }
@media (max-width: 1000px) {
  /* Wrapper : porte la bordure et contient les dégradés à l'intérieur */
  #packFiltersWrap { position:relative; margin:10px 0 0; border:1px solid #444; border-radius:14px; overflow:hidden; }
  #packFiltersWrap::before, #packFiltersWrap::after {
    content:""; position:absolute; top:0; bottom:0; width:74px; z-index:2; pointer-events:none; transition:opacity 0.3s;
  }
  #packFiltersWrap::before { left:0; background:linear-gradient(to right, #1a1a1a, transparent); }
  #packFiltersWrap::after  { right:0; background:linear-gradient(to left, #1a1a1a, transparent); }
  #packFiltersWrap.scroll-start::before { opacity:0; }
  #packFiltersWrap.scroll-end::after { opacity:0; }
  /* Filtres : plus de bordure ici, c'est le wrapper qui la porte */
  #packFilters { display:flex; gap:0; padding:10px 6px; border:none; border-radius:0; overflow-x:auto; -webkit-overflow-scrolling:touch; margin:0; scrollbar-width:none; -ms-overflow-style:none; }
  #packFilters::-webkit-scrollbar { display:none; }
  #packFilters .pfBack { display:none; }
  .packFilter { flex:0 0 40%; min-width:0; padding:8px 12px; border-radius:10px; opacity:0.5; box-sizing:border-box; }
  .packFilter.select { opacity:1; background:#0000fe; box-shadow:0 0 15px 4px rgba(0,0,246,0.4); }
  .packFilter .packName { font-size:11px; }
  .packFilter .packLine { font-size:9px; }
  .packFilter .pfIco { width:22px; height:22px; }
}

#packPromoInfo { text-align:center; font-size:12px; color:#4CAF50; margin:5px 0; min-height:20px; }

#matosListe { background:#111; border-radius:12px; padding:10px; max-height:300px; overflow-y:auto; }
.matosItem { display:flex; align-items:center; padding:10px 12px; border-radius:8px; margin:4px 0; cursor:pointer; transition:all 150ms ease; }
.matosItem:hover { background:#222; }
.matosItem.inclus { background:#0a0a0a; cursor:default; opacity:1; }
.matosItem.checked { background:#1a2a1a; }
.matosItem input[type="checkbox"] { width:18px; height:18px; margin-right:12px; accent-color:#0502f6; cursor:pointer; }
.matosItem .matosNom { flex:1; font-size:13px; color:#ddd; }
.matosItem .matosPrix { font-size:12px; color:#888; font-weight:bold; }
.matosItem.checked .matosPrix { color:#4CAF50; }
.matosItem.inclus .matosPrix { color:#888; font-style:italic; font-size:11px; }


.flatpickr-calendar { padding:15px !important; }
.flatpickr-time .numInputWrapper { height:30px !important; top:5px !important; }
.numInputWrapper span { opacity:1 !important; background:none !important; border:none !important; width:10px !important; right:4px !important; padding:0 0 0 1px !important; }
.flatpickr-time input { height: 100% !important; margin: 0 !important; top: -5px !important; width:40px !important; padding-right:13px !important; }
.flatpickr-time .flatpickr-time-separator { margin-left:0 !important; }
.numInputWrapper span:hover { background:none !important; }
.flatpickr-time .numInputWrapper span.arrowUp:after {
  border-bottom-color: #6f6f6f !important;
}
.flatpickr-time .numInputWrapper span.arrowDown:after {
  border-top-color: #6f6f6f !important;
}
flatpickr-time .numInputWrapper span.arrowUp:hover:after,
flatpickr-time .numInputWrapper span.arrowDown:hover:after {
  border-bottom-color: #1502f6 !important;
}
.numInputWrapper span.arrowUp {
  border-bottom: 1px solid #ccc !important;
}
.flatpickr-time.time24hr .numInputWrapper:first-child .arrowUp, .flatpickr-time.time24hr .numInputWrapper:first-child .arrowDown {
  display: none !important;
}
.flatpickr-time.time24hr .numInputWrapper:first-child input {
  padding-right: 0 !important;
  width: 30px !important;
}




#footer { background:#1c1c1c; color:#fff; text-align:center; margin:115px 0 0; }
#footer2 { max-width:1500px; width:90%; margin:0 auto; padding:65px 0 80px; }
#footer h1 { font-size:30px; font-family: 'Hoefler Text', serif;}
#footer h2 { font-size:25px; font-family: 'Hoefler Text', serif; color:#7d7d7d; margin:-10px 0 0 50px; }
#footer3 { margin:75px 0; color:#808080; font-weight:100 }
#footer3 a { color:#808080; text-decoration:none; margin:0 30px; }
@media(hover: hover) and (pointer: fine) {
  #footer3 a:hover { color:#fff }
}

#footer4, #footer5, #footer6 { text-align:center; color:#808080; margin:0 0 50px; }
#footer5 a { color:#d3d3d3; text-decoration:none; }
@media(hover: hover) and (pointer: fine) {
  #footer5 a:hover { color:#fff }
}

#footer6 svg { height:42px }
#footer6 path { fill:#fff }



@media (max-width:1900px){

  #header h2, #header h2 a { padding-top: 5px; }
  #menu a { font-size:18px; margin:0 0 0 34px; }
  #menu a.btn { line-height:65px; font-size:17px; }
  .btn, a.btn { font-size:25px; padding:0 80px; line-height:80px; }

  #accueil2 { padding:95px 0 130px; }
  #accueil3 { max-width:760px; padding:30px 50px 40px; border-radius:40px; }
  #accueil2 .new { padding:0 25px; }
  #accueil3 h1 { font-size:44px; }
  #accueil3 .btn { font-size:26px; padding:0 90px; line-height:80px; }

  #espaces0 .left, #espaces0 .right { width:90px; height:90px; top:340px; }
  #espaces .espace .progress { margin:32px 0 30px; }
  #espaces .espace h2 { font-size:40px; margin:0 0 30px; }

  #equipe h2 { font-size:45px; }
  #equipe2 .equipe { margin:0 52px; }
  #equipe .btn { padding:0 145px;font-size:28px; line-height:90px; }
  #equipe2 .equipe .img { width:170px; height:170px; margin:0 0 24px; }

  .separe { margin:120px auto; }

  #proximite h2 { font-size:46px; margin:0 0 20px; }
  #proximite p { margin:0 0 60px; }
  #proximite2 .enseigne { margin:0 15px; width:260px; height:240px; padding:20px 0 0; font-size:16px; }
  #proximite2 .enseigne .img { width:60px; }


  #tarifs .tarif { width:590px; padding:35px 40px 35px; margin:0 50px; }
  #tarifs .tarif .img { margin:0 auto 35px; }
  #tarifs .tarif h2 { font-size:44px; margin:0 0 20px; }
  #tarifs .choice { margin:0 0 30px; }
  #tarifs .price { font-size:47px; }
  #tarifs .list { margin:30px 0; font-size:23px; }
  #tarifs p { font-size:21px; margin:28px 0 0; }

  #footer h1 { font-size:20px; }
  #footer h2 { font-size:25px; margin:0px 0 0 100px; }

}
@media (max-width:1500px){

  body { font-size:14px; }
  #topBar { font-size:15px; }

  #header { padding:15px 40px 20px; }
  #menu { right:40px; }
  #menu a { font-size:16px; margin:0 0 0 20px; }
  #menu a.btn { font-size:15px; line-height:50px; padding:0 21px }

  #accueil2 .new { margin:0 0 15px; }
  #accueil3 { max-width:650px; padding:30px 40px 30px; }
  #accueil3 h1 { font-size:40px; }
  #accueil3 .btn { font-size:24px; padding:0 70px; line-height:70px; }

  #espaces { padding:100px 0 0; }
  #espaces .espace h2 { font-size:30px; margin:0 0 20px; }
  #espaces0 .left, #espaces0 .right { top:280px; }
  #espaces0 .left { left:25px; }
  #espaces0 .right { right:25px; }

  #equipe h2 { font-size:35px; }
  #equipe .btn { padding:0 105px; font-size:24px; line-height:80px; }

  #proximite h2 { font-size:38px; }
  #proximite2 .enseigne { width:230px;font-size:15px; }
  #proximite2 .enseigne .img { width:60px; height:90px; }

  #tarifs .tarif { width:400px; margin:0 30px; padding:25px 20px 25px; }
  #tarifs .tarif h2 { font-size:34px; }
  #tarifs .tarif .img { width:90%; }
  #tarifs .choice { margin:0 0 20px; height:56px; line-height:56px; }
  #tarifs .choice .left, #tarifs .choice .right { font-size:15px; }
  #tarifs .price { font-size:36px; }
  #tarifs .price .sup { font-size:18px;margin-top:-25px; }
  #tarifs .list { font-size:16px; margin:25px 0; }
  #tarifs .list .check { margin:0 10px 0 0; }
  #tarifs .btn { font-size:20px; padding:0 40px; line-height:60px; }
  #tarifs p { font-size:15px; }
  #tarifs p em { font-size:14px; }

  #footer2 { padding:45px 0 60px; }
  #footer h1 { font-size:20px; }
  #footer h2 { font-size:27px; }
  #footer3 { margin:45px 0; }
  #footer3 a { margin:0 20px; }
  #footer4, #footer5, #footer6 { margin:0 0 40px; }
  #footer6 { margin:0; }
  #footer6 svg { height:32px; }
} 
/* ─── Petit écran en hauteur (laptop 13-14", desktop fenêtre réduite) ─── */
@media (max-height:990px) and (min-width:1001px) {
  #reserver .close { top:20px; width:55px; height:55px; font-size:26px; line-height:57px; }
  #reserver2 { padding:25px 35px; border-radius:40px; }
  .openResa #reserver2 { margin-top:10px; }
  #reserver h1 { font-size:17px; }
  #reserver h2 { margin:0 0 12px; font-size:13px; }
  #reserver #steps { margin:0 0 14px; }
  #reserver #steps span { width:22px; height:22px; line-height:22px; font-size:14px; margin:0 7px; }
  #reserver input, #reserver textarea { height:65px; font-size:22px; margin:10px 0 16px; border-radius:16px; }
  #reserver textarea { height:160px; }
  #nbBureau { margin-bottom:30px; }
  #nbBureau input { height:65px; font-size:32px; margin:10px 20px 0; }
  #nbBureau .moins, #nbBureau .plus { width:56px; height:56px; line-height:56px; font-size:32px; margin:12px 0 0; }
  #reserver .footerBar { padding-top:10px; }
  /* Pack filters */
  #packFilters { margin:15px 0 0; padding:12px 10px; gap:8px; border-radius:16px; }
  .packFilter { padding:2px 2px; }
  .packFilter .pfIco { width:22px; height:22px; margin:0 auto 2px; }
  .packFilter .packName { font-size:11px; }
  .packFilter .packLine { font-size:9px; }
  #packPromoInfo { margin:3px 0; font-size:11px; }
}
@media (max-width:1000px){

  .sectionTitle { font-size:36px; margin:0 auto 30px; }

  /* Flatpickr : centré en modale sur mobile */
  .flatpickr-calendar { position:fixed !important; top:50% !important; left:50% !important; right:auto !important; bottom:auto !important; transform:translate(-50%,-50%) !important; width:90vw !important; max-width:360px !important; z-index:99998 !important; }
  .flatpickr-calendar .dayContainer { width:100%; min-width:100%; max-width:100%; }
  .flatpickr-calendar .flatpickr-days { width:100%; }
  .flatpickr-calendar .flatpickr-day { max-width:none; height:44px; line-height:44px; }

  #topBar { display:none; }
  #header { padding:12px 15px; text-align:left; position:fixed; top:0; left:0; right:0; z-index:10; background:transparent; display:flex; align-items:center; justify-content:space-between; transition:background 300ms ease; }
  #header.scrolled { background:rgba(0,0,0,0.35); }
  #header h1 { font-size:18px; }
  #header h2 { display:none; }
  #menu { margin:0; position:static; top:auto; transform:none; right:auto; text-align:right; background:none; padding:0; }
  #menu a { margin:0; display:none; }
  #menu a.btn { display:inline-block; font-size:13px; line-height:38px; padding:0 18px; border-radius:20px; box-shadow:none; }

  #accueil { overflow:hidden; }
  #accueil video { transform:translateX(-50%); left:50%; width:160%; min-height: auto; }
  #accueil2 { padding:240px 0 0px; }
  #accueil3 { margin:0 auto; width:100%; padding:30px 30px 35px; border-radius:25px; }
  #accueil3 h1 { font-size:28px; margin:0 0 20px; }
  #accueil3 .btn { font-size:18px; padding:0 27px; line-height:60px; }

  #espaces { padding:60px 6vw 0; touch-action:pan-y; }
  #espaces .espace { width:84vw; margin:0 1vw;padding:16px; }
  #espaces .espace .img { border-radius:20px; }
  #espaces .espace .progress { margin:22px 0 20px; }
  #espaces .espace h2 { font-size:21px; margin:0 0 10px; }
  #espaces .espace p { font-size:13px; }
  #espaces0 .left, #espaces0 .right { width:40px; height:40px; top:110px; background-size: 65%; display:none; }
  #espaces0 .left { left:15px; }
  #espaces0 .right { right:15px; }
  #espaces:before, #espaces:after { display:none;}

  .separe { margin:80px auto; }
  #services .service { width:100%; margin:0 0 20px; padding:25px 15px; font-size:14px; }
  #services .service svg { width:48px; height:40px;margin-right:20px; }
  #services .service strong { font-size:16px; }


  /* ─── Packs : scroll horizontal mobile ─── */
  #matosChoiceWrap { position:relative; width:90%; margin:0 auto; overflow:hidden; border:1px solid #666; border-radius:20px; }
  #matosChoiceWrap::before, #matosChoiceWrap::after { content:""; position:absolute; top:0; bottom:0; width:74px; z-index:3; pointer-events:none; transition:opacity 0.3s; }
  #matosChoiceWrap::before { left:0; background:linear-gradient(to right, #000, transparent); }
  #matosChoiceWrap::after { right:0; background:linear-gradient(to left, #000, transparent); }
  #matosChoiceWrap.scroll-start::before { opacity:0; }
  #matosChoiceWrap.scroll-end::after { opacity:0; }
  #matosChoice { display:flex; flex-direction:row; overflow-x:auto; overflow-y:hidden; -webkit-overflow-scrolling:touch; gap:12px; padding:16px 20px; margin:0; border-radius:0; width:100%; border:none; grid-template-columns:none; scrollbar-width:none; -ms-overflow-style:none; }
  #matosChoice::-webkit-scrollbar { display:none; }
  #matosChoice .back { border-radius:14px; box-shadow:0 0 18px 5px #0000fea3; }
  #matosChoice .txt { flex:0 0 auto; min-width:100px; }
  #matosChoice strong { font-size:12px; white-space:nowrap; }
  #matosChoice .txt .line { font-size:9px; white-space:normal; text-align:center; display:block; }

  #matos .service:after { right:10px; width:60px; height:60px; }

  /* ─── Liste matériel : collapse mobile ─── */
  #matos { position:relative; max-height:480px; overflow:hidden; transition:max-height 0.4s ease; }
  #matos.expanded { max-height:none; }
  #matosGradient { display:block; position:relative; height:75px; margin-top:-75px; background:linear-gradient(to bottom, transparent 0%, #000 90%); z-index:2; pointer-events:none; }
  #matos.expanded ~ #matosGradient { display:none; }
  #matosToggle { display:inline-block; text-align:center; margin:15px 0 20px; padding:12px 28px; font-size:13px; font-weight:600; color:#fff; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.2); border-radius:999px; cursor:pointer; position:relative; z-index:3; }

  #matos .service { width:100%; margin:0 0 20px; padding:25px 85px 25px 20px; font-size:14px; }
  #matos .service svg { width:48px; height:40px;margin-right:20px; }
  #matos .service strong { font-size:16px; }

  #equipe h2 { font-size:7vw; }
  #equipe u { margin:0 0 50px; }
  #equipe2 .equipe { margin:0 32px;font-size:22px; }
  #equipe2 .equipe .img { width:130px; height:130px; margin:0 0 13px; }
  #equipe .btn { padding:0 65px; line-height:70px;font-size:21px; }


  #matos .service, #matos .service:after { transition:none }
  #matos .service.unselect { transform:scale(0); margin:0; padding:0; height:0; font-size:0; }
  #matos .service.select { /*order:0;*/ }
  #matos .service.select .prix { font-size:0;background:#1800fe;padding:0 13px;line-height:22px; }
  #matos .service.select .prix:after { content:"Inclus dans le pack";font-size:9px;display:inline-block;line-height:22px; }

  #tarifs .tarif { width:95%; margin:0 auto 30px; padding:18px; border-radius:30px; max-width:360px; }
  #tarifs .list .check { width:27px; height:27px; margin:0 5px 0 0; }

  /* ─── z-index: sheets above header (header is z-index:10) ─── */
  #panierOverlay { z-index:40 !important; }
  #panierLateral { z-index:41 !important; }
  #panierCloseBtn { z-index:42 !important; }

  /* ─── Bottom sheet reservation box ─── */
  #reserver { font-size:14px; z-index:50; }

  /* Close button: fixed above the sheet */
  #reserver .close {
    position:fixed; left:50%; top:8px;
    transform:translateX(-50%); z-index:25;
    width:44px; height:44px; font-size:22px; line-height:46px;
    background:#fff; color:#141414; border:none; border-radius:50%;
    opacity:0; pointer-events:none;
    transition:opacity 200ms ease;
  }
  .openResa #reserver .close {
    opacity:1; pointer-events:auto;
    transition:opacity 200ms ease 250ms;
  }

  /* Sheet: fixed, full height minus close button area */
  #reserver2 {
    position:fixed !important; bottom:0 !important; left:0 !important; right:0 !important;
    top:60px !important;
    transform:translateY(100%) !important; width:100% !important; max-width:100% !important;
    max-height:none !important; height:auto !important;
    border-radius:20px 20px 0 0 !important; padding:20px 20px 0 !important;
    display:flex !important; flex-direction:column !important;
    margin-top:0 !important; opacity:1 !important;
    transition:transform 350ms cubic-bezier(0.32, 0.72, 0, 1) !important;
  }
  .openResa #reserver2 {
    transform:translateY(0) !important; margin-top:0 !important;
    transition:transform 350ms cubic-bezier(0.32, 0.72, 0, 1) 100ms !important;
  }

  /* Header area — flex-shrink:0 so headers never shrink in flex column */
  #reserver h1 { font-size:20px; flex-shrink:0; }
  #reserver h2 { margin:0 0 12px; font-size:14px; flex-shrink:0; }
  #reserver .boxTitle { font-size:22px; flex-shrink:0; }
  #reserver .boxSubtitle { margin:0 0 14px; font-size:14px; flex-shrink:0; }
  #reserver #steps { margin:0 auto 14px; flex-shrink:0; }
  #reserver #steps span { width:26px; height:26px; line-height:26px; font-size:14px; margin:0 8px; }
  #sessionBox { z-index:5; }

  /* FooterBar: fixed at bottom via flex column — content scrolls, footerBar stays */
  #reserver2 { overflow:hidden !important; }
  #reserver #step1,
  #reserver #step2,
  #reserver #step3 {
    flex:1 1 auto; flex-direction:column; min-height:0; overflow:hidden;
  }
  #reserver #step1.stepActive,
  #reserver #step2.stepActive,
  #reserver #step3.stepActive {
    display:flex !important;
  }
  #reserver .stepContent {
    flex:1 1 auto; overflow-y:auto; overflow-x:hidden; -webkit-overflow-scrolling:touch;
    min-height:0; padding-bottom:15px;
  }
  #reserver .footerBar {
    flex-shrink:0; z-index:5; background:#141414; border-top:1px solid #222; padding:16px 0; padding-bottom:max(16px, env(safe-area-inset-bottom)); margin:0;
  }

  #reserver input, #reserver textarea, #reserver select { width:100%; margin:6px 0 12px; font-size:18px; padding:0 14px; height:56px; box-sizing:border-box; }
  #reserver textarea { height:150px; padding:20px; }

  #nbBureau { margin-bottom:15px; }
  #nbBureau .moins, #nbBureau .plus { width:50px; height:50px; line-height:48px; font-size:30px; margin:8px 0 0; }
  #nbBureau input { font-size:32px; width:100px; height:58px; margin:6px 10px 0; }
  #reserver .btn { font-size:16px; padding:0 20px; line-height:52px; }

  /* FooterBar: additional mobile styling */
  #reserver .footerBar {
    align-items:center;
    padding-bottom:max(20px, env(safe-area-inset-bottom));
  }

  /* V1 responsive */
  #dateHeureRow { flex-direction:column; gap:0; margin-bottom:25px; }
  #dateArrivee, #heureArrivee { margin-bottom:20px; }
  #dateArrivee input, #heureArrivee select { width:100%; }
  #tarifHoraire { margin:0 0 12px; font-size:13px; }

  #footer3 a { display:block; margin:20px 0; }

}

/* ─── Petit mobile (≤399px, type iPhone SE) : sheet + fields plus compacts ─── */
@media (max-width:399px) {
  #reserver2 { padding:15px 15px 0 !important; top:50px !important; }
  #reserver .close { top:4px; width:40px; height:40px; font-size:20px; line-height:42px; }
  #reserver .boxTitle { font-size:18px; }
  #reserver .boxSubtitle { margin:0 0 10px; font-size:12px; }
  #reserver #steps { margin:0 auto 10px; }
  #reserver #steps span { width:22px; height:22px; line-height:22px; font-size:12px; margin:0 5px; }
  #reserver input, #reserver select { margin:4px 0 8px; font-size:16px; height:48px; padding:0 12px; }
  #reserver .btn { font-size:14px; padding:0 16px; line-height:46px; }
  #reserver .footerBar { padding:12px 0; padding-bottom:max(16px, env(safe-area-inset-bottom)); }
  #nbBureau .moins, #nbBureau .plus { width:44px; height:44px; line-height:42px; font-size:26px; }
  #nbBureau input { font-size:28px; width:85px; height:50px; }
}

/* ─── Très petits écrans (<380px) ─── */
@media (max-width:380px) {
  #espaces .espace h2 { font-size:17px; margin:0 0 8px; }
  #espaces .espace p { font-size:11px; }
  #espaces .espace { padding:12px; }
  #espaces .espace .progress { margin:14px 0 12px; }
  #accueil3 h1 { font-size:22px; }
  #accueil3 { padding:20px 20px 25px; }
  #accueil3 .btn { font-size:15px; line-height:50px; }
}