/*
Theme Name: MJ Marechalerie
Theme URI: https://www.mj-marechalerie.be
Author: MJ Marechalerie
Description: Theme WordPress pour MJ Marechalerie
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GPL v2 or later
Text Domain: mj-marechalerie
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
    --black:#0a0a0a;--white:#ffffff;--off-white:#f8f7f5;--cream:#f9f8f6;
    --g100:#e8e6e3;--g200:#d5d2ce;--g300:#c5c3c0;--g500:#888;--g700:#555;--g900:#1a1a1a;
    --line:#e0ddd8;--line-d:#2a2a2a;
    --serif:'Playfair Display',Georgia,serif;--sans:'Instrument Sans',system-ui,sans-serif;
    --ease:cubic-bezier(.16,1,.3,1);--ease-out:cubic-bezier(.33,1,.68,1)
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--white);color:var(--black);overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--black);color:var(--white)}
img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}

/* LOADER */
.mj-loader{position:fixed;inset:0;background:var(--white);z-index:10000;display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s ease}
.mj-loader.done{opacity:0;visibility:hidden;pointer-events:none}
.mj-loader-bar{width:100px;height:1px;background:var(--g100);position:relative;overflow:hidden}
.mj-loader-bar::after{content:'';position:absolute;left:0;top:0;height:100%;width:0;background:var(--black);animation:mjLoad 1s var(--ease) forwards}
@keyframes mjLoad{to{width:100%}}

/* GRAIN */
.mj-grain{position:fixed;inset:-50%;width:200%;height:200%;z-index:9998;pointer-events:none;opacity:.015;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:128px;animation:mjG .5s steps(4) infinite}
@keyframes mjG{0%{transform:translate(0)}25%{transform:translate(-5%,-5%)}50%{transform:translate(5%,5%)}75%{transform:translate(-3%,3%)}}

/* NAV */
.mj-nav{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:1.5rem 4vw;display:flex;justify-content:space-between;align-items:center;transition:all .5s var(--ease)}
.mj-nav::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--line);opacity:0;transition:opacity .5s ease}
.mj-nav.scrolled{padding:0.8rem 4vw;background:rgba(255,255,255,.96);backdrop-filter:blur(20px)}.mj-nav.scrolled::after{opacity:1}
.mj-nav-logo img{height:80px;width:auto;object-fit:contain;transition:all .5s var(--ease)}
.mj-nav.scrolled .mj-nav-logo img{height:52px}
.mj-nav-links{display:flex;gap:2.8rem;list-style:none}
.mj-nav-links a{color:var(--black);font-size:.72rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;position:relative;padding:.4rem 0}
.mj-nav-links a::after{content:'';position:absolute;bottom:0;left:50%;width:0;height:1px;background:var(--black);transition:all .5s var(--ease);transform:translateX(-50%)}.mj-nav-links a:hover::after{width:100%}
.mj-nav-cta{font-size:.7rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--white);background:var(--black);padding:.65rem 1.8rem;transition:all .4s var(--ease);display:inline-block}
.mj-nav-cta:hover{background:transparent;color:var(--black);box-shadow:inset 0 0 0 1px var(--black)}
.mj-menu-toggle{display:none;background:none;border:1px solid var(--line);width:44px;height:44px;align-items:center;justify-content:center;flex-direction:column;gap:5px;padding:0;cursor:pointer}
.mj-menu-toggle span{display:block;width:18px;height:1px;background:var(--black);transition:all .4s var(--ease);transform-origin:center}
.mj-mobile-menu{position:fixed;inset:0;background:var(--white);z-index:999;display:flex;flex-direction:column;justify-content:center;padding:2rem 6vw;clip-path:inset(0 0 100% 0);transition:clip-path .7s var(--ease)}
.mj-mobile-menu.open{clip-path:inset(0 0 0 0)}
.mj-mobile-menu a{font-family:var(--serif);font-size:clamp(2rem,6vw,3rem);font-weight:400;color:var(--black);display:block;padding:.8rem 0;border-bottom:1px solid var(--line);transition:padding-left .4s var(--ease)}.mj-mobile-menu a:hover{padding-left:1.5rem}

/* HERO */
.mj-hero{height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;position:relative;overflow:hidden;background:var(--white);color:var(--black)}
.mj-hero-content{position:relative;z-index:1;max-width:820px;padding:0 4vw}
.mj-hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(3.2rem,10vw,8.5rem);line-height:.95;letter-spacing:-.03em;text-transform:uppercase;opacity:0;transform:translateY(30px);animation:mjRU 1s 1.3s var(--ease) forwards}
.mj-hero h1 span{display:block;font-style:italic;font-weight:400;font-size:.4em;text-transform:none;letter-spacing:.01em;margin-top:.3em;color:var(--g700)}
.mj-hero-desc{font-size:1rem;font-weight:400;line-height:1.75;color:var(--g700);max-width:580px;margin:2.5rem auto 0;opacity:0;transform:translateY(15px);animation:mjRU .8s 1.6s var(--ease) forwards}
.mj-hero-btn{margin-top:3rem;opacity:0;transform:translateY(15px);animation:mjRU .8s 1.9s var(--ease) forwards}
.mj-btn-dark{display:inline-flex;align-items:center;gap:.8rem;background:var(--black);color:var(--white);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:1.1rem 3rem;transition:all .5s var(--ease)}
.mj-btn-dark:hover{background:transparent;color:var(--black);box-shadow:inset 0 0 0 1px var(--black)}
.mj-btn-dark svg{transition:all .4s var(--ease)}.mj-btn-dark:hover svg{stroke:var(--black);transform:translateX(4px)}
@keyframes mjP{0%,100%{opacity:.2;transform:scaleY(.7)}50%{opacity:.8;transform:scaleY(1)}}

/* ===================== SERVICES PANELS ===================== */
.mj-services-wrap{background:var(--black);padding-top:1px}
.mj-services-header{padding:5rem 4vw 3rem;text-align:left}
.mj-services-header h2{font-family:var(--serif);font-size:clamp(2.2rem,4.5vw,4rem);font-weight:400;line-height:1.12;color:var(--white)}
.mj-services-header h2 em{font-style:italic}

/* 3 panels side by side */
.mj-panels{display:flex;height:75vh;min-height:500px;overflow:hidden}
.mj-panel{position:relative;flex:1;cursor:pointer;overflow:hidden;transition:flex .7s var(--ease)}
.mj-panel:hover,.mj-panel.active{flex:2.5}
.mj-panel-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 6s var(--ease-out);filter:brightness(.45)}
.mj-panel:hover .mj-panel-bg,.mj-panel.active .mj-panel-bg{transform:scale(1.05);filter:brightness(.35)}
.mj-panel-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 50%,transparent 100%)}
.mj-panel-content{position:absolute;bottom:0;left:0;right:0;padding:3rem 2.5rem;z-index:2;color:var(--white)}
.mj-panel-content h3{font-family:var(--serif);font-size:clamp(1.5rem,2.5vw,2.2rem);font-weight:500;margin-bottom:1rem}
.mj-panel-content p{font-size:.88rem;line-height:1.75;color:rgba(255,255,255,.8);display:none;margin-bottom:1.5rem}
.mj-panel:hover .mj-panel-content p,.mj-panel.active .mj-panel-content p{display:block}
.mj-btn-panel{display:none;align-items:center;gap:.6rem;font-size:.68rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--white);border:1px solid rgba(255,255,255,.4);padding:.8rem 2rem;transition:background .3s ease,color .3s ease}
.mj-panel:hover .mj-btn-panel,.mj-panel.active .mj-btn-panel{display:inline-flex}
.mj-btn-panel:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.mj-btn-panel svg{transition:all .4s var(--ease)}.mj-btn-panel:hover svg{stroke:var(--black);transform:translateX(3px)}

/* ===================== ABOUT + CAROUSEL ===================== */
.mj-about{display:grid;grid-template-columns:1fr 1fr;min-height:auto;background:var(--white);margin:4rem 0}
.mj-about-text{padding:3rem 4vw 3rem 6vw;display:flex;flex-direction:column;justify-content:center}
.mj-about-title{font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.8rem);font-weight:400;line-height:1.15;margin-bottom:2rem}.mj-about-title em{font-style:italic}
.mj-about-line{width:50px;height:2px;background:var(--black);margin-bottom:2.5rem}
.mj-about-text p{font-size:.95rem;line-height:1.85;color:var(--g700);margin-bottom:1.5rem;max-width:520px}
.mj-about-text p:last-of-type{margin-bottom:2.5rem}

/* Tags / keywords */
.mj-tags{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.5rem}
.mj-tag{display:inline-block;font-size:.72rem;font-weight:500;letter-spacing:.08em;padding:.6rem 1.4rem;border:1px solid var(--black);color:var(--black);transition:all .4s var(--ease);cursor:default}
.mj-tag:hover{background:var(--black);color:var(--white)}

/* Carousel */
.mj-carousel{position:relative;overflow:hidden;width:85%;aspect-ratio:1/1;margin:auto;align-self:center;border-radius:16px}
.mj-carousel-track{position:absolute;inset:0}
.mj-carousel-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease}
.mj-carousel-slide.active{opacity:1}
.mj-carousel-slide img{width:100%;height:100%;object-fit:cover}
.mj-carousel-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:5;background:rgba(255,255,255,.9);border:none;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--black);transition:all .3s ease}
.mj-carousel-btn:hover{background:var(--white)}
.mj-carousel-prev{left:1.5rem}
.mj-carousel-next{right:1.5rem}
.mj-carousel-dots{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);display:flex;gap:.6rem;z-index:5}
.mj-dot{width:8px;height:8px;border-radius:50%;border:1px solid var(--white);background:transparent;cursor:pointer;transition:all .3s ease;padding:0}
.mj-dot.active{background:var(--white)}

/* ===================== CONTACT ===================== */
.mj-contact-section{background:var(--black);color:var(--white);padding:8rem 6vw}
.mj-contact-wrap{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:6rem}
.mj-contact-left{padding-right:4rem;border-right:1px solid var(--line-d)}
.mj-contact-right{padding-left:5rem}
.mj-col-title{font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.8rem);font-weight:400;line-height:1.15;margin-bottom:2.5rem}.mj-col-title em{font-style:italic}
.mj-info-block{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--line-d)}.mj-info-block:last-child{border-bottom:none}
.mj-info-lbl{font-size:.6rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--g500);margin-bottom:.6rem}
.mj-info-val{font-size:1rem;color:var(--white)}.mj-info-val a{color:var(--white);transition:opacity .3s ease}.mj-info-val a:hover{opacity:.6}
.mj-hours{display:grid;grid-template-columns:auto 1fr;gap:.3rem 1.5rem;font-size:.88rem;color:rgba(255,255,255,.7)}.mj-hours .day{font-weight:500;color:var(--white)}

/* FORM */
.mj-form{display:flex;flex-direction:column;gap:2rem}
.mj-form-row{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.mj-field label{display:block;font-size:.6rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--g500);margin-bottom:.7rem}
.mj-field label .opt{font-weight:400;letter-spacing:.05em;text-transform:none;color:rgba(255,255,255,.25);margin-left:.3rem}
.mj-field input:not([type="checkbox"]):not([type="radio"]),.mj-field textarea,.mj-field select{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line-d);color:var(--white);font-family:var(--sans);font-size:.95rem;padding:.8rem 0;outline:none;transition:border-color .4s ease;border-radius:0;-webkit-appearance:none}
.mj-field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' fill='none' stroke='%23888' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right center;cursor:pointer}
.mj-field select option{background:var(--black);color:var(--white)}
.mj-field input:not([type="checkbox"]):not([type="radio"])::placeholder,.mj-field textarea::placeholder{color:rgba(255,255,255,.15)}
.mj-field input:not([type="checkbox"]):not([type="radio"]):focus,.mj-field textarea:focus,.mj-field select:focus{border-bottom-color:var(--white)}
.mj-field textarea{resize:none;height:80px}
.mj-check-group{display:flex;gap:2rem;padding:.6rem 0}
.mj-check-group label{display:flex;align-items:center;gap:.6rem;font-size:.88rem;font-weight:400;color:var(--white);cursor:pointer;letter-spacing:0;text-transform:none}
.mj-check-group input[type="checkbox"],.mj-check-group input[type="radio"]{-webkit-appearance:auto;appearance:auto;width:18px;height:18px;accent-color:var(--white);cursor:pointer}
.mj-btn-submit{align-self:flex-start;background:var(--white);color:var(--black);border:none;font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:1.1rem 3rem;cursor:pointer;transition:all .5s var(--ease)}
.mj-btn-submit:hover{background:transparent;color:var(--white);box-shadow:inset 0 0 0 1px var(--white)}
.mj-form-success{display:none;padding:2rem;border:1px solid rgba(255,255,255,.2);text-align:center}.mj-form-success.show{display:block}
.mj-form-success h4{font-family:var(--serif);font-size:1.4rem;margin-bottom:.8rem}

/* FAQ */
.mj-faq{background:var(--off-white);color:var(--black);padding:8rem 4vw;overflow:hidden}
.mj-faq-container{max-width:800px;margin:0 auto}
.mj-faq-header{margin-bottom:4rem}
.mj-faq-header h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3.5rem);font-weight:400}.mj-faq-header h2 em{font-style:italic}
.mj-faq-item{border-bottom:1px solid var(--line)}.mj-faq-item:first-child{border-top:1px solid var(--line)}
.mj-faq-q{width:100%;background:none;border:none;text-align:left;font-family:var(--serif);font-size:1.12rem;font-weight:500;color:var(--black);padding:1.8rem 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:2rem;transition:color .3s ease}.mj-faq-q:hover{color:var(--g500)}
.mj-faq-icon{width:24px;height:24px;flex-shrink:0;position:relative}
.mj-faq-icon::before,.mj-faq-icon::after{content:'';position:absolute;background:var(--black);top:50%;left:50%;transform:translate(-50%,-50%);transition:all .4s var(--ease)}
.mj-faq-icon::before{width:14px;height:1px}.mj-faq-icon::after{width:1px;height:14px}
.mj-faq-item.open .mj-faq-icon::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.mj-faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.mj-faq-a-inner{padding:0 0 2rem;font-size:.9rem;line-height:1.85;color:var(--g700);max-width:620px}

/* FOOTER */
.mj-footer{background:var(--black);color:var(--white);padding:5rem 4vw 2rem}
.mj-footer-top{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:4rem;padding-bottom:4rem;border-bottom:1px solid var(--line-d)}
.mj-footer-brand{max-width:320px}.mj-footer-brand img{height:50px;filter:brightness(0) invert(1);margin-bottom:1.5rem}.mj-footer-brand p{font-size:.85rem;line-height:1.7;color:var(--g500)}
.mj-social{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--line-d);border-radius:50%;color:var(--g500);margin-top:1.2rem;transition:all .3s ease}
.mj-social:hover{color:var(--white);border-color:var(--white)}
.mj-footer-col h4{font-family:var(--serif);font-size:1rem;font-weight:500;margin-bottom:1.5rem}
.mj-footer-col ul{list-style:none}.mj-footer-col li{margin-bottom:.8rem}
.mj-footer-col a{font-size:.85rem;color:var(--g500);transition:color .3s ease}.mj-footer-col a:hover{color:var(--white)}
.mj-footer-col p{font-size:.85rem;color:var(--g500);line-height:1.7}
.mj-footer-col .zone-item{font-size:.85rem;color:var(--g500);margin-bottom:.8rem}
.mj-footer-bottom{max-width:1320px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding-top:2rem}
.mj-footer-bottom p{font-size:.7rem;color:rgba(255,255,255,.35)}
.mj-footer-bottom a{font-size:.68rem;color:rgba(255,255,255,.35);letter-spacing:.1em;text-transform:uppercase;transition:color .3s ease;margin-left:2rem}.mj-footer-bottom a:hover{color:var(--white)}

/* STICKY MOBILE */
.mj-sticky{display:none;position:fixed;bottom:0;left:0;right:0;z-index:900;padding:1rem 5vw;background:var(--white);border-top:1px solid var(--line);transform:translateY(100%);transition:transform .5s var(--ease)}
.mj-sticky.show{transform:translateY(0)}
.mj-sticky a{display:block;text-align:center;background:var(--black);color:var(--white);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:1rem}

/* REVEAL */
.mj-r{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform .9s var(--ease)}.mj-r.v{opacity:1;transform:translateY(0)}
@keyframes mjRU{to{opacity:1;transform:translateY(0)}}@keyframes mjFI{to{opacity:1}}

/* ===================== RESPONSIVE ===================== */
@media(max-width:1024px){
    .mj-hero{height:70svh;min-height:500px}
    .mj-panels{height:60vh;min-height:400px}
    .mj-panel-content{padding:2rem 1.8rem}
    .mj-about{grid-template-columns:1fr 1fr}
    .mj-about-text{padding:3rem 3vw 3rem 5vw}
    .mj-contact-wrap{grid-template-columns:1fr;gap:5rem}.mj-contact-left{padding-right:0;border-right:none;border-bottom:1px solid var(--line-d);padding-bottom:5rem}.mj-contact-right{padding-left:0}
    .mj-footer-top{grid-template-columns:1fr 1fr;gap:3rem}
}
@media(max-width:768px){
    .mj-nav{padding:1.2rem 5vw}.mj-nav-links,.mj-nav-cta{display:none}.mj-menu-toggle{display:flex}.mj-sticky{display:block}
    .mj-hero h1{font-size:clamp(2.8rem,13vw,4.5rem)}
    .mj-hero{height:100svh}
    .mj-panels{flex-direction:column;height:auto;min-height:0}
    .mj-panel{min-height:380px;flex:none}.mj-panel:hover{flex:none}
    .mj-panel-content p{display:block;margin-bottom:1rem}
    .mj-btn-panel{display:inline-flex}
    .mj-panel-content{padding:2.5rem 2rem}
    .mj-about{grid-template-columns:1fr}.mj-about{margin:2rem 0}
    .mj-about-text{padding:3rem 5vw}
    .mj-carousel{width:80%;max-height:400px;margin:0 auto 2rem}
    .mj-services-header{padding:4rem 5vw 1.5rem}
    .mj-contact-section{padding:5rem 5vw}.mj-form-row{grid-template-columns:1fr}
    .mj-check-group{flex-direction:column;gap:1rem}
    .mj-faq{padding:5rem 5vw}
    .mj-footer{padding:3rem 5vw 1.5rem}.mj-footer-top{grid-template-columns:1fr;gap:2.5rem}
    .mj-footer-bottom{flex-direction:column;gap:1rem;text-align:center}.mj-footer-bottom a{margin-left:0;margin:0 .8rem}
    .mj-nav-logo img{height:60px;width:auto;object-fit:contain}.mj-nav.scrolled .mj-nav-logo img{height:42px}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}.mj-grain{display:none}}
