/* Opale — composants (P1 : layout, header papier, nav, footer). Étendu en P3. */

/* ----- Largeurs & rythme global (aligne GeneratePress sur les tokens) ----- */
.grid-container,
.inside-header,
.site-content .inside-article,
.site-info .inside-site-info{
  max-width:var(--max);
  padding-left:var(--gutter);
  padding-right:var(--gutter);
  box-sizing:border-box;
}
.site-content .entry-content{max-width:var(--measure);margin-inline:auto}

/* ======================================================================
   HEADER papier + fin filet (plus distinctif que le bandeau noir modèle)
   ====================================================================== */
.opale-header{
  position:sticky;top:0;z-index:50;
  background:var(--paper);
  border-bottom:var(--rule);
}
.opale-header__inner{
  max-width:var(--max);
  margin-inline:auto;
  padding:clamp(.85rem,1.6vw,1.25rem) var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}

/* Logo / marque */
.opale-brand{display:flex;flex-direction:column;line-height:1;text-decoration:none}
.opale-brand__name{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(1.55rem,1.2rem + 1.4vw,2.1rem);
  color:var(--ink);
  letter-spacing:.01em;
}
.opale-brand__subline{
  font-family:var(--font-read);
  text-transform:uppercase;
  letter-spacing:var(--tracking-caps);
  font-size:.62rem;
  color:var(--brass);
  margin-top:.45rem;
}
.opale-brand:hover .opale-brand__name{color:var(--ink)}

/* Navigation principale — petites capitales lettrées */
.opale-nav{display:flex;align-items:center;gap:clamp(1rem,2vw,2.1rem)}
.opale-nav__list{
  list-style:none;margin:0;padding:0;
  display:flex;align-items:center;gap:clamp(1rem,2vw,2.1rem);
}
.opale-nav__list a{
  font-family:var(--font-read);
  text-transform:uppercase;
  letter-spacing:var(--tracking-caps);
  font-size:.78rem;
  color:var(--ink);
  text-decoration:none;
  padding-block:.4rem;
  display:inline-block;
}
.opale-nav__list a:hover{color:var(--brass-deep)}

/* Pilule "Blog" */
.opale-pill{
  border:1px solid var(--ink);
  border-radius:999px;
  padding:.4rem 1rem !important;
  font-size:.72rem !important;
  letter-spacing:var(--tracking-caps);
  transition:background .15s ease,color .15s ease;
}
.opale-pill:hover{background:var(--ink);color:var(--paper) !important}

/* Méga-menu (scaffold ; items remplis en P2/P3) */
.opale-has-mega{position:relative}
.opale-mega{
  position:absolute;left:50%;transform:translateX(-50%);top:100%;
  min-width:min(60rem,92vw);
  background:var(--paper);
  border:var(--rule);
  padding:clamp(1.5rem,2.5vw,2.5rem);
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
  opacity:0;visibility:hidden;translate:0 6px;
  transition:opacity .16s ease,translate .16s ease,visibility .16s;
  box-shadow:0 18px 40px -28px rgba(23,19,15,.4);
}
.opale-has-mega:hover .opale-mega,
.opale-has-mega:focus-within .opale-mega{opacity:1;visibility:visible;translate:0 0}
.opale-mega__col h3{
  font-family:var(--font-read);
  text-transform:uppercase;
  letter-spacing:var(--tracking-caps);
  font-size:.68rem;color:var(--brass);
  margin:0 0 .9rem;padding-bottom:.6rem;border-bottom:var(--rule);
}
.opale-mega__col ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.opale-mega__col a{font-family:var(--font-read);font-size:.95rem;color:var(--ink-soft);text-decoration:none}
.opale-mega__col a:hover{color:var(--brass-deep)}

/* Hamburger (mobile) */
.opale-burger{display:none;background:none;border:0;cursor:pointer;padding:.4rem}
.opale-burger span{display:block;width:24px;height:1.5px;background:var(--ink);margin:5px 0}

@media (max-width:860px){
  .opale-nav{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);
    background:var(--paper);border-left:var(--rule);
    flex-direction:column;align-items:flex-start;gap:0;
    padding:5rem var(--gutter) var(--gutter);
    translate:100% 0;transition:translate .22s ease;}
  .opale-nav[data-open="true"]{translate:0 0}
  .opale-nav__list{flex-direction:column;align-items:flex-start;gap:.2rem;width:100%}
  .opale-nav__list a{font-size:.9rem;padding-block:.7rem;width:100%;border-bottom:var(--rule)}
  .opale-mega{position:static;transform:none;grid-template-columns:1fr;min-width:0;
    border:0;padding:.5rem 0 0;box-shadow:none;opacity:1;visibility:visible;translate:0}
  .opale-burger{display:block;z-index:60}
}

/* ======================================================================
   FOOTER papier
   ====================================================================== */
.opale-footer{background:var(--paper-2);border-top:var(--rule);margin-top:clamp(3rem,6vw,6rem)}
.opale-footer__inner{
  max-width:var(--max);margin-inline:auto;padding:clamp(2.5rem,5vw,4rem) var(--gutter);
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;
}
.opale-footer h3{
  font-family:var(--font-read);text-transform:uppercase;letter-spacing:var(--tracking-caps);
  font-size:.68rem;color:var(--brass);margin:0 0 1rem;
}
.opale-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.opale-footer a{font-size:.95rem;color:var(--ink-soft);text-decoration:none}
.opale-footer a:hover{color:var(--brass-deep)}
.opale-footer__brand .opale-brand__name{font-size:1.7rem}
.opale-footer__legal{
  border-top:var(--rule);margin-top:1.5rem;
  padding:1.25rem var(--gutter);max-width:var(--max);margin-inline:auto;
  font-size:.8rem;color:var(--ink-soft);
  display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;justify-content:space-between;
}
@media (max-width:860px){.opale-footer__inner{grid-template-columns:1fr;gap:2rem}}

/* ======================================================================
   PRIMITIVES éditoriales
   ====================================================================== */
.opale-eyebrow{
  font-family:var(--font-read);text-transform:uppercase;
  letter-spacing:var(--tracking-caps);font-size:var(--step--1);color:var(--brass);
  display:inline-block;margin:0 0 .9rem;
}
.opale-section{padding-block:clamp(2.5rem,6vw,5.5rem)}
.opale-section--cream{background:var(--paper-2);border-block:var(--rule)}
.opale-wrap{max-width:var(--max);margin-inline:auto;padding-inline:var(--gutter)}
.opale-measure{max-width:var(--measure)}
.opale-h2{font-family:var(--font-display);font-weight:600;font-size:var(--step-3);color:var(--ink);line-height:1.08;margin:0 0 1rem}
.opale-chapo{font-size:var(--step-1);line-height:1.5;color:var(--ink-soft);max-width:var(--measure)}

/* Lettrine d'ouverture d'article */
.opale-lettrine::first-letter,
.opale-article .entry-content > p.has-drop-cap::first-letter{
  font-family:var(--font-display);float:left;font-weight:500;
  font-size:4.6em;line-height:.72;padding:.05em .12em 0 0;color:var(--ink);
}

/* Citation Fraunces italique */
.opale-citation{
  font-family:var(--font-display);font-style:italic;font-size:var(--step-2);
  line-height:1.25;color:var(--ink);border-left:2px solid var(--brass);
  padding-left:1.2rem;margin:2rem 0;max-width:var(--measure);
}

/* Boutons */
.opale-btn{
  display:inline-block;font-family:var(--font-read);text-transform:uppercase;
  letter-spacing:var(--tracking-caps);font-size:.78rem;
  background:var(--ink);color:var(--paper);text-decoration:none;
  padding:.85rem 1.5rem;border-radius:var(--radius);border:1px solid var(--ink);
  transition:background .15s ease,color .15s ease;
}
.opale-btn:hover{background:var(--brass-deep);border-color:var(--brass-deep);color:var(--paper)}
.opale-btn--secondary{background:transparent;color:var(--ink)}
.opale-btn--secondary:hover{background:var(--ink);color:var(--paper)}

/* ======================================================================
   HERO d'accueil
   ====================================================================== */
.opale-hero{padding-block:clamp(2.5rem,6vw,5rem)}
.opale-hero__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.opale-hero__title{font-family:var(--font-display);font-weight:600;font-size:var(--step-4);line-height:1.02;color:var(--ink);margin:.4rem 0 1.2rem}
.opale-hero__title .accent{font-style:italic;color:var(--brass)}
.opale-hero__cta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.6rem}
.opale-hero__media img{width:100%;height:auto;display:block;border:var(--rule)}
@media (max-width:860px){.opale-hero__inner{grid-template-columns:1fr;gap:1.8rem}}

/* ======================================================================
   GRILLES (univers, conseils, guides, derniers contenus)
   ====================================================================== */
.opale-grid{display:grid;gap:clamp(1.2rem,2.5vw,2rem)}
.opale-grid--4{grid-template-columns:repeat(4,1fr)}
.opale-grid--3{grid-template-columns:repeat(3,1fr)}
.opale-grid--2{grid-template-columns:repeat(2,1fr)}
@media (max-width:980px){.opale-grid--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.opale-grid--4,.opale-grid--3,.opale-grid--2{grid-template-columns:1fr}}

/* Vignette / carte univers (filet, pas d'ombre) */
.opale-vignette{display:block;text-decoration:none;color:inherit;border:var(--rule);background:var(--paper);transition:border-color .15s ease}
.opale-vignette:hover{border-color:var(--brass)}
.opale-vignette img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.opale-vignette__body{padding:1.1rem 1.2rem 1.3rem}
.opale-vignette__kicker{font-family:var(--font-read);text-transform:uppercase;letter-spacing:var(--tracking-caps);font-size:.62rem;color:var(--brass)}
.opale-vignette__title{font-family:var(--font-display);font-size:var(--step-1);color:var(--ink);margin:.45rem 0 0;line-height:1.12}

/* ======================================================================
   SOMMAIRE (TOC) sticky à ancres
   ====================================================================== */
.opale-toc{position:sticky;top:6rem;align-self:start;border:var(--rule);background:var(--paper);padding:1.25rem 1.3rem;font-size:.92rem}
.opale-toc h2{font-family:var(--font-read);text-transform:uppercase;letter-spacing:var(--tracking-caps);font-size:.66rem;color:var(--brass);margin:0 0 .8rem}
.opale-toc ol{list-style:none;margin:0;padding:0;counter-reset:toc;display:grid;gap:.5rem}
.opale-toc li{counter-increment:toc}
.opale-toc a{color:var(--ink-soft);text-decoration:none;display:flex;gap:.6rem}
.opale-toc a::before{content:counter(toc,decimal-leading-zero);color:var(--brass);font-variant-numeric:tabular-nums}
.opale-toc a:hover{color:var(--brass-deep)}

/* ======================================================================
   TABLEAU COMPARATIF sémantique
   ====================================================================== */
.opale-table{width:100%;border-collapse:collapse;font-size:.96rem;margin:1.5rem 0}
.opale-table caption{text-align:left;font-family:var(--font-read);text-transform:uppercase;letter-spacing:var(--tracking-caps);font-size:.66rem;color:var(--brass);margin-bottom:.8rem}
.opale-table thead th{background:var(--ink);color:var(--paper);font-family:var(--font-read);font-weight:500;text-align:left;padding:.8rem 1rem;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}
.opale-table tbody td,.opale-table tbody th{border-bottom:var(--rule);padding:.85rem 1rem;vertical-align:top;text-align:left;font-weight:400}
.opale-table tbody tr.is-pick{position:relative}
.opale-table tbody tr.is-pick td:first-child,.opale-table tbody tr.is-pick th:first-child{box-shadow:inset 3px 0 0 var(--brass)}
.opale-table .opale-pickflag{display:inline-block;font-family:var(--font-read);text-transform:uppercase;letter-spacing:var(--tracking-caps);font-size:.58rem;color:var(--brass-deep);margin-bottom:.25rem}
.opale-stars{color:var(--brass);letter-spacing:.1em;white-space:nowrap}
.opale-stars .off{color:var(--line)}
@media (max-width:680px){.opale-table thead{display:none}.opale-table tbody td{display:flex;justify-content:space-between;gap:1rem;border:0;border-bottom:var(--rule)}.opale-table tbody td::before{content:attr(data-th);color:var(--brass);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em}.opale-table tbody tr{display:block;border:var(--rule);margin-bottom:1rem}}

/* ======================================================================
   CARTE PRODUIT
   ====================================================================== */
.opale-card-produit{display:grid;grid-template-columns:120px 1fr;gap:1.2rem;border:var(--rule);background:var(--paper);padding:1.2rem;align-items:start}
.opale-card-produit img{width:100%;height:auto;display:block}
.opale-card-produit .marque{font-family:var(--font-read);text-transform:uppercase;letter-spacing:var(--tracking-caps);font-size:.62rem;color:var(--brass)}
.opale-card-produit .nom{font-family:var(--font-display);font-size:var(--step-1);color:var(--ink);margin:.2rem 0 .4rem;line-height:1.1}
.opale-card-produit .prix{font-variant-numeric:oldstyle-nums;font-size:1.05rem;color:var(--ink)}
.opale-card-produit .cta{display:inline-block;margin-top:.7rem;color:var(--ink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;font-size:.92rem}
.opale-card-produit .cta:hover{color:var(--brass-deep)}
.opale-card-produit ul{margin:.6rem 0 0;padding-left:1.1rem;font-size:.92rem}
@media (max-width:520px){.opale-card-produit{grid-template-columns:90px 1fr;gap:.9rem}}

/* ======================================================================
   ENCADRÉS pédagogiques / coup de cœur / profil / transparence
   ====================================================================== */
.opale-pedago{border:var(--rule);background:var(--paper-2);padding:1.4rem 1.5rem;margin:1.8rem 0}
.opale-pedago h3{font-family:var(--font-display);font-size:var(--step-1);margin:0 0 1rem}
.opale-pedago ol{list-style:none;margin:0;padding:0;counter-reset:step;display:grid;gap:.9rem}
.opale-pedago ol li{counter-increment:step;display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:baseline}
.opale-pedago ol li::before{content:counter(step,decimal-leading-zero);font-family:var(--font-display);color:var(--brass);font-size:1.1rem;font-variant-numeric:tabular-nums}

.opale-coup-de-coeur{border:1px solid var(--brass);background:var(--paper);padding:1.5rem;margin:1.8rem 0;display:grid;gap:.5rem}
.opale-coup-de-coeur .label{font-family:var(--font-read);text-transform:uppercase;letter-spacing:var(--tracking-caps);font-size:.62rem;color:var(--brass-deep)}
.opale-coup-de-coeur .nom{font-family:var(--font-display);font-size:var(--step-2);color:var(--ink);line-height:1.1}

.opale-profil{border:var(--rule);padding:1.4rem 1.5rem;margin:1.8rem 0}
.opale-profil h3{font-family:var(--font-display);font-size:var(--step-1);margin:0 0 1rem}
.opale-profil dl{margin:0;display:grid;gap:.8rem}
.opale-profil dt{font-family:var(--font-read);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;color:var(--brass)}
.opale-profil dd{margin:.15rem 0 0}

/* Transparence affiliation — sur toute page monétisée */
.opale-affiliation{border:1px solid var(--line);border-left:3px solid var(--brass);background:var(--paper-2);padding:1rem 1.2rem;margin:1.8rem 0;font-size:.88rem;color:var(--ink-soft);line-height:1.55}
.opale-affiliation strong{color:var(--ink)}

/* Verdict (avis) */
.opale-verdict{display:grid;gap:1rem;border:var(--rule);padding:1.5rem;margin:1.8rem 0}
.opale-verdict__reco{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.opale-verdict__reco h4{font-family:var(--font-read);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;margin:0 0 .6rem}
.opale-verdict__reco .oui h4{color:var(--brass-deep)}
.opale-verdict__reco ul{margin:0;padding-left:1.1rem;font-size:.94rem}
@media (max-width:560px){.opale-verdict__reco{grid-template-columns:1fr}}

/* ======================================================================
   FAQ accordéon (FAQPage)
   ====================================================================== */
.opale-faq{border-top:var(--rule);margin:2rem 0}
.opale-faq details{border-bottom:var(--rule)}
.opale-faq summary{cursor:pointer;list-style:none;padding:1.1rem 0;font-family:var(--font-display);font-size:var(--step-1);color:var(--ink);display:flex;justify-content:space-between;gap:1rem;align-items:center}
.opale-faq summary::-webkit-details-marker{display:none}
.opale-faq summary::after{content:"+";color:var(--brass);font-size:1.3rem;line-height:1}
.opale-faq details[open] summary::after{content:"\2013"}
.opale-faq details > div{padding:0 0 1.2rem;max-width:var(--measure);font-size:.98rem}

/* ======================================================================
   ARTICLES similaires
   ====================================================================== */
.opale-similar{border-top:var(--rule);padding-top:2rem;margin-top:3rem}

/* ======================================================================
   CODES PROMOS
   ====================================================================== */
.opale-code-card{border:var(--rule);background:var(--paper);padding:1.3rem;display:grid;gap:.6rem}
.opale-code-card .marque{font-family:var(--font-display);font-size:var(--step-1);color:var(--ink)}
.opale-code-card .reduc{font-family:var(--font-read);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:var(--brass-deep)}
.opale-code-card .code{font-family:var(--font-ui);letter-spacing:.15em;border:1px dashed var(--brass);padding:.5rem .9rem;display:inline-block;background:var(--paper-2)}

/* ======================================================================
   HERO d'archive + pills de filtre
   ====================================================================== */
.opale-archive-hero{padding-block:clamp(2rem,4vw,3.5rem);border-bottom:var(--rule)}
.opale-pills{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.2rem}
.opale-pills a{font-family:var(--font-read);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:var(--ink);text-decoration:none;border:1px solid var(--line);border-radius:999px;padding:.4rem 1rem;transition:border-color .15s,color .15s}
.opale-pills a:hover,.opale-pills a[aria-current="true"]{border-color:var(--brass);color:var(--brass-deep)}

/* ======================================================================
   QUIZ « Trouvez le soin qu'il vous faut »
   ====================================================================== */
.opale-quiz{border:var(--rule);background:var(--paper);padding:clamp(1.5rem,3vw,2.5rem)}
.opale-quiz__q{margin:0 0 1.4rem}
.opale-quiz__q legend{font-family:var(--font-display);font-size:var(--step-1);color:var(--ink);margin-bottom:.8rem;padding:0}
.opale-quiz__opts{display:flex;flex-wrap:wrap;gap:.6rem;border:0;padding:0;margin:0}
.opale-quiz__opts label{font-family:var(--font-read);font-size:.92rem;border:1px solid var(--line);border-radius:999px;padding:.45rem 1rem;cursor:pointer;transition:border-color .15s,background .15s}
.opale-quiz__opts input{position:absolute;opacity:0;width:0;height:0}
.opale-quiz__opts input:checked + span,.opale-quiz__opts label:has(input:checked){border-color:var(--brass);background:var(--paper-2)}
.opale-quiz__result{margin-top:1.5rem;padding-top:1.5rem;border-top:var(--rule)}
.opale-quiz__result[hidden]{display:none}

/* ======================================================================
   HERO COVER pleine largeur (comparatif / avis) — effet magazine
   ====================================================================== */
.opale-cover{position:relative;max-width:var(--max);margin:clamp(1rem,2.5vw,2rem) auto 0;border:var(--rule);overflow:hidden;background:var(--ink)}
.opale-cover__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(1.03);display:block}
.opale-cover::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,9,.86) 0%,rgba(15,12,9,.42) 36%,rgba(15,12,9,0) 68%);pointer-events:none}
.opale-cover__inner{position:relative;z-index:2;min-height:clamp(19rem,42vw,31rem);display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(1.4rem,4vw,3rem)}
.opale-cover__badge{align-self:flex-start;margin-bottom:auto;font-family:var(--font-read);text-transform:uppercase;letter-spacing:var(--tracking-caps);font-size:.62rem;color:#fff;background:rgba(20,16,12,.35);border:1px solid rgba(255,255,255,.55);padding:.32rem .85rem;border-radius:999px}
.opale-cover__title{font-family:var(--font-display);font-weight:600;color:#fff;font-size:var(--step-4);line-height:1.03;margin:1.1rem 0 .5rem;max-width:22ch;text-shadow:0 1px 30px rgba(0,0,0,.45)}
.opale-cover__title .accent{font-style:italic;color:#fff}
.opale-cover__meta{font-family:var(--font-read);color:rgba(255,255,255,.82);font-size:.85rem;letter-spacing:.02em}

/* ======================================================================
   CARTE UNIVERS illustrée (accueil « Explorez par univers »)
   ====================================================================== */
.opale-ucard{position:relative;display:block;aspect-ratio:4/3;border:var(--rule);overflow:hidden;text-decoration:none;background:var(--ink)}
.opale-ucard__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease;filter:saturate(.93)}
.opale-ucard:hover .opale-ucard__img{transform:scale(1.045)}
.opale-ucard::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,9,.78) 0%,rgba(15,12,9,.1) 58%,rgba(15,12,9,.02) 100%);pointer-events:none}
.opale-ucard__label{position:absolute;left:0;bottom:0;z-index:2;padding:1.05rem 1.2rem;font-family:var(--font-display);font-size:var(--step-1);color:#fff;text-shadow:0 1px 18px rgba(0,0,0,.45)}

/* ======================================================================
   FOOTER noir (texte clair) — monochrome Chanel
   ====================================================================== */
.opale-footer{background:#1D1D1D;border-top:1px solid #1D1D1D;color:#fff}
.opale-footer h3{color:rgba(255,255,255,.55)}
.opale-footer p{color:rgba(255,255,255,.72)}
.opale-footer a{color:rgba(255,255,255,.82)}
.opale-footer a:hover{color:#fff}
.opale-footer__brand .opale-brand__name{color:#fff}
.opale-footer__legal{color:rgba(255,255,255,.6);border-top:1px solid rgba(255,255,255,.16)}
.opale-footer__legal a{color:rgba(255,255,255,.82)}
.opale-footer__legal a:hover{color:#fff}

/* ======================================================================
   HEADER « façon Chanel » : logo centré + nav repliable au scroll
   ====================================================================== */
.opale-header{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:var(--rule)}
.opale-hd__bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;max-width:var(--max);margin-inline:auto;padding:clamp(.9rem,2vw,1.5rem) var(--gutter)}
.opale-hd__side{display:flex;align-items:center}
.opale-hd__side--left{justify-content:flex-start}
.opale-hd__side--right{justify-content:flex-end}
.opale-brand{display:flex;flex-direction:column;align-items:center;text-align:center;text-decoration:none;gap:.4rem}
.opale-brand__name{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.34em;font-size:clamp(1.4rem,1rem + 2.2vw,2.35rem);color:var(--ink);line-height:1;padding-left:.34em}
.opale-brand__subline{font-family:var(--font-read);text-transform:uppercase;letter-spacing:.26em;font-size:.55rem;color:var(--ink-soft);padding-left:.26em;margin:0}
.opale-brand:hover .opale-brand__name{color:var(--ink)}
.opale-hd__icon{background:none;border:0;cursor:pointer;color:var(--ink);padding:.4rem;display:inline-flex;align-items:center;justify-content:center;line-height:0}
.opale-hd__icon:hover{color:var(--brass-deep)}

/* Nav (rangée 2, desktop) — repli au scroll via data-shrink */
@media (min-width:861px){
	.opale-hd__nav{display:flex;justify-content:center;width:100%;border-top:var(--rule);overflow:hidden;max-height:4.5rem;opacity:1;transition:max-height .32s ease,opacity .25s ease,border-color .32s ease}
	.opale-hd__nav .opale-nav__list{padding:.75rem 0}
	.opale-header[data-shrink="true"] .opale-hd__nav{max-height:0;opacity:0;border-top-color:transparent}
}

/* Barre de recherche */
.opale-hd__search{border-top:var(--rule);background:var(--paper)}
.opale-hd__search[hidden]{display:none}
.opale-hd__searchform{max-width:var(--max);margin-inline:auto;padding:1rem var(--gutter);display:flex;gap:.8rem;align-items:center}
.opale-hd__searchform input{flex:1;border:0;border-bottom:1px solid var(--ink);background:transparent;font-family:var(--font-read);font-size:1rem;padding:.5rem .2rem;color:var(--ink)}
.opale-hd__searchform input::placeholder{color:#999}
.opale-hd__searchform input:focus{outline:none;border-bottom-color:var(--brass-deep)}
.opale-hd__searchform button{font-family:var(--font-read);text-transform:uppercase;letter-spacing:var(--tracking-caps);font-size:.72rem;background:var(--ink);color:var(--paper);border:0;padding:.65rem 1.2rem;cursor:pointer;border-radius:var(--radius);white-space:nowrap}
.opale-hd__searchform button:hover{background:#000}
