/* ==========================================================================
   Alpino Casino — style.css  (prefix: bri-)
   Archetipo: Kiosk Minimal · neutrali freddi + 1 accento · taglio asimmetrico
   ========================================================================== */

@property --bri-line {
  syntax: '<length>'; inherits: false; initial-value: 0px;
}

:root {
  /* superfici (tono freddo) */
  --bri-bg:        #ffffff;
  --bri-surface:   #f3f6f9;
  --bri-surface-2: #e8edf2;
  --bri-zone:      #dbeff0;            /* zona brand: header / footer */
  --bri-hairline:  color-mix(in srgb, #14181f 12%, transparent);
  --bri-hairline-2:color-mix(in srgb, #14181f 18%, transparent);

  /* inchiostri */
  --bri-ink:   #14181f;
  --bri-ink-2: #36404f;
  --bri-ink-3: #54607012;             /* placeholder, overridden below */
  --bri-ink-3: #525d6d;               /* muted, AA su bianco */

  /* accenti brand */
  --bri-accent:    #182a5e;
  --bri-accent-ink:#fff;
  --bri-cta:       #677395;
  --bri-cta-strong:#54607f;

  /* misure */
  --bri-wrap: 1283px;
  --bri-pad:  clamp(16px, 4vw, 34px);
  --bri-cut:  13px 0 13px 0;          /* taglio asimmetrico */
  --bri-r-sm: 8px;

  /* tipografia — scala 1.25 */
  --bri-step--1: clamp(.78rem, .76rem + .1vw, .84rem);
  --bri-step-0:  clamp(1rem, .97rem + .15vw, 1.06rem);
  --bri-step-1:  clamp(1.18rem, 1.1rem + .4vw, 1.33rem);
  --bri-step-2:  clamp(1.45rem, 1.3rem + .7vw, 1.75rem);
  --bri-step-3:  clamp(1.8rem, 1.5rem + 1.3vw, 2.45rem);
  --bri-step-4:  clamp(2.1rem, 1.6rem + 2.2vw, 3.1rem);

  /* movimento */
  --bri-ease: cubic-bezier(.16, 1, .3, 1);
  --bri-t1: .14s; --bri-t2: .2s; --bri-t3: .28s;

  --bri-head: 'Lexend', system-ui, 'Segoe UI', sans-serif;
  --bri-body: 'Atkinson Hyperlegible', system-ui, 'Segoe UI', sans-serif;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  background: var(--bri-bg);
  color: var(--bri-ink);
  font-family: var(--bri-body);
  font-size: var(--bri-step-0);
  line-height: 1.62;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1, h2, h3, h4 {
  font-family: var(--bri-head);
  line-height: 1.12;
  margin: 0 0 .5em;
  text-wrap: balance;
  letter-spacing: -.015em;
  color: var(--bri-ink);
}
p { margin: 0 0 1em; text-wrap: pretty; }

a { color: var(--bri-accent); text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { color: var(--bri-cta-strong); }

img, picture, video, svg { max-width: 100%; height: auto; }

:focus-visible { outline: 2px solid var(--bri-accent); outline-offset: 2px; }
::selection { background: color-mix(in srgb, var(--bri-accent) 22%, #fff); color: var(--bri-ink); }
::marker { color: var(--bri-accent); }
:root { accent-color: var(--bri-accent); scrollbar-color: var(--bri-accent) var(--bri-surface); }

/* ---------- contenitore ---------- */
.bri-wrap {
  width: 100%;
  max-width: var(--bri-wrap);
  margin-inline: auto;
  padding-inline: var(--bri-pad);
}

.bri-kicker {
  display: block;
  font-family: var(--bri-head);
  font-size: var(--bri-step--1);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 600;
  color: var(--bri-accent);
  margin-bottom: .55rem;
}

/* ==========================================================================
   HEADER / NAV
   ========================================================================== */
.bri-head {
  position: sticky; top: 0; z-index: 50;
  background: var(--bri-zone);
  border-bottom: 1px solid var(--bri-hairline-2);
}
.bri-head__in {
  display: flex; align-items: center; gap: 18px;
  min-height: 62px;
  padding-block: 8px;
}
.bri-logo { display: inline-flex; align-items: center; line-height: 0; flex: 0 0 auto; }
.bri-logo img { height: clamp(30px, 4vw, 42px); width: auto; display: block; }

.bri-chip {
  margin-inline: auto;
  font-family: var(--bri-head);
  font-size: var(--bri-step--1);
  font-weight: 600;
  letter-spacing: .03em;
  color: var(--bri-accent);
  background: color-mix(in srgb, #fff 60%, var(--bri-zone));
  border: 1px solid var(--bri-hairline-2);
  border-radius: var(--bri-cut);
  padding: 5px 12px;
  white-space: nowrap;
}

.bri-nav { flex: 0 0 auto; }
.bri-nav ul {
  list-style: none; display: flex; flex-wrap: nowrap;
  gap: clamp(10px, 1.4vw, 20px); margin: 0; padding: 0;
}
.bri-nav a {
  font-family: var(--bri-head);
  font-size: var(--bri-step--1);
  font-weight: 600;
  color: var(--bri-ink);
  text-decoration: none;
  white-space: nowrap;
  letter-spacing: .01em;
  padding: 4px 0;
  position: relative;
  transition: color var(--bri-t1) var(--bri-ease);
}
.bri-nav a::after {
  content: ''; position: absolute; left: 0; bottom: -2px; height: 2px; width: 100%;
  background: var(--bri-accent);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--bri-t2) var(--bri-ease);
}
.bri-nav a:hover, .bri-nav a[aria-current="page"] { color: var(--bri-accent); }
.bri-nav a:hover::after, .bri-nav a[aria-current="page"]::after { transform: scaleX(1); }

.bri-head__cta { flex: 0 0 auto; }
.bri-head__cta .bri-cta { white-space: nowrap; padding: 9px 16px; font-size: var(--bri-step--1); }

/* burger */
.bri-burger {
  display: none;
  flex-direction: column; gap: 4px;
  background: none; border: 0; cursor: pointer;
  padding: 8px; margin-left: auto; flex: 0 0 auto;
}
.bri-burger span { display: block; height: 2px; background: var(--bri-accent); border-radius: 2px; }
.bri-burger span:nth-child(1) { width: 14px; }
.bri-burger span:nth-child(2) { width: 21px; }
.bri-burger span:nth-child(3) { width: 28px; }

.bri-navtoggle { position: absolute; width: 1px; height: 1px; opacity: 0; overflow: hidden; }
.bri-drawer { display: contents; }

@media (max-width: 980px) {
  .bri-burger { display: flex; }
  .bri-chip { display: none; }
  .bri-head__cta { display: none; }
  .bri-logo { margin-right: auto; }
  .bri-drawer {
    display: block;
    position: fixed; inset: 0; z-index: 70;
    background: var(--bri-zone);
    padding: 64px var(--bri-pad) 32px;
    transform: translateX(100%);
    transition: transform var(--bri-t3) var(--bri-ease);
    visibility: hidden;
  }
  .bri-navtoggle:checked ~ .bri-drawer { transform: translateX(0); visibility: visible; }
  .bri-nav ul { flex-direction: column; flex-wrap: wrap; gap: 6px; align-items: flex-start; }
  .bri-nav a { font-size: var(--bri-step-2); padding: 10px 0; }
  .bri-drawer__close {
    position: absolute; top: 16px; right: var(--bri-pad);
    background: none; border: 0; font-size: 30px; line-height: 1;
    color: var(--bri-accent); cursor: pointer; font-family: var(--bri-head);
  }
  .bri-drawer__foot {
    margin-top: 28px; padding-top: 16px; border-top: 1px solid var(--bri-hairline-2);
    font-size: var(--bri-step--1); color: var(--bri-ink-2);
  }
}
@media (min-width: 981px) {
  .bri-drawer__close, .bri-drawer__foot { display: none; }
}

/* ==========================================================================
   CTA
   ========================================================================== */
.bri-cta {
  display: inline-flex; align-items: center; justify-content: center;
  gap: .5em;
  font-family: var(--bri-head); font-weight: 700;
  font-size: var(--bri-step-0);
  color: var(--bri-accent-ink);
  background: var(--bri-cta);
  border: 0; border-radius: var(--bri-cut);
  padding: 13px 26px;
  text-decoration: none;
  cursor: pointer;
  min-height: 48px;
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 28%, transparent);
  transition: transform var(--bri-t2) var(--bri-ease),
              background-color var(--bri-t2) var(--bri-ease),
              filter var(--bri-t2) var(--bri-ease);
}
.bri-cta:hover { color: #fff; background: var(--bri-cta-strong); transform: scale(1.02); filter: brightness(1.03); }
.bri-cta:active { transform: scale(.99); }
.bri-cta--ghost {
  background: transparent; color: var(--bri-accent);
  box-shadow: inset 0 0 0 1.5px var(--bri-accent);
}
.bri-cta--ghost:hover { background: color-mix(in srgb, var(--bri-accent) 8%, #fff); color: var(--bri-accent); }

@media (prefers-reduced-motion: no-preference) {
  .bri-cta--pulse { animation: bri-pulse .5s var(--bri-ease) 1; }
}
@keyframes bri-pulse { 0%{transform:scale(1)} 50%{transform:scale(1.03)} 100%{transform:scale(1)} }

.bri-ctarow { display: flex; justify-content: center; margin: 1.6rem 0; }

/* ==========================================================================
   BREADCRUMBS
   ========================================================================== */
.bri-crumbs { padding-block: 12px 4px; }
.bri-crumbs ol {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
  font-size: var(--bri-step--1); color: var(--bri-ink-3);
}
.bri-crumbs li { display: inline-flex; align-items: center; gap: 6px; }
.bri-crumbs li:not(:last-child)::after { content: '/'; color: var(--bri-hairline-2); }
.bri-crumbs a { color: var(--bri-ink-2); text-decoration: none; }
.bri-crumbs a:hover { color: var(--bri-accent); }
.bri-crumbs [aria-current="page"] { color: var(--bri-ink-3); }

/* ==========================================================================
   HERO
   ========================================================================== */
.bri-hero { padding-block: clamp(24px, 4vw, 40px); }
.bri-hero__grid {
  display: grid;
  grid-template-columns: 1fr 1.32fr;
  gap: clamp(24px, 4vw, 48px);
  align-items: center;
}
.bri-hero__copy { display: flex; flex-direction: column; gap: 16px; min-width: 0; }
.bri-hero__kicker {
  writing-mode: vertical-rl; transform: rotate(180deg);
  position: absolute; left: -2px; top: 0;
  font-size: var(--bri-step--1); letter-spacing: .22em; text-transform: uppercase;
  color: var(--bri-accent); font-family: var(--bri-head); font-weight: 600;
}
.bri-hero__h1 { font-size: var(--bri-step-3); font-weight: 800; margin: 0; }
.bri-hero__lead { font-size: var(--bri-step-1); color: var(--bri-ink-2); margin: 0; max-width: 46ch; }
.bri-hero__cta { display: flex; gap: 12px; flex-wrap: wrap; }

.bri-hero__media { position: relative; min-width: 0; }
.bri-hero__media::before {
  content: ''; position: absolute; inset: -6% 0; z-index: 0;
  background: radial-gradient(60% 60% at 60% 40%, color-mix(in srgb, var(--bri-accent) 24%, transparent), transparent 70%);
  filter: blur(38px);
}
.bri-hero__img {
  position: relative; z-index: 1;
  width: 100%; max-width: 440px; aspect-ratio: 1 / 1; object-fit: cover;
  margin-inline: auto; display: block;
  border-radius: var(--bri-cut);
  box-shadow: 0 2px 4px color-mix(in srgb, var(--bri-accent) 14%, transparent),
              0 22px 48px -18px color-mix(in srgb, var(--bri-accent) 40%, transparent);
}

/* fascia fatti */
.bri-facts {
  margin-top: clamp(18px, 3vw, 28px);
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px; background: var(--bri-hairline);
  border: 1px solid var(--bri-hairline); border-radius: var(--bri-cut); overflow: hidden;
}
.bri-facts > div { background: var(--bri-surface); padding: 14px 16px; box-shadow: inset 0 1px 0 #fff; }
.bri-facts dt { font-size: var(--bri-step--1); text-transform: uppercase; letter-spacing: .06em; color: var(--bri-ink-3); margin-bottom: 3px; }
.bri-facts dd { margin: 0; font-family: var(--bri-head); font-weight: 700; font-variant-numeric: tabular-nums lining-nums; color: var(--bri-ink); }

/* ==========================================================================
   PAGE TITLE (pagine trust/legal/autore — niente hero promo)
   ========================================================================== */
.bri-ptitle { padding-block: clamp(26px, 4vw, 44px) clamp(12px, 2vw, 20px); border-bottom: 1px solid var(--bri-hairline); }
.bri-ptitle h1 { font-size: var(--bri-step-3); font-weight: 800; }
.bri-ptitle__lead { font-size: var(--bri-step-1); color: var(--bri-ink-2); max-width: 70ch; margin: 0; }

/* ==========================================================================
   BYLINE
   ========================================================================== */
.bri-byline { padding-block: 14px; }
.bri-byline__in { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.bri-byline__ph { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; border: 1px solid var(--bri-hairline-2); }
.bri-byline__meta { font-size: var(--bri-step--1); color: var(--bri-ink-3); line-height: 1.4; }
.bri-byline__meta a { color: var(--bri-ink); font-weight: 700; text-decoration: none; font-family: var(--bri-head); }
.bri-byline__meta a:hover { color: var(--bri-accent); }
.bri-byline__dates { color: var(--bri-ink-3); }

/* ==========================================================================
   PROSA / CONTENUTO
   ========================================================================== */
.bri-main { padding-block: clamp(20px, 3vw, 34px) clamp(34px, 5vw, 60px); }
/* .bri-prose è anche contenitore: molte pagine lo usano senza .bri-wrap */
.bri-prose {
  width: 100%;
  max-width: var(--bri-wrap);
  margin-inline: auto;
  padding-inline: var(--bri-pad);
  padding-block: clamp(20px, 3vw, 32px) clamp(30px, 5vw, 54px);
}
.bri-main > .bri-prose { padding-block: 0; }   /* index: .bri-main fornisce già il padding */
.bri-prose > * { max-width: none; }
.bri-prose h2 { font-size: var(--bri-step-2); font-weight: 700; margin-top: 2.2rem; scroll-margin-top: 84px; position: relative; }
.bri-prose h3 { font-size: var(--bri-step-1); font-weight: 600; margin-top: 1.6rem; }
.bri-prose p, .bri-prose li { font-size: var(--bri-step-0); }
.bri-prose a:not(.bri-cta) {
  color: var(--bri-accent); text-decoration: underline;
  text-decoration-color: color-mix(in srgb, var(--bri-accent) 40%, transparent);
  text-underline-offset: 2px;
}
.bri-prose a:not(.bri-cta):hover { text-decoration-color: var(--bri-accent); }

/* numero sezione + divisore leader */
.bri-sec { margin-top: clamp(28px, 4vw, 40px); }
.bri-sec__head { display: flex; align-items: baseline; gap: 14px; }
.bri-sec__no {
  font-family: var(--bri-head); font-weight: 700; font-variant-numeric: tabular-nums;
  color: var(--bri-accent); font-size: var(--bri-step-1); flex: 0 0 auto;
}
.bri-sec__head h2 { margin: 0; flex: 1 1 auto; }
.bri-sec__lead {
  flex: 0 0 auto; align-self: center;
  border-bottom: 2px dotted var(--bri-hairline-2);
  min-width: 28px; height: 1px;
}
@media (max-width: 640px) { .bri-sec__lead { display: none; } }

/* liste */
.bri-prose ul { list-style: none; padding-left: 0; }
.bri-prose ul li { position: relative; padding-left: 1.5em; margin-bottom: .5em; }
.bri-prose ul li::before {
  content: ''; position: absolute; left: 0; top: .62em;
  width: 8px; height: 8px; background: var(--bri-accent); transform: rotate(45deg);
}
.bri-prose ol { padding-left: 1.4em; }
.bri-prose ol li { margin-bottom: .5em; }

/* immagine contenuto */
.bri-figure {
  width: min(72%, 760px); margin: 1.6rem auto; display: block;
}
.bri-figure img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: var(--bri-cut); display: block; }
.bri-figure figcaption { font-size: var(--bri-step--1); color: var(--bri-ink-3); margin-top: 8px; text-align: center; }
@media (max-width: 640px) { .bri-figure { width: 100%; } }

/* callout */
.bri-note {
  background: var(--bri-surface); border-left: 3px solid var(--bri-accent);
  border-radius: 0 var(--bri-r-sm) var(--bri-r-sm) 0;
  padding: 16px 18px; margin: 1.4rem 0;
  box-shadow: inset 0 1px 0 #fff;
}
.bri-note strong { font-family: var(--bri-head); }

/* ==========================================================================
   TABELLE  (anche <table> nuda)
   ========================================================================== */
.bri-tablewrap { overflow-x: auto; margin: 1.4rem 0; }
.bri-prose table, table:not(.bri-bare) {
  width: 100%; border-collapse: collapse;
  font-size: var(--bri-step--1);
  border: 1px solid var(--bri-hairline);
  border-radius: var(--bri-cut); overflow: hidden;
}
.bri-prose caption, table caption { caption-side: top; text-align: left; font-size: var(--bri-step--1); color: var(--bri-ink-3); margin-bottom: 6px; }
.bri-prose th, .bri-prose td, table:not(.bri-bare) th, table:not(.bri-bare) td {
  padding: 11px 14px; text-align: left; border-bottom: 1px solid var(--bri-hairline);
  font-variant-numeric: tabular-nums lining-nums;
}
.bri-prose thead th, table:not(.bri-bare) thead th {
  background: var(--bri-surface-2); font-family: var(--bri-head); font-weight: 700; color: var(--bri-ink);
}
.bri-prose tbody td:first-child, table:not(.bri-bare) tbody td:first-child { font-weight: 700; }
.bri-prose tbody tr:hover, table:not(.bri-bare) tbody tr:hover { background: color-mix(in srgb, var(--bri-accent) 4%, transparent); }
.bri-prose tbody tr:last-child td, table:not(.bri-bare) tbody tr:last-child td { border-bottom: 0; }

/* ==========================================================================
   FAQ / DETAILS  (anche <details> nudo)
   ========================================================================== */
.bri-faq { margin-top: clamp(28px, 4vw, 40px); }
.bri-faq details, details {
  border-top: 1px solid var(--bri-hairline);
  background: transparent;
}
.bri-faq details:last-of-type { border-bottom: 1px solid var(--bri-hairline); }
.bri-faq summary, details > summary {
  list-style: none; cursor: pointer;
  display: flex; align-items: center; gap: 12px;
  padding: 16px 4px;
  font-family: var(--bri-head); font-weight: 600; font-size: var(--bri-step-0);
  color: var(--bri-ink);
}
summary::-webkit-details-marker { display: none; }
.bri-faq summary::before, details > summary::before {
  content: '+'; flex: 0 0 auto;
  font-family: var(--bri-head); font-weight: 700; font-size: 1.2em;
  color: var(--bri-accent); width: 1em; text-align: center;
}
.bri-faq details[open] summary::before, details[open] > summary::before { content: '−'; }
.bri-faq__a, details > .bri-faq__a { padding: 0 4px 16px 26px; color: var(--bri-ink-2); }
.bri-faq__a > :last-child { margin-bottom: 0; }

/* ==========================================================================
   TOC
   ========================================================================== */
.bri-toc {
  margin: 1.4rem 0; border: 1px solid var(--bri-hairline);
  border-radius: var(--bri-cut); background: var(--bri-surface);
}
.bri-toc > summary {
  list-style: none; cursor: pointer; padding: 12px 16px;
  font-family: var(--bri-head); font-weight: 700; color: var(--bri-ink);
  display: flex; align-items: center; gap: 10px;
}
.bri-toc > summary::before { content: '☰'; color: var(--bri-accent); }
.bri-toclist { list-style: none; margin: 0; padding: 0 16px 14px 16px; counter-reset: toc; }
.bri-toclist li { counter-increment: toc; margin: 4px 0; }
.bri-toclist li::before { content: counter(toc, decimal-leading-zero) '  '; color: var(--bri-accent); font-variant-numeric: tabular-nums; font-family: var(--bri-head); }
.bri-toclist a { color: var(--bri-ink-2); text-decoration: none; }
.bri-toclist a:hover { color: var(--bri-accent); }

/* ==========================================================================
   SLOTS
   ========================================================================== */
.bri-slots { padding-block: clamp(24px, 4vw, 38px); }
.bri-slots__head { display: flex; align-items: end; justify-content: space-between; gap: 16px; margin-bottom: 18px; flex-wrap: wrap; }
.bri-slots__head h2 { font-size: var(--bri-step-2); font-weight: 700; margin: 0; }
.bri-slots__intro { color: var(--bri-ink-2); margin: .4rem 0 0; max-width: 60ch; }
.bri-slots__all { font-family: var(--bri-head); font-weight: 600; white-space: nowrap; text-decoration: none; color: var(--bri-accent); }
.bri-slots__grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
.bri-slot {
  display: block; text-decoration: none; color: inherit;
  border: 1px solid var(--bri-hairline); border-radius: var(--bri-cut);
  background: var(--bri-surface); overflow: hidden;
  box-shadow: inset 0 1px 0 #fff;
  transition: transform var(--bri-t2) var(--bri-ease), border-color var(--bri-t2) var(--bri-ease);
}
.bri-slot:hover { transform: translateY(-3px); border-color: var(--bri-accent); }
.bri-slot img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; }
.bri-slot span {
  display: block; padding: 8px 10px; font-size: var(--bri-step--1);
  font-family: var(--bri-head); font-weight: 600; text-align: center;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
@media (max-width: 1024px) { .bri-slots__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (max-width: 640px)  { .bri-slots__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

/* ==========================================================================
   RIGA "CONTINUA" / link correlati editoriali
   ========================================================================== */
.bri-related {
  max-width: var(--bri-wrap); margin: clamp(20px, 3vw, 30px) auto 0;
  padding: 14px 18px;
  border-top: 1px solid var(--bri-hairline);
  font-size: var(--bri-step-0); color: var(--bri-ink-2);
}
.bri-related span { font-family: var(--bri-head); font-weight: 600; color: var(--bri-ink); }
.bri-related a { color: var(--bri-accent); text-decoration: underline; text-underline-offset: 2px; }
.bri-related a:hover { text-decoration-color: var(--bri-accent); }

/* ==========================================================================
   CARD AUTORE (in fondo all'articolo)
   ========================================================================== */
.bri-author {
  margin: clamp(28px, 4vw, 40px) auto 0; max-width: 760px;
  display: flex; gap: 18px; align-items: flex-start;
  background: var(--bri-surface); border: 1px solid var(--bri-hairline);
  border-radius: var(--bri-cut); padding: 22px;
  box-shadow: inset 0 1px 0 #fff;
}
.bri-author__ph { width: 96px; height: 96px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; border: 1px solid var(--bri-hairline-2); }
.bri-author__name { font-family: var(--bri-head); font-weight: 700; font-size: var(--bri-step-1); margin: 0; }
.bri-author__name a { color: var(--bri-ink); text-decoration: none; }
.bri-author__name a:hover { color: var(--bri-accent); }
.bri-author__role { font-size: var(--bri-step--1); color: var(--bri-accent); text-transform: uppercase; letter-spacing: .05em; margin: 2px 0 8px; font-family: var(--bri-head); font-weight: 600; }
.bri-author__bio { font-size: var(--bri-step--1); color: var(--bri-ink-2); margin: 0 0 8px; }
.bri-author__more { font-size: var(--bri-step--1); font-family: var(--bri-head); font-weight: 600; text-decoration: none; }
@media (max-width: 560px) { .bri-author { flex-direction: column; align-items: center; text-align: center; } }

/* pagina autore (ProfilePage) */
.bri-profile { padding-block: clamp(20px, 3vw, 34px) clamp(34px, 5vw, 60px); }
.bri-profile__head { display: flex; gap: 22px; align-items: center; flex-wrap: wrap; margin-bottom: 18px; }
.bri-prose img.bri-profile__ph, .bri-profile__ph { width: 220px; aspect-ratio: 3 / 4; object-fit: cover; border-radius: var(--bri-cut); flex: 0 0 auto; }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.bri-foot {
  background: var(--bri-zone); border-top: 1px solid var(--bri-hairline-2);
  margin-top: clamp(34px, 5vw, 60px);
}
.bri-foot__grid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 28px;
  padding-block: clamp(28px, 4vw, 44px);
}
.bri-foot h4 { font-family: var(--bri-head); font-size: var(--bri-step-0); margin: 0 0 12px; color: var(--bri-accent); text-transform: uppercase; letter-spacing: .06em; }
.bri-foot ul { list-style: none; margin: 0; padding: 0; }
.bri-foot li { margin-bottom: 7px; }
.bri-foot a { color: var(--bri-ink-2); text-decoration: none; font-size: var(--bri-step--1); }
.bri-foot a:hover { color: var(--bri-accent); }
.bri-foot__logo img { height: 38px; width: auto; margin-bottom: 10px; }
.bri-foot__rg { font-size: var(--bri-step--1); color: var(--bri-ink-2); }
.bri-foot__rg a { display: inline; }
.bri-foot__bottom {
  border-top: 1px solid var(--bri-hairline-2); padding-block: 16px;
  font-size: var(--bri-step--1); color: var(--bri-ink-3);
  display: flex; flex-wrap: wrap; gap: 10px 18px; align-items: center; justify-content: space-between;
}
.bri-foot__age {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 30px; height: 22px; padding: 0 6px;
  border: 1.5px solid var(--bri-accent); border-radius: 5px;
  color: var(--bri-accent); font-family: var(--bri-head); font-weight: 700; font-size: .72rem;
}
@media (max-width: 760px) { .bri-foot__grid { grid-template-columns: 1fr; gap: 22px; } }

/* ==========================================================================
   COOKIE
   ========================================================================== */
.bri-cookie {
  position: fixed; right: 16px; bottom: 16px; z-index: 90;
  max-width: 360px; width: calc(100vw - 32px);
  background: #fff; border: 1px solid var(--bri-hairline-2);
  border-radius: var(--bri-cut); padding: 18px;
  box-shadow: 0 18px 48px -22px color-mix(in srgb, var(--bri-accent) 50%, transparent);
}
.bri-cookie[hidden] { display: none; }
.bri-cookie p { font-size: var(--bri-step--1); color: var(--bri-ink-2); margin: 0 0 12px; }
.bri-cookie__row { display: flex; gap: 10px; flex-wrap: wrap; }
.bri-cookie button {
  font-family: var(--bri-head); font-weight: 600; font-size: var(--bri-step--1);
  border-radius: var(--bri-r-sm); padding: 9px 14px; cursor: pointer; border: 1px solid var(--bri-accent);
  min-height: 40px;
}
.bri-cookie__ok { background: var(--bri-accent); color: #fff; }
.bri-cookie__min { background: transparent; color: var(--bri-accent); }

/* ==========================================================================
   HERO MOBILE  +  RESPONSIVE GENERALE
   ========================================================================== */
@media (max-width: 860px) {
  .bri-hero__grid { grid-template-columns: 1fr; gap: 18px; }
  .bri-hero__copy { order: 1; align-items: center; text-align: center; }
  .bri-hero__kicker { position: static; writing-mode: horizontal-tb; transform: none; }
  .bri-hero__lead { margin-inline: auto; }
  .bri-hero__cta { justify-content: center; order: 3; }
  .bri-hero__media { order: 2; }
  .bri-facts { grid-template-columns: repeat(2, minmax(0, 1fr)); order: 4; }
}
@media (max-width: 640px) {
  .bri-hero__img { max-height: 42vh; width: auto; aspect-ratio: 1 / 1; object-fit: contain; }
}

/* riduzione movimento globale */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
}
