/* Dimitsana.gr Phase 1 Foundation Makeover
   Scoped mostly to public pages so admin remains stable. */
:root {
  --dim-ink: #152019;
  --dim-muted: #667066;
  --dim-paper: #fffaf1;
  --dim-paper-soft: #f6efe3;
  --dim-stone: #e8dece;
  --dim-stone-2: #d8cbb8;
  --dim-forest: #264433;
  --dim-forest-2: #31583f;
  --dim-river: #1f6f7a;
  --dim-gold: #b8863b;
  --dim-shadow: 0 18px 48px rgba(21, 32, 25, .11);
  --dim-shadow-soft: 0 12px 28px rgba(21, 32, 25, .08);
  --dim-radius-sm: .85rem;
  --dim-radius: 1.15rem;
  --dim-radius-lg: 1.75rem;
  --dim-font-sans: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  --dim-font-serif: Georgia, "Times New Roman", Times, serif;
}

html { scroll-behavior: smooth; }

body.dimitsana-theme {
  color: var(--dim-ink);
  background:
    radial-gradient(circle at 12% 8%, rgba(184, 134, 59, .08), transparent 26rem),
    linear-gradient(180deg, #fbf7ef 0%, #f7f1e8 48%, #fbfaf7 100%) !important;
  font-family: var(--dim-font-sans);
  text-rendering: optimizeLegibility;
}

.skip-link {
  position: fixed;
  left: 1rem;
  top: .75rem;
  z-index: 2000;
  transform: translateY(-180%);
  padding: .55rem .85rem;
  border-radius: 999px;
  background: var(--dim-ink);
  color: #fff;
  text-decoration: none;
  box-shadow: var(--dim-shadow-soft);
}
.skip-link:focus { transform: translateY(0); color: #fff; }

body.dim-public .site-main {
  padding-top: clamp(1.75rem, 3vw, 3rem) !important;
  padding-bottom: clamp(2.5rem, 5vw, 4.5rem) !important;
}

body.dim-public h1,
body.dim-public .display-1,
body.dim-public .display-2,
body.dim-public .display-3,
body.dim-public .display-4,
body.dim-public .display-5,
body.dim-public .display-6 {
  letter-spacing: -.035em;
}

body.dim-public h1:not(.display-4):not(.display-md-3) {
  font-family: var(--dim-font-serif);
  font-weight: 700;
  color: var(--dim-ink);
}

body.dim-public p { line-height: 1.72; }
body.dim-public .text-secondary { color: var(--dim-muted) !important; }

/* Navigation: calmer, more editorial, still Bootstrap-compatible. */
.site-navbar {
  backdrop-filter: saturate(140%) blur(14px);
  box-shadow: 0 10px 28px rgba(21, 32, 25, .06);
}
body.dim-public .site-navbar.bg-white {
  background-color: rgba(255, 250, 241, .92) !important;
}
.site-brand {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  letter-spacing: -.025em;
  color: var(--dim-ink) !important;
}
.site-brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.15rem;
  height: 2.15rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--dim-forest), var(--dim-river));
  color: #fff;
  font-family: var(--dim-font-serif);
  font-size: 1.25rem;
  line-height: 1;
  box-shadow: 0 8px 20px rgba(38, 68, 51, .2);
}
.site-brand-text { white-space: nowrap; }
body.dim-public .site-navbar .nav-link {
  color: rgba(21, 32, 25, .78);
  font-weight: 600;
  border-radius: 999px;
  padding-inline: .78rem;
}
body.dim-public .site-navbar .nav-link:hover,
body.dim-public .site-navbar .nav-link:focus {
  color: var(--dim-forest);
  background: rgba(38, 68, 51, .07);
}
body.dim-public .site-navbar .dropdown-menu {
  border: 1px solid rgba(38, 68, 51, .12);
  border-radius: var(--dim-radius-sm);
  box-shadow: var(--dim-shadow-soft);
}
body.dim-public .search-form .form-control {
  border-radius: 999px;
  border-color: rgba(38, 68, 51, .16);
  background: rgba(255, 255, 255, .78);
}
body.dim-public .site-search-submit,
body.dim-public .site-lang-switch > .btn {
  border-radius: 999px;
}

/* Buttons */
body.dim-public .btn-primary {
  --bs-btn-bg: var(--dim-forest);
  --bs-btn-border-color: var(--dim-forest);
  --bs-btn-hover-bg: var(--dim-forest-2);
  --bs-btn-hover-border-color: var(--dim-forest-2);
  --bs-btn-active-bg: #1f3629;
  --bs-btn-active-border-color: #1f3629;
  box-shadow: 0 10px 20px rgba(38, 68, 51, .16);
}
body.dim-public .btn-outline-primary {
  --bs-btn-color: var(--dim-forest);
  --bs-btn-border-color: rgba(38, 68, 51, .48);
  --bs-btn-hover-bg: var(--dim-forest);
  --bs-btn-hover-border-color: var(--dim-forest);
  --bs-btn-active-bg: var(--dim-forest);
  --bs-btn-active-border-color: var(--dim-forest);
}
body.dim-public .btn {
  border-radius: 999px;
  font-weight: 650;
}

/* Cards: upgraded foundation, still compatible with existing Bootstrap markup. */
body.dim-public .card {
  border: 1px solid rgba(38, 68, 51, .10);
  border-radius: var(--dim-radius-lg) !important;
  background: rgba(255, 250, 241, .9);
  box-shadow: var(--dim-shadow-soft) !important;
  overflow: hidden;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
body.dim-public .card:hover {
  transform: translateY(-3px);
  border-color: rgba(184, 134, 59, .35);
  box-shadow: var(--dim-shadow) !important;
}
body.dim-public .card-img-top {
  min-height: 220px;
  max-height: 320px;
  object-fit: cover;
}
body.dim-public .card-title,
body.dim-public .card h2,
body.dim-public .card h3 {
  color: var(--dim-ink);
}
body.dim-public .card a:not(.btn) {
  color: var(--dim-forest);
  text-decoration-thickness: .08em;
  text-underline-offset: .18em;
}

/* Page/list foundations */
body.dim-public .row.g-4,
body.dim-public .row.g-3 { --bs-gutter-y: 1.5rem; }
body.dim-public main > h1:first-child,
body.dim-public main > .d-flex:first-child h1 {
  position: relative;
  margin-bottom: 1.35rem !important;
}
body.dim-public main > h1:first-child::after,
body.dim-public main > .d-flex:first-child h1::after {
  content: "";
  display: block;
  width: 5.25rem;
  height: .22rem;
  margin-top: .65rem;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--dim-gold), rgba(184, 134, 59, 0));
}

/* Home/greeting refinement */
body.dim-public .greeting-intro {
  background:
    radial-gradient(circle at top left, rgba(31, 111, 122, .08), transparent 30rem),
    linear-gradient(180deg, #fffaf1, #fff 72%) !important;
  border-color: rgba(38, 68, 51, .1);
}
body.dim-public .greeting-intro header h1 {
  font-family: var(--dim-font-serif);
}
body.dim-public .greeting-intro .greeting-underline {
  background: linear-gradient(90deg, var(--dim-gold), var(--dim-river));
  opacity: 1;
}
body.dim-public .greeting-intro .otro-blockquote {
  background: #f5ede0;
  border-left-color: var(--dim-gold);
  color: var(--dim-ink);
}
body.dim-public .greeting-intro .otro-blockquote::before { color: var(--dim-gold); }

/* Footer polish. The existing footer content/data stays unchanged. */
body.dim-public .site-footer {
  background:
    linear-gradient(135deg, rgba(21, 32, 25, .96), rgba(38, 68, 51, .94)),
    var(--dim-forest) !important;
  color: rgba(255, 250, 241, .86);
  border-top: 0 !important;
  box-shadow: none;
}
body.dim-public .site-footer h6,
body.dim-public .site-footer .text-muted,
body.dim-public .site-footer .brand-tagline,
body.dim-public .site-footer a,
body.dim-public .site-footer li {
  color: rgba(255, 250, 241, .82) !important;
}
body.dim-public .site-footer h6 { color: #fffaf1 !important; }
body.dim-public .site-footer a:hover { color: #fff !important; }
body.dim-public .site-footer .border-top { border-top-color: rgba(255, 250, 241, .18) !important; }
body.dim-public .site-footer ul li strong { color: #f0c873; }
body.dim-public .social-icons a {
  background: rgba(255, 250, 241, .08);
  border: 1px solid rgba(255, 250, 241, .14);
  border-radius: 999px;
}

/* Hero compatibility after navbar visual changes. */
.hero-active .site-navbar .site-brand,
.hero-active .site-navbar .nav-link { color: #fff !important; }
.hero-active .site-brand-mark { background: rgba(255, 255, 255, .18); }
.hero-active .site-navbar .search-form .form-control { background: rgba(255,255,255,.9); }
.hero-active .site-navbar .site-lang-switch > .btn { color: #fff; border-color: rgba(255,255,255,.7); }

@media (max-width: 991.98px) {
  body.dim-public .site-navbar .navbar-collapse {
    margin-top: .75rem;
    padding: .75rem;
    border-radius: var(--dim-radius);
    background: rgba(255, 250, 241, .98);
    box-shadow: var(--dim-shadow-soft);
  }
  .hero-active .site-navbar .navbar-collapse {
    background: rgba(21, 32, 25, .92) !important;
  }
  body.dim-public .search-form { margin-top: .75rem; }
  body.dim-public .site-lang-switch { margin-left: 0 !important; margin-top: .75rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
  }
}

/* Phase 2: Home page editorial redesign */
body.dim-public .home-hero .hero-overlay {
  background:
    radial-gradient(circle at 22% 78%, rgba(184, 134, 59, .28), transparent 28rem),
    linear-gradient(90deg, rgba(13, 20, 16, .76), rgba(13, 20, 16, .36) 54%, rgba(13, 20, 16, .62)),
    linear-gradient(180deg, rgba(0, 0, 0, .18), rgba(0, 0, 0, .62));
}
body.dim-public .home-hero-panel {
  max-width: 820px;
  padding: clamp(1.35rem, 3vw, 2.25rem);
  border: 1px solid rgba(255, 250, 241, .18);
  border-radius: 1.75rem;
  background: linear-gradient(135deg, rgba(13, 20, 16, .36), rgba(13, 20, 16, .1));
  box-shadow: 0 28px 70px rgba(0, 0, 0, .24);
  backdrop-filter: blur(3px);
}
body.dim-public .home-hero .display-3 {
  max-width: 760px;
  font-family: var(--dim-font-serif);
  letter-spacing: -.055em;
  text-shadow: 0 10px 36px rgba(0,0,0,.3);
}
body.dim-public .home-hero .lead {
  max-width: 620px;
  color: rgba(255, 250, 241, .88);
  font-size: clamp(1.1rem, 1.5vw, 1.35rem);
}
body.dim-public .home-kicker,
body.dim-public .section-kicker,
body.dim-public .home-card-label {
  margin: 0 0 .75rem;
  color: var(--dim-gold);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
}
body.dim-public .home-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
}
body.dim-public .home-hero-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 2.1rem;
  padding: .35rem .85rem;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  color: rgba(255, 250, 241, .86);
  font-weight: 650;
  backdrop-filter: blur(6px);
}

body.dim-public .home-intro-section {
  background:
    radial-gradient(circle at 10% 0%, rgba(31, 111, 122, .08), transparent 30rem),
    linear-gradient(180deg, #fffaf1, #fff 82%);
}
body.dim-public .home-section-title {
  font-family: var(--dim-font-serif);
  color: var(--dim-ink);
  font-size: clamp(2rem, 3.6vw, 3.55rem);
  line-height: .98;
  letter-spacing: -.045em;
}
body.dim-public .home-section-lead,
body.dim-public .home-intro-copy {
  color: var(--dim-muted);
  font-size: 1.075rem;
}
body.dim-public .home-intro-copy p:last-child { margin-bottom: 0; }
body.dim-public .home-quote-card {
  position: relative;
  padding: clamp(1.35rem, 3vw, 2rem);
  border: 1px solid rgba(38, 68, 51, .12);
  border-radius: var(--dim-radius-lg);
  background:
    linear-gradient(135deg, rgba(255,250,241,.96), rgba(245,237,224,.92)),
    #fffaf1;
  box-shadow: var(--dim-shadow-soft);
  overflow: hidden;
}
body.dim-public .home-quote-card::before {
  content: "";
  position: absolute;
  width: 12rem;
  height: 12rem;
  right: -5rem;
  top: -5rem;
  border-radius: 999px;
  background: rgba(184, 134, 59, .16);
}
body.dim-public .home-quote-card blockquote {
  position: relative;
  margin: 0 0 1.35rem;
  font-family: var(--dim-font-serif);
  color: var(--dim-ink);
  font-size: clamp(1.55rem, 2.3vw, 2.15rem);
  line-height: 1.12;
}
body.dim-public .home-quote-card blockquote span {
  display: block;
  margin-top: .9rem;
  color: var(--dim-muted);
  font-family: var(--dim-font-sans);
  font-size: .9rem;
  font-weight: 750;
  letter-spacing: .08em;
  text-transform: uppercase;
}
body.dim-public .home-stat-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
}
body.dim-public .home-stat-grid div {
  padding: .9rem;
  border: 1px solid rgba(38, 68, 51, .1);
  border-radius: var(--dim-radius-sm);
  background: rgba(255, 255, 255, .62);
}
body.dim-public .home-stat-grid strong {
  display: block;
  color: var(--dim-forest);
  font-size: 1.55rem;
  line-height: 1;
}
body.dim-public .home-stat-grid span {
  display: block;
  margin-top: .25rem;
  color: var(--dim-muted);
  font-size: .86rem;
  font-weight: 650;
}

body.dim-public .home-paths-section {
  background: #fff;
}
body.dim-public .home-path-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, .85fr);
  grid-auto-rows: minmax(230px, auto);
  gap: 1.25rem;
}
body.dim-public .home-path-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  border-radius: var(--dim-radius-lg);
  background: #fffaf1;
  box-shadow: var(--dim-shadow-soft);
  border: 1px solid rgba(38, 68, 51, .1);
  overflow: hidden;
}
body.dim-public .home-path-card--large {
  grid-row: span 2;
}
body.dim-public .home-path-media {
  min-height: 210px;
  overflow: hidden;
  background: var(--dim-stone);
}
body.dim-public .home-path-card--large .home-path-media { min-height: 420px; }
body.dim-public .home-path-media img {
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}
body.dim-public .home-path-card:hover .home-path-media img { transform: scale(1.035); }
body.dim-public .home-path-content {
  padding: clamp(1.15rem, 2.4vw, 1.65rem);
}
body.dim-public .home-path-content h3,
body.dim-public .home-feature-item h3 {
  font-family: var(--dim-font-serif);
  color: var(--dim-ink);
  font-size: clamp(1.45rem, 2vw, 2rem);
  letter-spacing: -.035em;
}
body.dim-public .home-path-content p,
body.dim-public .home-feature-item p {
  color: var(--dim-muted);
}
body.dim-public .home-text-link {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  color: var(--dim-forest);
  font-weight: 800;
  text-decoration: none;
}
body.dim-public .home-text-link::after {
  content: "→";
  transition: transform .18s ease;
}
body.dim-public .home-text-link:hover::after { transform: translateX(.18rem); }

body.dim-public .home-feature-band {
  background:
    linear-gradient(135deg, rgba(21, 32, 25, .97), rgba(38, 68, 51, .94)),
    var(--dim-forest);
  color: rgba(255, 250, 241, .86);
}
body.dim-public .home-feature-band .home-section-title,
body.dim-public .home-feature-band h3 { color: #fffaf1; }
body.dim-public .home-feature-band .home-section-lead,
body.dim-public .home-feature-band p { color: rgba(255, 250, 241, .76); }
body.dim-public .home-feature-band .home-text-link { color: #f0c873; }
body.dim-public .home-feature-band-inner {
  display: grid;
  grid-template-columns: minmax(0, .88fr) minmax(0, 1.12fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: start;
}
body.dim-public .home-feature-list {
  display: grid;
  gap: 1rem;
}
body.dim-public .home-feature-item {
  padding: 1.15rem;
  border: 1px solid rgba(255, 250, 241, .14);
  border-radius: var(--dim-radius);
  background: rgba(255, 250, 241, .06);
}

body.dim-public .home-explore-section {
  background:
    radial-gradient(circle at right top, rgba(184, 134, 59, .12), transparent 26rem),
    #fffaf1;
}
body.dim-public .home-explore-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
body.dim-public .home-explore-card {
  min-height: 150px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 1.2rem;
  border: 1px solid rgba(38, 68, 51, .12);
  border-radius: var(--dim-radius);
  background: rgba(255,255,255,.72);
  box-shadow: 0 18px 40px rgba(21, 32, 25, .06);
  color: var(--dim-ink);
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
body.dim-public .home-explore-card:hover {
  transform: translateY(-3px);
  border-color: rgba(184, 134, 59, .4);
  box-shadow: var(--dim-shadow-soft);
}
body.dim-public .home-explore-card span {
  font-family: var(--dim-font-serif);
  font-size: 1.55rem;
  font-weight: 750;
  letter-spacing: -.035em;
}
body.dim-public .home-explore-card small {
  margin-top: .4rem;
  color: var(--dim-muted);
  font-size: .94rem;
  line-height: 1.55;
}

@media (max-width: 991.98px) {
  body.dim-public .home-path-grid,
  body.dim-public .home-feature-band-inner {
    grid-template-columns: 1fr;
  }
  body.dim-public .home-path-card--large { grid-row: auto; }
  body.dim-public .home-path-card--large .home-path-media { min-height: 280px; }
}
@media (max-width: 767.98px) {
  body.dim-public .home-hero .display-3 { font-size: 2.7rem; }
  body.dim-public .home-hero-panel {
    padding: 1.1rem;
    border-radius: 1.15rem;
  }
  body.dim-public .home-hero-meta { display: none; }
  body.dim-public .home-stat-grid,
  body.dim-public .home-explore-grid {
    grid-template-columns: 1fr;
  }
  body.dim-public .home-path-media,
  body.dim-public .home-path-card--large .home-path-media { min-height: 220px; }
}

/* Phase 3: Public listing pages */
body.dim-public .listing-page {
  width: 100%;
}
body.dim-public .listing-hero {
  position: relative;
  margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
  padding: clamp(1.35rem, 3vw, 2.35rem);
  border: 1px solid rgba(38, 68, 51, .12);
  border-radius: var(--dim-radius-lg);
  background:
    radial-gradient(circle at 12% 0%, rgba(184, 134, 59, .13), transparent 25rem),
    linear-gradient(135deg, rgba(255,250,241,.98), rgba(246,239,227,.92));
  box-shadow: var(--dim-shadow-soft);
  overflow: hidden;
}
body.dim-public .listing-hero::after {
  content: "";
  position: absolute;
  right: -4rem;
  bottom: -5rem;
  width: 15rem;
  height: 15rem;
  border-radius: 50%;
  background: rgba(31, 111, 122, .08);
  pointer-events: none;
}
body.dim-public .listing-hero--split {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(280px, .7fr);
  gap: clamp(1rem, 3vw, 2.25rem);
  align-items: end;
}
body.dim-public .listing-hero--dark {
  background:
    radial-gradient(circle at right top, rgba(184, 134, 59, .22), transparent 22rem),
    linear-gradient(135deg, rgba(21, 32, 25, .98), rgba(38, 68, 51, .94));
  color: rgba(255,250,241,.88);
}
body.dim-public .listing-hero--dark .listing-title { color: #fffaf1; }
body.dim-public .listing-hero--dark .listing-lead { color: rgba(255,250,241,.78); }
body.dim-public .listing-kicker {
  position: relative;
  z-index: 1;
  margin: 0 0 .75rem;
  color: var(--dim-gold);
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .16em;
  text-transform: uppercase;
}
body.dim-public .listing-title {
  position: relative;
  z-index: 1;
  margin: 0;
  color: var(--dim-ink);
  font-family: var(--dim-font-serif);
  font-size: clamp(2.25rem, 5vw, 4.5rem);
  line-height: .95;
  letter-spacing: -.055em;
}
body.dim-public .listing-lead {
  position: relative;
  z-index: 1;
  max-width: 660px;
  margin: .85rem 0 0;
  color: var(--dim-muted);
  font-size: clamp(1.02rem, 1.4vw, 1.18rem);
  line-height: 1.68;
}
body.dim-public .listing-actions {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: flex-start;
}
body.dim-public .listing-filter {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin: -0.5rem 0 1.35rem;
}

body.dim-public .editorial-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.35rem);
  align-items: stretch;
}
body.dim-public .editorial-grid--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
body.dim-public .editorial-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  border: 1px solid rgba(38, 68, 51, .12);
  border-radius: var(--dim-radius-lg);
  background: rgba(255,250,241,.9);
  box-shadow: var(--dim-shadow-soft);
  overflow: hidden;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
body.dim-public .editorial-card:hover {
  transform: translateY(-3px);
  border-color: rgba(184, 134, 59, .38);
  box-shadow: var(--dim-shadow);
}
body.dim-public .editorial-card--feature {
  grid-column: span 2;
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(280px, .88fr);
}
body.dim-public .editorial-card--wide {
  grid-column: span 2;
}
body.dim-public .editorial-card__media {
  position: relative;
  display: block;
  min-height: 240px;
  background: var(--dim-stone);
  overflow: hidden;
}
body.dim-public .editorial-card--feature .editorial-card__media,
body.dim-public .editorial-card__media--wide { min-height: 320px; }
body.dim-public .editorial-card__media img {
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}
body.dim-public .editorial-card:hover .editorial-card__media img { transform: scale(1.035); }
body.dim-public .editorial-card__body {
  display: flex;
  flex-direction: column;
  gap: .65rem;
  flex: 1;
  padding: clamp(1.05rem, 2vw, 1.45rem);
}
body.dim-public .editorial-card__meta {
  color: var(--dim-gold);
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .095em;
  text-transform: uppercase;
}
body.dim-public .editorial-card__title {
  margin: 0;
  color: var(--dim-ink);
  font-family: var(--dim-font-serif);
  font-size: clamp(1.35rem, 2vw, 2rem);
  line-height: 1.05;
  letter-spacing: -.035em;
}
body.dim-public .editorial-card__title a,
body.dim-public .directory-card__title a,
body.dim-public .archive-card__title a {
  color: inherit;
  text-decoration: none;
}
body.dim-public .editorial-card__title a:hover,
body.dim-public .directory-card__title a:hover,
body.dim-public .archive-card__title a:hover { color: var(--dim-forest); }
body.dim-public .editorial-card__body p,
body.dim-public .directory-card__body p {
  margin: 0;
  color: var(--dim-muted);
}
body.dim-public .editorial-card__body .btn,
body.dim-public .archive-card__body .btn { align-self: flex-start; margin-top: auto; }

body.dim-public .directory-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
body.dim-public .directory-card {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  min-height: 220px;
  border: 1px solid rgba(38, 68, 51, .12);
  border-radius: var(--dim-radius);
  background: rgba(255,250,241,.88);
  box-shadow: var(--dim-shadow-soft);
  overflow: hidden;
}
body.dim-public .directory-card__media {
  display: block;
  min-height: 100%;
  background: var(--dim-stone);
  overflow: hidden;
}
body.dim-public .directory-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
body.dim-public .directory-card__body {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  padding: 1.1rem;
}
body.dim-public .directory-card__title {
  margin: 0;
  color: var(--dim-ink);
  font-family: var(--dim-font-serif);
  font-size: 1.35rem;
  line-height: 1.08;
  letter-spacing: -.03em;
}

body.dim-public .archive-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 1rem;
}
body.dim-public .archive-card {
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(38, 68, 51, .12);
  border-radius: var(--dim-radius);
  background: rgba(255,250,241,.9);
  box-shadow: var(--dim-shadow-soft);
  overflow: hidden;
}
body.dim-public .archive-card__cover {
  display: block;
  aspect-ratio: 2 / 3;
  background: var(--dim-stone);
  overflow: hidden;
}
body.dim-public .archive-card__cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
body.dim-public .archive-card__body {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  flex: 1;
  padding: 1rem;
}
body.dim-public .archive-card__title {
  margin: 0;
  color: var(--dim-ink);
  font-family: var(--dim-font-serif);
  font-size: 1.12rem;
  line-height: 1.12;
  letter-spacing: -.025em;
}
body.dim-public .archive-card__meta-line {
  color: var(--dim-muted);
  font-size: .88rem;
  line-height: 1.45;
}
body.dim-public .books-grid-item-hidden { display: none !important; }

body.dim-public .photo-grid--editorial {
  margin-top: 1.25rem;
}
body.dim-public .photo-grid--editorial .photo-card {
  border-radius: var(--dim-radius);
  box-shadow: var(--dim-shadow-soft);
}

@media (max-width: 1199.98px) {
  body.dim-public .editorial-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  body.dim-public .directory-grid { grid-template-columns: 1fr; }
}
@media (max-width: 991.98px) {
  body.dim-public .listing-hero--split,
  body.dim-public .editorial-card--feature {
    grid-template-columns: 1fr;
  }
  body.dim-public .editorial-card--feature,
  body.dim-public .editorial-card--wide { grid-column: auto; }
}
@media (max-width: 767.98px) {
  body.dim-public .editorial-grid,
  body.dim-public .editorial-grid--two {
    grid-template-columns: 1fr;
  }
  body.dim-public .directory-card {
    grid-template-columns: 1fr;
  }
  body.dim-public .directory-card__media { min-height: 210px; }
  body.dim-public .listing-title { font-size: 2.4rem; }
}

/* Phase 4.1: Contrast, width and modern navigation polish */
:root {
  --dim-site-gutter: clamp(1rem, 3vw, 3.25rem);
  --dim-container-wide: 1680px;
  --dim-container-readable: 1040px;
  --dim-nav-bg: rgba(9, 15, 18, .88);
  --dim-nav-bg-solid: rgba(9, 15, 18, .96);
  --dim-nav-border: rgba(255, 250, 241, .15);
}

body.dim-public .site-main {
  width: 100%;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

body.dim-public .site-main > :not(.hero):not(.home-intro-section):not(.home-paths-section):not(.home-feature-band):not(.home-explore-section):not(link):not(script):not(style) {
  width: min(calc(100% - (var(--dim-site-gutter) * 2)), var(--dim-container-wide));
  margin-left: auto;
  margin-right: auto;
}

body.dim-public .home-intro-section > .container,
body.dim-public .home-paths-section > .container,
body.dim-public .home-feature-band > .container,
body.dim-public .home-explore-section > .container,
body.dim-public .site-footer > .container,
body.dim-public .site-navbar > .site-nav-inner {
  width: min(calc(100% - (var(--dim-site-gutter) * 2)), var(--dim-container-wide));
  max-width: var(--dim-container-wide);
  padding-left: 0;
  padding-right: 0;
}

body.dim-public .site-navbar {
  background: var(--dim-nav-bg) !important;
  border-bottom: 1px solid var(--dim-nav-border) !important;
  box-shadow: 0 18px 45px rgba(0, 0, 0, .18);
  backdrop-filter: saturate(150%) blur(18px);
}

body.dim-public .site-navbar .site-nav-inner {
  min-height: 72px;
}

body.dim-public .site-brand {
  color: #fffaf1 !important;
  gap: .8rem;
}

body.dim-public .site-brand-mark {
  width: 2.45rem;
  height: 2.45rem;
  background: linear-gradient(135deg, rgba(240, 200, 115, .95), rgba(31, 111, 122, .96));
  color: #101a16;
  box-shadow: 0 12px 28px rgba(0, 0, 0, .25);
}

body.dim-public .site-brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}

body.dim-public .site-brand-title {
  color: #fffaf1;
  font-weight: 800;
  letter-spacing: -.035em;
}

body.dim-public .site-brand-subtitle {
  margin-top: .24rem;
  color: rgba(255, 250, 241, .64);
  font-size: .68rem;
  font-weight: 750;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.dim-public .site-navbar .navbar-nav {
  gap: .12rem;
}

body.dim-public .site-navbar .nav-link {
  color: rgba(255, 250, 241, .82) !important;
  font-size: .95rem;
  font-weight: 720;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: .55rem .82rem;
}

body.dim-public .site-navbar .nav-link:hover,
body.dim-public .site-navbar .nav-link:focus,
body.dim-public .site-navbar .nav-link.show {
  color: #fffaf1 !important;
  background: rgba(255, 250, 241, .11);
  border-color: rgba(255, 250, 241, .14);
}

body.dim-public .site-navbar .dropdown-menu {
  margin-top: .65rem;
  padding: .55rem;
  border: 1px solid rgba(255, 250, 241, .12);
  border-radius: 1rem;
  background: rgba(10, 18, 22, .96);
  box-shadow: 0 24px 60px rgba(0, 0, 0, .32);
  backdrop-filter: blur(18px);
}

body.dim-public .site-navbar .dropdown-item {
  color: rgba(255, 250, 241, .82);
  border-radius: .75rem;
  font-weight: 650;
  padding: .58rem .75rem;
}

body.dim-public .site-navbar .dropdown-item:hover,
body.dim-public .site-navbar .dropdown-item:focus,
body.dim-public .site-navbar .dropdown-item.active {
  color: #fffaf1;
  background: rgba(240, 200, 115, .16);
}

body.dim-public .site-nav-tools {
  display: flex;
  align-items: center;
  gap: .65rem;
  margin-left: 1rem;
}

body.dim-public .search-form {
  position: relative;
  align-items: center;
  gap: .35rem;
}

body.dim-public .search-form .form-control {
  width: clamp(10rem, 12vw, 15rem);
  min-height: 2.35rem;
  border: 1px solid rgba(255, 250, 241, .18);
  background: rgba(255, 250, 241, .09);
  color: #fffaf1;
  box-shadow: none;
}

body.dim-public .search-form .form-control::placeholder {
  color: rgba(255, 250, 241, .58);
}

body.dim-public .search-form .form-control:focus {
  border-color: rgba(240, 200, 115, .58);
  background: rgba(255, 250, 241, .14);
  color: #fff;
  box-shadow: 0 0 0 .2rem rgba(240, 200, 115, .12);
}

body.dim-public .site-search-submit,
body.dim-public .site-lang-switch > .btn {
  min-width: 2.35rem;
  min-height: 2.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-color: rgba(255, 250, 241, .22) !important;
  background: rgba(255, 250, 241, .08) !important;
  color: rgba(255, 250, 241, .9) !important;
  box-shadow: none;
}

body.dim-public .site-search-submit:hover,
body.dim-public .site-lang-switch > .btn:hover,
body.dim-public .site-lang-switch > .btn.show {
  color: #fffaf1 !important;
  border-color: rgba(240, 200, 115, .55) !important;
  background: rgba(240, 200, 115, .14) !important;
}

body.dim-public .navbar-toggler {
  border-color: rgba(255, 250, 241, .32);
  color: #fffaf1;
}

body.dim-public .navbar-toggler-icon {
  filter: invert(1) brightness(2);
}

body.dim-public .home-hero-panel {
  background: linear-gradient(135deg, rgba(9, 15, 18, .9), rgba(21, 32, 25, .82));
  border-color: rgba(255, 250, 241, .26);
  box-shadow: 0 34px 90px rgba(0, 0, 0, .42);
  backdrop-filter: blur(14px) saturate(130%);
}

body.dim-public .home-hero .lead {
  color: rgba(255, 250, 241, .94);
  text-shadow: 0 4px 18px rgba(0, 0, 0, .35);
}

body.dim-public .home-hero-meta span {
  border-color: rgba(255, 250, 241, .28);
  background: rgba(255, 250, 241, .13);
  color: rgba(255, 250, 241, .94);
}

@media (min-width: 1400px) {
  body.dim-public .editorial-grid,
  body.dim-public .home-path-grid,
  body.dim-public .photo-masonry {
    gap: 1.5rem;
  }
}

@media (max-width: 1199.98px) {
  body.dim-public .site-brand-subtitle { display: none; }
  body.dim-public .search-form .form-control { width: 10rem; }
}

@media (max-width: 991.98px) {
  body.dim-public .site-navbar .site-nav-inner { min-height: 64px; }
  body.dim-public .site-navbar .navbar-collapse {
    margin-top: .85rem;
    padding: .9rem;
    border: 1px solid rgba(255, 250, 241, .14);
    border-radius: 1.25rem;
    background: var(--dim-nav-bg-solid) !important;
    box-shadow: 0 24px 55px rgba(0, 0, 0, .32);
  }
  body.dim-public .site-navbar .navbar-nav { gap: .2rem; }
  body.dim-public .site-navbar .nav-link { padding: .72rem .85rem; }
  body.dim-public .site-nav-tools {
    width: 100%;
    margin-left: 0;
    margin-top: .85rem;
    align-items: stretch;
  }
  body.dim-public .search-form { flex: 1 1 auto; }
  body.dim-public .search-form .form-control { width: 100%; }
  body.dim-public .site-lang-switch { margin-top: 0 !important; }
}

@media (max-width: 575.98px) {
  :root { --dim-site-gutter: 1rem; }
  body.dim-public .site-brand-mark {
    width: 2.15rem;
    height: 2.15rem;
  }
  body.dim-public .site-brand-title { font-size: 1rem; }
  body.dim-public .site-nav-tools { flex-wrap: wrap; }
  body.dim-public .site-lang-switch { width: 100%; }
  body.dim-public .site-lang-switch > .btn { width: 100%; }
}

/* Phase 4.2: site-wide visual stabilization and polish.
   Keep these overrides late in the file so every public page gets the same
   readable navigation, breathing room and card rhythm. */
:root {
  --dim-header-offset: clamp(1.4rem, 2.4vw, 2.6rem);
  --dim-page-bottom: clamp(3rem, 5vw, 5rem);
}

/* Public pages need breathing room below the sticky header. Home keeps its
   cinematic hero flush; all other top-level content starts lower. */
body.dim-public .site-main > :not(.hero):not(link):not(script):not(style) {
  margin-top: var(--dim-header-offset);
  margin-bottom: var(--dim-page-bottom);
}
body.dim-public .site-main > .home-intro-section,
body.dim-public .site-main > .home-paths-section,
body.dim-public .site-main > .home-feature-band,
body.dim-public .site-main > .home-explore-section {
  margin-top: 0;
  margin-bottom: 0;
}

/* Make the navbar fully readable on every page, not only when the home hero is
   active. This intentionally wins over nav-priority underline rules. */
body.dim-public .site-navbar,
body.dim-public .site-navbar.bg-white {
  background: rgba(7, 13, 17, .94) !important;
  border-bottom: 1px solid rgba(255, 250, 241, .16) !important;
  box-shadow: 0 18px 45px rgba(0, 0, 0, .22) !important;
  backdrop-filter: saturate(150%) blur(18px);
}
body.dim-public .site-navbar .site-brand,
body.dim-public .site-navbar .site-brand-title,
body.dim-public .site-navbar .nav-link {
  color: #fffaf1 !important;
}
body.dim-public .site-navbar .site-brand-subtitle {
  color: rgba(255, 250, 241, .68) !important;
}
body.dim-public .site-navbar .priority-nav > .nav-item > .nav-link,
body.dim-public .site-navbar .nav-link {
  border: 1px solid transparent !important;
  border-bottom-color: transparent !important;
  text-decoration: none !important;
}
body.dim-public .site-navbar .priority-nav > .nav-item > .nav-link:hover,
body.dim-public .site-navbar .priority-nav > .nav-item > .nav-link:focus,
body.dim-public .site-navbar .priority-nav > .nav-item > .nav-link.show,
body.dim-public .site-navbar .nav-link:hover,
body.dim-public .site-navbar .nav-link:focus,
body.dim-public .site-navbar .nav-link.show {
  color: #fff !important;
  background: rgba(255, 250, 241, .12) !important;
  border-color: rgba(255, 250, 241, .16) !important;
}
body.dim-public .site-navbar .dropdown-menu {
  background: rgba(7, 13, 17, .98) !important;
  border-color: rgba(255, 250, 241, .14) !important;
  box-shadow: 0 28px 70px rgba(0, 0, 0, .38) !important;
}
body.dim-public .site-navbar .dropdown-item {
  color: rgba(255, 250, 241, .86) !important;
}
body.dim-public .site-navbar .dropdown-item:hover,
body.dim-public .site-navbar .dropdown-item:focus,
body.dim-public .site-navbar .dropdown-item.active {
  color: #fffaf1 !important;
  background: rgba(240, 200, 115, .18) !important;
}
body.dim-public .site-navbar .search-form .form-control {
  border-color: rgba(255, 250, 241, .22) !important;
  background: rgba(255, 250, 241, .1) !important;
  color: #fffaf1 !important;
}
body.dim-public .site-navbar .search-form .form-control::placeholder {
  color: rgba(255, 250, 241, .62) !important;
}
body.dim-public .site-navbar .site-search-submit,
body.dim-public .site-navbar .site-lang-switch > .btn {
  border-color: rgba(255, 250, 241, .24) !important;
  background: rgba(255, 250, 241, .09) !important;
  color: #fffaf1 !important;
}
body.dim-public .site-navbar .navbar-toggler {
  border-color: rgba(255, 250, 241, .34) !important;
}
body.dim-public .site-navbar .navbar-toggler-icon {
  filter: invert(1) brightness(2) !important;
}

/* Consistent hero treatment for all listing-style pages. */
body.dim-public .listing-page,
body.dim-public .gallery-experience {
  padding-bottom: clamp(1rem, 2vw, 2rem);
}
body.dim-public .listing-hero,
body.dim-public .gallery-hero {
  margin-top: 0 !important;
  margin-bottom: clamp(1.5rem, 3vw, 2.75rem) !important;
  border-radius: clamp(1.4rem, 2.4vw, 2.25rem) !important;
}
body.dim-public .listing-hero {
  padding: clamp(1.65rem, 3.4vw, 3.15rem) !important;
  background:
    radial-gradient(circle at 9% 0%, rgba(184, 134, 59, .18), transparent 27rem),
    radial-gradient(circle at 96% 20%, rgba(31, 111, 122, .12), transparent 24rem),
    linear-gradient(135deg, rgba(255,250,241,.99), rgba(246,239,227,.94)) !important;
  box-shadow: 0 24px 68px rgba(21, 32, 25, .10) !important;
}
body.dim-public .listing-hero--dark {
  background:
    radial-gradient(circle at 88% 6%, rgba(240, 200, 115, .25), transparent 24rem),
    radial-gradient(circle at 0% 100%, rgba(31, 111, 122, .2), transparent 25rem),
    linear-gradient(135deg, rgba(10, 18, 22, .98), rgba(27, 47, 36, .96)) !important;
  color: rgba(255, 250, 241, .9) !important;
}
body.dim-public .listing-hero--dark .listing-title {
  color: #fffaf1 !important;
}
body.dim-public .listing-hero--dark .listing-lead {
  color: rgba(255, 250, 241, .82) !important;
}
body.dim-public .listing-title {
  max-width: 980px;
}
body.dim-public .listing-lead {
  font-size: clamp(1.04rem, 1.25vw, 1.22rem) !important;
}

/* Make card systems visually consistent with the improved News cards. */
body.dim-public .editorial-card,
body.dim-public .directory-card,
body.dim-public .archive-card,
body.dim-public .album-tile,
body.dim-public .photo-card {
  border-color: rgba(38, 68, 51, .13) !important;
  background: rgba(255, 250, 241, .94) !important;
  box-shadow: 0 18px 48px rgba(21, 32, 25, .09) !important;
}
body.dim-public .editorial-card:hover,
body.dim-public .directory-card:hover,
body.dim-public .archive-card:hover,
body.dim-public .album-tile:hover,
body.dim-public .photo-card:hover {
  border-color: rgba(184, 134, 59, .42) !important;
  box-shadow: 0 28px 72px rgba(21, 32, 25, .14) !important;
}
body.dim-public .editorial-card__media,
body.dim-public .directory-card__media,
body.dim-public .archive-card__cover {
  background:
    linear-gradient(135deg, rgba(216,203,184,.75), rgba(246,239,227,.95)) !important;
}
body.dim-public .editorial-card__media img,
body.dim-public .directory-card__media img,
body.dim-public .archive-card__cover img {
  filter: saturate(1.03) contrast(1.02);
}
body.dim-public .home-text-link {
  margin-top: auto;
}
body.dim-public .directory-card {
  border-radius: var(--dim-radius-lg) !important;
}
body.dim-public .directory-card__body {
  padding: clamp(1.1rem, 2vw, 1.45rem) !important;
}
body.dim-public .archive-grid {
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)) !important;
}

/* Detail/article pages that still use Bootstrap markup should also sit well in
   the wider template instead of sticking to the header. */
body.dim-public article.container,
body.dim-public .container.py-3,
body.dim-public .container.py-4 {
  max-width: min(100% - (var(--dim-site-gutter) * 2), var(--dim-container-readable)) !important;
}
body.dim-public article.container,
body.dim-public .site-main > .container.py-3,
body.dim-public .site-main > .container.py-4 {
  margin-top: var(--dim-header-offset) !important;
  margin-bottom: var(--dim-page-bottom) !important;
}

@media (min-width: 1600px) {
  body.dim-public .editorial-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  body.dim-public .editorial-grid--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  body.dim-public .editorial-card--feature,
  body.dim-public .editorial-card--wide {
    grid-column: span 2;
  }
  body.dim-public .directory-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px) {
  body.dim-public .site-main > :not(.hero):not(link):not(script):not(style) {
    margin-top: 1rem;
  }
  body.dim-public .site-navbar .navbar-collapse {
    background: rgba(7, 13, 17, .98) !important;
  }
  body.dim-public .site-navbar .dropdown-menu {
    margin-top: .35rem;
    box-shadow: none !important;
  }
}

/* Phase 4.3: harmonize Gallery, Gigapixel, and Library Collection layouts
   with the News editorial rhythm. Public-only and additive. */
body.dim-public .listing-page--newslike {
  max-width: min(100% - (var(--dim-site-gutter) * 2), var(--dim-container-wide));
  margin-inline: auto;
}
body.dim-public .listing-page--newslike .listing-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, .24fr);
  gap: clamp(1.1rem, 2.4vw, 2rem);
  align-items: end;
}
body.dim-public .listing-page--newslike .listing-hero > div {
  max-width: 960px;
}
body.dim-public .listing-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: 1.25rem;
}
body.dim-public .listing-hero__stat {
  justify-self: end;
  align-self: stretch;
  min-width: 190px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: .45rem;
  padding: 1rem;
  border-radius: 1.35rem;
  border: 1px solid rgba(38, 68, 51, .10);
  background: rgba(255,255,255,.58);
  box-shadow: 0 12px 28px rgba(21,32,25,.07);
}
body.dim-public .listing-hero__stat-number {
  display: block;
  color: var(--dim-ink);
  font-family: var(--dim-font-serif);
  font-size: clamp(2.55rem, 5vw, 4.85rem);
  line-height: .88;
  letter-spacing: -.055em;
}
body.dim-public .listing-hero__stat-label {
  color: var(--dim-muted);
  font-size: .76rem;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
}
body.dim-public .listing-hero__thumb {
  display: block;
  margin-top: .8rem;
  height: 120px;
  border-radius: 1rem;
  overflow: hidden;
  background: var(--dim-stone);
  box-shadow: 0 14px 28px rgba(21,32,25,.12);
}
body.dim-public .listing-hero__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
body.dim-public .editorial-grid--giga .editorial-card__media,
body.dim-public .collection-card__media {
  min-height: 255px;
}
body.dim-public .collection-card__media img {
  object-fit: cover;
}
body.dim-public .collection-card:not(.collection-card--feature) .collection-card__media img {
  object-position: top center;
}
body.dim-public .collection-card__author {
  color: var(--dim-muted);
  font-size: .94rem;
  margin: 0;
}
body.dim-public .collection-card__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .65rem .85rem;
  margin-top: auto;
}
body.dim-public .collection-card__actions .home-text-link {
  margin-top: 0;
}
body.dim-public .collection-grid.books-grid {
  align-items: stretch;
}
body.dim-public .listing-page--collection .btn-outline-secondary {
  border-radius: 999px;
  border-color: rgba(38,68,51,.18);
  background: rgba(255,250,241,.74);
  color: var(--dim-forest);
  font-weight: 750;
}
body.dim-public .listing-page--collection .btn-outline-secondary:hover {
  border-color: var(--dim-forest);
  background: var(--dim-forest);
  color: #fffaf1;
}
@media (min-width: 1600px) {
  body.dim-public .listing-page--newslike .editorial-grid--news {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  body.dim-public .listing-page--newslike .editorial-card--feature {
    grid-column: span 2;
  }
}
@media (max-width: 991.98px) {
  body.dim-public .listing-page--newslike .listing-hero {
    grid-template-columns: 1fr;
  }
  body.dim-public .listing-hero__stat {
    justify-self: stretch;
    align-self: auto;
    min-width: 0;
  }
}
@media (max-width: 575.98px) {
  body.dim-public .listing-page--newslike {
    max-width: min(100% - 1.3rem, var(--dim-container-wide));
  }
  body.dim-public .listing-hero__stat {
    padding: .85rem;
  }
}

/* Phase 4.3.1: hero stabilization after news-style harmonization.
   News is the reference: all listing heroes should be a simple editorial panel,
   not a multi-column/stat grid. Keep this late in the cascade. */
body.dim-public .listing-page--newslike .listing-hero,
body.dim-public .gallery-experience .listing-hero,
body.dim-public .listing-page--collection .listing-hero,
body.dim-public .listing-page--giga .listing-hero {
  display: block !important;
  grid-template-columns: none !important;
  align-items: initial !important;
  gap: 0 !important;
}
body.dim-public .listing-page--newslike .listing-hero > div,
body.dim-public .gallery-experience .listing-hero > div,
body.dim-public .listing-page--collection .listing-hero > div,
body.dim-public .listing-page--giga .listing-hero > div {
  max-width: 960px !important;
}
body.dim-public .listing-hero__summary {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: 1rem;
}
body.dim-public .listing-hero__summary span {
  display: inline-flex;
  align-items: baseline;
  gap: .38rem;
  padding: .5rem .78rem;
  border-radius: 999px;
  border: 1px solid rgba(38, 68, 51, .13);
  background: rgba(255, 255, 255, .58);
  color: var(--dim-muted);
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .045em;
  text-transform: uppercase;
  box-shadow: 0 10px 24px rgba(21, 32, 25, .06);
}
body.dim-public .listing-hero__summary strong {
  color: var(--dim-ink);
  font-family: var(--dim-font-serif);
  font-size: 1.15rem;
  letter-spacing: -.03em;
}
body.dim-public .gallery-listing-hero,
body.dim-public .collection-hero,
body.dim-public .listing-page--giga .listing-hero {
  min-height: 0 !important;
  color: var(--dim-ink) !important;
}
body.dim-public .gallery-listing-hero .listing-kicker,
body.dim-public .collection-hero .listing-kicker,
body.dim-public .listing-page--giga .listing-kicker {
  color: var(--dim-gold) !important;
}
body.dim-public .gallery-listing-hero .listing-title,
body.dim-public .collection-hero .listing-title,
body.dim-public .listing-page--giga .listing-title {
  color: var(--dim-ink) !important;
}
body.dim-public .gallery-listing-hero .listing-lead,
body.dim-public .collection-hero .listing-lead,
body.dim-public .listing-page--giga .listing-lead {
  color: var(--dim-muted) !important;
}
body.dim-public .listing-hero__stat {
  display: none !important;
}
body.dim-public .album-detail-hero,
body.dim-public .album-detail-hero--editorial {
  min-height: 0 !important;
}
body.dim-public .album-editorial-copy--newslike {
  margin-top: 0 !important;
  margin-bottom: clamp(1.25rem, 2.5vw, 2rem) !important;
}

/* Phase 4.3.3: home quote/stat refinement. The quote is part of the
   introduction, while content counts move to a discreet footer treatment. */
body.dim-public .home-intro-editorial {
  max-width: var(--dim-container-wide, 1680px);
  margin: 0 auto;
}

body.dim-public .home-intro-copy-wrap {
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

body.dim-public .home-intro-copy-wrap .home-section-title {
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
}

body.dim-public .home-intro-copy-wrap .home-intro-copy {
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

body.dim-public .home-quote-card--featured {
  max-width: 1180px;
  margin: clamp(1.35rem, 3vw, 2.5rem) auto clamp(1.65rem, 3vw, 2.65rem);
  padding: clamp(1.35rem, 3vw, 2.45rem);
  border-color: rgba(184, 134, 59, .28);
  background:
    radial-gradient(circle at 96% 2%, rgba(184, 134, 59, .18), transparent 18rem),
    linear-gradient(135deg, rgba(255, 250, 241, .99), rgba(245, 237, 224, .94));
  box-shadow: 0 24px 70px rgba(21, 32, 25, .12);
}

body.dim-public .home-quote-card--featured::before {
  content: "“";
  position: absolute;
  top: -.45rem;
  right: clamp(1rem, 4vw, 3rem);
  width: auto;
  height: auto;
  background: none;
  color: rgba(184, 134, 59, .18);
  font-family: var(--dim-font-serif);
  font-size: clamp(5rem, 12vw, 11rem);
  line-height: 1;
}

body.dim-public .home-quote-card--featured blockquote {
  max-width: 1120px;
  margin-bottom: 0;
  font-size: clamp(1.55rem, 3vw, 3.05rem);
  line-height: 1.08;
  letter-spacing: -.035em;
}

body.dim-public .home-quote-card--featured blockquote span {
  color: var(--dim-forest);
}

body.dim-public .site-footer-stats {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  text-align: center;
  gap: .5rem .65rem;
  margin: .25rem auto 1rem;
  padding: .75rem 0 0;
  border-top: 1px solid rgba(255, 250, 241, .08);
  color: rgba(255, 250, 241, .58);
  font-size: .82rem;
}

body.dim-public .site-footer-stats .site-footer-stat,
body.dim-public .site-footer-stats span {
  display: inline-flex;
  align-items: baseline;
  gap: .3rem;
  padding: .28rem .6rem;
  border: 1px solid rgba(255, 250, 241, .1);
  border-radius: 999px;
  background: rgba(255, 250, 241, .035);
}

body.dim-public .site-footer-stats .site-footer-stat {
  color: rgba(255, 250, 241, .58);
  text-decoration: none;
  transition: border-color .18s ease, background .18s ease, color .18s ease, transform .18s ease;
}

body.dim-public .site-footer-stats .site-footer-stat:hover,
body.dim-public .site-footer-stats .site-footer-stat:focus {
  color: rgba(255, 250, 241, .92);
  border-color: rgba(240, 200, 115, .32);
  background: rgba(240, 200, 115, .08);
  transform: translateY(-1px);
}

body.dim-public .site-footer-stats strong {
  color: rgba(255, 250, 241, .86);
  font-weight: 800;
}

@media (max-width: 767.98px) {
  body.dim-public .home-quote-card--featured blockquote {
    font-size: clamp(1.45rem, 9vw, 2.15rem);
  }
  body.dim-public .site-footer-stats {
    gap: .45rem;
    justify-content: center;
  }
}


/* Phase 4.3.6: home editorial intro media and refined brand/meta styling. */
body.dim-public .site-brand-text {
  justify-content: center;
}

body.dim-public .home-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem 1rem;
  align-items: center;
}

body.dim-public .home-hero-meta span {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: 0;
  border: 0 !important;
  border-radius: 0;
  background: none !important;
  color: rgba(255, 250, 241, .82) !important;
  font-size: .84rem;
  font-weight: 650;
  letter-spacing: .04em;
  text-transform: uppercase;
}

body.dim-public .home-hero-meta span::before {
  content: "•";
  color: rgba(240, 200, 115, .72);
  font-size: .95em;
  line-height: 1;
}

body.dim-public .home-hero-meta span:first-child::before {
  content: "";
  display: none;
}

body.dim-public .home-intro-copy {
  text-align: center;
}

body.dim-public .home-intro-media-board {
  display: grid;
  grid-template-columns: minmax(0, .88fr) minmax(0, 1.12fr);
  gap: 1rem;
  align-items: stretch;
  width: min(100%, 1060px);
  margin: clamp(1.5rem, 3vw, 2rem) auto;
  text-align: left;
}

body.dim-public .home-intro-figure {
  position: relative;
  margin: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 1.45rem;
  border: 1px solid rgba(21, 32, 25, .08);
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,244,237,.96));
  box-shadow: 0 24px 65px rgba(21, 32, 25, .14);
}

body.dim-public .home-intro-figure img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
  display: block;
}

body.dim-public .home-intro-figure--portrait {
  min-height: 32rem;
}

body.dim-public .home-intro-figure--landscape {
  min-height: 32rem;
}

body.dim-public .home-intro-figure figcaption {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  padding: .8rem .95rem;
  border-radius: .95rem;
  background: rgba(7, 13, 17, .68);
  color: rgba(255, 250, 241, .94);
  font-size: .86rem;
  line-height: 1.45;
  box-shadow: 0 12px 28px rgba(0, 0, 0, .2);
  backdrop-filter: blur(10px);
}

@media (max-width: 991.98px) {
  body.dim-public .home-intro-media-board {
    grid-template-columns: 1fr;
  }
  body.dim-public .home-intro-figure--portrait,
  body.dim-public .home-intro-figure--landscape {
    min-height: 25rem;
  }
}

@media (max-width: 575.98px) {
  body.dim-public .home-hero-meta {
    gap: .5rem .75rem;
    justify-content: center;
  }
  body.dim-public .home-hero-meta span {
    font-size: .75rem;
    letter-spacing: .03em;
  }
  body.dim-public .home-intro-figure--portrait,
  body.dim-public .home-intro-figure--landscape {
    min-height: 19rem;
  }
  body.dim-public .home-intro-figure figcaption {
    left: .75rem;
    right: .75rem;
    bottom: .75rem;
    padding: .7rem .8rem;
    font-size: .8rem;
  }
}

/* Phase 4.3.9: make /library/collections follow the News editorial rhythm. */
body.dim-public .listing-page--collections .listing-hero {
  max-width: var(--dim-container-wide, 1680px);
}

body.dim-public .editorial-grid--collections .editorial-card__media {
  min-height: 260px;
}

body.dim-public .editorial-grid--collections .editorial-card--feature .editorial-card__media {
  min-height: 340px;
}

body.dim-public .editorial-grid--collections .editorial-card__body p {
  max-width: 66ch;
}


/* Phase 4.3.11: make /giga follow the same clean News-style card rhythm.
   Keep this late so older panorama-specific listing classes cannot change the
   visual treatment of the Giga listing page. */
body.dim-public .listing-page--giga.listing-page--news-style {
  max-width: min(100% - (var(--dim-site-gutter, clamp(1rem, 3vw, 3.25rem)) * 2), var(--dim-container-wide, 1680px));
  margin-left: auto;
  margin-right: auto;
}

body.dim-public .listing-page--giga.listing-page--news-style .listing-hero {
  display: block !important;
  min-height: 0 !important;
  color: var(--dim-ink) !important;
}

body.dim-public .listing-page--giga.listing-page--news-style .listing-hero > div {
  max-width: 960px !important;
}

body.dim-public .listing-page--giga.listing-page--news-style .editorial-grid--news {
  align-items: stretch;
}

body.dim-public .listing-page--giga.listing-page--news-style .editorial-card__media {
  min-height: 0;
}

/* Phase 4.3.22: privacy, terms and human sitemap theme alignment. */
body.dim-public .utility-page {
  width: min(calc(100% - (var(--dim-site-gutter, clamp(1rem, 3vw, 3.25rem)) * 2)), var(--dim-container-wide, 1680px));
  max-width: var(--dim-container-wide, 1680px);
  margin-left: auto;
  margin-right: auto;
}

body.dim-public .utility-hero {
  margin-bottom: clamp(1.5rem, 3vw, 2.5rem) !important;
}

body.dim-public .utility-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(38, 68, 51, .13);
  border-radius: clamp(1.2rem, 2.2vw, 2rem);
  background:
    radial-gradient(circle at 98% 0%, rgba(184, 134, 59, .12), transparent 18rem),
    linear-gradient(180deg, rgba(255, 250, 241, .98), rgba(246, 239, 227, .92));
  box-shadow: 0 22px 58px rgba(21, 32, 25, .10);
}

body.dim-public .utility-prose {
  width: min(100%, 1040px);
  margin: 0 auto;
  padding: clamp(1.25rem, 3vw, 3rem);
  color: var(--dim-ink);
  font-size: clamp(1rem, 1.05vw, 1.08rem);
  line-height: 1.82;
}

body.dim-public .utility-prose h1,
body.dim-public .utility-prose h2,
body.dim-public .utility-prose h3,
body.dim-public .utility-prose h4,
body.dim-public .utility-prose h5,
body.dim-public .utility-prose h6 {
  color: var(--dim-ink);
  font-family: var(--dim-font-serif);
  font-weight: 760;
  letter-spacing: -.025em;
  line-height: 1.15;
  margin-top: clamp(1.5rem, 3vw, 2.2rem);
  margin-bottom: .75rem;
}

body.dim-public .utility-prose h2 {
  font-size: clamp(1.45rem, 2.4vw, 2.05rem);
}

body.dim-public .utility-prose h3 {
  font-size: clamp(1.18rem, 1.8vw, 1.45rem);
}

body.dim-public .utility-prose p,
body.dim-public .utility-prose li {
  color: var(--dim-muted);
}

body.dim-public .utility-prose p {
  margin-bottom: 1.05rem;
}

body.dim-public .utility-prose a {
  color: var(--dim-teal);
  font-weight: 750;
  text-decoration: none;
  border-bottom: 1px solid rgba(31, 111, 122, .28);
}

body.dim-public .utility-prose a:hover,
body.dim-public .utility-prose a:focus {
  color: var(--dim-forest);
  border-bottom-color: rgba(38, 68, 51, .55);
}

body.dim-public .utility-prose ul,
body.dim-public .utility-prose ol {
  padding-left: 1.35rem;
  margin-bottom: 1.25rem;
}

body.dim-public .utility-prose li::marker {
  color: var(--dim-gold);
}

body.dim-public .utility-grid,
body.dim-public .sitemap-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
}

body.dim-public .sitemap-card {
  padding: clamp(1.1rem, 2.4vw, 1.65rem);
}

body.dim-public .sitemap-card h2 {
  margin: 0 0 1rem;
  color: var(--dim-ink);
  font-family: var(--dim-font-serif);
  font-size: clamp(1.35rem, 2vw, 1.8rem);
  letter-spacing: -.03em;
}

body.dim-public .sitemap-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

body.dim-public .sitemap-list li {
  border-bottom: 1px solid rgba(38, 68, 51, .1);
}

body.dim-public .sitemap-list li:last-child {
  border-bottom: 0;
}

body.dim-public .sitemap-list a {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: .72rem 0;
  color: var(--dim-muted);
  font-weight: 720;
  text-decoration: none;
}

body.dim-public .sitemap-list a::after {
  content: "›";
  color: var(--dim-gold);
  transition: transform .18s ease;
}

body.dim-public .sitemap-list a:hover,
body.dim-public .sitemap-list a:focus {
  color: var(--dim-forest);
}

body.dim-public .sitemap-list a:hover::after,
body.dim-public .sitemap-list a:focus::after {
  transform: translateX(.2rem);
}

body.dim-public .utility-note {
  width: min(100%, 1040px);
  margin: clamp(1.25rem, 2.5vw, 2rem) auto 0;
  padding: .95rem 1.15rem;
  border: 1px solid rgba(38, 68, 51, .1);
  border-radius: 999px;
  background: rgba(255, 250, 241, .75);
  color: var(--dim-muted);
  text-align: center;
  box-shadow: 0 12px 34px rgba(21, 32, 25, .06);
}

body.dim-public .utility-note p {
  margin: 0;
}

@media (max-width: 991.98px) {
  body.dim-public .utility-grid,
  body.dim-public .sitemap-grid {
    grid-template-columns: 1fr;
  }
  body.dim-public .utility-note {
    border-radius: 1.25rem;
  }
}


/* Phase 4.3.23: prettier human sitemap link cards. */
body.dim-public .sitemap-card {
  padding: clamp(1.15rem, 2.2vw, 1.85rem);
}

body.dim-public .sitemap-card h2 {
  display: flex;
  align-items: center;
  gap: .7rem;
  margin-bottom: 1.15rem;
}

body.dim-public .sitemap-card h2::before {
  content: "";
  width: .58rem;
  height: .58rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--dim-gold), var(--dim-teal));
  box-shadow: 0 0 0 .28rem rgba(184, 134, 59, .12);
}

body.dim-public .sitemap-list {
  display: none;
}

body.dim-public .sitemap-link-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: .65rem;
}

body.dim-public .sitemap-link-card {
  position: relative;
  display: grid;
  grid-template-columns: 2.45rem minmax(0, 1fr) auto;
  align-items: center;
  gap: .75rem;
  min-height: 3.25rem;
  padding: .72rem .82rem;
  border: 1px solid rgba(38, 68, 51, .10);
  border-radius: 1rem;
  background: rgba(255, 255, 255, .42);
  color: var(--dim-ink);
  text-decoration: none;
  box-shadow: 0 10px 26px rgba(21, 32, 25, .055);
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

body.dim-public .sitemap-link-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: .85rem;
  background: linear-gradient(135deg, rgba(184, 134, 59, .18), rgba(31, 111, 122, .12));
  color: var(--dim-forest);
  font-weight: 900;
  font-size: 1rem;
  line-height: 1;
}

body.dim-public .sitemap-link-text {
  min-width: 0;
  color: var(--dim-ink);
  font-weight: 780;
  letter-spacing: -.01em;
}

body.dim-public .sitemap-link-arrow {
  color: var(--dim-gold);
  font-weight: 900;
  transition: transform .18s ease;
}

body.dim-public .sitemap-link-card:hover,
body.dim-public .sitemap-link-card:focus {
  transform: translateY(-2px);
  border-color: rgba(184, 134, 59, .28);
  background: rgba(255, 250, 241, .9);
  box-shadow: 0 18px 38px rgba(21, 32, 25, .10);
}

body.dim-public .sitemap-link-card:hover .sitemap-link-arrow,
body.dim-public .sitemap-link-card:focus .sitemap-link-arrow {
  transform: translateX(.18rem);
}

@media (min-width: 1200px) {
  body.dim-public .sitemap-link-grid {
    gap: .72rem;
  }
}

@media (max-width: 575.98px) {
  body.dim-public .sitemap-link-card {
    grid-template-columns: 2.2rem minmax(0, 1fr) auto;
    padding: .66rem .72rem;
  }
  body.dim-public .sitemap-link-icon {
    width: 2rem;
    height: 2rem;
  }
}
