/* =============================================================
   THE FRIEND'S BOX — Styles globaux
   Direction "Polaroid Luxe"
   Couleurs : Bordeaux #B40830, Or #C9A84C, Creme #FAF7F2, Brun #2A2019
   Fonts : Playfair Display, Bebas Neue, Outfit
   ============================================================= */

/* ---- Reset & Base ---- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Outfit',sans-serif;background:#FAF7F2;color:#2A2019;overflow-x:hidden;line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button,input,textarea,select{font-family:inherit;font-size:inherit;border:none;outline:none}
ul,ol{list-style:none}

/* ---- CSS Variables ---- */
:root{
  --bordeaux:#B40830;
  --bordeaux-dark:#8C0625;
  --gold:#C9A84C;
  --gold-light:#E8D49C;
  --cream:#FAF7F2;
  --cream-alt:#F3EDE3;
  --brown:#2A2019;
  --brown-light:#5A4D3E;
  --brown-muted:#8A7D6B;
  --shadow-sm:0 2px 16px rgba(42,32,25,.05);
  --shadow-md:0 8px 32px rgba(42,32,25,.1);
  --shadow-lg:0 20px 60px rgba(42,32,25,.15);
  --radius-sm:6px;
  --radius-md:12px;
  --radius-lg:20px;
  --transition:0.4s cubic-bezier(.16,1,.3,1);
}

/* ---- Skip to content ---- */
.skip-link{position:absolute;top:-100%;left:16px;background:var(--bordeaux);color:#fff;padding:12px 24px;border-radius:0 0 var(--radius-sm) var(--radius-sm);z-index:10000;font-weight:600;transition:.3s}
.skip-link:focus{top:0}

/* ====== ANIMATIONS ====== */
@keyframes fadeUp{from{opacity:0;transform:translateY(60px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(180,8,48,.4)}70%{box-shadow:0 0 0 16px rgba(180,8,48,0)}}
@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* ---- Scroll reveal ---- */
.reveal{opacity:0;transform:translateY(50px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.12s}
.reveal-delay-2{transition-delay:.24s}
.reveal-delay-3{transition-delay:.36s}
.reveal-delay-4{transition-delay:.48s}
.reveal-delay-5{transition-delay:.6s}

/* ====== NAVIGATION ====== */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:16px 48px;background:rgba(250,247,242,.6);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid rgba(180,8,48,.06);transition:all .4s}
.nav.scrolled{padding:10px 48px;background:rgba(250,247,242,.95);box-shadow:0 2px 20px rgba(42,32,25,.08)}
.nav-logo{height:52px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.06));transition:var(--transition)}
.nav.scrolled .nav-logo{height:42px}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;color:var(--brown-light);letter-spacing:1px;transition:.3s;text-transform:uppercase;position:relative;padding:8px 0}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--bordeaux),var(--gold));transition:width .4s cubic-bezier(.16,1,.3,1)}
.nav-links a:hover,.nav-links a.active{color:var(--bordeaux)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:2px;padding:12px 32px;background:linear-gradient(135deg,var(--bordeaux),var(--bordeaux-dark));color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:.4s;text-transform:uppercase}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(180,8,48,.35)}

/* Hamburger menu mobile */
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:1001}
.nav-hamburger span{display:block;width:28px;height:2px;background:var(--brown);transition:.3s}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav overlay */
.nav-mobile{display:none;position:fixed;inset:0;background:rgba(250,247,242,.98);backdrop-filter:blur(20px);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:32px}
.nav-mobile.open{display:flex}
.nav-mobile a{font-family:'Playfair Display',serif;font-size:28px;color:var(--brown);transition:.3s}
.nav-mobile a:hover{color:var(--bordeaux)}

/* ====== HERO ====== */
/* [mobile-audit] 100vh -> 100dvh pour corriger le bug iOS Safari */
.hero{min-height:100dvh;min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:80px}
.hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hero-bg .mesh-1{position:absolute;top:-20%;right:-10%;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(180,8,48,.08) 0%,transparent 60%);filter:blur(80px);animation:float 8s ease-in-out infinite}
.hero-bg .mesh-2{position:absolute;bottom:-30%;left:-15%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.1) 0%,transparent 60%);filter:blur(60px);animation:float 10s ease-in-out 2s infinite reverse}
.hero-bg .mesh-3{position:absolute;top:20%;left:30%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(245,236,215,.6) 0%,transparent 50%);filter:blur(40px);animation:float 12s ease-in-out 4s infinite}
.hero-content{position:relative;width:100%;max-width:1300px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.hero-text{position:relative;z-index:2}
.hero-badge{display:inline-block;font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:4px;color:var(--gold);border:1.5px solid rgba(201,168,76,.4);padding:10px 28px;border-radius:50px;margin-bottom:32px;text-transform:uppercase}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(40px,5.5vw,78px);color:var(--brown);line-height:1.05;margin-bottom:24px;font-weight:800}
.hero h1 em{font-style:italic;color:var(--bordeaux);position:relative;display:inline-block}
.hero h1 em::after{content:'';position:absolute;bottom:6px;left:0;right:0;height:12px;background:rgba(201,168,76,.15);border-radius:4px;z-index:-1}
.hero .subtitle{font-size:18px;color:var(--brown-muted);line-height:1.75;margin-bottom:40px;max-width:500px}
.hero .cta-group{display:flex;gap:16px;flex-wrap:wrap}

/* Polaroid stack hero */
.hero-visual{position:relative;height:500px;perspective:1000px}
.polaroid{position:absolute;background:#fff;padding:10px 10px 40px;box-shadow:0 10px 50px rgba(42,32,25,.12);transition:.6s cubic-bezier(.16,1,.3,1);cursor:pointer}
.polaroid .inner{width:100%;height:100%;background-size:cover!important;background-position:center!important;overflow:hidden;position:relative;border-radius:2px}
.polaroid .inner::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(180,8,48,.06),transparent);opacity:0;transition:.4s}
.polaroid:hover .inner::after{opacity:1}
.polaroid .caption{position:absolute;bottom:10px;left:12px;right:12px;font-family:'Playfair Display',serif;font-size:12px;font-style:italic;color:var(--brown-muted);text-align:center}
.polaroid-1{width:220px;height:260px;top:10%;left:5%;transform:rotate(-8deg);z-index:3}
.polaroid-2{width:200px;height:240px;top:5%;right:10%;transform:rotate(6deg);z-index:2}
.polaroid-3{width:240px;height:280px;bottom:5%;left:25%;transform:rotate(3deg);z-index:4}
.polaroid:hover{transform:rotate(0deg) scale(1.05) translateY(-10px)!important;box-shadow:var(--shadow-lg);z-index:10}

/* ====== BUTTONS ====== */
.btn-primary{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:2px;padding:18px 48px;background:linear-gradient(135deg,var(--bordeaux),var(--bordeaux-dark));color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:.4s;box-shadow:0 8px 32px rgba(180,8,48,.25);position:relative;overflow:hidden;text-transform:uppercase;display:inline-block;text-align:center}
.btn-primary::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);transition:.6s}
.btn-primary:hover::before{left:100%}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(180,8,48,.35)}
.btn-secondary{font-family:'Outfit',sans-serif;font-size:15px;font-weight:500;padding:18px 40px;background:transparent;color:var(--bordeaux);border:2px solid rgba(180,8,48,.25);border-radius:var(--radius-sm);cursor:pointer;transition:.3s;letter-spacing:.5px;display:inline-block;text-align:center}
.btn-secondary:hover{border-color:var(--bordeaux);background:rgba(180,8,48,.04)}
.btn-gold{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:2px;padding:14px 36px;background:linear-gradient(135deg,var(--gold),#B8972E);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:.4s;text-transform:uppercase;display:inline-block}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(201,168,76,.35)}
.btn-white{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:2px;padding:18px 52px;background:#fff;color:var(--bordeaux);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:.4s;box-shadow:0 8px 32px rgba(0,0,0,.2);text-transform:uppercase;display:inline-block}
.btn-white:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 14px 44px rgba(0,0,0,.3)}

/* ====== SECTIONS ====== */
.section{padding:120px 48px;max-width:1240px;margin:0 auto}
.section-full{padding:120px 48px;width:100%}
.section-alt{background:var(--cream-alt);position:relative}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(32px,4vw,52px);color:var(--brown);text-align:center;margin-bottom:16px;font-weight:700}
.section-sub{font-size:17px;color:var(--brown-muted);text-align:center;margin-bottom:64px;max-width:580px;margin-left:auto;margin-right:auto;line-height:1.75}
.gold-line{width:60px;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light),var(--gold));background-size:200% 100%;animation:shimmer 3s linear infinite;margin:0 auto 20px;border-radius:2px}

/* ====== MARQUEE ====== */
.marquee-strip{overflow:hidden;white-space:nowrap;padding:20px 0;position:relative;background:var(--cream-alt)}
.marquee-strip::before,.marquee-strip::after{content:'';position:absolute;top:0;width:100px;height:100%;z-index:2}
.marquee-strip::before{left:0;background:linear-gradient(90deg,var(--cream-alt),transparent)}
.marquee-strip::after{right:0;background:linear-gradient(270deg,var(--cream-alt),transparent)}
.marquee-inner{display:inline-block;animation:marquee 25s linear infinite}
.marquee-inner span{display:inline-block;padding:0 40px;font-family:'Bebas Neue',sans-serif;font-size:clamp(16px,2.2vw,22px);color:var(--gold);letter-spacing:3px;text-transform:uppercase;opacity:.6}
.marquee-inner span::before{content:'\2022';margin-right:40px;opacity:.3}

/* ====== COUNTERS ====== */
.counters{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;padding:80px 48px;max-width:1240px;margin:0 auto;text-align:center}
.counter{padding:32px}
.counter-num{font-family:'Bebas Neue',sans-serif;font-size:clamp(48px,6vw,72px);color:var(--bordeaux);line-height:1;display:block;font-variant-numeric:tabular-nums}
.counter-label{font-size:14px;color:var(--brown-muted);margin-top:8px;text-transform:uppercase;letter-spacing:2px}

/* ====== CARDS (Formules) ====== */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;justify-items:center}
.cards-grid .card{width:100%}
.card{background:#fff;border-radius:var(--radius-md);padding:36px 28px 32px;box-shadow:var(--shadow-sm);position:relative;border:1px solid rgba(42,32,25,.04);overflow:hidden;transition:var(--transition);display:flex;flex-direction:column}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px}
.card:nth-child(1)::before{background:linear-gradient(90deg,var(--bordeaux),#D91D5D)}
.card:nth-child(2)::before{background:linear-gradient(90deg,var(--gold),var(--gold-light))}
.card:nth-child(3)::before{background:linear-gradient(90deg,#D91D5D,#E8457A)}
.card:nth-child(4)::before{background:linear-gradient(90deg,var(--bordeaux),var(--gold))}
.card:nth-child(5)::before{background:linear-gradient(90deg,var(--gold-light),var(--gold))}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.card .badge{position:absolute;top:14px;right:14px;background:linear-gradient(135deg,var(--gold),#B8972E);color:#fff;font-family:'Bebas Neue',sans-serif;font-size:12px;padding:6px 18px;border-radius:50px;letter-spacing:2px;text-transform:uppercase}
.card h3{font-family:'Playfair Display',serif;font-size:24px;color:var(--brown);margin-bottom:6px;font-weight:700}
.card .price{font-family:'Bebas Neue',sans-serif;font-size:42px;color:var(--bordeaux);margin:8px 0 20px;letter-spacing:1px}
.card .price span{font-family:'Outfit',sans-serif;font-size:14px;color:var(--brown-muted);font-weight:400}
.card ul{flex:1}
.card ul li{font-size:14px;color:var(--brown-light);padding:9px 0;border-bottom:1px solid rgba(42,32,25,.05)}
.card ul li::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--gold);margin-right:12px;vertical-align:middle}
.card .card-cta{margin-top:auto;padding-top:24px}
.card .card-cta .btn-primary{font-size:14px;padding:14px 0;width:100%}

/* Card option (lettres LOVE etc.) */
.card.card-option{background:var(--cream-alt);border:2px dashed rgba(180,8,48,.2);opacity:.92}
.card.card-option::before{background:linear-gradient(90deg,var(--gold-light),var(--gold))!important}
.card.card-option:hover{opacity:1}
.card.card-option{padding-top:48px}
.card.card-option .badge-option{background:linear-gradient(135deg,var(--bordeaux),#D91D5D);top:12px;right:12px}
.card.card-option .option-note{font-size:13px;color:var(--bordeaux);font-style:italic;margin:-2px 0 12px;line-height:1.5}
.card.card-option .card-cta .btn-primary{background:transparent;color:var(--bordeaux);border:2px solid var(--bordeaux)}
.card.card-option .card-cta .btn-primary:hover{background:var(--bordeaux);color:#fff}

/* ====== GALLERY ====== */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-item{aspect-ratio:4/3;border-radius:var(--radius-sm);overflow:hidden;background:linear-gradient(135deg,#EDE5D6,#E0D5C2);border:6px solid #fff;box-shadow:0 4px 24px rgba(42,32,25,.08);transition:.5s cubic-bezier(.16,1,.3,1);position:relative;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gallery-item::after{content:'Voir';position:absolute;inset:0;background:linear-gradient(135deg,rgba(180,8,48,.85),rgba(140,6,37,.9));color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:3px;opacity:0;transition:.5s;text-transform:uppercase}
.gallery-item:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-lg)}
.gallery-item:hover::after{opacity:1}
.gallery-item:hover img{transform:scale(1.1)}

/* Watermark overlay */
.gallery-item::before{content:'THE FRIEND\'S BOX';position:absolute;bottom:12px;right:12px;font-family:'Bebas Neue',sans-serif;font-size:11px;color:rgba(255,255,255,.5);letter-spacing:3px;z-index:1;text-transform:uppercase;pointer-events:none}

/* Gallery filters */
.gallery-filters{display:flex;gap:12px;justify-content:center;margin-bottom:48px;flex-wrap:wrap}
.gallery-filter{font-family:'Outfit',sans-serif;font-size:14px;font-weight:500;padding:10px 28px;background:transparent;border:1.5px solid rgba(42,32,25,.1);border-radius:50px;cursor:pointer;transition:.3s;color:var(--brown-light);text-transform:uppercase;letter-spacing:1px}
.gallery-filter:hover,.gallery-filter.active{background:var(--bordeaux);color:#fff;border-color:var(--bordeaux)}

/* ====== LIGHTBOX ====== */
.lightbox{position:fixed;inset:0;background:rgba(42,32,25,.95);z-index:10000;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.lightbox.open{display:flex;opacity:1}
.lightbox-img{max-width:90vw;max-height:85vh;border-radius:var(--radius-sm);box-shadow:0 20px 80px rgba(0,0,0,.5);border:6px solid #fff}
.lightbox-close{position:absolute;top:24px;right:32px;font-size:36px;color:#fff;cursor:pointer;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.1);transition:.3s}
.lightbox-close:hover{background:rgba(180,8,48,.8)}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:32px;color:#fff;cursor:pointer;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.1);transition:.3s}
.lightbox-nav:hover{background:rgba(180,8,48,.6)}
.lightbox-prev{left:24px}
.lightbox-next{right:24px}
.lightbox-caption{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);color:#fff;font-family:'Playfair Display',serif;font-size:16px;font-style:italic;background:rgba(42,32,25,.6);padding:12px 32px;border-radius:50px;white-space:nowrap}

/* ====== TESTIMONIALS ====== */
.testimonials-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.testimonial{background:#fff;padding:44px;border-radius:14px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;border:1px solid rgba(42,32,25,.04);transition:var(--transition)}
.testimonial::before{content:'\201C';position:absolute;top:-5px;left:24px;font-family:'Playfair Display',serif;font-size:120px;color:rgba(201,168,76,.1);line-height:1;pointer-events:none}
.testimonial:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.testimonial .stars{color:var(--gold);font-size:18px;letter-spacing:4px;margin-bottom:16px}
.testimonial p{font-family:'Playfair Display',serif;font-style:italic;font-size:17px;color:var(--brown-light);line-height:1.7;margin-bottom:20px;position:relative}
.testimonial .author{font-family:'Bebas Neue',sans-serif;font-size:14px;color:var(--bordeaux);letter-spacing:2px}
.testimonial .source{font-size:12px;color:var(--brown-muted);margin-top:4px}

/* ====== B2B SECTION ====== */
.b2b{background:linear-gradient(135deg,var(--bordeaux) 0%,#7A0520 50%,var(--bordeaux) 100%);background-size:200% 200%;animation:gradientShift 8s ease infinite;padding:120px 48px;text-align:center;color:#fff;position:relative;overflow:hidden}
.b2b::before{content:'';position:absolute;top:-50%;right:-20%;width:600px;height:600px;border-radius:50%;background:rgba(255,255,255,.04)}
.b2b::after{content:'';position:absolute;bottom:-30%;left:-10%;width:400px;height:400px;border-radius:50%;background:rgba(201,168,76,.08)}
.b2b h2{font-family:'Playfair Display',serif;font-size:clamp(30px,4vw,48px);font-weight:700;margin-bottom:20px;position:relative}
.b2b p{font-size:18px;opacity:.75;max-width:600px;margin:0 auto 40px;line-height:1.75;position:relative}

/* ====== FORMS ====== */
.form-group{margin-bottom:24px}
.form-label{display:block;font-family:'Outfit',sans-serif;font-size:14px;font-weight:500;color:var(--brown);margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}
.form-input,.form-select,.form-textarea{width:100%;padding:16px 20px;background:#fff;border:1.5px solid rgba(42,32,25,.1);border-radius:var(--radius-sm);font-size:15px;color:var(--brown);transition:.3s}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--bordeaux);box-shadow:0 0 0 4px rgba(180,8,48,.08)}
.form-textarea{min-height:140px;resize:vertical}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238A7D6B' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.form-error{color:var(--bordeaux);font-size:13px;margin-top:6px}
.form-success{background:rgba(0,147,69,.08);border:1px solid rgba(0,147,69,.2);color:#009345;padding:20px 28px;border-radius:var(--radius-sm);margin-bottom:24px;font-size:15px;line-height:1.6}
.form-errors-list{background:rgba(180,8,48,.06);border:1px solid rgba(180,8,48,.15);color:var(--bordeaux);padding:20px 28px;border-radius:var(--radius-sm);margin-bottom:24px}
.form-errors-list li{font-size:14px;padding:4px 0}

/* ====== CALENDAR ====== */
.calendar-container{max-width:800px;margin:0 auto}
.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}
.calendar-header h3{font-family:'Playfair Display',serif;font-size:28px;color:var(--brown);font-weight:700}
.calendar-nav{display:flex;gap:12px}
.calendar-nav button{width:44px;height:44px;border-radius:50%;background:#fff;border:1.5px solid rgba(42,32,25,.1);cursor:pointer;font-size:18px;color:var(--brown);transition:.3s;display:flex;align-items:center;justify-content:center}
.calendar-nav button:hover{background:var(--bordeaux);color:#fff;border-color:var(--bordeaux)}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.calendar-day-header{text-align:center;font-family:'Bebas Neue',sans-serif;font-size:14px;color:var(--brown-muted);letter-spacing:2px;padding:12px 0}
.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:15px;font-weight:500;cursor:default;transition:.3s;position:relative}
.calendar-day.empty{background:transparent}
.calendar-day.available{background:rgba(34,197,94,.08);color:#16a34a;border:1px solid rgba(34,197,94,.3)}
.calendar-day.available:hover{background:rgba(34,197,94,.15)}
.calendar-day.reserved{background:rgba(180,8,48,.08);color:var(--bordeaux);border:1px solid rgba(180,8,48,.2);cursor:not-allowed}
.calendar-day.partially-booked{background:rgba(245,158,11,.08);color:#d97706;border:1px solid rgba(245,158,11,.3)}
.calendar-day.fully-booked{background:rgba(180,8,48,.08);color:var(--brown-muted);border:1px solid rgba(180,8,48,.2);cursor:not-allowed}
.calendar-day.blocked{background:rgba(107,114,128,.08);color:var(--brown-muted);border:1px solid rgba(107,114,128,.15);cursor:not-allowed}
.calendar-day.today{font-weight:700;box-shadow:inset 0 0 0 2px var(--gold)}
.calendar-legend{display:flex;gap:24px;justify-content:center;margin-top:32px;flex-wrap:wrap}
.calendar-legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--brown-muted)}
.calendar-legend-item span{width:16px;height:16px;border-radius:4px;display:inline-block}
.dot-available{display:inline-block;width:12px;height:12px;border-radius:50%;background:#22c55e}
.dot-reserved{display:inline-block;width:12px;height:12px;border-radius:50%;background:#B40830}
.dot-blocked{display:inline-block;width:12px;height:12px;border-radius:50%;background:#6b7280}
.dot-partial{display:inline-block;width:12px;height:12px;border-radius:50%;background:#f59e0b}
.calendar-legend-item .dot-available{background:rgba(34,197,94,.2);border:1px solid rgba(34,197,94,.4)}
.calendar-legend-item .dot-partial{background:rgba(245,158,11,.2);border:1px solid rgba(245,158,11,.4)}
.calendar-legend-item .dot-reserved{background:rgba(180,8,48,.2);border:1px solid rgba(180,8,48,.4)}
.calendar-legend-item .dot-blocked{background:rgba(107,114,128,.15);border:1px solid rgba(107,114,128,.3)}
/* Filtre bornes */
.box-filter{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap;justify-content:center}
.box-filter-btn{padding:8px 20px;border-radius:99px;border:2px solid var(--cream-alt);background:#fff;color:var(--brown);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:8px}
.box-filter-btn:hover{border-color:var(--brown-muted)}
.box-filter-btn.active{background:var(--brown);color:#fff;border-color:var(--brown)}
.box-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
/* Pastilles par borne sur les jours */
.day-dots{display:flex;gap:3px;justify-content:center;margin-top:4px}
.day-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* Box cards (visualisation bornes) */
.box-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:28px}
.box-card{display:flex;align-items:center;gap:14px;background:#fff;border-radius:var(--radius-md);padding:12px;border:2px solid rgba(42,32,25,.06);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}
.box-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.box-card.active{border-color:var(--box-color,var(--bordeaux));box-shadow:0 0 0 1px var(--box-color,var(--bordeaux)),var(--shadow-md)}
.box-card-img{width:72px;height:72px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}
.box-card-placeholder{display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Bebas Neue',sans-serif;font-size:28px}
.box-card-info{flex:1;min-width:0}
.box-card-name{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;color:var(--brown);margin:0 0 4px;display:flex;align-items:center;gap:6px}
.box-card-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.box-card-desc{font-size:12px;color:var(--brown-muted);line-height:1.4;margin:0}

/* ====== FAQ / Accordion ====== */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{background:#fff;border-radius:var(--radius-md);margin-bottom:16px;box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid rgba(42,32,25,.04)}
.faq-question{width:100%;padding:24px 32px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-family:'Outfit',sans-serif;font-size:16px;font-weight:600;color:var(--brown);text-align:left;transition:.3s}
.faq-question:hover{color:var(--bordeaux)}
.faq-question .icon{font-size:24px;transition:transform .3s;color:var(--gold);flex-shrink:0;margin-left:16px}
.faq-item.open .faq-question .icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease;padding:0 32px}
.faq-item.open .faq-answer{max-height:500px;padding:0 32px 24px}
.faq-answer p{font-size:15px;color:var(--brown-light);line-height:1.75}

/* ====== PHOTOS PROTEGEES ====== */
.photos-access{max-width:480px;margin:0 auto;text-align:center}
.photos-access .lock-icon{font-size:64px;margin-bottom:24px;opacity:.3}

/* Barre de filtres photos */
.photos-filters-bar{display:flex;gap:10px;justify-content:center;margin-bottom:32px;flex-wrap:wrap}
.photo-filter-btn{font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;padding:8px 24px;background:transparent;border:1.5px solid rgba(42,32,25,.12);border-radius:50px;cursor:pointer;transition:.3s;color:var(--brown-light);text-transform:uppercase;letter-spacing:.5px}
.photo-filter-btn:hover{border-color:var(--bordeaux);color:var(--bordeaux)}
.photo-filter-btn.active{background:var(--bordeaux);color:#fff;border-color:var(--bordeaux)}

/* Grille de photos privées */
.photos-private-gallery{display:block;margin-top:20px}
.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}

/* Carte photo */
.photo-card{position:relative;border-radius:var(--radius-sm,8px);overflow:hidden;background:#fff;border:4px solid #fff;box-shadow:var(--shadow-sm);transition:.4s cubic-bezier(.16,1,.3,1)}
.photo-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.photo-card canvas{width:100%;aspect-ratio:1;object-fit:cover;display:block;cursor:pointer;background:linear-gradient(135deg,#EDE5D6,#E0D5C2)}
.photo-card-actions{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:flex-end;gap:6px;padding:8px 10px;background:linear-gradient(transparent,rgba(42,32,25,.6));opacity:0;transition:.3s}
.photo-card:hover .photo-card-actions{opacity:1}
.photo-dl-btn,.photo-view-btn{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.9);color:var(--brown);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;backdrop-filter:blur(4px)}
.photo-dl-btn:hover{background:var(--bordeaux);color:#fff}
.photo-view-btn:hover{background:var(--bordeaux);color:#fff}

/* Lightbox bottom bar */
.lightbox-bottom-bar{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:16px;background:rgba(42,32,25,.7);padding:10px 24px;border-radius:50px;backdrop-filter:blur(8px)}
.lightbox-dl-btn{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.3s}
.lightbox-dl-btn:hover{background:var(--bordeaux)}

/* Spinner animation */
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.spin{animation:spin 1s linear infinite}

/* ====== FOOTER ====== */
.footer{background:var(--brown);padding:80px 48px 40px;color:rgba(255,255,255,.6)}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:40px;max-width:1240px;margin:0 auto 48px}
.footer-col h4{font-family:'Playfair Display',serif;font-size:18px;color:#fff;margin-bottom:20px;font-weight:600}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,.5);padding:6px 0;transition:.3s}
.footer-col a:hover{color:var(--gold)}
.footer-col p{font-size:14px;line-height:1.75}
.footer-col .footer-logo{height:48px;margin-bottom:16px;filter:brightness(0) invert(1);opacity:.7}
.footer-bottom{text-align:center;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);font-size:13px;max-width:1240px;margin:0 auto}
.footer-bottom a{color:var(--gold);transition:.3s}
.footer-bottom a:hover{color:var(--gold-light)}

/* ====== WHATSAPP FAB ====== */
.whatsapp-fab{position:fixed;bottom:28px;right:28px;z-index:9000;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.35);transition:.4s;cursor:pointer;animation:pulse 2s infinite}
.whatsapp-fab:hover{transform:scale(1.1) translateY(-4px);box-shadow:0 8px 32px rgba(37,211,102,.45);animation:none}
.whatsapp-fab svg{width:28px;height:28px;fill:#fff}

/* Click to call (mobile only) */
.call-fab{position:fixed;bottom:28px;right:96px;z-index:9000;width:56px;height:56px;background:var(--bordeaux);border-radius:50%;display:none;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(180,8,48,.35);transition:.4s;cursor:pointer}
.call-fab:hover{transform:scale(1.1) translateY(-4px)}
.call-fab svg{width:24px;height:24px;fill:#fff}

/* ====== POPUP SAISONNIERE ====== */
.popup-overlay{position:fixed;inset:0;background:rgba(42,32,25,.6);backdrop-filter:blur(8px);z-index:10001;display:none;align-items:center;justify-content:center}
.popup-overlay.open{display:flex}
.popup-box{background:#fff;border-radius:var(--radius-lg);padding:48px;max-width:480px;width:90%;text-align:center;position:relative;box-shadow:0 32px 80px rgba(42,32,25,.2)}
.popup-box .popup-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:rgba(42,32,25,.05);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--brown-muted);transition:.3s;border:none}
.popup-box .popup-close:hover{background:var(--bordeaux);color:#fff}
.popup-box h3{font-family:'Playfair Display',serif;font-size:28px;color:var(--brown);margin-bottom:16px}
.popup-box p{font-size:15px;color:var(--brown-muted);line-height:1.75;margin-bottom:28px}

/* ====== PAGE HEADER (sous-pages) ====== */
.page-header{background:linear-gradient(135deg,var(--brown) 0%,#1a140e 100%);padding:160px 48px 80px;text-align:center;position:relative;overflow:hidden}
.page-header::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--bordeaux),var(--gold),var(--bordeaux))}
.page-header h1{font-family:'Playfair Display',serif;font-size:clamp(36px,5vw,56px);color:#fff;font-weight:800;margin-bottom:16px}
.page-header p{font-size:17px;color:rgba(255,255,255,.5);max-width:500px;margin:0 auto}
.page-header .breadcrumb{margin-top:20px;font-size:13px;color:rgba(255,255,255,.3)}
.page-header .breadcrumb a{color:var(--gold);transition:.3s}
.page-header .breadcrumb a:hover{color:var(--gold-light)}

/* ====== MENTIONS LEGALES ====== */
.legal-content{max-width:800px;margin:0 auto}
.legal-content h2{font-family:'Playfair Display',serif;font-size:24px;color:var(--brown);margin:40px 0 16px;font-weight:700}
.legal-content h3{font-size:18px;color:var(--brown);margin:24px 0 12px;font-weight:600}
.legal-content p{font-size:15px;color:var(--brown-light);line-height:1.75;margin-bottom:16px}
.legal-content ul{padding-left:24px;margin-bottom:16px}
.legal-content ul li{font-size:15px;color:var(--brown-light);line-height:1.75;list-style:disc}

/* ====== GOOGLE MAP ====== */
.map-container{border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-md);border:4px solid #fff}
.map-container iframe{width:100%;height:400px;display:block}

/* ====== RESPONSIVE ====== */
@media(max-width:1024px){
  .hero-content{grid-template-columns:1fr;text-align:center}
  .hero-visual{display:none}
  .hero .subtitle{margin-left:auto;margin-right:auto}
  .hero .cta-group{justify-content:center}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .counters{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .nav{padding:12px 20px}
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .nav-cta{display:none}
  .box-cards{grid-template-columns:1fr}
  .box-card-img{width:56px;height:56px}
  .section,.section-full{padding:80px 20px}
  .cards-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .testimonials-grid{grid-template-columns:1fr}
  .counters{grid-template-columns:repeat(2,1fr);padding:60px 20px}
  .hero{padding:60px 20px;min-height:auto;padding-top:120px}
  .hero-content{padding:0}
  .page-header{padding:140px 20px 60px}
  .b2b{padding:80px 20px}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer{padding:60px 20px 32px}
  .call-fab{display:flex}
  .calendar-day{font-size:13px}
  .box-filter-btn{padding:6px 14px;font-size:12px}
  .day-dot{width:6px;height:6px}
  .photos-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
  .photos-filters-bar{gap:6px}
  .photo-filter-btn{padding:6px 16px;font-size:12px}
  .lightbox-bottom-bar{padding:8px 16px;gap:10px;bottom:16px}

  /* Contact page — inline grid 2 cols -> 1 col (override inline style) */
  .section > div[style*="grid-template-columns"]{grid-template-columns:1fr !important;gap:40px !important}

  /* Hero text sizing mobile */
  .hero h1{font-size:clamp(32px,8vw,48px)}
  .hero .subtitle{font-size:16px}
  .hero-badge{font-size:12px;padding:8px 20px;letter-spacing:3px}

  /* Section titles mobile */
  .section-title{font-size:clamp(26px,6vw,36px)}
  .section-sub{font-size:15px;margin-bottom:40px}

  /* Page header mobile */
  .page-header h1{font-size:clamp(28px,7vw,40px)}
  .page-header p{font-size:15px}

  /* Button sizing mobile */
  .btn-primary{font-size:16px;padding:16px 36px}
  .btn-secondary{font-size:14px;padding:16px 32px}
  .cta-group{flex-direction:column;align-items:stretch}
  .cta-group .btn-primary,.cta-group .btn-secondary{width:100%;text-align:center}

  /* B2B text mobile */
  .b2b h2{font-size:clamp(24px,6vw,36px)}
  .b2b p{font-size:16px}

  /* FABs positioning — prevent overlap on small screens */
  .whatsapp-fab{bottom:24px;right:20px;width:52px;height:52px}
  .whatsapp-fab svg{width:26px;height:26px}
  .call-fab{bottom:24px;right:82px;width:52px;height:52px}
  .call-fab svg{width:22px;height:22px}

  /* Lightbox mobile */
  .lightbox-nav{width:44px;height:44px;font-size:24px}
  .lightbox-prev{left:12px}
  .lightbox-next{right:12px}
  .lightbox-close{top:16px;right:16px}
  .lightbox-caption{font-size:14px;padding:10px 24px;max-width:85vw;white-space:normal;text-align:center}

  /* Calendar mobile */
  .calendar-header h3{font-size:22px}
  .calendar-legend{gap:12px}
  .calendar-legend-item{font-size:12px}

  /* Nav mobile overlay text */
  .nav-mobile a{font-size:24px}

  /* FAQ mobile */
  .faq-question{padding:20px 20px;font-size:15px}
  .faq-answer{padding:0 20px}
  .faq-item.open .faq-answer{padding:0 20px 20px}

  /* Popup mobile */
  .popup-box{padding:32px 24px}
  .popup-box h3{font-size:24px}

  /* Footer text mobile */
  .footer-col h4{font-size:16px;margin-bottom:16px}
  .footer-col p,.footer-col a{font-size:13px}

  /* Map mobile */
  .map-container iframe{height:280px}
}
@media(max-width:480px){
  .gallery-grid{grid-template-columns:1fr}
  .counters{grid-template-columns:1fr}
  .gallery-filters{gap:8px}
  .gallery-filter{padding:8px 20px;font-size:12px}
  .photos-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
  .photo-card{border-width:3px}
  .photo-card-actions{opacity:1;background:linear-gradient(transparent,rgba(42,32,25,.5))}
}

/* ====== PHOTO PLACEHOLDERS ======
   PLACEHOLDER : Ces styles servent de placeholder visuel en attendant les vraies photos.
   Supprimer cette section et les classes .photo-placeholder une fois les images finales intégrées.
*/
.photo-placeholder{
  display:flex;align-items:center;justify-content:center;
  min-height:200px;position:relative;
  border-radius:2px;
}
.photo-placeholder::after{
  content:'';display:block;
  width:48px;height:48px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232A2019'%3E%3Cpath d='M12 15.2a3.2 3.2 0 1 0 0-6.4 3.2 3.2 0 0 0 0 6.4z'/%3E%3Cpath d='M9 2 7.17 4H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2h-3.17L15 2H9zm3 15a5 5 0 1 1 0-10 5 5 0 0 1 0 10z'/%3E%3C/svg%3E") center/contain no-repeat;
  opacity:0.15;
}
/* Variantes de dégradés pour les polaroids du hero */
.photo-placeholder--rose-gold{background:linear-gradient(135deg,#B40830 0%,#C9A84C 100%)}
.photo-placeholder--brun-creme{background:linear-gradient(135deg,#3E2C23 0%,#F5F0E8 100%)}
.photo-placeholder--bordeaux-rose{background:linear-gradient(135deg,#B40830 0%,#E8D5C8 100%)}
/* Variantes de dégradés pour la galerie (index + galerie.html) */
.photo-placeholder--v1{background:linear-gradient(135deg,#E8D5C8 0%,#F5F0E8 100%)}
.photo-placeholder--v2{background:linear-gradient(135deg,#C9A84C 0%,#F5F0E8 100%)}
.photo-placeholder--v3{background:linear-gradient(135deg,#B40830 0%,#C9A84C 100%)}
.photo-placeholder--v4{background:linear-gradient(135deg,#3E2C23 0%,#E8D5C8 100%)}
.photo-placeholder--v5{background:linear-gradient(135deg,#8C0625 0%,#F5F0E8 100%)}
.photo-placeholder--v6{background:linear-gradient(135deg,#C9A84C 0%,#E8D5C8 100%)}
.photo-placeholder--v7{background:linear-gradient(135deg,#5A4D3E 0%,#FAF7F2 100%)}
.photo-placeholder--v8{background:linear-gradient(135deg,#B40830 0%,#FAF7F2 100%)}
.photo-placeholder--v9{background:linear-gradient(135deg,#3E2C23 0%,#C9A84C 100%)}
/* Les placeholders dans la galerie doivent remplir toute la cellule */
.gallery-item .photo-placeholder{width:100%;height:100%;min-height:0;position:absolute;inset:0}

/* ====== PHOTO CATEGORY TABS & SECTIONS (Espace client) ====== */
.photo-category-tabs{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.photo-category-tab{padding:10px 20px;border-radius:999px;border:2px solid var(--brown-muted);background:transparent;color:var(--brown);font-family:'Outfit',sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}
.photo-category-tab.active,.photo-category-tab:hover{background:var(--bordeaux);color:#fff;border-color:var(--bordeaux)}
.photo-category-section{margin-bottom:40px}
.photo-category-section h3{font-family:'Playfair Display',serif;font-size:22px;color:var(--brown);margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--gold)}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
}

/* ====== [mobile-audit] CORRECTIONS MOBILE ====== */

/* [mobile-audit] Focus visible pour accessibilite clavier */
:focus-visible{outline:3px solid var(--bordeaux);outline-offset:2px;border-radius:var(--radius-sm)}

/* [mobile-audit] Touch action sur les boutons pour meilleure reactivite tactile */
.btn-primary,.btn-secondary,.btn-gold,.btn-white,.nav-cta,.nav-hamburger,.gallery-filter,.faq-question,.popup-close,.lightbox-close,.lightbox-nav,.whatsapp-fab,.call-fab,.calendar-nav button,.box-filter-btn,.photo-filter-btn,.photo-category-tab{touch-action:manipulation}

/* [mobile-audit] Font-size inputs >= 16px pour eviter zoom iOS */
.form-input,.form-select,.form-textarea{font-size:16px}

/* [mobile-audit] Safe area insets pour iPhone avec encoche */
.nav{padding-left:max(48px, env(safe-area-inset-left));padding-right:max(48px, env(safe-area-inset-right))}
.footer{padding-bottom:max(40px, env(safe-area-inset-bottom))}
.whatsapp-fab{right:max(28px, env(safe-area-inset-right));bottom:max(28px, env(safe-area-inset-bottom))}
.call-fab{right:max(96px, calc(68px + env(safe-area-inset-right)));bottom:max(28px, env(safe-area-inset-bottom))}

/* [mobile-audit] Zones cliquables min 44px pour footer links */
.footer-col a{min-height:44px;display:flex;align-items:center}

/* [mobile-audit] Checkbox et radio min 44px zone tactile */
input[type="checkbox"],input[type="radio"]{min-width:20px;min-height:20px}

/* [mobile-audit] Hamburger zone tactile agrandie */
.nav-hamburger{min-width:44px;min-height:44px;align-items:center;justify-content:center}

/* [mobile-audit] Corrections responsive safe-area 768px */
@media(max-width:768px){
  .nav{padding-left:max(20px, env(safe-area-inset-left));padding-right:max(20px, env(safe-area-inset-right))}
  .section,.section-full{padding-left:max(20px, env(safe-area-inset-left));padding-right:max(20px, env(safe-area-inset-right))}
  .footer{padding-left:max(20px, env(safe-area-inset-left));padding-right:max(20px, env(safe-area-inset-right))}
}

/* [mobile-audit] Overscroll behavior pour empecher scroll arriere-plan quand menu mobile ouvert */
.nav-mobile.open{overscroll-behavior:contain;-webkit-overflow-scrolling:touch}

/* [mobile-audit] Breakpoint 320px pour tres petits ecrans */
@media(max-width:320px){
  .hero h1{font-size:28px}
  .hero .subtitle{font-size:14px}
  .hero-badge{font-size:11px;padding:6px 16px;letter-spacing:2px}
  .btn-primary{font-size:14px;padding:14px 24px}
  .btn-secondary{font-size:13px;padding:14px 24px}
  .section-title{font-size:24px}
  .section-sub{font-size:14px}
  .page-header h1{font-size:24px}
  .counter-num{font-size:40px}
  .counter-label{font-size:12px;letter-spacing:1px}
  .nav-mobile a{font-size:20px;gap:24px}
  .footer-bottom{font-size:11px}
  .popup-box{padding:24px 16px}
  .popup-box h3{font-size:20px}
  .faq-question{padding:16px;font-size:14px}
  .testimonial{padding:24px}
  .testimonial p{font-size:15px}
  .lightbox-nav{width:40px;height:40px;font-size:20px}
  .lightbox-prev{left:8px}
  .lightbox-next{right:8px}
}

/* [mobile-audit] overscroll-behavior pour lightbox et popup */
.lightbox.open,.popup-overlay.open{overscroll-behavior:contain}

/* [mobile-audit] Largeur max pour images inline et iframes */
iframe{max-width:100%}

/* [mobile-audit] Orientation paysage mobile — ajustements */
@media(max-height:500px) and (orientation:landscape){
  .hero{min-height:auto;padding-top:80px;padding-bottom:40px}
  .page-header{padding-top:100px;padding-bottom:40px}
}
