@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,wght@0,400;0,700;0,900;1,400;1,700&family=Cormorant:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Jost:wght@200;300;400;500;600&display=swap');

/* ═══════════════════════════════════════════════════
   GRAND FUSION — CSS (Shiro-inspired structure)
   Palette : Blanc · Rouge laque · Or · Vert malachite
═══════════════════════════════════════════════════ */

:root {
  --ink:    #0e0e0e;
  --ink-1:  #141414;
  --ink-2:  #1a1a1a;
  --ink-3:  #222222;

  --red:    #c42020;
  --red-l:  #e03535;
  --red-d:  #7a1010;
  --red-glow: rgba(196,32,32,.25);

  --gold:   #c4922c;
  --gold-l: #b8860b;
  --gold-d: #7a5410;

  --jade:   #1a4a2e;
  --jade-l: #2d7a4a;
  --jade-ll:#3d9e5f;

  --t0: #1a1a1a;
  --t1: #2a2a2a;
  --t2: #555;

  --bg:  #ffffff;
  --bg-1:#faf9f7;
  --bg-2:#f4f2ef;
  --bg-3:#edeae5;

  --display: 'Bodoni Moda', 'Didot', Georgia, serif;
  --caps:    'Times New Roman', Times, serif;
  --serif:   'Times New Roman', Times, serif;
  --ui:      'Jost', 'Helvetica Neue', sans-serif;

  --nav-h: 84px;
  --gx:    88px;
  --gy:    130px;
  --radius: 15px;
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; font-size:18px; }
body {
  color: var(--t1);
  font-family: var(--ui);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  background-color: var(--bg);
}
a { color:inherit; text-decoration:none; }
img { display:block; width:100%; height:100%; object-fit:cover; }
button { font-family:inherit; cursor:pointer; }
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:var(--bg-1); }
::-webkit-scrollbar-thumb { background:var(--red); border-radius:3px; }
::selection { background:rgba(196,32,32,.15); color:var(--ink); }

/* ═══════════════════════════════════════════════════
   LOADER
═══════════════════════════════════════════════════ */
.loader {
  position:fixed; inset:0; z-index:10000;
  background:#fff;
  display:flex; align-items:center; justify-content:center;
  transition:opacity .6s ease, visibility .6s ease;
}
.loader.done { opacity:0; visibility:hidden; pointer-events:none; }
.loader-inner { text-align:center; }
.loader-logo {
  width:60px; height:60px; object-fit:contain; margin:0 auto 20px;
  filter:drop-shadow(0 0 20px rgba(196,32,32,.3));
  animation:loaderPulse 2s ease-in-out infinite;
}
@keyframes loaderPulse {
  0%,100% { filter:drop-shadow(0 0 20px rgba(196,32,32,.3)); }
  50% { filter:drop-shadow(0 0 35px rgba(196,32,32,.5)); }
}
.loader-text {
  font-family:var(--caps); font-size:14px; letter-spacing:12px;
  color:rgba(26,26,26,.5); margin-bottom:24px;
}
.loader-bar {
  width:180px; height:1px; background:rgba(0,0,0,.06);
  margin:0 auto 14px; position:relative; overflow:hidden;
  border-radius:2px;
}
.loader-progress {
  position:absolute; left:0; top:0; height:100%; width:0%;
  background:linear-gradient(90deg,var(--red-d),var(--red),var(--red-l));
  transition:width .3s ease; border-radius:2px;
}
.loader-hint {
  font-family:var(--ui); font-size:10px; letter-spacing:4px;
  text-transform:uppercase; color:rgba(196,32,32,.7);
}

/* ═══════════════════════════════════════════════════
   CUSTOM CURSOR
═══════════════════════════════════════════════════ */
.cursor-dot {
  position:fixed; width:8px; height:8px; border-radius:50%;
  background:var(--red); pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .2s, height .2s, background .2s;
  left:-100px; top:-100px;
}
.cursor-ring {
  position:fixed; width:36px; height:36px; border-radius:50%;
  border:1px solid rgba(196,32,32,.35); pointer-events:none; z-index:9997;
  transform:translate(-50%,-50%);
  transition:width .3s, height .3s, border-color .3s;
  left:-100px; top:-100px;
}
body.cursor-hover .cursor-dot { width:14px; height:14px; background:var(--red-l); }
body.cursor-hover .cursor-ring { width:50px; height:50px; border-color:rgba(196,32,32,.5); }
body.cursor-click .cursor-dot { width:6px; height:6px; }
body.cursor-click .cursor-ring { width:28px; height:28px; }
@media(max-width:1024px) { .cursor-dot,.cursor-ring { display:none; } }

/* ═══════════════════════════════════════════════════
   FLOATING ROUNDED NAVIGATION (Shiro-inspired)
═══════════════════════════════════════════════════ */
#nav {
  position:fixed; z-index:800;
  top:16px; left:24px; right:24px;
  height:70px;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 32px;
  background:rgba(14,14,14,.75);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.08);
  transition:background .4s, box-shadow .4s, top .4s;
}
#nav.solid {
  background:rgba(14,14,14,.92);
  box-shadow:0 4px 30px rgba(0,0,0,.15);
}
.logo-wrap { display:flex; align-items:center; gap:14px; position:relative; z-index:2; }
.logo-icon {
  width:38px; height:38px; object-fit:contain; flex:0 0 38px;
  filter:drop-shadow(0 0 8px rgba(196,32,32,.4));
}
.logo-text { display:flex; flex-direction:column; gap:1px; }
.logo-name { font-family:var(--caps); font-size:13px; font-weight:900; letter-spacing:8px; color:#fff; }
.logo-sub  { font-family:var(--ui); font-size:9px; letter-spacing:4px; text-transform:uppercase; color:rgba(196,32,32,.55); }
.nav-center {
  position:absolute; left:50%; transform:translateX(-50%);
  font-family:var(--caps); font-size:10px; letter-spacing:14px;
  text-transform:uppercase; color:rgba(255,255,255,.15);
  pointer-events:none;
}
.nav-links { display:flex; align-items:center; gap:32px; list-style:none; }
.nav-links a {
  font-family:var(--ui); font-size:12px; letter-spacing:3px; text-transform:uppercase;
  font-weight:500; color:rgba(255,255,255,.72);
  position:relative; padding-bottom:4px; transition:color .3s;
}
.nav-links a::after {
  content:''; position:absolute; bottom:0; left:0; width:0; height:1px;
  background:var(--red); transition:width .4s cubic-bezier(.16,1,.3,1);
}
.nav-links a:hover, .nav-links a.active { color:#fff; }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }
.nav-cta {
  padding:10px 24px; border:1px solid rgba(196,32,32,.45);
  border-radius:var(--radius);
  font-family:var(--ui); font-size:11px; letter-spacing:3px;
  text-transform:uppercase; font-weight:600; color:rgba(255,255,255,.85);
  position:relative; overflow:hidden;
  transition:border-color .3s, box-shadow .3s, color .3s;
}
.nav-cta::after {
  content:''; position:absolute; inset:0; background:var(--red);
  border-radius:var(--radius);
  transform:scaleX(0); transform-origin:right;
  transition:transform .5s cubic-bezier(.16,1,.3,1); z-index:-1;
}
.nav-cta:hover { border-color:var(--red); color:#fff; box-shadow:0 0 25px var(--red-glow); }
.nav-cta:hover::after { transform:scaleX(1); transform-origin:left; }
.burger { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:4px; position:relative; z-index:900; }
.burger i { display:block; height:1px; background:rgba(255,255,255,.7); transition:all .4s; }
.burger i:nth-child(1) { width:28px; }
.burger i:nth-child(2) { width:19px; }
.burger i:nth-child(3) { width:24px; }
.burger.open i:nth-child(1) { transform:rotate(45deg) translate(5px,5px); width:24px; }
.burger.open i:nth-child(2) { opacity:0; }
.burger.open i:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); width:24px; }

/* Nav styles for layout.js (sub-pages) */
.nav-logo {
  font-family:var(--caps); text-decoration:none; display:flex; flex-direction:column; gap:2px;
}
.nav-logo-main { font-size:13px; font-weight:900; letter-spacing:8px; color:#fff; }
.nav-logo-sub  { font-size:9px; letter-spacing:4px; text-transform:uppercase; color:rgba(196,32,32,.55); }
.nav-burger { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:4px; position:relative; z-index:900; }
.nav-burger span { display:block; height:1px; width:24px; background:rgba(255,255,255,.7); transition:all .4s; }
.nav-mobile {
  display:none; position:fixed; inset:0; z-index:700;
  background:rgba(14,14,14,.95);
  flex-direction:column; align-items:center; justify-content:center; gap:34px;
  opacity:0; pointer-events:none; transition:opacity .4s;
}
.nav-mobile.open { opacity:1; pointer-events:all; display:flex; }
.nav-mobile a { font-family:var(--caps); font-size:18px; letter-spacing:10px; text-transform:uppercase; color:rgba(255,255,255,.7); transition:color .3s; }
.nav-mobile a:hover { color:#fff; }

/* ═══════════════════════════════════════════════════
   FULL SCREEN MENU OVERLAY (Shiro-inspired dark)
═══════════════════════════════════════════════════ */
.menu-overlay {
  position:fixed; inset:0; z-index:850;
  background:rgba(14,14,14,.96);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .5s ease, visibility .5s ease;
}
.menu-overlay.open { opacity:1; visibility:visible; pointer-events:all; }
.menu-overlay-inner { width:100%; max-width:900px; padding:0 var(--gx); }
.menu-overlay-links { display:flex; flex-direction:column; gap:0; }
.mo-link {
  display:flex; align-items:baseline; gap:24px;
  padding:18px 0; border-bottom:1px solid rgba(255,255,255,.05);
  transition:padding-left .4s cubic-bezier(.16,1,.3,1);
}
.mo-link:hover { padding-left:20px; }
.mo-idx {
  font-family:var(--ui); font-size:12px; letter-spacing:3px;
  color:rgba(196,32,32,.5); min-width:36px;
}
.mo-label {
  font-family:var(--display); font-size:clamp(40px,6.5vw,72px); font-weight:400;
  color:rgba(255,255,255,.65); transition:color .3s;
  line-height:1.1;
}
.mo-link:hover .mo-label { color:#fff; }
.menu-overlay-footer {
  display:flex; gap:48px; margin-top:56px; padding-top:28px;
  border-top:1px solid rgba(255,255,255,.06);
}
.mof-col { flex:1; }
.mof-label {
  font-family:var(--ui); font-size:10px; letter-spacing:4px;
  text-transform:uppercase; color:transparent; -webkit-text-stroke:1px rgba(196,32,32,.5); margin-bottom:8px;
}
.mof-val {
  font-family:var(--serif); font-size:17px; color:rgba(255,255,255,.75); line-height:1.6;
}
.mof-val a { color:rgba(255,255,255,.75); transition:color .3s; }
.mof-val a:hover { color:var(--red-l); }

/* mob-menu (sub-pages generated by app.js) */
.mob-menu {
  position:fixed; inset:0; z-index:850;
  background:rgba(14,14,14,.96);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .5s ease, visibility .5s ease;
}
.mob-menu.open { opacity:1; visibility:visible; pointer-events:all; }
.mob-menu a {
  font-family:var(--display); font-size:clamp(22px,4vw,36px); font-weight:400;
  color:rgba(255,255,255,.65); padding:10px 0; transition:color .3s;
}
.mob-menu a:hover { color:#fff; }

/* ═══════════════════════════════════════════════════
   HERO (stays dark, rounded bottom)
═══════════════════════════════════════════════════ */
#hero {
  height:100svh; min-height:680px; position:relative; overflow:hidden;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  border-radius:0;
}
.hero-bg {
  position:absolute; inset:-8%;
  background:#fff center/cover no-repeat;
  animation:kzoom 22s ease-in-out infinite alternate; will-change:transform;
}
@keyframes kzoom { from{transform:scale(1.1);} to{transform:scale(1);} }
.hero-ov { position:absolute; inset:0; background:linear-gradient(180deg,rgba(255,255,255,.85) 0%,rgba(255,255,255,.22) 45%,rgba(255,255,255,.18) 60%,rgba(255,255,255,.92) 100%); }
.hero-sides { position:absolute; inset:0; background:linear-gradient(90deg,rgba(255,255,255,.5) 0%,transparent 20%,transparent 80%,rgba(255,255,255,.5) 100%); }
.hero-line { position:absolute; bottom:0; left:24px; right:24px; height:1px; background:linear-gradient(90deg,transparent,var(--red-d) 20%,var(--red) 50%,var(--gold) 78%,transparent); border-radius:1px; }
.hero-side-text {
  position:absolute; top:50%; z-index:3;
  font-family:var(--ui); font-size:10px; letter-spacing:6px;
  text-transform:uppercase; color:rgba(255,255,255,.35);
  writing-mode:vertical-lr;
}
.hero-side-left { left:var(--gx); transform:translateY(-50%) rotate(180deg); }
.hero-side-right { right:var(--gx); transform:translateY(-50%); }
.hero-content {
  position:relative; z-index:2;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  width:100%; padding:0 var(--gx); box-sizing:border-box;
}
.hero-logo {
  width:150px; height:auto; filter:drop-shadow(0 0 40px rgba(196,32,32,.6));
  animation:logoBeat 5s ease-in-out infinite; margin-bottom:32px;
}
@keyframes logoBeat {
  0%,100% { filter:drop-shadow(0 0 40px rgba(196,32,32,.6)) drop-shadow(0 0 90px rgba(196,32,32,.25)); }
  50% { filter:drop-shadow(0 0 60px rgba(196,32,32,.9)) drop-shadow(0 0 130px rgba(196,32,32,.4)); }
}
.hero-ey {
  font-family:var(--ui); font-size:18px; letter-spacing:11px;
  text-transform:uppercase; color:rgba(196,32,32,.75);
  margin-bottom:14px; display:flex; align-items:center; gap:16px;
}
.hero-ey::before,.hero-ey::after {
  content:''; display:block; width:36px; height:1px; background:rgba(196,32,32,.3);
}
.hero-grand {
  font-family:var(--caps); font-size:clamp(20px,2.5vw,32px);
  letter-spacing:24px; text-transform:uppercase;
  color:rgba(20,20,20,.75); margin-bottom:4px;
}
.hero-fusion {
  font-family:var(--display); font-size:clamp(110px,18vw,260px);
  font-weight:900; line-height:.88; overflow:hidden;
  background:linear-gradient(145deg,rgba(196,32,32,.65) 0%,#c42020 22%,#e03535 42%,#ff5a5a 55%,#e03535 68%,#c42020 84%,rgba(196,32,32,.85) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; filter:drop-shadow(0 0 55px rgba(196,32,32,.5));
}
.text-reveal {
  display:inline-block;
  animation:textRevealUp .8s cubic-bezier(.16,1,.3,1) .4s both;
}
@keyframes textRevealUp {
  from { transform:translateY(100%); opacity:0; }
  to { transform:translateY(0); opacity:1; }
}
.hero-orn { display:flex; align-items:center; justify-content:center; gap:18px; margin:30px 0 26px; }
.ho-l { width:80px; height:1px; background:linear-gradient(90deg,transparent,rgba(196,32,32,.4)); }
.ho-r { width:80px; height:1px; background:linear-gradient(270deg,transparent,rgba(196,32,32,.4)); }
.ho-gem { width:9px; height:9px; background:var(--red); transform:rotate(45deg); box-shadow:0 0 18px rgba(196,32,32,.75); }
.ho-dot { width:4px; height:4px; background:var(--gold); transform:rotate(45deg); }
.hero-sub {
  font-family:var(--serif); font-style:italic;
  font-size:clamp(18px,2.2vw,26px); color:rgba(20,20,20,.7); margin-bottom:44px;
}
.hero-btns { display:flex; gap:18px; flex-wrap:wrap; justify-content:center; padding-top:20px; }
#hero .btn-ghost { color:rgba(20,20,20,.8); border-color:rgba(20,20,20,.2); }
#hero .btn-ghost:hover { border-color:rgba(20,20,20,.5); }
#hero .btn-ghost::before { background:rgba(20,20,20,.08); }
.hero-scroll {
  position:absolute; bottom:40px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.hero-scroll span {
  font-family:var(--ui); font-size:9px; letter-spacing:4px;
  text-transform:uppercase; color:rgba(196,32,32,.3);
}
.hero-scroll-line {
  width:1px; height:40px; background:rgba(196,32,32,.15); position:relative; overflow:hidden;
}
.hero-scroll-line::after {
  content:''; position:absolute; top:-100%; left:0; width:100%; height:50%;
  background:linear-gradient(180deg,transparent,var(--red));
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine { 0% { top:-50%; } 100% { top:100%; } }

/* ═══════════════════════════════════════════════════
   MARQUEE (floating rounded)
═══════════════════════════════════════════════════ */
#marquee {
  background:var(--bg-1);
  border-top:1px solid rgba(196,32,32,.06);
  border-bottom:1px solid rgba(196,32,32,.06);
  border-radius:0;
  margin:0;
  padding:14px 0; overflow:hidden; position:relative;
}
.marquee-track { display:flex; white-space:nowrap; will-change:transform; }
.marquee-item {
  display:inline-flex; align-items:center; gap:26px; padding:0 26px;
  font-family:var(--ui); font-size:14px; letter-spacing:5px;
  text-transform:uppercase; color:rgba(26,26,26,.5);
}
.m-sep { width:5px; height:5px; background:var(--red); transform:rotate(45deg); opacity:.4; flex:0 0 5px; border-radius:1px; }
.m-acc { color:var(--red); }

/* ═══════════════════════════════════════════════════
   BLOCK REVEAL ANIMATIONS (Shiro-inspired)
═══════════════════════════════════════════════════ */
.block-reveal {
  position:relative; overflow:hidden;
  opacity:0;
  transition:opacity 0s;
}
.block-reveal::after {
  content:''; position:absolute; inset:0;
  background:var(--red);
  transform:scaleX(0); transform-origin:left;
  z-index:3;
  transition:none;
}
.block-reveal.revealed { opacity:1; }
.block-reveal.revealed::after {
  animation:blockWipe .9s cubic-bezier(.77,0,.18,1) forwards;
  animation-delay:var(--reveal-delay, 0s);
}
@keyframes blockWipe {
  0%   { transform:scaleX(0); transform-origin:left; }
  45%  { transform:scaleX(1); transform-origin:left; }
  55%  { transform:scaleX(1); transform-origin:right; }
  100% { transform:scaleX(0); transform-origin:right; }
}
.block-reveal-gold::after { background:var(--gold); }
.block-reveal-d1 { --reveal-delay:.12s; }
.block-reveal-d2 { --reveal-delay:.24s; }
.block-reveal-d3 { --reveal-delay:.36s; }
.block-reveal-d4 { --reveal-delay:.48s; }

/* ═══════════════════════════════════════════════════
   ORGANIC BLOB DECORATIONS (Shiro-inspired)
═══════════════════════════════════════════════════ */
.blob {
  position:absolute; pointer-events:none; z-index:0;
  opacity:.05;
  border-radius:40% 60% 70% 30% / 40% 50% 60% 50%;
  animation:blobMorph 14s ease-in-out infinite alternate;
}
@keyframes blobMorph {
  0%   { border-radius:40% 60% 70% 30% / 40% 50% 60% 50%; }
  33%  { border-radius:70% 30% 50% 50% / 30% 30% 70% 70%; }
  66%  { border-radius:50% 60% 30% 60% / 60% 40% 60% 40%; }
  100% { border-radius:30% 60% 70% 40% / 50% 60% 30% 60%; }
}
.blob-red  { background:var(--red); }
.blob-gold { background:var(--gold); }
.blob-jade { background:var(--jade-l); }

/* ═══════════════════════════════════════════════════
   ABOUT with WATERMARK + rotated images
═══════════════════════════════════════════════════ */
#about {
  position:relative; overflow:hidden;
  padding:var(--gy) var(--gx);
  background:var(--bg-1);
}
.about-watermark {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:var(--display); font-size:clamp(200px,30vw,500px);
  font-weight:900; line-height:1; white-space:nowrap;
  color:transparent; -webkit-text-stroke:1px rgba(196,32,32,.04);
  pointer-events:none; z-index:0;
}
.about-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:80px;
  align-items:center; position:relative; z-index:1;
}
.about-images {
  position:relative; min-height:500px;
}
.about-images::before {
  content:''; position:absolute; top:8%; right:5%;
  width:50%; aspect-ratio:1; border-radius:50%;
  background:rgba(196,32,32,.04); z-index:0;
}
.about-img-main {
  position:relative; width:80%; aspect-ratio:3/4;
  background-size:cover; background-position:center;
  border-radius:12px; transform:rotate(-3deg);
  z-index:1; overflow:hidden;
}
.about-img-float {
  position:absolute; bottom:-20px; right:-5%;
  width:55%; aspect-ratio:4/3;
  background-size:cover; background-position:center;
  border-radius:12px; transform:rotate(8deg);
  z-index:2; overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.12);
}
.about-content { position:relative; }
.about-stats {
  display:flex; gap:40px; margin-top:32px;
  padding-top:28px; border-top:1px solid rgba(196,32,32,.1);
}
.about-stat { text-align:center; }
.about-stat-n {
  display:block; font-family:var(--display); font-size:48px; font-weight:900;
  background:linear-gradient(135deg,var(--red-d),var(--red),var(--red-l));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1;
}
.about-stat-l {
  display:block; font-family:var(--ui); font-size:13px; letter-spacing:3px;
  text-transform:uppercase; color:rgba(26,26,26,.45); margin-top:6px;
}

/* ═══════════════════════════════════════════════════
   INTERIOR GALLERY (rounded frames)
═══════════════════════════════════════════════════ */
#interior { padding:var(--gy) var(--gx); background:var(--bg); }
.interior-grid { display:flex; flex-direction:column; gap:100px; }
.interior-card { display:grid; grid-template-columns:1.2fr 1fr; gap:60px; align-items:center; }
.interior-card-reverse { direction:rtl; }
.interior-card-reverse > * { direction:ltr; }
.interior-img-wrap {
  position:relative; overflow:hidden; aspect-ratio:4/3;
  border-radius:12px;
  border:none;
}
.interior-img {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transition:transform 1.2s cubic-bezier(.16,1,.3,1), filter .8s;
  filter:brightness(.85) saturate(1.05);
}
.interior-img-wrap:hover .interior-img {
  transform:scale(1.06); filter:brightness(.95) saturate(1.1);
}
.interior-info { padding:20px 0; }

/* ═══════════════════════════════════════════════════
   SPECIALS HORIZONTAL SCROLL
═══════════════════════════════════════════════════ */
#specials {
  padding:var(--gy) 0; overflow:hidden;
  background:var(--bg-2); position:relative;
}
.specials-header { text-align:center; padding:0 var(--gx); margin-bottom:56px; position:relative; z-index:1; }
.specials-track-wrap { overflow:hidden; margin-bottom:20px; }
.specials-track {
  display:flex; gap:20px; width:max-content;
  animation:scrollTrack 50s linear infinite;
}
.specials-track-reverse .specials-track {
  animation:scrollTrackReverse 55s linear infinite;
}
@keyframes scrollTrack {
  0% { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}
@keyframes scrollTrackReverse {
  0% { transform:translateX(-50%); }
  100% { transform:translateX(0); }
}
.spec-card {
  flex:0 0 360px; position:relative; overflow:hidden;
  border:1px solid rgba(0,0,0,.05); background:var(--bg);
  border-radius:12px;
  transition:border-color .4s, box-shadow .4s, transform .4s;
}
.spec-card:hover {
  border-color:rgba(196,32,32,.15);
  box-shadow:0 12px 40px rgba(0,0,0,.06);
  transform:translateY(-4px);
}
.spec-img {
  width:100%; aspect-ratio:3/4;
  background-size:cover; background-position:center;
  filter:brightness(.9) saturate(1.05);
  transition:filter .6s, transform 1s cubic-bezier(.16,1,.3,1);
}
.spec-card:hover .spec-img { filter:brightness(1) saturate(1.1); transform:scale(1.06); }
.spec-info { padding:18px 20px; }
.spec-cat {
  font-family:var(--ui); font-size:12px; letter-spacing:4px;
  text-transform:uppercase; color:var(--red); display:block; margin-bottom:6px;
}
.spec-name {
  font-family:var(--caps); font-size:16px; letter-spacing:2px;
  color:var(--t0); font-weight:600;
}

/* ═══════════════════════════════════════════════════
   FULL BLEED QUOTE (stays dark)
═══════════════════════════════════════════════════ */
#fullbleed {
  position:relative; height:300px;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
  border-radius:24px; margin:0 24px;
}
.fb-bg { position:absolute; inset:-8%; background:url('../img/salle1.jpg') center/cover no-repeat; filter:brightness(.25); }
.fb-ov { position:absolute; inset:0; background:rgba(10,10,10,.55); }
.fb-content { position:relative; z-index:2; text-align:center; padding:0 var(--gx); max-width:900px; }
.fb-quote {
  font-family:var(--display); font-style:italic;
  font-size:clamp(24px,3.8vw,44px); font-weight:400;
  line-height:1.5; color:rgba(240,236,228,.92); margin-bottom:16px;
}
.fb-attr {
  font-family:var(--ui); font-size:16px; font-weight:700; letter-spacing:6px;
  text-transform:uppercase; color:rgba(255,255,255,.9);
}

/* ═══════════════════════════════════════════════════
   TARIFS (rounded cards with gap)
═══════════════════════════════════════════════════ */
#tarifs { background:var(--bg); padding-bottom:40px; }
.tarifs-hd { text-align:center; padding:var(--gy) var(--gx) 56px; }
.tarifs-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; padding:0 var(--gx);
}
.tc {
  padding:52px 36px; border:none;
  text-align:center; position:relative;
  background:var(--bg);
  border-radius:var(--radius);
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 4px 24px rgba(0,0,0,.04);
  transition:box-shadow .4s, transform .4s;
}
.tc:hover { box-shadow:0 12px 48px rgba(0,0,0,.08); transform:translateY(-4px); }
.tc::before { content:''; position:absolute; top:0; left:20px; right:20px; height:2px; border-radius:2px; }
.tc:nth-child(1)::before { background:linear-gradient(90deg,transparent,var(--red-d),transparent); }
.tc:nth-child(2)::before { background:linear-gradient(90deg,transparent,var(--red),transparent); }
.tc:nth-child(3)::before { background:linear-gradient(90deg,transparent,rgba(26,26,26,.15),transparent); }
.tc-badge {
  position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  padding:5px 16px; font-family:var(--caps); font-size:11px;
  letter-spacing:3px; text-transform:uppercase; color:#fff; white-space:nowrap;
  border-radius:20px;
}
.tb-red { background:var(--red); } .tb-jade { background:var(--jade); }
.tc-label {
  font-family:Arial, Helvetica, sans-serif; font-size:14px; font-weight:700; letter-spacing:4px;
  text-transform:uppercase; color:var(--t0);
  margin-bottom:18px; margin-top:8px;
}
.tc-price {
  font-family:Arial, Helvetica, sans-serif; font-size:56px; font-weight:900;
  color:var(--t0); line-height:1;
}
.tc-price sup { font-size:28px; }
.tc-unit { font-family:Arial, Helvetica, sans-serif; font-size:14px; font-weight:600; letter-spacing:2px; color:var(--t2); margin:5px 0 20px; }
.tc-feats { display:flex; flex-direction:column; gap:10px; text-align:left; margin-bottom:28px; }
.tf {
  font-family:var(--serif); font-size:18px; color:rgba(26,26,26,.82);
  padding-left:17px; position:relative; line-height:1.55;
}
.tf::before { content:''; position:absolute; left:0; top:9px; width:7px; height:1px; background:var(--red-d); }
.tarifs-enfants {
  display:grid; grid-template-columns:1fr 1fr;
  gap:24px; padding:24px var(--gx) 0;
}
.tarifs-note {
  padding:24px var(--gx); text-align:center;
  font-family:Arial, Helvetica, sans-serif; font-style:italic; font-size:14px; font-weight:600;
  color:var(--t0);
}
.tarifs-menu-btn { text-align:center; padding:30px 0 10px; }

/* ═══════════════════════════════════════════════════
   PHOTO GALLERY (rounded items)
═══════════════════════════════════════════════════ */
#gallery { padding:0 24px; }
.gallery-grid {
  display:grid;
  grid-template-columns:1fr 1fr 1fr 1fr;
  grid-template-rows:300px 300px;
  gap:8px;
}
.gal-item {
  position:relative; overflow:hidden; display:block;
  border-radius:12px;
  opacity:0; transform:translateY(40px);
  transition:opacity .8s ease, transform .8s cubic-bezier(.16,1,.3,1);
}
.gal-item.visible { opacity:1; transform:translateY(0); }
.gal-item:nth-child(2) { transition-delay:.15s; }
.gal-item:nth-child(3) { transition-delay:.3s; }
.gal-item:nth-child(4) { transition-delay:.45s; }
.gal-item img {
  position:absolute; inset:0;
  filter:grayscale(.4) brightness(.85);
  transition:filter .8s, transform 1.2s cubic-bezier(.16,1,.3,1);
  transform:scale(1.05);
}
.gal-item:hover img { filter:grayscale(0) brightness(1); transform:scale(1); }
.gal-overlay {
  position:absolute; inset:0; z-index:2;
  background:linear-gradient(to top,rgba(10,10,10,.75) 0%,transparent 55%);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:24px; opacity:0; transition:opacity .4s;
  border-radius:12px;
}
.gal-item:hover .gal-overlay { opacity:1; }
.gal-title {
  font-family:var(--caps); font-size:16px; letter-spacing:3px;
  color:#fff; margin-bottom:4px;
}
.gal-sub {
  font-family:var(--ui); font-size:13px; letter-spacing:3px;
  text-transform:uppercase; color:rgba(255,255,255,.6);
}
.gal-large { grid-column:1/3; }
.gal-tall { grid-row:1/3; grid-column:3; }

/* ═══════════════════════════════════════════════════
   SERVICES (rounded cards)
═══════════════════════════════════════════════════ */
#services {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; padding:var(--gy) var(--gx);
  background:var(--bg-1);
}
.svc {
  padding:56px 40px;
  position:relative; overflow:hidden; text-decoration:none; display:block;
  background:var(--bg); border-radius:var(--radius);
  border:1px solid rgba(0,0,0,.05);
  transition:box-shadow .4s, transform .4s;
}
.svc:hover { box-shadow:0 12px 48px rgba(0,0,0,.07); transform:translateY(-4px); }
.svc-bar {
  position:absolute; left:0; top:20%; bottom:20%; width:3px;
  border-radius:0 3px 3px 0;
  transform:scaleY(0); transform-origin:bottom;
  transition:transform .5s cubic-bezier(.16,1,.3,1);
}
.svc:hover .svc-bar { transform:scaleY(1); }
.svc:nth-child(1) .svc-bar { background:linear-gradient(180deg,transparent,var(--red),transparent); }
.svc:nth-child(2) .svc-bar { background:linear-gradient(180deg,transparent,var(--gold),transparent); }
.svc:nth-child(3) .svc-bar { background:linear-gradient(180deg,transparent,var(--red),transparent); }
.svc-num {
  font-family:var(--ui); font-size:14px; letter-spacing:4px;
  color:rgba(196,32,32,.55); margin-bottom:24px;
}
.svc-ico {
  width:50px; height:50px; border:1px solid rgba(196,32,32,.12);
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:22px; transition:border-color .3s;
}
.svc:hover .svc-ico { border-color:rgba(196,32,32,.35); }
.svc-ico svg { width:22px; height:22px; }
.svc-title {
  font-family:var(--caps); font-size:16px; font-weight:600;
  letter-spacing:3px; color:var(--t0); margin-bottom:12px;
}
.svc-desc {
  font-family:var(--serif); font-size:19px; color:rgba(26,26,26,.75);
  line-height:1.85; margin-bottom:26px;
}
.svc-arrow {
  font-family:var(--ui); font-size:13px; letter-spacing:3px;
  text-transform:uppercase; font-weight:600;
  display:inline-flex; align-items:center; gap:12px;
  transition:gap .3s;
}
.svc:nth-child(1) .svc-arrow { color:var(--red); }
.svc:nth-child(2) .svc-arrow { color:var(--gold-l); }
.svc:nth-child(3) .svc-arrow { color:var(--red); }
.svc-arrow::after { content:''; display:block; width:22px; height:1px; background:currentColor; transition:width .3s; }
.svc:hover .svc-arrow { gap:18px; }
.svc:hover .svc-arrow::after { width:38px; }

/* ═══════════════════════════════════════════════════
   CONTACT CTA (with blobs)
═══════════════════════════════════════════════════ */
#contact-cta {
  position:relative; overflow:hidden;
  padding:var(--gy) var(--gx);
  text-align:center;
  background:var(--bg-2);
}
.contact-circles { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; pointer-events:none; }
.cc-ring {
  position:absolute; border-radius:50%;
  border:1px solid rgba(196,32,32,.04);
}
.cc-ring-1 { width:400px; height:400px; }
.cc-ring-2 { width:600px; height:600px; }
.cc-ring-3 { width:800px; height:800px; }
.contact-cta-inner { position:relative; z-index:1; }
.contact-cards {
  display:flex; gap:28px; justify-content:center; margin-top:40px; flex-wrap:wrap;
}
.cc-card {
  flex:1; padding:36px 44px; background:var(--bg);
  border:1px solid rgba(0,0,0,.05);
  border-radius:var(--radius);
  text-align:center; min-width:260px;
  transition:border-color .4s, box-shadow .4s, transform .4s;
}
.cc-card:hover {
  border-color:rgba(196,32,32,.15); transform:translateY(-4px);
  box-shadow:0 12px 48px rgba(0,0,0,.06);
}
.cc-card-icon { margin:0 auto 16px; }
.cc-card-icon svg { width:28px; height:28px; }
.cc-card-val {
  display:block; font-family:var(--caps); font-size:16px;
  letter-spacing:2px; color:var(--t0); margin-bottom:6px;
  transition:color .3s;
}
.cc-card-val:hover { color:var(--red); }
.cc-card-label {
  font-family:var(--ui); font-size:12px; letter-spacing:4px;
  text-transform:uppercase; color:rgba(196,32,32,.55);
}

/* ═══════════════════════════════════════════════════
   SCROLL PROGRESS INDICATOR (Shiro-inspired)
═══════════════════════════════════════════════════ */
.scroll-progress {
  position:fixed; bottom:30px; right:30px;
  width:48px; height:48px; z-index:700;
  cursor:pointer;
  opacity:0; transform:translateY(20px);
  transition:opacity .4s, transform .4s;
}
.scroll-progress.visible { opacity:1; transform:translateY(0); }
.scroll-progress svg { width:100%; height:100%; transform:rotate(-90deg); }
.sp-bg { fill:none; stroke:rgba(196,32,32,.12); stroke-width:2; }
.sp-fill {
  fill:none; stroke:var(--red); stroke-width:2.5;
  stroke-dasharray:125.66; stroke-dashoffset:125.66;
  stroke-linecap:round; transition:stroke-dashoffset .1s;
}
.sp-arrow {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-size:15px; color:var(--red); font-family:var(--ui);
}

/* ═══════════════════════════════════════════════════
   FOOTER (rounded top, stays dark)
═══════════════════════════════════════════════════ */
#footer {
  background:#0e0e0e;
  border-radius:20px 20px 0 0;
  position:relative; color:var(--bg-3);
  margin-top:48px;
  overflow:hidden;
}
#footer::before {
  content:''; position:absolute; inset:0;
  background-image:url('../img/marbre2.jpg');
  background-size:cover; background-position:center;
  opacity:.03; pointer-events:none;
}
.footer-inner {
  display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr;
  gap:48px; padding:72px var(--gx) 56px;
  border-bottom:1px solid rgba(255,255,255,.05);
  position:relative; z-index:1;
}
.ft-logo-row { display:flex; align-items:center; gap:14px; margin-bottom:10px; }
.ft-icon { width:52px; height:auto; max-height:52px; object-fit:contain; flex:0 0 52px; filter:drop-shadow(0 0 12px rgba(196,32,32,.45)); }
.ft-logo-name { font-family:var(--caps); font-size:14px; font-weight:900; letter-spacing:6px; color:#fff; display:block; }
.ft-logo-rest { font-family:var(--ui); font-size:10px; letter-spacing:5px; text-transform:uppercase; color:rgba(196,32,32,.35); }
.ft-tagline { font-family:var(--serif); font-style:italic; font-size:17px; color:rgba(240,236,228,.85); margin-bottom:24px; }
.ft-socials { display:flex; gap:10px; }
.ft-soc {
  width:42px; height:42px;
  border:1px solid rgba(196,32,32,.25);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:rgba(240,236,228,.65); transition:all .35s;
}
.ft-soc:hover { border-color:var(--red); color:#fff; background:rgba(196,32,32,.15); box-shadow:0 0 18px rgba(196,32,32,.15); }
.ft-brand { display:block; }
.ft-col { display:block; }
.ft-col h5 {
  font-family:var(--caps); font-size:11px; letter-spacing:4px; text-transform:uppercase;
  color:var(--red); margin-bottom:20px; padding-bottom:12px;
  border-bottom:1px solid rgba(196,32,32,.12);
}
.ft-col ul { list-style:none; display:flex; flex-direction:column; gap:11px; }
.ft-col li a { font-family:var(--ui); font-size:15px; color:rgba(240,236,228,.8); transition:color .3s, padding-left .3s; display:block; }
.ft-col li a:hover { color:#fff; padding-left:6px; }
.ft-info { display:flex; flex-direction:column; gap:14px; position:relative; z-index:1; }
.ft-info h5 {
  font-family:var(--caps); font-size:11px; letter-spacing:4px; text-transform:uppercase;
  color:var(--red); margin-bottom:6px; padding-bottom:12px;
  border-bottom:1px solid rgba(196,32,32,.12);
}
.fi b { display:block; font-family:var(--ui); font-size:10px; letter-spacing:3px; text-transform:uppercase; color:rgba(196,32,32,.7); margin-bottom:3px; font-weight:600; }
.fi span, .fi a { font-family:var(--serif); font-size:17px; color:rgba(240,236,228,.82); line-height:1.65; }
.fi a:hover { color:var(--red-l); }
.footer-bottom {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gx) 24px; flex-wrap:wrap; gap:10px;
  position:relative; z-index:1;
}
.ft-copy { font-size:13px; letter-spacing:1.5px; color:rgba(240,236,228,.55); }
.ft-legal { display:flex; gap:22px; }
.ft-legal a { font-size:13px; color:rgba(240,236,228,.55); transition:color .3s; }
.ft-legal a:hover { color:var(--red); }
.ft-powered { font-family:var(--ui); font-size:11px; letter-spacing:2px; text-transform:uppercase; color:rgba(240,236,228,.35); }
.ft-powered strong { color:rgba(240,236,228,.6); font-weight:600; }

/* Footer styles for layout.js (sub-pages) */
.ft-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr;
  gap:48px; padding:72px var(--gx) 56px;
  border-bottom:1px solid rgba(255,255,255,.05);
  position:relative; z-index:1;
}
.ft-logo {
  font-family:var(--caps); font-size:16px; font-weight:900;
  letter-spacing:6px; color:#fff; margin-bottom:8px;
}
.ft-bottom {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gx) 24px; flex-wrap:wrap; gap:10px;
  position:relative; z-index:1;
}
.marbre { position:relative; }
.marbre::before {
  content:''; position:absolute; inset:0;
  background-image:url('../img/marbre2.jpg');
  background-size:cover; background-position:center;
  opacity:.03; pointer-events:none;
}

/* ═══════════════════════════════════════════════════
   BUTTONS (Shiro-inspired rounded + italic)
═══════════════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:12px;
  padding:16px 44px;
  font-family:var(--ui); font-size:13px; letter-spacing:3px;
  text-transform:uppercase; font-weight:600; font-style:italic;
  position:relative; overflow:hidden; border:none; white-space:nowrap;
  border-radius:var(--radius);
  transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s, color .35s, background .35s;
}
.btn:hover { transform:translateY(-2px); }
.btn-red {
  background:var(--red); color:#fff;
  border:1px solid var(--red);
  box-shadow:0 6px 28px rgba(196,32,32,.15);
}
.btn-red:hover {
  background:transparent; color:var(--red);
  box-shadow:0 14px 50px rgba(196,32,32,.2);
}
.btn-ghost {
  background:transparent; color:var(--t1); border:1px solid rgba(26,26,26,.15);
}
.btn-ghost:hover {
  background:var(--t0); color:#fff; border-color:var(--t0);
}
.btn-ghost-red {
  background:transparent; color:var(--red); border:1px solid rgba(196,32,32,.25);
}
.btn-ghost-red:hover {
  background:var(--red); color:#fff; border-color:var(--red);
}
.btn-gold { background:linear-gradient(135deg,var(--gold-d),var(--gold),var(--gold-l)); color:#fff; box-shadow:0 6px 28px rgba(196,146,44,.15); border-radius:var(--radius); }
.btn-gold:hover { box-shadow:0 14px 50px rgba(196,146,44,.3); }
.btn-wide { width:100%; }
.btn-or { background:var(--red); color:#fff; border-radius:var(--radius); padding:14px 36px; font-family:var(--ui); font-size:13px; letter-spacing:3px; text-transform:uppercase; font-weight:600; }
.mt32 { margin-top:32px; }

/* ═══════════════════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════════════════ */
.tag { font-family:var(--ui); font-size:13px; letter-spacing:5px; text-transform:uppercase; font-weight:600; display:inline-block; margin-bottom:14px; }
.tag-red   { color:var(--red); }
.tag-gold  { color:var(--gold-l); }
.tag-white { color:rgba(26,26,26,.5); }
.tag-jade  { color:var(--jade-l); }
.h1 { font-family:var(--display); font-size:clamp(42px,6vw,84px); font-weight:700; line-height:1.04; color:var(--t0); }
.h1 em { font-style:italic; color:var(--gold-l); }
.h2 { font-family:var(--display); font-size:clamp(34px,4.5vw,60px); font-weight:700; line-height:1.06; color:var(--t0); }
.h2 em { font-style:italic; color:var(--gold-l); }
.h3 { font-family:var(--caps); font-size:clamp(16px,2vw,24px); font-weight:600; letter-spacing:3px; }
.body { font-family:var(--serif); font-size:22px; line-height:1.85; font-weight:400; color:rgba(26,26,26,.8); }

/* Ornement */
.orn { display:flex; align-items:center; gap:14px; margin:18px 0; }
.orn.c { justify-content:center; }
.orn-line   { flex:0 0 50px; height:1px; background:linear-gradient(90deg,transparent,rgba(196,32,32,.25)); }
.orn-line.r { background:linear-gradient(270deg,transparent,rgba(196,32,32,.25)); }
.orn.c .orn-line, .orn.c .orn-line.r { flex:0 0 72px; }
.orn-gem { width:8px; height:8px; background:var(--red); transform:rotate(45deg); box-shadow:0 0 12px rgba(196,32,32,.4); border-radius:2px; }
.orn-dot { width:4px; height:4px; background:var(--gold); transform:rotate(45deg); }

/* ═══════════════════════════════════════════════════
   PAGE HERO (pages interieures — stays dark)
═══════════════════════════════════════════════════ */
.page-hero {
  height:34vh; min-height:260px; padding-top:var(--nav-h);
  position:relative; overflow:hidden;
  display:flex; align-items:flex-end; justify-content:flex-start;
  padding-bottom:72px; padding-left:var(--gx); padding-right:var(--gx);
  border-radius:0;
}
.ph-img {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transform:scale(1.08); transition:transform 10s ease-out;
}
.ph-img.rdy { transform:scale(1); }
.ph-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(10,10,10,.75) 0%, rgba(10,10,10,.4) 40%, rgba(10,10,10,.15) 65%, rgba(10,10,10,.3) 100%);
}
.ph-stripe {
  position:absolute; bottom:0; left:24px; right:24px; height:1px;
  background:linear-gradient(90deg, transparent, var(--red-d) 25%, var(--red) 50%, var(--gold) 75%, transparent);
  border-radius:1px;
}
.ph-logo-wm { position:absolute; right:var(--gx); top:calc(var(--nav-h) + 24px); width:160px; object-fit:contain; opacity:.05; pointer-events:none; }
.ph-inner { position:relative; z-index:2; width:100%; max-width:860px; text-align:left; }
.breadcrumb { display:flex; align-items:center; gap:10px; font-family:var(--ui); font-size:11px; letter-spacing:3px; text-transform:uppercase; color:rgba(196,32,32,.4); margin-bottom:20px; }
.breadcrumb a:hover { color:var(--red); }
.breadcrumb-sep { color:rgba(196,32,32,.2); }
.ph-title { font-family:var(--display); font-size:clamp(52px,9vw,108px); font-weight:900; letter-spacing:1px; line-height:.92; color:#fff; text-align:left; }
.ph-title em { font-style:italic; color:var(--gold-l); font-weight:400; }

/* ── SECTIONS ── */
.s    { padding:var(--gy) var(--gx); }
.s-sm { padding:64px var(--gx); }
.s-dark   { background:var(--bg-2); }
.s-darker { background:var(--bg-3); }
.s-navy   { background:var(--bg-1); }

/* ── FORMULAIRES ── */
.field { display:flex; flex-direction:column; gap:8px; }
.field label { font-family:var(--ui); font-size:11px; letter-spacing:3px; text-transform:uppercase; color:rgba(196,32,32,.6); font-weight:600; }
.field input, .field select, .field textarea {
  background:var(--bg-1); border:1px solid rgba(0,0,0,.08);
  color:var(--t1); padding:14px 18px;
  font-family:var(--ui); font-size:16px; font-weight:300;
  outline:none; width:100%; appearance:none;
  border-radius:10px;
  transition:border-color .3s, background .3s, box-shadow .3s;
}
.field input::placeholder, .field textarea::placeholder { color:rgba(26,26,26,.45); }
.field input:focus, .field select:focus, .field textarea:focus { border-color:rgba(196,32,32,.35); background:#fff; box-shadow:0 0 0 3px rgba(196,32,32,.06); }
.field select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(196,32,32,.5)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; padding-right:44px; }
.field select option { background:#fff; }
.field textarea { resize:vertical; min-height:130px; line-height:1.8; }

/* ── ANIMATIONS ── */
.r-up, .r-left, .r-right, .r-scale, .r-clip,
.anim-up, .anim-left, .anim-right, .anim-scale {
  opacity:1 !important;
  transform:none !important;
  clip-path:none !important;
  visibility:visible !important;
}

/* ═══════════════════════════════════════════════════
   FOND MARBRE sur sections (light version)
═══════════════════════════════════════════════════ */
.has-marble { position:relative; }
.has-marble::after {
  content:''; position:absolute; inset:0; z-index:0;
  background-image:url('../img/marbre2.jpg');
  background-size:cover; background-position:center;
  opacity:.03; pointer-events:none;
}
.has-marble > * { position:relative; z-index:1; }

/* ═══════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════ */
@media(max-width:1200px) {
  :root { --gx:48px; --gy:100px; }
  .footer-inner, .ft-grid { grid-template-columns:1fr 1fr; gap:40px; }
  .about-grid { gap:50px; }
  .interior-card { gap:40px; }
}
@media(max-width:1100px) {
  .interior-card { grid-template-columns:1fr; }
  .interior-card-reverse { direction:ltr; }
  .about-grid { grid-template-columns:1fr; }
  .about-images { min-height:400px; }
  #services { grid-template-columns:1fr; }
  .tarifs-grid { grid-template-columns:1fr; }
  .tarifs-enfants { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .gal-large { grid-column:1/3; }
  .gal-tall { grid-row:auto; grid-column:auto; }
  .gal-item { min-height:250px; }
}
@media(max-width:900px) {
  :root { --gx:30px; --gy:80px; --nav-h:66px; }
  #nav { left:12px; right:12px; top:10px; height:60px; padding:0 20px; }
  .nav-links, .nav-cta, .nav-center { display:none; }
  .burger, .nav-burger { display:flex; }
  .footer-inner, .ft-grid { grid-template-columns:1fr; gap:28px; padding:44px var(--gx) 36px; }
  .hero-side-text { display:none; }
  .menu-overlay-footer { flex-direction:column; gap:24px; }
  .contact-cards { flex-direction:column; align-items:stretch; }
  .interior-grid { gap:60px; }
  #marquee { margin:0; }
  #fullbleed { margin:0 12px; border-radius:16px; }
  #gallery { padding:0 12px; }
}
@media(max-width:680px) {
  .specials-track-wrap { overflow:hidden; }
  .spec-card { flex:0 0 260px; }
  .gal-hide-mobile { display:none; }
  .gallery-grid { grid-template-columns:1fr; }
  .gal-large { grid-column:auto; }
  .hero-btns { flex-direction:column; align-items:center; }
  .about-stats { gap:24px; flex-wrap:wrap; justify-content:center; }
  .about-img-main { transform:rotate(-2deg); width:85%; }
  .about-img-float { transform:rotate(5deg); width:50%; }
}
@media(max-width:600px) {
  :root { --gx:22px; }
  .footer-inner, .ft-grid { grid-template-columns:1fr; }
  .footer-bottom, .ft-bottom { flex-direction:column; align-items:center; }
  .btn { padding:14px 32px; }
  .tarifs-grid { padding:0 var(--gx); }
}
