/* gondolevenise.fr — v1.0 — Cormorant Garamond + Jost, rouge vénitien / ivoire */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Jost:wght@300;400;500;600;700&display=swap');

:root {
  --rouge:    #8c1414;
  --rouge-dk: #620d0d;
  --rouge-lt: #fdf0f0;
  --ivoire:   #faf7f3;
  --creme:    #f0ebe3;
  --sable:    #e6dfd5;
  --canal:    #2c6b7a;
  --or:       #c8a052;
  --or-lt:    #fdf8ef;
  --encre:    #1c1714;
  --muted:    #5e564e;
  --bord:     #d8d0c5;
  --blanc:    #ffffff;
  --r:        6px;
  --r-lg:     14px;
  --ombre:    0 2px 18px rgba(28,23,20,.08);
  --ombre-g:  0 6px 30px rgba(28,23,20,.14);
  --larg:     1100px;
  --fh:       'Cormorant Garamond', Georgia, serif;
  --ft:       'Jost', Arial, sans-serif;
}

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 17px; scroll-behavior: smooth; }
body { font-family: var(--ft); font-size: 1.0625rem; color: var(--encre); background: var(--ivoire); line-height: 1.82; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--rouge); text-decoration: none; }
a:hover { color: var(--rouge-dk); text-decoration: underline; }
ul,ol { padding-left: 1.4rem; }
li { margin-bottom: .38rem; }

/* === HEADER === */
.bandeau-nav { background: var(--encre); position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 12px rgba(0,0,0,.35); }
.bandeau-in { max-width: var(--larg); margin: 0 auto; padding: .72rem 1.4rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.logo-marque { font-family: var(--fh); font-size: 1.1rem; font-weight: 600; font-style: italic; color: var(--or); letter-spacing: .04em; white-space: nowrap; }
.logo-marque:hover { color: var(--blanc); text-decoration: none; }
.menu-principal { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.menu-principal a { font-family: var(--ft); font-size: .82rem; font-weight: 500; color: rgba(255,255,255,.72); letter-spacing: .06em; text-transform: uppercase; transition: color .2s; }
.menu-principal a:hover { color: var(--or); text-decoration: none; }
.lien-reserve { background: var(--rouge); color: var(--blanc) !important; padding: .5rem 1.1rem; border-radius: var(--r); transition: background .2s; white-space: nowrap; }
.lien-reserve:hover { background: var(--rouge-dk) !important; }
.menu-toggle { display: none; background: none; border: none; cursor: pointer; padding: .3rem; flex-direction: column; gap: 5px; }
.menu-toggle span { display: block; width: 24px; height: 2px; background: var(--or); border-radius: 2px; }

/* === HERO === */
.scene { position: relative; min-height: 560px; display: flex; align-items: flex-end; overflow: hidden; }
.scene img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 40%; z-index: 0; }
.scene-voile { position: absolute; inset: 0; background: linear-gradient(to top, rgba(28,23,20,.88) 0%, rgba(28,23,20,.34) 55%, transparent 100%); z-index: 1; }
.scene-texte { position: relative; z-index: 2; max-width: var(--larg); margin: 0 auto; padding: 3rem 1.4rem 4rem; width: 100%; }
.scene-texte h1 { font-family: var(--fh); font-size: clamp(2.2rem,5.5vw,3.6rem); font-weight: 600; font-style: italic; color: var(--blanc); letter-spacing: .03em; line-height: 1.12; margin-bottom: 1rem; text-shadow: 0 2px 20px rgba(0,0,0,.55); }
.scene-texte p { color: rgba(255,255,255,.88); font-size: 1.1rem; max-width: 660px; margin-bottom: 1.5rem; line-height: 1.76; }
.btn-rouge { display: inline-block; background: var(--rouge); color: var(--blanc); font-family: var(--ft); font-size: .86rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: .9rem 2.2rem; border-radius: var(--r); transition: background .2s, transform .15s; }
.btn-rouge:hover { background: var(--rouge-dk); color: var(--blanc); text-decoration: none; transform: translateY(-1px); }

/* === RUBRIQUES === */
.rubrique { padding: 3.5rem 1.4rem; }
.rubrique-ivoire { background: var(--ivoire); }
.rubrique-creme { background: var(--creme); }
.rubrique-sable { background: var(--sable); }
.rubrique-or { background: var(--or-lt); }
.rubrique-in { max-width: var(--larg); margin: 0 auto; }
.rubrique h2 { font-family: var(--fh); font-size: clamp(1.4rem,3vw,2rem); font-weight: 600; font-style: italic; color: var(--encre); margin-bottom: 1.2rem; }
.rubrique p { font-size: 1.0625rem; line-height: 1.82; margin-bottom: 1rem; }
.rubrique ul,.rubrique ol { margin: .8rem 0 1rem; }
.rubrique strong { font-weight: 600; }

/* photo */
.img-section { width: 100%; height: 280px; object-fit: cover; object-position: center; border-radius: var(--r-lg); margin: 1.4rem 0; box-shadow: var(--ombre); }

/* fil d'ariane */
.chemin { background: var(--rouge-lt); padding: .6rem 1.4rem; font-size: .85rem; color: var(--muted); border-bottom: 1px solid var(--bord); }
.chemin-in { max-width: var(--larg); margin: 0 auto; }
.chemin a { color: var(--muted); }
.chemin a:hover { color: var(--rouge); }
.chemin span { margin: 0 .4rem; }

/* bandeau CTA */
.bandeau-rouge { background: var(--rouge); padding: 2.5rem 1.4rem; text-align: center; }
.bandeau-rouge h2 { font-family: var(--fh); color: var(--blanc); font-size: 1.5rem; font-style: italic; margin-bottom: .8rem; }
.bandeau-rouge p { color: rgba(255,255,255,.88); margin-bottom: 1.4rem; }
.btn-blanc { display: inline-block; background: var(--blanc); color: var(--rouge); font-family: var(--ft); font-size: .86rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; padding: .85rem 2rem; border-radius: var(--r); transition: .2s; }
.btn-blanc:hover { background: var(--ivoire); text-decoration: none; }
.btn-sombre { display: inline-block; background: var(--encre); color: var(--blanc); font-family: var(--ft); font-size: .86rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; padding: .82rem 1.8rem; border-radius: var(--r); transition: .2s; margin-left: .5rem; }
.btn-sombre:hover { background: #333; color: var(--blanc); text-decoration: none; }

/* tableaux */
.t-wrap { overflow-x: auto; margin: 1rem 0 1.2rem; -webkit-overflow-scrolling: touch; }
.t { width: 100%; border-collapse: collapse; font-size: 1rem; }
.t thead th { background: var(--rouge); color: var(--blanc); font-family: var(--ft); font-size: .82rem; font-weight: 600; letter-spacing: .07em; text-transform: uppercase; padding: .72rem 1rem; text-align: left; }
.t tbody tr:nth-child(even) { background: var(--rouge-lt); }
.t tbody tr:hover { background: var(--creme); }
.t td { padding: .65rem 1rem; border-bottom: 1px solid var(--bord); font-size: 1rem; }

/* partenaire box */
.encart-gyg { background: var(--blanc); border: 2px solid var(--rouge); border-radius: var(--r-lg); padding: 1.8rem; margin: 1.5rem 0; box-shadow: var(--ombre); }
.encart-gyg h3 { font-family: var(--fh); font-size: 1.25rem; font-style: italic; color: var(--rouge); margin-bottom: 1rem; }
.liste-ok { list-style: none; padding: 0; margin: .8rem 0; }
.liste-ok li { padding: .35rem 0 .35rem 1.6rem; position: relative; border-bottom: 1px solid var(--rouge-lt); font-size: 1rem; }
.liste-ok li::before { content: '✓'; color: var(--rouge); font-weight: 700; position: absolute; left: 0; }
.liste-ok li:last-child { border-bottom: none; }
.btn-tiqets { display: inline-block; background: var(--encre); color: var(--blanc); font-family: var(--ft); font-size: .86rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; padding: .8rem 1.8rem; border-radius: var(--r); transition: .2s; margin-top: .5rem; margin-left: .6rem; }
.btn-tiqets:hover { background: #333; color: var(--blanc); text-decoration: none; }

/* widget */
.zone-widget { background: var(--rouge-lt); border: 1px solid var(--bord); border-radius: var(--r-lg); padding: 1.5rem; margin: 1.5rem 0; overflow: hidden; }

/* grille 2 col */
.grille { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin: 1rem 0; }
.carte { background: var(--blanc); border: 1px solid var(--bord); border-radius: var(--r); padding: 1.2rem; }
.carte h3 { font-family: var(--ft); font-size: .88rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--rouge); margin-bottom: .6rem; }
.carte p,.carte li { font-size: .97rem; }

/* === FAQ === */
.faq-groupe { margin-bottom: 1.5rem; }
.faq-groupe > h2 { font-size: 1.2rem; font-style: italic; padding-bottom: .5rem; border-bottom: 2px solid var(--rouge-lt); margin-bottom: .9rem; }
.faq-volet { background: var(--blanc); border: 1px solid var(--bord); border-radius: var(--r); margin-bottom: .6rem; overflow: hidden; transition: box-shadow .2s; }
.faq-volet.actif { box-shadow: 0 3px 16px rgba(140,20,20,.1); border-color: var(--rouge); }
.faq-entete { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.2rem; cursor: pointer; gap: 1rem; }
.faq-entete h3 { font-family: var(--ft); font-size: .97rem; font-weight: 600; color: var(--encre); margin: 0; line-height: 1.4; }
.faq-symbole { width: 28px; height: 28px; border-radius: 50%; background: var(--rouge-lt); border: 1px solid var(--bord); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; color: var(--rouge); flex-shrink: 0; transition: transform .25s, background .2s; }
.faq-volet.actif .faq-symbole { transform: rotate(45deg); background: var(--rouge); color: var(--blanc); border-color: var(--rouge); }
.faq-corps { display: none; padding: 0 1.2rem 1.2rem; border-top: 1px solid var(--bord); }
.faq-volet.actif .faq-corps { display: block; }
.faq-corps p { margin-top: .9rem; font-size: 1rem; }

/* en-têtes pages internes */
.cap-interne { background: var(--creme); padding: 2.5rem 1.4rem 2rem; border-bottom: 1px solid var(--bord); }
.cap-interne h1 { font-family: var(--fh); font-size: clamp(1.5rem,4vw,2.2rem); font-style: italic; color: var(--rouge); }
.cap-interne p { color: var(--muted); margin-top: .5rem; }
.corps-interne { max-width: 820px; margin: 0 auto; padding: 2.5rem 1.4rem; }
.corps-interne h2 { font-family: var(--fh); font-size: 1.3rem; font-style: italic; margin: 2rem 0 .7rem; color: var(--encre); }
.corps-interne h3 { font-family: var(--ft); font-size: 1rem; font-weight: 600; margin: 1.4rem 0 .5rem; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; }
.corps-interne p,.corps-interne li { font-size: 1rem; line-height: 1.8; }
.corps-interne ul { margin: .5rem 0 1rem; }

/* 404 */
.erreur { min-height: 60vh; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 3rem 1.4rem; }
.erreur-404 { font-family: var(--fh); font-size: clamp(5rem,15vw,9rem); font-weight: 700; font-style: italic; color: var(--rouge-lt); line-height: 1; margin-bottom: .5rem; }
.erreur h1 { font-family: var(--fh); font-size: 1.6rem; font-style: italic; margin-bottom: .8rem; color: var(--rouge); }
.erreur p { color: var(--muted); margin-bottom: 1.8rem; max-width: 480px; }
.btn-err-a { display: inline-block; background: var(--rouge); color: var(--blanc); font-family: var(--ft); font-size: .86rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; padding: .85rem 2rem; border-radius: var(--r); margin: .4rem; }
.btn-err-b { display: inline-block; border: 2px solid var(--rouge); color: var(--rouge); font-family: var(--ft); font-size: .86rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; padding: .8rem 2rem; border-radius: var(--r); margin: .4rem; }
.btn-err-a:hover,.btn-err-b:hover { opacity: .85; text-decoration: none; }

/* === FOOTER === */
.pied { background: var(--encre); color: rgba(255,255,255,.65); padding: 3rem 1.4rem 1.5rem; }
.pied-grille { max-width: var(--larg); margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 2.5rem; margin-bottom: 2rem; }
.pied h4 { font-family: var(--fh); color: var(--or); font-style: italic; font-size: 1rem; margin-bottom: .8rem; }
.pied p { font-size: .9rem; line-height: 1.6; margin-bottom: .5rem; }
.pied a { color: rgba(255,255,255,.5); font-size: .9rem; }
.pied a:hover { color: var(--or); text-decoration: none; }
.pied-nav { list-style: none; padding: 0; }
.pied-nav li { margin-bottom: .4rem; }
.pied-bas { max-width: var(--larg); margin: 0 auto; padding-top: 1.2rem; border-top: 1px solid rgba(255,255,255,.1); display: flex; flex-wrap: wrap; gap: .8rem; justify-content: space-between; align-items: center; font-size: .82rem; color: rgba(255,255,255,.3); }

/* === RESPONSIVE === */
@media (max-width: 768px) {
  .menu-principal { display: none; flex-direction: column; align-items: flex-start; position: absolute; top: 100%; left: 0; right: 0; background: var(--encre); border-top: 1px solid rgba(255,255,255,.1); padding: 1rem 1.4rem; box-shadow: var(--ombre-g); gap: .8rem; }
  .menu-principal.visible { display: flex; }
  .menu-toggle { display: flex; }
  .pied-grille { grid-template-columns: 1fr; gap: 1.5rem; }
  .grille { grid-template-columns: 1fr; }
  .scene { min-height: 420px; }
  .scene-texte h1 { font-size: 1.9rem; }
  .t thead { display: none; }
  .t tr { display: block; border: 1px solid var(--bord); border-radius: var(--r); margin-bottom: .8rem; background: var(--blanc); }
  .t td { display: flex; justify-content: space-between; align-items: center; padding: .6rem 1rem; border-bottom: 1px solid var(--rouge-lt); font-size: .95rem; }
  .t td::before { content: attr(data-label); font-weight: 700; font-size: .82rem; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; flex-shrink: 0; margin-right: .8rem; }
  .t td:last-child { border-bottom: none; }
  .btn-tiqets { margin-left: 0; margin-top: .6rem; }
}
@media (max-width: 480px) {
  .rubrique { padding: 2.5rem 1rem; }
  .scene-texte { padding: 2rem 1rem 2.5rem; }
}
