/* ════════════════════════════════════════════════════════════════════
   Horsio Site Vitrine — CSS global (utilise les variables de thème)
   Les couleurs viennent du fichier themes/{nom}.css chargé par layout.php
   ════════════════════════════════════════════════════════════════════ */

/* ── Reset ─────────────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
img { max-width:100%; display:block; }
a { color:var(--t-primary); text-decoration:none; transition:color .3s; }
a:hover { color:var(--t-accent,var(--t-primary)); }

body {
  font-family: var(--t-font-body, 'Inter', sans-serif);
  background: var(--t-bg);
  color: var(--t-text);
  line-height: 1.75;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ── Layout ─────────────────────────────────────────────────────────── */
.container { max-width:1180px; margin:0 auto; padding:0 24px; }
.hide-mob { display:inline; }
--section-py: clamp(50px,7vw,70px);

/* ── Typographie ────────────────────────────────────────────────────── */
h1,h2,h3,h4 { font-family:var(--t-font-heading,'Playfair Display',serif); color:var(--t-heading); line-height:1.2; }
h2 { font-size:clamp(1.9rem,4vw,2.9rem); margin-bottom:18px; }
h2 em { font-style:italic; color:var(--t-primary); }
h3 { font-size:1.15rem; margin-bottom:8px; }

/* ── Composants communs ─────────────────────────────────────────────── */
.eq-badge {
  display:inline-flex; align-items:center; gap:7px;
  padding:6px 16px;
  background:var(--t-primary-dim); border:1px solid var(--t-border);
  border-radius:50px; font-size:.78rem; font-weight:600;
  letter-spacing:1px; text-transform:uppercase; color:var(--t-primary);
  margin-bottom:16px;
}
.section-head { text-align:center; max-width:660px; margin:0 auto 56px; }
.section-sub { color:var(--t-text-muted); font-size:1.02rem; line-height:1.8; }
.section-vide { text-align:center; color:var(--t-text-muted); font-size:.9rem; padding:40px 0; }

/* ── Boutons ────────────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 30px; border-radius:50px;
  font-family:var(--t-font-body); font-size:.92rem; font-weight:600;
  cursor:pointer; transition:all .35s; border:none; text-decoration:none;
}
.btn svg { width:17px; height:17px; }
.btn-gold  { background:var(--t-primary-grad); color:var(--t-bg); }
.btn-gold:hover  { transform:translateY(-2px); box-shadow:0 8px 30px var(--t-primary-dim); color:var(--t-bg); }
.btn-ghost { background:transparent; color:var(--t-heading); border:1.5px solid var(--t-border); }
.btn-ghost:hover { border-color:var(--t-primary); background:var(--t-primary-dim); color:var(--t-primary); transform:translateY(-2px); }
.btn-full  { width:100%; justify-content:center; }

/* ── Navbar ─────────────────────────────────────────────────────────── */
.navbar {
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  padding:12px 0; transition:all .4s;
  background:var(--t-nav-bg, transparent);
}
.navbar.scrolled {
  padding:6px 0;
  background:var(--t-nav-bg-scrolled, rgba(17,29,22,.88));
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--t-border);
}
.nav-container { max-width:1180px; margin:0 auto; padding:0 24px; display:flex; align-items:center; justify-content:space-between; }
.nav-logo { display:flex; align-items:center; gap:14px; color:var(--t-heading); }
.nav-logo img.nav-logo-img { height:52px; width:auto; max-width:160px; }
.logo-text { display:flex; flex-direction:column; line-height:1.2; }
.logo-name { font-family:var(--t-font-heading); font-size:1.1rem; color:var(--t-nav-text, var(--t-heading)); }
.logo-tagline { font-size:.62rem; font-weight:600; text-transform:uppercase; letter-spacing:1.5px; color:var(--t-text-muted); }
.nav-menu { display:flex; align-items:center; list-style:none; gap:4px; }
.nav-link { color:var(--t-nav-text, var(--t-text-muted)); font-size:.86rem; font-weight:500; padding:8px 14px; border-radius:50px; transition:all .3s; }
.nav-link:hover, .nav-link.active { color:var(--t-heading); background:var(--t-border-light); }
.nav-link.nav-cta { background:var(--t-primary-grad); color:var(--t-bg); font-weight:600; margin-left:8px; }
.nav-link.nav-cta:hover { box-shadow:0 4px 20px var(--t-primary-dim); color:var(--t-bg); }
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; z-index:1001; }
.nav-toggle span { width:24px; height:2px; background:var(--t-heading); border-radius:2px; transition:all .3s; }
.nav-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav-toggle.active span:nth-child(2) { opacity:0; }
.nav-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── Section wrapper générique ──────────────────────────────────────── */
.h-section { padding:clamp(50px,7vw,70px) 0; background:var(--t-bg); }
.h-section.alt { background:var(--t-bg-alt); }

/* ── Layout : HERO ─────────────────────────────────────────────────── */
.hero { position:relative; min-height:100vh; display:flex; flex-direction:column; justify-content:space-between; overflow:hidden; }
.hero-bg { position:absolute; inset:0; z-index:0; }
.hero-bg img { width:100%; height:100%; object-fit:cover; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(160deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.25) 100%); z-index:1; }
.hero-content { position:relative; z-index:3; padding:140px 24px 24px; max-width:1180px; margin:0 auto; width:100%; flex:1; display:flex; flex-direction:column; justify-content:center; align-items:flex-start; }
.hero-location { display:inline-flex; align-items:center; gap:6px; padding:7px 18px; background:rgba(255,255,255,.08); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.12); border-radius:50px; font-size:.78rem; font-weight:600; color:rgba(255,255,255,.7); margin-bottom:24px; }
.hero-title { font-family:var(--t-font-heading); line-height:1.08; margin-bottom:20px; }
.hero-line-1 { display:block; font-size:clamp(2rem,5vw,3.5rem); color:#fff; }
.hero-line-2 { display:block; font-size:clamp(3rem,8vw,6rem); }
.hero-subtitle { font-size:clamp(.95rem,1.6vw,1.15rem); color:rgba(255,255,255,.65); max-width:540px; line-height:1.8; margin-bottom:32px; }
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; }
.hero-bottom { position:relative; z-index:3; width:100%; padding:0 24px 32px; display:flex; align-items:flex-end; justify-content:space-between; max-width:1180px; margin:0 auto; }
.hero-stats { display:inline-flex; align-items:center; gap:24px; padding:10px 28px; background:rgba(255,255,255,.06); backdrop-filter:blur(12px); border:1px solid rgba(255,255,255,.1); border-radius:14px; }
.hstat { text-align:center; }
.hstat-val { display:block; font-family:var(--t-font-heading); font-size:1.3rem; color:#fff; line-height:1.2; }
.hstat-label { font-size:.7rem; color:rgba(255,255,255,.5); font-weight:600; text-transform:uppercase; letter-spacing:1px; }
.hstat-sep { width:1px; height:32px; background:rgba(255,255,255,.15); }

/* ── Layout : GRID (cards) ──────────────────────────────────────────── */
.svc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; }
.svc-card { background:var(--t-card); border:1px solid var(--t-border); border-radius:var(--t-radius); overflow:hidden; transition:all .35s; }
.svc-card:hover { transform:translateY(-5px); box-shadow:var(--t-shadow); border-color:var(--t-primary-dim); }
.svc-img-wrap { position:relative; height:200px; overflow:hidden; }
.svc-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.svc-card:hover .svc-img-wrap img { transform:scale(1.05); }
.svc-img-overlay { position:absolute; inset:0; background:linear-gradient(to bottom,transparent 40%,var(--t-card)); }
.svc-body { padding:24px 28px 28px; }
.svc-icon { width:48px; height:48px; background:var(--t-primary-dim); border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:14px; position:relative; z-index:2; color:var(--t-primary); border:2px solid var(--t-card); }
.svc-card:has(.svc-img-wrap) .svc-icon { margin-top:-40px; }
.svc-icon svg, .svc-icon i { width:22px; height:22px; }
.svc-card h3 { color:var(--t-heading); }
.svc-card p { color:var(--t-text-muted); font-size:.88rem; line-height:1.7; }

/* ── Layout : COLS-2-IMG (image + texte) ─────────────────────────────── */
.cols2img-layout { display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center; }
.cols2img-layout.img-right { }
.cols2img-layout.img-right .cols2img-img { order:2; }
.cols2img-layout.img-right .cols2img-text { order:1; }
.cols2img-img img { width:100%; border-radius:var(--t-radius); }
.cols2img-text p { color:var(--t-text-muted); margin-bottom:16px; }

/* ── Layout : COLS-2-TEXT / COLS-3-TEXT ──────────────────────────────── */
.colstext-grid { display:grid; gap:32px; }
.colstext-grid.cols-2 { grid-template-columns:1fr 1fr; }
.colstext-grid.cols-3 { grid-template-columns:repeat(3,1fr); }
.colstext-col { padding:24px; background:var(--t-card); border:1px solid var(--t-border); border-radius:var(--t-radius-sm); }
.colstext-col h3 { color:var(--t-heading); margin-bottom:12px; }
.colstext-col p { color:var(--t-text-muted); font-size:.9rem; line-height:1.8; }

/* ── Layout : TEXT simple ────────────────────────────────────────────── */
.text-layout { max-width:760px; margin:0 auto; }
.text-layout p { color:var(--t-text-muted); margin-bottom:16px; line-height:1.9; }

/* ── Layout : IMAGE ─────────────────────────────────────────────────── */
.image-layout img { width:100%; border-radius:var(--t-radius); }
.image-layout .legende { text-align:center; color:var(--t-text-muted); font-size:.85rem; margin-top:12px; font-style:italic; }

/* ── Layout : CONTACT ───────────────────────────────────────────────── */
.contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:48px; }
.contact-intro { color:var(--t-text-muted); margin-bottom:28px; font-size:.95rem; }
.contact-cards { display:flex; flex-direction:column; gap:14px; margin-bottom:24px; }
.ccard { display:flex; gap:14px; align-items:center; padding:16px 18px; background:var(--t-card); border:1px solid var(--t-border); border-radius:var(--t-radius-sm); }
.ccard-icon { width:44px; height:44px; background:var(--t-primary-dim); border:1px solid var(--t-border); border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--t-primary); }
.ccard strong { display:block; font-size:.75rem; color:var(--t-text-muted); font-weight:600; text-transform:uppercase; letter-spacing:.5px; }
.ccard span, .ccard a { color:var(--t-heading); font-size:.9rem; }
.ccard a:hover { color:var(--t-primary); }
.map-wrap { border-radius:var(--t-radius-sm); overflow:hidden; border:1px solid var(--t-border); }
.form-panel { background:var(--t-card); border:1px solid var(--t-border); border-radius:var(--t-radius); padding:36px; }
.form-panel h3 { color:var(--t-heading); display:flex; align-items:center; gap:8px; margin-bottom:24px; font-size:1.25rem; }
.fg { margin-bottom:16px; }
.fg label { display:block; font-size:.8rem; font-weight:600; color:var(--t-text-muted); margin-bottom:6px; }
.fg input, .fg textarea, .fg select { width:100%; padding:12px 16px; background:var(--t-bg-alt); border:1px solid var(--t-border); border-radius:var(--t-radius-sm); color:var(--t-text); font-family:var(--t-font-body); font-size:.9rem; outline:none; transition:all .3s; }
.fg input:focus, .fg textarea:focus, .fg select:focus { border-color:var(--t-primary); box-shadow:0 0 0 3px var(--t-primary-dim); }
.fg input::placeholder, .fg textarea::placeholder { color:var(--t-text-dim); }
.fg textarea { resize:vertical; min-height:100px; }
.fg select { cursor:pointer; }

/* ── Tarifs ─────────────────────────────────────────────────────────── */
.tarifs-cols { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:start; }
.tcol { background:var(--t-card); border:1px solid var(--t-border); border-radius:var(--t-radius); overflow:hidden; transition:all .35s; }
.tcol:hover { transform:translateY(-4px); box-shadow:var(--t-shadow); }
.tcol-featured { border:2px solid var(--t-primary); }
.tcol-head { padding:24px 24px 16px; text-align:center; border-bottom:1px solid var(--t-border); }
.tcol-head svg { width:24px; height:24px; margin-bottom:8px; }
.tcol-head h3 { color:var(--t-heading); font-size:1.15rem; }
.tcol-gold svg { color:var(--t-primary); }
.tcol-body { list-style:none; padding:8px 0; }
.tcol-body li { display:flex; justify-content:space-between; align-items:center; padding:12px 24px; border-bottom:1px solid var(--t-border-light); font-size:.86rem; }
.tcol-body li:last-child { border-bottom:none; }
.tcol-body li span { color:var(--t-text); }
.tcol-body li strong { color:var(--t-primary); font-weight:700; white-space:nowrap; }
.tcol-body li strong small { font-weight:400; font-size:.76rem; color:var(--t-text-muted); }
.tcol-sep { height:0 !important; padding:0 !important; border-bottom:2px dashed var(--t-border) !important; }
.tcol-note { padding:16px 24px; border-top:1px solid var(--t-border-light); color:var(--t-text-muted); font-size:.82rem; text-align:center; }

/* ── Footer ─────────────────────────────────────────────────────────── */
.footer { background:var(--t-bg-alt); border-top:1px solid var(--t-border); padding:52px 0 0; }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:44px; padding-bottom:40px; }
.footer-logo { display:flex; align-items:center; gap:10px; color:var(--t-primary); margin-bottom:12px; }
.footer-brand h3 { font-size:1.1rem; color:var(--t-heading); }
.footer-brand p { color:var(--t-text-muted); font-size:.85rem; }
.footer-col h4 { font-size:.75rem; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--t-primary); margin-bottom:16px; }
.footer-col ul { list-style:none; }
.footer-col li { margin-bottom:8px; font-size:.85rem; color:var(--t-text-muted); }
.footer-col a { color:var(--t-text-muted); }
.footer-col a:hover { color:var(--t-heading); }
.footer-social { display:flex; gap:12px; margin-top:16px; }
.footer-social a { width:38px; height:38px; background:var(--t-card); border:1px solid var(--t-border); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--t-text-muted); transition:all .3s; }
.footer-social a:hover { border-color:var(--t-primary); color:var(--t-primary); transform:translateY(-2px); }
.footer-bottom { border-top:1px solid var(--t-border); padding:18px 0; text-align:center; }
.footer-bottom p { font-size:.75rem; color:var(--t-text-dim); }

/* ── Animations ─────────────────────────────────────────────────────── */
.reveal, .reveal-left, .reveal-right { opacity:0; transition:opacity .7s, transform .7s; }
.reveal       { transform:translateY(28px); }
.reveal-left  { transform:translateX(-40px); }
.reveal-right { transform:translateX(40px); }
.reveal.visible, .reveal-left.visible, .reveal-right.visible { opacity:1; transform:translate(0); }

/* ── Formulaire messages ─────────────────────────────────────────────── */
.form-success, .form-error { padding:14px 18px; margin-bottom:20px; border-radius:8px; font-size:.9rem; }
.form-success { background:#e8f6ef; border-left:4px solid #2ecc71; color:#1b5e20; }
.form-error   { background:#fdecea; border-left:4px solid #e74c3c; color:#7f1d1d; }

/* ── Responsive ─────────────────────────────────────────────────────── */
@media (max-width:768px) {
  .nav-toggle { display:flex; }
  .nav-menu { position:fixed; top:0; right:-100%; width:80%; max-width:320px; height:100vh; background:var(--t-bg-alt); border-left:1px solid var(--t-border); flex-direction:column; padding:80px 28px 28px; gap:4px; z-index:1000; }
  .nav-menu.open { right:0; }
  .nav-link { padding:12px 16px; font-size:1rem; width:100%; }
  .cols2img-layout, .colstext-grid.cols-2, .colstext-grid.cols-3, .tarifs-cols, .contact-layout, .footer-grid { grid-template-columns:1fr; }
  .hero-bottom { flex-direction:column; align-items:flex-start; gap:16px; padding:16px 24px; }
  .hero-btns { flex-direction:column; }
  .btn { width:100%; justify-content:center; }
  .hide-mob { display:none; }
  .svc-grid { grid-template-columns:1fr; }
}
/* v202603300945 */

/* ── Contact : boutons d'action rapide ─────────────────────────────── */
.contact-action-btns { display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px; }
.cab { display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:50px;font-size:.88rem;font-weight:600;text-decoration:none;transition:all .3s;border:1.5px solid var(--t-border); }
.cab svg, .cab i { width:18px;height:18px;flex-shrink:0; }
.cab-tel   { background:var(--t-primary-grad);color:var(--t-bg);border-color:transparent; }
.cab-tel:hover { transform:translateY(-2px);box-shadow:0 6px 20px var(--t-primary-dim);color:var(--t-bg); }
.cab-wa    { background:#25D366;color:#fff;border-color:transparent; }
.cab-wa:hover { transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,.3);color:#fff; }
.cab-maps  { background:var(--t-card);color:var(--t-text);border-color:var(--t-border); }
.cab-maps:hover { border-color:var(--t-primary);color:var(--t-primary);transform:translateY(-2px); }
/* cab-redeploy 1774952107 */
