/* =========================================================
   LA TANIÈRE — Composants & écrans
   ========================================================= */

/* ---------- HEADER ---------- */
.header{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding:18px var(--gut);
  transition:background .35s, border-color .35s, padding .35s;
  border-bottom:1px solid transparent;
}
body.scrolled .header,
body:not(.on-home) .header{
  background:rgba(13,15,14,0.86);
  backdrop-filter:blur(14px);
  border-bottom-color:var(--line);
  padding-block:12px;
}
.logo{ display:flex; align-items:center; gap:12px; }
.logo-word{ display:flex; flex-direction:column; line-height:1; }
.logo-word b{ font-family:var(--font-display); font-weight:600; font-size:23px; letter-spacing:0.06em; }
.logo-word i{ font-family:var(--font-mono); font-style:normal; font-size:9.5px; letter-spacing:0.22em; color:var(--text-mute); text-transform:uppercase; margin-top:3px; }

.nav{ display:flex; align-items:center; gap:6px; }
.nav a{
  font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.05em;
  font-size:15px; font-weight:500; color:var(--text-dim);
  padding:9px 14px; border-radius:var(--r); transition:color .2s, background .2s; position:relative;
}
.nav a:hover{ color:var(--text); }
.nav a.is-active{ color:var(--brass-bright); }
.header-actions{ display:flex; align-items:center; gap:10px; }
.header-pro{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-dim); padding:9px 14px; border:1px solid var(--line); border-radius:var(--r); display:inline-flex; gap:8px; align-items:center; transition:border-color .2s,color .2s; }
.header-pro:hover{ border-color:var(--brass); color:var(--brass-bright); }
.header-pro svg{ width:15px; height:15px; }

.cart-btn{ position:relative; width:44px; height:44px; display:grid; place-items:center; border:1px solid var(--line-strong); border-radius:var(--r); background:transparent; color:var(--text); transition:background .2s,color .2s; }
.cart-btn:hover{ background:var(--brass); color:#1a140a; border-color:transparent; }
.cart-btn svg{ width:20px; height:20px; }
.cart-count{ position:absolute; top:-7px; right:-7px; min-width:19px; height:19px; padding:0 5px; background:var(--blaze); color:#fff; border-radius:20px; font-family:var(--font-mono); font-size:11px; display:grid; place-items:center; }
.menu-btn{ display:none; width:44px; height:44px; place-items:center; background:transparent; border:1px solid var(--line-strong); border-radius:var(--r); color:var(--text); }
.menu-btn svg{ width:22px; height:22px; }

body.on-pro .header{ display:none; }

/* nav desktop -> burger en mobile */
@media(max-width:860px){
  .nav{ display:none; }
  .header-pro{ display:none; }
  .menu-btn{ display:grid; }
}

/* ---------- MOBILE MENU ---------- */
.mobile-menu{ position:fixed; inset:0 0 0 auto; width:min(86vw,380px); background:var(--bg-2); z-index:90; transform:translateX(100%); transition:transform .4s cubic-bezier(.2,.7,.2,1); display:flex; flex-direction:column; padding:22px; border-left:1px solid var(--line); }
.mobile-menu.open{ transform:none; }
.mm-head{ display:flex; justify-content:flex-end; }
.mm-head button{ width:42px;height:42px;display:grid;place-items:center;background:transparent;border:1px solid var(--line);border-radius:var(--r);color:var(--text); }
.mobile-menu nav{ display:flex; flex-direction:column; gap:4px; margin-top:18px; }
.mobile-menu nav a{ font-family:var(--font-display); text-transform:uppercase; font-size:26px; letter-spacing:0.04em; padding:12px 0; border-bottom:1px solid var(--line); color:var(--text); }
.mm-foot{ margin-top:auto; display:flex; flex-direction:column; gap:10px; }

.overlay{ position:fixed; inset:0; background:rgba(0,0,0,0.6); z-index:80; opacity:0; pointer-events:none; transition:opacity .3s; backdrop-filter:blur(2px); }
.overlay.show{ opacity:1; pointer-events:auto; }

/* =========================================================
   HOME
   ========================================================= */
.hero{ position:relative; min-height:100vh; display:flex; align-items:flex-end; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; filter:saturate(.92) contrast(1.02); }
.hero-bg::after{ content:""; position:absolute; inset:0; background:
  linear-gradient(180deg, rgba(13,15,14,0.45) 0%, rgba(13,15,14,0.05) 32%, rgba(13,15,14,0.45) 60%, var(--bg) 100%),
  radial-gradient(110% 75% at 12% 92%, rgba(13,15,14,0.9), transparent 58%); }
.hero-inner{ position:relative; z-index:2; width:100%; max-width:var(--maxw); margin:0 auto; padding:0 var(--gut) clamp(48px,8vh,110px); }
.hero h1{ max-width:18ch; margin:18px 0 0; line-height:1.0; font-size:clamp(40px,6vw,86px); }
.hero h1 em{ font-style:normal; color:var(--brass-bright); }
.hero-sub{ max-width:52ch; margin-top:22px; font-size:clamp(16px,1.4vw,20px); color:var(--text-dim); }
.hero-cta{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero-scroll{ position:absolute; right:var(--gut); bottom:clamp(48px,8vh,110px); z-index:2; writing-mode:vertical-rl; font-family:var(--font-mono); font-size:11px; letter-spacing:0.3em; text-transform:uppercase; color:var(--text-mute); display:flex; align-items:center; gap:14px; }
.hero-scroll::after{ content:""; width:1px; height:54px; background:linear-gradient(var(--brass),transparent); }
@media(max-width:760px){ .hero-scroll{ display:none; } }

/* bandeau défilant */
.marquee{ border-block:1px solid var(--line); background:var(--bg-2); overflow:hidden; white-space:nowrap; padding-block:16px; }
.marquee-track{ display:inline-flex; gap:48px; animation:scrollX 32s linear infinite; }
.marquee span{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.08em; font-size:17px; color:var(--text-dim); display:inline-flex; align-items:center; gap:48px; }
.marquee span::after{ content:"✦"; color:var(--brass); }
@keyframes scrollX{ to{ transform:translateX(-50%); } }

/* sélection vedette */
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:40px; flex-wrap:wrap; }
.section-head h2{ margin-top:14px; max-width:18ch; }

/* catégories */
.cats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.cats-grid .cat-tile:first-child{ grid-column:span 2; grid-row:span 2; }
.cat-tile{ position:relative; min-height:210px; border-radius:var(--r-md); overflow:hidden; border:1px solid var(--line); display:flex; align-items:flex-end; padding:20px; }
.cat-tile img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.2,.7,.2,1); }
.cat-tile .scrim{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(13,15,14,0.1) 30%,rgba(13,15,14,0.88)); }
.cat-tile:hover img{ transform:scale(1.06); }
.cat-num{ position:absolute; top:16px; left:18px; font-size:12px; color:var(--brass); letter-spacing:0.2em; z-index:2; }
.cat-meta{ position:relative; z-index:2; display:flex; flex-direction:column; gap:2px; }
.cat-meta b{ font-size:clamp(20px,2vw,30px); text-transform:uppercase; letter-spacing:0.01em; }
.cat-meta i{ font-style:normal; font-family:var(--font-mono); font-size:12px; color:var(--text-dim); letter-spacing:0.06em; }
.cat-go{ position:absolute; top:16px; right:16px; width:38px; height:38px; border-radius:var(--r); border:1px solid var(--line-strong); display:grid; place-items:center; z-index:2; color:var(--text); background:rgba(0,0,0,0.3); transition:background .2s,color .2s; }
.cat-go svg{ width:16px; height:16px; }
.cat-tile:hover .cat-go{ background:var(--brass); color:#1a140a; }
.cat-tile:first-child .cat-meta b{ font-size:clamp(26px,3vw,44px); }
@media(max-width:880px){ .cats-grid{ grid-template-columns:repeat(2,1fr); } .cats-grid .cat-tile:first-child{ grid-column:span 2; grid-row:auto; } }
@media(max-width:520px){ .cats-grid{ grid-template-columns:1fr; } .cats-grid .cat-tile:first-child{ grid-column:auto; } }

/* split services (réparation / TLD) */
.split{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:0; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; }
.split-media{ position:relative; min-height:420px; }
.split-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.split-media::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,transparent,rgba(13,15,14,0.4)); }
.split-body{ padding:clamp(32px,4vw,64px); display:flex; flex-direction:column; justify-content:center; gap:18px; background:var(--bg-2); }
.split-body.alt{ background:var(--bg-3); }
.feature-list{ list-style:none; padding:0; margin:8px 0 0; display:flex; flex-direction:column; gap:14px; }
.feature-list li{ display:flex; gap:14px; align-items:flex-start; padding-bottom:14px; border-bottom:1px solid var(--line); }
.feature-list li:last-child{ border-bottom:0; }
.feature-list svg{ width:22px; height:22px; color:var(--brass); flex:none; margin-top:2px; }
.feature-list b{ display:block; font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.03em; font-size:18px; }
.feature-list span{ color:var(--text-dim); font-size:14.5px; }
@media(max-width:840px){ .split{ grid-template-columns:1fr; } .split-media{ min-height:280px; } }

/* expertise / stats */
.expertise{ background:var(--bg-2); border-block:1px solid var(--line); }
.stats-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; margin-top:44px; }
.stat-cell{ background:var(--bg); padding:34px 28px; }
.stat-cell b{ font-family:var(--font-display); font-size:clamp(40px,5vw,64px); color:var(--brass-bright); display:block; line-height:1; }
.stat-cell span{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-dim); margin-top:10px; display:block; }
@media(max-width:780px){ .stats-row{ grid-template-columns:repeat(2,1fr); } }

/* gérant */
.owner{ display:grid; grid-template-columns:0.8fr 1.2fr; gap:clamp(32px,5vw,72px); align-items:center; }
.owner-photo{ position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); aspect-ratio:4/5; background:var(--bg-3); }
.owner-photo img{ width:100%; height:100%; object-fit:cover; }
.owner-photo .ph-badge{ position:absolute; left:18px; bottom:18px; background:var(--bg); border:1px solid var(--line-strong); padding:10px 14px; border-radius:var(--r); font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; }
.owner-sign{ font-family:var(--font-display); font-size:26px; color:var(--brass-bright); margin-top:8px; }
@media(max-width:760px){ .owner{ grid-template-columns:1fr; } .owner-photo{ max-width:340px; } }

/* avis */
.reviews-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.review{ margin:0; padding:28px; border:1px solid var(--line); border-radius:var(--r-md); background:var(--bg-2); display:flex; flex-direction:column; gap:16px; }
.review blockquote{ margin:0; font-size:17px; line-height:1.6; color:var(--text); }
.review figcaption{ display:flex; flex-direction:column; }
.review figcaption b{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.03em; font-size:16px; }
.stars{ display:inline-flex; gap:3px; }
.stars span{ color:var(--bg-4); } .stars span.on{ color:var(--brass); } .stars span svg{ width:15px; height:15px; }
@media(max-width:840px){ .reviews-grid{ grid-template-columns:1fr; } }

/* CTA bandeau */
.cta-band{ position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); padding:clamp(48px,7vw,96px) clamp(28px,5vw,72px); text-align:center; }
.cta-band img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.cta-band::after{ content:""; position:absolute; inset:0; background:rgba(13,15,14,0.78); }
.cta-band > *{ position:relative; z-index:2; }
.cta-band .btn{ margin-top:28px; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--bg-2); border-top:1px solid var(--line); padding-block:64px 30px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; }
.footer-col h5{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.18em; text-transform:uppercase; color:var(--text-mute); margin:0 0 16px; }
.footer-col a{ display:block; color:var(--text-dim); padding:5px 0; font-size:14.5px; transition:color .2s; }
.footer-col a:hover{ color:var(--brass-bright); }
.footer-info p{ color:var(--text-dim); font-size:14.5px; line-height:1.7; margin:0; }
.footer-info .row{ gap:10px; margin-top:10px; color:var(--text); }
.footer-info svg{ width:16px; height:16px; color:var(--brass); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; margin-top:54px; padding-top:24px; border-top:1px solid var(--line); flex-wrap:wrap; }
.footer-bottom span{ font-family:var(--font-mono); font-size:12px; color:var(--text-mute); letter-spacing:0.05em; }
@media(max-width:840px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }

/* =========================================================
   BOUTIQUE
   ========================================================= */
.shop-head{ padding-top:140px; padding-bottom:18px; border-bottom:1px solid var(--line); }
.shop-head h1{ margin:14px 0 16px; }
.shop-layout{ padding-block:34px 100px; }
.shop-toolbar{ display:flex; align-items:center; justify-content:space-between; gap:18px; margin-bottom:18px; flex-wrap:wrap; }
.chips{ display:flex; gap:8px; flex-wrap:wrap; }
.chip{ font-family:var(--font-mono); font-size:12.5px; letter-spacing:0.06em; text-transform:uppercase; padding:9px 14px; border:1px solid var(--line); border-radius:20px; background:transparent; color:var(--text-dim); transition:all .2s; }
.chip:hover{ color:var(--text); border-color:var(--line-strong); }
.chip.is-active{ background:var(--brass); color:#1a140a; border-color:transparent; font-weight:500; }
.sort{ display:inline-flex; align-items:center; gap:10px; }
.sort .mono{ font-size:12px; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-mute); }
.sort select{ background:var(--bg-2); color:var(--text); border:1px solid var(--line-strong); border-radius:var(--r); padding:9px 12px; font-family:var(--font-mono); font-size:13px; }
.result-count{ font-size:12px; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-mute); margin:0 0 22px; }

/* =========================================================
   FICHE PRODUIT
   ========================================================= */
.pdp{ padding-top:120px; padding-bottom:100px; }
.crumbs{ font-size:12px; letter-spacing:0.08em; color:var(--text-mute); display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-bottom:28px; }
.crumbs a:hover{ color:var(--brass-bright); }
.pdp-grid{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:clamp(28px,4vw,64px); }
.pdp-main{ position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); aspect-ratio:4/3; background:var(--bg-3); }
.pdp-main img{ width:100%; height:100%; object-fit:cover; }
.pdp-main .card-tags{ position:absolute; top:16px; left:16px; display:flex; gap:6px; }
.pdp-thumbs{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:10px; }
.pdp-thumb{ aspect-ratio:1; border-radius:var(--r); overflow:hidden; border:1px solid var(--line); background:var(--bg-3); padding:0; opacity:.6; transition:opacity .2s,border-color .2s; }
.pdp-thumb img{ width:100%; height:100%; object-fit:cover; }
.pdp-thumb.is-active,.pdp-thumb:hover{ opacity:1; border-color:var(--brass); }
.pdp-info{ display:flex; flex-direction:column; gap:14px; }
.pdp-info h1{ margin:2px 0; }
.pdp-meta{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.pdp-price{ display:flex; align-items:center; gap:14px; margin-top:4px; }
.price.big{ font-size:30px; }
.pdp-buy{ display:flex; gap:12px; align-items:stretch; margin-top:6px; flex-wrap:wrap; }
.qty{ display:inline-flex; align-items:center; border:1px solid var(--line-strong); border-radius:var(--r); overflow:hidden; }
.qty button{ width:46px; height:100%; min-height:46px; background:transparent; color:var(--text); border:0; display:grid; place-items:center; }
.qty button:hover{ background:var(--bg-3); }
.qty span{ min-width:42px; text-align:center; font-family:var(--font-mono); }
.qty.sm button{ width:32px; min-height:32px; } .qty.sm span{ min-width:30px; font-size:13px; }
.pdp-buy .btn-primary{ flex:1; min-width:200px; }
.reg-note{ display:flex; gap:14px; padding:16px; border-radius:var(--r-md); border:1px solid var(--line-strong); background:var(--bg-2); margin-top:8px; }
.reg-note svg{ width:24px; height:24px; flex:none; color:var(--brass); }
.reg-note.blaze svg{ color:var(--blaze); }
.reg-note.green svg{ color:var(--green); }
.reg-note b{ display:block; font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.03em; font-size:15px; margin-bottom:3px; }
.reg-note span{ font-size:13.5px; color:var(--text-dim); }
.reg-note.sm{ margin-top:16px; } .reg-note.sm b{ font-size:13px; } .reg-note.sm span{ font-size:12.5px; }
.pdp-assur{ list-style:none; padding:16px 0 0; margin:6px 0 0; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:12px; font-size:13px; letter-spacing:0.04em; color:var(--text-dim); }
.pdp-assur li{ display:flex; gap:12px; align-items:center; }
.pdp-assur svg{ width:18px; height:18px; color:var(--brass); }
.pdp-detail{ display:grid; grid-template-columns:1.4fr 0.6fr; gap:clamp(28px,4vw,64px); margin-top:clamp(40px,5vw,80px); }
.spec-table{ width:100%; border-collapse:collapse; margin-top:20px; }
.spec-table th,.spec-table td{ text-align:left; padding:15px 0; border-bottom:1px solid var(--line); font-size:15px; }
.spec-table th{ color:var(--text-mute); font-weight:500; font-family:var(--font-mono); font-size:13px; letter-spacing:0.05em; width:40%; }
.pdp-help{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-md); padding:26px; display:flex; flex-direction:column; gap:14px; align-self:start; }
.pdp-help h4{ font-size:22px; text-transform:uppercase; letter-spacing:0.02em; }
.pdp-related{ margin-top:clamp(48px,6vw,90px); }
.pdp-related .eyebrow-row{ margin-bottom:28px; }
@media(max-width:860px){ .pdp-grid,.pdp-detail{ grid-template-columns:1fr; } }

/* =========================================================
   PANIER (drawer)
   ========================================================= */
.cart-drawer{ position:fixed; inset:0 0 0 auto; width:min(92vw,440px); background:var(--bg-2); z-index:90; transform:translateX(100%); transition:transform .4s cubic-bezier(.2,.7,.2,1); display:flex; flex-direction:column; border-left:1px solid var(--line); }
.cart-drawer.open{ transform:none; }
.cart-top{ display:flex; align-items:center; justify-content:space-between; padding:20px 22px; border-bottom:1px solid var(--line); }
.cart-top h3{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.04em; font-size:22px; margin:0; }
.cart-top button{ width:40px;height:40px;display:grid;place-items:center;background:transparent;border:1px solid var(--line);border-radius:var(--r);color:var(--text); }
.cart-body{ flex:1; overflow-y:auto; padding:14px 22px; }
.cart-empty{ text-align:center; padding:60px 20px; color:var(--text-dim); display:flex; flex-direction:column; align-items:center; gap:16px; }
.ce-icon{ width:54px;height:54px; color:var(--text-mute); } .ce-icon svg{ width:54px;height:54px; }
.cart-item{ display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--line); }
.cart-item img{ width:74px; height:74px; object-fit:cover; border-radius:var(--r); border:1px solid var(--line); }
.ci-main{ flex:1; display:flex; flex-direction:column; gap:3px; }
.ci-name{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.02em; font-size:16px; }
.ci-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:8px; }
.ci-del{ background:transparent; border:0; color:var(--text-mute); align-self:flex-start; padding:4px; }
.ci-del:hover{ color:var(--red); } .ci-del svg{ width:18px;height:18px; }
.cart-foot{ border-top:1px solid var(--line); padding:20px 22px; display:flex; flex-direction:column; gap:14px; }
.cart-foot .total-row{ display:flex; justify-content:space-between; align-items:baseline; }
.cart-foot .total-row b{ font-family:var(--font-display); text-transform:uppercase; font-size:18px; }
.cart-foot .total-row .price{ font-size:24px; }

/* =========================================================
   COMMANDE
   ========================================================= */
.co-wrap{ padding-top:120px; padding-bottom:100px; }
.co-steps{ display:flex; align-items:center; gap:14px; margin-bottom:40px; flex-wrap:wrap; }
.co-step{ display:flex; align-items:center; gap:10px; font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.04em; color:var(--text-mute); font-size:16px; }
.co-step span{ width:30px; height:30px; border-radius:50%; border:1px solid var(--line-strong); display:grid; place-items:center; font-family:var(--font-mono); font-size:12px; }
.co-step span svg{ width:16px; height:16px; }
.co-step.is-active{ color:var(--text); } .co-step.is-active span{ border-color:var(--brass); color:var(--brass-bright); }
.co-step.is-done{ color:var(--text-dim); } .co-step.is-done span{ background:var(--brass); color:#1a140a; border-color:transparent; }
.co-sep{ flex:1; height:1px; background:var(--line); min-width:14px; max-width:60px; }
.co-grid{ display:grid; grid-template-columns:1.5fr 0.8fr; gap:clamp(28px,4vw,56px); align-items:start; }
.co-panel{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-md); padding:clamp(24px,3vw,40px); }
.co-panel h3{ margin:0 0 22px; }
.co-item{ display:flex; align-items:center; gap:16px; padding:14px 0; border-bottom:1px solid var(--line); }
.co-item img{ width:62px; height:62px; object-fit:cover; border-radius:var(--r); }
.co-item div{ flex:1; display:flex; flex-direction:column; } .co-item b{ font-size:15px; } .co-item span{ font-size:13px; }
.co-actions{ display:flex; justify-content:space-between; gap:14px; margin-top:28px; }
.radio-card,.check-card{ display:flex; gap:14px; align-items:flex-start; padding:18px; border:1px solid var(--line-strong); border-radius:var(--r-md); margin-bottom:12px; cursor:pointer; transition:border-color .2s,background .2s; }
.radio-card div,.check-card div{ display:flex; flex-direction:column; gap:2px; }
.radio-card b,.check-card b{ font-size:15px; }
.radio-card svg{ width:22px; height:22px; color:var(--brass); flex:none; }
.radio-card.is-active{ border-color:var(--brass); background:var(--brass-soft); }
.radio-card.is-disabled{ opacity:.45; cursor:not-allowed; }
.radio-card input,.check-card input{ accent-color:var(--brass); width:18px; height:18px; margin-top:2px; }
.check-card input{ flex:none; }
.verif-list{ margin:10px 0; }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-grid input{ background:var(--bg); border:1px solid var(--line-strong); border-radius:var(--r); padding:14px 16px; color:var(--text); font-family:var(--font-body); font-size:15px; }
.form-grid input:focus{ outline:none; border-color:var(--brass); }
.co-summary{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-md); padding:28px; position:sticky; top:90px; }
.co-summary h4{ font-family:var(--font-display); text-transform:uppercase; font-size:20px; margin:0 0 18px; }
.sum-lines{ display:flex; flex-direction:column; gap:10px; margin-bottom:14px; }
.sum-line{ display:flex; justify-content:space-between; gap:12px; font-size:14px; }
.sum-line.total{ font-family:var(--font-display); text-transform:uppercase; font-size:20px; margin-top:8px; }
.sum-line.total .mono{ color:var(--brass-bright); }
.co-done{ text-align:center; padding:60px 30px; }
.done-mark{ width:74px; height:74px; border-radius:50%; background:var(--brass); color:#1a140a; display:grid; place-items:center; margin:0 auto 24px; }
.done-mark svg{ width:38px; height:38px; }
.co-done p{ max-width:46ch; margin:14px auto; }
@media(max-width:820px){ .co-grid{ grid-template-columns:1fr; } .co-summary{ position:static; } }

/* =========================================================
   ESPACE PRO
   ========================================================= */
.pro{ display:grid; grid-template-columns:248px 1fr; min-height:100vh; }
.pro-side{ background:var(--bg-2); border-right:1px solid var(--line); padding:24px 20px; display:flex; flex-direction:column; gap:30px; position:sticky; top:0; height:100vh; }
.pro-brand{ display:flex; align-items:center; gap:12px; font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.06em; font-size:19px; }
.pro-nav{ display:flex; flex-direction:column; gap:4px; }
.pro-nav a{ display:flex; align-items:center; gap:12px; padding:12px 14px; border-radius:var(--r); color:var(--text-dim); font-size:13px; letter-spacing:0.06em; text-transform:uppercase; cursor:pointer; transition:background .2s,color .2s; }
.pro-nav a svg{ width:18px; height:18px; }
.pro-nav a:hover{ color:var(--text); background:var(--bg-3); }
.pro-nav a.is-active{ background:var(--brass-soft); color:var(--brass-bright); }
.pro-side-foot{ margin-top:auto; display:flex; flex-direction:column; gap:4px; padding-top:20px; border-top:1px solid var(--line); }
.pro-side-foot b{ font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.04em; }
.pro-side-foot .arrow-link{ margin-top:10px; }
.pro-main{ padding:34px clamp(24px,3vw,48px); }
.pro-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:30px; }
.pro-head h1{ margin-top:8px; }
.pro-stats{ display:flex; gap:12px; }
.stat{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-md); padding:16px 22px; min-width:120px; }
.stat b{ font-size:26px; color:var(--text); display:block; line-height:1; }
.stat span{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--text-mute); margin-top:8px; display:block; }
.stat.accent b{ color:var(--brass-bright); }
.pro-grid{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:20px; align-items:start; }
.pro-scan,.pro-feed{ padding:26px; }
.ps-head{ display:flex; align-items:center; justify-content:space-between; gap:14px; margin-bottom:14px; flex-wrap:wrap; }
.pro-scan p{ font-size:14px; margin:0 0 20px; }
.scanner{ display:grid; grid-template-columns:1fr 0.9fr; gap:20px; align-items:stretch; }
.scan-window{ position:relative; aspect-ratio:1; background:var(--bg); border:1px solid var(--line-strong); border-radius:var(--r-md); overflow:hidden; display:grid; place-items:center; }
.scan-frame span{ position:absolute; width:28px; height:28px; border:2px solid var(--brass); }
.scan-frame span:nth-child(1){ top:16px; left:16px; border-right:0; border-bottom:0; }
.scan-frame span:nth-child(2){ top:16px; right:16px; border-left:0; border-bottom:0; }
.scan-frame span:nth-child(3){ bottom:16px; left:16px; border-right:0; border-top:0; }
.scan-frame span:nth-child(4){ bottom:16px; right:16px; border-left:0; border-top:0; }
.scan-line{ position:absolute; left:16px; right:16px; height:2px; background:linear-gradient(90deg,transparent,var(--brass),transparent); top:50%; opacity:0; }
.scan-line.scanning{ opacity:1; animation:scanY 1s ease-in-out infinite; }
@keyframes scanY{ 0%{ top:18%; } 50%{ top:82%; } 100%{ top:18%; } }
.scan-idle{ display:flex; flex-direction:column; align-items:center; gap:12px; color:var(--text-mute); }
.scan-idle svg{ width:54px; height:54px; }
.scan-idle p{ font-size:12px !important; letter-spacing:0.14em; text-transform:uppercase; margin:0 !important; }
.scan-result{ position:absolute; inset:0; padding:18px; display:flex; flex-direction:column; gap:12px; align-items:center; justify-content:center; text-align:center; background:var(--bg); }
.scan-result img{ width:88px; height:88px; object-fit:cover; border-radius:var(--r); border:1px solid var(--line); }
.sr-info b{ display:block; font-family:var(--font-display); text-transform:uppercase; font-size:16px; line-height:1.1; margin-bottom:2px; }
.sr-fields{ display:flex; gap:14px; justify-content:center; margin-top:12px; flex-wrap:wrap; }
.sr-fields span{ display:flex; flex-direction:column; gap:2px; font-size:13px; }
.sr-fields i{ font-style:normal; font-size:10px; letter-spacing:0.1em; text-transform:uppercase; }
.sr-published{ position:absolute; bottom:14px; left:14px; right:14px; background:var(--brass); color:#1a140a; padding:9px; border-radius:var(--r); font-size:12px; letter-spacing:0.08em; text-transform:uppercase; display:flex; align-items:center; justify-content:center; gap:8px; animation:fadeUp .4s both; }
.sr-published svg{ width:15px; height:15px; }
.scan-controls{ display:flex; flex-direction:column; gap:14px; justify-content:flex-end; }
.ean-field{ display:flex; flex-direction:column; gap:8px; }
.ean-field .mono{ font-size:11px; letter-spacing:0.12em; text-transform:uppercase; }
.ean-field input{ background:var(--bg); border:1px solid var(--line-strong); border-radius:var(--r); padding:14px; color:var(--text); font-size:16px; letter-spacing:0.06em; }
.pipeline{ display:flex; align-items:center; gap:6px; margin-top:24px; padding-top:22px; border-top:1px solid var(--line); flex-wrap:wrap; }
.pipe-step{ display:flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:11.5px; letter-spacing:0.04em; color:var(--text-mute); transition:color .3s; }
.pipe-dot{ width:24px; height:24px; border-radius:50%; border:1px solid var(--line-strong); display:grid; place-items:center; transition:all .3s; }
.pipe-step.active{ color:var(--text); } .pipe-step.active .pipe-dot{ border-color:var(--brass); color:var(--brass-bright); box-shadow:0 0 0 4px var(--brass-soft); }
.pipe-step.done{ color:var(--text-dim); } .pipe-step.done .pipe-dot{ background:var(--brass); color:#1a140a; border-color:transparent; }
.pipe-arrow{ color:var(--text-mute); } .pipe-arrow svg{ width:14px; height:14px; }
.feed-list{ display:flex; flex-direction:column; gap:10px; max-height:520px; overflow-y:auto; }
.feed-empty{ text-align:center; padding:50px 20px; font-size:13px; line-height:1.7; }
.feed-row{ display:flex; align-items:center; gap:14px; padding:12px; border:1px solid var(--line); border-radius:var(--r-md); background:var(--bg); }
.feed-row img{ width:52px; height:52px; object-fit:cover; border-radius:var(--r); }
.fr-main{ flex:1; display:flex; flex-direction:column; gap:2px; }
.fr-main b{ font-size:14px; }
.fr-main .mono{ font-size:11px; }
.pro-note{ display:flex; align-items:center; gap:10px; margin-top:24px; font-size:12px; line-height:1.6; }
.pro-note svg{ width:16px; height:16px; flex:none; color:var(--brass); }
@media(max-width:980px){ .pro{ grid-template-columns:1fr; } .pro-side{ position:static; height:auto; flex-direction:row; align-items:center; flex-wrap:wrap; } .pro-nav{ flex-direction:row; flex-wrap:wrap; } .pro-side-foot{ margin:0; border:0; padding:0; } .pro-grid{ grid-template-columns:1fr; } .scanner{ grid-template-columns:1fr; } }

/* =========================================================
   CONTACT
   ========================================================= */
.contact-hero{ padding-top:140px; }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,80px); margin-top:48px; }
.contact-card{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-md); padding:30px; display:flex; flex-direction:column; gap:18px; }
.contact-line{ display:flex; gap:14px; align-items:flex-start; padding-bottom:16px; border-bottom:1px solid var(--line); }
.contact-line:last-child{ border-bottom:0; padding-bottom:0; }
.contact-line svg{ width:22px; height:22px; color:var(--brass); flex:none; margin-top:2px; }
.contact-line b{ display:block; font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.03em; font-size:15px; }
.contact-line span{ color:var(--text-dim); font-size:14.5px; }
.contact-line a{ color:var(--text); } .contact-line a:hover{ color:var(--brass-bright); }
.contact-form{ display:flex; flex-direction:column; gap:14px; }
.contact-form input,.contact-form textarea,.contact-form select{ background:var(--bg); border:1px solid var(--line-strong); border-radius:var(--r); padding:14px 16px; color:var(--text); font-family:var(--font-body); font-size:15px; }
.contact-form textarea{ min-height:130px; resize:vertical; }
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{ outline:none; border-color:var(--brass); }
.map-embed{ margin-top:60px; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); height:380px; filter:grayscale(0.4) invert(0.9) hue-rotate(180deg) contrast(0.9); }
.map-embed iframe{ width:100%; height:100%; border:0; }
@media(max-width:820px){ .contact-grid{ grid-template-columns:1fr; } }
