/* ============================================================
   OPAL DX — Signature « Opale iridescente »
   Le nom de la marque = la pierre. Fonds nacrés vivants aux
   couleurs du logo (bleu / magenta / jaune / orange), halos,
   reflets. Aucune librairie. GPU-friendly (transform/opacity).
   ============================================================ */

:root {
  --opal-blue:    rgba(0, 96, 168, 0.16);
  --opal-magenta: rgba(192, 24, 96, 0.13);
  --opal-yellow:  rgba(240, 216, 0, 0.14);
  --opal-orange:  rgba(240, 144, 24, 0.12);
  --opal-blue-strong:    rgba(0, 96, 168, 0.30);
  --opal-magenta-strong: rgba(192, 24, 96, 0.26);
}

/* ---- HERO : fond BLEU OPAL UNI, typographie Bricolage Grotesque ---- */
.hero-carousel.opal-bg,
.hero.opal-bg {
  background: var(--c-brand);
}
.hero-carousel .hero-slide__title,
.hero .hero__title {
  font-family: 'Libre Baskerville', Baskerville, 'Baskerville Old Face', Georgia, serif;
  font-weight: 700;
  color: #FFFFFF;
  font-size: clamp(2.5rem, 6.5vw, 5.25rem);
  line-height: 1.08;
  letter-spacing: -0.005em;
}
.hero-carousel .hero-slide__title em,
.hero .hero__title em {
  background: none;
  -webkit-background-clip: initial;
  background-clip: initial;
  -webkit-text-fill-color: var(--c-featured);
  color: var(--c-featured);
  font-style: italic;
}
.hero-carousel .hero-slide__lead,
.hero .hero__lead { color: rgba(255,255,255,0.86); }
.hero-carousel .hero-slide__marquee,
.hero .hero__marquee { color: rgba(255,255,255,0.75); }
.hero-carousel .hero-slide__marquee span::before,
.hero .hero__marquee span::before { background: var(--c-featured); }
.hero-carousel .hero-slide__eyebrow,
.hero .hero__eyebrow {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.25);
  color: #FFFFFF;
  box-shadow: none;
}
.hero-carousel .btn--ghost,
.hero .btn--ghost {
  --btn-fg: #FFFFFF;
  --btn-bd: rgba(255,255,255,0.5);
  --btn-hover-bg: #FFFFFF;
}
.hero-carousel .btn--ghost:hover, .hero .btn--ghost:hover { color: var(--c-brand); border-color: #fff; }
.hero-carousel .btn--brand {
  --btn-bg: #FFFFFF;
  --btn-fg: var(--c-brand);
  --btn-bd: #FFFFFF;
  --btn-hover-bg: var(--c-featured);
}
.hero-carousel .btn--brand:hover { color: var(--c-text); }
.hero-carousel__dot { background: rgba(255,255,255,0.35); }
.hero-carousel__dot.is-active { background: #FFFFFF; }
.hero-carousel__arrow { background: rgba(255,255,255,0.16); color: #fff; backdrop-filter: blur(8px); }
.hero-carousel__arrow:hover { background: #fff; color: var(--c-brand); }

/* ---- Fond opale animé (sections hors hero) ----
   3 blobs en position absolue qui dérivent lentement. */
.opal-bg {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background:
    radial-gradient(90rem 60rem at 110% -20%, var(--opal-magenta), transparent 60%),
    radial-gradient(80rem 55rem at -15% 15%, var(--opal-blue), transparent 55%),
    linear-gradient(180deg, #FDFDFE 0%, #F4F5F8 100%);
}
.opal-bg::before,
.opal-bg::after {
  content: '';
  position: absolute;
  z-index: -1;
  border-radius: 50%;
  filter: blur(70px);
  pointer-events: none;
  will-change: transform;
}
.opal-bg::before {
  width: 55vw; height: 55vw;
  min-width: 480px; min-height: 480px;
  left: -14vw; top: -18vw;
  background:
    radial-gradient(closest-side, var(--opal-blue-strong), transparent 70%),
    radial-gradient(closest-side at 70% 70%, var(--opal-yellow), transparent 65%);
  animation: opal-drift-a 26s ease-in-out infinite alternate;
}
.opal-bg::after {
  width: 48vw; height: 48vw;
  min-width: 420px; min-height: 420px;
  right: -12vw; bottom: -16vw;
  background:
    radial-gradient(closest-side, var(--opal-magenta-strong), transparent 70%),
    radial-gradient(closest-side at 30% 30%, var(--opal-orange), transparent 60%);
  animation: opal-drift-b 32s ease-in-out infinite alternate;
}
@keyframes opal-drift-a {
  from { transform: translate3d(0, 0, 0) scale(1); }
  50%  { transform: translate3d(6vw, 4vw, 0) scale(1.12); }
  to   { transform: translate3d(-3vw, 7vw, 0) scale(0.96); }
}
@keyframes opal-drift-b {
  from { transform: translate3d(0, 0, 0) scale(1); }
  50%  { transform: translate3d(-7vw, -5vw, 0) scale(1.15) rotate(8deg); }
  to   { transform: translate3d(4vw, -8vw, 0) scale(0.94); }
}

/* Variante discrète pour sections intermédiaires */
.opal-bg--soft {
  background:
    radial-gradient(70rem 40rem at 85% 0%, rgba(0, 96, 168, 0.07), transparent 55%),
    radial-gradient(60rem 40rem at 10% 100%, rgba(192, 24, 96, 0.06), transparent 55%),
    #FFFFFF;
}
.opal-bg--soft::before, .opal-bg--soft::after { opacity: 0.5; }

/* ---- Halo produit (packshot hero + cartes) ---- */
.opal-halo {
  position: relative;
}
.opal-halo::before {
  content: '';
  position: absolute;
  inset: 8%;
  z-index: 0;
  border-radius: 50%;
  background: conic-gradient(from 180deg,
    rgba(0,96,168,.18), rgba(192,24,96,.15),
    rgba(240,144,24,.15), rgba(240,216,0,.13), rgba(0,96,168,.18));
  filter: blur(46px);
  animation: opal-halo-spin 18s linear infinite;
  pointer-events: none;
}
@keyframes opal-halo-spin { to { transform: rotate(360deg); } }
.opal-halo > * { position: relative; z-index: 1; }

/* ---- Nacre : liseré iridescent au hover des cartes ---- */
.product-card__media {
  position: relative;
}
.product-card__media::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.5px;
  background: linear-gradient(130deg,
    rgba(0,96,168,.55), rgba(192,24,96,.45) 30%,
    rgba(240,216,0,.5) 60%, rgba(240,144,24,.5) 80%, rgba(0,96,168,.55));
  background-size: 300% 300%;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out-expo);
  animation: opal-sheen 4s linear infinite;
  pointer-events: none;
  z-index: 3;
}
.product-card:hover .product-card__media::after { opacity: 1; }
@keyframes opal-sheen {
  from { background-position: 0% 50%; }
  to   { background-position: 300% 50%; }
}

/* ---- Tilt 3D (JS positionne --tilt-x / --tilt-y) ---- */
.product-card__media,
.hero-slide__visual {
  transform-style: preserve-3d;
  transform: perspective(900px)
    rotateX(var(--tilt-x, 0deg)) rotateY(var(--tilt-y, 0deg))
    translateY(var(--lift, 0));
  transition: transform 500ms var(--ease-out-expo), box-shadow 500ms var(--ease-out-expo);
}
.product-card:hover .product-card__media { --lift: -4px; }

/* ---- Flottement doux du packshot hero ---- */
.hero-slide__visual img,
.hero__visual img {
  animation: opal-float 7s ease-in-out infinite;
}
@keyframes opal-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

/* ---- Titre : ligne accent en dégradé opale ---- */
.hero-slide__title em,
.hero__title em {
  background: linear-gradient(100deg, var(--c-brand) 10%, #7A3FA8 45%, var(--c-promo) 85%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* ---- Eyebrow : pastille lumineuse ---- */
.hero-slide__eyebrow,
.hero__eyebrow {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  background: rgba(255,255,255,0.66);
  border: 1px solid rgba(0,96,168,0.14);
  border-radius: var(--r-pill);
  backdrop-filter: blur(10px);
  color: var(--c-text);
  box-shadow: 0 2px 12px -4px rgba(0,96,168,0.18);
}
.hero-slide__eyebrow::before,
.hero__eyebrow::before {
  content: '';
  width: 8px; height: 8px;
  border-radius: 50%;
  background: conic-gradient(from 0deg, #0060A8, #C01860, #F09018, #F0D800, #0060A8);
  animation: opal-halo-spin 4s linear infinite;
}

/* ---- Reveals stagger : enfants décalés ---- */
[data-reveal-stagger] > * {
  opacity: 0;
  transform: translateY(28px) scale(0.98);
  transition: opacity var(--dur-reveal) var(--ease-out-expo),
              transform var(--dur-reveal) var(--ease-out-expo);
}
[data-reveal-stagger].is-visible > * { opacity: 1; transform: none; }
[data-reveal-stagger].is-visible > *:nth-child(1) { transition-delay: 0ms; }
[data-reveal-stagger].is-visible > *:nth-child(2) { transition-delay: 70ms; }
[data-reveal-stagger].is-visible > *:nth-child(3) { transition-delay: 140ms; }
[data-reveal-stagger].is-visible > *:nth-child(4) { transition-delay: 210ms; }
[data-reveal-stagger].is-visible > *:nth-child(5) { transition-delay: 280ms; }
[data-reveal-stagger].is-visible > *:nth-child(6) { transition-delay: 350ms; }
[data-reveal-stagger].is-visible > *:nth-child(7) { transition-delay: 420ms; }
[data-reveal-stagger].is-visible > *:nth-child(8) { transition-delay: 490ms; }

/* ---- Category tiles : lueur opale au hover ---- */
.category-tile {
  position: relative;
  overflow: hidden;
}
.category-tile::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(24rem 12rem at var(--mx, 50%) 120%,
    rgba(0,96,168,0.10), rgba(192,24,96,0.05) 50%, transparent 75%);
  opacity: 0;
  transition: opacity var(--dur-base);
  pointer-events: none;
}
.category-tile:hover::after { opacity: 1; }
.category-tile__num {
  background: linear-gradient(100deg, var(--c-brand), var(--c-promo));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 700;
}

/* ---- Marquee de marques (bande défilante logos texte) ---- */
.brand-marquee {
  overflow: hidden;
  padding-block: clamp(20px, 3vw, 36px);
  border-block: 1px solid var(--c-border);
  background: #fff;
}
.brand-marquee__track {
  display: flex;
  width: max-content;
  animation: announcement-scroll 36s linear infinite;
}
.brand-marquee:hover .brand-marquee__track { animation-play-state: paused; }
.brand-marquee__group { display: flex; flex-shrink: 0; align-items: center; }
.brand-marquee__item {
  font-family: var(--ff-display);
  font-size: clamp(1.25rem, 2.4vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  padding-inline: clamp(24px, 3.5vw, 56px);
  color: transparent;
  -webkit-text-stroke: 1.3px rgba(10,10,11,0.24);
  transition: color var(--dur-base), -webkit-text-stroke-color var(--dur-base);
  white-space: nowrap;
  cursor: default;
}
.brand-marquee__item:hover {
  color: var(--c-brand);
  -webkit-text-stroke-color: transparent;
}

/* ---- USP dark : reflets opale dans la section sombre ---- */
.section--dark {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.section--dark::before {
  content: '';
  position: absolute;
  z-index: -1;
  width: 60vw; height: 60vw;
  min-width: 500px; min-height: 500px;
  right: -20vw; top: -30vw;
  border-radius: 50%;
  background:
    radial-gradient(closest-side, rgba(0,96,168,0.35), transparent 70%),
    radial-gradient(closest-side at 30% 70%, rgba(192,24,96,0.22), transparent 65%);
  filter: blur(80px);
  animation: opal-drift-b 30s ease-in-out infinite alternate;
  pointer-events: none;
}
.usp {
  position: relative;
  transition: background var(--dur-base);
}
.usp:hover { background: rgba(255,255,255,0.045); }
.usp__num {
  background: linear-gradient(100deg, #62B6FF, #FF6FAE);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ---- Compteurs animés (data-count-to) ---- */
.stat-figure {
  font-variant-numeric: tabular-nums;
}

/* ---- Boutons : shimmer discret sur le CTA principal ---- */
.btn--brand {
  position: relative;
  overflow: hidden;
}
.btn--brand::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 40%;
  left: -60%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,0.35), transparent);
  transform: skewX(-20deg);
  animation: opal-shimmer 4.5s ease-in-out infinite;
  pointer-events: none;
}
@keyframes opal-shimmer {
  0%, 60% { left: -60%; }
  85%, 100% { left: 130%; }
}

/* ---- Carousel dots : dégradé actif ---- */
.hero-carousel__dot.is-active {
  background: linear-gradient(90deg, var(--c-brand), var(--c-promo));
}

/* ---- Réduction de mouvement ---- */
@media (prefers-reduced-motion: reduce) {
  .opal-bg::before, .opal-bg::after,
  .opal-halo::before,
  .hero-slide__visual img, .hero__visual img,
  .product-card__media::after,
  .btn--brand::after,
  .brand-marquee__track,
  .section--dark::before { animation: none !important; }
}

/* Mobile : blobs plus petits, blur réduit (perf) */
@media (max-width: 767px) {
  .opal-bg::before, .opal-bg::after { filter: blur(46px); opacity: 0.8; }
  .opal-halo::before { filter: blur(30px); }
}

/* ---- Header : logo agrandi bien visible ---- */
.site-header__logo {
  height: 72px;
  width: auto;
  display: block;
}
.site-header__inner { min-height: 104px; }
@media (max-width: 767px) {
  .site-header__logo { height: 56px; }
  .site-header__inner { min-height: 84px; }
}

/* ============================================================
   FINALISATION DESIGN — cohérence Baskerville + opale sur tout le site
   ============================================================ */

/* Baskerville pour les grands titres éditoriaux (hors nav/UI/cartes) */
.pd-info__name,
.cat-head__title,
.cart-page__head h1,
.account-head h1,
.page-static h1,
.section-head .h-1,
.cta-band__title,
.hero-headline__title {
  font-family: 'Libre Baskerville', Baskerville, 'Baskerville Old Face', Georgia, serif;
  font-weight: 700;
  letter-spacing: -0.005em;
  line-height: 1.1;
}
.section-head .h-1 { line-height: 1.12; }

/* Accent italique jaune/bleu sur les titres à <em> */
.cta-band__title em,
.hero-headline__title em {
  font-style: italic;
  color: var(--c-brand);
  -webkit-text-fill-color: var(--c-brand);
  background: none;
}

/* En-têtes de page : léger wash opale (statique, non animé, léger) */
.cat-head,
.cart-page__head,
.page-static > h1:first-child,
.pd-gallery {
  position: relative;
}
.cat-head::before,
.cart-page__head::before {
  content: '';
  position: absolute;
  z-index: -1;
  inset: -40px -10vw auto -10vw;
  height: 240px;
  background:
    radial-gradient(40rem 16rem at 15% 0%, rgba(0,96,168,0.08), transparent 60%),
    radial-gradient(30rem 14rem at 90% 30%, rgba(192,24,96,0.06), transparent 60%);
  pointer-events: none;
}

/* Fiche produit : galerie sur fond nacré doux + halo derrière le packshot */
.pd-gallery__main {
  background:
    radial-gradient(60% 55% at 50% 40%, rgba(0,96,168,0.06), transparent 70%),
    var(--c-bg-subtle);
}
.pd-info__price {
  color: var(--c-brand);
}

/* Badges promo/phare : petit éclat */
.badge--featured { box-shadow: 0 2px 10px -2px rgba(240,216,0,0.5); }
.badge--promo { box-shadow: 0 2px 10px -2px rgba(192,24,96,0.4); }

/* Sous-titres de section (eyebrow) : point opale */
.eyebrow::first-letter { color: var(--c-brand); }

/* Boutons brand hors hero : garder le bleu plein (l'override hero ne s'applique qu'au hero) */

/* ============================================================
   ADMIN — zone d'upload d'images (drag & drop)
   ============================================================ */
.upload-drop {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 96px;
  margin-top: var(--s-3);
  padding: var(--s-4);
  border: 2px dashed var(--c-border-strong);
  border-radius: var(--r-3);
  background: var(--c-bg-subtle);
  color: var(--c-text-muted);
  font-size: var(--fs-14);
  text-align: center;
  cursor: pointer;
  transition: border-color var(--dur-fast), background var(--dur-fast), color var(--dur-fast);
}
.upload-drop:hover { border-color: var(--c-brand); color: var(--c-brand); }
.upload-drop.is-drag { border-color: var(--c-brand); background: var(--c-brand-50); color: var(--c-brand); }
.upload-url { margin-top: var(--s-3); }
.upload-url summary { font-size: var(--fs-13); color: var(--c-text-muted); cursor: pointer; }
.upload-url .row { margin-top: var(--s-2); }

/* ============================================================
   HERO FULL-BLEED (image plein cadre + texte en surimpression)
   ============================================================ */
.hero-slide--fullbleed {
  position: relative;
  display: flex;
  align-items: flex-end;
  min-width: 100%;
  overflow: hidden;
  background-image: var(--hero-bg, none);
  background-size: cover;
  background-position: center;
  background-color: var(--c-brand);
}
/* packshot de repli (quand pas d'image bannière) : grand, à droite */
.hero-slide__packshot {
  position: absolute;
  right: -4%;
  bottom: -6%;
  height: 108%;
  width: auto;
  max-width: 58%;
  object-fit: contain;
  filter: drop-shadow(0 30px 60px rgba(0,0,0,0.35));
  animation: opal-float 7s ease-in-out infinite;
  z-index: 1;
}
/* voile dégradé pour lisibilité du texte */
.hero-slide__scrim {
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(90deg, rgba(0,48,90,0.82) 0%, rgba(0,48,90,0.55) 42%, rgba(0,48,90,0.12) 70%, transparent 100%),
    linear-gradient(0deg, rgba(0,32,62,0.7) 0%, transparent 45%);
}
.hero-slide--center .hero-slide__scrim {
  background: linear-gradient(0deg, rgba(0,32,62,0.78) 0%, rgba(0,40,78,0.35) 50%, rgba(0,40,78,0.5) 100%);
}
.hero-slide__overlay {
  position: relative;
  z-index: 3;
  width: 100%;
  padding-block: clamp(56px, 9vw, 128px) clamp(72px, 10vw, 150px);
}
.hero-slide--fullbleed .hero-slide__copy { max-width: 44ch; }
.hero-slide--center .hero-slide__overlay { display: flex; justify-content: center; text-align: center; }
.hero-slide--center .hero-slide__copy { margin-inline: auto; }
.hero-slide--center .hero-slide__ctas { justify-content: center; }
.hero-slide--right .hero-slide__overlay { display: flex; justify-content: flex-end; text-align: right; }
.hero-slide--right .hero-slide__ctas { justify-content: flex-end; }

.hero-slide__flag {
  display: inline-block;
  margin-bottom: var(--s-3);
  padding: 6px 14px;
  background: var(--c-promo);
  color: #fff;
  border-radius: var(--r-pill);
  font-family: var(--ff-display);
  font-size: var(--fs-13);
  font-weight: 700;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}
.hero-slide--fullbleed .hero-slide__title {
  font-size: clamp(2.5rem, 6.5vw, 5.5rem);
  text-shadow: 0 2px 30px rgba(0,20,45,0.4);
}
.hero-slide--fullbleed .hero-slide__lead {
  text-shadow: 0 1px 12px rgba(0,20,45,0.4);
  max-width: 46ch;
}

@media (max-width: 767px) {
  .hero-slide__packshot { max-width: 78%; right: -8%; opacity: 0.9; }
  .hero-slide__scrim {
    background: linear-gradient(0deg, rgba(0,32,62,0.9) 12%, rgba(0,40,78,0.45) 55%, rgba(0,40,78,0.25) 100%);
  }
  .hero-slide--fullbleed { align-items: flex-end; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-slide__packshot { animation: none; }
}

/* ============================================================
   BANDEAU GROUPE DEXTERA (commun à tous les sites du groupe)
   ============================================================ */
.group-bar {
  background: #050505;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  font-size: 11px;
  letter-spacing: 0.04em;
}
.group-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 34px;
}
.group-bar__brand {
  color: rgba(255,255,255,0.85);
  font-family: var(--ff-display);
  font-weight: 500;
  letter-spacing: 0.14em;
  white-space: nowrap;
  transition: color var(--dur-fast);
}
.group-bar__brand strong { font-weight: 800; }
.group-bar__brand:hover { color: #fff; }
.group-bar__links {
  display: flex;
  align-items: center;
  gap: 10px;
  overflow-x: auto;
  scrollbar-width: none;
  white-space: nowrap;
}
.group-bar__links::-webkit-scrollbar { display: none; }
.group-bar__link {
  color: rgba(255,255,255,0.55);
  transition: color var(--dur-fast);
  padding: 8px 0;
}
.group-bar__link:hover { color: #fff; }
.group-bar__link.is-current {
  color: #fff;
  font-weight: 600;
  position: relative;
}
.group-bar__link.is-current::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 4px;
  height: 2px;
  background: linear-gradient(90deg, var(--c-brand), var(--c-promo));
  border-radius: 2px;
}
.group-bar__sep { color: rgba(255,255,255,0.25); }
@media (max-width: 767px) {
  .group-bar__brand { font-size: 10px; }
  .group-bar__links { font-size: 10px; gap: 8px; }
}

/* ---- Admin : badges de rôle + légende ---- */
.admin-role-badge {
  display: inline-block; padding: 2px 10px; border-radius: var(--r-pill);
  font-family: var(--ff-display); font-size: 11px; font-weight: 700;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
}
.admin-role-badge--admin   { background: var(--c-brand-50); color: var(--c-brand); }
.admin-role-badge--manager { background: #FFF4E6; color: var(--c-accent); }
.admin-role-badge--vendeur { background: #E6F4EE; color: var(--c-success); }
.admin-user .admin-role-badge { margin-top: 4px; }
.role-legend { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--s-4); }
.role-legend p { margin-top: 6px; font-size: var(--fs-13); line-height: 1.4; }

/* ---- Admin : écran de connexion staff ---- */
.admin-login-card {
  max-width: 400px; margin: clamp(40px, 8vh, 100px) auto; padding: 40px 32px;
  background: var(--c-bg); border: 1px solid var(--c-border); border-radius: var(--r-4);
  box-shadow: var(--shadow-2); text-align: left;
}
.admin-login-card h2 { font-size: var(--fs-24); margin-bottom: 4px; }
.admin-login-msg {
  margin-top: 12px; padding: 10px 14px; border-radius: var(--r-2);
  background: var(--c-brand-50); color: var(--c-brand); font-size: var(--fs-13);
}
.admin-login-alt { margin-top: 18px; text-align: center; }
.admin-link {
  background: none; border: 0; color: var(--c-text-muted); font-size: var(--fs-13);
  text-decoration: underline; cursor: pointer;
}
.admin-link:hover { color: var(--c-brand); }
.admin-body:has(.admin-login-card) { grid-template-columns: 1fr; }
.admin-aside[hidden]{display:none}
