/* ═══════════════════════════════════════════
   SEAMLESS GALLERY — jonathan-moyal.com
   ═══════════════════════════════════════════ */

/* ── ABOUT BIO (contact page) ── */
.about-bio {
  font-family: Rubik, Helvetica, sans-serif;
  font-weight: 300;
  font-size: 15px;
  line-height: 1.85;
  color: #4a4a4a;
  margin: 0;
  max-width: 56ch;
  padding: 8px 0 0;
}
.about-bio__kicker {
  font-family: Comfortaa, sans-serif;
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #888;
  display: block;
  margin: 0 0 18px;
}

/* ── GRID ── */
.gallery-grid {
  padding: 0;
}

.gallery-item {
  width: calc(25% - 5px);
  margin-bottom: 6px;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  background: #f5f5f5;
}
.gallery-item img.gallery-thumb {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.gallery-item .gallery-overlay {
  z-index: 2;
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 20px;
  transition: background 0.3s ease;
}
@media (hover: hover) {
  .gallery-item:hover .gallery-overlay { background: rgba(0,0,0,0.35); }
  .gallery-item:hover .gallery-overlay h2,
  .gallery-item:hover .gallery-overlay span { opacity: 1; transform: translateY(0); }
  .gallery-item:hover img.gallery-thumb { transform: scale(1.03); }
}
.gallery-item .gallery-overlay h2 {
  color: #fff;
  font-family: 'Comfortaa', sans-serif;
  font-weight: 300;
  font-size: 15px;
  letter-spacing: 3px;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.3s ease;
  margin: 0 0 6px;
}
.gallery-item .gallery-overlay span {
  color: #fff;
  font-family: 'Comfortaa', sans-serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-decoration: underline;
  text-underline-offset: 4px;
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.3s ease 0.05s;
}


/* ── FULLSCREEN VIEWER ── */
.viewer {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: #fff;
  display: none;
  flex-direction: column;
}
.viewer.open {
  display: flex;
}
.viewer-header {
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 30px;
  flex-shrink: 0;
}
.viewer-header h2 {
  font-family: 'Pullman', serif;
  font-weight: 300;
  font-size: 14px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #333;
}
.viewer-close {
  background: none;
  border: none;
  font-size: 14px;
  letter-spacing: 2px;
  color: #333;
  cursor: pointer;
  font-family: 'Comfortaa', sans-serif;
  text-transform: lowercase;
  transition: opacity 0.2s;
}
.viewer-close:hover { opacity: 0.5; }

.viewer-body {
  flex: 1;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 0 60px;
}
.viewer-img {
  max-width: 800px;
  max-height: 70vh;
  width: auto;
  height: auto;
  object-fit: contain;
  transition: opacity 0.3s ease;
}

/* The clone that animates from grid to viewer */
.viewer-clone {
  position: fixed;
  z-index: 10001;
  object-fit: cover;
  pointer-events: none;
  transition: all 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: top, left, width, height, object-fit;
}

.viewer-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  font-size: 40px;
  color: #333;
  cursor: pointer;
  padding: 20px;
  transition: opacity 0.2s;
  z-index: 2;
  user-select: none;
}
.viewer-arrow:hover { opacity: 0.4; }
.viewer-prev { left: 0; }
.viewer-next { right: 0; }

.viewer-footer {
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  gap: 20px;
}
.viewer-counter {
  font-family: 'Comfortaa', sans-serif;
  font-size: 13px;
  color: #999;
  letter-spacing: 2px;
}
.viewer-info {
  font-family: 'Comfortaa', sans-serif;
  font-size: 12px;
  color: #999;
}

/* ── NAV MENU ENHANCEMENTS ── */
.nav-menu-wrapper { background: #fff !important; overflow: hidden; }
.nav-preview {
  position: absolute; inset: 0; z-index: 0;
  opacity: 0; transition: opacity 0.6s ease, transform 0.6s ease;
  transform: scale(1.05); background-size: cover; background-position: center;
}
.nav-preview.visible { opacity: 0.15; transform: scale(1); }
.nav-menu-wrapper .nav-links-wrapper { position: relative; z-index: 2; }
.nav-menu-wrapper .link-block-2 {
  position: relative; overflow: hidden;
  transition: all 0.4s ease; padding: 12px 0 !important;
}
.nav-menu-wrapper .link-block-2 .heading-12 {
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.nav-menu-wrapper .link-block-2:hover .heading-12 {
  transform: translateX(20px) scale(1.05); letter-spacing: 0.08em;
}
.nav-menu-wrapper .link-block-2::after {
  content: ''; position: absolute; bottom: 6px; left: 0;
  width: 0; height: 1px; background: #111;
  transition: width 0.45s cubic-bezier(0.16, 1, 0.3, 1);
}
.nav-menu-wrapper .link-block-2:hover::after { width: 100%; }
.nav-menu-wrapper .link-block-2::before {
  content: '→'; position: absolute; right: 40px; top: 50%;
  transform: translateY(-50%) translateX(-20px);
  opacity: 0; font-size: 24px; color: #333;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.nav-menu-wrapper .link-block-2:hover::before {
  opacity: 1; transform: translateY(-50%) translateX(0);
}
.close-nav-button { z-index: 3; position: relative; transition: transform 0.3s ease; }
.close-nav-button:hover { transform: rotate(90deg); }
.nav-menu-wrapper .div-block-23 { position: relative; z-index: 2; }


/* Nav text — homogeneous across all pages */
.nav-menu-wrapper .heading-12 {
  color: #222 !important;
  font-size: 17px !important;
  letter-spacing: 3px !important;
  white-space: nowrap;
  font-weight: 300;
}
.nav-menu-wrapper .link-block-2 {
  opacity: 1 !important;
  padding: 10px 0 !important;
  justify-content: flex-start !important;
  width: auto;
  margin-bottom: 0 !important;
}
.nav-menu-wrapper .link-block-2::before { display: none !important; }
.nav-menu-wrapper .link-block-2:hover .heading-12 {
  transform: translateX(6px) !important;
  letter-spacing: 3px !important;
}
.nav-menu-wrapper .link-block-2:hover .heading-12 {
  color: #000 !important;
}
.nav-menu-wrapper .nav-links-wrapper {
  position: relative;
  z-index: 2;
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding-left: 14%;
  height: 70vh;
  width: 100%;
  box-sizing: border-box;
}
.nav-menu-wrapper .div-block-23 {
  position: absolute;
  bottom: 30px;
  left: 0; right: 0; text-align: center;
  z-index: 2;
}
.nav-menu-wrapper .div-block-23 .heading-18,
.nav-menu-wrapper .div-block-23 a {
  color: #999 !important;
  font-size: 13px !important;
}
.nav-menu-wrapper .close-nav-button {
  position: absolute;
  top: 30px;
  right: 30px;
}

/* Hide old Webflow gallery structure */
body.has-viewer .modal-cms { display: none !important; }


/* Mobile: no hover blocking */
@media (hover: none) {
  .gallery-item .gallery-overlay { background: rgba(0,0,0,0); }
  .gallery-item .gallery-overlay h2,
  .gallery-item .gallery-overlay span { opacity: 0; }
}

@media (hover: none) {
  .gallery-item .gallery-overlay { pointer-events: none; }
}

/* Mobile viewer layout */
@media (max-width: 767px) {
  .viewer-body { padding: 0 10px; }
  .viewer-arrow { display: none; }
  .viewer-footer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
    height: 60px;
  }
  .viewer-mob-prev, .viewer-mob-next {
    background: none;
    border: none;
    font-size: 28px;
    color: #333;
    padding: 10px;
    cursor: pointer;
  }
  .gallery-item .gallery-overlay {
    background: rgba(0,0,0,0.3);
  }
  .gallery-item .gallery-overlay h2,
  .gallery-item .gallery-overlay span {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Voyages: no overlay on thumbnails */
body.page-voyages .gallery-overlay { display: none; }

@media (max-width: 991px) { .gallery-item { width: calc(33.33% - 4px); } }
@media (max-width: 767px) { .gallery-item { width: calc(50% - 3px); } }
@media (max-width: 479px) { .gallery-item { width: 100%; } }

/* ══════════════════════════════════════════════════════════
   SEO CONTENT — styles for homepage intro + portfolio outros
   Visually aligned with site (Comfortaa headings, Rubik body)
   ══════════════════════════════════════════════════════════ */

/* Screen-reader-only — H1 for SEO without visible UI */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Shared typography for visible SEO blocks */
.seo-intro, .seo-page-outro {
  font-family: Rubik, Helvetica, sans-serif;
  color: #555;
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
}
.seo-intro h1, .seo-intro h2, .seo-intro h3,
.seo-page-outro h2, .seo-page-outro h3 {
  font-family: Comfortaa, sans-serif;
  font-weight: 300;
  color: #111;
  letter-spacing: 3px;
  text-transform: uppercase;
  line-height: 1.4;
  margin: 0;
}
.seo-intro p, .seo-page-outro p {
  margin: 0;
  font-size: 14px;
  line-height: 1.85;
  color: #555;
  max-width: 65ch;
}
.seo-intro a, .seo-page-outro a {
  color: #111;
  text-decoration: none;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  transition: border-color 0.3s ease;
}
.seo-intro a:hover, .seo-page-outro a:hover { border-bottom-color: #111; }

/* HOMEPAGE: .menu-wrapper is position:fixed; height:100% — it covers the
   whole viewport invisibly, blocking clicks on .seo-intro below the hero.
   Make wrapper transparent to clicks but keep nav links clickable. */
.menu-wrapper { pointer-events: none; }
.menu-wrapper > a { pointer-events: auto; }

/* HOMEPAGE INTRO */
.seo-intro {
  position: relative;
  z-index: 7;
  background: #fff;
  padding: clamp(120px, 16vw, 200px) clamp(32px, 8vw, 120px);
}
.seo-intro__inner {
  max-width: 1200px;
  margin: 0 auto;
}
.seo-intro__h1 {
  font-size: clamp(14px, 1.2vw, 16px);
  letter-spacing: 4px;
  margin: 0 0 64px !important;
  max-width: 760px;
  line-height: 1.5;
}
.seo-intro p.seo-intro__lede {
  font-size: 15px;
  line-height: 2;
  margin: 0 0 140px;
  max-width: 760px;
  color: #555;
}
.seo-intro__h2 {
  font-size: 12px;
  letter-spacing: 4px;
  margin: 0 0 56px !important;
  color: #888;
  max-width: none;
}
.seo-intro__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(40px, 5vw, 72px);
  margin-bottom: 120px;
}
.seo-intro__card {
  border-top: 1px solid #d8d8d8;
  padding-top: 32px;
}
.seo-intro__card h3 {
  font-size: 11px;
  letter-spacing: 3px;
  margin: 0 0 20px;
}
.seo-intro__card h3 a { border-bottom: none; }
.seo-intro__card p {
  font-size: 13.5px;
  line-height: 1.85;
  color: #5a5a5a;
  max-width: none;
}
/* The "Une approche sur-mesure" paragraph below the grid — full width */
.seo-intro p.seo-intro__approche {
  font-size: 15px;
  line-height: 2;
  margin: 0 0 96px;
  max-width: 820px;
  color: #555;
}
.seo-intro__cta {
  margin: 0;
  padding: 0;
  text-align: center;
  max-width: none !important;
}
.seo-intro__btn {
  display: inline-block;
  padding: 20px 52px;
  border: 1px solid #111;
  color: #111;
  font-family: Comfortaa, sans-serif;
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 4px;
  text-transform: uppercase;
  text-decoration: none;
  background: transparent;
  transition: background 0.35s ease, color 0.35s ease;
}
.seo-intro__btn:hover {
  background: #111;
  color: #fff;
  border-bottom-color: #111;
}
@media (max-width: 768px) {
  .seo-intro { padding: 80px 24px 96px; }
  .seo-intro__grid { grid-template-columns: 1fr; gap: 36px; margin-bottom: 80px; }
  .seo-intro__lede { margin-bottom: 80px; }
  .seo-intro__h2 { margin: 0 0 40px; }
  .seo-intro__approche { margin-bottom: 64px; }
}

/* PORTFOLIO PAGE OUTRO (below gallery) */
.seo-page-outro {
  background: #fafafa;
  padding: clamp(72px, 9vw, 110px) clamp(24px, 6vw, 80px);
  margin-top: clamp(48px, 6vw, 80px);
  border-top: 1px solid #ececec;
}
.seo-page-outro__inner { max-width: 1100px; margin: 0 auto; }
.seo-page-outro h2 {
  font-size: clamp(13px, 1.2vw, 16px);
  letter-spacing: 4px;
  margin-bottom: 40px;
}
.seo-page-outro h3 {
  font-size: 12px;
  letter-spacing: 3px;
  margin: 48px 0 16px;
  color: #888;
}
.seo-page-outro p {
  font-size: 14px;
  line-height: 1.85;
  margin-bottom: 18px;
  max-width: 65ch;
}
.seo-page-outro p + h3 { margin-top: 56px; }
@media (max-width: 768px) {
  .seo-page-outro { padding: 56px 20px 72px; }
  .seo-page-outro h3 { margin-top: 40px; }
}

/* ══════════════════════════════════════════════════════════
   SERVICE PAGES — dedicated landing pages for services
   /photographe-architecture-interieure-paris, etc.
   ══════════════════════════════════════════════════════════ */
.service-page {
  font-family: Rubik, Helvetica, sans-serif;
  color: #4a4a4a;
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  background: #fff;
  /* clear the fixed 150px nav */
  padding: clamp(200px, 24vh, 260px) clamp(32px, 8vw, 120px) clamp(96px, 12vw, 160px);
}
.service-page__inner {
  max-width: 780px;
  margin: 0 auto;
}
.service-page__header {
  text-align: center;
  margin-bottom: clamp(64px, 8vw, 96px);
  padding-bottom: clamp(48px, 6vw, 72px);
  border-bottom: 1px solid #ececec;
}
.service-page__h1 {
  font-family: Comfortaa, sans-serif;
  font-weight: 300;
  color: #111;
  font-size: clamp(14px, 1.4vw, 18px);
  letter-spacing: 3px;
  text-transform: uppercase;
  line-height: 1.6;
  margin: 0 auto 32px;
  max-width: none;
}
.service-page__lede {
  font-size: 15.5px;
  line-height: 1.9;
  color: #4a4a4a;
  margin: 0 auto;
  max-width: 60ch;
}
.service-page h2 {
  font-family: Comfortaa, sans-serif;
  font-weight: 300;
  color: #111;
  font-size: clamp(13px, 1.2vw, 15px);
  letter-spacing: 3px;
  text-transform: uppercase;
  line-height: 1.5;
  margin: 0 0 28px;
}
.service-page h3 {
  font-family: Comfortaa, sans-serif;
  font-weight: 300;
  color: #888;
  font-size: 12px;
  letter-spacing: 3px;
  text-transform: uppercase;
  margin: 40px 0 16px;
}
.service-page p {
  font-size: 15px;
  line-height: 1.9;
  color: #4a4a4a;
  max-width: none;
  margin: 0 0 22px;
}
.service-page ul,
.service-page ol {
  font-size: 15px;
  line-height: 1.9;
  color: #4a4a4a;
  max-width: none;
  padding: 0;
  margin: 0 0 24px 24px;
}
.service-page li {
  margin-bottom: 10px;
}
.service-page a {
  color: #111;
  text-decoration: none;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  transition: border-color 0.3s ease;
}
.service-page a:hover { border-bottom-color: #111; }
.service-page__section {
  margin-bottom: clamp(56px, 8vw, 96px);
}
.service-page__cta {
  text-align: center;
  margin-top: clamp(64px, 10vw, 120px);
  padding-top: clamp(64px, 8vw, 96px);
  border-top: 1px solid #ececec;
}
.service-page__cta p {
  max-width: none;
  margin: 0 0 32px;
}
.service-page__btn {
  display: inline-block;
  padding: 20px 52px;
  border: 1px solid #111 !important;
  color: #111 !important;
  font-family: Comfortaa, sans-serif;
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 4px;
  text-transform: uppercase;
  background: transparent;
  transition: background 0.35s ease, color 0.35s ease;
  text-decoration: none;
}
.service-page__btn:hover {
  background: #111;
  color: #fff !important;
}
@media (max-width: 768px) {
  .service-page { padding: 140px 24px 80px; }
  .service-page__header { margin-bottom: 56px; }
}

/* ══════════════════════════════════════════════════════════
   BLOG — editorial magazine layout
   Inspired by Dezeen, AD, The Socialite Family.
   Fonts: Oranienbaum (serif editorial), Comfortaa (labels),
   Rubik (body).
   ══════════════════════════════════════════════════════════ */

/* ── HEADER (text-only, no hero image) ── */
.blog-header {
  background: #fff;
  padding: clamp(200px, 24vh, 260px) clamp(24px, 6vw, 80px) clamp(56px, 7vw, 80px);
  text-align: center;
  border-bottom: 1px solid #ececec;
}
.blog-header__inner { max-width: 800px; margin: 0 auto; }
.blog-header__kicker {
  font-family: Comfortaa, sans-serif;
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: #888;
  margin: 0 0 24px;
}
.blog-header__h1 {
  font-family: Oranienbaum, 'DM Serif Display', Georgia, serif;
  font-weight: 400;
  font-size: clamp(30px, 4.5vw, 54px);
  line-height: 1.12;
  letter-spacing: -0.3px;
  color: #111;
  margin: 0 0 32px;
}
.blog-header__meta {
  font-family: Comfortaa, sans-serif;
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #888;
  margin: 0;
}
.blog-header__meta a { color: #555; border-bottom: 1px solid #ccc; text-decoration: none; }
.blog-header__meta a:hover { color: #111; border-bottom-color: #111; }

/* ── ARTICLE BODY ── */
.blog-article {
  font-family: Rubik, Helvetica, sans-serif;
  background: #fff;
  color: #3a3a3a;
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  padding: clamp(72px, 10vw, 120px) clamp(24px, 6vw, 60px) clamp(96px, 12vw, 160px);
}
.blog-content {
  max-width: 720px;
  margin: 0 auto;
}
.blog-content p {
  font-size: 17px;
  line-height: 1.85;
  margin: 0 0 28px;
  color: #3a3a3a;
}
.blog-content > p:first-of-type::first-letter {
  font-family: Oranienbaum, 'DM Serif Display', Georgia, serif;
  font-weight: 400;
  float: left;
  font-size: clamp(72px, 9vw, 104px);
  line-height: 0.85;
  margin: 6px 18px 0 0;
  color: #111;
}
.blog-content h2 {
  font-family: Oranienbaum, 'DM Serif Display', Georgia, serif;
  font-weight: 400;
  font-size: clamp(24px, 3vw, 34px);
  line-height: 1.2;
  letter-spacing: -0.3px;
  margin: 72px 0 28px;
  color: #111;
}
.blog-content h2::before {
  content: '';
  display: block;
  width: 56px;
  height: 1px;
  background: #111;
  margin: 0 0 28px;
}
.blog-content h3 {
  font-family: Comfortaa, sans-serif;
  font-weight: 300;
  color: #888;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  margin: 40px 0 16px;
}
.blog-content a {
  color: #111;
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,0.25);
  transition: border-color 0.3s ease, color 0.3s ease;
}
.blog-content a:hover { border-bottom-color: #111; color: #000; }
.blog-content strong { font-weight: 500; color: #111; }
.blog-content em { font-style: italic; color: #555; }
.blog-content ul, .blog-content ol {
  font-size: 17px;
  line-height: 1.85;
  margin: 0 0 28px 24px;
  padding: 0;
  color: #3a3a3a;
}
.blog-content li { margin-bottom: 10px; }

/* ── PULL QUOTE ── */
.blog-pullquote {
  font-family: Oranienbaum, 'DM Serif Display', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  font-size: clamp(22px, 2.6vw, 30px);
  line-height: 1.45;
  text-align: center;
  margin: clamp(56px, 7vw, 88px) auto;
  padding: clamp(40px, 5vw, 56px) 0;
  color: #1a1a1a;
  max-width: 600px;
  border: none;
}
.blog-pullquote::before,
.blog-pullquote::after {
  content: '';
  display: block;
  width: 48px;
  height: 1px;
  background: #111;
  margin: 0 auto;
}
.blog-pullquote::before { margin-bottom: clamp(28px, 4vw, 40px); }
.blog-pullquote::after { margin-top: clamp(28px, 4vw, 40px); }

/* ── INLINE FIGURE ── */
.blog-figure {
  margin: clamp(40px, 6vw, 72px) 0;
}
.blog-figure img {
  display: block;
  width: 100%;
  height: auto;
}
.blog-figure figcaption {
  font-family: Comfortaa, sans-serif;
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #888;
  text-align: center;
  margin: 16px 0 0;
}

/* ── ARTICLE FOOTER ── */
.blog-article__footer {
  max-width: 720px;
  margin: clamp(72px, 9vw, 120px) auto 0;
  padding-top: clamp(48px, 6vw, 72px);
  border-top: 1px solid #ececec;
  text-align: center;
}
.blog-article__footer p {
  font-family: Rubik, sans-serif;
  font-size: 14px;
  color: #888;
  margin: 0 0 24px;
}
.blog-article__back {
  display: inline-block;
  font-family: Comfortaa, sans-serif;
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #111;
  text-decoration: none;
  border-bottom: 1px solid #111;
  padding-bottom: 4px;
}
.blog-article__cta {
  display: inline-block;
  margin-left: 24px;
  padding: 16px 36px;
  border: 1px solid #111;
  font-family: Comfortaa, sans-serif;
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #111;
  text-decoration: none;
  transition: background 0.3s, color 0.3s;
}
.blog-article__cta:hover { background: #111; color: #fff; }

/* ══════════════════════════════════════════════════════════
   BLOG INDEX — magazine cover layout
   ══════════════════════════════════════════════════════════ */
.blog-index {
  background: #fff;
  padding: clamp(200px, 22vh, 240px) clamp(24px, 6vw, 80px) clamp(96px, 12vw, 160px);
}
.blog-index__inner { max-width: 1280px; margin: 0 auto; }
.blog-index__kicker {
  font-family: Comfortaa, sans-serif;
  font-weight: 300;
  font-size: 11px;
  letter-spacing: 4px;
  text-transform: uppercase;
  text-align: center;
  color: #888;
  margin: 0 0 16px;
}
.blog-index__h1 {
  font-family: Oranienbaum, 'DM Serif Display', Georgia, serif;
  font-weight: 400;
  color: #111;
  font-size: clamp(36px, 5vw, 56px);
  letter-spacing: -0.5px;
  line-height: 1.1;
  text-align: center;
  margin: 0 0 clamp(64px, 8vw, 96px);
}
.blog-index__intro {
  font-family: Rubik, sans-serif;
  font-size: 15px;
  line-height: 1.85;
  color: #666;
  text-align: center;
  max-width: 58ch;
  margin: -40px auto clamp(72px, 9vw, 96px);
}
/* ── BLOG INDEX — list with thumbnails ── */
.blog-index__list {
  display: flex;
  flex-direction: column;
  gap: clamp(48px, 6vw, 72px);
  max-width: 980px;
  margin: 0 auto;
}
.blog-index__entry {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: clamp(32px, 4vw, 56px);
  align-items: center;
  text-decoration: none;
  color: inherit;
  padding-bottom: clamp(48px, 6vw, 72px);
  border-bottom: 1px solid #ececec;
  transition: opacity 0.3s ease;
}
.blog-index__entry:last-child { border-bottom: none; padding-bottom: 0; }
.blog-index__entry:hover { opacity: 0.72; }
.blog-index__thumb {
  width: 100%;
  aspect-ratio: 4/3;
  background-size: cover;
  background-position: center;
  background-color: #f4f4f4;
  transition: filter 0.3s ease;
}
.blog-index__entry:hover .blog-index__thumb { filter: brightness(0.96); }
.blog-index__body { display: flex; flex-direction: column; }
.blog-index__kicker-entry {
  font-family: Comfortaa, sans-serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #888;
  margin: 0 0 16px;
}
.blog-index__title {
  font-family: Oranienbaum, 'DM Serif Display', Georgia, serif;
  font-weight: 400;
  font-size: clamp(22px, 2.6vw, 30px);
  line-height: 1.2;
  letter-spacing: -0.3px;
  color: #111;
  margin: 0 0 18px;
}
.blog-index__excerpt {
  font-family: Rubik, sans-serif;
  font-size: 14.5px;
  line-height: 1.8;
  color: #555;
  margin: 0 0 22px;
  max-width: 56ch;
}
.blog-index__link {
  font-family: Comfortaa, sans-serif;
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #111;
  border-bottom: 1px solid #111;
  padding-bottom: 5px;
  align-self: flex-start;
}

/* ── MOBILE ── */
@media (max-width: 768px) {
  .blog-header { padding: 140px 20px 48px; }
  .blog-article { padding: 56px 20px 80px; }
  .blog-content p, .blog-content ul, .blog-content ol { font-size: 16px; }
  .blog-content > p:first-of-type::first-letter { font-size: 64px; }
  .blog-content h2 { margin-top: 56px; }
  .blog-index { padding: 140px 20px 80px; }
  .blog-index__entry { grid-template-columns: 1fr; gap: 20px; }
  .blog-index__thumb { aspect-ratio: 16/10; }
  .blog-article__cta { display: block; margin: 24px auto 0; width: fit-content; }
}
