:root {
  --color-primary: #ff3e9d;
  --color-primary-2: #ff7abf;
  --color-secondary: #6854ff;
  --color-accent: #20d6f6;
  --color-dark: #17142a;
  --color-light: #fff8fc;
  --color-muted: #6f6882;
  --color-border: rgba(88, 70, 130, .16);
  --color-card: rgba(255,255,255,.86);
  --font-main: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-title: "Outfit", "Poppins", system-ui, sans-serif;
  --container: 1180px;
  --container-pad: clamp(1rem, 3vw, 2rem);
  --radius-sm: 14px;
  --radius-md: 22px;
  --radius-lg: 34px;
  --shadow-sm: 0 8px 24px rgba(31, 19, 63, .08);
  --shadow-md: 0 18px 55px rgba(31, 19, 63, .13);
  --shadow-lg: 0 30px 90px rgba(31, 19, 63, .2);
  --transition: .22s ease;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-main);
  color: var(--color-dark);
  background:
    radial-gradient(circle at 12% 3%, rgba(255,62,157,.16), transparent 32rem),
    radial-gradient(circle at 92% 8%, rgba(104,84,255,.14), transparent 30rem),
    linear-gradient(180deg, #fff9fd 0%, #f8f7ff 48%, #ffffff 100%);
  overflow-x: hidden;
  line-height: 1.7;
}
body, main, .site-container, .content-body { max-width: 100%; }
a { color: var(--color-secondary); text-decoration: none; transition: color var(--transition), opacity var(--transition); }
a:hover { color: var(--color-primary); }
img { max-width: 100%; height: auto; display: block; }
p { margin: 0 0 1.05rem; }
strong { font-weight: 700; color: #30205d; }
:focus-visible { outline: 3px solid rgba(32,214,246,.7); outline-offset: 3px; }
.skip-link { position: fixed; left: -999px; top: .5rem; z-index: 2000; padding: .75rem 1rem; background: #fff; border-radius: 999px; box-shadow: var(--shadow-md); }
.skip-link:focus { left: .5rem; }
.site-container { width: min(var(--container), calc(100% - var(--container-pad) * 2)); margin: 0 auto; }
.site-main { min-height: 55vh; }
.site-header { position: sticky; top: 0; z-index: 1000; padding: .75rem var(--container-pad); backdrop-filter: blur(18px); background: rgba(255,250,253,.78); border-bottom: 1px solid rgba(255,255,255,.68); box-shadow: 0 8px 28px rgba(58,36,100,.06); }
.site-nav { width: min(var(--container), 100%); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 1rem; position: relative; }
.site-brand, .footer-brand { display: inline-flex; align-items: center; gap: .7rem; color: var(--color-dark); font-family: var(--font-title); font-weight: 800; letter-spacing: -.02em; }
.site-brand-mark { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 15px; color: #fff; background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)); box-shadow: 0 12px 24px rgba(255,62,157,.26); }
.site-brand-text { display: flex; flex-direction: column; line-height: 1; }
.site-brand-text small { color: var(--color-muted); font-size: .72rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; margin-top: .18rem; }
.nav-links { align-items: center; gap: .25rem; }
.nav-link { color: #2f2850; font-weight: 700; font-size: .91rem; padding: .72rem .9rem; border-radius: 999px; white-space: nowrap; }
.nav-link:hover { background: rgba(104,84,255,.07); }
.nav-cta { color: #fff !important; background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)); box-shadow: 0 12px 24px rgba(104,84,255,.22); margin-left: .35rem; }
.nav-hamburger { width: 46px; height: 46px; border: 1px solid var(--color-border); border-radius: 16px; background: rgba(255,255,255,.82); display: none; flex-direction: column; justify-content: center; gap: 5px; padding: 0 12px; cursor: pointer; box-shadow: var(--shadow-sm); }
.nav-hamburger span { height: 2px; width: 100%; background: var(--color-dark); border-radius: 99px; transition: transform var(--transition), opacity var(--transition); }
.menu-open .nav-hamburger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-open .nav-hamburger span:nth-child(2) { opacity: 0; }
.menu-open .nav-hamburger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
@media (min-width: 1101px) { .nav-links { display: flex; flex-wrap: nowrap; } .nav-hamburger { display: none; } }
@media (max-width: 1100px) {
  .nav-hamburger { display: flex; }
  .nav-links { display: none; position: absolute; top: 62px; left: 0; right: 0; z-index: 999; flex-direction: column; align-items: stretch; gap: .35rem; padding: 1rem; background: rgba(255,255,255,.96); border: 1px solid var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
  .nav-links.nav-open { display: flex; }
  .nav-link { display: block; width: 100%; white-space: normal; line-height: 1.35; }
  .nav-cta { margin-left: 0; text-align: center; }
}
.site-page-hero { padding: clamp(3rem, 7vw, 5.8rem) 0 2rem; position: relative; overflow: hidden; }
.site-page-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 15% 30%, rgba(255,62,157,.2), transparent 24rem), radial-gradient(circle at 90% 25%, rgba(32,214,246,.17), transparent 20rem); pointer-events: none; }
.site-page-hero .site-container { position: relative; }
.eyebrow, .sidebar-kicker { margin: 0 0 .7rem; color: var(--color-primary); font-weight: 800; letter-spacing: .12em; text-transform: uppercase; font-size: .78rem; }
h1, h2, h3, h4 { font-family: var(--font-title); line-height: 1.05; color: #17142a; letter-spacing: -.035em; margin: 0 0 1rem; }
h1 { font-size: clamp(2.4rem, 7vw, 5.6rem); max-width: 920px; }
h2 { font-size: clamp(1.75rem, 4vw, 3.15rem); }
h3 { font-size: clamp(1.25rem, 2.4vw, 1.85rem); }
.site-page-hero p:not(.eyebrow) { max-width: 760px; font-size: clamp(1rem, 1.5vw, 1.2rem); color: var(--color-muted); }
.home-hero { position: relative; min-height: 760px; display: grid; place-items: center; overflow: hidden; isolation: isolate; }
.hero-bg-slide { position: absolute; inset: 0; opacity: 0; background-size: cover; background-position: center; transition: opacity 1.2s ease; transform: scale(1.04); }
.hero-bg-slide.is-active { opacity: 1; }
.hero-bg-slide::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(23,20,42,.82), rgba(23,20,42,.44) 48%, rgba(23,20,42,.14)); }
.hero-shell { position: relative; z-index: 2; width: min(var(--container), calc(100% - var(--container-pad) * 2)); display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(280px, .75fr); gap: clamp(2rem, 5vw, 4.5rem); align-items: center; padding: clamp(5rem, 10vw, 8rem) 0; color: #fff; }
.hero-content h1 { color: #fff; margin-bottom: 1rem; }
.hero-content h1 span { background: linear-gradient(135deg, #fff, #ffd5eb 42%, #8cf0ff); -webkit-background-clip: text; color: transparent; }
.hero-content .hero-lead { font-size: clamp(1.05rem, 1.8vw, 1.32rem); max-width: 740px; color: rgba(255,255,255,.86); }
.hero-actions, .content-actions, .error-actions { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; margin: 1.5rem 0; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; min-height: 48px; padding: .8rem 1.2rem; border-radius: 999px; border: 1px solid transparent; font-weight: 800; cursor: pointer; transition: transform var(--transition), box-shadow var(--transition), background var(--transition); }
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)); color: #fff !important; box-shadow: 0 18px 34px rgba(255,62,157,.28); }
.btn-secondary { color: #fff !important; background: rgba(255,255,255,.16); border-color: rgba(255,255,255,.28); backdrop-filter: blur(10px); }
.btn-soft { color: var(--color-secondary); background: rgba(104,84,255,.08); border-color: rgba(104,84,255,.14); }
.btn-full { width: 100%; }
.hero-trust { display: flex; flex-wrap: wrap; gap: .7rem; margin-top: 1.4rem; }
.hero-trust span, .pill { display: inline-flex; align-items: center; gap: .45rem; padding: .5rem .78rem; border: 1px solid rgba(255,255,255,.22); background: rgba(255,255,255,.12); border-radius: 999px; color: rgba(255,255,255,.9); font-size: .9rem; }
.hero-app-card { border: 1px solid rgba(255,255,255,.24); background: linear-gradient(180deg, rgba(255,255,255,.24), rgba(255,255,255,.1)); backdrop-filter: blur(18px); border-radius: 36px; padding: 1.2rem; box-shadow: var(--shadow-lg); position: relative; overflow: hidden; }
.hero-app-card::before { content: ""; position: absolute; width: 180px; height: 180px; border-radius: 50%; right: -50px; top: -55px; background: rgba(255,62,157,.36); filter: blur(10px); }
.app-window { position: relative; border-radius: 28px; background: rgba(255,255,255,.92); padding: 1rem; color: var(--color-dark); overflow: hidden; }
.app-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.app-avatar { display: flex; align-items: center; gap: .7rem; }
.app-avatar i { width: 48px; height: 48px; border-radius: 50%; display: block; background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)); box-shadow: 0 0 0 6px rgba(255,62,157,.12); }
.app-avatar strong { display: block; line-height: 1; }
.app-avatar small { display: block; color: var(--color-muted); font-weight: 700; font-size: .75rem; }
.app-badge { padding: .35rem .6rem; border-radius: 999px; color: #fff; background: var(--color-primary); font-size: .78rem; font-weight: 800; }
.chat-lines { display: grid; gap: .75rem; margin-bottom: 1rem; }
.chat-bubble { padding: .8rem .95rem; border-radius: 20px; font-size: .92rem; max-width: 88%; background: #f2eefb; }
.chat-bubble.me { margin-left: auto; color: #fff; background: linear-gradient(135deg, var(--color-secondary), var(--color-primary)); }
.builder-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .65rem; }
.builder-grid span { min-height: 72px; border-radius: 20px; background: linear-gradient(135deg, rgba(255,62,157,.15), rgba(104,84,255,.14)); display: grid; place-items: center; font-weight: 800; color: var(--color-secondary); }
.section { padding: clamp(3rem, 7vw, 6rem) 0; }
.section-tight { padding: clamp(2rem, 4vw, 3.5rem) 0; }
.section-head { max-width: 820px; margin-bottom: 2rem; }
.section-head.center { text-align: center; margin-inline: auto; }
.section-head p { color: var(--color-muted); font-size: 1.05rem; }
.glass-panel, .card, .content-card, .sidebar-widget, .blog-card, .article-shell, .contact-card, .error-card, .author-block { background: var(--color-card); border: 1px solid rgba(255,255,255,.72); box-shadow: var(--shadow-sm); border-radius: var(--radius-lg); backdrop-filter: blur(14px); }
.glass-panel { padding: clamp(1.25rem, 3vw, 2.2rem); }
.grid { display: grid; gap: 1.2rem; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.card { padding: 1.35rem; transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition); position: relative; overflow: hidden; }
.card:hover, .blog-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: rgba(255,62,157,.28); }
.card-icon { width: 54px; height: 54px; border-radius: 18px; display: grid; place-items: center; color: #fff; background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)); box-shadow: 0 14px 30px rgba(255,62,157,.22); margin-bottom: 1rem; font-size: 1.4rem; }
.card p, .content-card p { color: var(--color-muted); }
.featured-strip { margin-top: -2rem; position: relative; z-index: 5; }
.featured-strip .glass-panel { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem; }
.featured-logos { display: flex; flex-wrap: wrap; gap: .7rem; }
.featured-logos span { padding: .55rem .85rem; background: #fff; border: 1px solid var(--color-border); border-radius: 999px; color: #4a4266; font-weight: 800; }
.method-timeline { counter-reset: steps; display: grid; gap: 1rem; }
.method-step { counter-increment: steps; display: grid; grid-template-columns: 64px 1fr; gap: 1rem; align-items: start; padding: 1rem; border: 1px solid var(--color-border); border-radius: 24px; background: rgba(255,255,255,.62); }
.method-step::before { content: counter(steps); width: 54px; height: 54px; display: grid; place-items: center; border-radius: 18px; color: #fff; font-family: var(--font-title); font-size: 1.35rem; font-weight: 800; background: linear-gradient(135deg, var(--color-secondary), var(--color-accent)); }
.content-layout { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; padding: clamp(2rem, 4vw, 3rem) 0; }
.article-shell { padding: clamp(1.2rem, 4vw, 2.4rem); overflow: hidden; }
.content-body { font-size: 1.03rem; color: #2d2944; }
.content-body > *:first-child { margin-top: 0; }
.content-body h2, .content-body h3 { margin-top: 2rem; }
.content-body ul, .content-body ol { padding-left: 1.25rem; margin: 1rem 0 1.4rem; }
.content-body li { margin-bottom: .45rem; }



.content-body blockquote { margin: 1.4rem 0; padding: 1.25rem; border-left: 5px solid var(--color-primary); border-radius: 18px; background: rgba(255,62,157,.07); color: #342650; }
.content-image { border-radius: 30px; overflow: hidden; margin-bottom: 1.5rem; box-shadow: var(--shadow-md); }
.site-sidebar { position: sticky; top: 92px; display: grid; gap: 1rem; }
.sidebar-widget { padding: 1.15rem; }
.sidebar-widget-highlight { background: linear-gradient(160deg, rgba(255,62,157,.12), rgba(104,84,255,.12)); }
.sidebar-widget-title { font-size: 1.25rem; margin-bottom: .55rem; }
.sidebar-links, .sidebar-articles { display: grid; gap: .55rem; }
.sidebar-links a, .sidebar-articles a { display: block; padding: .75rem .85rem; border-radius: 16px; background: rgba(255,255,255,.72); border: 1px solid var(--color-border); color: var(--color-dark); }
.sidebar-articles strong { display: block; font-size: .92rem; }
.sidebar-articles span { color: var(--color-muted); font-size: .82rem; }
.sidebar-note { color: var(--color-muted); font-size: .95rem; }
.blog-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.25rem; }
.blog-card { overflow: hidden; transition: transform var(--transition), box-shadow var(--transition); }
.blog-card-img { aspect-ratio: 16 / 9; overflow: hidden; background: rgba(104,84,255,.1); }
.blog-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition); }
.blog-card:hover img { transform: scale(1.045); }
.blog-card-body { padding: 1.15rem; }
.blog-card h2, .blog-card h3 { font-size: 1.25rem; }
.blog-meta { color: var(--color-muted); font-weight: 700; font-size: .86rem; margin-bottom: .65rem; }
.pagination { display: flex; flex-wrap: wrap; justify-content: center; gap: .5rem; margin: 2rem 0; }
.pagination a, .pagination span { min-width: 44px; height: 44px; display: grid; place-items: center; border-radius: 15px; border: 1px solid var(--color-border); background: #fff; font-weight: 800; }
.pagination .is-current { color: #fff; background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)); }
.faq-list { display: grid; gap: .85rem; }
.faq-item { border: 1px solid var(--color-border); border-radius: 22px; background: rgba(255,255,255,.78); overflow: hidden; }
.faq-question { width: 100%; text-align: left; border: 0; background: transparent; padding: 1rem 1.2rem; color: var(--color-dark); font-family: var(--font-title); font-size: 1.05rem; font-weight: 800; cursor: pointer; display: flex; justify-content: space-between; gap: 1rem; }
.faq-question::after { content: "+"; color: var(--color-primary); font-size: 1.3rem; }
.faq-open .faq-question::after { content: "-"; }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height .25s ease; }
.faq-open .faq-answer { max-height: 380px; }
.faq-answer p { padding: 0 1.2rem 1rem; color: var(--color-muted); }
.author-block { display: grid; grid-template-columns: 86px 1fr; gap: 1rem; align-items: center; padding: 1.25rem; margin-top: 2rem; }
.author-avatar-fallback, .author-page-avatar { border-radius: 28px; display: grid; place-items: center; color: #fff; font-family: var(--font-title); font-weight: 800; background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)); box-shadow: var(--shadow-sm); }
.author-avatar-fallback { width: 76px; height: 76px; }
.author-page-avatar { width: 120px; height: 120px; font-size: 2rem; }
.contact-card, .error-card { padding: clamp(1.2rem, 4vw, 2.2rem); }
.form-grid { display: grid; gap: 1rem; }
.form-field label { display: block; font-weight: 800; margin-bottom: .35rem; }
.form-field input, .form-field textarea { width: 100%; border: 1px solid var(--color-border); border-radius: 18px; padding: .9rem 1rem; font: inherit; background: rgba(255,255,255,.9); color: var(--color-dark); }
.form-field textarea { min-height: 180px; resize: vertical; }
.form-hidden { position: absolute; left: -9999px; opacity: 0; height: 0; overflow: hidden; }
.alert { padding: .9rem 1rem; border-radius: 18px; margin-bottom: 1rem; font-weight: 700; }
.alert-success { background: rgba(32,214,246,.13); color: #045063; }
.alert-error { background: rgba(255,62,157,.12); color: #7d194d; }
.error-page { padding: clamp(3rem, 7vw, 6rem) 0; }
.error-card { text-align: center; max-width: 760px; margin: 0 auto; }
.error-code { font-family: var(--font-title); font-size: clamp(4rem, 16vw, 9rem); font-weight: 800; line-height: .9; background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)); -webkit-background-clip: text; color: transparent; }
.site-footer { margin-top: 4rem; padding: 3rem 0 1.2rem; color: rgba(255,255,255,.86); background: radial-gradient(circle at 18% 10%, rgba(255,62,157,.25), transparent 28rem), linear-gradient(135deg, #17142a, #241a49); }
.footer-grid { display: grid; grid-template-columns: 1.4fr .7fr .7fr; gap: 2rem; }
.footer-brand { color: #fff; margin-bottom: 1rem; }
.site-footer h2 { color: #fff; font-size: 1rem; letter-spacing: .04em; text-transform: uppercase; }
.site-footer a { display: block; color: rgba(255,255,255,.78); margin: .45rem 0; }
.site-footer a:hover { color: #fff; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.12); margin-top: 2rem; padding-top: 1rem; font-size: .9rem; color: rgba(255,255,255,.62); }
.premium-shine { position: relative; overflow: hidden; }
@media (prefers-reduced-motion: no-preference) {
  .premium-shine::after { content: ""; position: absolute; inset: 0; transform: translateX(-120%); background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.28) 45%, transparent 70%); transition: transform .75s ease; }
  .premium-shine:hover::after { transform: translateX(120%); }
  .card, .blog-card, .glass-panel { animation: floatIn .55s ease both; }
  @keyframes floatIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
}
@media (max-width: 980px) {
  .hero-shell, .content-layout, .grid-2, .grid-3, .footer-grid { grid-template-columns: 1fr; }
  .home-hero { min-height: auto; }
  .hero-app-card { max-width: 520px; }
  .site-sidebar { position: static; }
  .blog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  :root { --container-pad: 1rem; }
  .site-header { padding-inline: 1rem; }
  .site-brand-text small { display: none; }
  .hero-shell { padding: 5rem 0 3.5rem; }
  .hero-actions, .content-actions, .error-actions { flex-direction: column; align-items: stretch; }
  .btn { width: 100%; }
  .featured-strip { margin-top: 0; }
  .blog-grid { grid-template-columns: 1fr; }
  .method-step, .author-block { grid-template-columns: 1fr; }
  
  
  
  
}

.js-outlink, .js-social { cursor: pointer; user-select: none; }
.js-outlink:focus-visible, .js-social:focus-visible { outline: 3px solid rgba(255,255,255,.9); outline-offset: 3px; }
.footer-socials { display: flex; flex-wrap: wrap; align-items: center; gap: .7rem; margin-top: 1.25rem; }
.footer-social { width: 42px; height: 42px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; color: #fff; font-weight: 900; letter-spacing: -.03em; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18); box-shadow: inset 0 1px 0 rgba(255,255,255,.12); transition: transform var(--transition), background var(--transition), border-color var(--transition); }
.footer-social:hover { transform: translateY(-2px); background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.3); }

.blog-card-img--labelled {
  position: relative;
  display: block;
  overflow: hidden;
}

.blog-card-img--labelled::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 46%;
  background: linear-gradient(
    180deg,
    rgba(14, 8, 30, 0) 0%,
    rgba(14, 8, 30, 0.74) 100%
  );
  pointer-events: none;
  opacity: 0.95;
  transition: opacity var(--transition);
}

.blog-card-img-label {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: calc(100% - 2rem);
  padding: 0.62rem 0.92rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--color-dark);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  box-shadow: 0 14px 34px rgba(18, 9, 34, 0.22);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform var(--transition), background var(--transition), color var(--transition);
}

.blog-card-img--labelled:hover .blog-card-img-label,
.blog-card-img--labelled:focus-visible .blog-card-img-label {
  transform: translateY(-3px);
  background: var(--color-primary);
  color: #fff;
}

.blog-card-img--labelled:hover::after,
.blog-card-img--labelled:focus-visible::after {
  opacity: 1;
}



























.content-lead {
  max-width: 940px;
  margin: 1.6rem auto 0;
  font-size: clamp(1.02rem, 1.4vw, 1.18rem);
  line-height: 1.85;
  color: var(--color-muted);
}

.cta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.85rem;
  margin-top: 2rem;
}

.center.cta-row,
.hero-actions.center {
  justify-content: center;
  text-align: center;
}

.hero-actions.center {
  margin-top: 1.8rem;
}



@media (max-width: 760px) {
  .blog-card-img-label {
    left: 0.85rem;
    right: 0.85rem;
    bottom: 0.85rem;
    max-width: calc(100% - 1.7rem);
    padding: 0.55rem 0.78rem;
    font-size: 0.78rem;
  }

  

  

  

  

  

  

  

  

  

  

  .content-lead {
    margin-top: 1.25rem;
    font-size: 1rem;
    line-height: 1.75;
  }

  .cta-row,
  .hero-actions.center {
    width: 100%;
    justify-content: stretch;
  }

  .cta-row .btn,
  .hero-actions.center .btn,
  .hero-actions.center .js-outlink {
    width: 100%;
    justify-content: center;
  }
}

.dgf-profiles-section {
  position: relative;
}

.dgf-profiles-section::before {
  content: "";
  position: absolute;
  inset: 8% auto auto 50%;
  width: min(760px, 80vw);
  height: min(760px, 80vw);
  transform: translateX(-50%);
  background:
    radial-gradient(circle, rgba(255, 62, 148, 0.13), transparent 62%),
    radial-gradient(circle at 65% 35%, rgba(124, 77, 255, 0.12), transparent 46%);
  pointer-events: none;
  z-index: 0;
}

.dgf-profiles-section .site-container {
  position: relative;
  z-index: 1;
}

.dgf-profile-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.45rem);
  margin-top: 2.2rem;
}

.dgf-profile-card {
  position: relative;
  display: block;
  min-height: clamp(360px, 42vw, 520px);
  border-radius: 24px;
  overflow: hidden;
  cursor: pointer;
  background: #1b1228;
  box-shadow: 0 24px 58px rgba(28, 13, 47, 0.18);
  isolation: isolate;
  outline: none;
  transform: translateZ(0);
  transition:
    transform var(--transition),
    box-shadow var(--transition),
    filter var(--transition);
}

.dgf-profile-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(180deg, rgba(13, 8, 22, 0.05) 0%, rgba(13, 8, 22, 0.12) 42%, rgba(13, 8, 22, 0.82) 100%),
    radial-gradient(circle at 80% 15%, rgba(255, 255, 255, 0.2), transparent 24%);
  pointer-events: none;
}

.dgf-profile-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 4;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: inherit;
  pointer-events: none;
}

.dgf-profile-card:hover,
.dgf-profile-card:focus-visible {
  transform: translateY(-7px);
  box-shadow: 0 34px 78px rgba(28, 13, 47, 0.28);
  filter: saturate(1.05);
}

.dgf-profile-media {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: block;
}

.dgf-profile-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transform: scale(1.01);
  transition: transform 0.7s ease, filter 0.7s ease;
}

.dgf-profile-card:hover .dgf-profile-media img,
.dgf-profile-card:focus-visible .dgf-profile-media img {
  transform: scale(1.07);
  filter: contrast(1.04);
}

.dgf-profile-actions {
  position: absolute;
  top: 0.9rem;
  right: 0.9rem;
  z-index: 5;
  display: grid;
  gap: 0.55rem;
}

.dgf-profile-actions span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  color: #fff;
  font-size: 1rem;
  background: rgba(255, 255, 255, 0.22);
  border: 1px solid rgba(255, 255, 255, 0.32);
  box-shadow: 0 14px 26px rgba(0, 0, 0, 0.18);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition:
    transform var(--transition),
    background var(--transition),
    color var(--transition);
}

.dgf-profile-card:hover .dgf-profile-actions span {
  background: rgba(255, 255, 255, 0.32);
}

.dgf-profile-actions span:hover {
  transform: scale(1.08);
  background: var(--color-primary);
}

.dgf-profile-info {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 5;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.45rem;
}

.dgf-profile-info strong {
  color: #fff;
  font-size: clamp(1.2rem, 2vw, 1.55rem);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -0.04em;
  text-shadow: 0 10px 26px rgba(0, 0, 0, 0.32);
}

.dgf-profile-info small {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  width: fit-content;
  max-width: 100%;
  padding: 0.38rem 0.62rem;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(255, 62, 148, 0.94), rgba(180, 72, 190, 0.88));
  color: #fff;
  font-size: 0.76rem;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 12px 26px rgba(255, 62, 148, 0.28);
}

.dgf-profile-info small i {
  font-style: normal;
  font-size: 0.8rem;
  line-height: 1;
}

.dgf-profile-bottom {
  max-width: 820px;
  margin: 2rem auto 0;
  text-align: center;
}

.dgf-profile-bottom p {
  margin: 0 auto 1.15rem;
  color: var(--color-muted);
  line-height: 1.75;
}

@media (max-width: 980px) {
  .dgf-profile-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dgf-profile-card {
    min-height: clamp(340px, 62vw, 500px);
  }
}

@media (max-width: 620px) {
  .dgf-profile-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .dgf-profile-card {
    min-height: 470px;
    border-radius: 22px;
  }

  .dgf-profile-actions {
    top: 0.75rem;
    right: 0.75rem;
    gap: 0.45rem;
  }

  .dgf-profile-actions span {
    width: 38px;
    height: 38px;
    font-size: 0.92rem;
  }

  .dgf-profile-info {
    left: 0.9rem;
    right: 0.9rem;
    bottom: 0.9rem;
  }
}

@media (max-width: 420px) {
  .dgf-profile-card {
    min-height: 430px;
  }
}

.dgf-single-profile {
  padding: clamp(2rem, 5vw, 4.5rem) 0;
  background:
    radial-gradient(circle at 15% 10%, rgba(255, 62, 148, 0.1), transparent 34%),
    radial-gradient(circle at 85% 20%, rgba(124, 77, 255, 0.09), transparent 30%);
}

.dgf-single-shell {
  display: grid;
  grid-template-columns: minmax(280px, 420px) minmax(0, 1fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}

.dgf-single-photo {
  position: sticky;
  top: 98px;
  border-radius: 28px;
  overflow: hidden;
  background: #1a1026;
  box-shadow: 0 30px 80px rgba(29, 13, 48, 0.22);
  isolation: isolate;
}

.dgf-single-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(18, 9, 31, 0) 46%, rgba(18, 9, 31, 0.72) 100%),
    radial-gradient(circle at 78% 10%, rgba(255, 255, 255, 0.22), transparent 20%);
  z-index: 1;
  pointer-events: none;
}

.dgf-single-photo img {
  width: 100%;
  display: block;
  aspect-ratio: 3 / 4.45;
  object-fit: cover;
}

.dgf-single-photo-badge {
  position: absolute;
  right: 1rem;
  top: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.58rem 0.78rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
  color: var(--color-dark);
  font-weight: 900;
  box-shadow: 0 16px 36px rgba(20, 8, 35, 0.22);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.dgf-single-photo-badge span {
  color: var(--color-primary);
}

.dgf-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.7rem;
  color: var(--color-muted);
  font-size: 0.94rem;
}

.dgf-breadcrumb a {
  color: var(--color-muted);
  text-decoration: none;
}

.dgf-breadcrumb a:hover {
  color: var(--color-primary);
}

.dgf-single-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.4rem;
  padding-bottom: 1.4rem;
  border-bottom: 1px solid rgba(31, 20, 56, 0.1);
}

.dgf-single-head h1 {
  margin: 0.1rem 0 0;
  font-size: clamp(3rem, 7vw, 5.8rem);
  line-height: 0.88;
  letter-spacing: -0.08em;
  text-transform: uppercase;
}

.dgf-likes {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  min-width: fit-content;
  padding-top: 1.2rem;
  color: var(--color-muted);
}

.dgf-likes span {
  color: var(--color-primary);
  font-size: 1.6rem;
}

.dgf-likes strong {
  color: var(--color-dark);
  font-weight: 900;
}

.dgf-likes small {
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.72rem;
  font-weight: 800;
}

.dgf-profile-intro {
  max-width: 850px;
  margin: 1.5rem 0 2rem;
  color: var(--color-muted);
  font-size: clamp(1.02rem, 1.5vw, 1.16rem);
  line-height: 1.8;
}

.dgf-profile-specs {
  margin: 1.7rem 0;
}

.dgf-profile-specs h2 {
  margin: 0 0 1rem;
  font-size: clamp(1.2rem, 2vw, 1.65rem);
  text-transform: uppercase;
  letter-spacing: -0.04em;
  color: color-mix(in srgb, var(--color-dark) 72%, #fff);
}

.dgf-spec-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.95rem;
}

.dgf-spec-item {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 0.75rem;
  row-gap: 0.1rem;
  align-items: center;
  padding: 1rem;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 40px rgba(31, 20, 56, 0.08);
}

.dgf-spec-item-wide {
  grid-column: span 2;
}

.dgf-spec-item span {
  grid-row: span 2;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 16px;
  background: rgba(255, 62, 148, 0.1);
  color: var(--color-primary);
  font-size: 1.2rem;
}

.dgf-spec-item small {
  color: var(--color-muted);
  font-weight: 800;
  font-size: 0.78rem;
}

.dgf-spec-item strong {
  color: var(--color-dark);
  font-size: 0.98rem;
}

.dgf-profile-actions-main {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  margin-top: 2rem;
}

.dgf-locked-panel {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1.2rem;
  align-items: center;
  margin: clamp(2rem, 5vw, 4rem) auto 0;
  padding: clamp(1.2rem, 3vw, 2rem);
  max-width: 980px;
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(226, 246, 255, 0.95), rgba(242, 251, 255, 0.9)),
    radial-gradient(circle at 10% 20%, rgba(56, 172, 230, 0.18), transparent 40%);
  border: 1px solid rgba(255, 255, 255, 0.8);
  box-shadow: 0 24px 70px rgba(39, 83, 117, 0.14);
}

.dgf-locked-icon {
  display: grid;
  place-items: center;
  width: 64px;
  height: 64px;
  border-radius: 22px;
  color: #35a9e8;
  background: rgba(255, 255, 255, 0.7);
  font-size: 2rem;
  font-weight: 900;
}

.dgf-locked-panel h2,
.dgf-more-profiles h2 {
  margin: 0 0 0.3rem;
  font-size: clamp(1.3rem, 2.4vw, 2rem);
}

.dgf-locked-panel p,
.dgf-more-profiles p {
  margin: 0;
  color: var(--color-muted);
  line-height: 1.7;
}

.dgf-more-profiles {
  max-width: 860px;
  margin: clamp(2rem, 5vw, 4rem) auto 0;
  padding: clamp(1.4rem, 3vw, 2.4rem);
  text-align: center;
  border-radius: 30px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(255, 248, 253, 0.92));
  border: 1px solid rgba(255, 255, 255, 0.75);
  box-shadow: var(--shadow-md);
}

.dgf-more-profiles .btn {
  margin-top: 1.3rem;
}

@media (max-width: 980px) {
  .dgf-single-shell {
    grid-template-columns: 1fr;
  }

  .dgf-single-photo {
    position: relative;
    top: auto;
    max-width: 520px;
    margin: 0 auto;
  }

  .dgf-single-head {
    align-items: flex-start;
  }

  .dgf-spec-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dgf-spec-item-wide {
    grid-column: span 2;
  }

  .dgf-locked-panel {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .dgf-locked-icon {
    margin: 0 auto;
  }

  .dgf-locked-panel .btn {
    justify-self: center;
  }
}

@media (max-width: 620px) {
  .dgf-single-profile {
    padding-top: 1rem;
  }

  .dgf-single-head {
    flex-direction: column;
    gap: 0.7rem;
  }

  .dgf-single-head h1 {
    font-size: clamp(2.7rem, 18vw, 4.8rem);
  }

  .dgf-likes {
    padding-top: 0;
  }

  .dgf-spec-grid {
    grid-template-columns: 1fr;
  }

  .dgf-spec-item-wide {
    grid-column: auto;
  }

  .dgf-profile-actions-main .btn,
  .dgf-profile-actions-main .js-outlink {
    width: 100%;
    justify-content: center;
  }
}

.footer-socials {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

.footer-social {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  color: currentColor;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.14);
  cursor: pointer;
  transition: transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}

.footer-social:hover,
.footer-social:focus-visible {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.28);
  outline: none;
}

.footer-social__icon {
  width: 18px;
  height: 18px;
  display: block;
  fill: currentColor;
}

.footer-social[aria-label*="Discord"] .footer-social__icon {
  width: 21px;
  height: 21px;
}

.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.footer-socials {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

.footer-social {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  color: currentColor;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.14);
  cursor: pointer;
  transition: transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}

.footer-social:hover,
.footer-social:focus-visible {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.28);
  outline: none;
}

.footer-social__icon {
  display: block;
  fill: currentColor;
  pointer-events: none;
}

.footer-social--x .footer-social__icon {
  width: 17px;
  height: 17px;
}

.footer-social--facebook .footer-social__icon {
  width: 10px;
  height: 18px;
}

.footer-social--discord .footer-social__icon {
  width: 22px;
  height: 18px;
}

.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* =========================================================
   PATCH HOME HERO APP + COPY PREMIUM
   ========================================================= */

.app-avatar-photo {
  position: relative;
  display: grid !important;
  place-items: center;
  width: 46px;
  height: 46px;
  min-width: 46px;
  overflow: hidden;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(255, 62, 148, 0.2), rgba(124, 77, 255, 0.22));
  box-shadow: 0 14px 34px rgba(255, 62, 148, 0.22);
}

.app-avatar-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.32);
  pointer-events: none;
}

.app-avatar-photo img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transform: scale(1.08);
}

.chat-lines--wave .chat-bubble {
  opacity: 0;
  transform: translateY(14px) scale(0.98);
  animation: dgfBubbleWave .52s cubic-bezier(.2,.8,.2,1) forwards;
  will-change: opacity, transform;
}

.chat-lines--wave .chat-bubble:nth-child(1) {
  animation-delay: .35s;
}

.chat-lines--wave .chat-bubble:nth-child(2) {
  animation-delay: 1.35s;
}

.chat-lines--wave .chat-bubble:nth-child(3) {
  animation-delay: 2.35s;
}

@keyframes dgfBubbleWave {
  from {
    opacity: 0;
    transform: translateY(14px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.builder-grid--cta span {
  cursor: pointer;
  user-select: none;
  position: relative;
  transition:
    transform .22s ease,
    background .22s ease,
    color .22s ease,
    box-shadow .22s ease;
}

.builder-grid--cta span:hover,
.builder-grid--cta span:focus-visible {
  transform: translateY(-2px);
  background: linear-gradient(135deg, rgba(255, 62, 148, 0.18), rgba(124, 77, 255, 0.16));
  box-shadow: 0 14px 28px rgba(255, 62, 148, 0.16);
  outline: none;
}

.page-home .grid.grid-2 > .section-head,
.page-home .grid.grid-2 > .glass-panel {
  position: relative;
  overflow: hidden;
}

.page-home .grid.grid-2 > .section-head {
  padding: clamp(1.35rem, 2.4vw, 2rem);
  border-radius: 30px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(255, 248, 253, 0.72)),
    radial-gradient(circle at 0 0, rgba(255, 62, 148, 0.08), transparent 36%);
  border: 1px solid rgba(255, 255, 255, 0.72);
  box-shadow: 0 22px 60px rgba(31, 20, 56, 0.08);
}

.page-home .grid.grid-2 > .section-head::before,
.page-home .grid.grid-2 > .glass-panel::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, rgba(255, 62, 148, 0.14), transparent 68%);
  pointer-events: none;
}

.page-home .grid.grid-2 > .section-head .eyebrow,
.page-home .grid.grid-2 > .glass-panel .eyebrow,
.page-home .grid.grid-2 > .section-head h2,
.page-home .grid.grid-2 > .glass-panel h2,
.page-home .grid.grid-2 > .glass-panel h3,
.page-home .grid.grid-2 > .section-head p,
.page-home .grid.grid-2 > .glass-panel p,
.page-home .grid.grid-2 > .section-head .btn,
.page-home .grid.grid-2 > .glass-panel .btn {
  position: relative;
  z-index: 1;
}

.page-home .grid.grid-2 > .section-head p,
.page-home .grid.grid-2 > .glass-panel p {
  max-width: 72ch;
  color: color-mix(in srgb, var(--color-muted) 88%, #111);
  font-size: clamp(1rem, 1.15vw, 1.075rem);
  line-height: 1.88;
}

.page-home .grid.grid-2 > .section-head p + p,
.page-home .grid.grid-2 > .glass-panel p + p {
  margin-top: 1rem;
}

.page-home .grid.grid-2 strong {
  color: color-mix(in srgb, var(--color-dark) 82%, var(--color-primary));
  font-weight: 900;
  background: linear-gradient(180deg, transparent 58%, rgba(255, 62, 148, 0.16) 0);
  border-radius: 0.12em;
}

.page-home .content-lead {
  margin-top: 1.4rem;
  padding: clamp(1.05rem, 2vw, 1.35rem);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 42px rgba(31, 20, 56, 0.07);
  line-height: 1.85;
}

@media (prefers-reduced-motion: reduce) {
  .chat-lines--wave .chat-bubble {
    opacity: 1;
    transform: none;
    animation: none;
  }

  .builder-grid--cta span {
    transition: none;
  }
}

@media (max-width: 680px) {
  .app-avatar-photo {
    width: 42px;
    height: 42px;
    min-width: 42px;
  }

  .page-home .grid.grid-2 > .section-head {
    padding: 1.15rem;
    border-radius: 24px;
  }
}


/* Hero : les strong restent dans la couleur normale du texte */
.home-hero .hero-lead strong,
.home-hero .app-avatar strong {
  color: inherit !important;
  background: none !important;
  -webkit-text-fill-color: currentColor !important;
  text-shadow: none !important;
  font-weight: 800;
}

/* Avatar Lina AI */
.app-avatar-photo {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  overflow: hidden;
  display: block;
  position: relative;
  flex: 0 0 auto;
  background: rgba(255,255,255,.12);
  border: 2px solid rgba(255,255,255,.22);
  box-shadow: 0 12px 26px rgba(255, 62, 148, .28);
}

.app-avatar-photo::before,
.app-avatar-photo::after {
  display: none !important;
  content: none !important;
}

.app-avatar-photo img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/* Bulles progressives */
.chat-lines--wave .chat-bubble {
  opacity: 0;
  transform: translateY(12px);
  animation: chatBubbleWave .55s ease forwards;
}

.chat-lines--wave .chat-bubble:nth-child(1) {
  animation-delay: .25s;
}

.chat-lines--wave .chat-bubble:nth-child(2) {
  animation-delay: 1.25s;
}

.chat-lines--wave .chat-bubble:nth-child(3) {
  animation-delay: 2.25s;
}

@keyframes chatBubbleWave {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Mini CTA Chat / Images / Style */
.builder-grid--cta span {
  cursor: pointer;
  position: relative;
  isolation: isolate;
  transition: transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.builder-grid--cta span:hover,
.builder-grid--cta span:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(255, 62, 148, .55);
  background: rgba(255, 62, 148, .14);
  box-shadow: 0 12px 28px rgba(255, 62, 148, .18);
  outline: none;
}

/* Gros blocs plus aérés */
.rich-text-block {
  line-height: 1.78;
}

.rich-text-block p {
  margin-bottom: 1.05rem;
}

.rich-text-block p:last-child {
  margin-bottom: 0;
}

.rich-text-block strong {
  color: #fff;
  font-weight: 850;
  background: linear-gradient(135deg, rgba(255, 62, 148, .22), rgba(135, 83, 255, .18));
  border: 1px solid rgba(255, 255, 255, .10);
  border-radius: .45em;
  padding: .04em .32em;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

/* On évite que les strong des boutons ou du hero prennent le style badge */
.home-hero .rich-text-block strong,
.btn strong,
.nav-link strong {
  color: inherit !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
}

.rich-points {
  display: grid;
  gap: .7rem;
  margin: 1.2rem 0 1.35rem;
}

.rich-points span {
  display: block;
  padding: .78rem .9rem;
  border-radius: 14px;
  background: rgba(255, 255, 255, .065);
  border: 1px solid rgba(255, 255, 255, .10);
  line-height: 1.55;
}

.rich-points--soft span {
  background: rgba(255, 62, 148, .065);
  border-color: rgba(255, 62, 148, .13);
}

.rich-text-block .rich-points strong {
  color: inherit;
  background: none;
  border: 0;
  padding: 0;
  font-weight: 850;
}



/* =========================================================
   SAFE — rendu éditorial articles / piliers uniquement
   Scope strict : .article-shell.content-body
   ========================================================= */

.article-shell.content-body {
  font-size: 1.04rem;
  line-height: 1.78;
  color: rgba(255, 255, 255, .78);
}

/* Paragraphes */
.article-shell.content-body p {
  margin: 0 0 1.15rem;
}

.article-shell.content-body .lead {
  font-size: clamp(1.08rem, 1.4vw, 1.2rem);
  line-height: 1.72;
  color: rgba(255, 255, 255, .88);
  margin-bottom: 1.55rem;
}

/* Titres */
.article-shell.content-body h2 {
  margin: 2.35rem 0 1rem;
  line-height: 1.18;
  color: #fff;
}

.article-shell.content-body h3 {
  margin: 1.8rem 0 .75rem;
  line-height: 1.25;
  color: #fff;
}

/* Strong : simple, pas de badge, pas de fond */
.article-shell.content-body strong {
  color: #fff !important;
  font-weight: 850;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
  -webkit-text-fill-color: currentColor !important;
}

/* Listes */
.article-shell.content-body ul,
.article-shell.content-body ol {
  margin: 1.15rem 0 1.55rem;
  padding-left: 1.35rem;
}

.article-shell.content-body li {
  margin: 0 0 .65rem;
  padding-left: .15rem;
}

.article-shell.content-body li::marker {
  color: var(--color-primary);
  font-weight: 900;
}

/* Liens internes */
.article-shell.content-body a:not(.btn) {
  color: #fff;
  font-weight: 750;
  text-decoration: none;
  border-bottom: 2px solid rgba(255, 62, 148, .5);
}

.article-shell.content-body a:not(.btn):hover {
  color: var(--color-primary);
  border-bottom-color: transparent;
}

/* Encadré review */
.article-shell.content-body .review-rating-box {
  margin: 1.45rem 0 1.9rem;
  padding: 1.2rem 1.3rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, .055);
  border: 1px solid rgba(255, 255, 255, .12);
}

.article-shell.content-body .review-rating-box p {
  margin-bottom: .55rem;
}

.article-shell.content-body .review-rating-box p:last-child {
  margin-bottom: 0;
}

.article-shell.content-body .review-rating-box strong::before {
  content: "★ ";
  color: #ffd166;
}

















/* CTA bas d’article */
.article-shell.content-body .cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  align-items: center;
  margin-top: 1.6rem;
}

/* JSON-LD dans contenu */
.article-shell.content-body script[type="application/ld+json"] {
  display: none !important;
}

/* Mobile safe */
@media (max-width: 767px) {
  .article-shell.content-body {
    font-size: 1rem;
    line-height: 1.72;
  }

  .article-shell.content-body h2 {
    margin-top: 2rem;
  }

  

  

  .article-shell.content-body .cta-row {
    flex-direction: column;
    align-items: stretch;
  }

  .article-shell.content-body .cta-row .btn {
    width: 100%;
    justify-content: center;
  }
}

.featured-access {
  position: relative;
  z-index: 5;
  margin-top: -34px;
  margin-bottom: 2.4rem;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;

  padding: 1.18rem 1.35rem;
  border-radius: 24px;

  background:
    linear-gradient(135deg, rgba(255, 255, 255, .96), rgba(255, 245, 252, .94)) !important;
  border: 1px solid rgba(255, 62, 148, .16) !important;
  box-shadow:
    0 24px 70px rgba(30, 9, 40, .22),
    0 1px 0 rgba(255, 255, 255, .8) inset !important;

  color: #241226 !important;
  backdrop-filter: blur(18px);
}

.featured-access__text {
  display: grid;
  gap: .3rem;
  min-width: 0;
}

.featured-access__text > strong {
  color: #211126 !important;
  font-size: 1.05rem;
  font-weight: 950;
  letter-spacing: -.01em;
}

.featured-access__text > span {
  color: rgba(35, 18, 38, .78) !important;
  line-height: 1.56;
}

.featured-access__text > span strong {
  color: #d91b7f !important;
  font-weight: 900;
}

.featured-access__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .55rem;
  flex: 0 0 auto;
}

.featured-access__links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-height: 36px;
  padding: .5rem .78rem;
  border-radius: 999px;

  color: #8f1a66 !important;
  text-decoration: none !important;
  font-size: .88rem;
  font-weight: 900;

  background: rgba(255, 62, 148, .085) !important;
  border: 1px solid rgba(255, 62, 148, .22) !important;
  box-shadow: 0 8px 22px rgba(255, 62, 148, .08);

  transition:
    transform .18s ease,
    background .18s ease,
    border-color .18s ease,
    color .18s ease,
    box-shadow .18s ease;
}

.featured-access__links a:hover,
.featured-access__links a:focus-visible {
  color: #fff !important;
  background: linear-gradient(135deg, #ff3e94, #8753ff) !important;
  border-color: rgba(135, 83, 255, .5) !important;
  box-shadow: 0 12px 30px rgba(255, 62, 148, .28);
  transform: translateY(-1px);
  outline: none;
}

@media (max-width: 767px) {
  .featured-access {
    margin-top: -22px;
    margin-bottom: 1.8rem;
    flex-direction: column;
    align-items: flex-start;
    padding: 1rem;
    border-radius: 20px;
  }

  .featured-access__links {
    width: 100%;
    justify-content: flex-start;
  }

  .featured-access__links a {
    flex: 1 1 auto;
  }
}

/* =========================================================
   PATCH HOME — panels naturels + cards centrées + panels premium
   ========================================================= */

/* 1. Les blocs glass-panel dans les grilles 2 colonnes ne s'étirent plus */
.section .site-container.grid-2,
.section-tight .site-container.grid-2 {
  align-items: start;
}

.grid-2 > .glass-panel:not(.featured-access),
.grid-2 > .section-head,
.grid-2 > .rich-text-block {
  align-self: start;
}

.grid-2 > .glass-panel:not(.featured-access) {
  height: auto !important;
  min-height: 0 !important;
}

/* Le CTA dans les panels garde un placement propre */
.grid-2 > .glass-panel:not(.featured-access) .btn,
.grid-2 > .glass-panel:not(.featured-access) .js-outlink.btn {
  margin-top: .35rem;
}

/* 2. Icônes des cards centrées */
.card .card-icon {
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 1.05rem !important;
}

.card {
  text-align: center;
}

.card p {
  text-align: left;
}

/* Option propre : titre centré, paragraphe lisible */
.card h3 {
  text-align: center;
}

/* 3. Panels rich-text plus premium */
.glass-panel.rich-text-block:not(.featured-access),
.site-container.glass-panel.rich-text-block {
  position: relative;
  isolation: isolate;
  overflow: hidden;

  background:
    radial-gradient(circle at 12% 0%, rgba(255, 62, 157, .13), transparent 30%),
    radial-gradient(circle at 92% 12%, rgba(104, 84, 255, .12), transparent 32%),
    linear-gradient(145deg, rgba(255, 255, 255, .96), rgba(255, 247, 253, .9)) !important;

  border: 1px solid rgba(255, 255, 255, .86) !important;
  box-shadow:
    0 24px 70px rgba(31, 19, 63, .14),
    0 1px 0 rgba(255, 255, 255, .9) inset !important;

  color: #241b34;
}

/* Trait premium subtil en haut */
.glass-panel.rich-text-block:not(.featured-access)::before,
.site-container.glass-panel.rich-text-block::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  z-index: -1;
  background: linear-gradient(90deg, var(--color-primary), var(--color-secondary), var(--color-accent));
  opacity: .95;
}

/* Halo discret */
.glass-panel.rich-text-block:not(.featured-access)::after,
.site-container.glass-panel.rich-text-block::after {
  content: "";
  position: absolute;
  right: -80px;
  top: -80px;
  width: 190px;
  height: 190px;
  border-radius: 999px;
  z-index: -1;
  background: radial-gradient(circle, rgba(255, 62, 157, .16), transparent 68%);
  pointer-events: none;
}

.glass-panel.rich-text-block h2,
.glass-panel.rich-text-block h3,
.site-container.glass-panel.rich-text-block h2,
.site-container.glass-panel.rich-text-block h3 {
  color: #17142a;
}

.glass-panel.rich-text-block p,
.site-container.glass-panel.rich-text-block p {
  color: rgba(36, 27, 52, .76);
}

.glass-panel.rich-text-block .eyebrow,
.site-container.glass-panel.rich-text-block .eyebrow {
  color: var(--color-primary);
}

/* Strong lisibles et premium sur fond clair */
.glass-panel.rich-text-block strong,
.site-container.glass-panel.rich-text-block strong {
  color: #8f1a66 !important;
  font-weight: 900;
  background: linear-gradient(135deg, rgba(255, 62, 157, .12), rgba(104, 84, 255, .10)) !important;
  border: 1px solid rgba(255, 62, 157, .14) !important;
  border-radius: .5em;
  padding: .03em .32em;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

/* Sauf dans les boutons */
.glass-panel.rich-text-block .btn strong,
.site-container.glass-panel.rich-text-block .btn strong {
  color: inherit !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
}

/* Bouton secondaire utilisable sur panel clair */
.glass-panel.rich-text-block .btn-secondary,
.site-container.glass-panel.rich-text-block .btn-secondary {
  color: #8f1a66 !important;
  background: rgba(255, 62, 157, .08) !important;
  border-color: rgba(255, 62, 157, .22) !important;
  backdrop-filter: none;
}

.glass-panel.rich-text-block .btn-secondary:hover,
.site-container.glass-panel.rich-text-block .btn-secondary:hover {
  color: #fff !important;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)) !important;
  border-color: transparent !important;
}

/* 4. Rich points plus propres dans panels premium */
.glass-panel.rich-text-block .rich-points span,
.site-container.glass-panel.rich-text-block .rich-points span {
  background: rgba(255, 255, 255, .72);
  border: 1px solid rgba(255, 62, 157, .12);
  box-shadow: 0 10px 28px rgba(31, 19, 63, .055);
}

.glass-panel.rich-text-block .rich-points strong,
.site-container.glass-panel.rich-text-block .rich-points strong {
  color: #7b1d68 !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
}

/* Mobile : on garde le naturel sans casser les colonnes qui passent à 1 */
@media (max-width: 980px) {
  .grid-2 > .glass-panel:not(.featured-access),
  .grid-2 > .section-head,
  .grid-2 > .rich-text-block {
    align-self: auto;
  }

  .card {
    text-align: center;
  }

  .card p {
    text-align: left;
  }
}

/* =========================================================
   PATCH CTA SECONDAIRES — lisibles sur fonds clairs
   ========================================================= */

/* Par défaut hors hero sombre : bouton secondaire rose/violet lisible */
.section .btn-secondary,
.section-tight .btn-secondary,
.article-shell .btn-secondary,
.content-body .btn-secondary,
.glass-panel .btn-secondary {
  color: #8f1a66 !important;
  background: rgba(255, 62, 157, .085) !important;
  border-color: rgba(255, 62, 157, .24) !important;
  box-shadow: 0 10px 26px rgba(255, 62, 157, .10);
  backdrop-filter: none !important;
}

/* Hover premium */
.section .btn-secondary:hover,
.section-tight .btn-secondary:hover,
.article-shell .btn-secondary:hover,
.content-body .btn-secondary:hover,
.glass-panel .btn-secondary:hover {
  color: #fff !important;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)) !important;
  border-color: transparent !important;
  box-shadow: 0 16px 34px rgba(255, 62, 157, .25);
}

/* Exception : dans le hero sombre, on garde le style blanc translucide */
.home-hero .btn-secondary,
.hero-content .btn-secondary {
  color: #fff !important;
  background: rgba(255, 255, 255, .16) !important;
  border-color: rgba(255, 255, 255, .28) !important;
  box-shadow: none;
  backdrop-filter: blur(10px) !important;
}

.home-hero .btn-secondary:hover,
.hero-content .btn-secondary:hover {
  color: #fff !important;
  background: rgba(255, 255, 255, .24) !important;
  border-color: rgba(255, 255, 255, .38) !important;
}





/* =========================================================
   PATCH GF.PHP — image principale cliquable
   ========================================================= */

.gf-hero-media--clickable {
  cursor: pointer;
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 30px;
  isolation: isolate;
}

.gf-hero-media--clickable img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s ease, filter .55s ease;
}

.gf-hero-media--clickable::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  z-index: 1;
  height: 44%;
  background: linear-gradient(180deg, rgba(14, 8, 30, 0), rgba(14, 8, 30, .72));
  pointer-events: none;
}

.gf-hero-media--clickable:hover img,
.gf-hero-media--clickable:focus-visible img {
  transform: scale(1.045);
  filter: saturate(1.06) contrast(1.03);
}

.gf-hero-media__label {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: .55rem .9rem;
  border-radius: 999px;
  color: #fff;
  font-size: .84rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  box-shadow: 0 14px 34px rgba(255, 62, 157, .28);
}

.gf-hero-media--clickable:hover .gf-hero-media__label,
.gf-hero-media--clickable:focus-visible .gf-hero-media__label {
  background: linear-gradient(135deg, var(--color-secondary), var(--color-primary));
}

/* =========================================================
   PATCH IMAGES CTA — articles / piliers / blog / GF
   ========================================================= */

.content-image-link,
.blog-card-img.js-outlink,
.gf-hero-media--clickable {
  cursor: pointer;
  position: relative;
  display: block;
  color: inherit;
  outline: none;
}

.content-image-link:focus-visible,
.blog-card-img.js-outlink:focus-visible,
.gf-hero-media--clickable:focus-visible {
  outline: 3px solid rgba(255, 62, 157, .42);
  outline-offset: 4px;
}

.content-image {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  margin-bottom: 1.7rem;
  border-radius: 30px;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255, 62, 157, .14), rgba(104, 84, 255, .12)),
    #fff;
  border: 1px solid rgba(255, 255, 255, .86);
  box-shadow: 0 24px 64px rgba(31, 19, 63, .15);
  isolation: isolate;
}

.content-image img,
.blog-card-img.js-outlink img,
.gf-hero-media--clickable img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s ease, filter .55s ease;
}

.content-image::after,
.blog-card-img.js-outlink::after,
.gf-hero-media--clickable::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  z-index: 1;
  height: 44%;
  background: linear-gradient(180deg, rgba(14, 8, 30, 0), rgba(14, 8, 30, .72));
  pointer-events: none;
}

.content-image-link:hover img,
.content-image-link:focus-visible img,
.blog-card-img.js-outlink:hover img,
.blog-card-img.js-outlink:focus-visible img,
.gf-hero-media--clickable:hover img,
.gf-hero-media--clickable:focus-visible img {
  transform: scale(1.045);
  filter: saturate(1.06) contrast(1.03);
}

.content-image-label,
.gf-hero-media__label {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: .55rem .9rem;
  border-radius: 999px;
  color: #fff;
  font-size: .84rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  box-shadow: 0 14px 34px rgba(255, 62, 157, .28);
}

.blog-card-img.js-outlink .blog-card-img-label {
  pointer-events: none;
}

.content-image-link:hover .content-image-label,
.content-image-link:focus-visible .content-image-label,
.gf-hero-media--clickable:hover .gf-hero-media__label,
.gf-hero-media--clickable:focus-visible .gf-hero-media__label {
  background: linear-gradient(135deg, var(--color-secondary), var(--color-primary));
}

@media (max-width: 760px) {
  .content-image {
    aspect-ratio: 16 / 10;
    border-radius: 22px;
    margin-bottom: 1.25rem;
  }

  .content-image-label,
  .gf-hero-media__label {
    left: .8rem;
    bottom: .8rem;
    min-height: 32px;
    padding: .45rem .72rem;
    font-size: .76rem;
  }
}

/* =========================================================
   BLOG — image CTA + titre visible
   ========================================================= */

.blog-card--premium {
  background: rgba(255, 255, 255, .92);
  border: 1px solid rgba(255, 255, 255, .86);
  box-shadow: 0 18px 48px rgba(31, 19, 63, .10);
}

.blog-card-img--cta {
  position: relative;
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  cursor: pointer;
  background: #1b1228;
  color: #fff;
  isolation: isolate;
}

.blog-card-img--cta img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s ease, filter .55s ease;
}

.blog-card-img--cta::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(18, 10, 32, .08) 0%, rgba(18, 10, 32, .38) 42%, rgba(18, 10, 32, .88) 100%),
    radial-gradient(circle at 18% 12%, rgba(255, 62, 157, .34), transparent 34%);
  pointer-events: none;
}

.blog-card-img--cta:hover img,
.blog-card-img--cta:focus-visible img {
  transform: scale(1.055);
  filter: saturate(1.08) contrast(1.04);
}

.blog-card-img__content {
  position: absolute;
  inset: auto 1rem 1rem 1rem;
  z-index: 2;
  display: grid;
  gap: .38rem;
  color: #fff;
}

.blog-card-img__content small {
  width: fit-content;
  padding: .35rem .58rem;
  border-radius: 999px;
  color: #fff;
  font-size: .68rem;
  line-height: 1;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: rgba(255, 62, 157, .78);
  border: 1px solid rgba(255, 255, 255, .24);
  backdrop-filter: blur(12px);
}

.blog-card-img__content strong {
  color: #fff !important;
  font-family: var(--font-title);
  font-size: clamp(1.05rem, 1.7vw, 1.32rem);
  line-height: 1.08;
  font-weight: 950;
  letter-spacing: -.03em;
  text-shadow: 0 3px 18px rgba(0, 0, 0, .42);
}

.blog-card-img__content em {
  width: fit-content;
  margin-top: .2rem;
  padding: .46rem .7rem;
  border-radius: 999px;
  color: #fff;
  font-style: normal;
  font-size: .76rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  box-shadow: 0 12px 28px rgba(255, 62, 157, .25);
}

.blog-card-body h2 {
  margin-bottom: .7rem;
}

.blog-card-body h2 a {
  color: #17142a;
  text-decoration: none;
}

.blog-card-body h2 a:hover {
  color: var(--color-primary);
}

.blog-read-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: .35rem;
  min-height: 36px;
  padding: .5rem .78rem;
  border-radius: 999px;
  color: #8f1a66 !important;
  font-size: .82rem;
  font-weight: 900;
  background: rgba(255, 62, 157, .08);
  border: 1px solid rgba(255, 62, 157, .18);
  text-decoration: none;
}

.blog-read-link:hover {
  color: #fff !important;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  border-color: transparent;
}

@media (max-width: 760px) {
  .blog-card-img--cta {
    aspect-ratio: 16 / 11;
  }

  .blog-card-img__content {
    inset: auto .85rem .85rem .85rem;
  }

  .blog-card-img__content strong {
    font-size: 1.05rem;
  }
}

/* =========================================================
   PAGE AVIS — vrai bloc review premium
   ========================================================= */

.content-body .dgf-review-card.review-rating-box {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  margin: 2rem 0 2.5rem;
  padding: clamp(1rem, 2.6vw, 1.45rem);
  border-radius: 34px;
  background:
    radial-gradient(circle at 12% 0%, rgba(255, 62, 157, .22), transparent 34%),
    radial-gradient(circle at 92% 12%, rgba(104, 84, 255, .18), transparent 38%),
    linear-gradient(145deg, rgba(255, 255, 255, .98), rgba(255, 242, 251, .94));
  border: 1px solid rgba(255, 255, 255, .92);
  box-shadow:
    0 30px 86px rgba(31, 19, 63, .17),
    0 1px 0 rgba(255, 255, 255, .96) inset;
}

.content-body .dgf-review-card.review-rating-box::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 5px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-secondary), var(--color-accent));
  z-index: 1;
}

.content-body .dgf-review-card.review-rating-box strong::before {
  content: none !important;
}

.content-body .dgf-review-card__inner {
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr) 124px;
  gap: 1.15rem;
  align-items: center;
}

.content-body .dgf-review-media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 5;
  border-radius: 26px;
  background: #1b1228;
  box-shadow: 0 18px 42px rgba(31, 19, 63, .18);
}

.content-body .dgf-review-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.content-body .dgf-review-media::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 46%;
  background: linear-gradient(180deg, transparent, rgba(18, 10, 32, .82));
}

.content-body .dgf-review-media span {
  position: absolute;
  left: .75rem;
  right: .75rem;
  bottom: .75rem;
  z-index: 2;
  display: inline-flex;
  justify-content: center;
  padding: .45rem .65rem;
  border-radius: 999px;
  color: #fff;
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: rgba(255, 62, 157, .82);
  border: 1px solid rgba(255, 255, 255, .24);
  backdrop-filter: blur(10px);
}

.content-body .dgf-review-kicker {
  margin: 0 0 .35rem !important;
  color: var(--color-primary);
  font-size: .74rem;
  font-weight: 950;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.content-body .dgf-review-title {
  margin: 0 0 .55rem;
  color: #17142a;
  font-family: var(--font-title);
  font-size: clamp(1.55rem, 3vw, 2.35rem);
  line-height: 1.02;
  font-weight: 950;
  letter-spacing: -.045em;
}

.content-body .dgf-review-stars {
  display: flex;
  align-items: center;
  gap: .18rem;
  margin: .2rem 0 .75rem;
  color: #ffd166;
  font-size: clamp(1.45rem, 2.8vw, 2rem);
  line-height: 1;
  text-shadow: 0 8px 24px rgba(255, 209, 102, .38);
}

.content-body .dgf-review-stars .is-partial {
  color: transparent;
  background: linear-gradient(90deg, #ffd166 38%, rgba(23, 20, 42, .20) 38%);
  -webkit-background-clip: text;
  background-clip: text;
  text-shadow: none;
}

.content-body .dgf-review-summary {
  max-width: 720px;
  margin: 0 0 1rem !important;
  color: rgba(36, 27, 52, .76);
  line-height: 1.68;
}

.content-body .dgf-review-summary strong {
  color: #8f1a66 !important;
  font-weight: 950;
}

.content-body .dgf-review-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .55rem;
}

.content-body .dgf-review-metrics div {
  padding: .72rem .7rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, .74);
  border: 1px solid rgba(255, 62, 157, .12);
  box-shadow: 0 10px 24px rgba(31, 19, 63, .055);
}

.content-body .dgf-review-metrics strong {
  display: block;
  color: #17142a !important;
  font-family: var(--font-title);
  font-size: 1.18rem;
  line-height: 1;
  font-weight: 950;
}

.content-body .dgf-review-metrics span {
  display: block;
  margin-top: .25rem;
  color: rgba(36, 27, 52, .68);
  font-size: .76rem;
  font-weight: 850;
}

.content-body .dgf-review-score {
  display: grid;
  place-items: center;
  width: 124px;
  height: 124px;
  border-radius: 999px;
  color: #fff;
  background:
    radial-gradient(circle at 34% 20%, rgba(255, 255, 255, .42), transparent 30%),
    linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  box-shadow:
    0 20px 48px rgba(255, 62, 157, .30),
    0 0 0 9px rgba(255, 62, 157, .10);
}

.content-body .dgf-review-score strong {
  color: #fff !important;
  font-family: var(--font-title);
  font-size: 2.35rem;
  line-height: .78;
  font-weight: 950;
  letter-spacing: -.06em;
}

.content-body .dgf-review-score span {
  margin-top: -.18rem;
  color: rgba(255, 255, 255, .78);
  font-size: .92rem;
  font-weight: 950;
}

.content-body .dgf-review-score small {
  margin-top: -.08rem;
  color: #fff;
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.content-body .dgf-review-verdict {
  margin-top: 1.1rem;
  padding: 1rem 1.1rem;
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255, 62, 157, .10), rgba(104, 84, 255, .08)),
    rgba(255, 255, 255, .76);
  border: 1px solid rgba(255, 62, 157, .14);
}

.content-body .dgf-review-verdict strong {
  margin-bottom: .35rem;
  color: #17142a !important;
  font-family: var(--font-title);
  font-size: 1.1rem;
  font-weight: 950;
}

.content-body .dgf-review-verdict p {
  margin: 0 !important;
  color: rgba(36, 27, 52, .76);
  line-height: 1.68;
}

@media (max-width: 980px) {
  .content-body .dgf-review-card__inner {
    grid-template-columns: 140px minmax(0, 1fr);
  }

  .content-body .dgf-review-score {
    grid-column: 1 / -1;
    width: 112px;
    height: 112px;
    justify-self: start;
  }
}

@media (max-width: 640px) {
  .content-body .dgf-review-card.review-rating-box {
    border-radius: 26px;
    padding: 1rem;
  }

  .content-body .dgf-review-card__inner {
    grid-template-columns: 1fr;
  }

  .content-body .dgf-review-media {
    aspect-ratio: 16 / 9;
  }

  .content-body .dgf-review-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .content-body .dgf-review-score {
    justify-self: center;
  }
}

























/* =========================================================
   PAGE AVIS — REVIEW CARD V2 CLEAN
   ========================================================= */

.page-pilier .content-body .dgf-review-card.review-rating-box {
  position: relative !important;
  isolation: isolate !important;
  overflow: hidden !important;
  margin: 2rem 0 2.6rem !important;
  padding: clamp(1rem, 2.4vw, 1.35rem) !important;
  border-radius: 32px !important;
  background:
    radial-gradient(circle at 8% 0%, rgba(255, 62, 157, .16), transparent 34%),
    radial-gradient(circle at 94% 8%, rgba(104, 84, 255, .14), transparent 36%),
    linear-gradient(145deg, rgba(255, 248, 253, .98), rgba(247, 244, 255, .96)) !important;
  border: 1px solid rgba(255, 255, 255, .9) !important;
  box-shadow:
    0 26px 70px rgba(31, 19, 63, .13),
    0 1px 0 rgba(255, 255, 255, .96) inset !important;
}

.page-pilier .content-body .dgf-review-card.review-rating-box::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 0 auto 0 !important;
  height: 5px !important;
  background: linear-gradient(90deg, var(--color-primary), var(--color-secondary), #28c8ff) !important;
  z-index: 1 !important;
}

.page-pilier .content-body .dgf-review-card.review-rating-box strong::before {
  content: none !important;
}

/* Structure principale : plus de gros rond qui mange la largeur */
.page-pilier .content-body .dgf-review-card__inner {
  display: grid !important;
  grid-template-columns: 150px minmax(0, 1fr) !important;
  gap: 1.15rem !important;
  align-items: center !important;
}

.page-pilier .content-body .dgf-review-media {
  position: relative !important;
  overflow: hidden !important;
  aspect-ratio: 4 / 5 !important;
  border-radius: 24px !important;
  background: #1b1228 !important;
  box-shadow: 0 16px 38px rgba(31, 19, 63, .16) !important;
}

.page-pilier .content-body .dgf-review-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.page-pilier .content-body .dgf-review-media::after {
  content: "" !important;
  position: absolute !important;
  inset: auto 0 0 0 !important;
  height: 46% !important;
  background: linear-gradient(180deg, rgba(18, 10, 32, 0), rgba(18, 10, 32, .84)) !important;
}

.page-pilier .content-body .dgf-review-media span {
  position: absolute !important;
  left: .7rem !important;
  right: .7rem !important;
  bottom: .7rem !important;
  z-index: 2 !important;
  display: inline-flex !important;
  justify-content: center !important;
  padding: .5rem .65rem !important;
  border-radius: 999px !important;
  color: #fff !important;
  font-size: .7rem !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)) !important;
  box-shadow: 0 12px 26px rgba(255, 62, 157, .28) !important;
}

/* Header interne */
.page-pilier .content-body .dgf-review-content {
  min-width: 0 !important;
}

.page-pilier .content-body .dgf-review-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  margin-bottom: .8rem !important;
}

.page-pilier .content-body .dgf-review-kicker {
  margin: 0 0 .3rem !important;
  color: var(--color-primary) !important;
  font-size: .72rem !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  letter-spacing: .13em !important;
  text-transform: uppercase !important;
}

.page-pilier .content-body .dgf-review-title {
  margin: 0 0 .45rem !important;
  color: #17142a !important;
  font-family: var(--font-title) !important;
  font-size: clamp(1.7rem, 2.6vw, 2.15rem) !important;
  line-height: 1.02 !important;
  font-weight: 950 !important;
  letter-spacing: -.045em !important;
  text-wrap: balance;
}

/* Etoiles propres */
.page-pilier .content-body .dgf-review-stars {
  display: flex !important;
  align-items: center !important;
  gap: .14rem !important;
  margin: 0 !important;
  color: #f6c84c !important;
  font-size: 1.55rem !important;
  line-height: 1 !important;
  text-shadow: 0 7px 18px rgba(246, 200, 76, .28) !important;
}

.page-pilier .content-body .dgf-review-stars span {
  display: inline-block !important;
  width: 1em !important;
  text-align: center !important;
}

.page-pilier .content-body .dgf-review-stars .is-partial {
  color: transparent !important;
  background: linear-gradient(90deg, #f6c84c 42%, rgba(23, 20, 42, .18) 42%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  text-shadow: none !important;
}

/* Badge note compact, sans retour ligne moche */
.page-pilier .content-body .dgf-review-score {
  flex: 0 0 auto !important;
  display: inline-flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 108px !important;
  min-height: 78px !important;
  padding: .72rem .85rem !important;
  border-radius: 22px !important;
  text-align: center !important;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)) !important;
  box-shadow:
    0 16px 36px rgba(255, 62, 157, .27),
    0 0 0 7px rgba(255, 62, 157, .09) !important;
}

.page-pilier .content-body .dgf-review-score strong {
  display: block !important;
  color: #fff !important;
  font-family: var(--font-title) !important;
  font-size: 1.75rem !important;
  line-height: .95 !important;
  font-weight: 950 !important;
  letter-spacing: -.045em !important;
  white-space: nowrap !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
}

.page-pilier .content-body .dgf-review-score span {
  display: block !important;
  margin-top: .25rem !important;
  color: rgba(255, 255, 255, .88) !important;
  font-size: .68rem !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

/* Résumé : plus large, moins de retours forcés */
.page-pilier .content-body .dgf-review-summary {
  max-width: none !important;
  margin: 0 !important;
  color: rgba(36, 27, 52, .78) !important;
  font-size: 1rem !important;
  line-height: 1.68 !important;
  text-wrap: pretty;
}

.page-pilier .content-body .dgf-review-summary strong {
  color: #8f1a66 !important;
  font-weight: 950 !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
}

/* Métriques lisibles, pas compressées */
.page-pilier .content-body .dgf-review-metrics {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: .7rem !important;
  margin-top: 1.05rem !important;
}

.page-pilier .content-body .dgf-review-metrics > div {
  min-width: 0 !important;
  padding: .85rem .72rem !important;
  border-radius: 18px !important;
  text-align: center !important;
  background: rgba(255, 255, 255, .76) !important;
  border: 1px solid rgba(255, 62, 157, .11) !important;
  box-shadow: 0 10px 24px rgba(31, 19, 63, .045) !important;
}

.page-pilier .content-body .dgf-review-metrics strong {
  display: block !important;
  color: #17142a !important;
  font-family: var(--font-title) !important;
  font-size: 1.18rem !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
}

.page-pilier .content-body .dgf-review-metrics span {
  display: block !important;
  margin-top: .3rem !important;
  color: rgba(36, 27, 52, .64) !important;
  font-size: .74rem !important;
  line-height: 1.2 !important;
  font-weight: 850 !important;
  white-space: nowrap !important;
}

/* Verdict */
.page-pilier .content-body .dgf-review-verdict {
  margin-top: 1rem !important;
  padding: 1rem 1.05rem !important;
  border-radius: 22px !important;
  background:
    linear-gradient(135deg, rgba(255, 62, 157, .075), rgba(104, 84, 255, .055)),
    rgba(255, 255, 255, .78) !important;
  border: 1px solid rgba(255, 62, 157, .12) !important;
}

.page-pilier .content-body .dgf-review-verdict > strong {
  display: block !important;
  margin-bottom: .35rem !important;
  color: #17142a !important;
  font-family: var(--font-title) !important;
  font-size: 1.08rem !important;
  font-weight: 950 !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
}

.page-pilier .content-body .dgf-review-verdict p {
  margin: 0 !important;
  color: rgba(36, 27, 52, .78) !important;
  line-height: 1.68 !important;
}

.page-pilier .content-body .dgf-review-verdict p strong {
  color: #17142a !important;
  font-weight: 950 !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
}

/* Responsive */
@media (max-width: 780px) {
  .page-pilier .content-body .dgf-review-card__inner {
    grid-template-columns: 1fr !important;
  }

  .page-pilier .content-body .dgf-review-media {
    aspect-ratio: 16 / 9 !important;
  }

  .page-pilier .content-body .dgf-review-head {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .page-pilier .content-body .dgf-review-score {
    min-width: 116px !important;
  }

  .page-pilier .content-body .dgf-review-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 460px) {
  .page-pilier .content-body .dgf-review-card.review-rating-box {
    border-radius: 24px !important;
    padding: .9rem !important;
  }

  .page-pilier .content-body .dgf-review-title {
    font-size: 1.75rem !important;
  }

  .page-pilier .content-body .dgf-review-summary {
    font-size: .96rem !important;
  }

  .page-pilier .content-body .dgf-review-metrics span {
    white-space: normal !important;
  }
}





/* =========================================================
   AUTHOR PAGE + AUTHOR BLOCK — refonte premium
   ========================================================= */

.page-author .author-page-shell {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 10% 0%, rgba(255, 62, 157, .10), transparent 34%),
    radial-gradient(circle at 92% 8%, rgba(104, 84, 255, .10), transparent 34%),
    rgba(255, 255, 255, .92);
  border: 1px solid rgba(255, 255, 255, .9);
  box-shadow: 0 26px 76px rgba(31, 19, 63, .12);
}

.author-hero-card {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  gap: 1.25rem;
  align-items: center;
  margin-bottom: 1.5rem;
  padding: clamp(1.1rem, 2.6vw, 1.6rem);
  border-radius: 30px;
  background:
    linear-gradient(135deg, rgba(255, 248, 253, .96), rgba(247, 244, 255, .94));
  border: 1px solid rgba(255, 255, 255, .9);
  box-shadow: 0 18px 46px rgba(31, 19, 63, .08);
}

.author-page-avatar--premium,
.author-avatar-fallback--premium {
  display: grid;
  place-items: center;
  color: #fff;
  font-family: var(--font-title);
  font-weight: 950;
  letter-spacing: -.04em;
  background:
    radial-gradient(circle at 32% 22%, rgba(255, 255, 255, .42), transparent 28%),
    linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  box-shadow:
    0 18px 42px rgba(255, 62, 157, .24),
    0 0 0 8px rgba(255, 62, 157, .08);
}

.author-page-avatar--premium {
  width: 96px;
  height: 96px;
  border-radius: 30px;
  font-size: 2rem;
}

.author-hero-content h2,
.author-info-panel h2,
.author-method-card h2,
.author-responsibility-card h2 {
  margin-bottom: .7rem;
}

.author-lead {
  margin-bottom: 1rem;
  color: rgba(36, 27, 52, .78);
  font-size: clamp(1.03rem, 1.35vw, 1.16rem);
  line-height: 1.78;
}

.author-lead strong,
.author-info-panel strong,
.author-method-card strong,
.author-responsibility-card strong,
.author-block--premium strong {
  color: #8f1a66 !important;
  font-weight: 950;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
}

.author-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.author-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: .45rem .72rem;
  border-radius: 999px;
  color: #8f1a66;
  font-size: .8rem;
  font-weight: 900;
  background: rgba(255, 62, 157, .08);
  border: 1px solid rgba(255, 62, 157, .16);
}

.author-page-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin: 1.15rem 0;
}

.author-info-panel,
.author-method-card,
.author-responsibility-card {
  padding: clamp(1rem, 2.4vw, 1.35rem);
  border-radius: 26px;
  background: rgba(255, 255, 255, .74);
  border: 1px solid rgba(31, 20, 56, .08);
  box-shadow: 0 14px 34px rgba(31, 19, 63, .055);
}

.author-info-panel--soft {
  background:
    linear-gradient(135deg, rgba(255, 62, 157, .07), rgba(104, 84, 255, .055)),
    rgba(255, 255, 255, .78);
}

.author-info-panel p,
.author-method-card p,
.author-responsibility-card p {
  color: rgba(36, 27, 52, .78);
  line-height: 1.75;
}

.author-method-card {
  margin-top: 1rem;
}

.author-method-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .85rem;
  margin-top: 1rem;
}

.author-method-grid > div {
  padding: 1rem;
  border-radius: 22px;
  background: rgba(255, 255, 255, .78);
  border: 1px solid rgba(255, 62, 157, .10);
}

.author-method-grid strong {
  display: block;
  margin-bottom: .35rem;
  color: #17142a !important;
  font-family: var(--font-title);
  font-size: 1.06rem;
}

.author-method-grid p {
  margin: 0;
  font-size: .95rem;
}

.author-responsibility-card {
  margin-top: 1rem;
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 62, 157, .09), transparent 34%),
    rgba(255, 255, 255, .78);
}

.author-actions {
  margin-top: 1.4rem;
}

/* Bloc auteur sous articles */
.author-block--premium {
  position: relative;
  overflow: hidden;
  grid-template-columns: 74px minmax(0, 1fr);
  align-items: center;
  margin-top: 2rem;
  padding: clamp(1rem, 2.4vw, 1.25rem);
  border-radius: 28px;
  background:
    radial-gradient(circle at 8% 0%, rgba(255, 62, 157, .12), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, .94), rgba(255, 248, 253, .9));
  border: 1px solid rgba(255, 255, 255, .88);
  box-shadow: 0 18px 46px rgba(31, 19, 63, .09);
}

.author-avatar-fallback--premium {
  width: 74px;
  height: 74px;
  border-radius: 24px;
  font-size: 1.35rem;
}

.author-block-content h2 {
  margin: 0 0 .45rem;
  font-size: clamp(1.2rem, 2vw, 1.55rem);
}

.author-block-content p {
  margin: 0;
  color: rgba(36, 27, 52, .75);
  line-height: 1.68;
}

.author-block-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: .8rem;
}

.author-block-actions a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: .45rem .7rem;
  border-radius: 999px;
  color: #8f1a66 !important;
  font-size: .8rem;
  font-weight: 900;
  background: rgba(255, 62, 157, .08);
  border: 1px solid rgba(255, 62, 157, .15);
  text-decoration: none;
}

.author-block-actions a:hover {
  color: #fff !important;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  border-color: transparent;
}

@media (max-width: 860px) {
  .author-page-grid,
  .author-method-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 620px) {
  .author-hero-card,
  .author-block--premium {
    grid-template-columns: 1fr;
    text-align: left;
  }

  .author-page-avatar--premium,
  .author-avatar-fallback--premium {
    width: 72px;
    height: 72px;
    border-radius: 22px;
  }

  .author-badges {
    gap: .45rem;
  }

  .author-badges span {
    font-size: .76rem;
  }

  .author-block-actions a {
    width: 100%;
    justify-content: center;
  }
}

/* =========================================================
   LEGAL / PRIVACY — lisibilité fond clair
   ========================================================= */

.legal-page .legal-shell,
.privacy-page .legal-shell {
  background:
    radial-gradient(circle at 10% 0%, rgba(255, 62, 157, .08), transparent 34%),
    radial-gradient(circle at 92% 8%, rgba(104, 84, 255, .08), transparent 34%),
    rgba(255, 255, 255, .94) !important;
  color: #2d2944 !important;
}

.legal-page .legal-content,
.privacy-page .legal-content {
  color: #2d2944 !important;
}

.legal-page .legal-content h2,
.legal-page .legal-content h3,
.privacy-page .legal-content h2,
.privacy-page .legal-content h3 {
  background: #17142a !important;
  color:white!important;
}



.legal-page .legal-content a,
.privacy-page .legal-content a {
  color: #8f1a66 !important;
  font-weight: 800;
}

.legal-page .legal-content strong,
.privacy-page .legal-content strong {
  color: #17142a !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
}

/* =========================================================
   IMAGES INLINE — articles / piliers
   ========================================================= */

.content-body .dgf-inline-media {
  position: relative;
  display: block;
  margin: 2rem 0 2.15rem;
  border-radius: 30px;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255, 62, 157, .12), rgba(104, 84, 255, .10)),
    #fff;
  border: 1px solid rgba(255, 255, 255, .88);
  box-shadow: 0 22px 58px rgba(31, 19, 63, .12);
}

.content-body .dgf-inline-media__link {
  position: relative;
  display: block;
  cursor: pointer;
  overflow: hidden;
  aspect-ratio: 16 / 8.5;
  background: #1b1228;
}

.content-body .dgf-inline-media__link::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 42%;
  background:
    linear-gradient(180deg, rgba(14, 8, 30, 0), rgba(14, 8, 30, .72));
  pointer-events: none;
}

.content-body .dgf-inline-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s ease, filter .55s ease;
}

.content-body .dgf-inline-media__link:hover img,
.content-body .dgf-inline-media__link:focus-visible img {
  transform: scale(1.045);
  filter: saturate(1.06) contrast(1.03);
}

.content-body .dgf-inline-media__link:focus-visible {
  outline: 3px solid rgba(255, 62, 157, .42);
  outline-offset: 4px;
}

.content-body .dgf-inline-media figcaption {
  margin: 0;
  padding: .75rem .95rem .85rem;
  color: rgba(36, 27, 52, .66);
  font-size: .82rem;
  line-height: 1.45;
  font-weight: 700;
  background: rgba(255, 255, 255, .88);
}

@media (max-width: 760px) {
  .content-body .dgf-inline-media {
    margin: 1.55rem 0 1.7rem;
    border-radius: 22px;
  }

  .content-body .dgf-inline-media__link {
    aspect-ratio: 16 / 10;
  }

  .content-body .dgf-inline-media figcaption {
    padding: .65rem .75rem .75rem;
    font-size: .76rem;
  }
}

 







/* Répartition exacte des 4 colonnes */


















/* Mobile : cartes lisibles, pas de scroll cassé */




/* Wrapper propre */





/* On neutralise tous les vieux width nth-child */


/* Header */




/* Body */






/* Première colonne = libellé / profil / type */





/* 2 colonnes */




/* 3 colonnes */






/* 4 colonnes : le cas qui bug actuellement */








/* 5 colonnes */






/* Images inline venant des profils : crop aligné haut */
.content-body .dgf-inline-media--profile img {
  object-position: center top !important;
}

/* Un peu plus vertical si tu veux mieux respecter les portraits */
.content-body .dgf-inline-media--profile .dgf-inline-media__link {
  aspect-ratio: 16 / 9.8;
}

@media (max-width: 760px) {
  .content-body .dgf-inline-media--profile .dgf-inline-media__link {
    aspect-ratio: 16 / 11;
  }
}

/* =========================================================
   TABLEAUX — RESET FINAL PROPRE
   Bloc unique : remplace tous les anciens patchs tableaux.
   Desktop : vraie table fluide.
   Mobile : lignes transformées en cartes verticales pleine largeur.
   ========================================================= */

.content-table-wrap {
  width: 100% !important;
  max-width: 100% !important;
  margin: 2rem 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 28px !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .96), rgba(255, 248, 253, .92)) !important;
  border: 1px solid rgba(31, 20, 56, .08) !important;
  box-shadow: 0 18px 44px rgba(31, 19, 63, .075) !important;
}

.content-table-wrap > table,
.content-body > table {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-collapse: collapse !important;
  border-spacing: 0 !important;
  table-layout: auto !important;
  background: #fff !important;
  color: #2d2944 !important;
  font-size: .96rem !important;
}

.content-body > table {
  margin: 1.6rem 0 !important;
  overflow: hidden !important;
  border-radius: 24px !important;
  box-shadow: 0 16px 38px rgba(31, 19, 63, .07) !important;
}

.content-table-wrap > table thead th,
.content-body > table thead th {
  padding: 1rem 1rem !important;
  color: #17142a !important;
  font-family: var(--font-title) !important;
  font-size: .92rem !important;
  line-height: 1.35 !important;
  font-weight: 950 !important;
  text-align: left !important;
  vertical-align: top !important;
  background: linear-gradient(180deg, rgba(246, 240, 255, .98), rgba(241, 236, 250, .96)) !important;
  border: 1px solid rgba(31, 20, 56, .075) !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
}

.content-table-wrap > table tbody td,
.content-body > table tbody td {
  padding: 1rem 1rem !important;
  color: rgba(36, 27, 52, .82) !important;
  line-height: 1.55 !important;
  text-align: left !important;
  vertical-align: top !important;
  background: rgba(255, 255, 255, .96) !important;
  border: 1px solid rgba(31, 20, 56, .075) !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  hyphens: none !important;
}

.content-table-wrap > table tbody td:first-child,
.content-body > table tbody td:first-child {
  color: #17142a !important;
  font-family: var(--font-title) !important;
  font-weight: 950 !important;
  background:
    linear-gradient(135deg, rgba(255, 62, 157, .055), rgba(104, 84, 255, .04)),
    rgba(255, 255, 255, .98) !important;
}

.content-table-wrap > table tbody td:nth-child(2),
.content-body > table tbody td:nth-child(2) {
  color: #8f1a66 !important;
  font-weight: 850 !important;
}

.content-table-wrap > table strong,
.content-body > table strong {
  color: #17142a !important;
  font-weight: 950 !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}

.content-table-wrap > table a,
.content-body > table a {
  color: #8f1a66 !important;
  font-weight: 850 !important;
}

@media (max-width: 767px) {
  .content-table-wrap {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 1.45rem 0 1.8rem !important;
    padding: .8rem !important;
    overflow: visible !important;
    border-radius: 24px !important;
  }

  .content-table-wrap > table,
  .content-body > table {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-collapse: separate !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    table-layout: auto !important;
  }

  .content-body > table {
    margin: 1.45rem 0 1.8rem !important;
    padding: .8rem !important;
    border-radius: 24px !important;
    background: rgba(255, 255, 255, .96) !important;
    border: 1px solid rgba(31, 20, 56, .08) !important;
    box-shadow: 0 16px 40px rgba(31, 19, 63, .08) !important;
  }

  .content-table-wrap thead,
  .content-body > table thead {
    display: none !important;
  }

  .content-table-wrap tbody,
  .content-body > table tbody {
    display: grid !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    gap: .9rem !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .content-table-wrap tr,
  .content-body > table tr {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    border-radius: 20px !important;
    background: #fff !important;
    border: 1px solid rgba(31, 20, 56, .08) !important;
    box-shadow: 0 10px 26px rgba(31, 19, 63, .055) !important;
  }

  .content-table-wrap th,
  .content-table-wrap td,
  .content-body > table th,
  .content-body > table td {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: .88rem .95rem !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(31, 20, 56, .075) !important;
    background: #fff !important;
    color: rgba(36, 27, 52, .82) !important;
    font-size: .96rem !important;
    line-height: 1.55 !important;
    text-align: left !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    hyphens: none !important;
  }

  .content-table-wrap td:last-child,
  .content-body > table td:last-child {
    border-bottom: 0 !important;
  }

  .content-table-wrap td:first-child,
  .content-body > table td:first-child {
    color: #17142a !important;
    font-family: var(--font-title) !important;
    font-size: 1.04rem !important;
    font-weight: 950 !important;
    letter-spacing: -.015em !important;
    background:
      linear-gradient(135deg, rgba(255, 62, 157, .10), rgba(104, 84, 255, .075)),
      #fff !important;
  }

  .content-table-wrap td:nth-child(2),
  .content-body > table td:nth-child(2) {
    color: #8f1a66 !important;
    font-weight: 900 !important;
  }

  .content-table-wrap td:nth-child(n+3),
  .content-body > table td:nth-child(n+3) {
    color: rgba(36, 27, 52, .76) !important;
    font-weight: 600 !important;
  }

  .content-table-wrap td::before,
  .content-body > table td::before {
    display: none !important;
    content: none !important;
  }
}


/* =========================================================
   GF PROFILE — CTA secondaires lisibles
   ========================================================= */

.page-gf-profile .dgf-profile-actions-main .btn-secondary,
.page-gf-profile .dgf-profile-actions-main .js-outlink.btn-secondary {
  color: #8f1a66 !important;
  background: rgba(255, 62, 157, .085) !important;
  border: 1px solid rgba(255, 62, 157, .24) !important;
  box-shadow: 0 10px 26px rgba(255, 62, 157, .10) !important;
  backdrop-filter: none !important;
}

.page-gf-profile .dgf-profile-actions-main .btn-secondary:hover,
.page-gf-profile .dgf-profile-actions-main .btn-secondary:focus-visible {
  color: #fff !important;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)) !important;
  border-color: transparent !important;
  box-shadow: 0 16px 34px rgba(255, 62, 157, .25) !important;
  outline: none !important;
}

.page-gf-profile .dgf-profile-actions-main {
  align-items: center;
}

@media (max-width: 620px) {
  .page-gf-profile .dgf-profile-actions-main .btn,
  .page-gf-profile .dgf-profile-actions-main .js-outlink {
    width: 100% !important;
    justify-content: center !important;
  }
}


/* =========================================================
   DREAMGF.CH — footer language switcher / CH multilingual
   ========================================================= */

.footer-language-switcher {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 1.1rem;
}

.footer-language-switcher a {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  margin: 0 !important;
  padding: 0.48rem 0.72rem;
  border-radius: 999px;
  color: rgba(255,255,255,.82) !important;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  font-size: 0.86rem;
  font-weight: 800;
  line-height: 1;
}

.footer-language-switcher a:hover,
.footer-language-switcher a:focus-visible,
.footer-language-switcher a.is-current {
  color: #fff !important;
  background: rgba(255,255,255,.16);
  border-color: rgba(255,255,255,.28);
}

.featured-access {
  position: relative;
  z-index: 6;
  margin-top: -2rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.featured-access__text {
  display: grid;
  gap: 0.25rem;
  max-width: 620px;
}

.featured-access__text strong {
  color: var(--color-dark);
  font-family: var(--font-title);
  font-size: 1.2rem;
}

.featured-access__text span {
  color: var(--color-muted);
}

.featured-access__links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  justify-content: flex-end;
}

.featured-access__links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.55rem 0.78rem;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--color-border);
  color: var(--color-dark);
  font-weight: 800;
  font-size: 0.9rem;
}

.featured-access__links a:hover {
  color: var(--color-primary);
  border-color: rgba(255,62,157,.24);
}

.center {
  text-align: center;
}

.content-table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 1.4rem 0;
}

.content-table,
.content-body table,
.content-table-wrap table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  border-radius: 22px;
  background: rgba(255,255,255,.9);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
}

.content-table th,
.content-table td,
.content-body table th,
.content-body table td,
.content-table-wrap table th,
.content-table-wrap table td {
  padding: 0.95rem 1rem;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid rgba(88,70,130,.12);
}

.content-table th,
.content-body table th,
.content-table-wrap table th {
  background: linear-gradient(135deg, rgba(255,62,157,.12), rgba(104,84,255,.10));
  color: var(--color-dark);
  font-weight: 900;
}

.content-table tr:last-child td,
.content-body table tr:last-child td,
.content-table-wrap table tr:last-child td {
  border-bottom: 0;
}

@media (max-width: 760px) {
  .featured-access {
    margin-top: 0;
    align-items: stretch;
  }

  .featured-access__links {
    justify-content: stretch;
    width: 100%;
  }

  .featured-access__links a {
    flex: 1 1 140px;
  }

  .footer-language-switcher a {
    flex: 1 1 auto;
  }
}
