/* ===========================================================================
   Společně pro Frýdek-Místek — campaign homepage
   Static recreation of templates/homepage/Homepage.dc.html.
   Tokens transcribed verbatim from the design system (tokens/*.css);
   component styling recreated from templates/homepage/kit.jsx.
   =========================================================================== */

/* ------------------------------------------------------------------ Fonts */
/* Self-hosted Red Hat Display, subset to Latin + Czech (Latin Ext-A) and served as WOFF2.
   Only the 7 upright weights actually used in this sheet, plus the single italic face
   (.hero__quote, 800 italic), are declared. Unused italics were removed. */
@font-face { font-family:"Red Hat Display"; src:url("../assets/fonts/RedHatDisplay-Light.woff2") format("woff2");           font-weight:300; font-style:normal; font-display:swap; }
@font-face { font-family:"Red Hat Display"; src:url("../assets/fonts/RedHatDisplay-Regular.woff2") format("woff2");         font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:"Red Hat Display"; src:url("../assets/fonts/RedHatDisplay-Medium.woff2") format("woff2");          font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:"Red Hat Display"; src:url("../assets/fonts/RedHatDisplay-SemiBold.woff2") format("woff2");        font-weight:600; font-style:normal; font-display:swap; }
@font-face { font-family:"Red Hat Display"; src:url("../assets/fonts/RedHatDisplay-Bold.woff2") format("woff2");            font-weight:700; font-style:normal; font-display:swap; }
@font-face { font-family:"Red Hat Display"; src:url("../assets/fonts/RedHatDisplay-ExtraBold.woff2") format("woff2");       font-weight:800; font-style:normal; font-display:swap; }
@font-face { font-family:"Red Hat Display"; src:url("../assets/fonts/RedHatDisplay-Black.woff2") format("woff2");           font-weight:900; font-style:normal; font-display:swap; }
@font-face { font-family:"Red Hat Display"; src:url("../assets/fonts/RedHatDisplay-ExtraBoldItalic.woff2") format("woff2"); font-weight:800; font-style:italic; font-display:swap; }

/* ------------------------------------------------------------- Design tokens */
:root {
  /* Brand stops */
  --c-yellow:#ffca00; --c-red:#e50047; --c-magenta:#ce0067; --c-cyan:#32bef0;
  --c-navy:#00264a; --c-white:#ffffff;

  /* Navy ink scale */
  --navy-900:#001b35; --navy-800:#00264a; --navy-700:#0a3a64; --navy-600:#14507f;
  --navy-500:#2c6c9e; --navy-300:#8bb0cc; --navy-100:#d6e3ee;

  /* Neutral / paper */
  --paper:#ffffff; --paper-50:#f7f9fb; --paper-100:#eef2f6; --paper-200:#dde4ec;
  --paper-300:#c2cdd9; --ink-muted:#5b6b7b;

  /* Semantic */
  --text-strong:var(--c-navy); --text-body:#25384a; --text-muted:var(--ink-muted);
  --accent:var(--c-magenta); --accent-hover:#b3005a; --accent-press:#99004d;
  --focus-ring:0 0 0 3px rgba(50,190,240,.55);

  /* Typeface */
  --font:"Red Hat Display", system-ui, "Segoe UI", Arial, sans-serif;
  --font-display:var(--font); --font-body:var(--font);

  /* Type scale */
  --fs-body:16px; --lh-relaxed:1.62; --fw-regular:400;

  /* Gradients — the brand */
  --grad-brand:linear-gradient(to bottom left,
      var(--c-navy) 0%, var(--c-magenta) 32%, var(--c-red) 55%, #ff6a2b 80%, var(--c-yellow) 100%);
  --grad-sunset:linear-gradient(210deg,
      var(--c-magenta) 0%, var(--c-red) 38%, #ff7a2e 72%, var(--c-yellow) 100%);
  --grad-logo:linear-gradient(90deg,
      var(--c-yellow) 0%, var(--c-red) 33%, var(--c-magenta) 66%, var(--c-cyan) 100%);
  --grad-bar:linear-gradient(90deg,
      var(--c-yellow) 0%, var(--c-red) 40%, var(--c-magenta) 70%, var(--c-cyan) 100%);
  --grad-navy:linear-gradient(200deg, var(--navy-700) 0%, var(--c-navy) 70%);

  /* Radii */
  --r-xs:6px; --r-sm:10px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-pill:999px;

  /* Shadows (cool navy-tinted) */
  --shadow-xs:0 1px 2px rgba(0,38,74,.08);
  --shadow-sm:0 2px 8px rgba(0,38,74,.08);
  --shadow-md:0 8px 24px rgba(0,38,74,.10);
  --shadow-lg:0 18px 48px rgba(0,38,74,.14);
  --shadow-accent:0 10px 28px rgba(206,0,103,.35);

  /* Motion */
  --ease-out:cubic-bezier(.22,.61,.36,1);
  --dur-fast:140ms; --dur-base:240ms; --dur-slow:420ms;

  /* Layout */
  --container:1280px;
  --gutter:48px;
}

/* ------------------------------------------------------------------ Base */
*, *::before, *::after { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body {
  margin:0;
  background:#fff;
  font-family:var(--font);
  font-size:var(--fs-body);
  line-height:var(--lh-relaxed);
  font-weight:var(--fw-regular);
  color:var(--c-navy);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1, h2, h3, h4 { margin:0; color:var(--c-navy); font-family:var(--font); }
p { margin:0; text-wrap:pretty; }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
button { font-family:inherit; }
:focus-visible { outline:none; box-shadow:var(--focus-ring); border-radius:var(--r-xs); }
::selection { background:var(--c-magenta); color:#fff; }

.container { max-width:var(--container); margin:0 auto; padding:0 var(--gutter); }
.section { padding:96px 0; }
.section > .container { padding-left:var(--gutter); padding-right:var(--gutter); }
.visually-hidden {
  position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* Section heading block (eyebrow + display H2) */
.sec-head { display:flex; flex-direction:column; gap:8px; margin-bottom:40px; }
.sec-head--row { flex-direction:row; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.eyebrow {
  font-weight:500; font-size:14px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent);
}
.eyebrow--cyan { color:var(--c-cyan); }
.eyebrow--white { color:rgba(255,255,255,.92); }
.sec-title {
  margin:0; font-weight:900; font-size:clamp(30px,3.6vw,46px); line-height:1.04;
  letter-spacing:-.02em; text-transform:uppercase; color:var(--c-navy);
}
.sec-title--white { color:#fff; }
.sec-link {
  font-weight:700; font-size:14px; color:var(--accent);
  display:inline-flex; align-items:center; gap:4px; white-space:nowrap;
}
.sec-link:hover { text-decoration:underline; }

/* ---------------------------------------------------------------- Buttons */
.btn {
  display:inline-flex; width:auto; justify-content:center; align-items:center; gap:8px;
  border:none; cursor:pointer; font-family:var(--font); font-weight:700;
  border-radius:var(--r-pill); line-height:1; letter-spacing:0; text-transform:none;
  transition:transform .14s var(--ease-out), filter .14s var(--ease-out);
  text-decoration:none;
}
.btn:hover { filter:brightness(.93); }
.btn:active { transform:scale(.97); }
.btn--sm { padding:8px 16px; font-size:14px; }
.btn--md { padding:13px 26px; font-size:16px; }
.btn--lg { padding:16px 34px; font-size:18px; }
.btn--uppercase { text-transform:uppercase; letter-spacing:.06em; }
.btn--primary { background:var(--accent); color:#fff; box-shadow:var(--shadow-accent); }
.btn--secondary { background:var(--c-navy); color:#fff; }
.btn--onBrand { background:#fff; color:var(--c-navy); box-shadow:var(--shadow-md); }
.btn--ghost { background:transparent; color:#fff; box-shadow:inset 0 0 0 2px rgba(255,255,255,.6); }
.btn--ghost-accent { background:transparent; color:var(--accent); box-shadow:inset 0 0 0 2px var(--paper-200); }
.btn svg { display:block; flex:none; }

/* ------------------------------------------------------------------ Pills */
.pill {
  display:inline-flex; align-items:center; gap:7px; font-family:var(--font);
  font-weight:700; font-size:13px; letter-spacing:.04em; line-height:1;
  padding:7px 14px; border-radius:var(--r-pill);
}
.pill__dot { width:8px; height:8px; border-radius:50%; flex:none; }
.pill--navy { background:var(--c-navy); color:#fff; }
.pill--accent { background:var(--accent); color:#fff; }
.pill--gradient { background:var(--grad-bar); color:#fff; }
.pill--soft { background:rgba(0,38,74,.07); color:var(--c-navy); }
.pill--outline { background:transparent; color:var(--c-navy); box-shadow:inset 0 0 0 1.5px var(--paper-200); }

/* --------------------------------------------------------------- Top menu */
.topbar {
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(10px);
  -webkit-backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--paper-200);
}
.topbar__inner {
  max-width:var(--container); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  height:88px; padding:0 var(--gutter);
}
.topbar__logo { height:89px; width:auto; display:block; flex:none; }
.topbar__nav { display:flex; align-items:center; gap:22px; }
.topnav { display:flex; gap:24px; }
.topnav a { font-weight:600; font-size:15px; color:var(--c-navy); transition:color .14s var(--ease-out); }
.topnav a:hover { color:var(--accent); }
.topbar__socials { display:flex; gap:8px; }

/* Mobile menu toggle (hamburger) */
.menu-toggle {
  display:none; width:44px; height:44px; border:none; background:transparent; cursor:pointer;
  border-radius:var(--r-sm); padding:10px; flex-direction:column; justify-content:space-between;
}
.menu-toggle__bar { display:block; height:2.5px; width:100%; background:var(--c-navy); border-radius:2px; transition:transform .2s var(--ease-out), opacity .2s var(--ease-out); }
.topbar.is-open .menu-toggle__bar:nth-child(1) { transform:translateY(8.75px) rotate(45deg); }
.topbar.is-open .menu-toggle__bar:nth-child(2) { opacity:0; }
.topbar.is-open .menu-toggle__bar:nth-child(3) { transform:translateY(-8.75px) rotate(-45deg); }

/* Mobile menu dropdown panel */
.mobile-menu {
  display:flex; flex-direction:column; gap:4px; padding:12px var(--gutter) 24px;
  background:rgba(255,255,255,.98);
  backdrop-filter:saturate(150%) blur(10px); -webkit-backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--paper-200);
}
.mobile-menu[hidden] { display:none; }
.mobile-menu__link { font-weight:700; font-size:18px; color:var(--c-navy); padding:12px 4px; border-bottom:1px solid var(--paper-100); }
.mobile-menu__link:hover { color:var(--accent); }
.mobile-menu__cta { margin-top:14px; align-self:flex-start; }
.mobile-menu__socials { display:flex; gap:10px; margin-top:16px; }

/* Social round links */
.social {
  width:38px; height:38px; border-radius:50%; display:inline-flex; align-items:center;
  justify-content:center; background:rgba(0,38,74,.06); color:var(--c-navy);
  transition:all .16s var(--ease-out);
}
.social:hover { background:var(--c-navy); color:#fff; }

/* ------------------------------------------------------------------ Hero */
.hero {
  position:relative; height:var(--hero-h,820px); overflow:hidden;
  background:var(--grad-brand); color:#fff;
}
.hero__wrap {
  position:relative; z-index:1; max-width:var(--container); margin:0 auto; height:100%;
  padding:0 var(--gutter); display:flex; align-items:center; justify-content:space-between; gap:72px;
}
.hero__left { display:flex; flex-direction:column; align-items:flex-start; gap:26px; max-width:600px; }
.hero__kicker { display:inline-flex; align-items:center; gap:14px; }
.hero__kicker-bar { width:42px; height:3px; border-radius:999px; background:rgba(255,255,255,.9); }
.hero__kicker-text { font-weight:500; font-size:14px; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.92); }
.hero__title {
  margin:0; font-weight:900; font-size:clamp(56px,7.4vw,96px); line-height:1.0;
  letter-spacing:-.02em; text-transform:uppercase; color:#fff;
}
.hero__lead {
  margin:0; font-weight:400; font-size:16px; line-height:1.62;
  color:rgba(255,255,255,.94); max-width:560px; text-wrap:pretty;
}
.hero__quote {
  margin:6px 0 0; font-style:italic; font-weight:800; font-size:clamp(26px,3.2vw,40px);
  line-height:1.1; letter-spacing:-.01em; color:#fff;
}
.hero__cta { margin-top:10px; }

/* Hero orbit */
.orbit { position:relative; width:600px; height:600px; flex:none; }
.orbit__ring { position:absolute; inset:0; transition:transform .35s cubic-bezier(.2,.7,.3,1); will-change:transform; }
.orbit__ring svg { position:absolute; inset:0; overflow:visible; }
.orbit__node {
  position:absolute; width:116px; height:116px; display:flex; align-items:center; justify-content:center;
}
.orbit__node img { height:80px; width:auto; display:block; filter:brightness(0) invert(1); opacity:.95; }
.orbit__core {
  position:absolute; left:222px; top:222px; width:156px; height:156px; border-radius:50%;
  background:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 0 6px rgba(255,255,255,.35), 0 20px 44px rgba(0,21,53,.32);
}
.orbit__core img { height:86px; width:auto; display:block; }

/* hero entrance animations */
@keyframes hpPop { from { opacity:0; transform:scale(.6); } }
@keyframes hpRise { from { opacity:0; transform:translateY(22px); } }
@media (prefers-reduced-motion: no-preference) {
  .hp-pop { animation:hpPop .6s cubic-bezier(.2,.7,.3,1) backwards; }
  .hp-rise { animation:hpRise .7s cubic-bezier(.2,.7,.3,1) backwards; }
}

/* ------------------------------------------------------------------ Stats */
.section--navy { background:var(--c-navy); }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat { display:flex; flex-direction:column; gap:6px; padding-left:18px; border-left:3px solid var(--c-cyan); }
.stat__value { font-weight:900; font-size:52px; line-height:1; letter-spacing:-.02em; color:#fff; }
.stat__label { font-size:15px; font-weight:600; line-height:1.4; color:rgba(255,255,255,.85); }

/* --------------------------------------------------- Candidate card slider */
.cardslider-wrap { position:relative; }
.cardslider {
  display:grid; grid-auto-flow:column;
  grid-auto-columns:calc((100% - 4 * 24px) / 5);
  gap:24px; overflow-x:auto; scroll-snap-type:x mandatory;
  padding:6px 2px 14px; scrollbar-width:none;
}
.cardslider::-webkit-scrollbar { display:none; }
.cand-card { scroll-snap-align:start; display:flex; flex-direction:column; align-items:center; gap:18px; }
.cand-card__avatar-wrap { position:relative; display:inline-flex; }
.avatar-ring {
  display:inline-flex; border-radius:50%; flex:none; padding:3px; background:#fff;
  box-shadow:var(--shadow-sm);
}
.avatar {
  width:150px; height:150px; border-radius:50%; overflow:hidden; display:inline-flex;
  align-items:center; justify-content:center; font-weight:800; color:#fff;
  font-size:51px; /* 150 * .34 */
}
.avatar img { width:100%; height:100%; object-fit:cover; }
.avatar--magenta { background:var(--c-magenta); }
.avatar--navy { background:var(--c-navy); }
.cand-card__num {
  position:absolute; top:-4px; left:-4px; min-width:40px; height:40px; padding:0 10px;
  border-radius:999px; background:var(--c-magenta); color:#fff; font-weight:900; font-size:19px;
  display:inline-flex; align-items:center; justify-content:center; box-shadow:var(--shadow-sm); z-index:2;
}
.cand-card__name { display:flex; flex-direction:column; align-items:center; line-height:1.14; text-align:center; }
.cand-card__given { font-weight:300; font-size:16px; color:var(--ink-muted); }
.cand-card__surname { font-weight:800; font-size:20px; text-transform:uppercase; letter-spacing:.01em; color:var(--c-navy); }

/* slider edge arrows (round magenta) */
.slider-arrow {
  position:absolute; top:90px; transform:translateY(-50%);
  width:48px; height:48px; border-radius:50%; border:none; cursor:pointer;
  background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-accent); z-index:3; transition:filter .14s var(--ease-out), transform .14s var(--ease-out);
}
.slider-arrow:hover { filter:brightness(.93); }
.slider-arrow[hidden] { display:none; }
.slider-arrow--left { left:-14px; }
.slider-arrow--right { right:-14px; }

/* coalition strip */
.coalition {
  display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-top:36px;
  background:var(--paper-50); border:1px solid var(--paper-200); border-radius:var(--r-lg);
  padding:18px 24px;
}
.coalition__label { font-weight:700; font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-muted); }
.coalition__parties { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.coalition__party { font-weight:900; font-size:17px; letter-spacing:.02em; color:var(--c-navy); }
.coalition__sep { width:1px; height:18px; background:var(--paper-300); }

/* ---------------------------------------------------- Candidate name table */
.cand-table { display:grid; grid-template-columns:repeat(3,1fr); column-gap:28px; row-gap:0; }
.cand-row { display:flex; align-items:center; gap:14px; padding:12px 6px; border-bottom:1px solid var(--paper-200); }
.cand-row.is-hidden { display:none; }
.cand-row__avatar {
  width:56px; height:56px; border-radius:50%; flex:none; display:inline-flex; align-items:center;
  justify-content:center; background:var(--navy-100); color:var(--c-navy); font-weight:800; font-size:19px;
  box-shadow:var(--shadow-sm);
}
.cand-row__avatar img { width:100%; height:100%; border-radius:50%; object-fit:cover; }
.cand-row__body { min-width:0; line-height:1.2; }
.cand-row__name { display:block; font-size:15.5px; color:var(--c-navy); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cand-row__rank { font-weight:800; color:var(--accent); }
.cand-row__given { font-weight:400; }
.cand-row__surname { font-weight:800; }
.cand-row__role { display:block; font-size:13px; color:var(--ink-muted); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cand-table-foot { display:flex; flex-direction:column; align-items:flex-end; gap:14px; margin-top:30px; }
.cand-count { font-size:13px; font-weight:600; letter-spacing:.04em; color:var(--ink-muted); }
.cand-actions { display:flex; gap:12px; flex-wrap:wrap; justify-content:flex-end; }

/* ------------------------------------------------------- Timeline + events */
.section--paper { background:var(--paper-50); }
.timeline { display:flex; flex-direction:column; }
.tl-row { display:grid; grid-template-columns:auto 1fr; gap:20px; filter:grayscale(100%); opacity:.82; transition:filter .3s var(--ease-out), opacity .3s var(--ease-out); }
.tl-row:hover { filter:grayscale(0%); opacity:1; }
.tl-rail { display:flex; flex-direction:column; align-items:center; }
.tl-dot { width:16px; height:16px; border-radius:50%; box-shadow:0 0 0 4px rgba(0,38,74,.08); flex:none; margin-top:18px; }
.tl-line { flex:1; width:2px; background:var(--paper-200); margin-top:6px; }
.tl-body { padding-bottom:18px; max-width:560px; }

.event-card {
  display:flex; gap:16px; align-items:center; background:#fff; border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm); padding:16px;
}
.event-card__avatar {
  width:68px; height:68px; border-radius:50%; flex:none; display:inline-flex; align-items:center;
  justify-content:center; background:var(--navy-100); color:var(--c-navy); font-weight:800; font-size:23px;
  box-shadow:var(--shadow-sm);
}
.event-card__body { display:flex; flex-direction:column; gap:8px; min-width:0; }
.event-card__title { font-weight:800; font-size:17px; text-transform:uppercase; letter-spacing:.02em; color:var(--c-navy); line-height:1.1; }
.event-card__host { font-size:14px; color:var(--ink-muted); margin-top:2px; }
.event-card__place { display:flex; align-items:center; gap:6px; font-size:14px; font-weight:600; color:#25384a; }
.event-card__pin { color:var(--pin, var(--accent)); }

.dtbadge { display:inline-flex; gap:8px; flex-wrap:wrap; }
.dtbadge__chip {
  display:inline-flex; align-items:center; gap:6px; background:var(--c-navy); color:#fff;
  font-weight:700; font-size:13px; padding:7px 13px; border-radius:var(--r-pill); line-height:1; white-space:nowrap;
}
.dtbadge__chip--alt { background:var(--navy-700); }
.dtbadge__dot { width:8px; height:8px; border-radius:50%; }

/* ------------------------------------------------------------- Aktuality */
.cat-row { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:40px; }
.cat-pill {
  display:inline-flex; align-items:center; gap:7px; font-family:var(--font); font-weight:700;
  font-size:13px; letter-spacing:.04em; line-height:1; padding:7px 14px; border-radius:var(--r-pill);
  border:none; cursor:pointer; background:rgba(0,38,74,.07); color:var(--c-navy);
  filter:grayscale(100%); opacity:.8; transition:filter .25s var(--ease-out), opacity .25s var(--ease-out);
}
.cat-pill:hover { filter:grayscale(0%); opacity:1; }
.cat-pill[aria-pressed="true"] { background:var(--accent); color:#fff; filter:none; opacity:1; }
.cat-pill__dot { width:8px; height:8px; border-radius:50%; }
.cat-pill[aria-pressed="true"] .cat-pill__dot { display:none; }

.news { display:flex; flex-direction:column; gap:18px; }
.news-card {
  display:flex; flex-direction:column; background:#fff; border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm); overflow:hidden;
}
.news-card.is-hidden { display:none; }
.news-card__media { }
.news-card__media img {
  display:block; width:100%; aspect-ratio:16 / 10; object-fit:cover;
  filter:grayscale(100%); opacity:.6; transition:filter .4s var(--ease-out), opacity .4s var(--ease-out);
}
.news-card:hover .news-card__media img { filter:grayscale(0%); opacity:1; }
.news-card__body { padding:20px 22px 24px; display:flex; flex-direction:column; gap:12px; justify-content:center; flex:1; }
.news-card__meta { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.news-card__date { font-size:13px; color:var(--ink-muted); display:inline-flex; align-items:center; gap:6px; }
.news-card__title { margin:0; font-weight:800; font-size:19px; line-height:1.12; text-transform:uppercase; letter-spacing:-.005em; color:var(--c-navy); }
.news-card__excerpt { margin:0; font-size:14.5px; line-height:1.55; color:var(--ink-muted); }
.news-card__more { margin-top:2px; font-weight:700; font-size:14px; color:var(--accent); display:inline-flex; align-items:center; gap:5px; }
.news-card__more:hover { text-decoration:underline; }

/* featured news card */
.news-card--featured { flex-direction:row; }
.news-card--featured .news-card__media { flex:0 0 46%; }
.news-card--featured .news-card__media img { height:100%; aspect-ratio:auto; min-height:240px; }
.news-card--featured .news-card__body { padding:34px 36px; }
.news-card--featured .news-card__title { font-size:28px; }
.news-card--featured .news-card__excerpt { font-size:16px; }

.news-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.news-empty { display:none; padding:40px 0; text-align:center; color:var(--ink-muted); font-weight:600; }
.news-empty.is-visible { display:block; }

/* --------------------------------------------------------------- Proc slider */
.proc { }
.proc__frame {
  position:relative; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg);
  display:grid; grid-template-columns:1fr 42%; min-height:480px; background:var(--grad-brand);
}
.proc__text-col { position:relative; overflow:hidden; }
/* Readability scrim under the slider copy (same warm-corner problem as the hero). */
.proc__text-col::before {
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(to bottom left, rgba(0,21,53,0) 36%, rgba(0,21,53,.5) 100%),
    linear-gradient(0deg, rgba(0,21,53,.26) 0%, rgba(0,21,53,0) 42%);
}
.proc__text-col .proc__track { position:relative; z-index:2; }
.proc__track {
  display:flex; height:100%; transition:transform .5s var(--ease-out);
}
.proc__text-slide {
  flex:0 0 100%; display:flex; flex-direction:column; justify-content:center; gap:18px;
  padding:clamp(36px,4.5vw,68px);
}
.proc__eyebrow { font-weight:700; font-size:14px; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.85); }
.proc__title { margin:0; font-weight:900; font-size:clamp(32px,4vw,52px); line-height:1.02; letter-spacing:-.02em; color:#fff; max-width:520px; }
.proc__desc { margin:0; font-size:clamp(16px,1.4vw,18px); line-height:1.6; color:rgba(255,255,255,.92); max-width:460px; }
.proc__cta { margin-top:10px; }
.proc__photo-col { position:relative; overflow:hidden; }
.proc__photo-slide { position:relative; flex:0 0 100%; height:100%; }
.proc__bust { position:absolute; bottom:0; left:50%; transform:translateX(-50%); height:90%; width:auto; max-width:none; object-fit:contain; object-position:bottom; }
.proc__initials-wrap { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px; padding:20px; }
.proc__initials { width:168px; height:168px; border-radius:50%; background:#fff; display:inline-flex; align-items:center; justify-content:center; flex:none; box-shadow:var(--shadow-md); }
.proc__initials span { font-weight:900; font-size:60px; color:var(--c-navy); letter-spacing:.02em; }
.proc__person { font-weight:800; font-size:18px; color:#fff; text-align:center; text-shadow:0 1px 3px rgba(0,0,0,.2); }
.proc__party { position:absolute; top:26px; right:30px; z-index:2; display:inline-flex; align-items:center; gap:8px; }
.proc__party-mark { width:30px; height:30px; border-radius:50%; border:2px solid #fff; display:inline-flex; align-items:center; justify-content:center; flex:none; }
.proc__party-mark span { width:11px; height:11px; border-radius:50%; background:#fff; }
.proc__party-name { font-weight:900; font-size:19px; letter-spacing:.02em; color:#fff; text-shadow:0 1px 3px rgba(0,0,0,.22); }
.proc__nav { position:absolute; bottom:20px; width:50px; height:50px; border-radius:50%; border:none; cursor:pointer; background:#fff; color:var(--c-navy); display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-md); z-index:3; transition:filter .14s var(--ease-out); }
.proc__nav:hover { filter:brightness(.95); }
.proc__nav--prev { right:80px; }
.proc__nav--next { right:20px; }
.proc__dots { display:flex; gap:10px; margin-top:22px; align-items:center; justify-content:center; }
.proc__dot { border:none; cursor:pointer; height:8px; width:8px; border-radius:999px; background:var(--paper-300); transition:all .3s var(--ease-out); padding:0; }
.proc__dot[aria-current="true"] { width:36px; background:var(--c-magenta); }

/* --------------------------------------------------------------- Documents */
.docs { display:flex; flex-direction:column; gap:12px; max-width:720px; }
.doc {
  display:flex; align-items:center; gap:16px; background:#fff; border-radius:var(--r-md);
  box-shadow:var(--shadow-sm); padding:14px 18px;
}
.doc__icon {
  width:46px; height:46px; border-radius:10px; flex:none; display:inline-flex; align-items:center;
  justify-content:center; color:var(--ink-muted); background:var(--paper-100);
}
.doc__body { min-width:0; flex:1; }
.doc__name { font-weight:700; font-size:16px; color:var(--c-navy); }
.doc__meta { font-size:13px; color:var(--ink-muted); margin-top:2px; }

/* ------------------------------------------------------------------ Footer */
.footer { background:var(--c-navy); color:#fff; }
.footer__inner { max-width:var(--container); margin:0 auto; padding:72px var(--gutter) 56px; display:flex; flex-direction:column; gap:40px; }
.footer__top { display:flex; align-items:flex-start; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.footer__brand { display:flex; flex-direction:column; align-items:flex-start; gap:18px; max-width:420px; }
.footer__logo { height:64px; width:auto; display:block; }
.footer__about { margin:0; font-size:15px; line-height:1.6; color:rgba(255,255,255,.78); text-wrap:pretty; }
.footer__socials { display:flex; gap:10px; }
.footer__social { width:40px; height:40px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; color:#fff; background:rgba(255,255,255,.12); transition:background .16s var(--ease-out); }
.footer__social:hover { background:rgba(255,255,255,.24); }
.footer__nav { display:flex; gap:64px; flex-wrap:wrap; }
.footer__col { display:flex; flex-direction:column; gap:12px; }
.footer__col-title { font-weight:700; font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.55); }
.footer__link { font-size:15px; color:rgba(255,255,255,.88); }
.footer__link:hover { color:#fff; text-decoration:underline; }
.footer__rule { height:1px; background:rgba(255,255,255,.14); }
.footer__bottom { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.footer__legal { margin:0; font-size:13px; line-height:1.6; color:rgba(255,255,255,.55); max-width:760px; text-wrap:pretty; }
.footer__number { font-size:13px; color:rgba(255,255,255,.6); }

/* ================================================================ Responsive */
@media (max-width:1100px) {
  .news-card--featured { flex-direction:column; }
  .news-card--featured .news-card__media { flex:none; }
  .news-card--featured .news-card__media img { aspect-ratio:16 / 10; min-height:auto; }
  .news-card--featured .news-card__body { padding:24px 24px 28px; }
  .news-card--featured .news-card__title { font-size:23px; }
}
@media (max-width:1000px) {
  :root { --gutter:32px; }
  .hero__wrap { flex-direction:column; justify-content:center; text-align:center; gap:56px; height:auto; padding-top:96px; padding-bottom:96px; }
  .hero { height:auto; min-height:100vh; }
  .hero__left { align-items:center; max-width:660px; }
  .hero__kicker, .hero__cta { align-self:center; }
  .orbit { transform:scale(.82); }
  .topnav { display:none; }
  .menu-toggle { display:flex; }
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:32px 24px; }
  .cardslider { grid-auto-columns:calc((100% - 2 * 24px) / 3); }
  .cand-table { grid-template-columns:repeat(2,1fr); }
  .proc__frame { grid-template-columns:1fr; }
  .proc__photo-col { min-height:300px; }
  .proc__nav { bottom:auto; top:16px; background:rgba(255,255,255,.92); }
  .proc__nav--prev { right:74px; }
  .proc__nav--next { right:16px; }
}
@media (max-width:760px) {
  :root { --gutter:24px; }
  .section { padding:64px 0; }
  .topbar__logo { height:64px; }
  .topbar__inner { height:72px; }
  .topbar__socials { display:none; }
  .topbar__cta { display:none; }
  .sec-head { margin-bottom:28px; }
  .cardslider { grid-auto-columns:calc((100% - 24px) / 2); }
  .cand-table { grid-template-columns:1fr; }
  .news-grid { grid-template-columns:1fr; }
  .stats-grid { gap:28px 20px; }
  .footer__nav { gap:40px; }
  .footer__top { gap:32px; }
}
@media (max-width:560px) {
  .orbit { transform:scale(.58); }
  .cardslider { grid-auto-columns:calc((100% - 24px) / 2); }
  .avatar { width:120px; height:120px; font-size:40px; }
  .cand-actions { width:100%; justify-content:stretch; }
  .cand-actions .btn { flex:1; }
  .hero__title { font-size:clamp(40px,13vw,72px); }
  .hero__lead { font-size:15px; }
}
