/* Logo + layout additions for CMS */
.logo-text{background:var(--red);color:#fff;font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:22px;letter-spacing:.06em;padding:8px 14px;border-radius:4px;display:inline-block}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(19,21,25,.35) 0%,rgba(19,21,25,.85) 100%)}
.hero-content{position:relative;z-index:2;padding:120px 0 80px;width:100%}
.hero-kicker{text-transform:uppercase;font-size:12px;letter-spacing:.14em;color:var(--mut2);margin-bottom:12px}
.hero h1{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:clamp(2rem,5vw,3.4rem);text-transform:uppercase;line-height:1.05;margin-bottom:14px}
.hero-sub{font-size:1.1rem;color:var(--mut2);margin-bottom:8px}
.hero-slogan{font-size:1rem;color:var(--mut);margin-bottom:28px;max-width:560px}
.hero-cta{display:inline-block}
.section{padding:72px 0}
.section-title{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:1.8rem;text-transform:uppercase;margin-bottom:32px}
.families-grid{display:grid;grid-template-columns:repeat(var(--cols-categories,4),minmax(0,1fr));gap:20px}
@media(max-width:1024px){.families-grid{grid-template-columns:repeat(min(var(--cols-categories,4),3),minmax(0,1fr))}}
@media(max-width:640px){.families-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:420px){.families-grid{grid-template-columns:1fr}}
.family-card{background:var(--surf);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1),border-color .25s ease}
.family-card:hover{transform:translateY(-2px);border-color:var(--line2);box-shadow:0 12px 28px -18px rgba(0,0,0,.55)}
.family-card img{aspect-ratio:16/10;object-fit:cover;width:100%}
.family-card-body{padding:18px 20px;display:flex;align-items:center;justify-content:space-between}
.family-card h3{font-family:'Saira',sans-serif;font-weight:600;font-size:1rem}
.family-card .arrow{color:var(--red);transition:transform .25s cubic-bezier(.4,0,.2,1)}
.family-card:hover .arrow{transform:translateX(3px)}
.products-grid{display:grid;grid-template-columns:repeat(var(--cols-products,4),minmax(0,1fr));gap:18px}
@media(max-width:1024px){.products-grid{grid-template-columns:repeat(min(var(--cols-products,4),3),minmax(0,1fr))}}
@media(max-width:640px){.products-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:420px){.products-grid{grid-template-columns:1fr}}
.product-card{background:var(--surf);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:opacity .25s ease,transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1),border-color .25s ease}
.product-card:hover{transform:translateY(-2px);border-color:var(--line2);box-shadow:0 12px 28px -18px rgba(0,0,0,.55)}
.product-img{aspect-ratio:4/3;background:var(--surf2);overflow:hidden}
.product-img img{width:100%;height:100%;object-fit:cover}
.product-placeholder{height:100%;min-height:140px;background:var(--line)}
.product-body{padding:16px}
.product-body h3{font-size:.95rem;font-weight:600;margin-bottom:6px}
.price{color:var(--red);font-weight:600;font-size:.9rem}
.section-cta{margin-top:36px;text-align:center}
.about-box{background:var(--surf);border:1px solid var(--line);border-radius:16px;padding:32px;line-height:1.7}
.contact-band{background:var(--surf)}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px}
.page-head{padding-top:120px;padding-bottom:40px}
.search-form{display:flex;gap:12px;margin-top:20px;max-width:520px}
.search-form input{flex:1;background:var(--surf);border:1px solid var(--line);border-radius:8px;padding:12px 14px;color:var(--txt)}
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding-top:100px}
.product-gallery-main{margin-bottom:0}
.product-main-img{border-radius:16px;width:100%;display:block;aspect-ratio:4/3;object-fit:cover;background:var(--surf2)}
.product-gallery-thumbs{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.product-gallery-thumb{padding:0;border:2px solid var(--line);border-radius:8px;background:var(--surf2);cursor:pointer;overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease;line-height:0}
.product-gallery-thumb img{width:72px;height:72px;object-fit:cover;display:block}
.product-gallery-thumb:hover{border-color:var(--line2)}
.product-gallery-thumb.is-active{border-color:var(--red);box-shadow:0 0 0 1px var(--red)}
.product-thumbs{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.product-thumbs img{width:72px;height:72px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.price-lg{font-size:1.5rem;color:var(--red);font-weight:700;margin:16px 0}
.product-desc{color:var(--mut2);margin-bottom:24px;line-height:1.7}
.product-duration{font-size:.95rem;margin:-8px 0 16px}
.product-specs{margin-bottom:28px}
.specs-title{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:1.1rem;text-transform:uppercase;margin-bottom:12px;color:var(--mut2)}
.specs-table{width:100%;border-collapse:collapse;font-size:.92rem}
.specs-table th,.specs-table td{border-bottom:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}
.specs-table th{color:var(--mut);font-weight:500;width:42%}
.specs-table td{color:var(--txt)}
.site-footer{border-top:1px solid var(--line);padding:48px 0 32px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:24px}
.footer-copy{font-size:.85rem}
.mut{color:var(--mut)}
.resa-form{max-width:560px;display:grid;gap:16px}
.resa-form label{display:grid;gap:6px;font-size:.9rem}
.resa-form input:not([type="radio"]),.resa-form textarea,.resa-form select{background:var(--surf);border:1px solid var(--line);border-radius:8px;padding:12px;color:var(--txt)}
.resa-form select{cursor:pointer}
.input-readonly{opacity:.85;cursor:default}
.resa-type-fieldset{border:1px solid var(--line);border-radius:8px;padding:14px 16px;display:grid;gap:10px;margin:0}
.resa-type-fieldset legend{padding:0 6px;font-size:.85rem;color:var(--mut)}
.resa-form label.resa-type-option{display:flex;flex-direction:row;align-items:center;gap:8px;font-size:.9rem;cursor:pointer}
.resa-form input[type="radio"]{width:auto;margin:0;padding:0;border:none;background:transparent;flex-shrink:0;cursor:pointer}
.admin-product-ref{display:block;font-size:.8rem;margin-top:2px}
.hp{position:absolute;left:-9999px;height:0;width:0;opacity:0}
@media(max-width:880px){.product-layout{grid-template-columns:1fr}}
/* Theme tokens bridge */
:root{--color-primary:var(--red);--color-accent:var(--red-h);--color-background:var(--bg);--color-text:var(--txt);--color-secondary:var(--surf);--color-paper:#fff}
.logo-img{height:36px;width:auto;display:block}
.logo.has-image .logo-text{display:none}
.lang-switch{position:relative;margin-left:12px}
.lang-switch-btn{background:transparent;border:1px solid var(--line);border-radius:8px;color:var(--mut2);font-size:.78rem;padding:6px 10px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.lang-switch-btn:hover{border-color:var(--line2);color:var(--txt)}
.lang-switch-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:120px;background:var(--surf);border:1px solid var(--line2);border-radius:8px;padding:6px;display:none;z-index:220;box-shadow:0 12px 28px rgba(0,0,0,.45)}
.lang-switch.is-open .lang-switch-menu{display:grid;gap:2px}
.lang-switch-menu a{padding:8px 10px;border-radius:6px;font-size:.82rem;color:var(--mut2);text-decoration:none}
.lang-switch-menu a:hover,.lang-switch-menu a.is-active{background:var(--surf2);color:var(--txt)}

/* Hero slider — slides en absolute pour remplir .hero (min-height app.css) */
.hero-slider{position:relative}
.hero-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .7s ease,visibility .7s ease;pointer-events:none;display:flex;align-items:flex-end;z-index:0}
.hero-slide.is-active{opacity:1;visibility:visible;pointer-events:auto;z-index:1}
.hero-slider--single .hero-slide{opacity:1;visibility:visible;pointer-events:auto;z-index:1}
.hero-slide .bgimg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-slide .hero-overlay{z-index:1}
.hero-slide .hero-content{z-index:2}
.hero-slider-controls{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:4;display:flex;align-items:center;gap:12px}
.hero-slider-dots{display:flex;gap:8px}
.hero-slider-dot{width:10px;height:10px;border-radius:50%;border:1px solid rgba(255,255,255,.55);background:transparent;padding:0;cursor:pointer;transition:background .25s ease,border-color .25s ease}
.hero-slider-dot.is-active,.hero-slider-dot:hover{background:var(--red);border-color:var(--red)}
.hero-slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.25);color:#fff;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;transition:background .2s ease}
.hero-slider-arrow:hover{background:rgba(0,0,0,.55)}
.hero-slider-arrow--prev{left:16px}
.hero-slider-arrow--next{right:16px}
.hero-slider:not(.hero-slider--multi) .hero-slider-controls,.hero-slider:not(.hero-slider--multi) .hero-slider-arrow{display:none}
@media(max-width:880px){.lang-switch{margin-left:0}}
