/* ============================================================
   Alpino Casino — DECO PLATE design system. Prefisso: cuk-
   ============================================================ */

:root{
  --cuk-wrap:1255px;
  --cuk-pad:clamp(16px,4vw,34px);

  /* superfici tonali (off-white caldo) */
  --cuk-bg:#f7f5f0;
  --cuk-surface-1:#fffdf8;
  --cuk-surface-2:#f0ece2;
  --cuk-surface-3:#e7e1d4;
  --cuk-zone:#daf1f1;            /* zona brand: testata e footer */

  /* inchiostri */
  --cuk-ink:#1b1d22;
  --cuk-ink-2:#44474f;
  --cuk-ink-3:#5b5f69;

  /* accenti brand */
  --cuk-accent:#1a3c7a;
  --cuk-accent-deep:#13315f;
  --cuk-cta:#7487a6;
  --cuk-cta-deep:#5e7193;

  --cuk-line:color-mix(in srgb, var(--cuk-ink) 12%, transparent);
  --cuk-line-2:color-mix(in srgb, var(--cuk-ink) 7%, transparent);

  --cuk-r:20px;

  --cuk-serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --cuk-sans:"Jost", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  /* scala tipografica modulare (×1.25) */
  --cuk-s--1:.8rem;
  --cuk-s-0:1rem;
  --cuk-s-1:1.25rem;
  --cuk-s-2:1.563rem;
  --cuk-s-3:1.953rem;
  --cuk-s-4:2.441rem;
  --cuk-s-5:3.052rem;

  --cuk-shadow:0 18px 50px -28px rgba(20,24,36,.30);
}

*,*::before,*::after{box-sizing:border-box}
html{font-size:100%;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--cuk-bg);
  color:var(--cuk-ink);
  font-family:var(--cuk-sans);
  font-size:1.0625rem;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-variant-numeric:tabular-nums lining-nums;
  overflow-x:hidden;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--cuk-accent);text-decoration:none}
a:hover{color:var(--cuk-accent-deep)}

h1,h2,h3,h4{font-family:var(--cuk-serif);font-weight:600;line-height:1.1;color:var(--cuk-ink);margin:0 0 .5em;text-wrap:balance}
h1{font-size:clamp(2rem,1.3rem + 2.8vw,3rem);letter-spacing:-.01em}
h2{font-size:clamp(1.55rem,1.1rem + 1.7vw,2.2rem);letter-spacing:-.005em}
h3{font-size:var(--cuk-s-2)}
p{margin:0 0 1.05rem;text-wrap:pretty}

::selection{background:color-mix(in srgb,var(--cuk-accent) 22%,transparent);color:var(--cuk-ink)}
:focus-visible{outline:2px solid var(--cuk-accent);outline-offset:2px}
::marker{color:var(--cuk-accent)}
html{accent-color:var(--cuk-accent)}

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

/* offset ancore TOC sotto la testata sticky */
[id]{scroll-margin-top:88px}

/* ---------- divisore a ventaglio / asterismo ---------- */
.cuk-rule{border:0;height:auto;text-align:center;margin:30px 0;color:var(--cuk-accent);line-height:1}
.cuk-rule::before{content:"⁂";font-size:1.1rem;letter-spacing:.4em}

/* ============================================================
   TESTATA
   ============================================================ */
.cuk-head{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb,var(--cuk-zone) 92%,#fff);
  border-bottom:1px solid var(--cuk-line);
  min-height:64px;
}
.cuk-head__row{
  display:flex;align-items:center;gap:22px;
  min-height:64px;
}
.cuk-logo{display:inline-flex;align-items:center;line-height:0;flex:0 0 auto}
.cuk-logo img{height:clamp(30px,4vw,42px);width:auto}
.cuk-nav{margin-left:auto}
.cuk-nav ul{
  list-style:none;margin:0;padding:0;
  display:flex;flex-wrap:nowrap;align-items:center;gap:clamp(12px,1.4vw,22px);
}
.cuk-nav a{
  display:inline-block;white-space:nowrap;
  font-size:.95rem;font-weight:500;letter-spacing:.01em;
  color:var(--cuk-ink);padding:6px 2px;
  border-bottom:2px solid transparent;
  transition:color .15s ease,border-color .15s ease;
}
.cuk-nav a:hover{color:var(--cuk-accent)}
.cuk-nav a[aria-current="page"]{color:var(--cuk-accent);border-bottom-color:var(--cuk-accent)}
.cuk-head__cta{flex:0 0 auto}
.cuk-head__cta .cuk-cta{white-space:nowrap;padding:9px 18px;font-size:.9rem}

/* burger */
.cuk-burger{
  display:none;flex:0 0 auto;margin-left:auto;
  width:48px;height:48px;align-items:center;justify-content:center;
  background:transparent;border:1px solid var(--cuk-line);border-radius:2px;
  cursor:pointer;color:var(--cuk-ink);
}
.cuk-burger svg{width:22px;height:22px}
.cuk-drawer-tgl{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden;clip:rect(0 0 0 0)}

/* ============================================================
   HERO — quadro prezzo/offerta (senza foto)
   ============================================================ */
.cuk-hero{padding-block:clamp(22px,3.4vw,40px) clamp(20px,3vw,34px)}
.cuk-hero__grid{
  display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(20px,3vw,46px);
  align-items:center;
}
.cuk-hero__copy{display:flex;flex-direction:column;gap:14px;min-width:0}
.cuk-kicker{
  display:block;font-family:var(--cuk-sans);font-size:.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.22em;color:var(--cuk-accent);
}
.cuk-hero__copy h1{margin:0}
.cuk-hero__lead{
  margin:0;max-width:48ch;font-size:1.12rem;color:var(--cuk-ink-2);line-height:1.55;
}
.cuk-hero__actions{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-top:4px}
.cuk-hero__sec{font-weight:500;border-bottom:1px solid var(--cuk-line);padding-bottom:2px}

/* tabella offerta */
.cuk-offer{
  background:var(--cuk-surface-1);
  border:1px solid var(--cuk-line);border-radius:var(--cuk-r);
  border-top:3px solid var(--cuk-accent);
  padding:6px 0;box-shadow:var(--cuk-shadow);min-width:0;
}
.cuk-offer__row{
  display:flex;justify-content:space-between;align-items:baseline;gap:18px;
  padding:13px clamp(16px,2vw,24px);
  border-top:1px solid var(--cuk-line-2);
}
.cuk-offer__row:first-child{border-top:0}
.cuk-offer__k{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:var(--cuk-ink-3);font-weight:600}
.cuk-offer__v{font-family:var(--cuk-serif);font-size:1.3rem;font-weight:600;color:var(--cuk-ink);text-align:right}
.cuk-offer__v--accent{color:var(--cuk-accent)}
.cuk-hero__facts{
  margin-top:18px;color:var(--cuk-ink-3);font-size:.92rem;
  display:flex;flex-wrap:wrap;gap:6px 14px;
}
.cuk-hero__facts span{position:relative;padding-right:14px}
.cuk-hero__facts span::after{content:"·";position:absolute;right:3px;color:var(--cuk-line)}
.cuk-hero__facts span:last-child::after{content:""}

/* ============================================================
   PULSANTI CTA
   ============================================================ */
.cuk-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--cuk-sans);font-weight:600;font-size:1rem;letter-spacing:.01em;
  padding:13px 26px;border-radius:2px;cursor:pointer;border:1px solid transparent;
  min-height:48px;text-align:center;
  transition:transform .24s cubic-bezier(.16,1,.3,1),background-color .18s ease,filter .18s ease;
}
.cuk-cta--solid{background:var(--cuk-cta);color:#fff;border-color:var(--cuk-cta-deep)}
.cuk-cta--solid:hover{background:var(--cuk-cta-deep);color:#fff;transform:scale(1.02);filter:brightness(1.03)}
.cuk-cta--solid:active{transform:scale(.985)}
.cuk-cta--ghost{background:transparent;color:var(--cuk-accent);border-color:var(--cuk-accent)}
.cuk-cta--ghost:hover{background:color-mix(in srgb,var(--cuk-accent) 8%,transparent);color:var(--cuk-accent-deep);transform:scale(1.02)}
.cuk-cta__a{transition:transform .24s cubic-bezier(.16,1,.3,1);flex:0 0 auto}
.cuk-cta:hover .cuk-cta__a{transform:translateX(4px)}
.cuk-ctarow{display:flex;justify-content:center;margin:26px 0}

/* ============================================================
   BRICIOLE
   ============================================================ */
.cuk-crumbs{padding-block:14px 2px}
.cuk-crumbs ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px;font-size:.84rem;color:var(--cuk-ink-3)}
.cuk-crumbs li{display:flex;align-items:center;gap:6px}
.cuk-crumbs li+li::before{content:"›";color:var(--cuk-line);margin-right:0}
.cuk-crumbs a{color:var(--cuk-ink-3)}
.cuk-crumbs a:hover{color:var(--cuk-accent)}
.cuk-crumbs [aria-current="page"]{color:var(--cuk-ink-2)}

/* ============================================================
   BYLINE
   ============================================================ */
.cuk-byline{padding-block:14px}
.cuk-byline__in{display:flex;align-items:center;gap:14px;flex-wrap:wrap;border-top:1px solid var(--cuk-line);border-bottom:1px solid var(--cuk-line);padding-block:14px}
.cuk-byline img{width:52px;height:52px;border-radius:50%;object-fit:cover;flex:0 0 auto}
.cuk-byline__meta{font-size:.9rem;color:var(--cuk-ink-3);line-height:1.4}
.cuk-byline__meta strong{display:block;font-size:.98rem;color:var(--cuk-ink);font-weight:600}
.cuk-byline__meta a{font-weight:600}
.cuk-byline__dates{margin-left:auto;text-align:right;font-size:.82rem;color:var(--cuk-ink-3)}

/* ============================================================
   CORPO / PROSA
   ============================================================ */
.cuk-main{padding-block:6px 40px}
.cuk-prose{max-width:none;overflow-wrap:break-word}
.cuk-prose > *{max-width:none;min-width:0}
.cuk-section{padding-block:clamp(22px,3vw,38px) 0}
.cuk-section + .cuk-section{margin-top:6px}
.cuk-sec-no{
  display:block;font-family:var(--cuk-serif);font-size:.95rem;font-style:italic;
  color:var(--cuk-accent);letter-spacing:.04em;margin-bottom:2px;
}
.cuk-prose h2{position:relative;scroll-margin-top:84px;padding-top:14px}
.cuk-prose h2::before{content:"";position:absolute;top:0;left:0;width:2.5em;height:2px;background:var(--cuk-accent)}
.cuk-prose h2::after{content:"";position:absolute;top:1px;left:2.5em;right:0;height:1px;background:var(--cuk-line)}
.cuk-prose h3{margin-top:1.6rem;color:var(--cuk-accent-deep)}
.cuk-prose p{font-size:1.0625rem}
.cuk-prose a:not(.cuk-cta){
  color:var(--cuk-accent);text-decoration:underline;text-underline-offset:2px;
  text-decoration-color:var(--cuk-line);transition:text-decoration-color .15s ease,color .15s ease;
}
.cuk-prose a:not(.cuk-cta):hover{color:var(--cuk-accent-deep);text-decoration-color:var(--cuk-accent)}
.cuk-lead{font-size:1.18rem;line-height:1.55;color:var(--cuk-ink-2)}

/* liste con tacca angolare */
.cuk-prose ul{list-style:none;margin:0 0 1.1rem;padding:0}
.cuk-prose ul li{position:relative;padding-left:1.5em;margin:.4em 0}
.cuk-prose ul li::before{content:"⌐";position:absolute;left:0;top:0;color:var(--cuk-accent);font-weight:700}
.cuk-prose ol{margin:0 0 1.1rem;padding-left:1.4em}
.cuk-prose ol li{margin:.4em 0}

/* passi numerati con numero in margine */
.cuk-steps{list-style:none;margin:1rem 0;padding:0;counter-reset:cuk-step}
.cuk-steps li{position:relative;padding-left:3rem;margin:.7rem 0;counter-increment:cuk-step}
.cuk-steps li::before{
  content:counter(cuk-step);position:absolute;left:0;top:0;width:2.2rem;text-align:center;
  font-family:var(--cuk-serif);font-size:1.2rem;color:var(--cuk-accent);
  border-top:2px solid var(--cuk-accent);
}

/* definizione fatti */
.cuk-deflist{
  margin:1.2rem 0;border:1px solid var(--cuk-line);border-radius:var(--cuk-r);
  background:var(--cuk-surface-1);overflow:hidden;
}
.cuk-deflist div{display:grid;grid-template-columns:minmax(0,.4fr) minmax(0,.6fr);border-top:1px solid var(--cuk-line-2)}
.cuk-deflist div:first-child{border-top:0}
.cuk-deflist dt{padding:12px 18px;font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--cuk-ink-3);background:var(--cuk-surface-2)}
.cuk-deflist dd{margin:0;padding:12px 18px;color:var(--cuk-ink)}

/* callout */
.cuk-callout{
  margin:1.3rem 0;padding:18px 22px;background:var(--cuk-surface-2);
  border-left:3px solid var(--cuk-accent);border-radius:0 var(--cuk-r) var(--cuk-r) 0;
}
.cuk-callout p:last-child{margin-bottom:0}

/* ---------- tabelle (anche <table> nudo) ---------- */
.cuk-tablewrap{overflow-x:auto;margin:1.3rem 0}
.cuk-prose table,table:not(.cuk-bare){
  width:100%;border-collapse:collapse;font-size:.98rem;
  background:var(--cuk-surface-1);border:1px solid var(--cuk-line);border-radius:var(--cuk-r);
  overflow:hidden;
}
.cuk-prose caption,table caption{caption-side:top;text-align:left;font-size:.85rem;color:var(--cuk-ink-3);margin-bottom:8px}
.cuk-prose th,.cuk-prose td,table:not(.cuk-bare) th,table:not(.cuk-bare) td{
  padding:12px 16px;text-align:left;border-top:1px solid var(--cuk-line-2);vertical-align:top;
}
.cuk-prose thead th,table:not(.cuk-bare) thead th{
  background:var(--cuk-surface-2);border-top:0;font-weight:600;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.07em;color:var(--cuk-ink-2);
}
.cuk-prose tbody td:first-child,table:not(.cuk-bare) tbody td:first-child{font-weight:600}
.cuk-prose tbody tr:hover td,table:not(.cuk-bare) tbody tr:hover td{background:color-mix(in srgb,var(--cuk-accent) 4%,transparent)}
.cuk-prose td.num,.cuk-num{text-align:right;font-variant-numeric:tabular-nums}

/* ---------- FAQ / accordion (anche <details> nudo) ---------- */
.cuk-faq{margin:1.2rem 0;display:flex;flex-direction:column;gap:10px}
.cuk-prose details,details.cuk-faq__q{
  border:1px solid var(--cuk-line);border-radius:var(--cuk-r);overflow:hidden;background:var(--cuk-surface-1);
}
.cuk-prose summary,details.cuk-faq__q > summary{
  list-style:none;cursor:pointer;padding:15px 48px 15px 20px;position:relative;
  font-family:var(--cuk-serif);font-size:1.18rem;font-weight:600;color:var(--cuk-ink);
  background:var(--cuk-surface-2);
}
.cuk-prose summary::-webkit-details-marker,details.cuk-faq__q > summary::-webkit-details-marker{display:none}
.cuk-prose summary::after,details.cuk-faq__q > summary::after{
  content:"";position:absolute;right:20px;top:50%;width:11px;height:11px;
  border-right:2px solid var(--cuk-accent);border-bottom:2px solid var(--cuk-accent);
  transform:translateY(-65%) rotate(45deg);transition:transform .2s ease;
}
.cuk-prose details[open] summary::after,details.cuk-faq__q[open] > summary::after{transform:translateY(-35%) rotate(225deg)}
.cuk-faq__a,.cuk-prose details > p,.cuk-prose details > div{padding:6px 20px 18px}
.cuk-faq__a > *:last-child{margin-bottom:0}

/* ---------- TOC ---------- */
.cuk-toc{
  margin:1.3rem 0;border:1px solid var(--cuk-line);border-radius:var(--cuk-r);
  background:var(--cuk-surface-1);overflow:hidden;
}
.cuk-toc > summary{
  list-style:none;cursor:pointer;padding:14px 20px;position:relative;
  font-family:var(--cuk-sans);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  color:var(--cuk-accent);background:var(--cuk-surface-2);
}
.cuk-toc > summary::-webkit-details-marker{display:none}
.cuk-toc > summary::after{content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:1.2rem;color:var(--cuk-accent)}
.cuk-toc[open] > summary::after{content:"–"}
.cuk-toclist{list-style:none;margin:0;padding:10px 20px 16px;counter-reset:cuk-toc;columns:2;column-gap:32px}
.cuk-toclist li{counter-increment:cuk-toc;margin:.32em 0;break-inside:avoid}
.cuk-toclist li::before{content:counter(cuk-toc,decimal-leading-zero);color:var(--cuk-accent);font-family:var(--cuk-serif);margin-right:8px}
.cuk-toclist a{color:var(--cuk-ink-2)}
.cuk-toclist a:hover{color:var(--cuk-accent)}

/* ---------- figure ---------- */
.cuk-figure{width:min(72%,760px);margin:1.4rem auto}
.cuk-figure img{width:100%;border-radius:var(--cuk-r);border:1px solid var(--cuk-line)}
.cuk-figure figcaption{margin-top:8px;font-size:.85rem;color:var(--cuk-ink-3);text-align:center}

/* ============================================================
   GRIGLIA SLOT
   ============================================================ */
.cuk-slots{padding-block:clamp(22px,3vw,38px)}
.cuk-slots__head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.cuk-slots__head p{margin:.3rem 0 0;color:var(--cuk-ink-2);max-width:60ch}
.cuk-slots__all{font-weight:600;white-space:nowrap}
.cuk-slotgrid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:12px}
.cuk-slot{
  display:block;color:inherit;text-decoration:none;
  background:var(--cuk-surface-1);border:1px solid var(--cuk-line);border-radius:12px;
  overflow:hidden;transition:transform .2s cubic-bezier(.16,1,.3,1),border-color .2s ease;
}
.cuk-slot:hover{transform:translateY(-3px);border-color:var(--cuk-accent)}
.cuk-slot__img{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--cuk-surface-3)}
.cuk-slot__img img{width:100%;height:100%;object-fit:cover;transition:transform .25s ease}
.cuk-slot:hover .cuk-slot__img img{transform:scale(1.05)}
.cuk-slot__name{display:block;padding:8px 8px;font-size:.78rem;font-weight:500;text-align:center;color:var(--cuk-ink);line-height:1.25}

/* ============================================================
   SCHEDA AUTORE (in fondo alle pagine money)
   ============================================================ */
.cuk-author{
  display:flex;gap:20px;align-items:flex-start;
  max-width:780px;margin:30px auto 0;padding:22px;
  background:var(--cuk-surface-1);border:1px solid var(--cuk-line);border-radius:var(--cuk-r);
}
.cuk-author__photo{width:104px;height:104px;border-radius:50%;object-fit:cover;flex:0 0 auto}
.cuk-author__b h3{margin:0 0 2px}
.cuk-author__role{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--cuk-accent);font-weight:600;margin-bottom:8px}
.cuk-author__b p{margin:0 0 .6rem;color:var(--cuk-ink-2)}
.cuk-author__more{font-weight:600}
.cuk-author__rev{margin-top:6px;font-size:.85rem;color:var(--cuk-ink-3)}

/* pagina autore (ProfilePage) — layout articolo, non byline */
.cuk-profile{padding-block:10px 30px}
.cuk-profile__head{display:flex;gap:24px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
.cuk-profile__photo{width:200px;height:auto;aspect-ratio:3/4;object-fit:cover;border-radius:var(--cuk-r);border:1px solid var(--cuk-line)}
.cuk-profile__b{min-width:240px;flex:1}

/* ============================================================
   FOOTER
   ============================================================ */
.cuk-foot{background:var(--cuk-zone);border-top:1px solid var(--cuk-line);margin-top:40px;padding-block:38px 22px;color:var(--cuk-ink)}
.cuk-foot__top{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:28px}
.cuk-foot__brand img{height:38px;width:auto;background:#fff;padding:8px 14px;border-radius:12px;display:inline-block}
.cuk-foot__brand p{margin:14px 0 0;font-size:.9rem;color:var(--cuk-ink-2);max-width:34ch}
.cuk-foot h4{font-family:var(--cuk-sans);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--cuk-ink-3);margin:0 0 12px}
.cuk-foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.cuk-foot a{color:var(--cuk-ink-2);font-size:.92rem}
.cuk-foot a:hover{color:var(--cuk-accent)}
.cuk-foot__legal{display:flex;flex-wrap:wrap;gap:8px 18px;border-top:1px solid var(--cuk-line);margin-top:26px;padding-top:16px;font-size:.84rem}
.cuk-foot__legal a{color:var(--cuk-ink-3)}
.cuk-foot__disc{margin-top:16px;font-size:.82rem;line-height:1.6;color:var(--cuk-ink-3)}
.cuk-foot__disc strong{color:var(--cuk-ink-2)}
.cuk-foot__mail{margin-top:8px;font-size:.84rem;color:var(--cuk-ink-3)}

/* ============================================================
   COOKIE
   ============================================================ */
.cuk-cookie{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:80;
  width:min(560px,calc(100vw - 28px));
  background:var(--cuk-surface-1);border:1px solid var(--cuk-line);border-radius:var(--cuk-r);
  box-shadow:var(--cuk-shadow);padding:18px 20px;
}
.cuk-cookie[hidden]{display:none}
.cuk-cookie p{margin:0 0 12px;font-size:.9rem;color:var(--cuk-ink-2)}
.cuk-cookie a{font-weight:600}
.cuk-cookie__row{display:flex;gap:10px;flex-wrap:wrap}
.cuk-cookie button{
  font-family:var(--cuk-sans);font-weight:600;font-size:.88rem;cursor:pointer;
  padding:10px 18px;border-radius:2px;border:1px solid var(--cuk-cta-deep);
  background:var(--cuk-cta);color:#fff;min-height:44px;
}
.cuk-cookie button.cuk-cookie__ghost{background:transparent;color:var(--cuk-accent);border-color:var(--cuk-accent)}
.cuk-cookie__reopen{
  position:fixed;left:14px;bottom:14px;z-index:79;width:42px;height:42px;border-radius:50%;
  display:none;align-items:center;justify-content:center;cursor:pointer;
  background:var(--cuk-surface-1);border:1px solid var(--cuk-line);color:var(--cuk-accent);box-shadow:var(--cuk-shadow);
}
.cuk-cookie__reopen svg{width:20px;height:20px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .cuk-nav{
    position:absolute;top:100%;right:var(--cuk-pad);
    width:min(80vw,320px);
    background:color-mix(in srgb,var(--cuk-zone) 96%,#fff);
    border:1px solid var(--cuk-line);border-radius:0 0 var(--cuk-r) var(--cuk-r);
    box-shadow:var(--cuk-shadow);
    margin-left:0;padding:10px 16px 16px;
    transform:translateY(-8px);opacity:0;visibility:hidden;pointer-events:none;
    transition:transform .22s ease,opacity .22s ease,visibility .22s ease;
  }
  .cuk-drawer-tgl:checked ~ .cuk-nav{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto}
  .cuk-nav ul{flex-direction:column;align-items:stretch;gap:2px}
  .cuk-nav a{padding:12px 4px;border-bottom:1px solid var(--cuk-line-2)}
  .cuk-nav a[aria-current="page"]{border-bottom-color:var(--cuk-accent)}
  .cuk-burger{display:inline-flex}
  .cuk-head__cta{display:none}
}

@media (max-width:780px){
  .cuk-foot__top{grid-template-columns:1fr 1fr}
  .cuk-slotgrid{grid-template-columns:repeat(4,minmax(0,1fr))}
}

@media (max-width:720px){
  .cuk-hero__grid{grid-template-columns:1fr;gap:20px}
  .cuk-hero__copy{text-align:center;align-items:center}
  .cuk-hero__lead{margin-inline:auto}
  .cuk-hero__actions{justify-content:center}
  .cuk-hero__facts{justify-content:center}
  .cuk-toclist{columns:1}
  .cuk-deflist div{grid-template-columns:1fr}
  .cuk-deflist dt{border-bottom:1px solid var(--cuk-line-2)}
}

@media (max-width:640px){
  body{font-size:1rem}
  .cuk-slotgrid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
  .cuk-figure{width:100%}
  .cuk-prose table,table:not(.cuk-bare){display:block;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .cuk-author{flex-direction:column;align-items:center;text-align:center}
  .cuk-author__role{text-align:center}
  .cuk-byline__dates{margin-left:0;text-align:left}
  .cuk-foot__top{grid-template-columns:1fr}
  .cuk-profile__head{flex-direction:column;align-items:center;text-align:center}
}

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

/* CTA в теле статьи (голый cuk_cta() — прямой ребёнок .cuk-prose, без обёртки .cuk-ctarow) центрируем. */
.cuk-prose > a.cuk-cta{display:flex;width:fit-content;margin:1.6rem auto}
