/* ===================================================================
   Villa Brinda — Portfolio
   Site plein écran, switch entre panneaux. Double thème clair/sombre.
   Couleurs conformes WCAG AAA (contraste >= 7:1 sur le texte).
   =================================================================== */

:root{
  /* --- couleurs de marque fixes (servent au hero toujours sombre) --- */
  --c-cream:  #f4efe7;
  --c-ink:    #20201d;
  --gold-lt:  #e6c98c;          /* or clair : accent sur fond sombre */
  --wa:       #0a5e2b;          /* AAA : 7.93:1 texte blanc */
  --wa-dk:    #083f1d;

  /* --- jetons de thème (CLAIR par défaut) --- */
  --bg:          #f4efe7;
  --surface:     #ffffff;
  --surface-2:   #e7ddcf;
  --fg:          #20201d;       /* 14.3:1 / bg */
  --fg-soft:     #4a463f;       /* 8.2:1  / bg  AAA */
  --line:        rgba(32,32,29,.18);
  --accent:      #5f4519;       /* 7.8:1  / bg  AAA ; blanc dessus 8.9:1 */
  --accent-hover:#4d3712;
  --on-accent:   #ffffff;
  --invert-bg:   #20201d;       /* pastille active (nav, filtres) */
  --invert-fg:   #f4efe7;
  --glass:       rgba(255,255,255,.9);
  --glass-solid: rgba(255,255,255,.92);
  --glass-strong:rgba(255,255,255,.97);
  --dot:         rgba(32,32,29,.32);

  --shadow:   0 24px 60px -24px rgba(32,32,29,.45);
  --ease:     cubic-bezier(.6,.01,.15,1);
}

/* --- thème SOMBRE --- */
[data-theme="dark"]{
  --bg:          #16150f;
  --surface:     #211f18;
  --surface-2:   #2a271d;
  --fg:          #f4efe7;       /* 16:1  / bg */
  --fg-soft:     #cfc7b6;       /* 10.9:1 / bg AAA */
  --line:        rgba(244,239,231,.18);
  --accent:      #e6c98c;       /* 11.4:1 / bg AAA ; texte sombre dessus 11.4:1 */
  --accent-hover:#f0d9a6;
  --on-accent:   #20201d;
  --invert-bg:   #e6c98c;
  --invert-fg:   #20201d;
  --glass:       rgba(33,31,24,.88);
  --glass-solid: rgba(33,31,24,.9);
  --glass-strong:rgba(24,22,16,.97);
  --dot:         rgba(244,239,231,.4);
  --shadow:      0 24px 60px -24px rgba(0,0,0,.6);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html,body{
  height:100%;
  overflow:hidden;               /* pas de scroll vertical de page */
  background:var(--bg);
  color:var(--fg);
  font-family:"Inter",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  transition:background .4s var(--ease), color .4s var(--ease);
}

h1,h2{ font-family:"Cormorant Garamond",serif; font-weight:600; line-height:1; }

/* lien d'évitement (WCAG 2.4.1) */
.skip-link{ position:fixed; top:-80px; left:1rem; z-index:100; background:var(--accent);
  color:var(--on-accent); padding:.75rem 1.2rem; border-radius:0 0 10px 10px; font-size:.85rem;
  font-weight:600; text-decoration:none; transition:top .25s var(--ease); }
.skip-link:focus{ top:0; }

/* texte réservé aux lecteurs d'écran */
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
  clip:rect(0 0 0 0); white-space:nowrap; border:0; }

.eyebrow{
  font-size:.72rem; letter-spacing:.34em; text-transform:uppercase;
  color:var(--accent); font-weight:700; margin-bottom:1rem;
}
.section-title{ font-size:clamp(2.4rem,6vw,4.4rem); margin-bottom:1rem; }
.section-text{ color:var(--fg-soft); max-width:40ch; line-height:1.6; font-weight:400; }

/* ---------- Top bar ---------- */
.topbar{
  position:fixed; inset:0 0 auto 0; z-index:60;
  height:74px; display:flex; align-items:center; justify-content:space-between;
  padding:0 clamp(1.2rem,4vw,3rem);
}
.brand{ display:flex; align-items:center; gap:.6rem; text-decoration:none; color:var(--fg); }
.brand-mark{
  display:grid; place-items:center; width:38px; height:38px; border-radius:50%;
  background:var(--invert-bg); color:var(--invert-fg); font-family:"Cormorant Garamond",serif;
  font-size:1.4rem; font-weight:600;
}
.brand-name{ font-family:"Cormorant Garamond",serif; font-size:1.45rem; font-weight:600; letter-spacing:.02em; }

.nav{ display:flex; gap:.2rem; background:var(--glass); backdrop-filter:blur(10px);
  border:1px solid var(--line); border-radius:999px; padding:.3rem; }
.nav-link{
  border:0; background:transparent; cursor:pointer; color:var(--fg-soft);
  font-family:inherit; font-size:.82rem; font-weight:500; letter-spacing:.02em;
  padding:.5rem .95rem; border-radius:999px; transition:.35s var(--ease);
}
.nav-link:hover{ color:var(--fg); }
.nav-link.active{ background:var(--invert-bg); color:var(--invert-fg); }

.topbar-right{ display:flex; align-items:center; gap:.55rem; }
.lang-switch{ display:flex; align-items:center; gap:.3rem; background:var(--glass);
  backdrop-filter:blur(10px); border:1px solid var(--line); border-radius:999px; padding:.25rem .55rem; }
.lang-switch button{ border:0; background:transparent; cursor:pointer; color:var(--fg-soft);
  font-family:inherit; font-size:.76rem; font-weight:700; letter-spacing:.06em; padding:.2rem .25rem;
  min-width:30px; min-height:30px; transition:.3s var(--ease); }
.lang-switch button:hover{ color:var(--fg); }
.lang-switch button.active{ color:var(--accent); }
.lang-switch span{ color:var(--fg-soft); opacity:.5; font-size:.7rem; }

.theme-toggle{ display:grid; place-items:center; width:40px; height:40px; border-radius:50%;
  background:var(--glass); backdrop-filter:blur(10px); border:1px solid var(--line);
  color:var(--fg); cursor:pointer; transition:.3s var(--ease); }
.theme-toggle:hover{ color:var(--accent); }
.theme-toggle .ic-moon{ display:block; }
.theme-toggle .ic-sun{ display:none; }
[data-theme="dark"] .theme-toggle .ic-moon{ display:none; }
[data-theme="dark"] .theme-toggle .ic-sun{ display:block; }

.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.burger span{ width:24px; height:2px; background:var(--fg); transition:.3s var(--ease); }

/* ---------- Stage & panels ---------- */
.stage{ position:fixed; inset:0; }
.panel{
  position:absolute; inset:0;
  display:flex; align-items:safe center;   /* "safe" évite que le contenu trop haut soit rogné en haut */
  padding:96px clamp(1.2rem,5vw,5rem) 64px;
  overflow-y:auto;                          /* défilement interne si un panneau dépasse l'écran */
  -webkit-overflow-scrolling:touch;
  opacity:0; visibility:hidden; transform:translateX(40px) scale(.99);
  transition:opacity .6s var(--ease), transform .6s var(--ease), visibility .6s;
}
.panel.active{ opacity:1; visibility:visible; transform:none; }
.panel.leaving{ transform:translateX(-40px) scale(.99); }

/* ---------- Home (toujours sombre : couleurs fixes) ---------- */
.panel-bg{ position:absolute; inset:0; background-size:cover; background-position:center; z-index:-2; }
.panel-veil{ position:absolute; inset:0; z-index:-1;
  background:linear-gradient(100deg, rgba(20,18,15,.88) 0%, rgba(20,18,15,.6) 45%, rgba(20,18,15,.22) 100%); }
.panel[data-panel="home"]{ color:var(--c-cream); }
.home-content{ max-width:620px; }
.home-content .eyebrow{ color:var(--gold-lt); }
.display{ font-size:clamp(3.4rem,11vw,8rem); line-height:.92; margin-bottom:1.3rem; }
.lede{ font-size:1.08rem; line-height:1.65; font-weight:400; color:rgba(244,239,231,.92); max-width:46ch; }
.home-cta{ display:flex; gap:1rem; margin:2.2rem 0; flex-wrap:wrap; }
.facts{ display:flex; gap:2.6rem; list-style:none; }
.facts li{ display:flex; flex-direction:column; }
.facts strong{ font-family:"Cormorant Garamond",serif; font-size:2rem; font-weight:600; }
.facts span{ font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(244,239,231,.78); }

/* ---------- Buttons ---------- */
.btn{ font-family:inherit; font-size:.86rem; font-weight:600; letter-spacing:.03em;
  padding:.85rem 1.6rem; border-radius:999px; cursor:pointer; border:1px solid transparent;
  transition:.3s var(--ease); display:inline-flex; align-items:center; gap:.5rem; }
.btn-solid{ background:var(--accent); color:var(--on-accent); }
.btn-solid:hover{ background:var(--accent-hover); transform:translateY(-2px); }
.btn-ghost{ background:transparent; border-color:currentColor; color:inherit; }
.btn-ghost:hover{ background:rgba(255,255,255,.14); }
.btn-whatsapp{ background:var(--wa); color:#fff; margin-top:1.8rem; }
.btn-whatsapp:hover{ background:var(--wa-dk); transform:translateY(-2px); }

/* ---------- Room layout (bedrooms / rooms / garden) ---------- */
.room-layout{ display:grid; grid-template-columns:minmax(280px,360px) 1fr; gap:clamp(1.5rem,4vw,4rem);
  align-items:center; width:100%; height:100%; }
.room-intro{ max-width:380px; }
.room-tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.6rem; }
.room-tags span{ font-size:.72rem; letter-spacing:.05em; padding:.4rem .8rem; border:1px solid var(--line);
  border-radius:999px; color:var(--fg-soft); }

/* image vedette + miniatures (remplace le carrousel) */
.showcase{ display:flex; flex-direction:column; gap:.9rem; width:100%;
  height:min(72vh,600px); min-height:0; }
.showcase-main{ position:relative; flex:1 1 auto; min-height:0; border-radius:16px; overflow:hidden;
  background:var(--surface-2); box-shadow:var(--shadow); cursor:zoom-in; }
.showcase-main img{ width:100%; height:100%; object-fit:cover;
  transition:transform .8s var(--ease); }
.showcase-main:hover img{ transform:scale(1.03); }
.showcase-main figcaption{ position:absolute; left:0; right:0; bottom:0; display:flex; align-items:baseline;
  gap:.7rem; padding:1.7rem 1.4rem 1.1rem; color:#fff;
  background:linear-gradient(transparent, rgba(15,13,10,.85)); }
.showcase-main .m-ref{ font-family:"Cormorant Garamond",serif; font-size:1.35rem; font-weight:600;
  color:var(--gold-lt); line-height:1; }
.showcase-main .m-title{ font-size:1rem; font-weight:600; letter-spacing:.02em; }

.thumbs{ display:flex; gap:.7rem; flex:0 0 auto; height:clamp(62px,11vh,94px);
  overflow-x:auto; padding-bottom:.3rem; scrollbar-width:thin; }
.thumbs::-webkit-scrollbar{ height:5px; }
.thumbs::-webkit-scrollbar-thumb{ background:var(--surface-2); border-radius:99px; }
.thumb{ flex:0 0 auto; aspect-ratio:4/3; height:100%; padding:0; border:2px solid transparent;
  border-radius:10px; overflow:hidden; cursor:pointer; background:var(--surface-2); opacity:.5;
  transition:opacity .3s var(--ease), border-color .3s var(--ease); }
.thumb img{ width:100%; height:100%; object-fit:cover; }
.thumb:hover{ opacity:.85; }
.thumb.active{ opacity:1; border-color:var(--accent); }

/* ---------- Plan ---------- */
.plan-layout{ display:grid; grid-template-columns:minmax(260px,340px) 1fr; gap:clamp(1.5rem,4vw,4rem);
  align-items:center; width:100%; height:100%; }
.legend{ list-style:none; margin-top:1.6rem; display:flex; flex-direction:column; gap:.6rem; }
.legend li{ display:flex; align-items:center; gap:.6rem; font-size:.85rem; color:var(--fg-soft); }
.dot{ width:11px; height:11px; border-radius:50%; }
.d1{ background:var(--accent); } .d2{ background:#6f8a4f; } .d3{ background:#5b8794; }
.plan-figure{ height:min(72vh,640px); border-radius:16px; overflow:hidden; background:var(--surface);
  box-shadow:var(--shadow); cursor:zoom-in; display:grid; place-items:center; }
.plan-figure img{ width:100%; height:100%; object-fit:contain; }

/* ---------- Gallery ---------- */
.panel[data-panel="gallery"]{ flex-direction:column; align-items:stretch; }
.gallery-head{ display:flex; align-items:baseline; justify-content:space-between; flex-wrap:wrap;
  gap:1rem; margin-bottom:1.2rem; }
.filters{ display:flex; gap:.4rem; flex-wrap:wrap; }
.filters button{ border:1px solid var(--line); background:transparent; cursor:pointer;
  font-family:inherit; font-size:.78rem; font-weight:500; letter-spacing:.04em; padding:.45rem .9rem;
  border-radius:999px; color:var(--fg-soft); transition:.3s var(--ease); }
.filters button:hover{ color:var(--fg); }
.filters button.active{ background:var(--invert-bg); color:var(--invert-fg); border-color:var(--invert-bg); }
/* grille catalogue : 2 rangées alignées, défilement horizontal, fiches de largeur fixe */
.gallery-grid{ flex:1; display:grid; grid-auto-flow:column; grid-template-rows:repeat(2,1fr);
  grid-auto-columns:clamp(230px,24vw,272px); gap:1.1rem; overflow-x:auto; overflow-y:hidden;
  padding-bottom:1rem; scroll-snap-type:x proximity; scrollbar-width:thin; }
.gallery-grid::-webkit-scrollbar{ height:7px; }
.gallery-grid::-webkit-scrollbar-thumb{ background:var(--surface-2); border-radius:99px; }

/* fiche produit */
.tile{ display:flex; flex-direction:column; min-height:0; border-radius:14px; overflow:hidden;
  cursor:pointer; background:var(--surface); border:1px solid var(--line); box-shadow:var(--shadow);
  scroll-snap-align:start; transition:transform .35s var(--ease), box-shadow .35s var(--ease); }
.tile:hover{ transform:translateY(-5px); box-shadow:0 30px 60px -28px rgba(32,32,29,.5); }
.tile-img{ position:relative; flex:1 1 auto; min-height:0; overflow:hidden; background:var(--surface-2); }
.tile-img img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.tile:hover .tile-img img{ transform:scale(1.06); }
/* bandeau d'info toujours visible (style catalogue) */
.tile-info{ display:grid; grid-template-columns:1fr auto; align-items:center; gap:.55rem;
  padding:.7rem .85rem; border-top:1px solid var(--line); }
.tile-title{ font-size:.86rem; font-weight:600; color:var(--fg); white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis; }
.tile-cat{ font-size:.62rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--fg-soft); border:1px solid var(--line); padding:.2rem .5rem; border-radius:999px;
  white-space:nowrap; }

/* ---------- Contact ---------- */
.contact-layout{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,6rem);
  align-items:center; width:100%; max-width:1100px; margin:auto; }
.contact-list{ list-style:none; margin-top:1.8rem; display:flex; flex-direction:column; gap:1rem; }
.contact-list li{ display:flex; align-items:center; gap:.9rem; font-size:.98rem; }
.contact-list a{ color:var(--fg); text-decoration:none; }
.contact-list a:hover{ color:var(--accent); text-decoration:underline; }
.ci-ico{ display:grid; place-items:center; width:38px; height:38px; border-radius:50%;
  border:1px solid var(--line); color:var(--accent); }
.contact-form{ display:flex; flex-direction:column; gap:1rem; background:var(--glass);
  border:1px solid var(--line); border-radius:18px; padding:1.8rem; backdrop-filter:blur(8px); }
.contact-form label{ display:flex; flex-direction:column; gap:.4rem; font-size:.74rem;
  letter-spacing:.12em; text-transform:uppercase; color:var(--fg-soft); }
.contact-form input,.contact-form textarea{ font-family:inherit; font-size:.95rem; color:var(--fg);
  background:var(--surface); border:1px solid var(--line); border-radius:10px; padding:.7rem .85rem; resize:none;
  text-transform:none; letter-spacing:0; }
.contact-form input::placeholder,.contact-form textarea::placeholder{ color:var(--fg-soft); opacity:1; }
.contact-form input:focus,.contact-form textarea:focus{ outline:3px solid var(--accent); outline-offset:1px; border-color:var(--accent); }
.form-note{ font-size:.82rem; font-weight:600; color:var(--accent); min-height:1em; }

/* ---------- Tarifs ---------- */
.panel[data-panel="tarifs"]{ flex-direction:column; align-items:center; }
.tarifs-head{ text-align:center; max-width:640px; margin:0 auto 1.6rem; }
.tarifs-head .section-text{ margin:0 auto; }
.pricing{ display:grid; grid-template-columns:repeat(3,minmax(0,300px)); gap:1.4rem;
  justify-content:center; width:100%; }
.price-card{ display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--line);
  border-radius:18px; padding:1.8rem 1.6rem; box-shadow:var(--shadow); transition:transform .35s var(--ease); }
.price-card:hover{ transform:translateY(-5px); }
.price-card.featured{ border-color:var(--accent); border-width:2px; }
.price-badge{ align-self:flex-start; font-size:.62rem; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:var(--on-accent); background:var(--accent);
  padding:.25rem .6rem; border-radius:999px; margin-bottom:.9rem; }
.price-name{ font-family:"Cormorant Garamond",serif; font-size:1.7rem; font-weight:600; color:var(--fg); }
.price-amount{ display:flex; align-items:baseline; gap:.35rem; margin:.6rem 0 1.2rem; }
.price-amount .amt{ font-size:2.2rem; font-weight:700; color:var(--accent); line-height:1; }
.price-amount .per{ font-size:.8rem; color:var(--fg-soft); }
.price-features{ list-style:none; display:flex; flex-direction:column; gap:.7rem; margin-bottom:1.6rem; flex:1; }
.price-features li{ display:flex; align-items:flex-start; gap:.55rem; font-size:.88rem; color:var(--fg-soft); line-height:1.4; }
.price-features li::before{ content:"✓"; color:var(--accent); font-weight:700; flex:0 0 auto; }
.price-card .btn{ justify-content:center; }

/* ---------- Switch arrows ---------- */
.switch-arrow{ position:fixed; top:50%; transform:translateY(-50%); z-index:50;
  width:48px; height:48px; border-radius:50%; border:1px solid var(--line);
  background:var(--glass-solid); backdrop-filter:blur(8px); color:var(--fg);
  font-size:1.2rem; cursor:pointer; transition:.3s var(--ease); }
.switch-arrow:hover{ background:var(--surface); transform:translateY(-50%) scale(1.08); }
.switch-arrow.prev{ left:clamp(.6rem,2vw,1.6rem); }
.switch-arrow.next{ right:clamp(.6rem,2vw,1.6rem); }

/* logo & burger lisibles sur l'accueil (hero sombre) */
body.on-dark .brand{ color:var(--c-cream); }
body.on-dark .burger span{ background:var(--c-cream); }

/* ---------- Barre de progression (navigation entre pages) ---------- */
.progress{ position:fixed; bottom:1rem; left:50%; transform:translateX(-50%); z-index:50;
  display:flex; align-items:center; gap:.85rem; padding:.4rem .85rem; border-radius:999px;
  background:var(--glass); backdrop-filter:blur(10px); border:1px solid var(--line); }
.progress-label{ font-size:.74rem; font-weight:600; letter-spacing:.04em; color:var(--fg);
  min-width:64px; text-align:right; }
.progress-track{ display:flex; align-items:center; gap:5px; }
.progress-seg{ width:26px; height:5px; border:0; padding:0; border-radius:99px; cursor:pointer;
  background:var(--dot); transition:background .35s var(--ease), width .35s var(--ease), transform .2s var(--ease); }
.progress-seg:hover{ transform:scaleY(1.6); }
.progress-seg.done{ background:var(--accent); }
.progress-seg.active{ background:var(--accent); width:40px; }

/* ---------- Floating WhatsApp ---------- */
.wa-float{ position:fixed; right:clamp(1rem,3vw,2rem); bottom:clamp(1rem,3vw,2rem); z-index:70;
  width:60px; height:60px; border-radius:50%; background:var(--wa); color:#fff;
  display:grid; place-items:center; text-decoration:none;
  box-shadow:0 12px 30px -8px rgba(10,94,43,.7); animation:wa-pulse 2.6s infinite; transition:.3s var(--ease); }
.wa-float:hover{ background:var(--wa-dk); transform:scale(1.08); }
@keyframes wa-pulse{ 0%{ box-shadow:0 0 0 0 rgba(10,94,43,.5);} 70%{ box-shadow:0 0 0 16px rgba(10,94,43,0);} 100%{ box-shadow:0 0 0 0 rgba(10,94,43,0);} }

/* ---------- Lightbox ---------- */
.lightbox{ position:fixed; inset:0; z-index:90; background:rgba(12,11,9,.95);
  display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden;
  transition:.35s var(--ease); }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox img{ max-width:88vw; max-height:80vh; border-radius:8px; box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lb-close{ position:absolute; top:1.2rem; right:1.4rem; background:none; border:0; color:#fff;
  font-size:2.4rem; line-height:1; cursor:pointer; opacity:.85; }
.lb-close:hover{ opacity:1; }
.lb-nav{ position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.14);
  border:0; color:#fff; width:52px; height:52px; border-radius:50%; font-size:1.4rem; cursor:pointer; transition:.3s; }
.lb-nav:hover{ background:rgba(255,255,255,.28); }
.lb-prev{ left:2vw; } .lb-next{ right:2vw; }
.lb-caption{ position:absolute; bottom:1.4rem; left:0; right:0; text-align:center; color:#fff;
  font-size:.9rem; letter-spacing:.04em; }

/* ---------- Responsive ---------- */
@media (max-width:880px){
  .nav{ position:fixed; top:74px; right:clamp(1.2rem,4vw,3rem); flex-direction:column; gap:.2rem;
    background:var(--glass-strong); padding:.6rem; border-radius:16px; box-shadow:var(--shadow);
    transform:translateY(-12px); opacity:0; visibility:hidden; transition:.3s var(--ease); }
  .nav.open{ transform:none; opacity:1; visibility:visible; }
  .nav-link{ text-align:left; padding:.7rem 1.2rem; }
  .burger{ display:flex; }
  .room-layout,.plan-layout,.contact-layout{ grid-template-columns:1fr; gap:1.2rem; align-content:center; }
  .room-intro,.contact-info{ order:0; }
  .showcase{ height:min(52vh,440px); }
  .plan-figure{ height:min(46vh,420px); }
  .gallery-grid{ grid-template-rows:repeat(2,1fr); grid-auto-columns:78vw; }
  .switch-arrow{ display:none; }
  .panel{ padding:90px 1.2rem 70px; }
  .facts{ gap:1.6rem; }
  .pricing{ grid-template-columns:minmax(0,360px); }
  .progress-label{ display:none; }
  .progress-seg{ width:18px; }
  .progress-seg.active{ width:28px; }
}
@media (max-width:560px){
  .gallery-grid{ grid-template-rows:repeat(2,1fr); grid-auto-columns:72vw; }
}

/* ---------- Desktop : dégager le contenu des flèches latérales ---------- */
@media (min-width:881px){
  .panel{ padding-left:clamp(6rem,7vw,8rem); padding-right:clamp(6rem,7vw,8rem); }
}

/* ---------- Accessibilité : focus clavier visible (WCAG 2.4.7) ---------- */
:focus-visible{ outline:3px solid var(--accent); outline-offset:3px; border-radius:4px; }
.panel[data-panel="home"] :focus-visible,
.switch-arrow:focus-visible{ outline-color:var(--gold-lt); }
.lightbox :focus-visible{ outline-color:#fff; }

/* ---------- Mouvement réduit (WCAG 2.3.3) ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.01ms !important; scroll-behavior:auto !important; }
  .panel{ transition:opacity .15s linear !important; transform:none !important; }
  .panel.leaving{ transform:none !important; }
  .wa-float{ animation:none !important; }
  .showcase-main:hover img,.tile:hover .tile-img img{ transform:none !important; }
}
