/* =========================================================
   JOAILLERIE HOUILLON — main.css
   Reproduction Framer. Marine / Creme / Cuivre.
   ========================================================= */
:root{
    --navy:#1a3a6a;
    --navy-deep:#142d54;
    --navy-darker:#0e2444;
    --navy-rgb:26,58,106;
    --cream:#f2ede5;
    --cream-soft:#f7f3ec;
    --copper:#c97f56;
    --copper-light:#dc9269;
    --copper-rgb:201,127,86;
    --ink:#22324c;
    --ink-soft:#4a5a72;
    --line:rgba(26,58,106,.14);
    --white:#ffffff;

    --font-display:'Jomolhari', Georgia, 'Times New Roman', serif;
    --font-body:'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    --wrap:1180px;
    --wrap-narrow:820px;
    --header-h:84px;
    --ease:cubic-bezier(.22,1,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html,body{overflow-x:hidden}
body{
    margin:0;max-width:100vw;
    font-family:var(--font-body);
    color:var(--ink);
    background:var(--cream);
    font-size:16px;line-height:1.7;font-weight:400;
    -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px 14px;z-index:9999;border-radius:4px}

/* ---------- TYPO ---------- */
h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:400;margin:0;line-height:1.18}
.hou-h2{
    font-family:var(--font-display);
    font-size:clamp(1.7rem,3.4vw,2.7rem);
    letter-spacing:.10em;text-transform:uppercase;
    color:var(--navy);margin:0 0 1.4rem;font-weight:400;
}
.hou-h2--center{text-align:center}
.hou-h2--light{color:var(--white)}
.hou-eyebrow{
    font-family:var(--font-body);font-size:.72rem;font-weight:600;
    letter-spacing:.34em;text-transform:uppercase;color:var(--copper);margin:0 0 1rem;
}
.hou-eyebrow--center{text-align:center}
.hou-eyebrow--light{color:var(--copper-light)}

/* ---------- LAYOUT ---------- */
.hou-wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 28px}
.hou-section{padding:96px 0;position:relative}
.hou-section--cream{background:var(--cream)}
.hou-section--navy{background:var(--navy);color:var(--white)}
.hou-section--navy .hou-h2{color:var(--white)}

/* ---------- BUTTONS ---------- */
.btn-resa{
    display:inline-flex;align-items:center;justify-content:center;gap:.5em;
    font-family:var(--font-body);font-size:.74rem;font-weight:600;
    letter-spacing:.2em;text-transform:uppercase;
    padding:15px 32px;border-radius:2px;cursor:pointer;border:1px solid var(--navy);
    background:var(--navy);color:var(--white);
    transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease);
}
.btn-resa:hover{background:var(--copper);border-color:var(--copper);color:var(--white)}
.btn-resa--light{background:transparent;border-color:rgba(255,255,255,.55);color:#fff}
.btn-resa--light:hover{background:var(--copper);border-color:var(--copper)}

.hou-link-arrow{
    display:inline-flex;align-items:center;gap:.6em;
    font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--copper);
    transition:gap .3s var(--ease),color .3s var(--ease);
}
.hou-link-arrow i{font-size:.78em;transition:transform .3s var(--ease)}
.hou-link-arrow:hover{color:var(--copper-light)}
.hou-link-arrow:hover i{transform:translateX(5px)}
.hou-section--navy .hou-link-arrow{color:var(--copper-light)}

/* =========================================================
   HEADER
   ========================================================= */
.hou-header{
    position:fixed;top:0;left:0;width:100%;z-index:1000;
    transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
    padding:12px 0;
}
.hou-header__inner{
    width:100%;max-width:1340px;margin:0 auto;padding:0 32px;
    display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.hou-brand{flex:0 0 auto;display:flex;align-items:center}
.hou-brand__img{height:58px;width:auto;filter:brightness(0) invert(1);transition:filter .4s var(--ease)}
.hou-nav__list{
    list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:center;
}
.hou-nav__list a{
    font-family:var(--font-body);font-size:.78rem;font-weight:500;letter-spacing:.13em;text-transform:uppercase;
    color:rgba(255,255,255,.92);position:relative;padding:6px 0;transition:color .3s var(--ease);
}
.hou-nav__list a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--copper-light);transition:width .3s var(--ease)}
.hou-nav__list a:hover{color:#fff}
.hou-nav__list a:hover::after{width:100%}
.hou-nav__list .current-menu-item>a::after{width:100%}
.hou-resa{flex:0 0 auto;padding:12px 24px;font-size:.68rem;background:var(--copper);border-color:var(--copper)}
.hou-resa:hover{background:#fff;border-color:#fff;color:var(--navy)}

/* scrolled state */
.hou-header.is-scrolled{background:var(--navy);box-shadow:0 6px 28px rgba(10,24,44,.25);padding:6px 0}
.hou-header.is-scrolled .hou-brand__img{height:48px}

.hou-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.hou-burger span{width:26px;height:2px;background:#fff;display:block;transition:.3s}

/* mobile menu overlay */
.hou-mobile{
    position:fixed;inset:0;z-index:1100;background:var(--navy-deep);
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
    opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;
}
.hou-mobile.is-open{opacity:1;visibility:visible}
.hou-mobile__close{position:absolute;top:24px;right:28px;background:none;border:0;color:#fff;font-size:2.4rem;line-height:1;cursor:pointer}
.hou-mobile__list{list-style:none;margin:0;padding:0;text-align:center;display:flex;flex-direction:column;gap:6px}
.hou-mobile__list a{
    font-family:var(--font-display);font-size:1.5rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;padding:10px;display:block;
}
.hou-mobile__list a:hover{color:var(--copper-light)}
.hou-mobile__resa{margin-top:24px}

/* =========================================================
   HERO (home)
   ========================================================= */
.hou-hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hou-hero__bg{position:absolute;inset:0;z-index:0}
.hou-hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hou-hero__veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,28,52,.55) 0%,rgba(14,28,52,.42) 45%,rgba(14,28,52,.72) 100%)}
.hou-hero__content{position:relative;z-index:2;color:#fff;padding:120px 24px 60px;max-width:900px}
.hou-hero__crest{width:150px;height:auto;margin:0 auto 26px;opacity:.95}
.hou-hero__eyebrow{font-family:var(--font-body);font-size:.8rem;font-weight:600;letter-spacing:.5em;text-transform:uppercase;color:rgba(255,255,255,.9);margin:0 0 12px;padding-left:.5em}
.hou-hero__title{font-family:var(--font-display);font-size:clamp(2.2rem,6vw,4.6rem);letter-spacing:.14em;text-transform:uppercase;margin:0;font-weight:400}
.hou-hero__subtitle{font-family:var(--font-display);font-size:clamp(1.5rem,4vw,2.8rem);letter-spacing:.42em;text-transform:uppercase;margin:.4rem 0 0;color:var(--copper-light);padding-left:.4em}
.hou-hero__scroll{display:inline-flex;flex-direction:column;align-items:center;gap:12px;margin-top:48px;font-size:.7rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:#fff}
.hou-hero__chev{width:38px;height:38px;border:1px solid rgba(255,255,255,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;animation:hou-bounce 2s infinite}
@keyframes hou-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* =========================================================
   INTRO
   ========================================================= */
.hou-intro__grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.hou-intro__text .hou-h2{margin-bottom:1.6rem}
.hou-richtext{color:var(--ink-soft);font-size:1rem;line-height:1.85}
.hou-richtext p{margin:0 0 1.2rem}
.hou-richtext p:last-child{margin-bottom:0}
.hou-intro__hours{margin:1.6rem 0 1.8rem;font-size:.92rem;color:var(--ink);font-weight:500;white-space:pre-line}
.hou-intro__media img{width:100%;height:100%;object-fit:cover;border-radius:3px;box-shadow:0 28px 60px rgba(14,28,52,.18)}

/* =========================================================
   DECOUVREZ (cards)
   ========================================================= */
.hou-disc__title{margin-bottom:3rem;color:#fff}
.hou-disc__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.hou-disc-card{position:relative;display:block;height:430px;overflow:hidden;border-radius:3px;background:var(--navy-deep)}
.hou-disc-card__media,.hou-disc-card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hou-disc-card__media img{transition:transform .8s var(--ease)}
.hou-disc-card__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,28,52,.1) 0%,rgba(14,28,52,.8) 100%)}
.hou-disc-card__body{position:absolute;left:0;right:0;bottom:0;padding:26px 22px;z-index:2;display:flex;flex-direction:column;gap:14px}
.hou-disc-card__title{font-family:var(--font-display);font-size:1.18rem;letter-spacing:.06em;color:#fff;line-height:1.3}
.hou-disc-card__more{font-size:.66rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--copper-light);display:inline-flex;align-items:center;gap:.5em}
.hou-disc-card.hou-card-clickable:hover .hou-disc-card__media img{transform:scale(1.07)}
.hou-disc-card.hou-card-clickable:hover .hou-disc-card__more{color:#fff}

/* =========================================================
   CREATION
   ========================================================= */
.hou-creation__inner{max-width:var(--wrap-narrow);margin:0 auto;text-align:center}
.hou-creation__text{margin-top:1.5rem;font-size:1.02rem}
.hou-creation__text p{margin-bottom:1.4rem}

/* =========================================================
   NOS SERVICES
   ========================================================= */
.hou-serv__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;margin-top:1.5rem}
.hou-serv__list{display:flex;flex-direction:column;gap:34px}
.hou-serv-item{border-left:2px solid rgba(255,255,255,.16);padding-left:24px}
.hou-serv-item__title{font-size:1.3rem;letter-spacing:.05em;color:#fff;margin:0 0 .6rem;text-transform:uppercase}
.hou-serv-item__text{color:rgba(255,255,255,.74);font-size:.94rem;margin:0 0 1rem;line-height:1.75}
.hou-serv__media{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.hou-serv__img{overflow:hidden;border-radius:3px}
.hou-serv__img img{width:100%;height:100%;object-fit:cover}
.hou-serv__img--1{grid-row:span 2;min-height:480px}
.hou-serv__img--2{min-height:230px}

/* =========================================================
   CITATION / HISTOIRE
   ========================================================= */
.hou-quote__inner{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.hou-quote__media{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:end}
.hou-quote__img{overflow:hidden;border-radius:3px}
.hou-quote__img img{width:100%;height:100%;object-fit:cover}
.hou-quote__img--1{margin-top:36px}
.hou-quote__mark{font-family:var(--font-display);font-size:5rem;line-height:.6;color:var(--copper);display:block;margin-bottom:.4rem}
.hou-quote__line{font-family:var(--font-display);font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.5;color:var(--navy);margin:0 0 1.8rem}

/* =========================================================
   PRENONS RENDEZ-VOUS
   ========================================================= */
.hou-rdv__inner{text-align:center;max-width:900px;margin:0 auto}
.hou-rdv__text{color:rgba(255,255,255,.82);font-size:1.05rem;max-width:620px;margin:0 auto 1.4rem}
.hou-rdv__hours{color:#fff;margin:0 0 2rem;white-space:pre-line;line-height:1.8}
.hou-rdv__hours strong{color:var(--copper-light);font-weight:600;letter-spacing:.04em}
.hou-rdv__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px}

/* ---------- INFO CARDS ---------- */
.hou-info-card{background:var(--cream-soft);border-radius:4px;padding:34px 24px;text-align:center;box-shadow:0 10px 30px rgba(14,28,52,.08)}
.hou-info-card--light{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);box-shadow:none}
.hou-info-card__icon{width:52px;height:52px;border-radius:50%;background:var(--navy);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:1.05rem;margin-bottom:16px}
.hou-info-card--light .hou-info-card__icon{background:var(--copper)}
.hou-info-card__label{font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--copper);margin:0 0 .6rem}
.hou-info-card--light .hou-info-card__label{color:var(--copper-light)}
.hou-info-card p{margin:0;font-size:.92rem;line-height:1.6;white-space:pre-line}
.hou-info-card--light p{color:rgba(255,255,255,.86)}
.hou-info-card a{transition:color .3s}
.hou-info-card a:hover{color:var(--copper)}

/* =========================================================
   PAGE HERO (interior)
   ========================================================= */
.page-hero{position:relative;min-height:54vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:var(--navy)}
.page-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.page-hero__veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,28,52,.62),rgba(14,28,52,.7));z-index:1}
.page-hero--plain{background:var(--navy)}
.page-hero--plain .page-hero__veil{background:none}
.page-hero__content{position:relative;z-index:2;color:#fff;padding:130px 24px 70px;max-width:880px}
.page-hero__eyebrow{font-family:var(--font-body);font-size:.74rem;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--copper-light);margin:0 0 14px}
.page-hero__title{font-family:var(--font-display);font-size:clamp(1.9rem,4.6vw,3.4rem);letter-spacing:.12em;text-transform:uppercase;margin:0;font-weight:400}
.page-hero__sub{margin:1rem 0 0;font-size:1.02rem;color:rgba(255,255,255,.85);font-family:var(--font-body)}

/* =========================================================
   PAGE BODY (raw HTML content from editor)
   ========================================================= */
.hou-page-body{background:var(--cream)}
.hou-richtext h2,.hou-page-body h2{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.1rem);letter-spacing:.08em;text-transform:uppercase;color:var(--navy);margin:0 0 1.2rem}
.hou-richtext h3,.hou-page-body h3{font-family:var(--font-display);font-size:1.35rem;letter-spacing:.04em;color:var(--navy);margin:2rem 0 .8rem}

/* shared content sections (used by interior page raw HTML) */
.hou-block{padding:84px 0}
.hou-block--cream{background:var(--cream)}
.hou-block--navy{background:var(--navy);color:#fff}
.hou-block--soft{background:var(--cream-soft)}
.hou-block--navy h2,.hou-block--navy h3{color:#fff}
.hou-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.hou-grid-2--text p{color:var(--ink-soft)}
.hou-media img{width:100%;border-radius:3px;object-fit:cover;box-shadow:0 22px 50px rgba(14,28,52,.16)}
.hou-lead{font-size:1.08rem;line-height:1.85;color:var(--ink-soft)}
.hou-center{max-width:var(--wrap-narrow);margin:0 auto;text-align:center}
.hou-center .hou-lead{text-align:left}
.hou-legal{max-width:840px;margin:0 auto}
.hou-legal h2{font-size:1.15rem;letter-spacing:.06em;margin:2.2rem 0 .7rem;color:var(--navy)}
.hou-legal p,.hou-legal li{color:var(--ink-soft);font-size:.95rem}
.hou-legal ul{margin:0 0 1.2rem;padding-left:1.2rem}

/* numbered steps (process) */
.hou-steps{display:flex;flex-direction:column;gap:18px;margin-top:1.5rem;counter-reset:step}
.hou-step{display:grid;grid-template-columns:auto 1fr auto;gap:26px;align-items:center;background:var(--cream-soft);border:1px solid var(--line);border-radius:4px;padding:24px 28px}
.hou-block--navy .hou-step{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12)}
.hou-step__num{counter-increment:step;font-family:var(--font-display);font-size:1.4rem;color:var(--copper);width:54px;height:54px;border:1px solid var(--copper);border-radius:50%;display:flex;align-items:center;justify-content:center}
.hou-step__num::before{content:counter(step,decimal-leading-zero)}
.hou-step__body h3{margin:0 0 .3rem;font-size:1.12rem;text-transform:uppercase;letter-spacing:.04em}
.hou-step__body p{margin:0;color:var(--ink-soft);font-size:.94rem}
.hou-block--navy .hou-step__body p{color:rgba(255,255,255,.74)}
.hou-step__media{width:120px;height:90px;overflow:hidden;border-radius:3px}
.hou-step__media img{width:100%;height:100%;object-fit:cover}

/* 3-card row */
.hou-cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:1.5rem}
.hou-mini-card{background:var(--cream-soft);border:1px solid var(--line);border-radius:4px;overflow:hidden;display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.hou-mini-card.hou-card-clickable:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(14,28,52,.16)}
.hou-mini-card__media{aspect-ratio:3/2;overflow:hidden}
.hou-mini-card__media img{width:100%;height:100%;object-fit:cover}
.hou-mini-card__body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.hou-mini-card__title{font-family:var(--font-display);font-size:1.15rem;color:var(--navy);text-transform:uppercase;letter-spacing:.04em}
.hou-mini-card__text{font-size:.9rem;color:var(--ink-soft);margin:0;flex:1}

/* CTA band */
.hou-cta-band{background:var(--navy);color:#fff;text-align:center;padding:90px 0}
.hou-cta-band h2{color:#fff}
.hou-cta-band p{color:rgba(255,255,255,.82);max-width:600px;margin:1rem auto 1.8rem}

/* gallery grid */
.hou-gallery{columns:3;column-gap:16px}
.hou-gallery img{width:100%;margin-bottom:16px;border-radius:3px;break-inside:avoid;transition:filter .4s,transform .4s}
.hou-gallery a:hover img{filter:brightness(1.05)}

/* =========================================================
   ACTUS
   ========================================================= */
.hou-actus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.hou-actu-card{background:var(--cream-soft);border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.hou-actu-card:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(14,28,52,.16)}
.hou-actu-card__link{display:flex;flex-direction:column;height:100%}
.hou-actu-card__media{aspect-ratio:16/10;overflow:hidden;display:block}
.hou-actu-card__media img{width:100%;height:100%;object-fit:cover}
.hou-actu-card__body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.hou-actu-card__date{font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--copper)}
.hou-actu-card__title{font-family:var(--font-display);font-size:1.2rem;color:var(--navy);line-height:1.35}
.hou-actu-card__excerpt{font-size:.9rem;color:var(--ink-soft);flex:1}
.hou-actu-card__more{font-size:.66rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--copper)}
.hou-pagination{margin-top:48px;text-align:center}
.hou-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 8px;margin:0 4px;border:1px solid var(--line);border-radius:3px;color:var(--navy);font-size:.85rem}
.hou-pagination .page-numbers.current{background:var(--navy);color:#fff;border-color:var(--navy)}
.hou-empty{text-align:center;color:var(--ink-soft);padding:40px 0}

/* article */
.hou-page-body--article{padding:80px 0}
.hou-article{max-width:760px;margin:0 auto;padding:0 28px}
.hou-article p{margin:0 0 1.3rem;color:var(--ink-soft);line-height:1.85}
.hou-article img{border-radius:3px;margin:1.6rem 0}
.hou-back{max-width:760px;margin:2.4rem auto 0;padding:0 28px}
.hou-back a{color:var(--copper);font-weight:600;font-size:.85rem;letter-spacing:.04em}

/* =========================================================
   CONTACT
   ========================================================= */
.hou-contact__head{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;margin-bottom:48px}
.hou-contact__lead{font-size:1.05rem;color:var(--ink-soft);margin:0 0 1.2rem}
.hou-contact__hours{font-size:.95rem;color:var(--ink);white-space:pre-line}
.hou-contact__hours strong{color:var(--navy)}
.hou-contact__photo img{width:100%;border-radius:3px;box-shadow:0 22px 50px rgba(14,28,52,.16)}
.hou-contact__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:56px}
.hou-form-wrap{max-width:760px;margin:0 auto}
.hou-form-title{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--navy);text-align:center;margin:0 0 2rem;letter-spacing:.02em}
.hou-form__row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.hou-form__field{display:flex;flex-direction:column;gap:8px}
.hou-form__field span{font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.hou-form__field input,.hou-form__field textarea{
    font-family:var(--font-body);font-size:.95rem;padding:13px 16px;border:1px solid var(--line);border-radius:3px;background:#fff;color:var(--ink);width:100%;
}
.hou-form__field input:focus,.hou-form__field textarea:focus{outline:none;border-color:var(--copper)}
.hou-form__field--full{margin-bottom:24px}
.hou-form__submit{width:100%}
.hou-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.hou-form-flash{padding:14px 18px;border-radius:3px;margin-bottom:20px;font-size:.92rem}
.hou-form-flash--ok{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.hou-form-flash--err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* =========================================================
   FOOTER
   ========================================================= */
.hou-footer{background:var(--navy-deep);color:#fff;padding:70px 0 36px;text-align:center}
.hou-footer__inner{max-width:var(--wrap);margin:0 auto;padding:0 28px}
.hou-footer__logo{height:120px;width:auto;margin:0 auto 36px}
.hou-footer__list{list-style:none;margin:0 0 38px;padding:0;display:flex;flex-wrap:wrap;gap:14px 34px;justify-content:center}
.hou-footer__list a{font-size:.74rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.82);transition:color .3s}
.hou-footer__list a:hover{color:var(--copper-light)}
.hou-footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:26px;display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:center;font-size:.78rem;color:rgba(255,255,255,.6)}
.hou-footer__bottom p{margin:0}
.hou-footer__legal{color:rgba(255,255,255,.6);text-decoration:underline;text-underline-offset:3px}
.hou-footer__legal:hover{color:var(--copper-light)}

.hou-top{position:fixed;right:24px;bottom:24px;width:46px;height:46px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;z-index:900;opacity:0;visibility:hidden;transform:translateY(10px);transition:.35s var(--ease)}
.hou-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}
.hou-top:hover{background:var(--copper)}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
    .hou-nav{display:none}
    .hou-resa{display:none}
    .hou-burger{display:flex}
    .hou-disc__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
    .hou-section{padding:64px 0}
    .hou-intro__grid,.hou-serv__grid,.hou-quote__inner,.hou-contact__head,.hou-grid-2{grid-template-columns:1fr;gap:36px}
    .hou-serv__media,.hou-quote__media{grid-template-columns:1fr 1fr}
    .hou-rdv__cards,.hou-contact__cards,.hou-cards-3,.hou-actus-grid{grid-template-columns:1fr}
    .hou-gallery{columns:2}
    .hou-form__row{grid-template-columns:1fr}
    .hou-quote__inner .hou-quote__media{order:-1}
    .hou-serv__img--1{min-height:300px}
}
@media (max-width:560px){
    .hou-disc__grid{grid-template-columns:1fr}
    .hou-gallery{columns:1}
    .hou-step{grid-template-columns:auto 1fr;gap:16px}
    .hou-step__media{display:none}
    .hou-header__inner{padding:0 18px}
    .hou-hero__content{padding-top:110px}
}
