/* ============================================================
   Faubourg de Ris — styles publics
   Police inspirée du logo "Faubourg de la Vape" :
   Cinzel (capitales Art Déco) + Pinyon Script (accent calligraphié)
   ============================================================ */
:root{
  --font-display:'Cinzel',Georgia,serif;
  --font-serif:'Cormorant Garamond',Georgia,serif;
  --font-script:'Pinyon Script','Cormorant Garamond',cursive;
  --font-body:'Jost','Helvetica Neue',Arial,sans-serif;
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);
  line-height:1.6;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* Pendant le chargement : aucune transition/animation (évite le clignotement
   du bouton — la couleur par défaut du lien n'est plus animée au 1er rendu). */
.preload *,.preload *::before,.preload *::after{
  transition:none !important;animation:none !important}

/* ----- thèmes ----- */
.theme-vape{
  --bg:#0a0a0a; --ink:#ffffff; --muted:#c2beb6; --accent:#ffffff;
  --panel:#000; --panel-text:#ffffff; --line:rgba(255,255,255,.16);
  --card:#161616; --foot-bg:#000; --foot-ink:#e8e6e1;
}
/* Page vape : éléments secondaires en gris clair (pas de doré) */
.theme-vape .kicker,.theme-vape .meta-label,.theme-vape .cat-back{color:#bdb9b1}
.theme-nature{
  --bg:#fbfcfb; --ink:#2f3a30; --muted:#6f7d6f; --accent:#7d9480;
  --panel:#EDEFED; --panel-text:#2f3a30; --line:rgba(125,148,128,.30);
  --card:#f1f4f1; --foot-bg:#e3e8e3; --foot-ink:#3a463b;
}

.accent{font-family:var(--font-script);font-weight:400;color:var(--accent);
  font-size:1.3em;line-height:1.35;display:inline-block;padding:.1em 0 .35em}
.kicker{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.28em;
  font-size:.72rem;color:var(--accent);font-weight:500;margin-bottom:1rem}

/* ===================== BOUTONS ===================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-body);font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  font-size:.78rem;padding:.95rem 1.9rem;border-radius:2px;cursor:pointer;border:1px solid transparent;
  transition:background-color .25s ease,color .25s ease,border-color .25s ease}
.btn-dark{background:#0d0d0d;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-dark:hover{background:#fff;color:#0d0d0d;border-color:#fff}
/* Faubourg de la Vape : bouton inversé (blanc -> noir au survol) + angles arrondis */
.theme-vape .btn-dark{background:#fff;color:#0d0d0d;border-color:#fff;border-radius:10px}
.theme-vape .btn-dark:hover{background:#0d0d0d;color:#fff;border-color:rgba(255,255,255,.55)}
/* Faubourg Nature : bouton catalogue en vert */
.theme-nature .btn-dark{background:#4f6a54;color:#fff;border-color:#4f6a54}
.theme-nature .btn-dark:hover{background:#3c5341;color:#fff;border-color:#3c5341}

/* ===================== HOME (sans scroll) ===================== */
html.nope{}
body.no-scroll,html:has(body.no-scroll){height:100%;overflow:hidden}
.splash{position:fixed;inset:0;width:100%;height:100dvh;overflow:hidden}
.splash-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.splash-overlay{position:absolute;inset:0;z-index:1;
  background:radial-gradient(120% 120% at 50% 40%,rgba(0,0,0,.68),rgba(0,0,0,.92));}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.splash-center{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:1.5rem;gap:1.8rem}
.splash-logo-vape{width:clamp(230px,34vw,360px);height:auto;
  filter:drop-shadow(0 10px 34px rgba(0,0,0,.65))}
.splash-corner{position:absolute;left:clamp(1rem,4vw,3.2rem);bottom:clamp(1.4rem,5vh,3rem);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.45rem}
.splash-logolink{display:inline-block}
.splash-logo-nature{width:clamp(190px,24vw,270px);height:auto;
  filter:drop-shadow(0 4px 18px rgba(0,0,0,.85)) brightness(1.1)}
.splash-enter{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.3em;
  font-size:.72rem;font-weight:400;color:#fff;border:1px solid rgba(255,255,255,.6);
  padding:.62rem 1.7rem;border-radius:2px;background:rgba(0,0,0,.18);backdrop-filter:blur(2px);transition:.25s ease}
.splash-enter:hover{background:#fff;color:#0a0a0a;border-color:#fff}

/* ===================== NAV ===================== */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:center;
  gap:1rem;padding:.55rem clamp(1rem,4vw,2rem)}
/* Flèche retour, collée le plus à gauche possible (ancrée au bord de la barre). Clic -> accueil. */
.nav-home{position:absolute;left:clamp(.5rem,1.5vw,1rem);top:50%;transform:translateY(-50%);
  display:inline-flex;align-items:center;justify-content:center;color:var(--ink);line-height:0;padding:.3rem}
.nav-home:hover{color:var(--accent)}
.nav-brand{display:flex;align-items:center}
.nav-logo{height:30px;width:auto;display:block}
.nav-logo-nature{height:34px}
.nav-links{display:flex;align-items:center;gap:clamp(.7rem,2vw,1.4rem)}
.nav-links>a{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.1em;
  font-size:.68rem;font-weight:400;color:var(--ink);padding:.35rem 0;position:relative;white-space:nowrap}
.nav-links>a:hover,.nav-links>a.is-active{color:var(--accent)}
.nav-links>a.is-active::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:var(--accent)}
.nav-phone{display:inline-flex;align-items:center;gap:.4rem;border:1px solid var(--line);
  padding:.38rem .7rem!important;border-radius:2px;color:var(--ink)!important;
  font-family:var(--font-body);font-size:.68rem;letter-spacing:.1em;white-space:nowrap}
.nav-phone:hover{background:var(--accent);color:var(--bg)!important}
.nav-phone svg{flex:none}
/* Bouton burger : caché sur desktop, visible sur mobile */
.nav-toggle{display:none;position:absolute;right:clamp(.6rem,2vw,1rem);top:50%;transform:translateY(-50%);
  background:none;border:0;cursor:pointer;padding:.45rem;flex-direction:column;gap:5px;z-index:6}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* Badge horaires (ouvert/fermé) collé à droite de la barre de menu */
.nav-status{position:absolute;right:clamp(.6rem,2vw,1.4rem);top:50%;transform:translateY(-50%);
  display:inline-flex;align-items:center;gap:.45rem;font-size:.7rem;letter-spacing:.02em;
  color:var(--ink);white-space:nowrap;cursor:pointer}
.nav-status:hover{color:var(--accent)}
#horaires{scroll-margin-top:80px}
.nav-status .dot{width:8px;height:8px;border-radius:50%;background:#bbb;flex:none}
.nav-status.is-open .dot{background:#5fd07a;box-shadow:0 0 8px #5fd07a}
.nav-status.is-closed .dot{background:#e07a5f}
@media(max-width:980px){.nav-status-label{display:none}}

/* ===================== HERO ===================== */
.hero{position:relative;min-height:92vh;display:flex;flex-direction:column;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,.8) 0%,rgba(0,0,0,.7) 40%,rgba(0,0,0,.95) 100%)}
.theme-nature .hero-overlay{background:linear-gradient(180deg,rgba(12,18,14,.78) 0%,rgba(12,18,14,.66) 40%,rgba(12,18,14,.95) 100%)}
.hero-content{position:relative;z-index:2;flex:1 1 auto;display:flex;align-items:center;justify-content:center;
  max-width:var(--maxw);width:100%;margin:0 auto;padding:1.5rem clamp(1rem,4vw,2rem);color:#fff}
.hero-kicker{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.28em;
  font-size:.72rem;color:rgba(255,255,255,.85);margin-bottom:1rem}
.hero-title{font-family:var(--font-display);font-weight:500;font-size:clamp(1.6rem,6vw,4.7rem);
  line-height:1.1;letter-spacing:.02em;white-space:nowrap}
/* Sous-titre calligraphié : sur sa propre ligne, plus petit, avec de l'air pour les jambages */
.hero-title .accent{color:#fff;opacity:.95;display:block;font-size:clamp(1.55rem,3.6vw,2.7rem);line-height:1.55;
  padding:.3em 0 .22em;margin-top:0}
/* Bloc haut : titre + sous-titre + description, centrés */
.hero-head{text-align:center;max-width:none;margin:0 auto}
.hero-sub{font-family:var(--font-serif);font-size:clamp(.95rem,1.4vw,1.1rem);
  max-width:72ch;margin:1rem auto 0;color:rgba(255,255,255,.92);font-weight:400}
/* Rangée basse : bandeau épinglé en bas du hero (bouton + livraison centrés, horaires à droite, flèche dessous) */
.hero-bottom{position:relative;z-index:2;flex:none;width:100%;max-width:var(--maxw);margin:0 auto;
  padding:0 clamp(1rem,4vw,2rem) clamp(1.4rem,3.5vh,2.6rem);
  display:flex;flex-direction:column;align-items:center;gap:1.2rem;color:#fff}
.hero-bottom-center{display:flex;flex-direction:column;align-items:center;gap:1.1rem;text-align:center}
.hero-bottom-right{position:absolute;right:0;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;align-items:flex-end;gap:.7rem;text-align:right}
/* Flèche « défiler vers le bas » avec légère animation */
.hero-scroll{margin-top:.4rem;color:rgba(255,255,255,.85);display:inline-flex;
  animation:scrollHint 1.8s ease-in-out infinite}
.hero-scroll:hover{color:#fff}
@keyframes scrollHint{0%,100%{transform:translateY(0);opacity:.7}50%{transform:translateY(7px);opacity:1}}
@media(prefers-reduced-motion:reduce){.hero-scroll{animation:none}}
.hero-status{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;letter-spacing:.04em;
  color:#fff;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.25);padding:.5rem .9rem;border-radius:2rem}
.hero-status .dot{width:8px;height:8px;border-radius:50%;background:#bbb}
.hero-status.is-open .dot{background:#5fd07a;box-shadow:0 0 8px #5fd07a}
.hero-status.is-closed .dot{background:#e07a5f}
.hero-delivery{margin:0;font-size:.95rem;color:rgba(255,255,255,.9);text-align:center}
.hero-hours{margin:0;color:#fff;min-width:240px;max-width:330px}
.hero-hours summary{cursor:pointer;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.85);list-style:none}
.hero-hours summary::-webkit-details-marker{display:none}
.hero-hours summary::before{content:"▾ "}
.hero-hours ul{list-style:none;margin-top:.7rem;font-size:.88rem}
.hero-hours li{display:flex;justify-content:space-between;gap:1rem;padding:.22rem 0;border-bottom:1px solid rgba(255,255,255,.12)}
.hero-hours li.is-today{color:var(--accent);font-weight:500}

/* ===================== PRESENTATION (section 2) ===================== */
.presentation{display:grid;grid-template-columns:0.9fr 1.1fr;align-items:stretch}
.presentation-logo{background:var(--panel);display:flex;align-items:center;justify-content:center;
  padding:clamp(2.5rem,6vw,5rem);min-height:340px}
.presentation-logo img{max-width:min(460px,94%);max-height:400px;object-fit:contain}
.theme-vape .presentation-logo img{border-radius:6px}
/* Logo Nature : agrandi et légèrement remonté */
.theme-nature .presentation-logo img{width:min(500px,94%);max-height:none;margin-top:-1.4rem}
.presentation-text{padding:clamp(2.2rem,5vw,4.5rem);display:flex;flex-direction:column;justify-content:center;max-width:640px}
.presentation-text h2{font-family:var(--font-display);font-weight:500;font-size:clamp(1.6rem,3.4vw,2.5rem);
  line-height:1.12;margin-bottom:1.2rem}
.presentation-text p{margin-bottom:1rem;color:var(--ink);opacity:.92;font-size:1.02rem}
.presentation-meta{margin-top:1rem;display:flex;flex-wrap:wrap;gap:1.5rem;border-top:1px solid var(--line);padding-top:1.3rem}
.presentation-meta div{display:flex;flex-direction:column;gap:.2rem}
.meta-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.2em;color:var(--accent)}

/* ===================== GALERIE (section 3) ===================== */
.gallery-section{max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,5.5rem) clamp(1rem,4vw,2rem)}
.section-head{text-align:center;margin-bottom:2.5rem}
.section-head h2{font-family:var(--font-display);font-weight:500;font-size:clamp(1.6rem,3.4vw,2.4rem)}
.gallery-grid{columns:3;column-gap:14px}
.g-item{break-inside:avoid;margin-bottom:14px;overflow:hidden;border-radius:4px;background:var(--card);
  border:1px solid var(--line);cursor:default}

/* Lightbox galerie */
.lightbox{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;z-index:1000;display:none;
  align-items:center;justify-content:center;background:rgba(0,0,0,.93);padding:4vmin;cursor:default}
.lightbox.open{display:flex}
.lightbox-content{max-width:92vw;max-height:92vh;display:flex;align-items:center;justify-content:center}
.lightbox-content img,.lightbox-content video{max-width:92vw;max-height:92vh;width:auto;height:auto;
  border-radius:4px;box-shadow:0 20px 60px rgba(0,0,0,.6);cursor:default;animation:lbFade .25s ease}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
.lightbox-close{position:absolute;top:14px;right:24px;background:none;border:none;color:#fff;
  font-size:2.6rem;line-height:1;cursor:pointer;opacity:.85;z-index:2}
.lightbox-close:hover{opacity:1}
/* Flèches de navigation (glyphe flèche, texte masqué) */
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:2;
  background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.35);color:#fff;
  width:48px;height:48px;border-radius:50%;font-size:0;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;opacity:.85;transition:background .2s ease,opacity .2s ease}
.lightbox-nav::before{font-size:1.5rem;line-height:1}
.lightbox-prev::before{content:"\2190"}
.lightbox-next::before{content:"\2192"}
.lightbox-nav:hover{opacity:1;background:rgba(0,0,0,.6)}
.lightbox-prev{left:max(12px,2vw)}
.lightbox-next{right:max(12px,2vw)}
.cat-item{cursor:default}
/* Lightbox sur mobile (portrait) : flèches discrètes SOUS l'image */
@media(max-width:680px){
  .lightbox{padding:2.5vmin}
  .lightbox-content{max-height:75vh}
  .lightbox-nav{top:auto;bottom:max(3vh,env(safe-area-inset-bottom));transform:none;
    background:none;border:none;width:auto;height:auto;opacity:.8}
  .lightbox-nav:hover{background:none}
  .lightbox-nav::before{font-size:2rem}
  .lightbox-prev{left:calc(50% - 74px);right:auto}
  .lightbox-next{left:calc(50% + 14px);right:auto}
}
/* Téléphone en paysage : image en plein écran (lisibilité) */
@media(orientation:landscape) and (max-height:540px){
  .lightbox{padding:1.2vmin}
  .lightbox-content{max-width:99vw;max-height:99vh}
  .lightbox-content img,.lightbox-content video{max-width:99vw;max-height:99vh}
  .lightbox-nav{top:auto;bottom:6px;transform:none;background:none;border:none;width:auto;height:auto;opacity:.6}
  .lightbox-nav::before{font-size:1.7rem}
  .lightbox-prev{left:calc(50% - 62px);right:auto}
  .lightbox-next{left:calc(50% + 12px);right:auto}
}
.g-item img,.g-item video{width:100%;height:auto;transition:transform .5s ease}
.g-item:hover img{transform:scale(1.04)}
.g-video video{width:100%}
.section-cta{text-align:center;margin-top:2.6rem}

/* ===================== CATALOGUE ===================== */
.cat-main{max-width:880px;margin:0 auto;padding:clamp(1.5rem,4vw,2.5rem) clamp(1rem,4vw,1.5rem) 4rem}
.cat-head{text-align:center;margin-bottom:2rem}
.cat-back{display:inline-block;font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-bottom:1rem}
.cat-head h1{font-family:var(--font-display);font-weight:500;font-size:clamp(1.7rem,4vw,2.6rem)}
.cat-intro{max-width:60ch;margin:1rem auto 0;color:var(--muted);font-family:var(--font-serif);font-size:1.1rem}
.cat-stack{display:flex;flex-direction:column;gap:18px}
.cat-item{border:1px solid var(--line);border-radius:4px;overflow:hidden;background:var(--card)}
.cat-item img,.cat-item video{width:100%;height:auto}
.cat-footer-cta{text-align:center;margin-top:2.5rem}

/* bouton d'appel flottant (mobile, pages catalogue) */
.fab-call{position:fixed;right:18px;bottom:18px;z-index:60;width:58px;height:58px;border-radius:50%;
  display:none;align-items:center;justify-content:center;background:var(--accent);color:#0a0a0a;
  box-shadow:0 8px 24px rgba(0,0,0,.35);transition:transform .2s ease}
.theme-vape .fab-call{color:#0a0a0a}
.fab-call:active{transform:scale(.92)}

/* ===================== PAGE MENTIONS LÉGALES ===================== */
.legal-main{max-width:820px;margin:0 auto;padding:clamp(2.2rem,5vw,4rem) clamp(1rem,4vw,2rem)}
.legal-main h1{font-family:var(--font-display);font-weight:500;font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:1.6rem}
.legal-main h2{font-family:var(--font-display);font-weight:500;font-size:1.25rem;margin:1.9rem 0 .6rem;color:var(--ink)}
.legal-main p{color:var(--ink);opacity:.9;line-height:1.75}
.legal-main a{color:var(--accent)}

/* ===================== FOOTER ===================== */
.foot{background:var(--foot-bg);color:var(--foot-ink);border-top:1px solid var(--line);
  padding:clamp(2.5rem,5vw,3.5rem) clamp(1rem,4vw,2rem) 1.5rem}
/* Avertissement légal vapotage */
.foot-warning{max-width:var(--maxw);margin:0 auto 1.8rem;padding:.7rem 1rem;text-align:center;
  font-size:.84rem;letter-spacing:.02em;color:var(--foot-ink);opacity:.9;
  border:1px solid var(--line);border-radius:4px}
.foot-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.foot-title{font-family:var(--font-display);letter-spacing:.06em;margin-bottom:.7rem;color:var(--ink)}
.foot a:hover{color:var(--accent)}
.foot-sub{opacity:.85;max-width:34ch}
.foot-hours{list-style:none;font-size:.9rem}
.foot-hours li{display:flex;justify-content:space-between;gap:1rem;padding:.18rem 0;border-bottom:1px solid var(--line)}
.foot-hours li.is-today{color:var(--accent);font-weight:500}
.foot-bottom{max-width:var(--maxw);margin:2rem auto 0;padding-top:1.2rem;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.78rem;opacity:.8}

/* ===================== RESPONSIVE ===================== */
@media(max-width:860px){
  .presentation{grid-template-columns:1fr}
  .presentation-logo{min-height:240px}
  .gallery-grid{columns:2}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  /* === Menu mobile : flèche à gauche, statut + téléphone au centre, burger à droite === */
  .nav-inner{justify-content:center;gap:.55rem;padding-left:2.6rem;padding-right:2.8rem}
  .nav-toggle{display:flex}
  .nav-status{position:static;transform:none;order:1;font-size:.62rem}
  .nav-status-label{display:inline}
  .nav-phone{order:2;font-size:.62rem;padding:.32rem .5rem!important;gap:.3rem}
  /* Liens marque dans un panneau déroulant (burger) */
  .nav-links{position:absolute;top:calc(100% + .35rem);right:.6rem;left:auto;width:min(74vw,250px);
    display:flex;flex-direction:column;align-items:stretch;gap:.1rem;
    background:color-mix(in srgb,var(--bg) 96%,transparent);backdrop-filter:blur(12px);
    border:1px solid var(--line);border-radius:12px;padding:.4rem;box-shadow:0 14px 34px rgba(0,0,0,.4);
    opacity:0;visibility:hidden;transform:translateY(-8px);
    transition:opacity .2s ease,transform .2s ease,visibility .2s ease}
  .nav-toggle[aria-expanded="true"] ~ .nav-links{opacity:1;visibility:visible;transform:translateY(0)}
  .nav-links>a{font-size:.85rem;letter-spacing:.05em;padding:.78rem .85rem;width:100%;text-align:left;border-radius:8px}
  .nav-links>a.is-active{color:var(--accent)}
  .nav-links>a.is-active::after{display:none}

  /* Home mobile : remonter légèrement le logo vape + bouton Entrée */
  .splash-center{transform:translateY(-7%)}
  .hero{min-height:88vh}
  /* Filtre hero plus sombre sur mobile (meilleure lisibilité du texte) */
  .hero-overlay{background:linear-gradient(180deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.76) 40%,rgba(0,0,0,.91) 100%)}
  .theme-nature .hero-overlay{background:linear-gradient(180deg,rgba(12,18,14,.82) 0%,rgba(12,18,14,.74) 40%,rgba(12,18,14,.91) 100%)}
  /* Titre mobile agrandi : "Faubourg" sur la 1re ligne, le reste sur la 2e */
  .hero-title{white-space:normal;font-size:clamp(2.5rem,12vw,3.8rem)}
  .hero-title .t-word,.hero-title .t-rest{display:block}
  /* Bloc titre/sous-titre/description légèrement descendu sur mobile */
  .hero-head{transform:translateY(5vh)}
  .hero-bottom{gap:1.1rem}
  .gallery-grid{columns:1}
  .foot-grid{grid-template-columns:1fr}
  .fab-call{display:flex}
}
@media(min-width:681px){
  .catalogue .fab-call{display:none}
}
