/* ============================================================
   Delfosse Properties — Login + Espace voyageur
   Hérite de style.css pour variables, typo, boutons.
   ============================================================ */

/* ============== PAGE DE CONNEXION ============== */
.auth-page{background:var(--bg)}
.auth-wrap{
  min-height:100vh;min-height:100dvh;
  display:grid;grid-template-columns:1.05fr 1fr;
}

/* Colonne visuelle gauche */
.auth-visual{
  position:relative;overflow:hidden;background:var(--bg-deep);
}
.auth-visual img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  animation:auth-zoom 18s var(--ease-out) infinite alternate;
}
@keyframes auth-zoom{
  0%{transform:scale(1)}
  100%{transform:scale(1.08)}
}
.auth-visual-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,.15) 40%, rgba(0,0,0,.6) 100%);
}
.auth-visual-meta{
  position:absolute;top:40px;left:40px;z-index:2;color:rgba(255,255,255,.85);
  display:flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:.26em;text-transform:uppercase;font-weight:500;
}
.auth-visual-meta .rec{
  width:8px;height:8px;border-radius:50%;background:#ff3b30;
  box-shadow:0 0 0 2px rgba(255,59,48,.25);
  animation:rec-blink 2s ease-in-out infinite;
}
.auth-visual-quote{
  position:absolute;left:40px;right:40px;bottom:44px;z-index:2;color:#fff;
}
.auth-visual-quote p{
  font-family:var(--f-serif);font-weight:300;font-style:italic;
  font-size:clamp(22px, 2.2vw, 30px);line-height:1.3;letter-spacing:-.01em;
  margin:0 0 12px;max-width:520px;text-shadow:0 2px 24px rgba(0,0,0,.4);
}
.auth-visual-quote cite{
  font-style:normal;font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(255,255,255,.8);font-weight:500;
}

/* Colonne formulaire droite */
.auth-panel{
  display:grid;grid-template-rows:auto 1fr auto;
  padding:32px clamp(28px, 5vw, 72px);
  position:relative;
}
.brand-auth{align-self:start}
.brand-auth .brand-mono{font-size:26px}
.brand-auth .brand-sub{font-size:10px;letter-spacing:.44em}

.auth-card{
  align-self:center;max-width:460px;width:100%;margin:0 auto;
  padding:var(--s-4) 0;
}
.auth-card .h-display{margin-top:var(--s-1);margin-bottom:var(--s-3)}
.auth-card .lede{margin-bottom:var(--s-5)}

.auth-form{display:grid;gap:var(--s-3)}
.auth-form label{
  display:grid;gap:8px;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-muted);font-weight:500;
}
.auth-form input{
  font:inherit;color:var(--ink);
  background:transparent;border:0;border-bottom:1px solid var(--line);
  padding:12px 0;outline:none;font-size:16px;text-transform:none;letter-spacing:0;
  transition:border-color var(--t-med) var(--ease);
  min-height:46px;
}
.auth-form input:focus{border-color:var(--accent)}
.auth-form input:focus-visible{outline:none;border-color:var(--accent)}

.pw-wrap{position:relative}
.pw-toggle{
  position:absolute;right:0;bottom:8px;
  width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink-muted);transition:color var(--t-med) var(--ease);
}
.pw-toggle:hover{color:var(--ink)}

.auth-submit{justify-self:start;margin-top:var(--s-3)}

.auth-err{
  min-height:20px;font-size:13px;color:#b42318;letter-spacing:.02em;
  font-weight:500;
}
.auth-help{font-size:13px;color:var(--ink-muted);margin:var(--s-2) 0 0}
.auth-help a{border-bottom:1px solid var(--line);color:var(--ink)}
.auth-help a:hover{border-bottom-color:var(--ink)}

.auth-hint{
  margin-top:var(--s-5);padding:var(--s-3);
  border:1px solid var(--line);background:var(--bg-alt);
  font-size:13px;
}
.auth-hint summary{cursor:pointer;font-weight:500;letter-spacing:.02em;color:var(--ink-soft)}
.auth-hint ul{margin:var(--s-2) 0 0;padding-left:var(--s-3);list-style:disc}
.auth-hint li{margin:4px 0;color:var(--ink-soft)}
.auth-hint code{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  background:var(--bg);padding:2px 6px;font-size:12px;color:var(--ink);
  border:1px solid var(--line);
}

.auth-foot{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-size:12px;color:var(--ink-muted);letter-spacing:.06em;
  padding-top:var(--s-3);border-top:1px solid var(--line);
}
.auth-foot a:hover{color:var(--ink)}

/* Animation shake sur erreur */
.auth-form.is-shaking{animation:shake .48s var(--ease)}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  20%,60%{transform:translateX(-6px)}
  40%,80%{transform:translateX(6px)}
}

/* Transition de sortie */
body.is-leaving{opacity:0;transition:opacity .32s var(--ease)}

/* ============== ESPACE VOYAGEUR ============== */
.espace-page{background:var(--bg)}
.espace-page .site-header{position:sticky;top:0}

/* User chip */
.user-chip{
  display:inline-flex;align-items:center;padding:8px 14px;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  color:var(--ink-soft);border:1px solid var(--line);background:var(--bg);
  min-height:36px;
}
.logout-btn{font-size:11px;padding:10px 18px}

/* Banner personnalisé */
.espace-banner{
  position:relative;min-height:72vh;overflow:hidden;isolation:isolate;
  display:flex;align-items:flex-end;color:#fff;
  padding:clamp(60px, 8vw, 120px) var(--gutter) clamp(56px, 7vw, 96px);
  margin-top:-1px;
}
.espace-banner img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-1;
  animation:auth-zoom 22s var(--ease-out) infinite alternate;
}
.espace-banner-overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg, rgba(0,0,0,.4) 0%, rgba(0,0,0,.15) 40%, rgba(0,0,0,.75) 100%);
}
.espace-banner-content{max-width:var(--container);margin:0 auto;width:100%}
.espace-banner .display{margin-bottom:var(--s-3);font-size:clamp(48px, 8vw, 110px)}
.espace-banner .lede{max-width:58ch}

/* Sections génériques */
.espace-section{padding:clamp(80px, 10vw, 140px) var(--gutter)}
.espace-section.dark{background:var(--bg-deep);max-width:none;color:var(--bg);border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.espace-section.dark .section-head,.espace-section.dark .access-grid{max-width:var(--container);margin-left:auto;margin-right:auto}
.espace-section.dark .eyebrow-num{color:var(--accent)}
.espace-section.alt{background:var(--bg-alt);max-width:none;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.espace-section.alt .section-head,.espace-section.alt .extras-list,.espace-section.alt .btn-link{max-width:var(--container);margin-left:auto;margin-right:auto}
.espace-section.alt .btn-link{display:inline-block;margin-top:var(--s-4)}

/* Info grid — mon séjour */
.info-grid{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(210px, 1fr));
  gap:0;border-top:1px solid var(--line);
}
.info-cell{
  padding:var(--s-4) var(--s-3) var(--s-4) 0;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  display:grid;gap:6px;align-content:start;
  transition:background var(--t-med) var(--ease);
}
.info-cell:hover{background:rgba(164,113,72,.04)}
.info-cell:last-child{border-right:0}
.info-cell.highlight{background:var(--bg-alt)}
.info-cell.highlight strong{color:var(--accent-dk)}
.info-label{
  font-family:var(--f-sans);font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink-muted);font-weight:500;
}
.info-cell strong{
  font-family:var(--f-serif);font-weight:400;
  font-size:clamp(22px, 2.4vw, 30px);line-height:1.1;letter-spacing:-.015em;
  color:var(--ink);
}
.info-sub{font-size:13px;color:var(--ink-muted);letter-spacing:.02em}

/* ============== ARRIVÉE — Visionneuse photos + carte itinéraire ============== */
.arrival-grid{
  max-width:var(--container);margin:0 auto 40px;
  display:grid;grid-template-columns:1fr 1fr;gap:var(--s-4);
  padding:0;
}
@media (max-width: 820px){
  .arrival-grid{grid-template-columns:1fr;gap:24px}
}
.arrival-photos,
.arrival-map{
  background:rgba(10,22,40,.42);
  border:1px solid rgba(201,169,97,.22);
  overflow:hidden;
  display:flex;flex-direction:column;
}

/* Header commun */
.apv-head, .apm-head{
  padding:20px 24px 18px;
  border-bottom:1px solid rgba(245,237,224,.08);
}
.apv-eyebrow, .apm-eyebrow{
  font-family:var(--f-sans);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(245,237,224,.55);display:block;margin-bottom:6px;font-weight:500;
}
.apv-head h3, .apm-head h3{
  font-family:var(--f-serif);font-weight:400;font-style:italic;
  font-size:clamp(22px, 2vw, 26px);color:#F5EDE0;margin:0;
}

/* ---------- COVERFLOW 3D PHOTOS D'ARRIVÉE ---------- */
.arrival-coverflow{
  position:relative;
  padding:0 0 16px;
  background:#0A1628;
  isolation:isolate;
  flex:1 1 auto;
}
.arrival-coverflow .cf-track{
  width:100%;
  height:clamp(340px, 48vh, 480px);
  perspective:1800px;
  perspective-origin:50% 45%;
  position:relative;
}
.arrival-coverflow .cf-stage{
  position:absolute;inset:0;
  transform-style:preserve-3d;
}
.arrival-cf-card{
  position:absolute;left:50%;top:50%;
  height:clamp(300px, 42vh, 420px);
  width:clamp(220px, 60%, 320px);
  border-radius:10px;
  overflow:hidden;cursor:pointer;
  background:#0d1b30;
  border:1px solid rgba(245,237,224,.18);
  box-shadow:0 24px 60px -30px rgba(0,0,0,.55);
  opacity:0;
  transform:translate(-50%, -50%) translate3d(0,0,-80px) scale(.7);
  transition:
    transform 900ms cubic-bezier(.22,1,.36,1),
    opacity   700ms cubic-bezier(.22,1,.36,1),
    box-shadow 600ms cubic-bezier(.22,1,.36,1);
  user-select:none;-webkit-user-select:none;
  -webkit-user-drag:none;-webkit-touch-callout:none;
  backface-visibility:hidden;-webkit-backface-visibility:hidden;
}
.arrival-cf-card.is-current{
  box-shadow:
    0 50px 110px -30px rgba(0,0,0,.7),
    0 0 0 1px rgba(201,169,97,.28);
}
.arrival-cf-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  pointer-events:none;
}
/* Voile dégradé bas pour lisibilité caption */
.arrival-cf-card::after{
  content:"";position:absolute;inset:auto 0 0 0;height:50%;z-index:2;
  pointer-events:none;
  background:linear-gradient(to top,
    rgba(10,22,40,.92) 0%,
    rgba(10,22,40,.4)  55%,
    transparent 100%);
}
.arrival-cf-caption{
  position:absolute;inset:auto 0 0 0;z-index:3;
  padding:16px 18px 20px;
  color:#F5EDE0;
  text-shadow:0 2px 10px rgba(0,0,0,.5);
  pointer-events:none;
  display:flex;flex-direction:column;gap:4px;
}
.arrival-cf-caption .cap-fr{
  font-family:var(--f-serif);font-style:italic;font-weight:400;
  font-size:14px;line-height:1.35;color:#F5EDE0;
}
.arrival-cf-caption .cap-en{
  font-family:var(--f-sans);font-weight:400;
  font-size:11px;letter-spacing:.04em;line-height:1.4;
  color:rgba(245,237,224,.7);
  text-transform:none;
}
/* Icône "voir en grand" sur carte active */
.arrival-cf-zoom{
  position:absolute;top:12px;right:12px;z-index:4;
  width:34px;height:34px;border-radius:50%;
  background:rgba(10,22,40,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(245,237,224,.3);
  color:#F5EDE0;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:scale(.85);
  transition:opacity .4s var(--ease), transform .4s var(--ease), background .3s var(--ease);
  pointer-events:none;
}
.arrival-cf-card.is-current .arrival-cf-zoom{
  opacity:.95;transform:scale(1);
}
.arrival-cf-card.is-current:hover .arrival-cf-zoom{
  background:var(--accent);color:#0A1628;border-color:var(--accent);
}

/* Contrôles (compteur, dots, flèches) */
.arrival-coverflow .cf-controls{
  margin-top:clamp(18px, 3vw, 28px);
  padding:0 clamp(16px, 3vw, 28px);
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.arrival-coverflow .cf-counter{
  font-family:var(--f-serif);font-weight:300;color:#F5EDE0;
  display:inline-flex;align-items:baseline;gap:8px;
}
.arrival-coverflow .cf-counter #arrivalCfCur{
  font-style:italic;font-size:clamp(30px, 3vw, 42px);line-height:1;
}
.arrival-coverflow .cf-sep{font-size:18px;color:rgba(201,169,97,.5);font-style:normal}
.arrival-coverflow .cf-tot{
  font-family:var(--f-sans);font-size:11px;letter-spacing:.25em;
  color:rgba(245,237,224,.55);
}
.arrival-coverflow .cf-dots{
  display:flex;align-items:center;gap:6px;flex:1 1 auto;justify-content:center;flex-wrap:wrap;
}
.arrival-coverflow .cf-dot{
  width:18px;height:2px;border:0;padding:0;
  background:rgba(245,237,224,.3);cursor:pointer;
  transition:width .5s var(--ease-cine), background .5s var(--ease-cine);
}
.arrival-coverflow .cf-dot.is-active{width:42px;background:#F5EDE0}
.arrival-coverflow .cf-arrows{display:inline-flex;gap:8px}
.arrival-coverflow .cf-arrow{
  width:38px;height:38px;border-radius:50%;
  background:transparent;color:#F5EDE0;
  border:1px solid rgba(245,237,224,.35);
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.arrival-coverflow .cf-arrow:hover{background:#F5EDE0;color:#0A1628;border-color:#F5EDE0}

@media (max-width: 820px){
  .arrival-coverflow .cf-track{height:clamp(320px, 50vh, 420px)}
  .arrival-cf-card{
    height:clamp(280px, 44vh, 380px);
    width:clamp(220px, 72%, 320px);
  }
}

.apv-empty{
  padding:60px 30px;text-align:center;color:rgba(245,237,224,.65);
  display:none;flex-direction:column;align-items:center;gap:12px;
}
.apv-empty-icon{font-size:32px;opacity:.5}
.apv-empty p{margin:0;font-size:13px;letter-spacing:.1em;max-width:32ch;line-height:1.5}

/* ============== LIGHTBOX PHOTOS D'ARRIVÉE ============== */
.arrival-lightbox{
  position:fixed;inset:0;z-index:1000;
  background:rgba(6,14,28,.94);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  display:flex;align-items:center;justify-content:center;
  padding:clamp(16px, 4vw, 60px);
  opacity:0;pointer-events:none;
  transition:opacity .4s var(--ease-cine);
}
.arrival-lightbox.is-open{opacity:1;pointer-events:auto}
.arrival-lightbox[aria-hidden="true"]{visibility:hidden}
.arrival-lightbox.is-open[aria-hidden="false"]{visibility:visible}

.alb-stage{
  width:min(1100px, 92vw);
  height:min(80vh, 760px);
  background-position:center;background-size:contain;background-repeat:no-repeat;
  user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;
}
.alb-caption{
  position:absolute;bottom:clamp(30px, 5vw, 70px);left:0;right:0;
  padding:0 clamp(60px, 8vw, 120px);
  text-align:center;
  color:#F5EDE0;
  pointer-events:none;
}
.alb-caption-fr{
  font-family:var(--f-serif);font-style:italic;font-weight:400;
  font-size:clamp(18px, 2vw, 26px);line-height:1.3;
  margin:0 0 8px;color:#F5EDE0;
  text-shadow:0 2px 14px rgba(0,0,0,.55);
}
.alb-caption-en{
  font-family:var(--f-sans);font-weight:400;
  font-size:clamp(12px, 1.1vw, 14px);
  letter-spacing:.04em;line-height:1.4;
  color:rgba(245,237,224,.72);
  margin:0;text-shadow:0 2px 10px rgba(0,0,0,.4);
}
.alb-close{
  position:absolute;top:clamp(16px, 2.5vw, 32px);right:clamp(16px, 2.5vw, 32px);
  z-index:3;
  width:44px;height:44px;border-radius:50%;
  background:rgba(10,22,40,.6);
  border:1px solid rgba(245,237,224,.3);color:#F5EDE0;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:background .3s var(--ease), border-color .3s var(--ease);
}
.alb-close:hover{background:var(--accent);color:#0A1628;border-color:var(--accent)}
.alb-nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:48px;height:48px;border-radius:50%;
  background:rgba(10,22,40,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(245,237,224,.3);color:#F5EDE0;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:background .3s var(--ease), border-color .3s var(--ease);
}
.alb-nav:hover{background:var(--accent);color:#0A1628;border-color:var(--accent)}
.alb-prev{left:clamp(12px, 3vw, 40px)}
.alb-next{right:clamp(12px, 3vw, 40px)}
.alb-counter{
  position:absolute;top:clamp(16px, 2.5vw, 32px);left:50%;transform:translateX(-50%);
  z-index:3;
  font-family:var(--f-sans);font-size:12px;letter-spacing:.28em;
  color:rgba(245,237,224,.85);text-transform:uppercase;font-weight:500;
}
@media (max-width: 640px){
  .alb-stage{height:min(70vh, 560px)}
  .alb-caption{padding:0 clamp(50px, 12vw, 80px)}
  .alb-caption-fr{font-size:16px}
  .alb-caption-en{font-size:11px}
}

/* ---------- CARTE ITINÉRAIRE ---------- */
.apm-route{
  display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap;
  font-family:var(--f-sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(245,237,224,.8);font-weight:500;
}
.apm-step{display:inline-flex;align-items:center;gap:8px}
.pin{
  width:20px;height:20px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:600;font-size:10px;font-family:var(--f-sans);letter-spacing:0;
  flex-shrink:0;
}
.pin-a{background:var(--accent);color:#0A1628}
.pin-b{background:#1EC770;color:#fff}
.apm-dash{
  color:rgba(245,237,224,.35);letter-spacing:0;font-size:12px;user-select:none;
}
.apm-canvas{
  height:360px;width:100%;
  background:#0A1628;
  flex:1 1 auto;
}
.apm-canvas .leaflet-tile-pane{filter:saturate(.78) brightness(.92)}
@media (max-width: 820px){
  .apm-canvas{height:300px}
  .apv-viewer{aspect-ratio:3/2}
}
/* Markers personnalisés */
.apm-marker{
  background:transparent;border:0;
}
.apm-marker-dot{
  width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-sans);font-weight:600;font-size:12px;color:#fff;
  box-shadow:0 6px 20px -4px rgba(0,0,0,.5), 0 0 0 3px rgba(10,22,40,.95);
}
.apm-marker-dot.is-a{background:var(--accent)}
.apm-marker-dot.is-b{background:#1EC770}

/* ============== Access grid (code + wifi — gardé) ============== */
.access-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--s-4);
}
/* Variante 3 colonnes (boîte + laverie + wifi) */
.access-grid--3{
  grid-template-columns:repeat(3, 1fr);
}
@media (max-width: 1024px){
  .access-grid--3{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .access-grid,
  .access-grid--3{grid-template-columns:1fr}
}
.access-card{
  padding:var(--s-5);
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.02);
  color:rgba(255,255,255,.8);
}
.access-card p{font-size:14px;line-height:1.65;margin:var(--s-3) 0 0;max-width:44ch;color:rgba(255,255,255,.6)}
.access-card .hint{color:rgba(255,255,255,.4);font-size:12px;margin-top:var(--s-2)}
.access-label{
  font-family:var(--f-sans);font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--accent);font-weight:500;display:block;margin-bottom:var(--s-3);
}
.big-code{
  font-family:var(--f-serif);font-weight:300;
  font-size:clamp(72px, 8vw, 120px);line-height:1;letter-spacing:.12em;
  color:#fff;font-variant-numeric:tabular-nums;
  padding:var(--s-2) 0;
}
.kv{
  display:flex;justify-content:space-between;align-items:baseline;gap:var(--s-3);
  padding:var(--s-2) 0;border-bottom:1px solid rgba(255,255,255,.08);
}
.kv:last-of-type{border-bottom:0}
.kv span{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.5);font-weight:500;
}
.kv strong{
  font-family:var(--f-serif);font-weight:400;
  font-size:clamp(20px, 2vw, 26px);color:#fff;font-variant-numeric:tabular-nums;
}
.copy-field{cursor:pointer;transition:color var(--t-med) var(--ease)}
.copy-field:hover{color:var(--accent)}

/* Concierge card */
.concierge-card{
  display:grid;grid-template-columns:auto 1fr;gap:var(--s-5);
  align-items:center;padding:var(--s-5);
  border:1px solid var(--line);background:var(--white);
}
.concierge-avatar{
  width:120px;height:120px;border-radius:50%;background:var(--bg-deep);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-serif);font-weight:400;font-size:40px;letter-spacing:.02em;
}
.concierge-body h3{
  font-family:var(--f-serif);font-weight:400;font-size:clamp(26px, 3vw, 38px);
  margin:var(--s-1) 0 8px;letter-spacing:-.015em;
}
.concierge-meta{color:var(--ink-muted);font-size:14px;margin:0 0 var(--s-4)}
.concierge-actions{display:flex;gap:var(--s-3);align-items:center;flex-wrap:wrap}

.eyebrow.small{font-size:10px;margin-bottom:4px}

/* Extras list */
.extras-list{display:grid;gap:0;border-top:1px solid var(--line);margin:0;padding:0}
.extra-row{
  display:flex;justify-content:space-between;gap:var(--s-3);align-items:baseline;
  padding:var(--s-3) 0;border-bottom:1px solid var(--line);
  transition:padding var(--t-med) var(--ease);
}
.extra-row:hover{padding-left:var(--s-2)}
.extra-label{
  font-family:var(--f-serif);font-weight:400;font-size:20px;letter-spacing:-.01em;
}
.extra-status{
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent-dk);font-weight:500;
}

/* Footer espace */
.espace-foot{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding:var(--s-4) var(--gutter);
  font-size:12px;color:var(--ink-muted);letter-spacing:.06em;
  border-top:1px solid var(--line);background:var(--bg);
}
.espace-foot a:hover{color:var(--ink)}

/* Toast */
.toast{
  position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--bg-deep);color:var(--bg);
  padding:12px 22px;font-size:13px;letter-spacing:.08em;
  border:1px solid rgba(255,255,255,.12);
  opacity:0;pointer-events:none;z-index:100;
  transition:opacity var(--t-med) var(--ease), transform var(--t-med) var(--ease);
}
.toast.in{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============== RESPONSIVE ============== */
@media (max-width: 960px){
  .auth-wrap{grid-template-columns:1fr}
  .auth-visual{min-height:240px;max-height:300px}
  .auth-panel{padding:24px var(--gutter)}
  .access-grid{grid-template-columns:1fr}
  .concierge-card{grid-template-columns:1fr;text-align:center}
  .concierge-actions{justify-content:center}
  .info-cell{border-right:0}
  .user-chip{display:none}
}
@media (max-width: 520px){
  .auth-visual-quote p{font-size:18px}
  .big-code{font-size:64px}
  .extra-row{flex-direction:column;gap:6px;align-items:flex-start}
}

/* ============================================================
   GUIDE / WIFI / INVENTAIRE — nouvelles sections espace
   ============================================================ */

/* ---------- GUIDE (PDF viewer + download) ---------- */
.guide-intro{
  font-family:var(--f-serif);font-style:italic;font-weight:300;
  font-size:clamp(16px, 1.2vw, 20px);line-height:1.6;
  color:var(--ink-soft);max-width:58ch;margin-top:var(--s-3);
}
.guide-viewer{
  max-width:var(--container);margin:0 auto;
  background:var(--bg-alt);
  border:1px solid var(--line);
  border-radius:10px;overflow:hidden;
  box-shadow:0 20px 50px -30px rgba(10,10,10,.25);
}
.guide-head{
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;
  gap:var(--s-3);padding:clamp(18px, 2.4vw, 28px) clamp(20px, 3vw, 36px);
  border-bottom:1px solid var(--line-soft);
  background:var(--bg);
}
.guide-meta{display:flex;flex-direction:column;gap:4px}
.guide-meta-label{
  font-family:var(--f-sans);font-size:10px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--ink-muted);
}
.guide-meta strong{
  font-family:var(--f-serif);font-style:italic;font-weight:400;
  font-size:22px;color:var(--ink);letter-spacing:-.01em;
}
.guide-meta-sub{font-size:12px;color:var(--ink-muted);letter-spacing:.04em}
.guide-download{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;
  background:var(--ink);color:var(--bg);
  border:1px solid var(--ink);border-radius:2px;
  font-family:var(--f-sans);font-weight:500;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;
  transition:background 400ms var(--ease-out), color 400ms var(--ease-out);
}
.guide-download:hover{background:var(--accent);color:var(--ink);border-color:var(--accent)}
.guide-iframe{
  display:block;width:100%;height:clamp(520px, 80vh, 920px);
  border:0;background:#2a2a2a;
}
/* PDF.js viewer : pages rendues en canvas, empilement vertical scrollable */
.guide-pdfjs{
  position:relative;
  background:#2a2a2a;
  min-height:clamp(480px, 70vh, 780px);
  max-height:clamp(720px, 90vh, 1200px);
  overflow-y:auto;
  overflow-x:hidden;
  padding:20px;
  scrollbar-color: rgba(201,169,97,.4) transparent;
  scrollbar-width:thin;
}
.guide-pdfjs::-webkit-scrollbar{width:10px}
.guide-pdfjs::-webkit-scrollbar-track{background:transparent}
.guide-pdfjs::-webkit-scrollbar-thumb{background:rgba(201,169,97,.4);border-radius:10px}
.guide-pdf-pages{
  display:flex;flex-direction:column;align-items:center;gap:20px;
}
.guide-pdf-canvas{
  display:block;
  max-width:100%;height:auto;
  background:#fff;
  box-shadow:0 10px 30px -10px rgba(0,0,0,.4);
  border-radius:2px;
}
.guide-pdf-loading,
.guide-pdf-error{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  color:var(--bg);
  font-family:var(--f-sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
}
.guide-pdf-error p{max-width:32ch;text-align:center;line-height:1.6;letter-spacing:.04em;text-transform:none;font-size:14px;color:rgba(245,237,224,.85)}
.guide-pdf-error .btn-primary{padding:14px 22px;letter-spacing:.22em}
.guide-pdf-spinner{
  display:inline-block;width:32px;height:32px;
  border:2px solid rgba(245,237,224,.25);
  border-top-color:var(--accent);
  border-radius:50%;
  animation:guide-spin 900ms linear infinite;
}
@keyframes guide-spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion: reduce){
  .guide-pdf-spinner{animation:none}
}
@media (max-width: 820px){
  .guide-head{padding:16px 20px;flex-direction:column;align-items:flex-start;gap:14px}
  .guide-download{width:100%;justify-content:center}
  .guide-iframe{height:70vh;min-height:480px}
  .guide-pdfjs{padding:12px;max-height:70vh}
  .guide-pdf-pages{gap:12px}
}

/* ---------- WIFI ---------- */
.wifi-grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:var(--s-5);
  max-width:var(--container);margin:0 auto;align-items:start;
}
.wifi-card{
  background:rgba(245,237,224,.06);
  border:1px solid var(--gold-20);
  border-radius:10px;
  padding:clamp(24px, 3vw, 40px);
  color:var(--bg);
}
.wifi-label{
  display:block;
  font-family:var(--f-sans);font-weight:500;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(245,237,224,.65);margin-bottom:12px;
}
.wifi-field{
  display:flex;align-items:baseline;justify-content:space-between;gap:16px;
  padding-bottom:20px;margin-bottom:24px;
  border-bottom:1px solid var(--gold-20);
}
.wifi-field:last-of-type{margin-bottom:32px}
.wifi-value{
  display:block;
  font-family:var(--f-mono);font-weight:400;
  font-size:clamp(22px, 2.8vw, 32px);
  letter-spacing:.02em;color:var(--bg);
  word-break:break-all;
  font-variant-numeric:tabular-nums;
}
.wifi-copy{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;
  background:transparent;
  border:1px solid var(--gold-30);border-radius:999px;
  color:rgba(245,237,224,.85);
  font-family:var(--f-sans);font-weight:500;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  cursor:pointer;flex-shrink:0;
  transition:background 400ms var(--ease-out), border-color 400ms var(--ease-out), color 400ms var(--ease-out);
}
.wifi-copy:hover{background:rgba(201,169,97,.15);border-color:var(--accent);color:var(--accent-lt)}
.wifi-copy.is-copied{background:var(--accent);border-color:var(--accent);color:var(--ink)}
.wifi-steps h4{
  font-family:var(--f-sans);font-weight:500;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent-lt);margin:0 0 14px;
}
.wifi-steps ol{
  list-style:none;counter-reset:step;margin:0;padding:0;
  display:flex;flex-direction:column;gap:10px;
}
.wifi-steps ol li{
  counter-increment:step;
  position:relative;padding-left:34px;
  font-family:var(--f-serif);font-style:italic;
  font-size:15px;line-height:1.5;
  color:rgba(245,237,224,.85);
}
.wifi-steps ol li::before{
  content:counter(step);
  position:absolute;left:0;top:2px;
  width:22px;height:22px;border-radius:50%;
  border:1px solid var(--accent);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--f-sans);font-style:normal;font-weight:500;font-size:11px;
  color:var(--accent-lt);
}
.wifi-qr-card{
  background:var(--bg);
  border:1px solid var(--gold-30);
  border-radius:10px;padding:24px;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  box-shadow:var(--shadow-lev);
}
.wifi-qr{
  width:240px;height:240px;
  display:flex;align-items:center;justify-content:center;
  background:#fff;border-radius:6px;overflow:hidden;
}
.wifi-qr img{width:100%;height:100%;display:block}
.wifi-qr-placeholder{
  font-family:var(--f-mono);font-size:11px;color:var(--ink-muted);
  letter-spacing:.18em;text-transform:uppercase;
}
.wifi-qr-caption{
  font-family:var(--f-sans);font-weight:500;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-muted);margin:0;
}
.wifi-help{
  max-width:var(--container);margin:var(--s-5) auto 0;
  padding:24px 0 0;border-top:1px solid var(--gold-20);
}
.wifi-help h4{
  font-family:var(--f-sans);font-weight:500;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent-lt);margin:0 0 14px;
}
.wifi-help ul{
  margin:0;padding:0;list-style:none;
  display:grid;grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:12px 24px;
}
.wifi-help li{
  font-size:14px;line-height:1.55;color:rgba(245,237,224,.75);
  padding-left:18px;position:relative;
}
.wifi-help li::before{content:"·";color:var(--accent);position:absolute;left:4px;top:-2px;font-size:18px}

@media (max-width: 820px){
  .wifi-grid{grid-template-columns:1fr;gap:20px}
  .wifi-qr{width:200px;height:200px}
  .wifi-field{flex-direction:column;align-items:flex-start;gap:10px}
  .wifi-copy{align-self:flex-end}
}

/* ---------- INVENTAIRE ---------- */
.inv-intro{
  font-family:var(--f-serif);font-style:italic;font-weight:300;
  font-size:clamp(15px, 1.1vw, 18px);color:var(--ink-soft);
  max-width:58ch;margin-top:var(--s-3);
}
.inv-rooms{
  max-width:var(--container);margin:0 auto;
  display:flex;flex-direction:column;
  border-top:1px solid var(--line);
}
.inv-room{
  border-bottom:1px solid var(--line-soft);
  transition:background 400ms var(--ease-out);
}
.inv-room[open]{background:rgba(201,169,97,.04)}
.inv-room summary{
  display:flex;align-items:center;gap:16px;
  padding:22px 0;cursor:pointer;list-style:none;user-select:none;
}
.inv-room summary::-webkit-details-marker{display:none}
.inv-room-label{
  font-family:var(--f-serif);font-weight:300;font-style:italic;
  font-size:clamp(22px, 2.2vw, 32px);letter-spacing:-.01em;color:var(--ink);
}
.inv-room-count{
  font-family:var(--f-sans);font-size:12px;letter-spacing:.12em;
  color:var(--ink-muted);flex:1;
}
.inv-chev{color:var(--accent);transition:transform 400ms var(--ease-out)}
.inv-room[open] .inv-chev{transform:rotate(180deg)}
.inv-list{
  list-style:none;margin:0;padding:0 0 24px;
  display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:10px 32px;
}
.inv-list li{
  display:flex;align-items:baseline;gap:14px;
  padding:10px 0;border-bottom:1px solid var(--line-soft);
  font-size:15px;color:var(--ink);line-height:1.5;
}
.inv-q{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;
  color:var(--accent);flex:0 0 auto;min-width:48px;
  padding:3px 8px;border-radius:3px;
  background:rgba(201,169,97,.1);text-align:center;
}
.inv-footer{
  max-width:var(--container);margin:var(--s-5) auto 0;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding-top:24px;border-top:1px solid var(--line);flex-wrap:wrap;
}
.inv-footer .btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;font-size:12px;letter-spacing:.22em;
}
.inv-note{
  font-family:var(--f-serif);font-style:italic;
  font-size:15px;color:var(--ink-soft);margin:0;max-width:40ch;
}
.inv-note em{color:var(--accent-dk)}

@media (max-width: 820px){
  .inv-list{grid-template-columns:1fr}
  .inv-footer{flex-direction:column;align-items:flex-start}
}

/* Toast feedback clipboard */
.toast-feedback{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(40px);
  padding:14px 28px;
  background:var(--accent);color:var(--ink);
  font-family:var(--f-sans);font-weight:500;
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;
  border-radius:999px;
  box-shadow:0 20px 40px -15px rgba(0,0,0,.4);
  z-index:60;pointer-events:none;opacity:0;
  transition:opacity 400ms var(--ease-out), transform 400ms var(--ease-out);
}
.toast-feedback.is-visible{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============================================================
   CONTACTS (3 interlocuteurs) · RÈGLEMENT · VIDÉOS
   ============================================================ */

/* ---------- CONTACTS ---------- */
.contacts-grid{
  max-width:var(--container);margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:clamp(16px, 2vw, 28px);
}
@media (max-width: 1100px){
  .contacts-grid{grid-template-columns:repeat(auto-fit, minmax(280px, 1fr))}
}
.contact-card{
  display:flex;gap:20px;
  padding:clamp(22px, 2.4vw, 32px);
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:10px;
  transition:transform 500ms var(--ease-out),
             border-color 500ms var(--ease-out),
             box-shadow 500ms var(--ease-out);
}
.contact-card:hover{
  transform:translateY(-4px);
  border-color:var(--accent);
  box-shadow:0 30px 60px -30px rgba(10,10,10,.35);
}
.contact-avatar{
  flex:0 0 auto;
  width:60px;height:60px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--ink);color:var(--bg);
  font-family:var(--f-serif);font-style:italic;font-weight:400;
  font-size:24px;letter-spacing:-.02em;
}
.contact-body{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.contact-role{
  font-family:var(--f-sans);font-weight:500;
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent-dk);margin:0;
}
.contact-name{
  font-family:var(--f-serif);font-style:italic;font-weight:400;
  font-size:clamp(26px, 2.4vw, 32px);line-height:1;letter-spacing:-.01em;
  color:var(--ink);margin:0;
}
.contact-phone{
  font-family:var(--f-mono);font-size:13px;letter-spacing:.04em;
  color:var(--ink-muted);margin:2px 0 12px;
  font-variant-numeric:tabular-nums;
}
.contact-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:auto}
.contact-call{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;
  background:var(--ink);color:var(--bg);border:1px solid var(--ink);
  border-radius:2px;text-decoration:none;
  font-family:var(--f-sans);font-weight:500;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  transition:background 400ms var(--ease-out), color 400ms var(--ease-out);
}
.contact-call:hover{background:var(--accent);color:var(--ink);border-color:var(--accent)}
.contact-whatsapp{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;
  background:#25D366;color:#fff;border:1px solid #25D366;
  border-radius:2px;text-decoration:none;
  font-family:var(--f-sans);font-weight:500;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  transition:background 400ms var(--ease-out), transform 400ms var(--ease-out);
}
.contact-whatsapp:hover{background:#128C7E;transform:translateY(-1px)}

.contacts-note{
  max-width:var(--container);margin:clamp(28px, 3vw, 40px) auto 0;
  font-family:var(--f-serif);font-style:italic;
  font-size:15px;line-height:1.6;color:var(--ink-soft);
  text-align:center;
}
.contacts-note em{color:var(--accent-dk);font-weight:500}

@media (max-width: 820px){
  .contact-card{padding:20px;gap:16px}
  .contact-avatar{width:52px;height:52px;font-size:22px}
  .contact-actions{gap:8px}
  .contact-call,.contact-whatsapp{flex:1;justify-content:center;padding:12px 14px}
}

/* ---------- RÈGLEMENT INTÉRIEUR ---------- */
.rules-intro{
  font-family:var(--f-serif);font-style:italic;font-weight:300;
  font-size:clamp(16px, 1.2vw, 20px);line-height:1.55;
  color:var(--ink-soft);margin-top:var(--s-3);max-width:52ch;
}
.rules-grid{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:clamp(16px, 2vw, 28px);
}
.rule-card{
  padding:clamp(22px, 2.4vw, 32px);
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:8px;
  display:flex;flex-direction:column;gap:12px;
  transition:border-color 400ms var(--ease-out), transform 400ms var(--ease-out);
}
.rule-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.rule-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:50%;
  background:rgba(201,169,97,.12);
  color:var(--accent-dk);
}
.rule-card h3{
  font-family:var(--f-serif);font-style:italic;font-weight:400;
  font-size:20px;letter-spacing:-.01em;color:var(--ink);margin:0;
}
.rule-card p{
  font-size:14px;line-height:1.6;color:var(--ink-soft);margin:0;
}

/* ---------- VIDÉOS ---------- */
.videos-intro{
  font-family:var(--f-serif);font-style:italic;font-weight:300;
  font-size:clamp(16px, 1.2vw, 20px);line-height:1.55;
  color:var(--ink-soft);margin-top:var(--s-3);max-width:52ch;
}
.videos-grid{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:clamp(20px, 2.4vw, 32px);
}
.video-card{
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:10px;overflow:hidden;
  transition:border-color 400ms var(--ease-out), box-shadow 400ms var(--ease-out);
}
.video-card:hover{border-color:var(--accent);box-shadow:0 30px 60px -30px rgba(10,10,10,.25)}
.video-frame{
  position:relative;
  aspect-ratio:16 / 9;
  background:#1a1a1a;
  display:flex;align-items:center;justify-content:center;
}
.video-frame video{
  width:100%;height:100%;display:block;object-fit:cover;
}
.video-coming{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  background:linear-gradient(135deg, #1a1a1a 0%, #2a2218 100%);
  color:var(--accent-lt);
  font-family:var(--f-sans);font-weight:500;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
}
.video-coming svg{opacity:.7}
.video-body{
  padding:clamp(18px, 2vw, 24px);
  display:flex;flex-direction:column;gap:8px;
}
.video-num{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;
  color:var(--accent-dk);text-transform:uppercase;
}
.video-body h3{
  font-family:var(--f-serif);font-style:italic;font-weight:400;
  font-size:clamp(22px, 2vw, 28px);letter-spacing:-.01em;
  color:var(--ink);margin:0;line-height:1.1;
}
.video-body p{font-size:14px;line-height:1.6;color:var(--ink-soft);margin:0}
.videos-note{
  max-width:var(--container);margin:clamp(24px, 3vw, 40px) auto 0;
  font-family:var(--f-serif);font-style:italic;
  font-size:14px;line-height:1.6;color:var(--ink-muted);
  text-align:center;
}

@media (max-width: 820px){
  .videos-grid,.rules-grid,.contacts-grid{grid-template-columns:1fr}
}
