:root {
  --cidme-blue: #0759a6;
  --cidme-navy: #102033;
  --cidme-cyan: #00a0c8;
  --cidme-green: #51a35f;
  --cidme-paper: #f4f7f8;
  --cidme-ink: #1d2835;
  --cidme-muted: #667281;
  --cidme-line: #dce5ec;
}

* {
  letter-spacing: 0;
}

body {
  color: var(--cidme-ink);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.5;
}

a {
  text-decoration: none;
}

.draft-tabs {
  display: grid;
  gap: .35rem;
  left: .65rem;
  position: fixed;
  top: calc(.65rem + 50px);
  z-index: 1300;
}

.draft-tabs a {
  align-items: center;
  background: rgba(245, 247, 250, .94);
  border: 1px solid #dfe7ef;
  border-radius: 999px;
  box-shadow: 0 10px 28px rgba(16, 32, 51, .14);
  color: #344052;
  display: inline-flex;
  font-size: .74rem;
  font-weight: 900;
  height: 34px;
  justify-content: center;
  width: 42px;
}

.draft-tabs a.active {
  background: var(--cidme-navy);
  border-color: var(--cidme-navy);
  color: #fff;
}

.cidme-navbar {
  background: rgba(12, 24, 38, .82);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255, 255, 255, .12);
}

.cidme-navbar .navbar-brand,
.cidme-navbar .nav-link {
  color: #fff;
}

.cidme-navbar .nav-link {
  font-weight: 650;
  opacity: .82;
}

.cidme-navbar .nav-link:hover,
.cidme-navbar .nav-link.active {
  color: #fff;
  opacity: 1;
}

.inner-nav {
  position: static;
  background: var(--cidme-navy);
}

.light-nav {
  background: rgba(255, 255, 255, .9);
}

.light-nav .navbar-brand,
.light-nav .nav-link {
  color: var(--cidme-navy);
}

.navbar-brand {
  align-items: center;
  display: inline-flex;
  font-weight: 800;
  gap: .55rem;
}

.brand-mark {
  align-items: center;
  background: linear-gradient(135deg, var(--cidme-blue), var(--cidme-cyan));
  border-radius: 7px;
  color: #fff;
  display: inline-flex;
  height: 34px;
  justify-content: center;
  width: 34px;
}

.brand-logo {
  display: block;
  height: 48px;
  object-fit: contain;
  width: auto;
}

.light-nav .brand-logo {
  height: 52px;
}

.footer-logo {
  display: block;
  height: auto;
  max-width: 210px;
  width: 100%;
}

.hero {
  color: #fff;
  min-height: 720px;
  position: relative;
}

.hero-electric {
  background:
    linear-gradient(90deg, rgba(11, 26, 43, .92), rgba(11, 26, 43, .56), rgba(11, 26, 43, .18)),
    linear-gradient(135deg, rgba(0, 160, 200, .22), transparent 42%),
    url("https://images.unsplash.com/photo-1498084393753-b411b2d26b34?auto=format&fit=crop&w=1800&q=80") center/cover;
}

.hero h1,
.hero-b h1 {
  font-size: clamp(2.55rem, 5.8vw, 5.5rem);
  font-weight: 850;
  line-height: .98;
  max-width: 980px;
}

.hero-copy,
.hero-b p {
  font-size: 1.22rem;
  max-width: 700px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  margin-top: 1.75rem;
}

.eyebrow {
  color: #8ce8ff;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: 0;
  margin-bottom: .8rem;
  text-transform: uppercase;
}

.eyebrow.dark {
  color: var(--cidme-blue);
}

.section-pad {
  padding: 5.5rem 0;
}

.page-top {
  min-height: 78vh;
}

.section-head {
  align-items: end;
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  margin-bottom: 1.7rem;
}

.section-head h2,
.page-top h1 {
  font-weight: 820;
  margin: 0;
}

.link-arrow {
  color: var(--cidme-blue);
  font-weight: 750;
  white-space: nowrap;
}

.stat-card,
.content-card,
.map-panel,
.contact-box,
.contact-form,
.admin-card,
.admin-panel {
  background: #fff;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  box-shadow: 0 18px 48px rgba(16, 32, 51, .08);
}

.stat-card {
  min-height: 142px;
  padding: 1.3rem;
}

.stat-card strong {
  color: var(--cidme-blue);
  display: block;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1;
}

.stat-card span {
  color: var(--cidme-muted);
  display: block;
  font-weight: 700;
  margin-top: .65rem;
}

.image-slider {
  border-radius: 8px;
  box-shadow: 0 24px 70px rgba(16, 32, 51, .18);
  overflow: hidden;
}

.image-slider.compact {
  box-shadow: none;
}

.slide-img {
  min-height: 420px;
}

.compact .slide-img {
  min-height: 520px;
}

.slide-one {
  background: linear-gradient(rgba(9, 28, 48, .15), rgba(9, 28, 48, .4)), url("https://images.unsplash.com/photo-1581092160562-40aa08e78837?auto=format&fit=crop&w=1500&q=80") center/cover;
}

.slide-two {
  background: linear-gradient(rgba(9, 28, 48, .12), rgba(9, 28, 48, .42)), url("https://images.unsplash.com/photo-1621905251918-48416bd8575a?auto=format&fit=crop&w=1500&q=80") center/cover;
}

.slide-three {
  background: linear-gradient(rgba(9, 28, 48, .16), rgba(9, 28, 48, .5)), url("https://images.unsplash.com/photo-1516321318423-f06f85e504b3?auto=format&fit=crop&w=1500&q=80") center/cover;
}

.carousel-caption {
  background: rgba(10, 23, 38, .72);
  border-radius: 8px;
  left: 2rem;
  padding: 1.2rem;
  right: auto;
  text-align: left;
  width: min(520px, calc(100% - 4rem));
}

.cidme-map {
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  height: 560px;
  overflow: hidden;
}

.cidme-map .leaflet-tile-pane {
  filter: grayscale(1) contrast(.96) brightness(1.04);
}

.map-full-section {
  padding-bottom: 0;
}

.map-full-wrap {
  margin-top: 1rem;
  position: relative;
}

.cidme-map-full {
  border-left: 0;
  border-right: 0;
  border-radius: 0;
  height: 680px;
  width: 100%;
}

.map-overlay-container {
  inset: 0;
  pointer-events: none;
  position: absolute;
}

.map-overlay-panel {
  margin-left: auto;
  max-width: 420px;
  padding-top: 2rem;
  pointer-events: auto;
}

.map-overlay-panel .map-panel {
  box-shadow: 0 24px 70px rgba(16, 32, 51, .18);
}

.cidme-pin span {
  border: 3px solid #fff;
  border-radius: 50%;
  box-shadow: 0 4px 12px rgba(16, 32, 51, .28);
  display: block;
  height: 22px;
  width: 22px;
}

.map-panel {
  height: 560px;
  overflow: hidden;
  padding: 1.2rem;
}

.map-list {
  display: grid;
  gap: .75rem;
  max-height: 455px;
  overflow: auto;
  padding-right: .25rem;
}

.map-item {
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  cursor: pointer;
  display: grid;
  gap: .8rem;
  grid-template-columns: 54px 1fr;
  padding: .9rem;
  transition: border-color .2s ease, transform .2s ease;
}

.map-item:hover {
  border-color: var(--cidme-blue);
  transform: translateY(-1px);
}

.map-item strong,
.map-item span {
  display: block;
  color: black;
}

.map-item span {
  color: var(--cidme-muted);
  font-size: .93rem;
}

.map-item .type {
  color: var(--cidme-blue);
  font-size: .76rem;
  font-weight: 800;
  text-transform: uppercase;
}

.map-item-logo,
.map-popup-logo {
  background: #fff;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  object-fit: contain;
}

.map-item-logo {
  height: 54px;
  padding: .35rem;
  width: 54px;
}

.map-popup {
  align-items: flex-start;
  display: flex;
  gap: .75rem;
  min-width: 230px;
}

.map-popup-logo {
  height: 50px;
  padding: .3rem;
  width: 50px;
}

.logo-fallback {
  align-items: center;
  background: linear-gradient(135deg, var(--cidme-blue), var(--cidme-cyan));
  color: #fff;
  display: inline-flex;
  font-weight: 850;
  justify-content: center;
  padding: 0;
}

.cidme-cluster {
  align-items: center;
  background: rgba(7, 89, 166, .18);
  border-radius: 50%;
  display: flex;
  justify-content: center;
}

.cidme-cluster span {
  align-items: center;
  background: var(--cidme-blue);
  border: 3px solid #fff;
  border-radius: 50%;
  box-shadow: 0 8px 22px rgba(16, 32, 51, .28);
  color: #fff;
  display: flex;
  font-weight: 850;
  height: 38px;
  justify-content: center;
  width: 38px;
}

.cidme-cluster-medium span {
  background: var(--cidme-cyan);
}

.cidme-cluster-large span {
  background: var(--cidme-green);
}

.content-card {
  height: 100%;
  overflow: hidden;
  padding: 0;
}

.content-card h2,
.content-card h3 {
  font-size: 1.25rem;
  font-weight: 780;
  margin: 1rem 0 .55rem;
}

.content-card h2 a,
.content-card h3 a,
.event-list h2 a {
  color: var(--cidme-ink);
}

.member-card {
  background: #fff;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  height: 100%;
  padding: 1.35rem;
}

.member-card img {
  height: 64px;
  margin-bottom: 1rem;
  object-fit: contain;
  object-position: left center;
  width: 150px;
}

.member-card span {
  color: var(--cidme-blue);
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.member-card h3 {
  font-size: 1.3rem;
  font-weight: 800;
  margin: .55rem 0 .35rem;
}

.member-hero-grid {
  align-items: center;
  display: grid;
  gap: 2rem;
  grid-template-columns: 1fr auto;
}

.member-logo {
  background: #fff;
  border-radius: 8px;
  max-height: 150px;
  max-width: 240px;
  object-fit: contain;
  padding: 1rem;
}

.content-card h2 a:hover,
.content-card h3 a:hover,
.event-list h2 a:hover {
  color: var(--cidme-blue);
}

.card-media-link,
.event-thumb {
  display: block;
}

.content-card .badge,
.content-card h2,
.content-card h3,
.content-card p,
.content-card small {
  margin-left: 1.35rem;
  margin-right: 1.35rem;
}

.content-card .badge {
  margin-top: 1.35rem;
}

.content-card small {
  display: block;
  margin-bottom: 1.35rem;
}

.content-card small {
  color: var(--cidme-muted);
  font-weight: 700;
}

.card-media,
.event-thumb,
.table-thumb {
  background-position: center;
  background-size: cover;
}

.card-media {
  aspect-ratio: 16 / 9;
  width: 100%;
}

.media-news {
  background-image: linear-gradient(rgba(9, 28, 48, .05), rgba(9, 28, 48, .28)), url("https://images.unsplash.com/photo-1497366811353-6870744d04b2?auto=format&fit=crop&w=900&q=80");
}

.media-event {
  background-image: linear-gradient(rgba(9, 28, 48, .08), rgba(9, 28, 48, .34)), url("https://images.unsplash.com/photo-1517048676732-d65bc937f952?auto=format&fit=crop&w=900&q=80");
}

.media-map {
  background-image: linear-gradient(rgba(9, 28, 48, .06), rgba(9, 28, 48, .3)), url("https://images.unsplash.com/photo-1524661135-423995f22d0b?auto=format&fit=crop&w=900&q=80");
}

.media-office {
  background-image: linear-gradient(rgba(9, 28, 48, .08), rgba(9, 28, 48, .32)), url("https://images.unsplash.com/photo-1551434678-e076c223a692?auto=format&fit=crop&w=900&q=80");
}

.media-supplier {
  background-image: linear-gradient(rgba(9, 28, 48, .08), rgba(9, 28, 48, .34)), url("https://images.unsplash.com/photo-1581091226825-a6a2a5aee158?auto=format&fit=crop&w=900&q=80");
}

.media-training {
  background-image: linear-gradient(rgba(9, 28, 48, .08), rgba(9, 28, 48, .32)), url("https://images.unsplash.com/photo-1517245386807-bb43f82c33c4?auto=format&fit=crop&w=900&q=80");
}

.event-list {
  display: grid;
  gap: 1rem;
}

.event-list article {
  align-items: center;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  display: grid;
  gap: 1.3rem;
  grid-template-columns: 180px 180px 1fr;
  overflow: hidden;
  padding: 0 1.2rem 0 0;
}

.event-thumb {
  align-self: stretch;
  min-height: 150px;
}

.event-list time {
  color: var(--cidme-blue);
  font-weight: 800;
}

.event-list h2 {
  font-size: 1.3rem;
  font-weight: 780;
}

.contact-box,
.contact-form {
  display: grid;
  gap: .6rem;
  padding: 1.4rem;
}

.site-footer {
  background: var(--cidme-navy);
  color: #fff;
  padding: 2.2rem 0;
}

.site-footer p {
  color: rgba(255, 255, 255, .72);
  margin: .35rem 0 0;
}

.site-footer a {
  color: #fff;
  font-weight: 700;
  margin-left: 1rem;
}

.rich-footer {
  padding: 4.5rem 0 2rem;
}

.rich-footer h2 {
  color: #fff;
  font-size: .9rem;
  font-weight: 850;
  margin-bottom: 1rem;
  text-transform: uppercase;
}

.rich-footer .footer-brand {
  color: #fff;
  margin-bottom: 1rem;
}

.footer-address,
.footer-links {
  display: grid;
  gap: .55rem;
}

.footer-address span,
.footer-newsletter small {
  color: rgba(255, 255, 255, .68);
}

.footer-links a {
  color: rgba(255, 255, 255, .82);
  font-weight: 700;
  margin: 0;
}

.footer-links a:hover {
  color: #fff;
}

.footer-newsletter .form-control {
  border-color: rgba(255, 255, 255, .24);
}

.footer-newsletter small {
  display: block;
  margin-top: .65rem;
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, .14);
  color: rgba(255, 255, 255, .66);
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: space-between;
  margin-top: 3rem;
  padding-top: 1.2rem;
}

@media (max-width: 767px) {
  .rich-footer {
    padding: 2.4rem 0 1.4rem;
  }

  .rich-footer .row {
    --bs-gutter-y: 2rem;
  }

  .rich-footer p {
    font-size: 1rem;
  }

  .footer-address {
    gap: .35rem;
  }

  .footer-address span,
  .footer-address a {
    font-size: .98rem;
  }

  .footer-menu-col,
  .footer-info-col {
    width: 50%;
  }

  .rich-footer h2 {
    font-size: .82rem;
    margin-bottom: .7rem;
  }

  .footer-links {
    gap: .42rem;
  }

  .footer-links a {
    font-size: .98rem;
    line-height: 1.25;
  }

  .footer-newsletter .input-group {
    align-items: stretch;
    display: grid;
    grid-template-columns: 1fr auto;
  }

  .footer-newsletter .form-control {
    min-width: 0;
  }

  .footer-bottom {
    font-size: .9rem;
    margin-top: 2rem;
  }
}

.detail-page {
  background: #fff;
}

.detail-hero {
  background: var(--cidme-navy);
  color: #fff;
  padding: 5.5rem 0 4rem;
}

.detail-hero h1 {
  font-size: clamp(2.3rem, 5vw, 4.6rem);
  font-weight: 850;
  line-height: 1;
  max-width: 980px;
}

.detail-hero p {
  color: rgba(255, 255, 255, .82);
  font-size: 1.18rem;
  max-width: 760px;
}

.detail-hero time,
.detail-meta span {
  color: #8ce8ff;
  font-weight: 800;
}

.detail-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.detail-image {
  aspect-ratio: 16 / 7;
  border-radius: 8px;
  box-shadow: 0 24px 70px rgba(16, 32, 51, .15);
  display: block;
  margin: -2rem 0 3rem;
  object-fit: cover;
  width: 100%;
}

.detail-content {
  font-size: 1.08rem;
  max-width: 900px;
  padding-bottom: 5rem;
}

.detail-content h2,
.detail-content h3 {
  font-weight: 820;
  margin-top: 2rem;
}

.detail-content a {
  color: var(--cidme-blue);
  font-weight: 700;
}

.hero-b {
  background:
    linear-gradient(90deg, rgba(250, 253, 255, .96), rgba(250, 253, 255, .76), rgba(250, 253, 255, .12)),
    url("https://images.unsplash.com/photo-1604014237800-1c9102c219da?auto=format&fit=crop&w=1800&q=80") center/cover;
  color: var(--cidme-navy);
  min-height: 720px;
}

.ticker-band {
  background: var(--cidme-navy);
  color: #fff;
  padding: 1.2rem 0;
}

.ticker-band strong,
.ticker-band span {
  display: block;
}

.ticker-band span {
  color: rgba(255, 255, 255, .7);
}

.mini-feature {
  align-items: center;
  border-top: 1px solid var(--cidme-line);
  display: flex;
  gap: 1rem;
  padding: 1rem 0;
}

.mini-feature i {
  color: var(--cidme-blue);
  font-size: 1.45rem;
}

.bright {
  background: #fff;
  border-top: 1px solid var(--cidme-line);
  color: var(--cidme-navy);
}

.admin-body {
  background: #eef3f6;
}

.admin-shell {
  display: grid;
  grid-template-columns: 280px 1fr;
  min-height: 100vh;
}

.admin-sidebar {
  background: var(--cidme-navy);
  color: #fff;
  padding: 1.4rem;
}

.admin-sidebar nav {
  display: grid;
  gap: .4rem;
  margin-top: 2rem;
}

.admin-sidebar a {
  align-items: center;
  border-radius: 8px;
  color: rgba(255, 255, 255, .78);
  display: flex;
  gap: .7rem;
  padding: .85rem .9rem;
}

.admin-sidebar a.active,
.admin-sidebar a:hover {
  background: rgba(255, 255, 255, .12);
  color: #fff;
}

.admin-main {
  padding: 2rem;
}

.admin-topbar {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 1.4rem;
}

.admin-topbar h1 {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 830;
  margin: 0;
}

.admin-user {
  align-items: center;
  background: #fff;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  display: flex;
  gap: .6rem;
  padding: .7rem 1rem;
}

.admin-card,
.admin-panel {
  padding: 1.2rem;
}

.admin-card span {
  color: var(--cidme-muted);
  display: block;
  font-weight: 700;
}

.admin-card strong {
  display: block;
  font-size: 2.4rem;
  line-height: 1.05;
  margin: .4rem 0 1rem;
}

.panel-head {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.admin-panel h2 {
  font-size: 1.25rem;
  font-weight: 790;
}

.login-screen {
  align-items: center;
  display: flex;
  min-height: 100vh;
  justify-content: center;
  padding: 1rem;
}

.login-card {
  background: #fff;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  box-shadow: 0 24px 70px rgba(16, 32, 51, .15);
  padding: 2rem;
  width: min(440px, 100%);
}

.login-card h1 {
  font-size: 1.8rem;
  font-weight: 830;
}

.login-card p {
  color: var(--cidme-muted);
}

.content-form textarea {
  resize: vertical;
}

.current-image-preview {
  aspect-ratio: 16 / 7;
  background-color: #eef3f6;
  background-position: center;
  background-size: cover;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  max-width: 620px;
}

.current-logo-preview {
  background-color: #fff;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  height: 150px;
  width: min(320px, 100%);
}

.table-actions {
  align-items: center;
  display: inline-flex;
  gap: .45rem;
  justify-content: flex-end;
}

.table-actions form {
  margin: 0;
}

.seo-panel {
  background: #f8fafb;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  padding: 1.2rem;
}

.seo-panel .panel-head {
  align-items: start;
  margin-bottom: 1rem;
}

.seo-panel .panel-head p {
  color: var(--cidme-muted);
  margin: .25rem 0 0;
}

.seo-score {
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 800;
  padding: .35rem .75rem;
  white-space: nowrap;
}

.seo-score.good {
  background: #dff3e4;
  color: #1e7a32;
}

.seo-score.weak {
  background: #fff2cf;
  color: #926400;
}

.seo-score.bad {
  background: #fde4e1;
  color: #a5281c;
}

.seo-meter {
  background: #dbe4ea;
  border-radius: 999px;
  height: 8px;
  margin-top: .55rem;
  overflow: hidden;
}

.seo-meter span {
  display: block;
  height: 100%;
  transition: width .2s ease, background-color .2s ease;
}

.seo-meter span.empty {
  background: #aeb9c2;
}

.seo-meter span.good {
  background: #2f9e44;
}

.seo-meter span.weak {
  background: #f2b705;
}

.seo-meter span.bad {
  background: #d9382c;
}

.seo-count {
  color: var(--cidme-muted);
  display: block;
  font-weight: 700;
  margin-top: .35rem;
}

.seo-count.good {
  color: #1e7a32;
}

.seo-count.weak {
  color: #926400;
}

.seo-count.bad {
  color: #a5281c;
}

.google-preview {
  background: #fff;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  margin-top: 1.1rem;
  max-width: 720px;
  padding: 1rem;
}

.google-preview span {
  color: #3c4043;
  display: block;
  font-size: .9rem;
  margin-bottom: .25rem;
  overflow-wrap: anywhere;
}

.google-preview strong {
  color: #1a0dab;
  display: block;
  font-family: Arial, sans-serif;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.25;
  margin-bottom: .35rem;
}

.google-preview p {
  color: #4d5156;
  font-family: Arial, sans-serif;
  font-size: .95rem;
  line-height: 1.42;
  margin: 0;
}

.table-thumb {
  border-radius: 6px;
  display: inline-block;
  height: 42px;
  margin-right: .7rem;
  vertical-align: middle;
  width: 58px;
}

@media (max-width: 991px) {
  .hero,
  .hero-b {
    min-height: 680px;
  }

  .section-head,
  .admin-topbar {
    align-items: start;
    flex-direction: column;
  }

  .map-panel,
  .cidme-map {
    height: 460px;
  }

  .map-full-wrap {
    display: grid;
  }

  .cidme-map-full {
    height: 520px;
  }

  .map-overlay-container {
    inset: auto;
    pointer-events: auto;
    position: static;
  }

  .map-overlay-panel {
    max-width: none;
    padding-top: 1rem;
  }

  .admin-shell {
    grid-template-columns: 1fr;
  }

  .admin-sidebar {
    position: static;
  }
}

@media (max-width: 767px) {
  .brand-logo,
  .light-nav .brand-logo {
    height: 42px;
  }

  .section-pad {
    padding: 3.5rem 0;
  }

  .hero h1,
  .hero-b h1 {
    font-size: 2.45rem;
  }

  .carousel-caption {
    bottom: 1rem;
    left: 1rem;
    width: calc(100% - 2rem);
  }

  .slide-img,
  .compact .slide-img {
    min-height: 360px;
  }

  .event-list article {
    grid-template-columns: 1fr;
    padding: 0 0 1rem;
  }

  .event-list article time,
  .event-list article div:not(.event-thumb) {
    padding: 0 1rem;
  }

  .admin-main {
    padding: 1rem;
  }
}

.concept-c {
  background: #f6f8f9;
}

.concept-hero {
  --cursor-x: 50%;
  --cursor-y: 50%;
  color: #fff;
  min-height: 92vh;
  overflow: hidden;
  position: relative;
}

.concept-hero::after {
  background:
    linear-gradient(90deg, transparent calc(var(--cursor-x) - 1px), rgba(140, 232, 255, .34) var(--cursor-x), transparent calc(var(--cursor-x) + 1px)),
    linear-gradient(0deg, transparent calc(var(--cursor-y) - 1px), rgba(140, 232, 255, .24) var(--cursor-y), transparent calc(var(--cursor-y) + 1px));
  content: "";
  inset: 0;
  opacity: .55;
  pointer-events: none;
  position: absolute;
  transition: opacity .2s ease;
  z-index: 1;
}

.concept-hero-bg {
  background:
    linear-gradient(90deg, rgba(5, 13, 22, .96), rgba(5, 13, 22, .76) 45%, rgba(5, 13, 22, .2)),
    url("https://images.unsplash.com/photo-1558618666-fcd25c85cd64?auto=format&fit=crop&w=1800&q=80") center/cover;
  inset: 0;
  position: absolute;
  transform: scale(1.02);
}

.concept-hero-inner {
  padding-bottom: 6rem;
  padding-top: 11rem;
  position: relative;
  z-index: 2;
}

.concept-kicker {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-bottom: 1.5rem;
}

.concept-kicker span {
  border: 1px solid rgba(255, 255, 255, .32);
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 800;
  padding: .45rem .8rem;
}

.concept-hero h1 {
  font-size: clamp(3.2rem, 8vw, 8.4rem);
  font-weight: 900;
  line-height: .88;
  max-width: 1180px;
}

.hero-rotator {
  color: #8ce8ff;
  display: inline-grid;
  min-width: min(860px, 100%);
  vertical-align: baseline;
}

.hero-rotator span {
  animation: heroWordFade 9s infinite;
  grid-area: 1 / 1;
  opacity: 0;
}

.hero-rotator span:nth-child(2) {
  animation-delay: 3s;
}

.hero-rotator span:nth-child(3) {
  animation-delay: 6s;
}

@keyframes heroWordFade {
  0%, 8% {
    opacity: 0;
    transform: translateY(.2em);
  }

  14%, 30% {
    opacity: 1;
    transform: translateY(0);
  }

  38%, 100% {
    opacity: 0;
    transform: translateY(-.16em);
  }
}

.concept-hero p {
  color: rgba(255, 255, 255, .8);
  font-size: 1.24rem;
  margin-top: 1.5rem;
  max-width: 740px;
}

.concept-rail {
  align-items: center;
  background: rgba(255, 255, 255, .08);
  border-top: 1px solid rgba(255, 255, 255, .14);
  bottom: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  left: 0;
  position: absolute;
  right: 0;
  z-index: 1;
}

.concept-rail span {
  border-right: 1px solid rgba(255, 255, 255, .14);
  font-weight: 800;
  padding: 1.2rem 2rem;
}

.concept-band {
  background: #07131f;
  color: #fff;
  padding: 1.6rem 0;
}

.concept-metrics {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(4, 1fr);
}

.concept-metrics strong,
.concept-metrics span {
  display: block;
}

.concept-metrics strong {
  color: #8ce8ff;
  font-size: 2.2rem;
  line-height: 1;
}

.concept-metrics span {
  color: rgba(255, 255, 255, .7);
  font-weight: 700;
}

.concept-grid-section,
.concept-news-section,
.concept-events-section {
  padding: 6rem 0;
}

.concept-events-section {
  background: #fff;
}

.concept-section-title {
  margin-bottom: 2rem;
  max-width: 780px;
}

.concept-section-title.split {
  align-items: end;
  display: flex;
  justify-content: space-between;
  max-width: none;
}

.concept-section-title h2 {
  font-size: clamp(2.4rem, 5vw, 5rem);
  font-weight: 900;
  line-height: .95;
}

.concept-feature-grid {
  display: grid;
  gap: 1px;
  grid-template-columns: repeat(3, 1fr);
}

.concept-feature-grid article {
  background: #fff;
  border: 1px solid var(--cidme-line);
  min-height: 310px;
  padding: 2rem;
}

.concept-feature-grid i {
  color: var(--cidme-blue);
  font-size: 2rem;
}

.concept-feature-grid h3,
.concept-news-grid h3 {
  font-weight: 850;
  margin-top: 1.4rem;
}

.concept-map-section {
  background: #07131f;
  color: #fff;
  display: block;
}

.concept-map-copy {
  align-items: end;
  display: grid;
  gap: 2rem;
  grid-template-columns: minmax(320px, 1.1fr) minmax(320px, .9fr);
  margin: 0 auto;
  max-width: 1320px;
  padding: 5rem 1.5rem 2.5rem;
  position: relative;
  z-index: 2;
}

.concept-map-copy h2 {
  font-size: clamp(2.6rem, 5vw, 5.8rem);
  font-weight: 900;
  line-height: .92;
  max-width: 900px;
}

.concept-map-copy p:not(.eyebrow) {
  color: rgba(255, 255, 255, .72);
  font-size: 1.12rem;
  max-width: 520px;
}

.concept-map-shell {
  min-height: 760px;
  position: relative;
}

.concept-map {
  border: 0;
  border-radius: 0;
  height: 760px;
}

.concept-map-list {
  bottom: auto;
  position: absolute;
  right: 2rem;
  top: 2rem;
  width: min(410px, calc(100% - 4rem));
  z-index: 700;
}

.concept-map-list .map-panel {
  height: min(620px, calc(760px - 4rem));
}

.concept-join-section {
  background:
    linear-gradient(135deg, rgba(7, 89, 166, .08), transparent 34%),
    #f6f8f9;
  padding: 6.5rem 0;
}

.join-grid {
  align-items: center;
  display: grid;
  gap: 4rem;
  grid-template-columns: minmax(320px, .85fr) minmax(360px, 1.15fr);
}

.join-copy h2 {
  font-size: clamp(2.6rem, 5.4vw, 5.9rem);
  font-weight: 900;
  line-height: .92;
  max-width: 900px;
}

.join-copy p:not(.eyebrow) {
  color: var(--cidme-muted);
  font-size: 1.16rem;
  margin-top: 1.4rem;
  max-width: 680px;
}

.join-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 1.2rem;
  margin-top: 2rem;
}

.join-visual {
  display: grid;
  gap: 1rem;
}

.join-chart-card {
  background: #07131f;
  border-radius: 8px;
  box-shadow: 0 24px 70px rgba(16, 32, 51, .2);
  color: #fff;
  min-height: 360px;
  overflow: hidden;
  padding: 1.4rem;
  position: relative;
}

.join-chart-card::before {
  background:
    linear-gradient(rgba(255, 255, 255, .06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .06) 1px, transparent 1px);
  background-size: 48px 48px;
  content: "";
  inset: 0;
  opacity: .55;
  position: absolute;
}

.join-chart-head,
.join-chart,
.join-line-chart {
  position: relative;
  z-index: 1;
}

.join-chart-head {
  align-items: start;
  display: flex;
  justify-content: space-between;
}

.join-chart-head span {
  color: rgba(255, 255, 255, .62);
  font-weight: 800;
  text-transform: uppercase;
}

.join-chart-head strong {
  color: #8ce8ff;
  font-size: 1.05rem;
}

.join-chart {
  align-items: end;
  display: grid;
  gap: .75rem;
  grid-template-columns: repeat(5, 1fr);
  height: 210px;
  margin-top: 2.4rem;
}

.join-chart span {
  background: linear-gradient(180deg, #8ce8ff, #0759a6);
  border-radius: 7px 7px 0 0;
  box-shadow: 0 0 28px rgba(140, 232, 255, .22);
  display: block;
}

.join-line-chart {
  inset: auto 1.4rem 1.1rem 1.4rem;
  position: absolute;
}

.join-line-chart svg {
  display: block;
  height: 130px;
  overflow: visible;
  width: 100%;
}

.join-line-chart path {
  fill: none;
  stroke: #51a35f;
  stroke-linecap: round;
  stroke-width: 6;
}

.join-line-chart circle {
  fill: #51a35f;
  stroke: #fff;
  stroke-width: 4;
}

.join-benefits {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, 1fr);
}

.join-benefits article {
  background: #fff;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  display: grid;
  gap: .45rem;
  min-height: 180px;
  padding: 1.2rem;
}

.join-benefits i {
  color: var(--cidme-blue);
  font-size: 1.7rem;
}

.join-benefits strong {
  font-size: 1.05rem;
  font-weight: 850;
}

.join-benefits span {
  color: var(--cidme-muted);
  font-size: .96rem;
}

.concept-carousel {
  position: relative;
}

.concept-card-track {
  display: grid;
  gap: 1rem;
  grid-auto-columns: minmax(310px, 390px);
  grid-auto-flow: column;
  overflow-x: auto;
  padding: .25rem .1rem 1rem;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}

.concept-card-track::-webkit-scrollbar {
  display: none;
}

.concept-content-card {
  background: #fff;
  border: 1px solid var(--cidme-line);
  border-radius: 8px;
  min-height: 430px;
  overflow: hidden;
  scroll-snap-align: start;
}

.concept-events-section .concept-content-card {
  background: #f8fafb;
}

.concept-content-card a {
  color: var(--cidme-ink);
  display: flex;
  flex-direction: column;
  height: 100%;
}

.concept-card-image {
  aspect-ratio: 16 / 9;
  background-position: center;
  background-size: cover;
  width: 100%;
}

.concept-content-card span,
.concept-content-card h3,
.concept-content-card p,
.concept-content-card small {
  margin-left: 1.2rem;
  margin-right: 1.2rem;
}

.concept-content-card span {
  color: var(--cidme-blue);
  font-size: .78rem;
  font-weight: 850;
  margin-top: 1.2rem;
  text-transform: uppercase;
}

.concept-content-card small {
  color: var(--cidme-muted);
  font-weight: 800;
  margin-top: auto;
  padding-bottom: 1.2rem;
}

.carousel-nav {
  align-items: center;
  background: var(--cidme-navy);
  border: 0;
  border-radius: 50%;
  box-shadow: 0 16px 38px rgba(16, 32, 51, .22);
  color: #fff;
  display: flex;
  height: 46px;
  justify-content: center;
  position: absolute;
  top: 42%;
  transform: translateY(-50%);
  width: 46px;
  z-index: 3;
}

.carousel-nav.prev {
  left: -23px;
}

.carousel-nav.next {
  right: -23px;
}

.carousel-nav:hover {
  background: var(--cidme-blue);
}

@media (max-width: 991px) {
  .concept-rail,
  .concept-metrics,
  .concept-feature-grid,
  .concept-news-grid {
    grid-template-columns: 1fr;
  }

  .concept-map-copy {
    align-items: start;
    grid-template-columns: 1fr;
  }

  .concept-map-copy {
    padding: 4rem 1rem;
  }

  .concept-map-list {
    position: static;
    width: 100%;
  }

  .concept-map-shell,
  .concept-map {
    min-height: auto;
    height: auto;
  }

  .concept-map {
    height: 520px;
  }

  .join-grid,
  .join-benefits {
    grid-template-columns: 1fr;
  }

  .concept-join-section {
    padding: 4.5rem 0;
  }

  .carousel-nav {
    display: none;
  }
}
