/*
Theme Name: AquilOhm
Theme URI: https://www.aquilohm.fr/
Author: Oscar SEO
Author URI: https://oscar-seo.ai/
Description: Thème WordPress sur mesure pour AquilOhm (TMA), fabricant français de radiateurs à infrarouges lointains. Design moderne sombre avec l'orange « infrarouge » en couleur signature, intégration WooCommerce et mise en avant du produit phare AquilOhm Régulus 36. Palette et typographies centralisées.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: aquilohm
Tags: e-commerce, woocommerce, custom-logo, custom-menu, featured-images, dark, one-column, translation-ready
*/

/* =========================================================================
   1. Variables — TOUT se règle ici (couleurs & polices)
   ========================================================================= */
:root{
  --bg:#0d0c0b; --bg-2:#16130f; --bg-3:#1f1b15;
  --ink:#f6f1ea; --muted:#b4a89b; --faint:#7d7468;
  --orange:#ff6a18; --orange-2:#ff9b3d; --orange-deep:#df5009;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.14);
  --card:#15120e;
  --radius:18px; --radius-lg:26px;
  --container:1180px;
  --font-d:'Space Grotesk',sans-serif; --font-b:'Inter',-apple-system,sans-serif;
}

/* =========================================================================
   2. Base
   ========================================================================= */
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg); color:var(--ink); font-family:var(--font-b);
  font-size:17px; line-height:1.65; margin:0; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--orange);text-decoration:none;transition:color .2s}
a:hover{color:var(--orange-2)}
h1,h2,h3,h4{font-family:var(--font-d);line-height:1.1;letter-spacing:-.02em;font-weight:600;margin:0 0 .5em;color:var(--ink)}
p{margin:0 0 1.2em}
:focus-visible{outline:2px solid var(--orange);outline-offset:3px;border-radius:3px}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px}
.orange{color:var(--orange)}
.muted{color:var(--muted)}
.eyebrow{font-family:var(--font-d);font-size:.8rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--orange)}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;z-index:999;background:var(--orange);color:#fff;padding:.6em 1em;border-radius:0 0 8px 8px}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
.page-layout{display:flex;flex-direction:column;min-height:100vh}

/* =========================================================================
   3. Boutons
   ========================================================================= */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-d);font-weight:600;font-size:.98rem;
  padding:.92em 1.5em;border-radius:999px;transition:.25s cubic-bezier(.2,.7,.2,1);cursor:pointer;border:1px solid transparent;white-space:nowrap;line-height:1}
.btn-primary{background:linear-gradient(135deg,var(--orange),var(--orange-deep));color:#fff;box-shadow:0 10px 30px -10px rgba(255,106,24,.6)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px -10px rgba(255,106,24,.75);color:#fff}
.btn-ghost{border-color:var(--line-2);color:var(--ink);background:rgba(255,255,255,.02)}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange)}
.btn svg{width:16px;height:16px}

/* =========================================================================
   4. En-tête + navigation (une seule ligne)
   ========================================================================= */
.site-header{position:sticky;top:0;z-index:50;transition:.3s;border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(13,12,11,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom-color:var(--line)}
.nav{display:flex;align-items:center;gap:28px;min-height:78px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-d);font-weight:700;font-size:1.5rem;letter-spacing:-.02em;color:var(--ink)}
.brand img{height:42px;width:auto}
.brand .mark{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange-deep));
  display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;box-shadow:0 0 22px -2px rgba(255,106,24,.7);flex:0 0 auto}
.nav-menu{display:flex;align-items:center;gap:26px;margin:0 0 0 auto;padding:0;list-style:none;flex-wrap:nowrap}
.nav-menu li{flex:0 0 auto}
.nav-menu a{font-size:.96rem;color:var(--muted);font-weight:500;transition:.2s;white-space:nowrap}
.nav-menu a:hover,.nav-menu .current-menu-item>a{color:var(--ink)}
.nav .btn{flex:0 0 auto}
.burger{display:none;background:none;border:0;color:var(--ink);cursor:pointer;padding:6px}

/* =========================================================================
   5. Hero
   ========================================================================= */
.hero{position:relative;padding:54px 0 80px;overflow:hidden}
.hero::before{content:"";position:absolute;top:-220px;right:-180px;width:760px;height:760px;
  background:radial-gradient(circle,rgba(255,106,24,.35),rgba(255,106,24,.07) 42%,transparent 66%);z-index:0;pointer-events:none}
.hero::after{content:"";position:absolute;left:-160px;bottom:-200px;width:520px;height:520px;
  background:radial-gradient(circle,rgba(255,154,61,.14),transparent 64%);z-index:0;pointer-events:none}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(2.6rem,5.4vw,4.3rem);font-weight:700}
.hero h1 em{font-style:normal;color:var(--orange)}
.hero p.lead{margin:24px 0 32px;font-size:1.18rem;color:var(--muted);max-width:36ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:34px}
.badge{display:inline-flex;align-items:center;gap:8px;font-size:.84rem;font-weight:500;color:var(--ink);
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:999px;padding:.5em 1em}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--orange);box-shadow:0 0 10px var(--orange)}
.hero-visual{position:relative}
.hero-visual .glow{position:absolute;inset:8% 12%;background:radial-gradient(circle,rgba(255,106,24,.5),transparent 60%);filter:blur(34px);z-index:0}
.hero-visual img{position:relative;z-index:1;width:100%;border-radius:var(--radius-lg);border:1px solid var(--line-2);box-shadow:0 40px 80px -30px rgba(0,0,0,.8)}
.hero-tag{position:absolute;z-index:2;bottom:22px;left:-14px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:16px;padding:14px 18px;box-shadow:0 20px 40px -16px rgba(0,0,0,.7)}
.hero-tag .price{font-family:var(--font-d);font-weight:700;font-size:1.4rem;color:var(--orange)}
.hero-tag small{color:var(--faint);display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.12em}

/* =========================================================================
   6. Bandeau statistiques
   ========================================================================= */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;padding:34px 0}
.stat{text-align:center;padding:8px}
.stat .n{font-family:var(--font-d);font-weight:700;font-size:2rem;color:var(--ink)}
.stat .n span{color:var(--orange)}
.stat .l{font-size:.82rem;color:var(--muted);margin-top:4px}

/* =========================================================================
   7. Sections génériques
   ========================================================================= */
.section{padding:90px 0}
.sec-head{max-width:620px;margin-bottom:48px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.9rem);margin-top:14px}
.sec-head p{margin-top:16px;color:var(--muted);font-size:1.08rem}

/* Avantages */
.adv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.adv{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:.28s}
.adv:hover{border-color:rgba(255,106,24,.45);transform:translateY(-4px);background:#1a1610}
.adv .ico{width:50px;height:50px;border-radius:14px;background:rgba(255,106,24,.12);border:1px solid rgba(255,106,24,.3);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.adv .ico svg{width:24px;height:24px;stroke:var(--orange)}
.adv h3{font-size:1.22rem;margin-bottom:8px}
.adv p{font-size:.96rem;color:var(--muted);margin:0}

/* =========================================================================
   8. Section produit (Régulus 36)
   ========================================================================= */
.product-feature{background:linear-gradient(180deg,var(--bg-2),var(--bg));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.prod-grid{display:grid;grid-template-columns:1fr 1.02fr;gap:56px;align-items:center}
.prod-gallery{position:relative}
.prod-gallery .main{border-radius:var(--radius-lg);border:1px solid var(--line-2);overflow:hidden;background:#fff;box-shadow:0 40px 90px -36px rgba(0,0,0,.85)}
.prod-gallery .main img{width:100%;aspect-ratio:4/3.4;object-fit:cover}
.prod-glow{position:absolute;inset:-6% -4%;background:radial-gradient(circle at 70% 40%,rgba(255,106,24,.28),transparent 60%);filter:blur(30px);z-index:-1}
.thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:14px}
.thumbs img{border-radius:12px;border:1px solid var(--line);aspect-ratio:1;object-fit:cover;background:#fff;transition:.2s}
.thumbs img:hover{border-color:var(--orange)}
.prod-info .price{font-family:var(--font-d);font-weight:700;font-size:2.4rem;color:var(--orange);margin:8px 0 4px}
.prod-info .price small{font-size:1rem;color:var(--muted);font-weight:400}
.prod-info .desc{color:var(--muted);margin:14px 0 26px;font-size:1.05rem}
.specs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}
.spec{display:flex;gap:12px;align-items:flex-start;background:rgba(255,255,255,.025);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.spec svg{width:18px;height:18px;stroke:var(--orange);flex:0 0 auto;margin-top:3px}
.spec b{display:block;font-size:.95rem;font-weight:600}
.spec span{font-size:.82rem;color:var(--muted)}
.opt-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.opt{font-size:.82rem;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:.42em .95em}
.opt b{color:var(--ink);font-weight:600}
.prod-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* =========================================================================
   9. Principe de fonctionnement
   ========================================================================= */
.how-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.phase{display:flex;gap:18px;margin-bottom:26px}
.phase .num{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,106,24,.4);color:var(--orange);font-family:var(--font-d);font-weight:700;display:flex;align-items:center;justify-content:center;flex:0 0 auto;background:rgba(255,106,24,.08)}
.phase h4{font-size:1.15rem;margin-bottom:5px}
.phase p{color:var(--muted);font-size:.98rem;margin:0}
.how-visual{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line-2);position:relative}
.how-visual img{width:100%;aspect-ratio:4/3;object-fit:cover}
.how-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,106,24,.18),transparent 55%)}
.callout-line{font-size:.95rem;border-left:2px solid var(--orange);padding-left:16px;margin-top:24px;color:var(--muted)}
.callout-line b{color:var(--ink)}

/* =========================================================================
   10. Gamme
   ========================================================================= */
.range-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.range-card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--card);transition:.28s}
.range-card:hover{transform:translateY(-5px);border-color:rgba(255,106,24,.4)}
.range-card .ph{aspect-ratio:16/11;background:#fff;overflow:hidden}
.range-card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.range-card:hover .ph img{transform:scale(1.05)}
.range-card .body{padding:22px}
.range-card h3{font-size:1.3rem;margin-bottom:8px}
.range-card p{color:var(--muted);font-size:.94rem;margin:0 0 14px}
.range-card .link{font-family:var(--font-d);font-weight:600;font-size:.92rem;color:var(--orange);display:inline-flex;gap:6px;align-items:center}

/* =========================================================================
   11. Confiance + CTA final
   ========================================================================= */
.trust{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust-grid{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}
.trust-item{display:flex;align-items:center;gap:10px;font-size:.92rem;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:.6em 1.15em}
.trust-item svg{width:18px;height:18px;stroke:var(--orange)}
.cta-box{position:relative;background:linear-gradient(135deg,#1c1610,#120f0b);border:1px solid rgba(255,106,24,.3);border-radius:var(--radius-lg);padding:64px 48px;text-align:center;overflow:hidden}
.cta-box::before{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:600px;height:300px;background:radial-gradient(circle,rgba(255,106,24,.32),transparent 65%);filter:blur(20px)}
.cta-box h2{position:relative;font-size:clamp(2rem,4vw,3rem)}
.cta-box p{position:relative;color:var(--muted);margin:16px auto 30px;max-width:48ch;font-size:1.1rem}
.cta-box .hero-cta{position:relative;justify-content:center}

/* =========================================================================
   12. Pied de page
   ========================================================================= */
.site-footer{background:#0a0908;border-top:1px solid var(--line);padding:64px 0 30px;margin-top:auto}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;margin-bottom:40px}
.foot-brand p{color:var(--muted);font-size:.95rem;margin-top:16px;max-width:34ch}
.foot-col h4{font-family:var(--font-d);font-size:1rem;margin-bottom:16px}
.foot-col ul{list-style:none;display:grid;gap:10px;margin:0;padding:0}
.foot-col a{color:var(--muted);font-size:.93rem}
.foot-col a:hover{color:var(--orange)}
.foot-col address{color:var(--muted);font-size:.93rem;font-style:normal;line-height:1.7}
.foot-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.85rem;color:var(--faint)}
.foot-bottom a{color:var(--faint)}
.foot-bottom .made{display:inline-flex;align-items:center;gap:8px}
.flag{width:20px;height:14px;border-radius:2px;overflow:hidden;display:inline-flex}
.flag i{flex:1}.flag .b{background:#0055A4}.flag .w{background:#fff}.flag .r{background:#EF4135}

/* =========================================================================
   13. Contenu éditorial (articles, pages)
   ========================================================================= */
.entry{padding:60px 0}
.entry-header{max-width:760px;margin:0 auto 30px;text-align:center}
.entry-title{font-size:clamp(2rem,4vw,3rem)}
.entry-content,.page-content{max-width:760px;margin:0 auto;color:#e7ded3}
.entry-content a,.page-content a{text-decoration:underline;text-underline-offset:3px}
.entry-content h2{margin-top:1.6em}
.entry-content img{border-radius:var(--radius)}
.entry-content blockquote{border-left:3px solid var(--orange);padding-left:20px;margin:1.5em 0;font-family:var(--font-d);font-size:1.25rem;color:var(--ink)}
.post-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.28s}
.post-card:hover{transform:translateY(-4px);border-color:rgba(255,106,24,.4)}
.post-card .ph{aspect-ratio:16/9;overflow:hidden;background:var(--bg-3)}
.post-card .ph img{width:100%;height:100%;object-fit:cover}
.post-card .body{padding:22px}
.post-card h2{font-size:1.3rem;margin-bottom:8px}
.post-card h2 a{color:var(--ink)}
.post-card h2 a:hover{color:var(--orange)}
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;padding-bottom:60px}
.pagination{display:flex;gap:8px;justify-content:center;padding-bottom:60px}
.pagination .page-numbers{display:inline-flex;min-width:44px;height:44px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:10px;color:var(--muted)}
.pagination .current{background:var(--orange);border-color:var(--orange);color:#fff}

/* =========================================================================
   14. WooCommerce — habillage sombre/orange
   ========================================================================= */
.wc-page{padding:54px 0 80px}
.woocommerce .container.wc-wrap{padding-top:10px}
.woocommerce-products-header__title,.wc-page h1{font-family:var(--font-d)}
.woocommerce ul.products{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:0;list-style:none}
.woocommerce ul.products li.product{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;text-align:left;width:auto!important;float:none!important;margin:0!important;transition:.28s}
.woocommerce ul.products li.product:hover{transform:translateY(-4px);border-color:rgba(255,106,24,.4)}
.woocommerce ul.products li.product img{border-radius:12px;background:#fff;margin-bottom:14px}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:var(--font-d);font-size:1.1rem;color:var(--ink);padding:0}
.woocommerce ul.products li.product .price{color:var(--orange)!important;font-family:var(--font-d);font-weight:600}
.woocommerce ul.products li.product .price del{color:var(--faint)!important}
.woocommerce div.product .product_title{font-family:var(--font-d);font-size:clamp(1.8rem,3vw,2.6rem)}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--orange);font-family:var(--font-d);font-weight:700;font-size:1.8rem}
.woocommerce div.product .woocommerce-product-details__short-description{color:var(--muted)}
.woocommerce #respond input#submit,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce .single_add_to_cart_button,.woocommerce #place_order{
  background:linear-gradient(135deg,var(--orange),var(--orange-deep))!important;color:#fff!important;
  border-radius:999px!important;font-family:var(--font-d);font-weight:600;padding:.9em 1.6em!important;border:0!important;transition:.25s}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce .single_add_to_cart_button:hover,.woocommerce #place_order:hover{
  transform:translateY(-2px);box-shadow:0 12px 30px -10px rgba(255,106,24,.7);color:#fff!important}
.woocommerce a.button.alt,.woocommerce .button.add_to_cart_button{background:linear-gradient(135deg,var(--orange),var(--orange-deep))!important}
.woocommerce .woocommerce-message,.woocommerce .woocommerce-info,.woocommerce .woocommerce-error{
  background:var(--bg-2);border-top:3px solid var(--orange);color:var(--ink);border-radius:8px}
.woocommerce .woocommerce-message::before,.woocommerce .woocommerce-info::before{color:var(--orange)}
.woocommerce table.shop_table,.woocommerce table.shop_attributes{border:1px solid var(--line);border-radius:12px;background:var(--card)}
.woocommerce table.shop_table th,.woocommerce table.shop_attributes th{color:var(--ink)}
.woocommerce table.shop_table td,.woocommerce table.shop_attributes td{color:var(--muted);border-top:1px solid var(--line)}
.woocommerce .quantity input,.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,
.woocommerce select,.select2-container .select2-selection{
  background:var(--bg-2)!important;border:1px solid var(--line-2)!important;color:var(--ink)!important;border-radius:10px}
.woocommerce div.product form.cart .variations label{color:var(--ink)}
.woocommerce .price ins{text-decoration:none}
.woocommerce .star-rating span,.woocommerce p.stars a{color:var(--orange)}
.woocommerce-tabs ul.tabs li{background:var(--card)!important;border-color:var(--line)!important;border-radius:10px 10px 0 0}
.woocommerce-tabs ul.tabs li.active{background:var(--bg-2)!important}
.woocommerce-tabs ul.tabs::before{border-color:var(--line)!important}
.woocommerce div.product .woocommerce-tabs .panel{color:var(--muted)}
.woocommerce nav.woocommerce-pagination ul{border:0;display:flex;gap:8px;justify-content:center}
.woocommerce nav.woocommerce-pagination ul li{border:0}
.woocommerce nav.woocommerce-pagination ul li a,.woocommerce nav.woocommerce-pagination ul li span{
  border:1px solid var(--line);border-radius:10px;color:var(--muted);background:var(--card)}
.woocommerce nav.woocommerce-pagination ul li span.current{background:var(--orange);color:#fff;border-color:var(--orange)}

/* =========================================================================
   15. Animations & responsive
   ========================================================================= */
@media (prefers-reduced-motion:no-preference){
  .adv,.range-card,.hero-copy>*{animation:rise .7s both}
  .adv:nth-child(2){animation-delay:.06s}.adv:nth-child(3){animation-delay:.12s}.adv:nth-child(4){animation-delay:.18s}
  @keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
}
@media(max-width:900px){
  .hero-grid,.prod-grid,.how-grid{grid-template-columns:1fr;gap:36px}
  .hero-visual{order:-1}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:18px}
  .adv-grid{grid-template-columns:repeat(2,1fr)}
  .range-grid,.posts-grid,.woocommerce ul.products{grid-template-columns:1fr!important}
  .foot-grid{grid-template-columns:1fr;gap:28px}
  .nav-menu{position:fixed;inset:78px 0 auto 0;background:rgba(13,12,11,.98);flex-direction:column;padding:24px;gap:18px;border-bottom:1px solid var(--line);display:none}
  .nav-menu.open{display:flex}
  .nav-menu a{font-size:1.05rem}
  .burger{display:block;margin-left:auto}
  .nav .btn.header-cta{display:none}
}
@media(max-width:560px){.specs{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.section{padding:64px 0}}
