/* ============================================================
   HYCONTROL STORE — Thème public
   Couleurs : cuivre #BE7C4C · marine #162D4F
   ============================================================ */

/* ---------- Polices locales (Poppins) ---------- */
@font-face{font-family:'Poppins';font-style:normal;font-weight:300;font-display:swap;src:url('../fonts/poppins-300.woff2') format('woff2');}
@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/poppins-400.woff2') format('woff2');}
@font-face{font-family:'Poppins';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/poppins-500.woff2') format('woff2');}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/poppins-600.woff2') format('woff2');}
@font-face{font-family:'Poppins';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/poppins-700.woff2') format('woff2');}
@font-face{font-family:'Poppins';font-style:normal;font-weight:800;font-display:swap;src:url('../fonts/poppins-800.woff2') format('woff2');}

:root{
  --navy:#162D4F;
  --navy-700:#1f3c66;
  --navy-900:#0f2038;
  --copper:#BE7C4C;
  --copper-600:#a96a3d;
  --copper-100:#f3e6da;
  --ink:#1c2433;
  --muted:#6b7686;
  --line:#e7e9ef;
  --bg:#ffffff;
  --bg-soft:#f6f7fa;
  --radius:14px;
  --shadow-sm:0 2px 10px rgba(22,45,79,.06);
  --shadow:0 14px 40px rgba(22,45,79,.12);
  --container:1240px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins',system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  margin:0;
  line-height:1.6;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container-x{max-width:var(--container);margin:0 auto;padding:0 20px}

h1,h2,h3,h4{font-weight:700;color:var(--navy);line-height:1.2;letter-spacing:-.01em}
.section{padding:72px 0}
.text-copper{color:var(--copper)!important}
.text-navy{color:var(--navy)!important}
.bg-navy{background:var(--navy)!important;color:#fff}
.bg-soft{background:var(--bg-soft)!important}

/* ---------- Boutons ---------- */
.btn-copper{
  --bs-btn-bg:var(--copper);--bs-btn-border-color:var(--copper);
  --bs-btn-hover-bg:var(--copper-600);--bs-btn-hover-border-color:var(--copper-600);
  --bs-btn-active-bg:var(--copper-600);--bs-btn-active-border-color:var(--copper-600);
  --bs-btn-color:#fff;--bs-btn-hover-color:#fff;--bs-btn-active-color:#fff;
  --bs-btn-disabled-bg:var(--copper);--bs-btn-disabled-border-color:var(--copper);
  font-weight:600;letter-spacing:.01em;
}
.btn-navy{
  --bs-btn-bg:var(--navy);--bs-btn-border-color:var(--navy);
  --bs-btn-hover-bg:var(--navy-900);--bs-btn-hover-border-color:var(--navy-900);
  --bs-btn-active-bg:var(--navy-900);
  --bs-btn-color:#fff;--bs-btn-hover-color:#fff;--bs-btn-active-color:#fff;font-weight:600;
}
.btn-outline-navy{
  --bs-btn-color:var(--navy);--bs-btn-border-color:var(--navy);
  --bs-btn-hover-bg:var(--navy);--bs-btn-hover-border-color:var(--navy);--bs-btn-hover-color:#fff;
  font-weight:600;
}
.btn{border-radius:999px;padding:.62rem 1.4rem}
.btn-lg{padding:.85rem 2rem}

.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;font-weight:600;
  color:var(--copper);
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--copper)}

/* ============================================================
   HEADER
   ============================================================ */
.topbar{background:var(--navy-900);color:#cdd6e4;font-size:.82rem}
.topbar a{color:#cdd6e4}
.topbar a:hover{color:#fff}
.topbar .container-x{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:9px;padding-bottom:9px;flex-wrap:wrap}
.topbar .tb-info{display:flex;gap:1.4rem;flex-wrap:wrap;align-items:center}
.topbar .tb-info i{color:var(--copper);margin-right:.35rem}
.topbar .tb-social a{margin-left:.7rem;font-size:.95rem}

.site-header{position:sticky;top:0;z-index:1030;background:#fff;border-bottom:1px solid var(--line);transition:box-shadow .2s}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-main{display:flex;align-items:center;gap:1.5rem;padding:14px 0}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand img{height:50px;width:auto}
.brand .brand-text{font-weight:800;font-size:1.5rem;color:var(--navy);letter-spacing:.02em;line-height:1}
.brand .brand-text span{color:var(--copper)}
.brand .brand-sub{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:500}

.header-search{flex:1;max-width:520px}
.header-search form{display:flex;background:var(--bg-soft);border:1px solid var(--line);border-radius:999px;overflow:hidden}
.header-search input{flex:1;border:0;background:transparent;padding:.6rem 1.1rem;outline:none;font-size:.92rem}
.header-search button{border:0;background:var(--copper);color:#fff;padding:0 1.1rem;font-size:1.05rem}

.header-actions{display:flex;align-items:center;gap:.4rem;margin-left:auto}
.icon-btn{position:relative;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  color:var(--navy);background:var(--bg-soft);font-size:1.15rem;border:0;cursor:pointer;transition:.2s}
.icon-btn:hover{background:var(--navy);color:#fff}
.icon-btn .badge-count{position:absolute;top:-3px;right:-3px;background:var(--copper);color:#fff;
  font-size:.66rem;font-weight:700;min-width:20px;height:20px;border-radius:999px;display:grid;place-items:center;padding:0 5px}

/* ---------- Navigation ---------- */
.main-nav{background:var(--navy)}
.main-nav .container-x{display:flex;align-items:center;gap:.3rem}
.main-nav a.nav-link{color:#e7ecf4;font-weight:500;padding:.85rem 1.05rem;font-size:.93rem;position:relative;display:flex;align-items:center;gap:.4rem}
.main-nav a.nav-link:hover,.main-nav a.nav-link.active{color:#fff}
.main-nav a.nav-link::after{content:"";position:absolute;left:1.05rem;right:1.05rem;bottom:.55rem;height:2px;background:var(--copper);transform:scaleX(0);transform-origin:left;transition:.25s}
.main-nav a.nav-link:hover::after,.main-nav a.nav-link.active::after{transform:scaleX(1)}
.main-nav .nav-cta{margin-left:auto}

/* Dropdown catégories */
.has-mega{position:relative}
.mega{position:absolute;top:100%;left:0;background:#fff;min-width:260px;border-radius:0 0 var(--radius) var(--radius);
  box-shadow:var(--shadow);padding:.6rem;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;z-index:50}
.has-mega:hover .mega{opacity:1;visibility:visible;transform:translateY(0)}
.mega a{display:flex;align-items:center;gap:.6rem;padding:.6rem .8rem;border-radius:10px;color:var(--ink);font-size:.9rem;font-weight:500}
.mega a:hover{background:var(--copper-100);color:var(--navy)}
.mega a i{color:var(--copper)}

/* Burger mobile */
.nav-toggle{display:none}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;background-color:var(--navy-900);background-size:cover;background-position:center;color:#fff;overflow:hidden}
.hero .hero-overlay{position:absolute;inset:0;z-index:1;background:
  linear-gradient(110deg,rgba(15,32,56,.94) 0%,rgba(22,45,79,.86) 45%,rgba(15,32,56,.55) 100%),
  radial-gradient(700px 400px at 88% -10%,rgba(190,124,76,.40),transparent 60%);}
.hero .container-x{position:relative;z-index:2;padding:96px 20px 104px}
.hero-content{max-width:680px}
.hero h1{color:#fff;font-size:clamp(2.1rem,4.6vw,3.6rem);max-width:16ch}
.hero p{color:#cdd6e4;font-size:1.12rem;max-width:52ch;margin:1.2rem 0 2rem}
.hero .eyebrow{color:var(--copper)}
.hero-stats{display:flex;gap:2.5rem;margin-top:3rem;flex-wrap:wrap}
.hero-stats .num{font-size:2rem;font-weight:800;color:#fff}
.hero-stats .lbl{font-size:.82rem;color:#aab6c8;text-transform:uppercase;letter-spacing:.1em}

/* ============================================================
   CARTES CATÉGORIES
   ============================================================ */
.cat-card{position:relative;border-radius:var(--radius);overflow:hidden;display:block;height:230px;background:var(--navy);box-shadow:var(--shadow-sm)}
.cat-card img{width:100%;height:100%;object-fit:cover;transition:.5s}
.cat-card:hover img{transform:scale(1.07)}
.cat-card .ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(15,32,56,.86));display:flex;flex-direction:column;justify-content:flex-end;padding:1.2rem}
.cat-card .ov h3{color:#fff;font-size:1.12rem;margin:0}
.cat-card .ov span{color:var(--copper);font-size:.8rem;font-weight:600;display:inline-flex;align-items:center;gap:.35rem;margin-top:.25rem}
.cat-card.empty{display:grid;place-items:center;color:#fff}
.cat-card.empty .ov{position:static;background:none;align-items:center}

/* ============================================================
   CARTES PRODUITS
   ============================================================ */
.product-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;height:100%;display:flex;flex-direction:column;transition:.25s}
.product-card:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:transparent}
.product-card .pc-media{position:relative;aspect-ratio:4/3;background:var(--bg-soft);overflow:hidden}
.product-card .pc-media img{width:100%;height:100%;object-fit:cover;transition:.5s}
.product-card:hover .pc-media img{transform:scale(1.06)}
.product-card .pc-cat{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.92);color:var(--navy);font-size:.7rem;font-weight:600;padding:.25rem .6rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}
.product-card .pc-quick{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;gap:.4rem;opacity:0;transform:translateX(8px);transition:.25s}
.product-card:hover .pc-quick{opacity:1;transform:translateX(0)}
.product-card .pc-quick a{width:38px;height:38px;border-radius:50%;background:#fff;display:grid;place-items:center;color:var(--navy);box-shadow:var(--shadow-sm)}
.product-card .pc-quick a:hover{background:var(--navy);color:#fff}
.product-card .pc-body{padding:1rem 1.1rem 1.2rem;display:flex;flex-direction:column;flex:1}
.product-card .pc-ref{font-size:.72rem;color:var(--muted);letter-spacing:.05em}
.product-card .pc-title{font-size:1.02rem;font-weight:600;color:var(--navy);margin:.15rem 0 .5rem}
.product-card .pc-title a:hover{color:var(--copper)}
.product-card .pc-desc{font-size:.85rem;color:var(--muted);margin-bottom:1rem}
.product-card .pc-foot{margin-top:auto}
.btn-add-quote{width:100%}
.btn-add-quote.added{--bs-btn-bg:var(--navy);--bs-btn-border-color:var(--navy)}

/* ============================================================
   PANNEAU DEVIS (offcanvas custom)
   ============================================================ */
.quote-drawer{position:fixed;top:0;right:0;height:100%;width:400px;max-width:92vw;background:#fff;z-index:2000;
  box-shadow:-20px 0 60px rgba(15,32,56,.25);transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column}
.quote-drawer.open{transform:translateX(0)}
.quote-backdrop{position:fixed;inset:0;background:rgba(15,32,56,.5);z-index:1999;opacity:0;visibility:hidden;transition:.3s}
.quote-backdrop.open{opacity:1;visibility:visible}
.quote-head{background:var(--navy);color:#fff;padding:1.1rem 1.3rem;display:flex;align-items:center;justify-content:space-between}
.quote-head h5{color:#fff;margin:0;font-size:1.05rem}
.quote-head .close-q{background:none;border:0;color:#fff;font-size:1.5rem;line-height:1}
.quote-body{flex:1;overflow-y:auto;padding:1rem 1.1rem}
.q-item{display:flex;gap:.8rem;padding:.7rem 0;border-bottom:1px solid var(--line)}
.q-item img{width:62px;height:62px;object-fit:cover;border-radius:10px;background:var(--bg-soft)}
.q-item .qi-info{flex:1;min-width:0}
.q-item .qi-name{font-size:.9rem;font-weight:600;color:var(--navy);margin:0}
.q-item .qi-ref{font-size:.72rem;color:var(--muted)}
.q-qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;overflow:hidden;margin-top:.35rem}
.q-qty button{border:0;background:var(--bg-soft);width:26px;height:26px;color:var(--navy);font-weight:700}
.q-qty span{min-width:30px;text-align:center;font-size:.85rem;font-weight:600}
.q-remove{background:none;border:0;color:#c0392b;font-size:1rem}
.quote-foot{padding:1rem 1.1rem;border-top:1px solid var(--line)}
.quote-empty{text-align:center;color:var(--muted);padding:3rem 1rem}
.quote-empty i{font-size:3rem;color:var(--line);display:block;margin-bottom:1rem}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--navy-900);color:#aeb9ca;padding-top:64px;font-size:.92rem}
.site-footer h5{color:#fff;font-size:1rem;margin-bottom:1.2rem;text-transform:uppercase;letter-spacing:.06em}
.site-footer a{color:#aeb9ca}
.site-footer a:hover{color:var(--copper)}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{margin-bottom:.6rem}
.footer-contact li{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:.9rem}
.footer-contact i{color:var(--copper);margin-top:.2rem}
.footer-social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.07);display:inline-grid;place-items:center;margin-right:.5rem;color:#fff}
.footer-social a:hover{background:var(--copper)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:48px;padding:20px 0;font-size:.82rem;color:#7c8aa0}

/* ============================================================
   DIVERS / PAGES
   ============================================================ */
.page-hero{background:linear-gradient(120deg,var(--navy-900),var(--navy));color:#fff;padding:60px 0}
.page-hero h1{color:#fff}
.breadcrumb-x{font-size:.85rem;color:#aab6c8}
.breadcrumb-x a{color:#cdd6e4}
.breadcrumb-x a:hover{color:var(--copper)}

.feature{display:flex;gap:1rem;align-items:flex-start}
.feature .fi{flex-shrink:0;width:54px;height:54px;border-radius:14px;background:var(--copper-100);color:var(--copper);display:grid;place-items:center;font-size:1.4rem}
.feature h4{font-size:1.05rem;margin:.1rem 0 .35rem}
.feature p{color:var(--muted);font-size:.9rem;margin:0}

/* Cartes avantages — hauteur & texte homogènes */
.feature-card{height:100%;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem 1.4rem;transition:.25s}
.feature-card:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:transparent}
.feature-card .fi{width:54px;height:54px;border-radius:14px;background:var(--copper-100);color:var(--copper);display:grid;place-items:center;font-size:1.5rem;margin-bottom:1rem}
.feature-card h4{font-size:1.08rem;margin:0 0 .5rem;min-height:2.6rem;display:flex;align-items:center}
.feature-card p{color:var(--muted);font-size:.9rem;margin:0;line-height:1.65;
  display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;min-height:5.9rem}

/* ---------- Carrousel (catégories) ---------- */
.carousel-wrap{position:relative}
.carousel-track{display:flex;gap:1.2rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:6px 2px 1.4rem;-ms-overflow-style:none;scrollbar-width:none}
.carousel-track::-webkit-scrollbar{display:none}
.carousel-item-x{flex:0 0 300px;max-width:300px;scroll-snap-align:start}

/* Catégories : image ronde sans fond + nom dessous (5 visibles) */
.cat-circle{flex:0 0 calc((100% - 4 * 1.2rem) / 5);max-width:none;display:flex;flex-direction:column;align-items:center;
  text-align:center;scroll-snap-align:start;padding:.3rem;color:var(--navy)}
.cat-circle .cc-img{width:100%;aspect-ratio:1;max-width:170px;border-radius:50%;overflow:hidden;background:transparent;
  display:block;transition:transform .3s ease,box-shadow .3s ease}
.cat-circle .cc-img img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.cat-circle:hover .cc-img{transform:translateY(-4px) scale(1.04);box-shadow:0 16px 30px rgba(22,45,79,.18)}
.cat-circle .cc-name{margin-top:1rem;font-size:1rem;font-weight:600;color:var(--navy);transition:color .2s}
.cat-circle:hover .cc-name{color:var(--copper)}
@media(max-width:991px){.cat-circle{flex-basis:calc((100% - 2 * 1.2rem) / 3)}}
@media(max-width:575px){.cat-circle{flex-basis:calc((100% - 1.2rem) / 2)}}
.carousel-nav{position:absolute;top:calc(50% - 1.4rem);transform:translateY(-50%);width:48px;height:48px;border-radius:50%;
  border:0;background:#fff;color:var(--navy);box-shadow:var(--shadow);display:grid;place-items:center;font-size:1.2rem;cursor:pointer;z-index:5;transition:.2s}
.carousel-nav:hover{background:var(--copper);color:#fff}
.carousel-nav.prev{left:-18px}
.carousel-nav.next{right:-18px}
.carousel-nav:disabled{opacity:0;pointer-events:none}
@media(max-width:575px){.carousel-item-x{flex-basis:78vw;max-width:78vw}.carousel-nav.prev{left:4px}.carousel-nav.next{right:4px}}

/* ---------- Témoignages ---------- */
.testimonial-card{height:100%;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;margin:0;position:relative;transition:.25s}
.testimonial-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.testimonial-card::before{content:"\201C";position:absolute;top:.4rem;right:1.2rem;font-size:4rem;line-height:1;color:var(--copper-100);font-family:Georgia,serif}
.testimonial-card .t-stars{color:var(--copper);font-size:.9rem;margin-bottom:.8rem;letter-spacing:.1rem}
.testimonial-card blockquote{font-size:.95rem;color:var(--ink);line-height:1.7;margin:0 0 1.4rem;position:relative;z-index:1}
.testimonial-card figcaption{display:flex;align-items:center;gap:.8rem}
.testimonial-card .t-avatar{width:48px;height:48px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:700;overflow:hidden;flex-shrink:0}
.testimonial-card .t-avatar img{width:100%;height:100%;object-fit:cover}
.testimonial-card figcaption strong{display:block;color:var(--navy);font-size:.95rem}
.testimonial-card figcaption span{display:block;color:var(--muted);font-size:.8rem}

/* ---------- Références (partenaires) ---------- */
.references .ref-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.2rem}
.ref-item{height:96px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  display:grid;place-items:center;padding:1rem;transition:.25s}
.ref-item:hover{background:rgba(255,255,255,.12);border-color:var(--copper)}
.ref-item img{max-height:54px;max-width:100%;object-fit:contain;filter:brightness(0) invert(1);opacity:.85}
.ref-item span{color:#dfe6f0;font-weight:600;font-size:1rem;text-align:center}
@media(max-width:991px){.references .ref-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.references .ref-grid{grid-template-columns:repeat(2,1fr)}}

.section-head{text-align:center;max-width:640px;margin:0 auto 48px}
.section-head h2{font-size:clamp(1.7rem,3vw,2.4rem);margin:.6rem 0 .6rem}
.section-head p{color:var(--muted)}

.cta-band{background:linear-gradient(120deg,var(--copper),var(--copper-600));color:#fff;border-radius:22px;padding:48px;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;right:-40px;top:-40px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.12)}
.cta-band h2{color:#fff}

.empty-state{text-align:center;padding:70px 20px;color:var(--muted)}
.empty-state i{font-size:3.4rem;color:var(--line);display:block;margin-bottom:1rem}

.form-control,.form-select{border-radius:10px;border-color:var(--line);padding:.65rem .9rem}
.form-control:focus,.form-select:focus{border-color:var(--copper);box-shadow:0 0 0 .2rem rgba(190,124,76,.18)}

.toast-quote{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--navy);color:#fff;
  padding:.8rem 1.4rem;border-radius:999px;box-shadow:var(--shadow);z-index:2100;opacity:0;visibility:hidden;transition:.3s;font-weight:500}
.toast-quote.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.toast-quote i{color:var(--copper);margin-right:.4rem}

/* ---------- Animations d'apparition ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:991px){
  .header-search{display:none}
  .main-nav .container-x{display:none;flex-direction:column;align-items:stretch;padding-bottom:1rem}
  .main-nav.open .container-x{display:flex}
  .main-nav a.nav-link{padding:.8rem 0}
  .main-nav a.nav-link::after{display:none}
  .nav-cta{margin:.5rem 0 0!important}
  .nav-toggle{display:grid;place-items:center;background:var(--navy);color:#fff;border:0;width:100%;padding:.7rem;font-weight:600;gap:.5rem}
  .mega{position:static;box-shadow:none;opacity:1;visibility:visible;transform:none;display:none;padding-left:1rem}
  .has-mega.open .mega{display:block}
  .hero-stats{gap:1.5rem}
}
@media(max-width:575px){
  .topbar .tb-info{font-size:.74rem;gap:.8rem}
  .section{padding:48px 0}
}
