/*
Theme Name: Santo Spirito Studi
Theme URI: https://example.com/santo-spirito-studi
Description: Child theme Genesis per un sito editoriale e istituzionale dedicato al Centro Studi Internazionale Leone XIV ETS.
Author: Claudio Tirinnanzi
Author URI: https://example.com
Version: 1.10.7
Template: genesis
Text Domain: santo-spirito-studi
Requires at least: 6.0
Requires PHP: 8.0
*/

:root {
  --ss-ink: #1c1a18;
  --ss-muted: #6b625b;
  --ss-paper: #f7f3ec;
  --ss-stone: #e5ded1;
  --ss-brick: #8d3f2d;
  --ss-brick-dark: #61281e;
  --ss-olive: #536c4d;
  --ss-gold: #c79a43;
  --ss-white: #fffdf8;
  --ss-font-body: "Inter", "Helvetica Neue", Arial, sans-serif;
  --ss-font-heading: Georgia, "Times New Roman", serif;
  --ss-font-body-weight: 400;
  --ss-font-body-weight-bold: 700;
  --ss-font-heading-weight: 700;
  --ss-font-alt: Georgia, "Times New Roman", serif;
  --ss-font-alt-weight: 700;
  --ss-logo-width: 150px;
  --ss-header-padding-y: 18px;
  --ss-header-gap: 34px;
  --ss-topbar-bg: #1c1a18;
  --ss-topbar-text: #d8d0c5;
  --ss-topbar-link: #fffdf8;
  --ss-header-bg: #f7f3ec;
  --ss-header-text: #1c1a18;
  --ss-header-menu: #1c1a18;
  --ss-header-cta-bg: #8d3f2d;
  --ss-header-cta-text: #fffdf8;
  --ss-hero-overlay-rgb: 28, 26, 24;
  --ss-hero-overlay-opacity: 0.78;
  --ss-hero-text: #fffdf8;
  --ss-hero-kicker: #c79a43;
  --ss-hero-button-bg: #8d3f2d;
  --ss-hero-button-text: #fffdf8;
  --ss-promos-bg: #f7f3ec;
  --ss-promos-card-bg: #fffdf8;
  --ss-promos-text: #1c1a18;
  --ss-promos-accent: #c79a43;
  --ss-activities-bg: #fffdf8;
  --ss-activities-text: #1c1a18;
  --ss-activities-card-bg: #fffdf8;
  --ss-activities-accent: #8d3f2d;
  --ss-mission-bg: #1c1a18;
  --ss-mission-text: #fffdf8;
  --ss-mission-accent: #c79a43;
  --ss-notice-bg: #61281e;
  --ss-notice-text: #fffdf8;
  --ss-latest-bg: #e5ded1;
  --ss-latest-text: #1c1a18;
  --ss-center-intro-bg: #fffdf8;
  --ss-center-map-bg: #e5ded1;
  --ss-center-text: #1c1a18;
  --ss-page-header-bg: #f7f3ec;
  --ss-page-header-text: #1c1a18;
  --ss-page-header-accent: #8d3f2d;
  --ss-page-header-background-text: #fffdf8;
  --ss-page-header-overlay-rgb: 28, 26, 24;
  --ss-page-header-overlay-opacity: 0.72;
  --ss-before-footer-bg: #f7f3ec;
  --ss-before-footer-text: #1c1a18;
  --ss-before-footer-link: #8d3f2d;
  --ss-footer-bg: #1c1a18;
  --ss-footer-text: #d8d0c5;
  --ss-footer-link: #fffdf8;
  --ss-footer-logo-width: 230px;
  --ss-footer-title-size: 18px;
  --ss-footer-text-size: 14px;
  --ss-footer-padding-y: 76px;
  --ss-archive-columns: 3;
  --ss-max: 1180px;
  --ss-shadow: 0 24px 80px rgba(28, 26, 24, 0.12);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: var(--ss-paper);
  color: var(--ss-ink);
  font-family: var(--ss-font-body);
  font-size: 18px;
  font-weight: var(--ss-font-body-weight);
  line-height: 1.65;
}

strong,
b {
  font-weight: var(--ss-font-body-weight-bold);
}

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

a {
  color: var(--ss-brick-dark);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}

a:hover,
a:focus {
  color: var(--ss-brick);
}

.site-container {
  overflow: hidden;
}

.wrap,
.ss-wrap {
  margin: 0 auto;
  max-width: var(--ss-max);
  padding: 0 24px;
}

.ss-topbar {
  background: var(--ss-topbar-bg);
  color: var(--ss-topbar-text);
  font-size: 13px;
}

.ss-topbar .wrap {
  align-items: center;
  display: flex;
  gap: 24px;
  justify-content: space-between;
  min-height: 38px;
}

.ss-topbar p {
  margin: 0;
}

.ss-topbar__links,
.ss-topbar-menu {
  align-items: center;
  display: flex;
  gap: 14px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.ss-topbar a {
  color: var(--ss-topbar-link);
  font-weight: 800;
  text-decoration: none;
  text-transform: uppercase;
}

.site-header {
  background: var(--ss-header-bg);
  border-bottom: 1px solid rgba(28, 26, 24, 0.12);
  position: sticky;
  top: 0;
  z-index: 20;
}

.site-header .wrap {
  align-items: center;
  display: flex;
  gap: var(--ss-header-gap);
  min-height: 84px;
  padding-bottom: var(--ss-header-padding-y);
  padding-top: var(--ss-header-padding-y);
}

.title-area {
  flex: 0 0 auto;
}

.site-title {
  font-family: var(--ss-font-heading);
  font-size: 30px;
  font-weight: var(--ss-font-heading-weight);
  line-height: 1;
  margin: 0;
}

.site-title a {
  color: var(--ss-header-text);
  text-decoration: none;
}

.custom-logo-link {
  display: inline-flex;
}

.custom-logo {
  height: auto !important;
  max-height: none;
  max-width: none;
  width: var(--ss-logo-width) !important;
}

.wp-custom-logo .site-title,
.wp-custom-logo .site-description {
  display: none;
}

.site-header .nav-primary {
  flex: 1 1 auto;
  margin-left: clamp(18px, 3vw, 54px);
  min-width: 0;
}

.site-header .genesis-nav-menu {
  justify-content: center;
}

.ss-header-actions {
  align-items: center;
  align-self: center;
  display: flex;
  gap: 10px;
  margin-left: auto;
}

.ss-header-action {
  align-items: center;
  border: 1px solid var(--ss-ink);
  color: var(--ss-header-menu);
  display: inline-flex;
  font-size: 12px;
  font-weight: 800;
  justify-content: center;
  letter-spacing: 0.08em;
  min-height: 40px;
  padding: 0 14px;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.ss-header-action.is-primary {
  background: var(--ss-header-cta-bg);
  border-color: var(--ss-header-cta-bg);
  color: var(--ss-header-cta-text);
}

.site-description {
  color: var(--ss-muted);
  font-size: 13px;
  letter-spacing: 0.08em;
  margin: 8px 0 0;
  text-transform: uppercase;
}

.genesis-nav-menu {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 20px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.genesis-nav-menu .menu-item {
  list-style: none;
  margin: 0;
  position: relative;
}

.genesis-nav-menu a {
  color: var(--ss-header-menu);
  display: block;
  font-size: 14px;
  font-weight: 650;
  letter-spacing: 0.045em;
  padding: 10px 0;
  text-decoration: none;
  text-transform: uppercase;
}

.genesis-nav-menu .menu-item-has-children > a {
  align-items: center;
  display: flex;
  gap: 7px;
}

.genesis-nav-menu .menu-item-has-children > a::after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  content: "";
  display: inline-block;
  transform: translateY(1px);
}

.genesis-nav-menu .sub-menu .menu-item-has-children > a {
  justify-content: space-between;
}

.genesis-nav-menu .sub-menu .menu-item-has-children > a::after {
  border-bottom: 4px solid transparent;
  border-left: 5px solid currentColor;
  border-right: 0;
  border-top: 4px solid transparent;
}

.genesis-nav-menu .sub-menu {
  background: var(--ss-header-bg);
  border: 1px solid rgba(28, 26, 24, 0.14);
  box-shadow: var(--ss-shadow);
  display: none;
  left: 0;
  list-style: none;
  margin: 0;
  min-width: 280px;
  padding: 12px 0;
  position: absolute;
  top: 100%;
  z-index: 50;
}

.genesis-nav-menu .menu-item:hover > .sub-menu,
.genesis-nav-menu .menu-item:focus-within > .sub-menu {
  display: block;
}

.genesis-nav-menu .sub-menu .sub-menu {
  left: 100%;
  top: -13px;
}

.genesis-nav-menu .sub-menu a {
  border: 0;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1.25;
  padding: 11px 18px;
  text-transform: none;
}

.genesis-nav-menu .sub-menu a:hover,
.genesis-nav-menu .sub-menu a:focus {
  background: var(--ss-paper);
}

.menu-toggle {
  align-items: center;
  background: var(--ss-ink);
  border: 0;
  color: var(--ss-white);
  cursor: pointer;
  display: none;
  font-weight: 800;
  min-height: 44px;
  padding: 0 18px;
}

.menu-toggle__bars,
.menu-toggle__bars::before,
.menu-toggle__bars::after {
  background: currentColor;
  border-radius: 999px;
  display: block;
  height: 2px;
  width: 20px;
}

.menu-toggle__bars {
  position: relative;
}

.menu-toggle__bars::before,
.menu-toggle__bars::after {
  content: "";
  left: 0;
  position: absolute;
}

.menu-toggle__bars::before {
  top: -6px;
}

.menu-toggle__bars::after {
  top: 6px;
}

.ss-mobile-nav {
  display: none;
}

.ss-mobile-nav__close {
  display: none;
}

.site-inner {
  clear: both;
  margin: 0 auto;
  max-width: var(--ss-max);
  padding: 64px 24px;
}

.ss-page-header {
  background: var(--ss-page-header-bg);
  color: var(--ss-page-header-text);
  margin-bottom: 0;
  overflow: hidden;
  position: relative;
  width: 100%;
}

.ss-page-header.is-image-background {
  background:
    linear-gradient(90deg, rgba(var(--ss-page-header-overlay-rgb), var(--ss-page-header-overlay-opacity)), rgba(var(--ss-page-header-overlay-rgb), calc(var(--ss-page-header-overlay-opacity) * 0.42))),
    var(--ss-page-header-image),
    var(--ss-page-header-bg);
  background-position: center;
  background-size: cover;
  color: var(--ss-page-header-background-text);
}

.ss-page-header.is-image-background .ss-page-header__text {
  max-width: 960px;
}

.ss-page-header.is-image-background p {
  color: var(--ss-page-header-background-text);
}

.ss-page-header.is-image-hidden p {
  color: var(--ss-page-header-text);
}

.ss-page-header__inner {
  align-items: center;
  display: grid;
  gap: 42px;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.8fr);
  min-height: 340px;
  padding-bottom: 58px;
  padding-top: 58px;
}

.ss-page-header.is-image-below .ss-page-header__inner,
.ss-page-header.is-image-hidden .ss-page-header__inner,
.ss-page-header.is-image-background .ss-page-header__inner {
  grid-template-columns: 1fr;
}

.ss-page-header__text {
  max-width: 840px;
}

.ss-page-header .ss-kicker {
  color: var(--ss-page-header-accent);
}

.ss-page-header h1 {
  font-family: var(--ss-font-heading);
  font-size: clamp(34px, 5vw, 62px);
  font-weight: var(--ss-font-heading-weight);
  line-height: 1.03;
  margin: 0;
}

.ss-page-header p {
  font-size: clamp(17px, 1.35vw, 21px);
  line-height: 1.45;
  margin: 22px 0 0;
  max-width: 680px;
}

.single-post .ss-page-header h1 {
  font-size: clamp(32px, 4.2vw, 54px);
  max-width: 980px;
}

.ss-page-header__image {
  margin: 0;
}

.ss-page-header__image img {
  aspect-ratio: 4 / 3;
  height: auto;
  object-fit: cover;
  width: 100%;
}

.ss-page-header.is-image-below .ss-page-header__image img {
  aspect-ratio: 16 / 7;
}

.content-sidebar-wrap {
  display: grid;
  gap: 56px;
  grid-template-columns: minmax(0, 1fr) 320px;
}

.full-width-content .content-sidebar-wrap,
.ss-front-page .site-inner,
.page-template-centro-studi .site-inner {
  display: block;
  max-width: none;
  padding: 0;
}

.entry {
  background: var(--ss-white);
  box-shadow: var(--ss-shadow);
  padding: 56px;
}

.ss-archive-intro {
  margin-bottom: 34px;
}

.archive .content > .ss-archive-intro,
.blog:not(.home) .content > .ss-archive-intro,
.search .content > .ss-archive-intro {
  grid-column: 1 / -1;
}

.ss-archive-intro__text {
  color: var(--ss-muted);
  font-size: clamp(18px, 1.7vw, 23px);
  line-height: 1.5;
  max-width: 820px;
}

.ss-archive-intro__text p {
  margin: 0 0 16px;
}

.blog:not(.home) .content,
.archive .content,
.search .content {
  display: grid;
  gap: 28px;
  grid-template-columns: repeat(var(--ss-archive-columns), minmax(0, 1fr));
}

.blog:not(.home) .content > .archive-description,
.blog:not(.home) .content > .breadcrumb,
.blog:not(.home) .content > .archive-pagination,
.archive .content > .archive-description,
.archive .content > .breadcrumb,
.archive .content > .archive-pagination,
.search .content > .archive-description,
.search .content > .breadcrumb,
.search .content > .archive-pagination {
  grid-column: 1 / -1;
}

.blog:not(.home) .content > .entry,
.archive .content > .entry,
.search .content > .entry {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 0;
  overflow: hidden;
}

.blog:not(.home) .entry-header,
.blog:not(.home) .entry-content,
.archive .entry-header,
.search .entry-header,
.archive .entry-content,
.search .entry-content {
  padding-left: 28px;
  padding-right: 28px;
}

.blog:not(.home) .entry-header,
.archive .entry-header,
.search .entry-header {
  padding-top: 28px;
}

.blog:not(.home) .entry-content,
.archive .entry-content,
.search .entry-content {
  padding-bottom: 28px;
}

.blog:not(.home) .entry-content img,
.blog:not(.home) .entry-content .wp-block-image,
.archive .entry-content img,
.search .entry-content img,
.archive .entry-content .wp-block-image,
.search .entry-content .wp-block-image {
  display: none;
}

.ss-archive-thumb {
  display: block;
}

.ss-archive-thumb img {
  aspect-ratio: 16 / 10;
  object-fit: cover;
  width: 100%;
}

.blog:not(.home) .entry-title,
.archive .entry-title,
.search .entry-title {
  font-size: clamp(24px, 2.2vw, 34px);
  line-height: 1.08;
  margin-bottom: 16px;
}

.blog:not(.home) .entry-content,
.blog:not(.home) .entry-meta,
.archive .entry-content,
.search .entry-content,
.archive .entry-meta,
.search .entry-meta {
  font-size: 16px;
  line-height: 1.6;
}

.entry-title,
.archive-title {
  font-family: var(--ss-font-heading);
  font-size: clamp(42px, 7vw, 74px);
  font-weight: var(--ss-font-heading-weight);
  line-height: 0.98;
  margin: 0 0 24px;
}

.ss-entry-lead {
  color: var(--ss-brick-dark);
  font-family: var(--ss-font-heading);
  font-size: clamp(23px, 2.35vw, 32px);
  font-weight: var(--ss-font-heading-weight);
  line-height: 1.22;
  margin: 0 0 32px;
}

.entry-content h2,
.entry-content h3 {
  font-family: var(--ss-font-heading);
  font-weight: var(--ss-font-heading-weight);
  line-height: 1.12;
}

.entry-content .alignright,
.entry-content .wp-block-image.alignright {
  float: right;
  margin: 8px 0 24px 32px;
  max-width: min(46%, 420px);
}

.entry-content .alignleft,
.entry-content .wp-block-image.alignleft {
  float: left;
  margin: 8px 32px 24px 0;
  max-width: min(46%, 420px);
}

.entry-content .aligncenter,
.entry-content .wp-block-image.aligncenter {
  clear: both;
  margin-left: auto;
  margin-right: auto;
}

.entry-content::after {
  clear: both;
  content: "";
  display: table;
}

.entry-content .slx-section,
.entry-content .slx-organi,
.entry-content .slx-comitati {
  margin-left: auto;
  margin-right: auto;
  max-width: 1060px;
}

.entry-content .slx-section {
  background: transparent !important;
  padding: 18px 0 38px;
}

.entry-content .slx-section > p,
.entry-content .slx-excerpt-text,
.entry-content .slx-organi > p,
.entry-content .slx-comitati > p {
  color: var(--ss-ink);
  font-size: clamp(18px, 1.45vw, 22px);
  line-height: 1.75;
  max-width: 920px;
}

.entry-content .slx-anchors {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  list-style: none;
  margin: 22px 0 46px;
  padding: 0;
}

.entry-content .slx-anchors a {
  align-items: center;
  border: 1px solid var(--ss-stone);
  color: var(--ss-brick-dark);
  display: inline-flex;
  font-size: 13px;
  font-weight: 800;
  min-height: 38px;
  padding: 0 14px;
  text-decoration: none;
}

.entry-content .slx-anchors a:hover,
.entry-content .slx-anchors a:focus {
  background: var(--ss-brick);
  border-color: var(--ss-brick);
  color: var(--ss-white);
}

.entry-content .slx-organi .wp-block-columns,
.entry-content .slx-comitati .wp-block-columns {
  align-items: stretch;
  gap: 28px;
  margin: 34px 0;
}

.entry-content .slx-comitati .wp-block-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.entry-content .slx-organi .wp-block-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.entry-content .slx-organi .wp-block-column,
.entry-content .slx-comitati .wp-block-column {
  background: var(--ss-white);
  border: 1px solid color-mix(in srgb, var(--ss-brick-dark) 14%, transparent);
  box-shadow: 0 18px 54px rgba(28, 26, 24, 0.05);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  min-height: 300px;
  padding: clamp(26px, 4vw, 54px);
  text-align: center;
}

.entry-content .slx-comitati .wp-block-column {
  min-height: 300px;
  padding: 34px 24px;
}

.entry-content .slx-organi h2,
.entry-content .slx-organi h3,
.entry-content .slx-comitati h2,
.entry-content .slx-comitati h3,
.entry-content .slx-excerpt-title {
  color: var(--ss-brick-dark);
  letter-spacing: 0;
}

.entry-content .slx-organi h2,
.entry-content .slx-organi h3,
.entry-content .slx-comitati h3 {
  font-size: clamp(24px, 2.2vw, 34px);
  line-height: 1.12;
  margin: 0 0 22px;
}

.entry-content .slx-comitati .wp-block-column h3 {
  font-size: clamp(19px, 1.45vw, 25px);
  hyphens: manual;
  overflow-wrap: normal;
  text-wrap: balance;
  word-break: normal;
}

.entry-content .slx-excerpt-title {
  font-size: clamp(30px, 3.2vw, 44px);
  line-height: 1.12;
  margin: 52px 0 18px;
}

.entry-content .slx-organi .wp-block-column p,
.entry-content .slx-comitati .wp-block-column p {
  color: var(--ss-ink);
  font-size: 17px;
  line-height: 1.75;
  margin-left: auto;
  margin-right: auto;
}

.entry-content .slx-comitati .wp-block-column p {
  color: color-mix(in srgb, var(--ss-brick-dark) 72%, var(--ss-ink));
  font-size: 14px;
  line-height: 1.55;
}

.entry-content .slx-comitati figure,
.entry-content .slx-organi figure {
  margin: 0 auto 24px;
}

.entry-content .slx-comitati figure img,
.entry-content .slx-organi figure img {
  aspect-ratio: 1;
  border: 4px solid var(--ss-white);
  border-radius: 999px;
  box-shadow: 0 12px 30px rgba(28, 26, 24, 0.16);
  height: 142px;
  margin: 0 auto;
  object-fit: cover;
  width: 142px;
}

.entry-content .slx-organi .wp-block-column:empty,
.entry-content .slx-comitati .wp-block-column:empty {
  display: none;
}

.is-style-altfont,
.is-style-altfont *,
.has-alt-font,
.has-alt-font * {
  font-family: var(--ss-font-alt);
  font-weight: var(--ss-font-alt-weight);
}

.breadcrumb,
.ss-breadcrumb {
  color: var(--ss-muted);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin: 0 auto 24px;
  max-width: var(--ss-max);
  padding: 0 24px;
  text-transform: uppercase;
}

.breadcrumb a,
.ss-breadcrumb a {
  color: var(--ss-brick-dark);
  text-decoration: none;
}

.breadcrumb span,
.ss-breadcrumb span {
  display: inline-block;
  margin-left: 8px;
}

.ss-layout-narrow-content .site-inner {
  max-width: 860px;
}

.ss-layout-wide-content .site-inner {
  max-width: 1380px;
}

.button,
.wp-block-button__link,
.ss-button {
  align-items: center;
  background: var(--ss-brick);
  border: 1px solid var(--ss-brick);
  color: var(--ss-white);
  display: inline-flex;
  font-size: 14px;
  font-weight: 800;
  justify-content: center;
  letter-spacing: 0.06em;
  min-height: 46px;
  padding: 0 22px;
  text-decoration: none;
  text-transform: uppercase;
}

.button:hover,
.button:focus,
.wp-block-button__link:hover,
.wp-block-button__link:focus,
.ss-button:hover,
.ss-button:focus {
  background: var(--ss-brick-dark);
  border-color: var(--ss-brick-dark);
  color: var(--ss-white);
}

.ss-button.is-secondary {
  background: transparent;
  color: var(--ss-ink);
}

.ss-kicker {
  color: var(--ss-brick);
  display: block;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.12em;
  margin-bottom: 14px;
  text-transform: uppercase;
}

.ss-hero {
  background: var(--ss-ink);
  color: var(--ss-hero-text);
  min-height: calc(100vh - 84px);
  position: relative;
}

.ss-hero::before {
  background:
    linear-gradient(90deg, rgba(var(--ss-hero-overlay-rgb), var(--ss-hero-overlay-opacity)), rgba(var(--ss-hero-overlay-rgb), calc(var(--ss-hero-overlay-opacity) * 0.48))),
    var(--ss-hero-image, linear-gradient(135deg, #2f3129, #8d3f2d));
  background-position: center;
  background-size: cover;
  content: "";
  inset: 0;
  position: absolute;
}

.ss-hero__inner {
  align-items: end;
  display: grid;
  gap: 36px;
  grid-template-columns: minmax(0, 1fr) 340px;
  min-height: calc(100vh - 84px);
  padding-bottom: 80px;
  padding-top: 110px;
  position: relative;
}

.ss-hero h1 {
  font-family: var(--ss-font-heading);
  font-size: clamp(44px, 6.8vw, 82px);
  line-height: 0.96;
  margin: 0 0 28px;
  max-width: 950px;
}

.ss-hero p,
.ss-hero__text {
  color: var(--ss-hero-text);
  font-size: clamp(18px, 1.8vw, 23px);
  line-height: 1.5;
  margin: 0;
  max-width: 720px;
}

.ss-hero__text p {
  margin: 0 0 12px;
}

.ss-hero__panel {
  border-left: 4px solid var(--ss-hero-kicker);
  padding-left: 22px;
}

.ss-hero__panel strong,
.ss-hero__panel-text {
  display: block;
  font-family: var(--ss-font-heading);
  font-size: 26px;
  line-height: 1.1;
  margin-bottom: 12px;
}

.ss-hero__panel-text p {
  margin: 0 0 12px;
}

.ss-hero .ss-kicker {
  color: var(--ss-hero-kicker);
}

.ss-hero .ss-button {
  background: var(--ss-hero-button-bg);
  border-color: var(--ss-hero-button-bg);
  color: var(--ss-hero-button-text);
}

.ss-band {
  padding: 88px 0;
}

.ss-band.is-white {
  background: var(--ss-white);
}

.ss-band.is-paper {
  background: var(--ss-paper);
}

.ss-band.is-stone {
  background: var(--ss-stone);
}

.ss-promos {
  background: var(--ss-promos-bg);
  color: var(--ss-promos-text);
}

.ss-activities {
  background: var(--ss-activities-bg);
  color: var(--ss-activities-text);
}

.ss-latest {
  background: var(--ss-latest-bg);
  color: var(--ss-latest-text);
}

.ss-center-intro {
  background: var(--ss-center-intro-bg);
  color: var(--ss-center-text);
}

.ss-center-map {
  background: var(--ss-center-map-bg);
  color: var(--ss-center-text);
}

.ss-section-head {
  align-items: end;
  display: grid;
  gap: 28px;
  grid-template-columns: minmax(0, 1fr) auto;
  margin-bottom: 40px;
}

.ss-section-head h2 {
  font-family: var(--ss-font-heading);
  font-size: clamp(38px, 5vw, 70px);
  line-height: 0.96;
  margin: 0;
}

.ss-section-head p,
.ss-section-head__text {
  color: var(--ss-muted);
  margin: 0;
  max-width: 540px;
}

.ss-section-head__text p {
  margin: 0 0 12px;
}

.ss-grid {
  display: grid;
  gap: 24px;
}

.ss-grid.is-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ss-grid.is-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ss-card {
  background: var(--ss-activities-card-bg);
  border: 1px solid rgba(28, 26, 24, 0.14);
  color: var(--ss-ink);
  display: flex;
  flex-direction: column;
  min-height: 280px;
  padding: 28px;
  text-decoration: none;
}

.ss-latest .ss-card {
  padding: 0;
}

.ss-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: 28px;
}

.ss-card__image {
  display: block;
  overflow: hidden;
}

.ss-card__image img {
  aspect-ratio: 16 / 10;
  object-fit: cover;
  width: 100%;
}

.ss-card:hover,
.ss-card:focus {
  border-color: var(--ss-brick);
  box-shadow: var(--ss-shadow);
  color: var(--ss-ink);
}

.ss-card h3 {
  font-family: var(--ss-font-heading);
  font-size: 31px;
  line-height: 1.08;
  margin: 0 0 18px;
}

.ss-card p {
  color: var(--ss-muted);
  margin: 0;
}

.ss-card__text p {
  margin: 0 0 12px;
}

.ss-activity-card .ss-card__button {
  align-self: flex-start;
  margin-top: auto;
}

.ss-card__meta {
  color: var(--ss-activities-accent);
  display: block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.1em;
  margin-bottom: 18px;
  text-transform: uppercase;
}

.ss-card__event-meta {
  color: var(--ss-brick-dark);
  font-size: 14px;
  font-weight: 800;
  line-height: 1.45;
  margin: 0 0 14px;
}

.ss-card__button {
  align-items: center;
  border: 1px solid var(--ss-brick);
  color: var(--ss-brick-dark);
  display: inline-flex;
  font-size: 12px;
  font-weight: 800;
  justify-content: center;
  letter-spacing: 0.08em;
  margin-top: auto;
  min-height: 40px;
  padding: 0 16px;
  text-decoration: none;
  text-transform: uppercase;
}

.ss-card__button:hover,
.ss-card__button:focus {
  background: var(--ss-brick);
  color: var(--ss-white);
}

.ss-archive-card-label {
  color: var(--ss-activities-accent);
  display: block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.1em;
  margin-bottom: 14px;
  text-transform: uppercase;
}

.ss-archive-card-action {
  margin: auto 28px 28px;
}

.ss-archive-card-action a {
  align-items: center;
  border: 1px solid var(--ss-brick);
  color: var(--ss-brick-dark);
  display: inline-flex;
  font-size: 12px;
  font-weight: 800;
  justify-content: center;
  letter-spacing: 0.08em;
  min-height: 40px;
  padding: 0 16px;
  text-decoration: none;
  text-transform: uppercase;
}

.ss-archive-card-action a:hover,
.ss-archive-card-action a:focus {
  background: var(--ss-brick);
  color: var(--ss-white);
}

.post-type-archive-ss_event .entry,
.tax-ss_event_category .entry {
  border-left: 5px solid var(--ss-gold);
}

.post-type-archive-ss_publication .entry {
  border-top: 5px solid var(--ss-olive);
}

.ss-quick-links {
  background: var(--ss-white);
  border-bottom: 1px solid rgba(28, 26, 24, 0.12);
  border-top: 1px solid rgba(28, 26, 24, 0.12);
}

.ss-quick-links__inner {
  align-items: center;
  display: grid;
  gap: 22px;
  grid-template-columns: auto minmax(0, 1fr);
  min-height: 92px;
}

.ss-quick-links h2 {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.1em;
  margin: 0;
  text-transform: uppercase;
}

.ss-quick-links__nav {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ss-quick-links__nav a {
  align-items: center;
  background: var(--ss-paper);
  color: var(--ss-ink);
  display: flex;
  font-weight: 800;
  justify-content: space-between;
  min-height: 52px;
  padding: 0 18px;
  text-decoration: none;
}

.ss-quick-links__nav a::after {
  content: ">";
  color: var(--ss-brick);
  font-weight: 800;
}

.ss-quick-links__nav a:hover,
.ss-quick-links__nav a:focus {
  background: var(--ss-brick);
  color: var(--ss-white);
}

.ss-quick-links__nav a:hover::after,
.ss-quick-links__nav a:focus::after {
  color: var(--ss-white);
}

.ss-promo-grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ss-promo {
  background: var(--ss-promos-card-bg);
  border-top: 6px solid var(--ss-promos-accent);
  color: var(--ss-promos-text);
  min-height: 330px;
  padding: clamp(30px, 4vw, 52px);
  text-decoration: none;
}

.ss-promo:hover,
.ss-promo:focus {
  box-shadow: var(--ss-shadow);
  color: var(--ss-ink);
}

.ss-promo h3 {
  font-family: var(--ss-font-heading);
  font-size: clamp(34px, 4vw, 56px);
  line-height: 0.98;
  margin: 0 0 20px;
}

.ss-promo p {
  color: var(--ss-promos-text);
  margin: 0;
  max-width: 620px;
}

.ss-promo__action {
  color: var(--ss-promos-accent);
  display: inline-block;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.1em;
  margin-top: 34px;
  text-transform: uppercase;
}

.ss-feature {
  align-items: stretch;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
}

.ss-feature__image {
  background: linear-gradient(135deg, var(--ss-olive), var(--ss-brick));
  min-height: 520px;
}

.ss-feature__image img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.ss-feature__content {
  align-content: center;
  background: var(--ss-mission-bg);
  color: var(--ss-mission-text);
  display: grid;
  padding: clamp(42px, 6vw, 82px);
}

.ss-feature__content p {
  color: var(--ss-mission-text);
}

.ss-feature__content .ss-kicker {
  color: var(--ss-mission-accent);
}

.ss-feature__content h2 {
  font-family: var(--ss-font-heading);
  font-size: clamp(40px, 5vw, 68px);
  line-height: 0.98;
  margin: 0 0 22px;
}

.ss-notice {
  background: var(--ss-notice-bg);
  color: var(--ss-notice-text);
  padding: 28px;
}

.ss-notice h2,
.ss-notice p {
  margin: 0;
}

.ss-notice h2 {
  font-family: var(--ss-font-heading);
  font-size: clamp(26px, 3vw, 40px);
  line-height: 1.05;
}

.ss-notice p {
  color: var(--ss-notice-text);
  margin-top: 10px;
}

.ss-notice a {
  color: var(--ss-white);
  text-decoration: none;
}

.ss-notice .ss-card__meta,
.ss-notice__event-meta,
.ss-notice__event-place {
  color: var(--ss-gold);
}

.ss-home-events {
  display: grid;
  gap: 24px;
  margin-top: 18px;
}

.ss-home-events.is-count-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ss-home-events.is-count-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ss-home-event {
  min-width: 0;
}

.ss-home-event h2 {
  margin: 0 0 14px;
}

.ss-home-event p {
  margin-bottom: 0;
}

.ss-home-event .ss-notice__event-meta,
.ss-home-event .ss-notice__event-place {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.05em;
  line-height: 1.4;
  margin: 0 0 8px;
  text-transform: uppercase;
}

.ss-event-detail-link {
  align-items: center;
  border: 1px solid var(--ss-gold);
  color: var(--ss-white);
  display: inline-flex;
  font-size: 12px;
  font-weight: 800;
  justify-content: center;
  letter-spacing: 0.08em;
  margin-top: 20px;
  min-height: 40px;
  padding: 0 16px;
  text-decoration: none;
  text-transform: uppercase;
}

.ss-event-detail-link:hover,
.ss-event-detail-link:focus {
  background: var(--ss-gold);
  color: var(--ss-ink);
}

.site-footer {
  background: var(--ss-footer-bg);
  color: var(--ss-footer-text);
  font-size: 15px;
  padding: 0;
}

.site-footer a {
  color: var(--ss-footer-link);
}

.ss-before-footer {
  background: var(--ss-before-footer-bg);
  color: var(--ss-before-footer-text);
  padding: 46px 0;
}

.ss-before-footer a {
  color: var(--ss-before-footer-link);
}

.ss-before-footer .widget {
  margin: 0;
}

.ss-before-footer .widget-title,
.ss-before-footer h2,
.ss-before-footer h3 {
  font-family: var(--ss-font-heading);
  font-weight: var(--ss-font-heading-weight);
  line-height: 1.1;
  margin-top: 0;
}

.footer-widgets {
  background: var(--ss-footer-bg);
  color: var(--ss-footer-text);
  font-size: var(--ss-footer-text-size);
  padding: var(--ss-footer-padding-y) 0 calc(var(--ss-footer-padding-y) * 0.76);
}

.footer-widgets a,
.footer-brand a,
.footer-newsletter a {
  color: var(--ss-footer-link);
}

.footer-widgets .wrap,
.footer-main-grid {
  display: grid;
  gap: clamp(34px, 5vw, 72px);
  grid-template-columns: minmax(280px, 1.1fr) minmax(220px, 0.8fr) minmax(270px, 0.95fr);
}

.footer-brand {
  border-right: 1px solid rgba(255, 253, 248, 0.16);
  padding-right: clamp(30px, 4vw, 58px);
  text-align: left;
}

.footer-logo-text {
  color: var(--ss-footer-link);
  font-family: var(--ss-font-heading);
  font-size: 30px;
  line-height: 1;
}

.footer-logo img {
  height: auto;
  margin-bottom: 28px;
  max-width: min(100%, var(--ss-footer-logo-width));
  width: var(--ss-footer-logo-width);
}

.footer-brand-title {
  line-height: 1.25;
  margin-bottom: 18px;
  margin-top: 0;
  max-width: 360px;
}

.footer-info p {
  color: var(--ss-footer-text);
  line-height: 1.55;
  margin: 0 0 15px;
}

.footer-intro {
  color: var(--ss-footer-text);
  margin: 0;
  max-width: 360px;
}

.footer-menu ul {
  display: grid;
  gap: 13px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-menu a {
  color: var(--ss-footer-link);
  font-size: var(--ss-footer-text-size);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-decoration: none;
  text-transform: uppercase;
}

.footer-links-column {
  text-align: left;
}

.footer-newsletter {
  border-right: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
}

.footer-newsletter p {
  margin-top: 0;
  max-width: 360px;
}

.ss-footer-link {
  align-items: center;
  color: var(--ss-footer-link);
  display: inline-flex;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  border: 1px solid var(--ss-gold);
  justify-content: center;
  margin-top: 18px;
  min-height: 48px;
  padding: 0 24px;
  text-decoration: none;
  text-transform: uppercase;
}

.footer-widgets h3 {
  color: var(--ss-footer-link);
  font-family: var(--ss-font-heading);
  font-size: var(--ss-footer-title-size);
  letter-spacing: 0.08em;
  margin-top: 0;
  text-transform: uppercase;
}

.footer-social {
  display: flex;
  gap: 10px;
  justify-content: flex-start;
  margin-top: 30px;
}

.footer-social a {
  align-items: center;
  background: rgba(255, 253, 248, 0.08);
  border: 1px solid rgba(255, 253, 248, 0.28);
  border-radius: 999px;
  color: var(--ss-footer-link);
  display: inline-flex;
  font-size: 12px;
  font-weight: 800;
  height: 34px;
  justify-content: center;
  min-width: 34px;
  padding: 0 8px;
  text-decoration: none;
  text-transform: uppercase;
}

.footer-social .dashicons {
  font-size: 17px;
  height: 17px;
  line-height: 17px;
  width: 17px;
}

.ss-event-meta {
  color: var(--ss-brick-dark);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.06em;
  margin: -10px 0 24px;
  text-transform: uppercase;
}

.footer-social a:hover,
.footer-social a:focus {
  border-color: var(--ss-footer-link);
}

.site-footer .wrap {
  align-items: center;
  display: flex;
  gap: 24px;
  justify-content: space-between;
  min-height: 68px;
}

.site-footer .creds {
  align-items: center;
  display: flex;
  gap: 24px;
  justify-content: space-between;
  margin: 0;
  width: 100%;
}

.footer-credits-text {
  color: var(--ss-footer-text);
}

.footer-credits-menu {
  margin-left: auto;
}

.footer-legal-links {
  margin-left: 0;
}

.footer-credits-menu ul {
  display: flex;
  gap: 28px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-credits-menu a {
  font-weight: 800;
  text-decoration: none;
}

@media (max-width: 960px) {
  .content-sidebar-wrap,
  .ss-hero__inner,
  .ss-section-head,
  .ss-feature,
  .footer-brand {
    grid-template-columns: 1fr;
  }

  .ss-grid.is-4,
  .ss-grid.is-3,
  .ss-promo-grid,
  .footer-widgets .wrap,
  .footer-main-grid {
    grid-template-columns: 1fr;
  }

  .blog:not(.home) .content,
  .archive .content,
  .search .content {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .entry-content .slx-comitati .wp-block-columns,
  .entry-content .slx-organi .wp-block-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footer-brand,
  .footer-links-column,
  .footer-newsletter {
    border-bottom: 1px solid rgba(255, 253, 248, 0.16);
    border-right: 0;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 30px;
    text-align: left;
  }

  .footer-newsletter {
    border-bottom: 0;
  }

  .footer-logo img,
  .footer-intro {
    margin-left: 0;
    margin-right: 0;
  }

  .footer-social {
    justify-content: flex-start;
  }

  .site-header .wrap {
    display: grid;
    gap: 14px 18px;
    grid-template-columns: minmax(0, 1fr) auto;
    justify-items: stretch;
    padding-bottom: 16px;
    padding-top: 16px;
  }

  .title-area {
    max-width: none;
    order: 1;
    text-align: left;
  }

  .custom-logo {
    max-width: 150px;
    width: min(var(--ss-logo-width), 150px) !important;
  }

  .menu-toggle {
    align-self: center;
    display: inline-flex;
    height: 44px;
    justify-content: center;
    justify-self: end;
    min-height: 44px;
    order: 2;
    padding: 0;
    width: 44px;
  }

  .ss-topbar .wrap {
    align-items: stretch;
    flex-direction: column;
  }

  .ss-header-actions {
    align-items: stretch;
    display: grid;
    flex-basis: 100%;
    grid-column: 1 / -1;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-left: 0;
    order: 4;
    width: 100%;
  }

  .site-header .nav-primary {
    display: none;
  }

  .ss-page-header__inner {
    grid-template-columns: 1fr;
    min-height: auto;
    padding-bottom: 48px;
    padding-top: 48px;
  }

  .ss-header-actions {
    display: none;
  }

  .ss-mobile-menu-open {
    overflow: hidden;
  }

  .ss-mobile-nav {
    background: var(--ss-ink);
    color: var(--ss-white);
    display: block;
    inset: 0;
    opacity: 0;
    overflow-y: auto;
    pointer-events: none;
    position: fixed;
    transform: translateY(14px);
    transition: opacity 180ms ease, transform 180ms ease;
    z-index: 999;
  }

  .ss-mobile-nav.is-open {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  .ss-mobile-nav__inner {
    display: grid;
    gap: 34px;
    min-height: 100vh;
    padding: 28px 28px 54px;
  }

  .ss-mobile-nav__head {
    align-items: center;
    display: flex;
    gap: 24px;
    justify-content: space-between;
  }

  .ss-mobile-nav__logo {
    display: inline-flex;
    max-width: 150px;
  }

  .ss-mobile-nav__logo img,
  .ss-mobile-nav__logo .custom-logo {
    max-width: 150px;
    width: min(var(--ss-logo-width), 150px) !important;
  }

  .ss-mobile-nav__logo.is-filtered .custom-logo {
    filter: brightness(0) invert(1);
  }

  .ss-mobile-nav__name {
    color: var(--ss-white);
    font-family: var(--ss-font-heading);
    font-size: 24px;
    line-height: 1;
    text-decoration: none;
  }

  .ss-mobile-nav__close {
    background: transparent;
    border: 1px solid rgba(255, 253, 248, 0.32);
    color: var(--ss-white);
    cursor: pointer;
    display: inline-flex;
    font-size: 34px;
    height: 48px;
    justify-content: center;
    justify-self: end;
    line-height: 1;
    padding: 0;
    width: 48px;
  }

  .ss-mobile-menu,
  .ss-mobile-menu .sub-menu {
    display: grid;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .ss-mobile-menu a {
    border-top: 1px solid rgba(255, 253, 248, 0.18);
    color: var(--ss-white);
    display: block;
    font-family: var(--ss-font-heading);
    font-size: clamp(28px, 8vw, 46px);
    font-weight: var(--ss-font-heading-weight);
    letter-spacing: 0;
    line-height: 1.05;
    padding: 18px 0;
    text-decoration: none;
    text-transform: none;
  }

  .ss-mobile-menu .sub-menu {
    padding: 0 0 10px 18px;
  }

  .ss-mobile-menu .sub-menu a {
    border-top: 0;
    font-family: var(--ss-font-body);
    font-size: 17px;
    font-weight: 800;
    letter-spacing: 0.04em;
    line-height: 1.35;
    padding: 8px 0;
    text-transform: uppercase;
  }

  .ss-mobile-nav__actions {
    display: grid;
    gap: 12px;
    margin-top: auto;
  }

  .ss-mobile-action {
    align-items: center;
    border: 1px solid rgba(255, 253, 248, 0.42);
    color: var(--ss-white);
    display: inline-flex;
    font-size: 13px;
    font-weight: 800;
    justify-content: center;
    letter-spacing: 0.08em;
    min-height: 48px;
    padding: 0 18px;
    text-decoration: none;
    text-transform: uppercase;
  }

  .ss-mobile-action.is-primary {
    background: var(--ss-gold);
    border-color: var(--ss-gold);
    color: var(--ss-ink);
  }

  .footer-brand {
    grid-template-columns: 1fr;
  }

  .footer-menu ul {
    justify-content: flex-start;
  }

  .site-footer .wrap,
  .site-footer .creds,
  .footer-credits-menu ul {
    align-items: flex-start;
    flex-direction: column;
  }

  .footer-credits-menu {
    margin-left: 0;
    margin-top: 12px;
  }
}

@media (max-width: 640px) {
  body {
    font-size: 17px;
  }

  .ss-topbar {
    display: none;
  }

  .wrap,
  .ss-wrap {
    padding-left: 18px;
    padding-right: 18px;
  }

  .entry {
    padding: 30px 22px;
  }

  .entry-content .alignright,
  .entry-content .alignleft,
  .entry-content .wp-block-image.alignright,
  .entry-content .wp-block-image.alignleft {
    float: none;
    margin: 0 0 24px;
    max-width: 100%;
  }

  .blog:not(.home) .content,
  .archive .content,
  .search .content {
    gap: 22px;
    grid-template-columns: 1fr;
  }

  .blog:not(.home) .entry-header,
  .blog:not(.home) .entry-content,
  .archive .entry-header,
  .search .entry-header,
  .archive .entry-content,
  .search .entry-content {
    padding-left: 22px;
    padding-right: 22px;
  }

  .entry-content .slx-organi,
  .entry-content .slx-comitati {
    max-width: 100%;
  }

  .entry-content .slx-organi .wp-block-columns,
  .entry-content .slx-comitati .wp-block-columns {
    display: grid;
    gap: 22px;
    grid-template-columns: 1fr;
    margin: 24px 0;
  }

  .entry-content .slx-organi .wp-block-column,
  .entry-content .slx-comitati .wp-block-column {
    min-height: 0;
    padding: 30px 24px;
  }

  .entry-content .slx-excerpt-title {
    margin-top: 38px;
  }

  .ss-band {
    padding: 64px 0;
  }

  .ss-grid.is-4,
  .ss-grid.is-3,
  .ss-promo-grid,
  .footer-widgets .wrap,
  .footer-main-grid {
    grid-template-columns: 1fr;
  }

  .site-header .wrap {
    align-items: center;
    justify-items: stretch;
    min-height: 0;
    padding-bottom: 12px;
    padding-top: 12px;
  }

  .title-area {
    max-width: none;
    text-align: left;
  }

  .custom-logo {
    max-width: 96px;
    width: min(var(--ss-logo-width), 96px) !important;
  }

  .menu-toggle {
    height: 42px;
    min-height: 42px;
    width: 42px;
  }

  .ss-header-actions {
    gap: 8px;
    grid-template-columns: 1fr;
  }

  .ss-header-action {
    min-height: 38px;
    width: 100%;
  }

  .ss-page-header h1,
  .entry-title,
  .archive-title,
  .single-post .ss-page-header h1 {
    font-size: clamp(30px, 10vw, 42px);
    line-height: 1.04;
  }

  .ss-page-header__inner {
    padding-bottom: 38px;
    padding-top: 38px;
  }

  .ss-page-header p {
    font-size: 16px;
    line-height: 1.45;
  }

  .ss-entry-lead {
    font-size: clamp(21px, 6.4vw, 28px);
    line-height: 1.22;
    margin-bottom: 26px;
  }

  .footer-widgets {
    padding: 48px 0 34px;
  }

  .footer-logo img {
    margin-bottom: 22px;
    max-width: 180px;
  }

  .site-footer .wrap {
    min-height: 0;
    padding-bottom: 24px;
    padding-top: 24px;
  }

  .ss-hero {
    min-height: 0;
  }

  .ss-hero__inner {
    align-items: start;
    gap: 26px;
    min-height: 0;
    padding-bottom: 56px;
    padding-top: 68px;
  }

  .ss-hero h1 {
    font-size: clamp(36px, 12vw, 48px);
    line-height: 0.98;
    margin-bottom: 18px;
  }

  .ss-hero .ss-kicker {
    font-size: 11px;
    letter-spacing: 0.09em;
    margin-bottom: 12px;
  }

  .ss-hero p,
  .ss-hero__text {
    font-size: 16px;
    line-height: 1.48;
  }

  .ss-hero__text p:not(:first-child) {
    display: none;
  }

  .ss-hero__panel {
    border-left-width: 3px;
    padding-left: 16px;
  }

  .ss-hero__panel-text {
    font-size: 20px;
    line-height: 1.18;
  }

  .ss-band {
    padding: 48px 0;
  }

  .ss-quick-links__inner {
    align-items: stretch;
    gap: 14px;
    grid-template-columns: 1fr;
    padding-bottom: 22px;
    padding-top: 22px;
  }

  .ss-quick-links__nav {
    grid-template-columns: 1fr;
  }

  .ss-quick-links__nav a {
    min-height: 46px;
  }

  .ss-section-head {
    gap: 14px;
    margin-bottom: 24px;
  }

  .ss-section-head h2 {
    font-size: clamp(30px, 10vw, 42px);
    line-height: 1;
  }

  .ss-section-head__text,
  .ss-section-head p {
    font-size: 16px;
    line-height: 1.45;
  }

  .ss-promo,
  .ss-card {
    min-height: 0;
    padding: 22px;
  }

  .ss-latest .ss-card {
    padding: 0;
  }

  .ss-card__body {
    padding: 22px;
  }

  .ss-card h3 {
    font-size: 26px;
    line-height: 1.08;
  }

  .ss-archive-card-action {
    margin: auto 22px 22px;
  }

  .ss-card p,
  .ss-card__text {
    font-size: 16px;
    line-height: 1.48;
  }

  .ss-promo h3 {
    font-size: clamp(28px, 9vw, 38px);
  }

  .ss-feature__image {
    min-height: 260px;
  }

  .ss-feature__content {
    padding: 34px 22px;
  }

  .ss-feature__content h2 {
    font-size: clamp(30px, 10vw, 42px);
  }

  .ss-notice {
    padding: 22px;
  }

  .ss-notice h2 {
    font-size: clamp(24px, 8vw, 34px);
  }

  .ss-home-events {
    gap: 22px;
  }

  .ss-home-events.is-count-2,
  .ss-home-events.is-count-3 {
    grid-template-columns: 1fr;
  }
}
