:root{--bg:#000;--text:#fff;--picola-brown:#3b2f2f;--overlay-bg:rgba(0,0,0,0);--overlay-hover-bg:rgba(0,0,0,.45)}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:'Playfair Display',serif;scroll-behavior:smooth;overflow-x:hidden}
*,*::before,*::after{box-sizing:border-box}
a{color:inherit;text-decoration:none}
.visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}

/* Header */
.site-header{position:absolute;top:0;left:0;right:0;width:100%;z-index:1000;padding:16px 20px;display:flex;justify-content:space-between;align-items:center}
.logo{font-family:'Playfair Display',serif;font-size:32px;letter-spacing:1px;color:var(--picola-brown);line-height:1;text-align:center;display:inline-block}
.logo-sub{display:block;font-size:9px;letter-spacing:.04em;color:var(--picola-brown);line-height:1.2;margin-top:3px;text-align:center;max-width:100%}
.navbar{position:relative;display:flex;align-items:center}
.nav-links{list-style:none;display:flex;gap:24px;margin:0;padding:0}
.nav-links a{color:#fff;text-decoration:none;font-family:'Playfair Display',serif;font-size:16px;position:relative}
.nav-links a:after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:1px;background:#fff;transform:scaleX(0);transition:transform .2s}
.nav-links a:hover:after{transform:scaleX(1)}
.menu-toggle{display:none;position:relative;width:36px;height:28px;border:0;background:transparent;cursor:pointer}
.menu-toggle .bar{display:block;height:2px;background:#fff;margin:6px 0}

/* Grid + cards */
.grid{display:grid;grid-template-columns:repeat(3,1fr);height:auto;max-width:100%}
.card{position:relative;overflow:hidden;background:#000;display:block}
.card img{display:block;width:100%;height:auto;object-fit:cover;transition:transform .6s ease}
.card:hover img{transform:scale(1.03)}
.overlay{position:absolute;inset:0;background:var(--overlay-bg);display:flex;align-items:center;justify-content:center;opacity:1;transition:background .35s ease;pointer-events:none}
.label{font-size:18px;letter-spacing:2px;text-transform:uppercase;background:none;padding:6px 0;opacity:.5;text-shadow:0 1px 2px rgba(0,0,0,.55);position:absolute;top:76%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;transition:opacity .25s ease,transform .25s ease,background .25s ease;color:#fff}

/* Effets hover (désactivés plus bas pour écrans tactiles) */
.card:hover .overlay,.card:focus .overlay,.card:active .overlay{background:var(--overlay-hover-bg)}
.card:hover .label,.card:focus .label,.card:active .label{background:rgba(0,0,0,.2);padding:6px 18px;border-radius:2px;opacity:.7;transform:translate(-50%,-52%)}

/* Contact */
.contact{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;text-align:center;opacity:0;transform:translateY(20px);transition:opacity 1s ease,transform 1s ease}
.contact.visible{opacity:1;transform:translateY(0)}
.contact h2{font-size:32px;margin-bottom:15px}
.contact p{font-size:18px;color:#ccc;max-width:520px}
.email{display:inline-block;margin-top:20px;font-size:20px;border-bottom:1px solid #aaa}
.email:hover{border-color:#fff}

/* ======= Responsive ======= */
@media(max-width:1200px) and (orientation:portrait){
  .grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:1200px) and (orientation:landscape){
  .grid{grid-template-columns:repeat(3,1fr)}
}

/* Mobile: 1 colonne, hauteurs naturelles, aucune unité vh */
@media(max-width:900px){
  .logo{font-size:26px}
  .menu-toggle{display:block}
  .nav-links{position:absolute;top:100%;right:0;display:none;flex-direction:column;background:rgba(0,0,0,.92);backdrop-filter:saturate(130%) blur(2px);width:220px;padding:12px;border:1px solid rgba(255,255,255,.08)}
  .nav-links.show{display:flex}
  .nav-links a{padding:10px 6px;font-size:15px}

  .grid{display:block}
  .card{display:block}
  .card img{width:100%;height:auto;object-fit:contain}

  /* neutraliser les effets hover sur écrans tactiles (évite assombrissement “collé”) */
  @media (pointer:coarse){
    .card:hover .overlay,.card:focus .overlay,.card:active .overlay{background:var(--overlay-bg)}
    .card:hover .label,.card:focus .label,.card:active .label{background:none;opacity:.5;transform:translate(-50%,-50%)}
  }

  .label{top:76%}
  .contact{padding-top:25px;padding-bottom:25px}
}

/* iPad portrait intermédiaire */
@media(min-width:901px) and (max-width:1200px) and (orientation:portrait){
  .contact{padding-top:25px;padding-bottom:25px}
}

/* Small phones tweaks */
@media(max-width:420px){
  .logo{font-size:24px}
  .nav-links a{font-size:14px}
}