/* FILE: /assets/css/app.css */

/* =========================================
   THEME: Bleu institutionnel premium
   - Réécriture complète
   - Même structure de classes
   - Palette bleu / blanc / verre froid
========================================= */

:root{
  --bg0:#06101d;
  --bg1:#0c1b30;
  --bg2:#102743;

  --ink:#f4f8ff;
  --muted:rgba(220,232,248,.78);
  --mutedSoft:rgba(220,232,248,.58);
  --stroke:rgba(158,190,230,.16);
  --strokeStrong:rgba(158,190,230,.26);

  --brand:#4f8fdf;
  --brand2:#2f6fc8;
  --accent:#89c2ff;
  --accentSoft:rgba(137,194,255,.18);

  --ok:#63b3ff;
  --err:#7aa8ff;

  --panel:rgba(255,255,255,.055);
  --panelSoft:rgba(255,255,255,.038);
  --panelDark:rgba(7,18,32,.42);

  --shadow:0 18px 60px rgba(0,12,28,.42);
  --shadowSoft:0 12px 34px rgba(0,10,24,.28);

  --r:18px;
  --max:1280px;
  --pad:24px;
  --padSm:16px;
  --navH:78px;
}

/* =========================================
   Reset
========================================= */
*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  color:var(--ink);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  overflow-x:hidden;
  position:relative;

  background:
    radial-gradient(1200px 700px at 18% 12%, rgba(137,194,255,.10), transparent 62%),
    radial-gradient(1000px 620px at 82% 18%, rgba(79,143,223,.09), transparent 64%),
    radial-gradient(1100px 760px at 50% 100%, rgba(47,111,200,.08), transparent 68%),
    linear-gradient(180deg, #102743 0%, #0c1b30 42%, #081423 72%, #06101d 100%);

  background-attachment: fixed, fixed, fixed, fixed;
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
  background-size: auto, auto, auto, 100% 100%;
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  opacity:.035;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.08) 0, transparent 22%),
    radial-gradient(circle at 80% 30%, rgba(255,255,255,.05) 0, transparent 18%),
    radial-gradient(circle at 40% 75%, rgba(255,255,255,.04) 0, transparent 20%);
}

.container{
  width:min(var(--max), 100%);
  margin:0 auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}

.container.isWide{ max-width:1420px; }

@media (max-width:680px){
  .container{
    padding-left:var(--padSm);
    padding-right:var(--padSm);
  }
}

/* =========================================
   Background FX canvas
========================================= */
#bgFxCanvas{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  z-index:0;
  pointer-events:none;
  opacity:.34;
}

main,
footer,
.hero,
.heroPage,
.navMobile{
  position:relative;
  z-index:2;
}

/* =========================================
   Buttons
========================================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.85rem 1.05rem;
  border-radius:14px;
  border:1px solid var(--stroke);
  color:var(--ink);
  text-decoration:none;
  background:rgba(255,255,255,.055);
  backdrop-filter:blur(12px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
  transition:
    transform .18s ease,
    background .18s ease,
    border-color .18s ease,
    box-shadow .18s ease;
}

.btn:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.08);
  border-color:var(--strokeStrong);
  box-shadow:0 10px 24px rgba(0,14,34,.18);
}

.btnGhost{
  background:rgba(255,255,255,.04);
}

.btnPrimary{
  border-color:rgba(137,194,255,.28);
  background:linear-gradient(135deg, rgba(79,143,223,.34), rgba(47,111,200,.26));
  box-shadow:
    0 14px 34px rgba(47,111,200,.16),
    0 8px 22px rgba(79,143,223,.12),
    inset 0 1px 0 rgba(255,255,255,.08);
}

.btnPrimary:hover{
  border-color:rgba(137,194,255,.40);
  background:linear-gradient(135deg, rgba(79,143,223,.42), rgba(47,111,200,.34));
}

/* =========================================
   NAV
========================================= */
.navWrap{
  position:sticky;
  top:0;
  z-index:2000;
  height:var(--navH);
  overflow:visible;
}

.navBlur{
  position:absolute;
  inset:0;
  background:rgba(8,18,32,.62);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(158,190,230,.10);
  z-index:0;
}

.navWrap .container{
  position:relative;
  z-index:2;
  height:var(--navH);
  display:flex;
  align-items:center;
  gap:16px;
  overflow:visible;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:var(--ink);
}

.brandMark{
  width:14px;
  height:14px;
  border-radius:6px;
  background:linear-gradient(135deg, var(--accent), var(--brand2));
  box-shadow:0 0 0 4px rgba(137,194,255,.10);
}

.brandText{
  font-weight:800;
  letter-spacing:.08em;
  font-size:.86rem;
  opacity:.96;
}

.nav{
  margin-left:auto;
  display:flex;
  gap:18px;
  align-items:center;
  overflow:visible;
}

.nav a{
  color:rgba(230,239,250,.80);
  text-decoration:none;
  font-weight:650;
  font-size:.92rem;
  transition:color .18s ease, opacity .18s ease;
}

.nav a:hover{
  color:var(--ink);
}

.navActions{
  margin-left:auto;
  display:flex;
  gap:10px;
  align-items:center;
}

.navBurger{
  display:none;
  background:transparent;
  border:0;
  color:var(--ink);
  font-size:1.4rem;
  cursor:pointer;
}

/* Dropdown */
.navDrop{
  position:relative;
  display:flex;
  align-items:center;
  overflow:visible;
}

.navDrop::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:100%;
  height:18px;
}

.navDropLink{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:0;
  margin:0;
  height:auto;
}

.navDrop .caret{
  opacity:.76;
  font-size:.9em;
  transform:translateY(-1px);
}

.navDropMenu{
  position:absolute;
  top:calc(100% + 2px);
  left:50%;
  transform:translateX(-50%) translateY(6px);
  min-width:240px;
  padding:10px;
  border-radius:16px;
  border:1px solid rgba(158,190,230,.16);
  background:rgba(8,20,36,.94);
  backdrop-filter:blur(16px);
  box-shadow:0 18px 60px rgba(0,10,24,.45);
  opacity:0;
  visibility:hidden;
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
  z-index:2100;
}

.navDropMenu::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:-10px;
  height:10px;
}

.navDropMenu a{
  display:flex;
  padding:10px 10px;
  border-radius:12px;
  color:rgba(237,244,255,.90);
  text-decoration:none;
  font-weight:700;
  font-size:.92rem;
}

.navDropMenu a:hover{
  background:rgba(255,255,255,.06);
  color:var(--ink);
}

.navDropSep{
  height:1px;
  margin:6px 8px;
  background:rgba(158,190,230,.14);
}

.navDropStrong{
  border:1px solid rgba(158,190,230,.14);
  background:rgba(255,255,255,.03);
}

.navDrop:hover .navDropMenu,
.navDrop:focus-within .navDropMenu{
  opacity:1;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
}

/* Mobile drawer */
.navMobile{
  position:fixed;
  inset:var(--navH) 0 auto 0;
  z-index:1900;
  padding:12px 14px 18px;
  background:rgba(7,17,31,.66);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(158,190,230,.10);
}

.navMobileInner{
  border-radius:18px;
  border:1px solid rgba(158,190,230,.14);
  background:linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  box-shadow:0 22px 70px rgba(0,10,24,.50);
  overflow:hidden;
}

.navMobileHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 14px;
  border-bottom:1px solid rgba(158,190,230,.10);
  background:rgba(5,12,22,.24);
}

.navMobileTitle{
  font-weight:900;
  letter-spacing:.08em;
  font-size:.82rem;
  opacity:.92;
  text-transform:uppercase;
}

.navClose{
  border:1px solid rgba(158,190,230,.16);
  background:rgba(255,255,255,.04);
  color:var(--ink);
  border-radius:12px;
  padding:8px 10px;
  cursor:pointer;
}

.navMItem{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  color:rgba(236,244,255,.92);
  text-decoration:none;
  border-bottom:1px solid rgba(158,190,230,.06);
}

.navMItem:hover{
  background:rgba(255,255,255,.04);
}

.navMIco{
  width:28px;
  height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  border:1px solid rgba(158,190,230,.12);
  background:rgba(5,12,22,.22);
  font-size:14px;
}

.navMDetails{
  border-bottom:1px solid rgba(158,190,230,.06);
}

.navMDetails > summary{
  cursor:pointer;
  list-style:none;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  color:rgba(236,244,255,.92);
  font-weight:850;
}

.navMDetails > summary::-webkit-details-marker{ display:none; }

.navMCaret{
  margin-left:auto;
  opacity:.8;
}

.navMSub{
  padding:6px 8px 10px;
  background:rgba(0,0,0,.10);
}

.navMSubItem{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 10px;
  margin:6px 6px 0;
  border-radius:14px;
  text-decoration:none;
  color:rgba(236,244,255,.90);
  border:1px solid rgba(158,190,230,.08);
  background:rgba(255,255,255,.03);
}

.navMSubItem:hover{
  background:rgba(255,255,255,.05);
}

.navMIcoSm{
  width:26px;
  height:26px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  border:1px solid rgba(158,190,230,.10);
  background:rgba(5,12,22,.20);
  font-size:13px;
}

.navMSep{
  height:1px;
  margin:10px 14px 2px;
  background:rgba(158,190,230,.10);
}

.navMSubStrong{
  border-color:rgba(137,194,255,.24);
  background:linear-gradient(135deg, rgba(79,143,223,.14), rgba(47,111,200,.10));
}

.navMobileFoot{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  padding:12px 14px 14px;
  border-top:1px solid rgba(158,190,230,.10);
  background:rgba(0,0,0,.10);
}

.navMBtn{ width:100%; }

/* =========================================
   HERO
========================================= */
.hero{
  position:relative;
  overflow:hidden;
  min-height:clamp(560px, 72vh, 760px);
}

.heroVideo .heroVideoMedia{
  position:absolute;
  inset:0;
  overflow:hidden;
  background:#000;
  z-index:0;
  pointer-events:none;
}

.heroVideo .heroVideoIframe{
  position:absolute;
  top:50%;
  left:50%;
  width:100vw;
  height:56.25vw;
  min-width:100%;
  min-height:100%;
  transform:translate(-50%, -50%);
  border:0;
  filter:saturate(1.03) contrast(1.04);
}

.hero::before,
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
}

.hero::before{
  z-index:1;
  background:
    radial-gradient(900px 520px at 22% 28%, rgba(137,194,255,.13), transparent 62%),
    radial-gradient(980px 560px at 78% 22%, rgba(79,143,223,.12), transparent 64%),
    linear-gradient(180deg, rgba(6,16,29,.08), rgba(6,16,29,.74));
}

.hero::after{
  z-index:2;
  opacity:.09;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

.heroFx{
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  opacity:.75;
}

#fxCanvas{
  width:100%;
  height:100%;
  display:block;
}

.heroInner{
  position:relative;
  z-index:4;
  padding:clamp(50px, 8vh, 92px) 0;
}

.heroGlass{
  width:min(680px, 100%);
  border-radius:22px;
  border:1px solid rgba(158,190,230,.15);
  background:linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.035));
  box-shadow:var(--shadow);
  padding:26px 26px 20px;
  backdrop-filter:blur(18px);
}

.kicker{
  font-weight:700;
  letter-spacing:.18em;
  font-size:.72rem;
  color:rgba(225,237,252,.76);
  text-transform:uppercase;
}

.lead{
  margin:0 0 16px;
  color:var(--muted);
  line-height:1.6;
  font-size:1.02rem;
}

.heroCtas{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:14px 0 10px;
}

.heroBadges{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}

.badge{
  border:1px solid rgba(158,190,230,.15);
  background:rgba(255,255,255,.045);
  padding:.45rem .65rem;
  border-radius:999px;
  font-weight:650;
  font-size:.86rem;
  color:rgba(236,243,255,.90);
}

.heroStrip{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
}

.stripCard{
  position:relative;
  padding:14px 14px;
  border-radius:18px;
  border:1px solid rgba(158,190,230,.15);
  background:linear-gradient(135deg, rgba(255,255,255,.09), rgba(255,255,255,.03));
  backdrop-filter:blur(16px);
  box-shadow:0 16px 46px rgba(0,10,24,.28);
  text-decoration:none;
  color:var(--ink);
  overflow:hidden;
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}

.stripCard:hover{
  transform:translateY(-2px);
  border-color:rgba(137,194,255,.24);
  background:linear-gradient(135deg, rgba(255,255,255,.11), rgba(8,18,32,.08));
}

.stripTag{
  display:inline-flex;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.70rem;
  opacity:.82;
}

.stripCard b{
  display:block;
  margin-top:6px;
  line-height:1.2;
}

.stripGo{
  display:inline-block;
  margin-top:10px;
  font-weight:900;
  opacity:.9;
}

/* =========================================
   Reveal animation
========================================= */
.reveal{
  opacity:0;
  transform:translateY(14px) scale(.992);
  filter:blur(6px);
  transition:opacity .70s ease, transform .70s ease, filter .70s ease;
  will-change:opacity, transform, filter;
}

.reveal.is-in{
  opacity:1;
  transform:translateY(0) scale(1);
  filter:blur(0);
}

body.is-leaving{
  opacity:0;
  transform:translateY(8px) scale(.995);
  transition:opacity .28s ease, transform .28s ease;
}

/* =========================================
   Sections / layout
========================================= */
.section{ padding:44px 0; }
.homeSection{ padding:34px 0; }

.secHead{ margin-bottom:14px; }

.secHead h2{
  margin:0 0 6px;
  font-size:1.55rem;
  letter-spacing:.01em;
}

.secFoot{ margin-top:14px; }

.grid3{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}

.card{
  position:relative;
  border-radius:18px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(255,255,255,.04);
  padding:18px;
  text-decoration:none;
  color:var(--ink);
  overflow:hidden;
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}

.card:hover{
  transform:translateY(-2px);
  border-color:rgba(137,194,255,.24);
  background:rgba(255,255,255,.05);
}

.card h3{
  margin:0 0 8px;
  position:relative;
}

.card p{
  margin:0;
  color:var(--muted);
  position:relative;
}

.cardMedia{
  padding:18px;
  min-height:230px;
}

.cardMediaBg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  transform:scale(1.02);
  filter:saturate(1.03) contrast(1.04);
}

.cardMediaShade{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(4,10,18,.08), rgba(4,10,18,.74));
}

.cardMedia h3,
.cardMedia p,
.cardMedia .chip{
  position:relative;
}

.chip{
  position:relative;
  display:inline-flex;
  margin-top:12px;
  padding:.5rem .7rem;
  border-radius:999px;
  border:1px solid rgba(158,190,230,.15);
  background:rgba(5,12,22,.24);
  font-weight:800;
  color:var(--ink);
}

.split{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:14px;
  align-items:stretch;
}

.glassPanel{
  border-radius:18px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(255,255,255,.045);
  padding:18px;
  box-shadow:var(--shadowSoft);
}

.imageFrame{
  border-radius:18px;
  border:1px solid rgba(158,190,230,.14);
  background-size:cover;
  background-position:center;
  min-height:240px;
  box-shadow:var(--shadowSoft);
}

.miniStats{
  display:flex;
  gap:14px;
  margin-top:12px;
  flex-wrap:wrap;
}

.miniStats div{
  border:1px solid rgba(158,190,230,.12);
  border-radius:14px;
  padding:10px 12px;
  background:rgba(6,16,29,.20);
}

.miniStats b{
  display:block;
  font-size:1.2rem;
}

.miniStats span{
  color:var(--muted);
  font-size:.92rem;
}

.homeLinks{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

.homePill{
  display:inline-flex;
  padding:.55rem .75rem;
  border-radius:999px;
  border:1px solid rgba(158,190,230,.15);
  background:rgba(255,255,255,.045);
  color:rgba(240,246,255,.94);
  text-decoration:none;
  font-weight:800;
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}

.homePill:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.065);
  border-color:rgba(137,194,255,.22);
}

.featGrid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
}

.featCard{
  position:relative;
  border-radius:18px;
  border:1px solid rgba(158,190,230,.14);
  background:linear-gradient(135deg, rgba(255,255,255,.06), rgba(6,16,29,.18));
  padding:14px 14px;
  text-decoration:none;
  color:var(--ink);
  overflow:hidden;
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}

.featCard::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:radial-gradient(420px 220px at var(--mx, 40%) var(--my, 30%), rgba(137,194,255,.16), transparent 60%);
  opacity:0;
  transition:opacity .18s ease;
}

.featCard:hover{
  transform:translateY(-2px);
  border-color:rgba(137,194,255,.24);
}

.featCard:hover::before{
  opacity:1;
}

.featIco{
  width:34px;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(6,16,29,.22);
  margin-bottom:10px;
}

.featTxt{
  display:block;
  margin-top:6px;
  color:var(--muted);
  font-weight:650;
}

.featGo{
  position:absolute;
  right:14px;
  bottom:12px;
  font-weight:900;
  opacity:.85;
}

.homeStats{
  margin:18px 0 6px;
  border-radius:22px;
  border:1px solid rgba(158,190,230,.14);
  background:linear-gradient(135deg, rgba(79,143,223,.10), rgba(47,111,200,.07), rgba(255,255,255,.03));
  overflow:hidden;
}

.homeStatsInner{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:10px;
  padding:14px;
}

.statBox{
  border-radius:18px;
  border:1px solid rgba(158,190,230,.12);
  background:rgba(6,16,29,.18);
  padding:14px 14px;
}

.statNum{
  display:block;
  font-size:1.8rem;
  letter-spacing:.02em;
}

.statBox span{
  color:var(--muted);
  font-weight:700;
}

.galleryMini{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:10px;
}

.gMini{
  position:relative;
  border-radius:18px;
  border:1px solid rgba(158,190,230,.14);
  min-height:140px;
  background-size:cover;
  background-position:center;
  overflow:hidden;
  transition:transform .18s ease, border-color .18s ease, filter .18s ease;
}

.gMiniShade{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(4,10,18,.04), rgba(4,10,18,.56));
  opacity:.64;
  transition:opacity .18s ease;
}

.gMini:hover{
  transform:translateY(-2px) scale(1.01);
  border-color:rgba(137,194,255,.22);
  filter:saturate(1.04) contrast(1.04);
}

.gMini:hover .gMiniShade{
  opacity:.34;
}

.quickBar{
  margin:22px 0 10px;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:10px;
}

.qBtn{
  border-radius:16px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(255,255,255,.045);
  padding:14px 14px;
  text-decoration:none;
  color:var(--ink);
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:space-between;
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}

.qBtn:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.065);
  border-color:rgba(158,190,230,.20);
}

.qBtnStrong{
  border-color:rgba(137,194,255,.26);
  background:linear-gradient(135deg, rgba(79,143,223,.12), rgba(47,111,200,.10));
}

.welcomeDir{ margin-top:18px; }

.welcomeGrid{
  display:grid;
  grid-template-columns:3fr 9fr;
  gap:14px;
  align-items:stretch;
}

.welcomePhoto{
  border-radius:18px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(255,255,255,.04);
  overflow:hidden;
}

.welcomePhotoFrame{
  width:100%;
  aspect-ratio:4 / 5;
  background-size:cover;
  background-position:center;
  filter:saturate(1.03) contrast(1.04);
  transform:scale(1.02);
}

.welcomeMeta{
  padding:12px 12px 14px;
  border-top:1px solid rgba(158,190,230,.10);
  background:rgba(6,16,29,.18);
}

.welcomeMeta b{
  display:block;
  font-size:1.02rem;
}

.welcomeMeta span{
  display:block;
  color:var(--muted);
  margin-top:4px;
  font-size:.92rem;
}

.welcomeText{
  border-radius:18px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(255,255,255,.04);
  overflow:hidden;
}

.welcomePaper{
  padding:16px 16px 14px;
  background:
    radial-gradient(900px 420px at 12% 18%, rgba(137,194,255,.08), transparent 60%),
    radial-gradient(820px 420px at 88% 18%, rgba(79,143,223,.08), transparent 62%),
    rgba(255,255,255,.02);
}

.welcomePaper p{
  margin:0;
  color:rgba(239,245,255,.90);
  line-height:1.72;
  font-size:1.02rem;
}

.welcomeActions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

/* =========================================
   Footer
========================================= */
.footer{
  margin-top:30px;
  padding:28px 0;
  border-top:1px solid rgba(158,190,230,.10);
  background:rgba(5,12,22,.18);
  backdrop-filter:blur(10px);
}

.footerGrid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr;
  gap:16px;
}

.footerTitle{
  font-weight:800;
  margin-bottom:10px;
}

.footerMuted{
  color:var(--muted);
  margin:6px 0;
}

.footer a{
  display:block;
  color:rgba(230,240,252,.84);
  text-decoration:none;
  margin:6px 0;
}

.footer a:hover{
  color:var(--ink);
}

.footerBottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-top:12px;
  color:rgba(220,232,248,.72);
}

.adminLink{
  color:rgba(137,194,255,.96);
  text-decoration:none;
}

/* =========================================
   HERO image pages
========================================= */
.hero .heroMedia{
  position:absolute;
  inset:0;
  z-index:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  transform:scale(1.03);
  filter:saturate(1.03) contrast(1.04);
}

.heroAbout::before{
  background:
    radial-gradient(900px 520px at 18% 22%, rgba(137,194,255,.12), transparent 62%),
    radial-gradient(980px 560px at 80% 18%, rgba(79,143,223,.12), transparent 64%),
    linear-gradient(180deg, rgba(6,16,29,.08), rgba(6,16,29,.76));
}

.heroAbout .heroFx{ z-index:2; }
.heroAbout .heroInner{ z-index:4; }

/* =========================================
   About page
========================================= */
.aboutIndex{ padding:10px 0 22px; }

.aboutPills{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.aboutPill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:.6rem .8rem;
  border-radius:999px;
  border:1px solid rgba(158,190,230,.15);
  background:rgba(255,255,255,.045);
  backdrop-filter:blur(12px);
  color:rgba(239,245,255,.92);
  text-decoration:none;
  font-weight:850;
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}

.aboutPill span{
  opacity:.85;
  font-weight:900;
}

.aboutPill:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.065);
  border-color:rgba(137,194,255,.22);
}

.aboutVideo{ padding:10px 0 28px; }

.videoCard{
  border-radius:22px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(255,255,255,.045);
  overflow:hidden;
  box-shadow:var(--shadow);
}

.videoRatio{
  position:relative;
  width:100%;
  aspect-ratio:16 / 9;
  background:rgba(0,0,0,.24);
}

.videoRatio iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}

.aboutBlock{ padding:34px 0; }
.aboutBlock.isAlt{ padding:34px 0; }

.aboutGrid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:14px;
  align-items:stretch;
}

.aboutMedia{
  position:relative;
  border-radius:22px;
  border:1px solid rgba(158,190,230,.14);
  overflow:hidden;
  min-height:320px;
  background:rgba(255,255,255,.03);
}

.aboutImg{
  position:absolute;
  inset:-8px;
  background-size:cover;
  background-position:center;
  transform:translateY(0) scale(1.06);
  filter:saturate(1.04) contrast(1.04);
}

.aboutImgShade{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(4,10,18,.08), rgba(4,10,18,.74));
}

.aboutImgTag{
  position:absolute;
  left:14px;
  top:14px;
  z-index:3;
}

.aboutImgTag span{
  display:inline-flex;
  padding:.45rem .65rem;
  border-radius:999px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(5,12,22,.24);
  font-weight:900;
  letter-spacing:.08em;
  font-size:.72rem;
  text-transform:uppercase;
  opacity:.92;
}

.aboutCopy{
  border-radius:22px;
  border:1px solid rgba(158,190,230,.14);
  background:linear-gradient(135deg, rgba(255,255,255,.06), rgba(6,16,29,.16));
  padding:18px;
}

.aboutKicker{
  font-weight:850;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.72rem;
  color:rgba(225,237,252,.76);
}

.aboutTitle{
  margin:10px 0 8px;
  font-size:1.6rem;
}

.aboutText{
  margin:0;
  color:var(--muted);
  line-height:1.72;
  font-size:1.02rem;
}

.aboutActions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

/* =========================================
   Forms
========================================= */
.pageHead{
  margin:8px 0 18px;
}

.pageHead h1{
  margin:0 0 8px;
  font-size:clamp(28px, 3.2vw, 44px);
  letter-spacing:.01em;
}

.muted{ color:var(--muted); }

.alert{
  border-radius:16px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(255,255,255,.05);
  padding:12px 14px;
  margin:12px 0 16px;
  backdrop-filter:blur(12px);
}

.alert.ok{
  border-color:rgba(99,179,255,.26);
  background:linear-gradient(135deg, rgba(99,179,255,.14), rgba(255,255,255,.03));
}

.alert.err{
  border-color:rgba(122,168,255,.26);
  background:linear-gradient(135deg, rgba(122,168,255,.14), rgba(255,255,255,.03));
}

.formGlass{
  border-radius:22px;
  border:1px solid rgba(158,190,230,.14);
  background:linear-gradient(135deg, rgba(255,255,255,.07), rgba(6,16,29,.16));
  box-shadow:var(--shadow);
  padding:18px;
  backdrop-filter:blur(16px);
}

.formGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px 14px;
  align-items:start;
}

.formGrid label{
  display:flex;
  flex-direction:column;
  gap:8px;
  font-weight:800;
  color:rgba(239,245,255,.94);
  font-size:.95rem;
}

.formGrid input,
.formGrid select,
.formGrid textarea{
  width:100%;
  border-radius:14px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(6,16,29,.34);
  color:var(--ink);
  padding:.78rem .9rem;
  outline:none;
  font:inherit;
  transition:border-color .18s ease, background .18s ease, transform .18s ease, box-shadow .18s ease;
}

.formGrid input::placeholder,
.formGrid textarea::placeholder{
  color:rgba(220,232,248,.48);
}

.formGrid input:focus,
.formGrid select:focus,
.formGrid textarea:focus{
  border-color:rgba(137,194,255,.30);
  background:rgba(6,16,29,.48);
  box-shadow:0 0 0 3px rgba(137,194,255,.08);
}

.formGrid textarea{
  resize:vertical;
  min-height:120px;
}

.formGrid .span2{
  grid-column:1 / -1;
}

.formActions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
  align-items:center;
}

.formGrid input[type="date"],
.formGrid select{
  color-scheme:dark;
}

/* =========================================
   Compat new public pages
========================================= */
.heroPage{
  position:relative;
  overflow:hidden;
  min-height:clamp(380px, 58vh, 620px);
}

.heroPageMedia{
  position:absolute;
  inset:0;
  z-index:0;
  background:#0b1422;
}

.heroPageMedia img,
.heroPageMedia video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.heroPageOverlay{
  position:relative;
  z-index:2;
  min-height:inherit;
  display:flex;
  align-items:flex-end;
  padding:clamp(44px, 8vh, 92px) 0 42px;
  background:
    radial-gradient(900px 520px at 20% 20%, rgba(137,194,255,.12), transparent 62%),
    radial-gradient(980px 560px at 82% 18%, rgba(79,143,223,.12), transparent 64%),
    linear-gradient(180deg, rgba(6,16,29,.14), rgba(6,16,29,.80));
}

.heroPageOverlay .container{
  position:relative;
}

.heroPageOverlay h1{
  margin:0 0 12px;
  font-size:clamp(2rem, 4vw, 4rem);
  line-height:1.06;
  color:var(--ink);
}

.heroPageOverlay p{
  margin:0;
  max-width:760px;
  color:var(--muted);
  line-height:1.8;
  font-size:1.03rem;
}

.heroKicker{
  margin-bottom:10px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:.75rem;
  color:rgba(225,237,252,.78);
}

.contentCard{
  border-radius:22px;
  border:1px solid rgba(158,190,230,.14);
  background:linear-gradient(135deg, rgba(255,255,255,.07), rgba(6,16,29,.16));
  box-shadow:var(--shadow);
  padding:18px;
  backdrop-filter:blur(14px);
}

.form-group{ margin-bottom:14px; }

.form-label{
  display:block;
  margin-bottom:8px;
  font-weight:800;
  color:rgba(239,245,255,.94);
}

.form-control,
.form-select,
input.form-control,
select.form-control,
textarea.form-control{
  width:100%;
  border-radius:14px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(6,16,29,.34);
  color:var(--ink);
  padding:.78rem .9rem;
  outline:none;
  font:inherit;
  transition:border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

.form-control:focus,
.form-select:focus,
input.form-control:focus,
select.form-control:focus,
textarea.form-control:focus{
  border-color:rgba(137,194,255,.30);
  background:rgba(6,16,29,.48);
  box-shadow:0 0 0 3px rgba(137,194,255,.08);
}

.form-control::placeholder,
textarea.form-control::placeholder{
  color:rgba(220,232,248,.48);
}

textarea.form-control{
  resize:vertical;
  min-height:120px;
}

.row{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.col-md-6,
.col-md-4,
.col-md-3,
.col-md-8{
  min-width:0;
}

.mb-3{ margin-bottom:14px; }

.featCard > div[style*="background:url"]{
  border-top-left-radius:18px;
  border-top-right-radius:18px;
}

.section .secHead h1,
.section .secHead h2{
  margin-top:0;
}

.contentCard a,
.alert a{
  color:var(--accent);
}

/* =========================================
   Reservation page tuning
========================================= */
.reservationPage{
  padding-top:34px;
  padding-bottom:60px;
}

.reservationHead{
  margin-bottom:20px;
}

.reservationCardsGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  margin-bottom:30px;
}

.reservationTypeCard{
  position:relative;
  border-radius:22px;
  border:1px solid rgba(158,190,230,.14);
  background:linear-gradient(135deg, rgba(255,255,255,.07), rgba(6,16,29,.18));
  box-shadow:0 18px 48px rgba(0,10,24,.34);
  overflow:hidden;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
  backdrop-filter:blur(14px);
}

.reservationTypeCard:hover{
  transform:translateY(-3px);
  border-color:rgba(137,194,255,.22);
  box-shadow:0 24px 60px rgba(0,10,24,.42);
}

.reservationTypeMedia{
  height:220px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

.reservationTypeBody{
  padding:18px;
}

.reservationTypeTop{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}

.reservationTypeTop h3{
  margin:0;
  font-size:1.08rem;
  line-height:1.28;
  color:var(--ink);
}

.reservationTypeDesc{
  margin:0 0 14px;
  color:rgba(220,232,248,.74);
  line-height:1.6;
  min-height:68px;
}

.reservationTypeMeta{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.reservationTypeLabel{
  font-size:.85rem;
  color:rgba(220,232,248,.60);
}

.reservationTypePrice{
  font-size:1.12rem;
  font-weight:900;
  color:#9bcbff;
}

.reservationTypeCapacity{
  color:rgba(220,232,248,.76);
  font-size:.94rem;
}

.reservationTypeCapacity strong{
  color:var(--ink);
}

.reservationAlertBox{
  margin-bottom:16px;
}

.reservationFormWide{
  width:100%;
  max-width:100%;
  margin:0;
  padding:22px;
}

.reservationFormGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px 16px;
}

.reservationSpan3{
  grid-column:1 / -1;
}

.reservationFormActions{
  margin-top:18px;
  display:flex;
  justify-content:flex-start;
  align-items:center;
  gap:10px;
}

.reservationFormWide .form-label{
  margin-bottom:8px;
  font-size:.94rem;
  font-weight:800;
  color:rgba(239,245,255,.94);
}

.reservationFormWide .form-control,
.reservationFormWide select.form-control,
.reservationFormWide textarea.form-control{
  min-height:48px;
  border-radius:14px;
  border:1px solid rgba(158,190,230,.14);
  background:rgba(6,16,29,.38);
  color:var(--ink);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}

.reservationFormWide textarea.form-control{
  min-height:130px;
}

.reservationFormWide .form-control:focus,
.reservationFormWide select.form-control:focus,
.reservationFormWide textarea.form-control:focus{
  border-color:rgba(137,194,255,.30);
  background:rgba(6,16,29,.52);
  box-shadow:0 0 0 3px rgba(137,194,255,.08);
}

.reservationFormWide .form-control::placeholder,
.reservationFormWide textarea.form-control::placeholder{
  color:rgba(220,232,248,.46);
}

/* =========================================
   Responsive
========================================= */
@media (max-width:980px){
  :root{ --navH:66px; }

  body{
    background:
      radial-gradient(900px 520px at 20% 12%, rgba(137,194,255,.08), transparent 60%),
      radial-gradient(820px 520px at 80% 18%, rgba(79,143,223,.07), transparent 62%),
      linear-gradient(180deg, #0d2038 0%, #091728 52%, #06101d 100%);
    background-attachment:scroll, scroll, scroll;
    background-repeat:no-repeat, no-repeat, no-repeat;
    background-size:auto, auto, 100% 100%;
  }

  body::before{
    opacity:.018;
  }

  #bgFxCanvas{
    opacity:.14;
  }

  .nav{ display:none; }
  .navBurger{ display:block; }

  .navCtaDesktop{ display:none !important; }
  .navWrap .container{ gap:10px; }
  .brandText{ font-size:.78rem; letter-spacing:.06em; }
  .navLang{ padding:.65rem .85rem; border-radius:999px; }

  .navBlur{
    background:rgba(5,12,22,.86);
    border-bottom:1px solid rgba(158,190,230,.14);
    backdrop-filter:blur(12px);
  }

  .hero{ min-height:620px; }
  .heroInner{ padding:44px 0 26px; }

  .heroGlass,
  .contentCard,
  .glassPanel,
  .welcomeText,
  .welcomePhoto,
  .aboutCopy,
  .videoCard,
  .formGlass,
  .reservationTypeCard,
  .reservationFormWide,
  .homeStats,
  .statBox,
  .card,
  .featCard,
  .qBtn,
  .stripCard{
    background:linear-gradient(180deg, rgba(9,22,38,.92), rgba(6,16,29,.94)) !important;
    border-color:rgba(158,190,230,.18) !important;
    box-shadow:0 10px 28px rgba(0,8,20,.32) !important;
    backdrop-filter:none !important;
  }

  .heroGlass{
    padding:18px 16px 14px;
    border-radius:18px;
  }

  .heroGlass h1{
    font-size:30px;
    line-height:1.08;
  }

  .lead,
  .muted,
  .card p,
  .featTxt,
  .aboutText,
  .welcomePaper p,
  .reservationTypeDesc,
  .reservationTypeCapacity,
  .reservationTypeLabel,
  .footerMuted,
  .footerBottom,
  .heroPageOverlay p{
    color:rgba(228,238,250,.88) !important;
  }

  .badge,
  .chip,
  .homePill,
  .aboutPill{
    background:rgba(255,255,255,.08) !important;
    border-color:rgba(158,190,230,.18) !important;
    color:#f3f8ff !important;
  }

  .form-control,
  .form-select,
  input.form-control,
  select.form-control,
  textarea.form-control,
  .reservationFormWide .form-control,
  .reservationFormWide select.form-control,
  .reservationFormWide textarea.form-control{
    background:rgba(3,10,18,.84) !important;
    border-color:rgba(158,190,230,.18) !important;
    color:#f4f8ff !important;
  }

  .form-control::placeholder,
  textarea.form-control::placeholder,
  .reservationFormWide .form-control::placeholder,
  .reservationFormWide textarea.form-control::placeholder{
    color:rgba(214,226,243,.58) !important;
  }

  .footer{
    background:rgba(5,12,22,.74);
    backdrop-filter:none;
  }

  .heroStrip{ grid-template-columns:1fr; }
  .grid3{ grid-template-columns:1fr; }
  .split{ grid-template-columns:1fr; }
  .footerGrid{ grid-template-columns:1fr; }
  .featGrid{ grid-template-columns:1fr; }
  .homeStatsInner{ grid-template-columns:repeat(2, 1fr); }
  .galleryMini{ grid-template-columns:repeat(2, 1fr); }
  .quickBar{ grid-template-columns:1fr 1fr; }
  .welcomeGrid{ grid-template-columns:1fr; }
  .welcomePhotoFrame{ aspect-ratio:16 / 10; }
  .aboutGrid{ grid-template-columns:1fr; }
  .aboutMedia{ min-height:240px; }
  .formGrid{ grid-template-columns:1fr; }
  .formGrid .span2{ grid-column:auto; }
  .row{ grid-template-columns:1fr; }
}






@media (max-width:1180px){
  .reservationCardsGrid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .reservationFormGrid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width:760px){
  .reservationCardsGrid{ grid-template-columns:1fr; }
  .reservationFormGrid{ grid-template-columns:1fr; }
  .reservationSpan3{ grid-column:auto; }
  .reservationFormWide{ padding:16px; }
  .reservationTypeMedia{ height:200px; }
}


/* FILE: /assets/css/app.css */

@media (max-width:980px){
  .reveal{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
  }

  .heroPageOverlay{
    background:
      radial-gradient(700px 360px at 20% 18%, rgba(137,194,255,.10), transparent 58%),
      linear-gradient(180deg, rgba(5,12,22,.34), rgba(5,12,22,.84));
  }

  .heroPageOverlay h1,
  .heroGlass h1,
  .secHead h2,
  .card h3,
  .featCard b,
  .welcomeMeta b,
  .aboutTitle,
  .statNum,
  .qBtn,
  .stripCard b,
  .footerTitle{
    color:#f4f8ff !important;
  }

  .cardMediaShade,
  .aboutImgShade,
  .gMiniShade{
    background:linear-gradient(180deg, rgba(4,10,18,.10), rgba(4,10,18,.78)) !important;
  }

  .welcomePaper{
    background:
      radial-gradient(700px 320px at 12% 16%, rgba(137,194,255,.06), transparent 60%),
      rgba(8,18,32,.92) !important;
  }

  .navMobile,
  .navMobileInner{
    background:rgba(5,12,22,.96) !important;
  }
}







/* FILE: /assets/css/app.css */

/* =========================================
   MOBILE HARD OVERRIDE
   - corrige le fond général
   - assombrit les cartes et sections
   - neutralise les restes desktop
========================================= */
@media (max-width:980px){

  html,
  body{
    background-color:#07111d !important;
  }

  body{
    color:var(--ink);
    background:
      radial-gradient(900px 540px at 18% 10%, rgba(137,194,255,.10), transparent 58%),
      radial-gradient(760px 460px at 82% 16%, rgba(79,143,223,.08), transparent 60%),
      linear-gradient(180deg, #10253f 0%, #0a1a2d 42%, #07111d 100%) !important;
    background-repeat:no-repeat, no-repeat, no-repeat !important;
    background-size:100% 100%, 100% 100%, 100% 100% !important;
    background-attachment:scroll !important;
  }

  body::before{
    opacity:.02 !important;
  }

  main,
  section,
  footer{
    position:relative;
    z-index:2;
  }

  main.container,
  main.container.isWide{
    background:transparent !important;
  }

  .section,
  .homeSection,
  .aboutIndex,
  .aboutBlock,
  .aboutVideo,
  .reservationPage{
    background:transparent !important;
  }

  .hero{
    min-height:auto;
  }

  .hero::before{
    background:
      radial-gradient(760px 420px at 20% 18%, rgba(137,194,255,.10), transparent 58%),
      linear-gradient(180deg, rgba(5,12,22,.18), rgba(5,12,22,.74)) !important;
  }

  .hero::after{
    opacity:.05 !important;
  }

  .heroInner{
    padding:34px 0 22px !important;
  }

  .heroGlass,
  .contentCard,
  .glassPanel,
  .welcomeText,
  .welcomePhoto,
  .aboutCopy,
  .videoCard,
  .formGlass,
  .reservationTypeCard,
  .reservationFormWide,
  .homeStats,
  .statBox,
  .card,
  .featCard,
  .qBtn,
  .stripCard,
  .imageFrame,
  .aboutMedia,
  .welcomeMeta,
  .welcomePaper,
  .navMobile,
  .navMobileInner{
    background:
      linear-gradient(180deg, rgba(10,22,38,.96), rgba(6,16,29,.98)) !important;
    border-color:rgba(158,190,230,.18) !important;
    box-shadow:0 12px 30px rgba(0,8,20,.34) !important;
    backdrop-filter:none !important;
  }

  .heroGlass{
    border-radius:20px !important;
    padding:18px 16px 14px !important;
  }

  .heroGlass h1{
    font-size:30px !important;
    line-height:1.08 !important;
  }

  .heroPage{
    min-height:260px !important;
    background:#07111d !important;
  }

  .heroPageMedia{
    background:#07111d !important;
  }

  .heroPageOverlay{
    min-height:260px !important;
    padding:26px 0 22px !important;
    align-items:flex-end !important;
    background:
      radial-gradient(760px 360px at 20% 18%, rgba(137,194,255,.10), transparent 58%),
      linear-gradient(180deg, rgba(5,12,22,.22), rgba(5,12,22,.86)) !important;
  }

  .heroPageOverlay h1,
  .heroGlass h1,
  .secHead h2,
  .card h3,
  .featCard b,
  .welcomeMeta b,
  .aboutTitle,
  .statNum,
  .qBtn,
  .stripCard b,
  .footerTitle,
  .heroKicker,
  .pageHead h1{
    color:#f4f8ff !important;
  }

  .lead,
  .muted,
  .card p,
  .featTxt,
  .aboutText,
  .welcomePaper p,
  .reservationTypeDesc,
  .reservationTypeCapacity,
  .reservationTypeLabel,
  .footerMuted,
  .footerBottom,
  .heroPageOverlay p,
  .welcomeMeta span,
  .miniStats span,
  .statBox span{
    color:rgba(226,237,250,.86) !important;
  }

  .badge,
  .chip,
  .homePill,
  .aboutPill{
    background:rgba(255,255,255,.08) !important;
    border-color:rgba(158,190,230,.18) !important;
    color:#f3f8ff !important;
    backdrop-filter:none !important;
  }

  .cardMediaShade,
  .aboutImgShade,
  .gMiniShade{
    background:linear-gradient(180deg, rgba(4,10,18,.12), rgba(4,10,18,.82)) !important;
  }

  .cardMediaBg,
  .aboutImg,
  .welcomePhotoFrame,
  .imageFrame,
  .gMini{
    filter:saturate(1) contrast(1.02) brightness(.92) !important;
  }

  .form-control,
  .form-select,
  input.form-control,
  select.form-control,
  textarea.form-control,
  .reservationFormWide .form-control,
  .reservationFormWide select.form-control,
  .reservationFormWide textarea.form-control,
  .formGrid input,
  .formGrid select,
  .formGrid textarea{
    background:rgba(3,10,18,.88) !important;
    border-color:rgba(158,190,230,.18) !important;
    color:#f4f8ff !important;
    box-shadow:none !important;
  }

  .form-control::placeholder,
  textarea.form-control::placeholder,
  .reservationFormWide .form-control::placeholder,
  .reservationFormWide textarea.form-control::placeholder,
  .formGrid input::placeholder,
  .formGrid textarea::placeholder{
    color:rgba(214,226,243,.58) !important;
  }

  .footer{
    background:linear-gradient(180deg, rgba(7,17,31,.92), rgba(5,12,22,.98)) !important;
    backdrop-filter:none !important;
  }

  .footer a{
    color:rgba(230,240,252,.88) !important;
  }

  .reveal{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
  }

  .heroStrip,
  .grid3,
  .split,
  .footerGrid,
  .featGrid,
  .welcomeGrid,
  .aboutGrid,
  .formGrid,
  .row{
    grid-template-columns:1fr !important;
  }

  .homeStatsInner{
    grid-template-columns:repeat(2, 1fr) !important;
  }

  .galleryMini{
    grid-template-columns:repeat(2, 1fr) !important;
  }

  .quickBar{
    grid-template-columns:1fr 1fr !important;
  }
}


/* FILE: /assets/css/app.css */

.galleryPageGrid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:14px;
}

@media (max-width:980px){
  .galleryPageGrid{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:12px;
  }
}

@media (max-width:560px){
  .galleryPageGrid{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:10px;
  }
}