/* ==========================================================================
   Winnita — foglio di stile completo (prefisso .ikr-)
   Archetipo MANUSCRIPT: carta-inchiostro, serif old-style + mono da macchina
   per scrivere, niente ombre, divisori a caratteri mono, sottolineatura accento.
   ========================================================================== */

:root {
  /* Superfici (tè caldo: avena -> umbra) */
  --ikr-bg:        #f4ecdd;
  --ikr-surface:   #faf3e6;
  --ikr-surface-2: #ece1cc;
  --ikr-hairline:  color-mix(in srgb, #2b2117 16%, transparent);
  --ikr-hairline-2:color-mix(in srgb, #2b2117 9%, transparent);

  /* Inchiostro */
  --ikr-ink:   #2b2117;
  --ikr-ink-2: #5a4d3c;
  --ikr-ink-3: #6f6048;

  /* Accento: mattone-ruggine, dosato */
  --ikr-accent:    #a8472a;
  --ikr-accent-2:  #8f3a20;
  --ikr-accent-sel:color-mix(in srgb, #a8472a 22%, var(--ikr-surface));

  /* Tipografia */
  --ikr-serif: "Source Serif 4", Georgia, "Times New Roman", serif;
  --ikr-mono:  "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;

  /* Scala modulare 1.25 */
  --ikr-step--1: 0.8rem;
  --ikr-step-0:  1rem;
  --ikr-step-1:  1.25rem;
  --ikr-step-2:  1.5625rem;
  --ikr-step-3:  1.953rem;
  --ikr-step-4:  2.441rem;
  --ikr-step-5:  3.052rem;

  /* Ritmo (compatto) */
  --ikr-s1: 4px;
  --ikr-s2: 8px;
  --ikr-s3: 12px;
  --ikr-s4: 16px;
  --ikr-s5: 22px;
  --ikr-s6: 30px;
  --ikr-s7: 42px;

  /* Forma (manuscript = quasi spigolo) */
  --ikr-r-sm: 2px;
  --ikr-r-md: 4px;

  --ikr-wrap: 1232px;
  --ikr-pad: clamp(16px, 4vw, 30px);
}

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; overflow-x: clip; }

body {
  margin: 0;
  background: var(--ikr-bg);
  color: var(--ikr-ink);
  font-family: var(--ikr-serif);
  font-size: 1.0625rem;
  line-height: 1.62;
  font-variant-numeric: tabular-nums lining-nums;
  -webkit-font-smoothing: antialiased;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas: "head" "bc" "hero" "by" "main" "foot";
}

::selection { background: var(--ikr-accent-sel); color: var(--ikr-ink); }

img { max-width: 100%; height: auto; display: block; }

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

:focus-visible { outline: 2px solid var(--ikr-accent); outline-offset: 2px; }

h1, h2, h3, h4 { font-family: var(--ikr-serif); line-height: 1.12; font-weight: 700; letter-spacing: -0.012em; color: var(--ikr-ink); text-wrap: balance; }
p { text-wrap: pretty; }

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

/* ----------------------------- Testata --------------------------------- */
.ikr-head {
  grid-area: head;
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--ikr-bg) 92%, transparent);
  backdrop-filter: saturate(1.1);
  border-bottom: 1px solid var(--ikr-hairline);
}
.ikr-head__row {
  display: flex;
  align-items: center;
  gap: var(--ikr-s4);
  min-height: 60px;
}
.ikr-logo {
  font-family: var(--ikr-mono);
  font-weight: 700;
  font-size: 1.18rem;
  letter-spacing: 0.02em;
  color: var(--ikr-ink);
  text-decoration: none;
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  white-space: nowrap;
}
.ikr-logo b { color: var(--ikr-accent); font-weight: 700; }
.ikr-logo i { font-style: normal; color: var(--ikr-ink-3); font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; margin-left: 6px; }

.ikr-nav { margin-left: auto; }
.ikr-nav__list {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  align-items: center;
  gap: 11px;
  flex-wrap: nowrap;
  justify-content: flex-end;
}
.ikr-nav__list a {
  font-family: var(--ikr-mono);
  font-size: 0.75rem;
  letter-spacing: 0.02em;
  color: var(--ikr-ink-2);
  text-decoration: none;
  padding: 4px 2px;
  white-space: nowrap;
  box-shadow: inset 0 0 0 0 var(--ikr-accent);
}
.ikr-nav__list a:hover { color: var(--ikr-ink); }
.ikr-nav__list a[aria-current="page"] {
  color: var(--ikr-ink);
  box-shadow: inset 0 -2px 0 0 var(--ikr-accent);
}
.ikr-head .ikr-cta { margin-left: var(--ikr-s2); padding: 8px 14px; font-size: 0.8rem; white-space: nowrap; flex: none; }
/* Узкий десктоп (901-1200px): ужимаем шапку, чтобы меню оставалось в ОДИН ряд без бокового overflow (ниже 900px — бургер) */
@media (min-width:901px) and (max-width:1200px){
  .ikr-nav__list{gap:7px}
  .ikr-nav__list a{font-size:.72rem;padding:4px 1px}
  .ikr-head .ikr-cta{padding:8px 11px;font-size:.76rem}
}

/* Burger (coppia display:none + media query, inseparabili) */
.ikr-burger {
  display: none;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  background: none;
  border: 1px solid var(--ikr-hairline);
  border-radius: var(--ikr-r-sm);
  padding: 8px 10px;
  font-family: var(--ikr-mono);
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  color: var(--ikr-ink);
  cursor: pointer;
  min-height: 44px;
}
.ikr-burger svg { width: 18px; height: 18px; }
@media (max-width: 900px) {
  .ikr-burger { display: inline-flex; }
  .ikr-head .ikr-cta { display: none; }
}

/* Drawer mobile */
.ikr-drawer {
  position: fixed;
  inset: 0 0 0 auto;
  width: min(86vw, 340px);
  background: var(--ikr-surface);
  border-left: 1px solid var(--ikr-hairline);
  transform: translateX(100%);
  transition: transform .18s ease;
  z-index: 60;
  padding: var(--ikr-s5);
  overflow-y: auto;
}
.ikr-drawer.is-open { transform: translateX(0); }
.ikr-drawer__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--ikr-s4); }
.ikr-drawer__age { font-family: var(--ikr-mono); font-size: 0.68rem; letter-spacing: 0.1em; color: var(--ikr-ink-3); text-transform: uppercase; }
.ikr-drawer__close { background: none; border: none; font-size: 1.4rem; line-height: 1; color: var(--ikr-ink); cursor: pointer; padding: 4px 8px; }
.ikr-drawer ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.ikr-drawer li { border-top: 1px solid var(--ikr-hairline-2); }
.ikr-drawer a { display: block; padding: 14px 6px; font-family: var(--ikr-mono); font-size: 0.92rem; color: var(--ikr-ink); text-decoration: none; }
.ikr-drawer .ikr-cta { margin-top: var(--ikr-s4); width: 100%; text-align: center; }
.ikr-scrim {
  position: fixed; inset: 0; background: rgba(20,14,8,.42);
  opacity: 0; visibility: hidden; transition: opacity .18s ease, visibility .18s ease;
  z-index: 55;
}
.ikr-scrim.is-open { opacity: 1; visibility: visible; }

/* ----------------------------- Breadcrumbs ----------------------------- */
.ikr-bc { grid-area: bc; padding-top: var(--ikr-s4); }
.ikr-bc ol {
  list-style: none; margin-block: 0; margin-inline: auto; padding-block: 0; padding-inline: var(--ikr-pad);
  display: flex; flex-wrap: wrap; align-items: center;
  font-family: var(--ikr-mono); font-size: 0.72rem; color: var(--ikr-ink-3);
  letter-spacing: 0.02em;
}
.ikr-bc li { display: inline-flex; align-items: center; }
.ikr-bc li + li::before { content: "/"; margin: 0 8px; color: var(--ikr-ink-3); }
.ikr-bc a { color: var(--ikr-ink-2); text-decoration: none; }
.ikr-bc a:hover { color: var(--ikr-accent); }
.ikr-bc [aria-current="page"] { color: var(--ikr-ink); }

/* Indice di pagina (TOC) — навигация по секциям (генерится JS) */
.ikr-toc { margin: 0 0 var(--ikr-s5); padding: var(--ikr-s4) var(--ikr-s5); background: var(--ikr-surface); border: 1px solid var(--ikr-hairline); border-radius: var(--ikr-r-md); }
.ikr-toc__t { margin: 0 0 var(--ikr-s3); font-family: var(--ikr-mono); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ikr-ink-3); }
.ikr-toc ol { margin: 0; padding: 0; list-style: none; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px var(--ikr-s5); counter-reset: toc; }
.ikr-toc li { counter-increment: toc; min-width: 0; }
.ikr-toc a { display: flex; gap: 9px; align-items: baseline; color: var(--ikr-ink-2); text-decoration: none; font-size: .92rem; line-height: 1.35; }
.ikr-toc a::before { content: counter(toc, decimal-leading-zero); font-family: var(--ikr-mono); font-size: .72rem; color: var(--ikr-accent); flex: none; }
.ikr-toc a:hover { color: var(--ikr-accent); }
.ikr-main h2 { scroll-margin-top: 78px; }
@media (max-width: 640px) { .ikr-toc ol { grid-template-columns: minmax(0, 1fr); } }

/* ----------------------------- Byline ---------------------------------- */
.ikr-byline { grid-area: by; padding-top: var(--ikr-s4); }
.ikr-byline__in {
  display: flex; align-items: center; gap: var(--ikr-s3);
  padding: var(--ikr-s3) 0;
  border-top: 1px solid var(--ikr-hairline-2);
  border-bottom: 1px solid var(--ikr-hairline-2);
  flex-wrap: wrap;
}
.ikr-byline img {
  width: 46px; height: 46px; border-radius: 50%;
  object-fit: cover; flex: none;
  border: 1px solid var(--ikr-hairline);
}
.ikr-byline__meta { font-size: 0.9rem; line-height: 1.35; }
.ikr-byline__meta a { font-family: var(--ikr-serif); font-weight: 700; text-decoration: none; }
.ikr-byline__role { color: var(--ikr-ink-3); font-family: var(--ikr-mono); font-size: 0.72rem; letter-spacing: 0.02em; }
.ikr-byline__date { margin-left: auto; font-family: var(--ikr-mono); font-size: 0.72rem; color: var(--ikr-ink-3); }

/* ----------------------------- Main ------------------------------------ */
.ikr-main {
  grid-area: main;
  container-type: inline-size;
  container-name: ikrmain;
  padding-block: var(--ikr-s5) var(--ikr-s6);
}

/* ----------------------------- Hero ------------------------------------ */
.ikr-hero { grid-area: hero; padding-block: var(--ikr-s5) var(--ikr-s4); }
/* Заголовок простой (не-money) страницы — без промо-hero; тот же grid-area, что hero */
.ikr-ptitle { grid-area: hero; padding-block: var(--ikr-s5) 0; }
.ikr-ptitle__kicker { display: block; font-family: var(--ikr-mono); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ikr-accent); margin-bottom: var(--ikr-s2); }
.ikr-ptitle__h1 { margin: 0; font-size: clamp(1.8rem, 1.1rem + 2.6vw, 2.6rem); line-height: 1.1; font-weight: 700; letter-spacing: -.012em; }
.ikr-ptitle__lead { margin: var(--ikr-s3) 0 0; color: var(--ikr-ink-2); font-size: 1.15rem; line-height: 1.5; max-width: 62ch; }
.ikr-hero__grid {
  display: grid;
  gap: var(--ikr-s4) var(--ikr-s6);
  grid-template-columns: minmax(0, 1.02fr) minmax(0, 1fr);
  grid-template-areas:
    "img  head"
    "img  lead"
    "img  cta"
    "facts facts";
  align-items: start;
}
.ikr-hero__fig {
  grid-area: img;
  position: relative;
  margin: 0;
}
.ikr-hero__fig::before {           /* alone d'accento dietro l'immagine */
  content: "";
  position: absolute;
  inset: -8% 0 -10% 0;
  background: radial-gradient(60% 55% at 50% 45%, color-mix(in srgb, var(--ikr-accent) 24%, transparent), transparent 70%);
  filter: blur(26px);
  z-index: 0;
  pointer-events: none;
}
.ikr-hero__img {
  position: relative;
  z-index: 1;
  width: 100%;
  aspect-ratio: 1 / 1;
  max-height: 430px;
  width: auto;
  margin-inline: auto;
  object-fit: cover;
  border-radius: var(--ikr-r-md);
  border: 1px solid var(--ikr-hairline);
}
.ikr-hero__head { grid-area: head; }
.ikr-hero__kicker {
  display: block;
  font-family: var(--ikr-mono);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ikr-accent);
  margin-bottom: var(--ikr-s2);
}
.ikr-hero__h1 {
  margin: 0;
  font-size: clamp(1.9rem, 1.2rem + 3vw, 3rem);
  line-height: 1.08;
}
.ikr-hero__lead {
  grid-area: lead;
  margin: 0;
  color: var(--ikr-ink-2);
  font-size: var(--ikr-step-1);
  line-height: 1.5;
  max-width: 46ch;
}
.ikr-hero__cta { grid-area: cta; display: flex; align-items: flex-start; }
.ikr-hero__facts {
  grid-area: facts;
  margin-top: var(--ikr-s3);
  background: var(--ikr-surface);
  border: 1px solid var(--ikr-hairline);
  border-radius: var(--ikr-r-md);
  padding: var(--ikr-s4) var(--ikr-s5);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--ikr-s3) var(--ikr-s5);
}
.ikr-fact { display: flex; flex-direction: column; gap: 2px; }
.ikr-fact dt { font-family: var(--ikr-mono); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ikr-ink-3); margin: 0; }
.ikr-fact dd { margin: 0; font-weight: 600; font-size: 0.98rem; }

@media (max-width: 860px) {
  .ikr-hero__grid {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas: "img" "head" "cta" "lead" "facts";
    gap: var(--ikr-s4);
  }
  .ikr-hero__img { max-height: 42vh; }
  .ikr-hero__cta { justify-content: center; }
  .ikr-hero__lead { max-width: none; }
  .ikr-hero__facts { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ----------------------------- CTA ------------------------------------- */
.ikr-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--ikr-mono);
  font-weight: 600;
  font-size: 0.92rem;
  letter-spacing: 0.01em;
  line-height: 1;
  min-height: 48px;
  padding: 14px 22px;
  color: #fbf3e8;
  background: var(--ikr-accent);
  border: 1px solid var(--ikr-accent-2);
  border-radius: var(--ikr-r-md);
  text-decoration: none;
  cursor: pointer;
  transition: background-color .15s ease, transform .12s ease, border-color .15s ease;
}
.ikr-cta:hover { background: var(--ikr-accent-2); color: #fff; }
.ikr-cta:active { transform: translateY(1px); }
.ikr-ctarow { display: flex; justify-content: center; margin: var(--ikr-s5) 0; }

/* ----------------------------- Prosa ----------------------------------- */
.ikr-prose { padding-block: var(--ikr-s4); }
.ikr-prose > * { max-width: none; }
.ikr-prose h2 {
  font-size: clamp(1.45rem, 1.1rem + 1.4vw, var(--ikr-step-3));
  margin: var(--ikr-s7) 0 var(--ikr-s3);
  padding-left: var(--ikr-s4);
  border-left: 3px solid var(--ikr-accent);
}
.ikr-prose h3 {
  font-size: var(--ikr-step-1);
  margin: var(--ikr-s5) 0 var(--ikr-s2);
}
.ikr-prose p { margin: 0 0 var(--ikr-s4); }
.ikr-prose a:not(.ikr-cta) { color: var(--ikr-accent); font-weight: 600; }
.ikr-prose a:not(.ikr-cta):hover { color: var(--ikr-accent-2); }
.ikr-prose ul, .ikr-prose ol { margin: 0 0 var(--ikr-s4); padding-left: 1.3em; }
.ikr-prose li { margin-bottom: var(--ikr-s2); }
.ikr-prose strong { font-weight: 700; }
.ikr-prose sup { font-family: var(--ikr-mono); font-size: 0.62em; color: var(--ikr-accent); }

/* kicker di sezione (numero mono) */
.ikr-kick {
  font-family: var(--ikr-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ikr-ink-3);
  display: block;
  margin-bottom: var(--ikr-s2);
}

/* divisore a caratteri mono */
.ikr-rule {
  font-family: var(--ikr-mono);
  color: var(--ikr-ink-3);
  letter-spacing: 0.5em;
  text-align: center;
  margin: var(--ikr-s6) 0;
  font-size: 0.8rem;
  user-select: none;
}
.ikr-rule::before { content: "·  ·  ·  ·  ·  ·  ·  ·"; }

/* tag mono verdetto */
.ikr-tag {
  display: inline-block;
  font-family: var(--ikr-mono);
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ikr-accent);
  border: 1px solid var(--ikr-accent);
  border-radius: var(--ikr-r-sm);
  padding: 2px 7px;
  margin-right: 6px;
}

/* TL;DR / callout */
.ikr-tldr {
  background: var(--ikr-surface);
  border: 1px solid var(--ikr-hairline);
  border-left: 3px solid var(--ikr-accent);
  border-radius: var(--ikr-r-md);
  padding: var(--ikr-s4) var(--ikr-s5);
  margin: var(--ikr-s4) 0 var(--ikr-s6);
}
.ikr-tldr h2 { border: none; padding: 0; margin: 0 0 var(--ikr-s2); font-size: var(--ikr-step-1); }
.ikr-tldr ul { list-style: none; margin: 0; padding: 0; }
.ikr-tldr li { position: relative; padding-left: 1.5em; margin-bottom: var(--ikr-s2); }
.ikr-tldr li::before { content: "—"; position: absolute; left: 0; color: var(--ikr-accent); font-family: var(--ikr-mono); }

/* rating pill */
.ikr-rating {
  display: inline-flex; align-items: baseline; gap: 6px;
  font-family: var(--ikr-mono); font-weight: 600;
  background: var(--ikr-surface-2); color: var(--ikr-ink);
  border: 1px solid var(--ikr-hairline);
  border-radius: 999px;
  padding: 3px 12px; font-size: 0.82rem;
}
.ikr-rating b { font-size: 0.98rem; color: var(--ikr-accent); }

/* chips di vantaggi */
.ikr-chips { list-style: none; margin: var(--ikr-s3) 0 var(--ikr-s5); padding: 0; display: flex; flex-wrap: wrap; gap: var(--ikr-s2); }
.ikr-chips li {
  font-family: var(--ikr-mono); font-size: 0.78rem;
  background: var(--ikr-surface); border: 1px solid var(--ikr-hairline);
  border-radius: var(--ikr-r-sm); padding: 6px 12px; margin: 0;
}
.ikr-chips li::before { content: "+ "; color: var(--ikr-accent); }
.ikr-chips--con li::before { content: "− "; color: var(--ikr-ink-3); }

/* ----------------------------- Tabelle --------------------------------- */
.ikr-tablewrap { overflow-x: auto; margin: var(--ikr-s4) 0 var(--ikr-s6); -webkit-overflow-scrolling: touch; }
table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.96rem;
  background: var(--ikr-surface);
  border: 1px solid var(--ikr-hairline);
  border-radius: var(--ikr-r-md);
  overflow: hidden;
}
table caption { text-align: left; font-family: var(--ikr-mono); font-size: 0.72rem; letter-spacing: 0.06em; color: var(--ikr-ink-3); text-transform: uppercase; padding: 0 0 var(--ikr-s2); }
th, td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--ikr-hairline-2); vertical-align: top; }
thead th { background: var(--ikr-surface-2); font-family: var(--ikr-mono); font-size: 0.72rem; letter-spacing: 0.05em; text-transform: uppercase; color: var(--ikr-ink-2); }
tbody tr:last-child td { border-bottom: none; }
tbody tr:hover td { background: color-mix(in srgb, var(--ikr-accent) 5%, var(--ikr-surface)); }
td:first-child, th:first-child { font-weight: 600; }
td + td, th + th { font-variant-numeric: tabular-nums; }

/* ----------------------------- FAQ / details --------------------------- */
.ikr-faq { margin: var(--ikr-s4) 0 var(--ikr-s6); }
details {
  border-top: 1px solid var(--ikr-hairline);
  background: transparent;
}
details:last-of-type { border-bottom: 1px solid var(--ikr-hairline); }
details > summary {
  list-style: none;
  cursor: pointer;
  padding: var(--ikr-s4) 32px var(--ikr-s4) 28px;
  position: relative;
  font-family: var(--ikr-serif);
  font-weight: 700;
  font-size: 1.02rem;
}
details > summary::-webkit-details-marker { display: none; }
details > summary::before {
  content: "▸";
  position: absolute; left: 4px; top: 50%; transform: translateY(-50%);
  color: var(--ikr-accent);
  transition: transform .15s ease;
}
details[open] > summary::before { transform: translateY(-50%) rotate(90deg); }
details > div, details > p { padding: 0 28px var(--ikr-s4); margin: 0; color: var(--ikr-ink-2); }

/* ----------------------------- Figure contenuto ------------------------ */
.ikr-figure {
  width: min(70%, 760px);
  margin: var(--ikr-s5) auto;
}
.ikr-figure img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: var(--ikr-r-md);
  border: 1px solid var(--ikr-hairline);
}
.ikr-figure figcaption { font-family: var(--ikr-mono); font-size: 0.72rem; color: var(--ikr-ink-3); margin-top: var(--ikr-s2); text-align: center; }
@media (max-width: 640px) { .ikr-figure { width: 100%; } }

/* ----------------------------- Slot grid ------------------------------- */
.ikr-slots { padding-block: var(--ikr-s5); }
.ikr-slots__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--ikr-s3); flex-wrap: wrap; margin-bottom: var(--ikr-s4); }
.ikr-slots__head h2 { font-size: var(--ikr-step-2); margin: 0; padding-left: var(--ikr-s3); border-left: 3px solid var(--ikr-accent); }
.ikr-slots__all { font-family: var(--ikr-mono); font-size: 0.78rem; text-decoration: none; }
.ikr-slots__grid {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: var(--ikr-s3);
}
.ikr-slot {
  display: block;
  color: inherit;
  text-decoration: none;
  border: 1px solid var(--ikr-hairline);
  border-radius: var(--ikr-r-md);
  overflow: hidden;
  background: var(--ikr-surface);
  transition: border-color .15s ease, transform .12s ease;
}
.ikr-slot:hover { border-color: var(--ikr-accent); transform: translateY(-2px); }
.ikr-slot img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; }
.ikr-slot span { display: block; font-family: var(--ikr-mono); font-size: 0.68rem; padding: 6px 7px; color: var(--ikr-ink-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
@media (max-width: 1080px) { .ikr-slots__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (max-width: 560px)  { .ikr-slots__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

/* ----------------------------- Card autore ----------------------------- */
.ikr-author {
  display: flex;
  gap: var(--ikr-s4);
  align-items: flex-start;
  background: var(--ikr-surface);
  border: 1px solid var(--ikr-hairline);
  border-radius: var(--ikr-r-md);
  padding: var(--ikr-s5);
  margin: var(--ikr-s6) auto;
  max-width: 820px;
}
.ikr-author img { width: 100px; height: 100px; border-radius: 50%; object-fit: cover; flex: none; border: 1px solid var(--ikr-hairline); aspect-ratio: auto; }
.ikr-author__name { font-weight: 700; font-size: var(--ikr-step-1); text-decoration: none; }
.ikr-author__role { font-family: var(--ikr-mono); font-size: 0.72rem; letter-spacing: 0.02em; color: var(--ikr-ink-3); margin: 2px 0 var(--ikr-s2); }
.ikr-author__bio { margin: 0 0 var(--ikr-s2); color: var(--ikr-ink-2); font-size: 0.96rem; }
.ikr-author__more { font-family: var(--ikr-mono); font-size: 0.76rem; text-decoration: none; }
.ikr-author__rev { font-family: var(--ikr-mono); font-size: 0.72rem; color: var(--ikr-ink-3); margin-top: var(--ikr-s2); }
@media (max-width: 560px) { .ikr-author { flex-direction: column; } }

/* ritratto pagina autore */
.ikr-prose img.ikr-portrait { width: 220px; height: auto; aspect-ratio: 3 / 4; object-fit: cover; float: left; margin: 0 var(--ikr-s5) var(--ikr-s3) 0; border-radius: var(--ikr-r-md); border: 1px solid var(--ikr-hairline); }

/* disclaimer */
.ikr-disclaim {
  font-size: 0.84rem;
  color: var(--ikr-ink-3);
  border-top: 1px solid var(--ikr-hairline);
  padding-top: var(--ikr-s4);
  margin-top: var(--ikr-s6);
}

/* ----------------------------- Footer ---------------------------------- */
.ikr-foot {
  grid-area: foot;
  background: var(--ikr-surface);
  border-top: 1px solid var(--ikr-hairline);
  padding-block: var(--ikr-s6) var(--ikr-s5);
  margin-top: var(--ikr-s6);
}
.ikr-foot__brand { font-family: var(--ikr-mono); font-weight: 700; font-size: 1.1rem; color: var(--ikr-ink); }
.ikr-foot__note { color: var(--ikr-ink-2); font-size: 0.9rem; margin: var(--ikr-s3) 0; max-width: 60ch; }
.ikr-foot__cols { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--ikr-s5); margin-top: var(--ikr-s5); }
.ikr-foot h3 { font-family: var(--ikr-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ikr-ink-3); margin: 0 0 var(--ikr-s3); }
.ikr-foot ul { list-style: none; margin: 0; padding: 0; }
.ikr-foot li { margin-bottom: var(--ikr-s2); }
.ikr-foot a { color: var(--ikr-ink-2); text-decoration: none; font-size: 0.9rem; }
.ikr-foot a:hover { color: var(--ikr-accent); }
.ikr-foot__legal { border-top: 1px solid var(--ikr-hairline-2); margin-top: var(--ikr-s5); padding-top: var(--ikr-s4); font-size: 0.78rem; color: var(--ikr-ink-3); display: flex; flex-wrap: wrap; gap: var(--ikr-s3); align-items: center; }
.ikr-foot__age { font-family: var(--ikr-mono); border: 1px solid var(--ikr-accent); color: var(--ikr-accent); border-radius: var(--ikr-r-sm); padding: 1px 7px; }
@media (max-width: 720px) { .ikr-foot__cols { grid-template-columns: minmax(0, 1fr); gap: var(--ikr-s4); } }

/* ----------------------------- Cookie ---------------------------------- */
.ikr-cookie {
  position: fixed;
  z-index: 70;
  right: 18px; bottom: 18px;
  width: min(380px, calc(100vw - 36px));
  background: var(--ikr-surface);
  border: 1px solid var(--ikr-hairline);
  border-radius: var(--ikr-r-md);
  padding: var(--ikr-s4) var(--ikr-s5);
  font-size: 0.86rem;
  color: var(--ikr-ink-2);
}
.ikr-cookie[hidden] { display: none; }
.ikr-cookie p { margin: 0 0 var(--ikr-s3); }
.ikr-cookie__row { display: flex; gap: var(--ikr-s2); }
.ikr-cookie button {
  font-family: var(--ikr-mono); font-size: 0.78rem; cursor: pointer;
  border-radius: var(--ikr-r-sm); padding: 9px 14px; min-height: 40px; border: 1px solid var(--ikr-hairline);
  background: var(--ikr-surface-2); color: var(--ikr-ink);
}
.ikr-cookie button.ikr-cookie__ok { background: var(--ikr-accent); border-color: var(--ikr-accent-2); color: #fbf3e8; }
@media (max-width: 560px) {
  .ikr-cookie { left: 0; right: 0; bottom: 0; width: 100%; border-radius: var(--ikr-r-md) var(--ikr-r-md) 0 0; }
}

/* 404 */
.ikr-404 { text-align: center; padding-block: var(--ikr-s7); }
.ikr-404 h1 { font-size: clamp(2.5rem, 1.5rem + 6vw, 5rem); margin: 0; }
.ikr-404 p { color: var(--ikr-ink-2); }

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; }
}
