*{box-sizing:border-box;margin:0;padding:0}
:root{
  --green:#1E4D3A;--green-light:#2D6B52;--green-pale:#EDF3EF;
  --gold:#B8976A;--gold-light:#E8D5B0;--cream:#FAF8F5;
  --dark:#1A1A1A;--border:rgba(30,77,58,0.12);--text:#2C2C2C;--muted:#7A7A7A
}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:#F5F0EB;color:var(--text);max-width:600px;margin:0 auto;padding:0}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(60px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── NAV ── */
nav{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.75rem;background:#F5F0EB;border-bottom:0.5px solid var(--border);position:sticky;top:0;z-index:100}
.nav-brand{font-family:'Playfair Display',serif;font-size:14px;color:var(--green);letter-spacing:0.06em;font-style:italic}
nav ul{display:flex;gap:1.75rem;list-style:none}
nav ul li a{font-size:10px;text-decoration:none;color:var(--muted);letter-spacing:0.15em;text-transform:uppercase}
nav ul li a:hover{color:var(--green)}

/* ── SPLASH PLEINE PAGE ── */
.splash{
  height:calc(100vh - 38px);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  background:#F5F0EB;
  position:relative;
  padding:2rem;
}
.splash-logo{
  width:280px;max-width:80%;height:auto;
  display:block;
  animation:fadeIn 1.2s ease forwards;
}
.splash-fallback{
  display:none;flex-direction:column;align-items:center;gap:1.25rem;
  animation:fadeIn 1.2s ease forwards;
}
.splash-circle{
  width:140px;height:140px;border-radius:50%;
  background:var(--green);color:var(--gold-light);
  font-family:'Playfair Display',serif;font-size:64px;font-style:italic;
  display:flex;align-items:center;justify-content:center;
}
.splash-name{
  font-family:'Playfair Display',serif;font-size:32px;
  color:var(--green);font-style:italic;letter-spacing:0.04em;
}
.splash-scroll{
  position:absolute;bottom:4rem;left:0;right:0;margin:0 auto;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  cursor:pointer;opacity:.5;transition:opacity .2s;
  animation:fadeIn 2s ease forwards;
}
.splash-scroll:hover{opacity:1}
.splash-scroll span{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--green)}
.scroll-arrow{
  font-size:18px;color:var(--green);
  animation:bounce 2s infinite;
}
@keyframes fadeIn{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* ── HERO CONTENT ── */
.hero-content{
  background:#F5F0EB;
  padding:5rem 2rem 4rem;
  text-align:center;
  border-bottom:0.5px solid var(--border);
}
.eyebrow{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);margin-bottom:.75rem}
.hero-content h1{font-family:'Playfair Display',serif;font-size:32px;line-height:1.25;color:var(--dark);margin-bottom:.5rem}
.hero-content h1 em{color:var(--green);font-style:italic}
.rule{width:36px;height:1px;background:var(--gold);margin:.9rem auto 1.1rem}
.hero-sub{font-size:14px;color:var(--muted);line-height:1.9;max-width:320px;margin:0 auto 2.25rem}
.btn-gold{background:var(--green);color:white;border:none;padding:1rem 2.75rem;font-family:'DM Sans',sans-serif;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;cursor:pointer;display:inline-block;transition:background .25s}
.btn-gold:hover{background:var(--gold)}

/* ── INFO BAND ── */
.infos-section{background:var(--green);padding:2.5rem 1.75rem}
.info-elegant{display:flex;align-items:center;justify-content:center}
.info-elegant-item{flex:1;text-align:center;padding:1rem}
.info-elegant-sep{width:0.5px;height:60px;background:rgba(255,255,255,0.2);flex-shrink:0}
.info-elegant-label{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold-light);margin-bottom:.5rem;opacity:.7}
.info-elegant-value{font-family:'Playfair Display',serif;font-size:16px;color:white;font-style:italic;margin-bottom:.25rem}
.info-elegant-sub{font-size:11px;color:rgba(255,255,255,0.5);letter-spacing:0.05em}

/* ── BOOKING ── */
.booking-wrapper{padding:2.5rem 1.75rem;background:#F5F0EB}
.booking-header{text-align:center;margin-bottom:2.25rem}
.booking-header h2{font-family:'Playfair Display',serif;font-size:22px;color:var(--green);margin-bottom:.35rem}
.booking-header p{font-size:12px;color:var(--muted);line-height:1.7}
.divider{width:36px;height:1px;background:var(--gold);margin:.7rem auto}

/* ── STEPS ── */
.steps{display:flex;align-items:center;justify-content:center;gap:.35rem;margin-bottom:2.25rem}
.step{display:flex;align-items:center;gap:.3rem}
.step-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:500;flex-shrink:0;transition:all .3s}
.step-dot.done{background:var(--gold);color:white}
.step-dot.active{background:var(--green);color:white}
.step-dot.pending{background:transparent;border:0.5px solid var(--border);color:var(--muted)}
.step-label{color:var(--muted);font-size:10px;letter-spacing:0.06em;text-transform:uppercase}
.step-label.active{color:var(--green);font-weight:500}
.step-sep{width:18px;height:0.5px;background:var(--border)}

/* ── SECTION TITLES ── */
.section-title{font-family:'Playfair Display',serif;font-size:17px;color:var(--green);margin-bottom:.2rem}
.section-sub{font-size:11px;color:var(--muted);margin-bottom:1.25rem}

/* ── SERVICES ── */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.service-card{border:0.5px solid var(--border);padding:1.1rem;cursor:pointer;background:#F5F0EB;transition:all .2s}
.service-card:hover,.service-card.active{border-color:var(--green);background:var(--green-pale)}
.service-card.active{box-shadow:inset 0 0 0 1px var(--green)}
.service-icon{font-size:20px;margin-bottom:.5rem}
.service-name{font-size:13px;font-weight:500;color:var(--dark)}
.service-price{font-size:12px;color:var(--gold);margin-top:3px;font-weight:500}
.service-duration{font-size:11px;color:var(--muted);margin-top:2px}

/* ── STYLISTS ── */
.stylists-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.stylist-card{border:0.5px solid var(--border);padding:1.5rem 1rem;cursor:pointer;background:#F5F0EB;text-align:center;transition:all .2s}
.stylist-card:hover,.stylist-card.active{border-color:var(--green);background:var(--green-pale)}
.stylist-avatar{width:56px;height:56px;border-radius:50%;margin:0 auto .75rem;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:22px;font-style:italic}
.av-k{background:var(--green);color:var(--gold-light)}
.av-x{background:var(--green-pale);color:var(--green);border:0.5px solid var(--border)}
.stylist-name{font-size:14px;font-weight:500;color:var(--dark)}
.stylist-spec{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.5}
.stylist-badge{display:inline-block;font-size:10px;padding:3px 10px;margin-top:10px;background:#FFFBF0;color:var(--gold);border:0.5px solid var(--gold-light);letter-spacing:0.05em}

/* ── CALENDAR ── */
.month-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.month-name{font-family:'Playfair Display',serif;font-size:15px;color:var(--green)}
.nav-btn{background:none;border:0.5px solid var(--border);padding:5px 14px;cursor:pointer;font-size:12px;color:var(--muted)}
.nav-btn:hover{border-color:var(--green);color:var(--green)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:1.25rem}
.cal-day-header{text-align:center;font-size:9px;color:var(--muted);letter-spacing:0.08em;text-transform:uppercase;padding:4px 0}
.cal-day{text-align:center;padding:9px 2px;font-size:12px;cursor:pointer;border:0.5px solid transparent;transition:all .15s}
.cal-day:hover:not(.past):not(.empty){background:var(--green-pale);border-color:var(--border)}
.cal-day.past{color:var(--muted);cursor:default;opacity:.3}
.cal-day.selected{background:var(--green);color:white}
.cal-day.today{border-color:var(--gold);color:var(--gold);font-weight:500}

/* ── SLOTS ── */
.slots-title{font-size:13px;font-weight:500;color:var(--green);margin-bottom:.75rem;font-family:'Playfair Display',serif}
.slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.slot{border:0.5px solid var(--border);padding:.65rem;text-align:center;font-size:12px;cursor:pointer;background:#F5F0EB;transition:all .15s}
.slot:hover{border-color:var(--green)}
.slot.taken{background:var(--cream);color:var(--muted);cursor:not-allowed;border-color:transparent}
.slot.selected{background:var(--green);color:white;border-color:var(--green)}
.slot .slot-time{font-weight:500}
.slot .slot-avail{font-size:10px;color:var(--muted);margin-top:1px}
.slot.selected .slot-avail{color:rgba(255,255,255,0.5)}

/* ── RECAP & FORM ── */
.recap{margin:0 0 1.75rem;padding:1.5rem;border:0.5px solid var(--border);background:#F5F0EB;border-left:2px solid var(--green)}
.recap-title{font-family:'Playfair Display',serif;font-size:15px;color:var(--green);margin-bottom:1rem}
.recap-row{display:flex;justify-content:space-between;align-items:flex-start;padding:.5rem 0;border-bottom:0.5px solid var(--border)}
.recap-row:last-child{border-bottom:none}
.recap-label{font-size:12px;color:var(--muted);flex-shrink:0}
.recap-value{font-size:12px;color:var(--dark);font-weight:500;text-align:right;max-width:58%}
.recap-total .recap-label{font-size:13px;font-weight:500;color:var(--dark)}
.recap-total .recap-value{font-family:'Playfair Display',serif;font-size:20px;color:var(--gold)}
.form-title{font-family:'Playfair Display',serif;font-size:17px;color:var(--green);margin-bottom:1rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:9px;color:var(--muted);letter-spacing:0.15em;text-transform:uppercase}
.form-field input{border:0.5px solid var(--border);background:#F5F0EB;padding:.8rem .85rem;font-size:15px;font-family:'DM Sans',sans-serif;color:var(--dark);outline:none;-webkit-appearance:none;width:100%}
.form-field input:focus{border-color:var(--green)}
.form-full{grid-column:1/-1}
.confirm-btn{width:100%;background:var(--green);color:white;border:none;padding:1.15rem;font-family:'DM Sans',sans-serif;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;cursor:pointer;margin-top:.5rem;transition:background .25s}
.confirm-btn:hover:not(:disabled){background:var(--gold)}
.confirm-btn:disabled{opacity:.35;cursor:not-allowed}

/* ── SUCCESS ── */
.success{text-align:center;padding:5rem 1.75rem}
.success-icon{font-size:48px;margin-bottom:1.5rem}
.success h2{font-family:'Playfair Display',serif;font-size:24px;color:var(--green);margin-bottom:.75rem}
.success p{font-size:14px;color:var(--muted);line-height:1.9;max-width:340px;margin:0 auto}
.success-ref{display:inline-block;margin:1.75rem 0;padding:.9rem 2.25rem;background:var(--green);color:var(--gold-light);font-size:11px;letter-spacing:0.12em}

/* ── FOOTER ── */
footer{text-align:center;padding:2rem;border-top:0.5px solid var(--border);font-size:11px;color:var(--muted);letter-spacing:0.08em;background:#F5F0EB}
footer span{color:var(--green);font-weight:500}
.footer-instagram{margin-top:.75rem}
.insta-link{display:inline-flex;align-items:center;gap:.4rem;font-size:11px;color:var(--gold);text-decoration:none;letter-spacing:0.06em;border-bottom:0.5px solid var(--gold-light);padding-bottom:1px;transition:color .2s}
.insta-link:hover{color:var(--green)}

/* ── MOBILE ── */
@media(max-width:480px){
  .splash-logo{width:220px}
  .splash-circle{width:110px;height:110px;font-size:50px}
  .splash-name{font-size:26px}
  .hero-content{padding:3.5rem 1.5rem 3rem}
  .hero-content h1{font-size:26px}
  .booking-wrapper{padding:2rem 1.25rem}
  .infos-section{padding:1.25rem}
  .form-grid{grid-template-columns:1fr}
  .form-full{grid-column:1}
  .step-label{display:none}
}
.services-list{display:flex;flex-direction:column}
.service-row{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1rem;border-bottom:0.5px solid rgba(30,77,58,0.12);cursor:pointer;background:#F5F0EB;transition:all .2s;position:relative}
.service-row:first-child{border-top:0.5px solid rgba(30,77,58,0.12)}
.service-row::after{content:'';position:absolute;left:0;top:0;width:2px;height:100%;background:#B8976A;opacity:0;transition:opacity .2s}
.service-row:hover::after,.service-row.active::after{opacity:1}
.service-row:hover,.service-row.active{background:white}
.service-row-left{display:flex;flex-direction:column;gap:3px}
.service-row-name{font-family:'Playfair Display',serif;font-size:15px;color:#1A1A1A;font-style:italic}
.service-row-duration{font-size:10px;color:#7A7A7A;letter-spacing:0.08em}
.service-row-price{font-size:13px;color:#B8976A;font-weight:500;letter-spacing:0.03em;flex-shrink:0}
.ticker-wrap{background:var(--green);padding:.6rem 0;overflow:hidden;white-space:nowrap;border-top:0.5px solid rgba(255,255,255,0.1);border-bottom:0.5px solid rgba(255,255,255,0.1)}
.ticker{display:inline-block;animation:ticker 20s linear infinite}
.ticker span{font-size:11px;color:var(--gold-light);letter-spacing:0.15em;text-transform:uppercase;padding:0 2.5rem}
.ticker span::before{content:'✦';margin-right:2.5rem;opacity:.5}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.coming-soon-rdv{text-align:center;padding:3rem 1.5rem;border:0.5px solid var(--border);background:white}
.coming-soon-rdv p{font-family:'Playfair Display',serif;font-size:16px;color:var(--green);font-style:italic;margin-bottom:1.25rem;line-height:1.8}
.back-btn{background:none;border:none;color:#7A7A7A;font-size:12px;letter-spacing:0.08em;cursor:pointer;padding:0 0 1.25rem;display:flex;align-items:center;gap:.4rem;font-family:'DM Sans',sans-serif}
.back-btn:hover{color:#1E4D3A}

/* ── LONGUEUR CHEVEUX ── */
.length-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:.5rem}
.length-card{border:0.5px solid var(--border);padding:1.5rem 1rem;cursor:pointer;background:white;text-align:center;transition:all .2s}
.length-card:hover,.length-card.active{border-color:var(--green);background:var(--green-pale)}
.length-card.active{box-shadow:inset 0 0 0 1px var(--green)}
.length-name{font-family:'Playfair Display',serif;font-size:16px;color:var(--dark);font-style:italic;margin-bottom:.4rem}
.length-price{font-size:13px;color:var(--gold);font-weight:500}
