:root{
  --bg:#050505;
  --surface:#101010;
  --surface-light:#171717;
  --text:#ffffff;
  --muted:rgba(255,255,255,.72);
  --blue:#1f8fcf;
  --blue-soft:rgba(31,143,207,.16);
  --green:#39b54a;
  --green-soft:rgba(57,181,74,.14);
  --border:rgba(31,143,207,.22);
  --wood:#d7a866;
  --radius:18px;
  --shadow:0 24px 70px rgba(0,0,0,.45),0 0 50px rgba(31,143,207,.08);
  --shadow-hover:0 30px 90px rgba(0,0,0,.56),0 0 58px rgba(31,143,207,.18);
  --focus-ring:0 0 0 4px rgba(31,143,207,.28);
  --transition:all .35s cubic-bezier(.16,1,.3,1);
  --ease-premium:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}
body.modal-open{overflow:hidden}
img{display:block;width:100%;object-fit:cover;object-position:center}
a{text-decoration:none;color:inherit}
button{font:inherit;color:inherit}
a:focus-visible,button:focus-visible{outline:2px solid rgba(31,143,207,.72);outline-offset:4px}
.container{width:min(1280px,calc(100% - 40px));margin:auto}
.section{padding:112px 0;position:relative}
header{position:fixed;inset:0 0 auto;z-index:300;padding:12px 0;transition:var(--transition)}
header.scrolled,header.nav-open{background:rgba(5,5,5,.9);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.08)}
.nav{width:min(1400px,calc(100% - 36px));margin:auto;display:flex;align-items:center;justify-content:space-between;gap:20px}
.logo{display:flex;align-items:center;gap:14px;font-weight:900;text-transform:uppercase;flex:0 0 auto}
.logo img{width:74px;height:74px;object-fit:contain}
.logo span{font-size:15px;color:#fff}
.menu{display:flex;align-items:center}
.menu-list{display:flex;align-items:center;gap:5px;list-style:none}
.menu-item{position:relative}
.has-submenu:after{content:"";position:absolute;left:0;right:0;top:100%;height:18px}
.menu-link{min-height:44px;padding:0 10px;display:inline-flex;align-items:center;gap:6px;border:0;border-radius:999px;background:transparent;color:rgba(255,255,255,.78);font-size:15px;font-weight:800;cursor:pointer;transition:var(--transition);white-space:nowrap}
.menu-link:hover,.menu-link:focus-visible,.has-submenu:hover>.menu-link,.has-submenu.submenu-open>.menu-link{color:#fff;background:rgba(255,255,255,.06);box-shadow:0 10px 28px rgba(0,0,0,.18);outline:0}
.catalogue-menu-button{padding:0 16px;border:1px solid var(--border);color:#fff;background:rgba(31,143,207,.12)}
.catalogue-menu-button:hover,.catalogue-menu-button:focus-visible{border-color:rgba(31,143,207,.5);box-shadow:0 0 24px rgba(31,143,207,.16)}
.chevron{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;transition:var(--transition)}
.has-submenu:hover .chevron,.has-submenu.submenu-open .chevron{transform:rotate(180deg)}
.submenu{position:absolute;top:calc(100% + 8px);left:0;min-width:300px;padding:12px 10px 10px;display:grid;gap:4px;border-radius:18px;background:rgba(5,5,5,.96);border:1px solid var(--border);box-shadow:0 28px 78px rgba(0,0,0,.58),0 0 48px rgba(31,143,207,.12);backdrop-filter:blur(18px);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(8px) scale(.98);transform-origin:top;transition:opacity .24s var(--ease-premium),transform .24s var(--ease-premium),border-color .24s ease,visibility .24s ease}
.menu-item:nth-child(4) .submenu,.menu-item:nth-child(5) .submenu{left:auto;right:0}
.has-submenu:hover .submenu,.has-submenu:focus-within .submenu,.has-submenu.submenu-open .submenu{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}
.submenu a{padding:13px 14px;border-radius:15px;color:rgba(255,255,255,.76);font-size:14px;font-weight:800;transition:var(--transition)}
.submenu a:hover,.submenu a:focus-visible{color:#fff;background:var(--blue-soft);transform:translateX(3px);outline:0}
.nav-toggle{width:50px;height:50px;display:none;align-items:center;justify-content:center;border:1px solid rgba(31,143,207,.55);border-radius:999px;background:rgba(5,5,5,.86);color:var(--text);cursor:pointer;backdrop-filter:blur(18px);transition:var(--transition)}
.nav-toggle svg,.catalogue-close svg,.cta-float svg{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.nav-toggle svg{width:23px;height:23px}
.nav-toggle:hover{border-color:rgba(31,143,207,.5);box-shadow:0 0 28px rgba(31,143,207,.18)}
h1,h2,h3,h4{line-height:1.06;letter-spacing:0}
h1{font-size:clamp(46px,5vw,84px);max-width:1080px}
h2{font-size:clamp(34px,5vw,62px);margin-bottom:26px}
h3{font-size:clamp(28px,4vw,48px);margin-bottom:22px}
h4{font-size:22px;margin-bottom:12px}
p{color:var(--muted);font-size:17px}
p+p{margin-top:16px}
.eyebrow{display:inline-flex;align-items:center;gap:14px;color:var(--blue);text-transform:uppercase;letter-spacing:0;font-size:13px;font-weight:900;margin-bottom:22px}
.eyebrow:before{content:"";width:42px;height:1px;background:var(--blue)}
.btn{position:relative;isolation:isolate;overflow:hidden;min-height:54px;padding:0 28px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-weight:900;transition:transform .28s var(--ease-premium),box-shadow .28s ease,border-color .28s ease,background .28s ease;color .28s ease;border:0;cursor:pointer}
.btn:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.18),transparent);transform:translateX(-120%);transition:transform .7s var(--ease-premium);z-index:-1}
.btn-primary{background:linear-gradient(135deg,var(--blue),#45bfff);color:#fff;box-shadow:0 18px 38px rgba(31,143,207,.26)}
.btn-outline{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.05);color:#fff;backdrop-filter:blur(14px)}
.btn:hover,.btn:focus-visible{transform:translateY(-3px);box-shadow:0 22px 50px rgba(0,0,0,.34),0 0 34px rgba(31,143,207,.24);outline:0}
.btn:hover:before,.btn:focus-visible:before{transform:translateX(120%)}
.hero{--hero-parallax:0px;min-height:100vh;display:flex;align-items:center;overflow:hidden;position:relative;background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.54),rgba(0,0,0,.86)),url("../images/showroom-spa-occitan.webp");background-size:cover;background-position:center calc(50% + var(--hero-parallax));transition:background-position .18s linear}
.hero:before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(circle at 24% 42%,rgba(31,143,207,.12),transparent 32%),linear-gradient(180deg,rgba(5,5,5,.1),rgba(5,5,5,.34))}
.hero:after{content:"";position:absolute;inset:auto 0 0;height:180px;z-index:1;background:linear-gradient(to bottom,transparent,var(--bg))}
.hero-glow{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(31,143,207,.24),transparent 70%);top:-220px;right:-240px}
.hero-content{position:relative;z-index:2;text-shadow:0 2px 22px rgba(0,0,0,.34)}
.hero-content>p{font-size:23px;max-width:820px;margin:26px 0 0}
.hero-subline{color:#fff;font-weight:800}
.hero-slogan{font-size:18px;color:rgba(255,255,255,.78)}
.hero-actions{margin-top:34px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.home-hero,.vente-spa-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.54),rgba(0,0,0,.86)),url("../images/showroom-spa-occitan.webp") center/cover}
.spa-hero,.installation-spa-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.5),rgba(0,0,0,.84)),url("../images/spa-bien-etre-terrasse.webp") center/cover}
.sauna-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/sauna/sauna-premium-bois.webp") center/cover}
.amenagement-hero,.pergola-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/pergola-terrasse-exterieure.webp") center/cover}
.terrain-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/terrain-petanque-jardin.webp") center/cover}
.embellissement-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/pergola-ombrage-terrasse.webp") center/cover}
.construction-hero,.structures-hero,.terrasse-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/terrasse-bois-espace-detente.webp") center/cover}
.bardage-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/cloture-bois-exterieure.webp") center/cover}
.claustra-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/spa-occitan-garde-corps-terrasse.webp") center/cover}
.equipements-hero,.cuisine-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/cuisine-exterieure-plancha.webp") center/cover}
.brasero-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/brasero-terrasse-conviviale.webp") center/cover}
.chauffage-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/chauffage-exterieur-terrasse-soiree.webp") center/cover}
.piscine-hero{background:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.48),rgba(0,0,0,.82)),url("../images/spa-occitan-piscine-terrasse.webp") center/cover}
.emo-hero{background:linear-gradient(90deg,rgba(0,0,0,.9),rgba(0,0,0,.58),rgba(0,0,0,.86)),url("../images/installation-technique-exterieure.webp") center/cover}
.gallery-hero{background:linear-gradient(90deg,rgba(0,0,0,.9),rgba(0,0,0,.56),rgba(0,0,0,.86)),url("../images/showroom-spa-occitan.webp") center/cover}
.contact-hero,.legal-hero{min-height:70vh;background:linear-gradient(90deg,rgba(0,0,0,.9),rgba(0,0,0,.6),rgba(0,0,0,.88)),url("../images/showroom-spa-occitan.webp") center/cover}
.hero{background-size:cover;background-position:center calc(50% + var(--hero-parallax))}
.page-hero{min-height:78vh}
.hero-quick-grid{max-width:960px;margin-top:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.hero-quick-card{min-height:118px;padding:24px;display:flex;align-items:center;justify-content:center;text-align:center;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);color:var(--text);font-weight:900}
.split{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:76px;align-items:center}
.page-split{align-items:start}
.content .btn,.section-heading .btn{margin-top:28px}
.image-card{position:relative;isolation:isolate;min-height:520px;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);background:var(--surface)}
.image-card:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(145deg,rgba(255,255,255,.08),transparent 42%,rgba(31,143,207,.08));opacity:.72;transition:opacity .45s ease}
.image-card img{height:100%;min-height:520px;transition:transform 1.1s var(--ease-premium),filter .6s ease}
.image-card:hover{box-shadow:var(--shadow-hover);border-color:rgba(31,143,207,.28)}
.image-card:hover:after{opacity:1}
.image-card:hover img{transform:scale(1.045);filter:saturate(1.04)}
.object-position-top,.object-position-top img{object-position:center top}
.object-position-center,.object-position-center img{object-position:center}
.object-position-bottom,.object-position-bottom img{object-position:center bottom}
.dark{background:linear-gradient(180deg,#090909,#050505)}
.premium-list{list-style:none;display:grid;gap:14px;margin:28px 0}
.premium-list li{padding:17px 18px;border-radius:14px;background:linear-gradient(135deg,var(--surface),var(--surface-light));border:1px solid var(--border)}
.premium-list a{color:#fff;text-decoration:underline;text-decoration-color:rgba(31,143,207,.55);text-underline-offset:4px}
.inline-links{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.inline-links a{padding:12px 15px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid var(--border);color:#fff;font-weight:900;transition:var(--transition)}
.inline-links a:hover,.inline-links a:focus-visible{background:var(--blue-soft);border-color:rgba(31,143,207,.5);outline:0}
.services{background:radial-gradient(circle at top right,rgba(31,143,207,.16),transparent 34%),linear-gradient(180deg,#0c0c0c,#050505)}
.section-heading{max-width:870px}
.section-heading p{font-size:20px}
.service-grid,.card-grid{margin-top:56px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px}
.card-grid.three{grid-template-columns:repeat(3,1fr)}
.service-card{position:relative;isolation:isolate;overflow:hidden;min-height:360px;border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;gap:14px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);transition:transform .34s var(--ease-premium),box-shadow .34s ease,border-color .34s ease}
.service-card:before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.92),rgba(0,0,0,.48) 42%,rgba(0,0,0,.12));z-index:-1;transition:opacity .36s ease}
.service-card:after{content:"";position:absolute;inset:1px;border-radius:calc(var(--radius) - 1px);border:1px solid rgba(255,255,255,.08);pointer-events:none;opacity:.65;transition:opacity .34s ease,border-color .34s ease}
.service-card img{position:absolute;inset:0;height:100%;z-index:-2;transition:transform 1.05s var(--ease-premium),filter .7s ease}
.service-card h4{color:#fff}
.service-card p{font-size:15px}
.service-card span{display:inline-flex;align-items:center;gap:8px;color:#fff;font-size:13px;font-weight:900;opacity:.82;transform:translateY(0);transition:opacity .32s ease,transform .32s var(--ease-premium)}
.service-card span:after{content:"";width:26px;height:1px;background:var(--blue);transform:scaleX(.5);transform-origin:left;transition:transform .32s var(--ease-premium)}
.link-card{min-height:310px;padding:30px;display:flex;flex-direction:column;justify-content:space-between;border-radius:var(--radius);background:linear-gradient(135deg,var(--surface),var(--surface-light));border:1px solid var(--border);box-shadow:var(--shadow);transition:var(--transition)}
.link-card:hover{transform:translateY(-8px);border-color:rgba(31,143,207,.5);box-shadow:var(--shadow-hover)}
.link-card p{font-size:16px}
.link-card span{color:var(--blue);font-weight:900;margin-top:26px;transition:transform .28s var(--ease-premium)}
@media(hover:hover){
  .service-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-hover);border-color:rgba(31,143,207,.38)}
  .service-card:hover:before{opacity:.9}
  .service-card:hover:after{opacity:1;border-color:rgba(31,143,207,.34)}
  .service-card:hover img{transform:scale(1.055);filter:saturate(1.05)}
  .service-card:hover span,.service-card:focus-visible span{opacity:1;transform:translateY(-2px)}
  .service-card:hover span:after,.service-card:focus-visible span:after{transform:scaleX(1)}
  .link-card:hover span,.link-card:focus-visible span{transform:translateX(4px)}
}
.gallery{display:grid;grid-template-columns:1.2fr .8fr 1fr 1fr;gap:18px}
.gallery img{height:380px;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);transition:transform .42s var(--ease-premium),box-shadow .42s ease,filter .42s ease}
.gallery img:nth-child(2){height:460px}
.gallery img:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover);filter:saturate(1.04)}
.gallery-intro{padding-bottom:42px}
.gallery-filter-bar{position:sticky;top:96px;z-index:80;padding:16px 0;background:rgba(5,5,5,.78);backdrop-filter:blur(18px);border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.gallery-filters{display:flex;gap:10px;flex-wrap:wrap}
.gallery-filter{min-height:42px;padding:0 16px;border:1px solid rgba(255,255,255,.14);border-radius:999px;background:rgba(255,255,255,.04);color:rgba(255,255,255,.72);font-size:14px;font-weight:900;cursor:pointer;transition:var(--transition)}
.gallery-filter:hover,.gallery-filter:focus-visible,.gallery-filter.is-active{color:#fff;border-color:rgba(31,143,207,.55);background:rgba(31,143,207,.16);outline:0}
.gallery-category{padding:78px 0;border-top:1px solid rgba(255,255,255,.06)}
.gallery-category[hidden]{display:none}
.gallery-category-heading{max-width:780px;margin-bottom:28px}
.gallery-category-heading p{max-width:700px}
.photo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.photo-card{overflow:hidden;border-radius:18px;background:var(--surface);border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 45px rgba(0,0,0,.28);transition:transform .34s var(--ease-premium),box-shadow .34s ease,border-color .34s ease}
.photo-button{width:100%;padding:0;border:0;background:transparent;cursor:zoom-in;display:block;text-align:left;overflow:hidden}
.photo-button img{height:300px;transition:transform .9s var(--ease-premium),filter .45s ease}
.photo-button:hover img,.photo-button:focus-visible img{transform:scale(1.045);filter:saturate(1.04)}
.photo-button:focus-visible{outline:2px solid var(--blue);outline-offset:3px}
.photo-card:hover{transform:translateY(-6px);border-color:rgba(31,143,207,.36);box-shadow:var(--shadow-hover)}
.photo-card figcaption{padding:14px 16px 16px;color:rgba(255,255,255,.74);font-size:14px;font-weight:800}
.gallery-lightbox{position:fixed;inset:0;z-index:1200;display:grid;place-items:center;padding:24px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s ease,visibility .28s ease}
.gallery-lightbox.is-open{opacity:1;visibility:visible;pointer-events:auto}
.gallery-lightbox-overlay{position:absolute;inset:0;background:rgba(0,0,0,.86);backdrop-filter:blur(10px)}
.gallery-lightbox-dialog{position:relative;width:min(1120px,100%);max-height:calc(100vh - 48px);display:grid;gap:16px;outline:0;transform:translateY(16px) scale(.985);transition:transform .34s var(--ease-premium)}
.gallery-lightbox.is-open .gallery-lightbox-dialog{transform:translateY(0) scale(1)}
.gallery-lightbox-image{max-height:calc(100vh - 140px);width:100%;object-fit:contain;border-radius:20px;background:#050505;box-shadow:0 28px 80px rgba(0,0,0,.6)}
.gallery-lightbox-caption{color:#fff;font-weight:900;text-align:center}
.gallery-lightbox-close{position:absolute;top:14px;right:14px;width:46px;height:46px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:rgba(5,5,5,.72);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.gallery-lightbox-close:hover,.gallery-lightbox-close:focus-visible{border-color:rgba(31,143,207,.55);outline:0}
.gallery-lightbox-close svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}
.emo-card,.compact-cta{padding:58px;border-radius:40px;background:linear-gradient(135deg,rgba(31,143,207,.18),rgba(57,181,74,.08)),var(--surface);border:1px solid rgba(31,143,207,.24);box-shadow:var(--shadow)}
.emo-card p,.compact-cta p{max-width:900px}
.emo-card .btn,.compact-cta .btn{margin-top:28px}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:46px}
.why-card{padding:30px;min-height:210px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition)}
.why-card p{font-size:15px}
.why-card:hover{transform:translateY(-8px);border-color:rgba(57,181,74,.35);box-shadow:var(--shadow)}
.cta{background:linear-gradient(90deg,rgba(0,0,0,.86),rgba(0,0,0,.55)),url("../images/showroom-spa-occitan.webp") center/cover}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:50px}
.cta-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.contact-form{padding:34px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:grid;gap:14px;box-shadow:var(--shadow)}
label{font-weight:900;font-size:14px}
input,select,textarea{width:100%;padding:15px 16px;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#080808;color:#fff;font:inherit;outline:0}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-soft)}
.legal-content{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.legal-block{padding:32px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow)}
.legal-block h2{font-size:clamp(28px,3vw,42px);margin-bottom:18px}
.legal-block p{font-size:16px}
.faq-list{margin-top:38px;display:grid;gap:16px}
.faq-item{padding:26px;border-radius:24px;background:linear-gradient(135deg,var(--surface),var(--surface-light));border:1px solid var(--border);box-shadow:var(--shadow)}
.faq-item h3{font-size:22px;margin-bottom:10px}
.faq-item p{font-size:16px}
footer{background:#030303;padding:78px 0 30px;border-top:1px solid rgba(255,255,255,.08)}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:60px;padding-bottom:46px}
.footer-logo-link{display:inline-block;margin-bottom:18px}
.footer-logo{width:92px;height:auto;margin-bottom:0}
footer h6{text-transform:uppercase;letter-spacing:0;font-size:13px;margin-bottom:18px}
footer ul{list-style:none;display:grid;gap:10px}
footer li{color:rgba(255,255,255,.62)}
footer a{transition:var(--transition)}
footer a:hover{color:var(--blue)}
.footer-emo-link{display:inline-block;margin-top:14px;max-width:420px;color:rgba(255,255,255,.42);font-size:13px}
.footer-emo-link:hover{color:rgba(255,255,255,.72)}
.footer-catalogue-link{padding:0;border:0;background:transparent;color:rgba(255,255,255,.62);cursor:pointer;transition:var(--transition)}
.footer-catalogue-link:hover{color:var(--blue)}
.footer-bottom{padding-top:24px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;gap:20px;color:rgba(255,255,255,.48);font-size:14px}
.floating-cta{position:fixed;right:18px;top:50%;transform:translateY(-50%);z-index:250;display:grid;gap:12px}
.cta-float{position:relative;width:54px;height:54px;min-height:54px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:999px;background:rgba(5,5,5,.74);border:1px solid var(--border);color:var(--text);box-shadow:0 18px 42px rgba(0,0,0,.38),0 0 34px rgba(31,143,207,.12);backdrop-filter:blur(18px);transition:var(--transition);cursor:pointer}
.cta-float svg{width:21px;height:21px;flex:0 0 21px}
.cta-phone svg{color:var(--green)}
.cta-map svg{color:var(--blue)}
.cta-top svg{color:#fff}
.cta-float:hover,.cta-float:focus-visible{transform:translateX(-6px);border-color:rgba(31,143,207,.5);box-shadow:0 22px 50px rgba(0,0,0,.44),0 0 42px rgba(31,143,207,.22);outline:0}
.cta-float:after{content:attr(data-tooltip);position:absolute;right:calc(100% + 10px);top:50%;transform:translateY(-50%) translateX(6px);padding:8px 10px;border-radius:999px;background:rgba(5,5,5,.9);border:1px solid rgba(255,255,255,.1);color:#fff;font-size:12px;font-weight:900;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;transition:var(--transition)}
.cta-float:hover:after,.cta-float:focus-visible:after{opacity:1;visibility:visible;transform:translateY(-50%) translateX(0)}
.catalogue-modal{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;padding:24px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s ease,visibility .28s ease}
.catalogue-modal.is-open{opacity:1;visibility:visible;pointer-events:auto}
.catalogue-overlay{position:absolute;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(8px)}
.catalogue-dialog{position:relative;width:min(1120px,100%);max-height:calc(100vh - 48px);overflow:auto;padding:42px;border-radius:32px;background:linear-gradient(135deg,rgba(31,143,207,.13),rgba(57,181,74,.06)),#080808;border:1px solid rgba(255,255,255,.12);box-shadow:0 34px 90px rgba(0,0,0,.65),0 0 70px rgba(31,143,207,.14);outline:0;transform:translateY(18px) scale(.985);transition:transform .34s var(--ease-premium),border-color .34s ease,box-shadow .34s ease}
.catalogue-modal.is-open .catalogue-dialog{transform:translateY(0) scale(1)}
.catalogue-close{position:absolute;top:18px;right:18px;width:46px;height:46px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:rgba(255,255,255,.04);cursor:pointer;transition:var(--transition)}
.catalogue-close svg{width:22px;height:22px}
.catalogue-close:hover,.catalogue-close:focus-visible{border-color:rgba(31,143,207,.5);color:#fff;outline:0}
.catalogue-heading{max-width:760px;padding-right:52px}
.catalogue-grid{margin-top:34px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.catalogue-card{overflow:hidden;border-radius:24px;background:var(--surface);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow);transition:transform .32s var(--ease-premium),box-shadow .32s ease,border-color .32s ease}
.catalogue-card:hover{transform:translateY(-6px);border-color:rgba(31,143,207,.38);box-shadow:var(--shadow-hover)}
.catalogue-card img{height:190px;transition:transform .85s var(--ease-premium),filter .45s ease}
.catalogue-card:hover img{transform:scale(1.04);filter:saturate(1.04)}
.catalogue-card div{padding:24px}
.catalogue-card h3{font-size:28px;margin-bottom:10px}
.catalogue-card p{font-size:15px}
.catalogue-card .btn{width:100%;margin-top:22px}
.reveal{opacity:1;transform:none;filter:none}
body.reveal-ready .reveal{opacity:0;transform:translateY(28px);filter:blur(8px);transition:opacity .78s ease,transform .78s var(--ease-premium),filter .78s ease;transition-delay:var(--reveal-delay,0ms);will-change:opacity,transform,filter}
body.reveal-ready .reveal.active{opacity:1;transform:translateY(0);filter:blur(0)}
@media(min-width:1440px){
  .container{width:min(1440px,calc(100% - 72px))}
  .nav{width:min(1480px,calc(100% - 56px))}
  .section{padding:118px 0}
  .hero{min-height:92vh}
  .page-hero{min-height:74vh}
  .hero-content>p{max-width:880px}
  .hero-actions{margin-top:38px}
  .split{gap:92px}
  .image-card,.image-card img{min-height:560px}
  .service-grid,.card-grid,.why-grid,.photo-grid{gap:26px}
  .service-card{min-height:390px;padding:30px}
  .section-heading{max-width:980px}
  .gallery img{height:420px}
  .gallery img:nth-child(2){height:500px}
  .photo-button img{height:330px}
  .footer-grid{grid-template-columns:1.2fr .75fr 1.15fr;gap:80px}
}
@media(min-width:1800px){
  .container{width:min(1560px,calc(100% - 96px))}
  .nav{width:min(1560px,calc(100% - 72px))}
  .hero{min-height:88vh}
  .page-hero{min-height:70vh}
  .home-hero .hero-content{padding-top:22px}
  .hero-content>p{max-width:900px}
  .split{gap:110px}
  .image-card,.image-card img{min-height:590px}
  .service-grid,.card-grid{gap:30px}
  .service-card{min-height:420px;padding:34px}
  .link-card{min-height:330px}
  .why-grid{gap:24px}
  .why-card{min-height:230px}
  .gallery{gap:24px}
  .gallery img{height:450px}
  .gallery img:nth-child(2){height:530px}
  .photo-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .photo-button img{height:320px}
}
@media(max-width:1380px) and (min-width:1181px){
  .nav{width:min(100% - 28px,1400px);gap:12px}
  .logo{gap:10px}
  .logo img{width:60px;height:60px}
  .logo span{font-size:14px}
  .menu-list{gap:2px}
  .menu-link{padding:0 7px;font-size:14px}
  .catalogue-menu-button{padding:0 12px}
}
@media(max-width:1180px){
  .nav{position:relative}
  .logo img{width:66px;height:66px}
  .nav-toggle{display:inline-flex;flex:0 0 50px;position:fixed;top:18px;right:18px;z-index:360}
  .has-submenu:after{display:none}
  .menu{position:fixed;top:86px;right:18px;width:min(420px,calc(100vw - 36px));max-height:calc(100vh - 110px);overflow:auto;padding:12px;display:block;border-radius:24px;background:#050505;border:1px solid var(--border);box-shadow:var(--shadow);backdrop-filter:blur(18px);opacity:0;transform:translateY(-8px);visibility:hidden;pointer-events:none;transition:opacity .24s ease,transform .24s ease}
  header.nav-open .menu{opacity:1;transform:translateY(0);visibility:visible;pointer-events:auto}
  .menu-list{display:grid;gap:5px}
  .menu-link{width:100%;min-height:48px;justify-content:space-between;padding:0 16px;border-radius:16px;white-space:normal;text-align:left}
  .submenu{position:static;min-width:0;margin:4px 0 8px;padding:0 0 0 10px;display:none;border:0;border-left:1px solid var(--border);border-radius:0;background:transparent;box-shadow:none;opacity:1;visibility:visible;pointer-events:auto;transform:none;backdrop-filter:none}
  .has-submenu:hover .submenu,.has-submenu:focus-within .submenu{display:none}
  .has-submenu.submenu-open .submenu{display:grid}
  .submenu a{padding:12px 14px}
  .split,.cta-inner,.footer-grid{grid-template-columns:1fr;display:grid}
  .service-grid,.card-grid,.why-grid,.legal-content{grid-template-columns:repeat(2,1fr)}
  .card-grid.three{grid-template-columns:repeat(2,1fr)}
  .gallery,.photo-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .container{width:min(100% - 28px,1200px)}
  .section{padding:78px 0}
  header{padding:10px 0}
  .nav{width:min(100% - 24px,1400px)}
  .logo img{width:60px;height:60px}
  .logo span{font-size:13px}
  .hero{min-height:auto;padding:145px 0 90px}
  .page-hero{min-height:auto}
  h1{font-size:42px}
  h2{font-size:34px}
  .hero-content{width:calc(100% - 28px);max-width:360px;min-width:0;margin-left:14px;margin-right:auto}
  .hero-content>p{max-width:100%;overflow-wrap:break-word}
  .hero-content>p{font-size:19px}
  .hero-actions{align-items:stretch}
  .hero-actions .btn{width:100%}
  .hero-quick-grid{grid-template-columns:1fr}
  .hero-quick-card{min-height:96px}
  .service-grid,.card-grid,.card-grid.three,.why-grid,.legal-content,.gallery,.photo-grid,.catalogue-grid{grid-template-columns:1fr}
  .service-card{min-height:360px;padding:26px 24px 82px}
  .image-card,.image-card img{min-height:360px}
  .gallery img,.gallery img:nth-child(2),.photo-button img{height:310px}
  .gallery-filter-bar{top:80px}
  .gallery-filters{gap:8px;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}
  .gallery-filter{flex:0 0 auto}
  .gallery-category{padding:58px 0}
  .gallery-lightbox{padding:12px}
  .gallery-lightbox-image{max-height:calc(100vh - 120px);border-radius:16px}
  .emo-card,.compact-cta{padding:34px 24px;border-radius:28px}
  .legal-block{padding:26px 22px}
  footer{padding-bottom:118px}
  .footer-bottom{flex-direction:column}
  .catalogue-modal{padding:14px}
  .catalogue-dialog{padding:30px 18px 22px;border-radius:24px}
  .catalogue-heading{padding-right:48px}
  .catalogue-card img{height:175px}
  .floating-cta{top:auto;left:50%;right:auto;bottom:18px;transform:translateX(-50%);display:flex;gap:10px}
  .cta-float{width:48px;height:48px;min-height:48px;border-radius:18px}
  .cta-float:after{display:none}
}
@media(max-width:420px){
  .menu{width:calc(100vw - 24px)}
  h1{font-size:38px}
  .btn{width:100%;padding:0 18px}
  .cta-actions{width:100%}
  .cta-actions .btn{width:100%}
}
@media(hover:none){
  .btn:hover,.service-card:hover,.link-card:hover,.image-card:hover,.photo-card:hover,.catalogue-card:hover,.gallery img:hover,.cta-float:hover{transform:none}
  .service-card:hover img,.image-card:hover img,.photo-button:hover img,.catalogue-card:hover img{transform:none;filter:none}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero{--hero-parallax:0px!important;background-position:center!important}
  body.reveal-ready .reveal,.reveal{opacity:1!important;transform:none!important;filter:none!important}
}
