/* Eternis Clinic — entry stylesheet */
@import url('./tokens.css');
@import url('./base.css');
@import url('./components.css');
@import url('./animations.css');

/* Self-hosted variable fonts (SIL OFL 1.1 — see assets/fonts/OFL-*.txt).
   Replaces the Google Fonts CDN @import to keep all font requests first-party
   (DPDP-aligned: no third-party calls on every page load). */
@font-face {
  font-family: 'Inter';
  src: url('../fonts/Inter-VariableFont.woff2') format('woff2-variations'),
       url('../fonts/Inter-VariableFont.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('../fonts/Inter-Italic-VariableFont.woff2') format('woff2-variations'),
       url('../fonts/Inter-Italic-VariableFont.woff2') format('woff2');
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('../fonts/Fraunces-VariableFont.woff2') format('woff2-variations'),
       url('../fonts/Fraunces-VariableFont.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('../fonts/Fraunces-Italic-VariableFont.woff2') format('woff2-variations'),
       url('../fonts/Fraunces-Italic-VariableFont.woff2') format('woff2');
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}

/* Page-specific tweaks live here */

/* Home — treatments carousel */
.tcarousel { position: relative; }
.tcarousel__track {
  display: flex;
  gap: var(--etc-space-5);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  scroll-behavior: smooth;
  cursor: grab;
}
.tcarousel__track:active { cursor: grabbing; }
.tcarousel__track::-webkit-scrollbar { display: none; }
.tcarousel__track > * {
  flex: 0 0 calc((100% - var(--etc-space-5) * 2) / 3);
  scroll-snap-align: start;
  min-width: 0;
}
.tcarousel__nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--etc-space-6);
}
.tcarousel__dots {
  display: flex;
  gap: 8px;
  align-items: center;
}
.tcarousel__dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--etc-rule);
  border: none; padding: 0;
  cursor: pointer;
  transition: background .25s, transform .25s, border-radius .25s, width .25s;
  flex-shrink: 0;
}
.tcarousel__dot.is-active {
  background: var(--etc-teal-deeper);
  width: 22px;
  border-radius: 4px;
}
.tcarousel__btn {
  display: flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1.5px solid var(--etc-rule);
  background: var(--etc-surface);
  cursor: pointer;
  transition: border-color .2s, background .2s, opacity .2s;
  color: var(--etc-ink);
}
.tcarousel__btn:hover:not(:disabled) { border-color: var(--etc-teal); background: #fff; }
.tcarousel__btn:disabled { opacity: 0.28; cursor: default; }
@media (max-width: 980px) {
  .tcarousel__track > * { flex-basis: calc((100% - var(--etc-space-5)) / 2); }
}
@media (max-width: 600px) {
  .tcarousel__track > * { flex-basis: 82%; }
}

.home-doctors {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--etc-space-7);
}
@media (max-width: 760px) { .home-doctors { grid-template-columns: 1fr; } }

/* Treatment-card grid — used on /treatments index sections,
   /treatments/{slug} related-care and auto-cluster blocks. */
.home-treatments {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--etc-space-5);
}
@media (max-width: 920px) { .home-treatments { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .home-treatments { grid-template-columns: 1fr; } }

.home-locations {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--etc-space-6);
}
@media (max-width: 760px) { .home-locations { grid-template-columns: 1fr; } }

.home-loc-img {
  border-radius: var(--etc-radius-lg);
  overflow: hidden;
  min-height: 320px;
  background: var(--etc-paper-soft);
}
.home-loc-img picture,
.home-loc-img img,
.home-loc-img .home-loc-map,
.home-loc-img iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  border: 0;
}

.location-card {
  background: var(--etc-paper);
  border: 1px solid var(--etc-line);
  border-radius: var(--etc-radius-lg);
  padding: var(--etc-space-7);
  display: flex; flex-direction: column;
  gap: var(--etc-space-5);
  transition: border-color var(--etc-dur) var(--etc-ease),
              transform var(--etc-dur) var(--etc-ease),
              box-shadow var(--etc-dur) var(--etc-ease);
}
.location-card:hover {
  transform: translateY(-2px);
  border-color: var(--etc-ink);
  box-shadow: var(--etc-shadow-3);
}
.location-card__head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: var(--etc-space-3);
}
.location-card__name {
  font-family: var(--etc-font-serif);
  font-size: 1.7rem;
  letter-spacing: -0.014em;
  color: var(--etc-ink);
}
.location-card__pin { font-size: 0.75rem; color: var(--etc-mute-2); letter-spacing: 0.04em; }
.location-card__addr { color: var(--etc-mute); line-height: 1.55; font-size: 0.9rem; }
.location-card__row { display: flex; gap: var(--etc-space-2); flex-wrap: wrap; }

.cta-band {
  position: relative;
  background: linear-gradient(135deg, var(--etc-deep) 0%, var(--etc-deep-soft) 100%);
  color: var(--etc-canvas);
  border-radius: var(--etc-radius-xl);
  padding: clamp(2.25rem, 6vw, 5rem);
  overflow: hidden;
}
@media (max-width: 540px) {
  .cta-band { border-radius: var(--etc-radius-lg); }
}
.cta-band::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(60% 80% at 80% 20%, rgba(202,169,122,0.40), transparent 60%),
    radial-gradient(50% 70% at 10% 100%, rgba(31,168,188,0.18), transparent 70%);
  pointer-events: none;
}
.cta-band__inner {
  position: relative;
  display: flex; flex-direction: column; gap: var(--etc-space-6);
  max-width: 60ch;
}
.cta-band__title {
  font-family: var(--etc-font-serif);
  font-size: clamp(2rem, 3.6vw, 3.4rem);
  line-height: 1.05;
  letter-spacing: -0.022em;
  color: #fff;
}
.cta-band__lead { color: rgba(255,255,255,0.75); font-size: var(--etc-lead); }

/* About page */
.about-doctors { display: grid; grid-template-columns: 1fr 1fr; gap: var(--etc-space-7); }
@media (max-width: 800px) { .about-doctors { grid-template-columns: 1fr; } }

/* Why Eternis 4-col grid */
.why-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--etc-space-5); }
@media (max-width: 1080px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .why-grid { grid-template-columns: 1fr; } }

/* Process two-col → one-col */
.process-grid { display: grid; grid-template-columns: 1fr 1.6fr; gap: var(--etc-space-9); align-items: start; }
@media (max-width: 920px) { .process-grid { grid-template-columns: 1fr; } }

/* Before-after preview */
.ba-preview { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--etc-space-4); }
@media (max-width: 1080px) { .ba-preview { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .ba-preview { grid-template-columns: 1fr; } }

/* Stats four-col → 2x2 on mobile (always two cols, never collapses to 1). */
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--etc-space-6); margin-top: var(--etc-space-7); }
@media (max-width: 760px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: var(--etc-space-4) var(--etc-space-3); }
  .stat__num  { font-size: clamp(1.75rem, 8vw, 2.4rem); }
  .stat__label { font-size: 0.68rem; }
}

/* Generic 3-col grid that collapses cleanly on mobile.
   Use class="grid-3" instead of inline grid-template-columns: repeat(3, 1fr). */
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--etc-space-5); }
@media (max-width: 920px) { .grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .grid-3 { grid-template-columns: 1fr; } }

/* Generic 2-col split for "label/content" rows */
.grid-2-split { display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--etc-space-9); align-items: start; }
@media (max-width: 800px) { .grid-2-split { grid-template-columns: 1fr; gap: var(--etc-space-6); } }

/* Defensive: any inline grid-template-columns containing "repeat(3" or "repeat(4"
   should still collapse on phones. Shadowed by more-specific classes above. */
@media (max-width: 540px) {
  [style*="grid-template-columns: repeat(3"],
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns: repeat(4"],
  [style*="grid-template-columns:repeat(4"] {
    grid-template-columns: 1fr !important;
  }
}
@media (min-width: 541px) and (max-width: 920px) {
  [style*="grid-template-columns: repeat(3"],
  [style*="grid-template-columns:repeat(3"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  [style*="grid-template-columns: repeat(4"],
  [style*="grid-template-columns:repeat(4"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* Process step */
.proc-step {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--etc-space-5);
  align-items: start;
}
.proc-step__num {
  font-family: var(--etc-font-serif);
  font-size: 2.2rem;
  color: var(--etc-teal-deeper);
  letter-spacing: -0.02em;
  line-height: 1;
}
.proc-step__title {
  font-family: var(--etc-font-serif);
  font-size: 1.3rem;
  letter-spacing: -0.012em;
  margin-bottom: 6px;
}
@media (max-width: 540px) {
  .proc-step { grid-template-columns: 56px 1fr; gap: var(--etc-space-4); padding: var(--etc-space-5); }
  .proc-step__num { font-size: 1.6rem; }
  .proc-step__title { font-size: 1.1rem; }
}

/* Trust strip */
.trust-strip {
  background: var(--etc-paper);
  border-block: 1px solid var(--etc-line);
  padding-block: var(--etc-space-7);
}
.trust-strip__inner {
  display: grid;
  grid-template-columns: 1fr repeat(4, auto);
  gap: var(--etc-space-7);
  align-items: center;
}
.trust-strip__label {
  font-size: 0.7rem;
  letter-spacing: var(--etc-tracking-wider);
  text-transform: uppercase;
  color: var(--etc-mute-2);
}
.trust-strip__item {
  display: flex;
  align-items: center;
  gap: var(--etc-space-2);
  font-size: 0.825rem;
  color: var(--etc-mute);
  font-weight: 500;
}
.trust-strip__item .icon { color: var(--etc-teal); flex-shrink: 0; }
@media (max-width: 920px) {
  .trust-strip__inner { grid-template-columns: repeat(2, 1fr); gap: var(--etc-space-5); }
  .trust-strip__label { grid-column: 1 / -1; }
}
@media (max-width: 480px) {
  .trust-strip__inner { grid-template-columns: 1fr; }
}

/* Treatments index grid */
.treat-cat-head {
  display: flex; align-items: end; justify-content: space-between;
  border-top: 1px solid var(--etc-line);
  padding-top: var(--etc-space-6);
  margin-bottom: var(--etc-space-7);
}
.treat-cat-head h2 {
  font-family: var(--etc-font-serif);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  letter-spacing: -0.022em;
}

/* Detail page */
.tdetail-hero {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--etc-space-9);
  align-items: center;
  padding-top: clamp(8rem, 14vw, 11rem);
  padding-bottom: clamp(2rem, 5vw, 4rem);
}
@media (max-width: 920px) { .tdetail-hero { grid-template-columns: 1fr; } }
.tdetail-hero__img {
  aspect-ratio: 3/2;
  border-radius: var(--etc-radius-lg);
  overflow: hidden;
  background: linear-gradient(135deg, var(--etc-gold-glow), var(--etc-paper-soft));
}
.tdetail-hero__img img { width: 100%; height: 100%; object-fit: cover; }
.tdetail-hero__title {
  font-family: var(--etc-font-serif);
  font-size: clamp(2.25rem, 4.6vw, 4rem);
  line-height: 1;
  letter-spacing: -0.025em;
  margin-top: var(--etc-space-3);
}
.tdetail-meta {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--etc-space-4);
  border-block: 1px solid var(--etc-line);
  padding-block: var(--etc-space-6);
  margin-block: var(--etc-space-9);
}
@media (max-width: 700px) { .tdetail-meta { grid-template-columns: 1fr; } }
.tdetail-meta__cell { display: flex; flex-direction: column; gap: 6px; }
.tdetail-meta__label { font-size: 0.7rem; letter-spacing: var(--etc-tracking-wider); text-transform: uppercase; color: var(--etc-mute-2); }
.tdetail-meta__val { font-family: var(--etc-font-serif); font-size: 1.2rem; color: var(--etc-ink); }
.tdetail-process {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: var(--etc-space-5);
  margin-top: var(--etc-space-7);
}
@media (max-width: 920px) { .tdetail-process { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .tdetail-process { grid-template-columns: 1fr; } }
.tdetail-step {
  background: var(--etc-paper);
  border: 1px solid var(--etc-line);
  border-radius: var(--etc-radius-md);
  padding: var(--etc-space-6);
}
.tdetail-step__num {
  font-family: var(--etc-font-serif);
  font-size: 0.9rem;
  color: var(--etc-gold-deep);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.tdetail-step__title {
  font-family: var(--etc-font-serif);
  font-size: 1.2rem;
  color: var(--etc-ink);
  margin: 8px 0 6px 0;
}
.tdetail-step__body { color: var(--etc-mute); font-size: 0.9rem; line-height: 1.55; }

.quick-answer {
  background: var(--etc-paper-soft);
  border: 1px solid var(--etc-line-soft);
  border-radius: var(--etc-radius-lg);
  padding: var(--etc-space-7);
  font-family: var(--etc-font-serif);
  font-size: 1.2rem;
  color: var(--etc-ink);
  line-height: 1.55;
  letter-spacing: -0.005em;
}
.quick-answer .label {
  display: inline-flex;
  font-family: var(--etc-font-sans);
  font-size: 0.7rem;
  letter-spacing: var(--etc-tracking-wider);
  text-transform: uppercase;
  color: var(--etc-gold-deep);
  margin-bottom: var(--etc-space-3);
}

/* Contact / book layout */
.form-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--etc-space-9);
  align-items: stretch;
}
@media (max-width: 920px) { .form-grid { grid-template-columns: 1fr; } }
.form-grid__panel {
  background: var(--etc-paper);
  border: 1px solid var(--etc-line);
  border-radius: var(--etc-radius-lg);
  padding: clamp(2rem, 4vw, 3rem);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--etc-space-4); }
@media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } }
.form-stack > * + * { margin-top: var(--etc-space-5); }
.form-success {
  background: var(--etc-paper-soft);
  border: 1px dashed var(--etc-gold);
  border-radius: var(--etc-radius-md);
  padding: var(--etc-space-6);
  text-align: center;
}
.form-success .ref-pill {
  display: inline-block;
  font-family: var(--etc-font-serif);
  font-size: 1.1rem;
  background: var(--etc-paper);
  border: 1px solid var(--etc-line);
  padding: 8px 16px;
  border-radius: 999px;
  margin-top: 8px;
}

/* ============================================================
   Clinic walk-through gallery
   ============================================================ */
.clinic-gallery { background: var(--etc-paper-soft); }
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--etc-space-4);
}
.gallery-tile {
  position: relative;
  border: 0; padding: 0; margin: 0;
  background: var(--etc-paper);
  border-radius: var(--etc-radius-md);
  overflow: hidden;
  cursor: pointer;
  aspect-ratio: 4 / 3;
  text-align: left;
  font: inherit;
  transition: transform 320ms var(--etc-ease), box-shadow 320ms var(--etc-ease);
  box-shadow: 0 1px 2px rgba(17,22,28,0.04);
}
.gallery-tile--wide { grid-column: span 2; aspect-ratio: 16 / 10; }
.gallery-tile:hover { transform: translateY(-2px); box-shadow: 0 14px 30px -16px rgba(17,22,28,0.25); }
.gallery-tile img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--etc-ease);
}
.gallery-tile:hover img { transform: scale(1.04); }
.gallery-tile__caption {
  position: absolute;
  inset: auto 0 0 0;
  padding: var(--etc-space-5) var(--etc-space-5) var(--etc-space-4);
  background: linear-gradient(180deg, transparent 0%, rgba(12,46,53,0.78) 100%);
  color: #fff;
  display: flex; flex-direction: column; gap: 2px;
}
.gallery-tile__title {
  font-family: var(--etc-font-serif);
  font-size: 1.15rem;
  letter-spacing: -0.01em;
}
.gallery-tile__sub {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.78);
}
@media (max-width: 980px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-tile--wide { grid-column: span 2; aspect-ratio: 16 / 9; }
}
@media (max-width: 540px) {
  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-tile--wide { aspect-ratio: 4 / 3; }
}

/* ===== Gallery viewer overlay ===== */
.gallery-viewer {
  position: fixed; inset: 0;
  z-index: var(--z-modal);
  background: rgba(12, 18, 22, 0.96);
  display: none;
  align-items: center; justify-content: center;
  padding: max(20px, env(safe-area-inset-top)) max(20px, env(safe-area-inset-right))
           max(20px, env(safe-area-inset-bottom)) max(20px, env(safe-area-inset-left));
}
.gallery-viewer.is-open { display: flex; }
.gallery-viewer__img {
  max-width: 100%;
  max-height: 100%;
  border-radius: var(--etc-radius-md);
  box-shadow: 0 24px 60px rgba(0,0,0,0.6);
  object-fit: contain;
  touch-action: pan-y;
}
.gallery-viewer__close,
.gallery-viewer__nav {
  position: absolute;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.20);
  color: #fff;
  width: 44px; height: 44px;
  border-radius: 50%;
  display: grid; place-items: center;
  cursor: pointer;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: background var(--etc-dur) var(--etc-ease);
}
.gallery-viewer__close { top: 20px; right: 20px; }
.gallery-viewer__nav { top: 50%; transform: translateY(-50%); }
.gallery-viewer__nav--prev { left: 20px; }
.gallery-viewer__nav--next { right: 20px; }
.gallery-viewer__close:hover, .gallery-viewer__nav:hover { background: rgba(255,255,255,0.18); }
.gallery-viewer__caption {
  position: absolute;
  left: 0; right: 0; bottom: 24px;
  text-align: center;
  color: rgba(255,255,255,0.88);
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  pointer-events: none;
}
@media (max-width: 540px) {
  .gallery-viewer__nav { width: 38px; height: 38px; }
}

/* Image-protection visual deterrent — disable selection / save UI on
   protected surfaces. JS handles the actual contextmenu + dragstart blocks.
   Default-protect every <img>; opt out via [data-no-protect] or by
   placing the image inside a .brand-logo wrapper. */
img:not([data-no-protect]) {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -webkit-user-drag: none;
  -webkit-touch-callout: none;
  pointer-events: auto;
}
.brand-logo img {
  -webkit-user-select: auto;
  -moz-user-select: auto;
  user-select: auto;
  -webkit-user-drag: auto;
  -webkit-touch-callout: default;
}

/* ============================================================
   Technology & Treatment Rooms page  (/technology)
   ============================================================ */

/* Sticky room nav */
.tech-rooms-nav {
  position: sticky;
  top: 68px;
  z-index: 40;
  background: var(--etc-canvas);
  border-bottom: 1px solid var(--etc-line);
  padding-block: 0;
}
.tech-rooms-nav__inner {
  display: flex;
  overflow-x: auto;
  scrollbar-width: none;
  gap: 0;
}
.tech-rooms-nav__inner::-webkit-scrollbar { display: none; }
.tech-rooms-nav__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 20px;
  white-space: nowrap;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--etc-mute);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color .18s, border-color .18s;
  flex-shrink: 0;
}
.tech-rooms-nav__item:hover { color: var(--etc-ink); }
.tech-rooms-nav__item.is-active {
  color: var(--etc-ink);
  border-bottom-color: var(--etc-gold);
}
.tech-rooms-nav__num {
  font-variant-numeric: tabular-nums;
  color: var(--etc-gold-deep);
  font-weight: 600;
}

/* Room sections */
.tech-room {
  padding-block: clamp(3.5rem, 7vw, 6rem);
  border-top: 1px solid var(--etc-line);
}
.tech-room:first-of-type { border-top: none; }
.tech-room__inner {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(2.5rem, 5vw, 5rem);
  align-items: center;
}
.tech-room--flip .tech-room__inner {
  grid-template-columns: 1fr 1.05fr;
}
.tech-room--flip .tech-room__img-wrap { order: 2; }
.tech-room--flip .tech-room__content  { order: 1; }

/* Room image */
.tech-room__img-wrap {
  position: relative;
  border-radius: var(--etc-radius-lg);
  overflow: hidden;
  aspect-ratio: 3/2;
  cursor: zoom-in;
  background: var(--etc-paper-soft);
}
.tech-room__img-wrap picture,
.tech-room__img-wrap img {
  display: block;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .9s var(--etc-ease);
}
.tech-room__img-wrap:hover img { transform: scale(1.05); }
.tech-room__img-badge {
  position: absolute;
  bottom: 14px; right: 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 6px 12px;
  border-radius: 999px;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .2s, transform .2s;
  pointer-events: none;
}
.tech-room__img-wrap:hover .tech-room__img-badge {
  opacity: 1;
  transform: translateY(0);
}

/* Room content */
.tech-room__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: var(--etc-space-3);
}
.tech-room__num {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--etc-gold-deep);
}
.tech-room__cat {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--etc-mute);
}
.tech-room__title {
  font-family: var(--etc-font-serif);
  font-size: clamp(1.9rem, 3vw, 2.8rem);
  line-height: 1.08;
  letter-spacing: -0.025em;
  margin-bottom: var(--etc-space-3);
}
.tech-room__equip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 0.78rem;
  color: var(--etc-mute);
  background: var(--etc-paper-soft);
  padding: 5px 12px;
  border-radius: 999px;
  margin-bottom: var(--etc-space-5);
}
.tech-room__lead {
  font-size: 1.02rem;
  line-height: 1.72;
  color: var(--etc-mute);
  max-width: 48ch;
  margin-bottom: var(--etc-space-6);
}
.tech-room__detail {
  font-size: 0.875rem;
  line-height: 1.8;
  color: var(--etc-mute-2);
  border-left: 2px solid var(--etc-gold);
  padding-left: var(--etc-space-4);
  margin-bottom: var(--etc-space-6);
}

/* Spec grid */
.tech-spec-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--etc-space-2);
  margin-bottom: var(--etc-space-5);
}
.tech-spec {
  background: var(--etc-paper-soft);
  border-radius: var(--etc-radius);
  padding: 14px 16px;
}
.tech-spec__label {
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--etc-mute);
  margin-bottom: 3px;
}
.tech-spec__val {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--etc-ink);
  line-height: 1.4;
}

.tech-room__treats {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.chip--sm {
  font-size: 0.7rem;
  padding: 5px 12px;
  gap: 4px;
}

/* Lightbox */
.tech-lightbox {
  border: none;
  background: rgba(0,0,0,0.92);
  padding: 0;
  max-width: 92vw;
  max-height: 92vh;
  border-radius: var(--etc-radius-lg);
  overflow: hidden;
  outline: none;
}
.tech-lightbox::backdrop { background: rgba(0,0,0,0.75); }
.tech-lightbox__img {
  display: block;
  max-width: 92vw;
  max-height: 88vh;
  object-fit: contain;
}
.tech-lightbox__close {
  position: absolute;
  top: 12px; right: 12px;
  background: rgba(255,255,255,0.12);
  border: none;
  border-radius: 50%;
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  cursor: pointer;
  transition: background .15s;
}
.tech-lightbox__close:hover { background: rgba(255,255,255,0.22); }

/* Responsive */
@media (max-width: 860px) {
  .tech-room__inner,
  .tech-room--flip .tech-room__inner { grid-template-columns: 1fr; }
  .tech-room--flip .tech-room__img-wrap { order: 0; }
  .tech-room--flip .tech-room__content  { order: 0; }
}
@media (max-width: 540px) {
  .tech-spec-grid { grid-template-columns: 1fr 1fr; }
  .tech-rooms-nav__item { padding: 12px 14px; font-size: 0.66rem; }
}

/* ── Reception intro ─────────────────────────────────── */
.clinic-reception {
  padding: clamp(3rem,7vw,5.5rem) 0 clamp(4rem,8vw,7rem);
  background: var(--etc-surface);
}
.clinic-reception__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.5rem,5vw,5rem);
  align-items: center;
}
.clinic-reception__photos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 12px;
}
.clinic-reception__photo-main {
  grid-column: 1 / -1;
  border-radius: 12px;
  overflow: hidden;
  aspect-ratio: 16/9;
}
.clinic-reception__photo-accent {
  grid-column: 1 / -1;
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 16/7;
}
.clinic-reception__photo-main img,
.clinic-reception__photo-accent img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .55s ease;
}
.clinic-reception__photo-accent img {
  object-position: center bottom;
}
.clinic-reception__photo-main:hover img,
.clinic-reception__photo-accent:hover img { transform: scale(1.03); }
.clinic-reception__content { padding-left: clamp(0px, 2vw, 24px); }
.clinic-reception__title {
  font-family: var(--etc-font-serif);
  font-size: clamp(1.6rem,3.2vw,2.4rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: var(--etc-space-4) 0 var(--etc-space-5);
  color: var(--etc-ink);
}
.clinic-reception__body {
  font-size: clamp(0.95rem,1.6vw,1.05rem);
  line-height: 1.75;
  color: var(--etc-mute);
  margin: 0 0 var(--etc-space-4);
}
.clinic-reception__detail {
  margin-top: var(--etc-space-6);
  display: flex;
  flex-direction: column;
  gap: 14px;
  border-top: 1px solid var(--etc-rule);
  padding-top: var(--etc-space-5);
}
.clinic-reception__detail-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.clinic-reception__detail-label {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--etc-mute);
  font-weight: 500;
}
.clinic-reception__detail-val {
  font-size: 0.92rem;
  color: var(--etc-ink);
  font-weight: 500;
}
@media (max-width: 860px) {
  .clinic-reception__inner { grid-template-columns: 1fr; gap: clamp(2rem,5vw,3rem); }
  .clinic-reception__content { padding-left: 0; }
  .clinic-reception__photos { grid-template-columns: 1fr 1fr; }
  .clinic-reception__photo-main { grid-column: 1 / -1; }
  .clinic-reception__photo-accent { grid-column: 1 / -1; }
}
@media (max-width: 540px) {
  .clinic-reception__photo-accent { aspect-ratio: 16/9; }
}

/* ====================================================
   Lead magnet — "Get personalised guidance" inline form
   Variants: lmag--home (2-col), lmag--treatment (1-col compact),
             lmag--contact (1-col compact). Forms are <data-async>
             so public/assets/js/forms.js handles submit + success.
   ==================================================== */
.lmag {
  padding: clamp(3.5rem, 7vw, 6rem) 0;
  background: linear-gradient(180deg, var(--etc-paper-soft) 0%, transparent 100%);
}
.lmag--treatment, .lmag--contact {
  padding: clamp(2.5rem, 5vw, 4rem) 0;
  background: var(--etc-paper-soft);
  border-top: 1px solid var(--etc-line);
}
.lmag__inner {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(2.5rem, 5vw, 4.5rem);
  align-items: start;
}
.lmag--treatment .lmag__inner,
.lmag--contact   .lmag__inner,
.lmag--compact   .lmag__inner { grid-template-columns: 1fr; max-width: 720px; margin: 0 auto; }
@media (max-width: 860px) { .lmag__inner { grid-template-columns: 1fr; } }

.lmag__copy { padding-top: var(--etc-space-3); }
.lmag__title {
  font-family: var(--etc-font-serif);
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--etc-ink);
  margin: var(--etc-space-3) 0 var(--etc-space-4);
}
.lmag__lead {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--etc-mute);
  margin: 0 0 var(--etc-space-5);
  max-width: 50ch;
}
.lmag__what {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}
.lmag__what li {
  position: relative;
  padding-left: 28px;
  color: var(--etc-mute);
  font-size: 0.92rem;
  line-height: 1.55;
}
.lmag__what li::before {
  content: "";
  position: absolute;
  left: 0; top: 6px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: rgba(202,169,122,0.20);
  border: 1px solid rgba(202,169,122,0.45);
}
.lmag__what li::after {
  content: "✓";
  position: absolute;
  left: 4px; top: 4px;
  font-size: 10px;
  color: var(--etc-gold-deep);
  font-weight: 700;
}

/* Form card */
.lmag__form {
  background: #fff;
  border: 1px solid var(--etc-line);
  border-radius: var(--etc-radius-lg);
  padding: clamp(1.5rem, 3vw, 2.25rem);
  display: grid;
  gap: var(--etc-space-4);
  box-shadow: 0 6px 24px -12px rgba(12, 46, 53, 0.10);
}

/* Concern chip-radio rail */
.lmag__chips { border: 0; padding: 0; margin: 0; }
.lmag__chips legend {
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--etc-gold-deep);
  margin-bottom: 10px;
  padding: 0;
}
.lmag__chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.chip-radio {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  position: relative;
}
.chip-radio input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.chip-radio span {
  display: inline-block;
  padding: 8px 14px;
  font-size: 0.85rem;
  line-height: 1.2;
  color: var(--etc-ink);
  background: var(--etc-paper-soft);
  border: 1px solid var(--etc-line);
  border-radius: 999px;
  transition: all 0.18s ease;
  user-select: none;
}
.chip-radio:hover span { border-color: var(--etc-gold-deep); color: var(--etc-deep); }
.chip-radio input:checked + span,
.chip-radio input:focus-visible + span {
  background: var(--etc-deep);
  color: #fff;
  border-color: var(--etc-deep);
}

/* Fields */
.lmag__field { display: grid; gap: 6px; }
.lmag__field label {
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--etc-mute);
  font-weight: 500;
}
.lmag__field input {
  width: 100%;
  padding: 12px 14px;
  font-size: 0.95rem;
  font-family: inherit;
  color: var(--etc-ink);
  background: #fff;
  border: 1px solid var(--etc-line);
  border-radius: var(--etc-radius-md);
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
.lmag__field input:focus {
  outline: 0;
  border-color: var(--etc-gold-deep);
  box-shadow: 0 0 0 3px rgba(202,169,122,0.15);
}
.lmag__field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--etc-space-3);
}
@media (max-width: 540px) { .lmag__field-row { grid-template-columns: 1fr; } }

.lmag__submit { width: 100%; justify-content: center; margin-top: 4px; }
.lmag__finep {
  margin: 0;
  font-size: 0.74rem;
  line-height: 1.5;
  color: var(--etc-mute-2);
  text-align: center;
}

/* Inline error helper inherits .field__error from base.css; ensure visible spacing here */
.lmag__form .field__error {
  display: block;
  font-size: 0.78rem;
  color: #b8324a;
  min-height: 1em;
}

/* Success state injected by forms.js — keep brand-consistent */
.lmag__form .form-success {
  text-align: center;
  padding: var(--etc-space-5) var(--etc-space-3);
}
.lmag__form .ref-pill {
  display: inline-block;
  padding: 6px 14px;
  background: rgba(202,169,122,0.18);
  color: var(--etc-gold-deep);
  border-radius: 999px;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  font-weight: 500;
}

/* ====================================================
   Blog detail — single-line breadcrumb
   (replaces the back-link + eyebrow combo that flowed inline)
   ==================================================== */
.post-breadcrumb {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: var(--etc-space-7);
  font-size: 0.78rem;
  flex-wrap: wrap;
}
.post-breadcrumb__back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--etc-mute);
  text-decoration: none;
  transition: color var(--etc-dur) var(--etc-ease);
}
.post-breadcrumb__back:hover { color: var(--etc-teal-deeper); }
.post-breadcrumb__sep {
  color: var(--etc-mute-2);
  font-size: 0.75rem;
  user-select: none;
}
.post-breadcrumb__cat {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--etc-gold-deep);
  font-weight: 500;
  font-size: 0.7rem;
}

/* ====================================================
   /treatments — Browse-by-condition chip rail filter

   Sits inline under the hero copy as a flowing flex row — no heavy white box,
   no 1fr-spacer "blank space" in the middle. The label reads as a small gold
   eyebrow, the chips read as quiet outline pills until selected, and the
   live-count text only renders when a filter is active.
   ==================================================== */
.cond-filter {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px var(--etc-space-3);
  margin-top: var(--etc-space-6);
  padding-top: var(--etc-space-4);
  border-top: 1px solid var(--etc-rule);
}
.cond-filter__label {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--etc-gold-deep);
  font-weight: 600;
  white-space: nowrap;
  margin-right: 4px;
}
.cond-filter__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.cond-filter__count {
  font-size: 0.78rem;
  color: var(--etc-mute-2);
  margin-left: auto;
}
.cond-filter__count:empty { display: none; }
.cond-chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  font-size: 0.85rem;
  line-height: 1.2;
  font-family: inherit;
  color: var(--etc-mute);
  background: transparent;
  border: 1px solid var(--etc-rule);
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.cond-chip:hover { border-color: var(--etc-gold-deep); color: var(--etc-deep); background: var(--etc-paper); }
.cond-chip.is-active {
  background: var(--etc-deep);
  color: #fff;
  border-color: var(--etc-deep);
}
/* First category section after the hero+chip rail — tighten the top padding
   so the page reads as one flowing block instead of two stacked sections with
   a 160px chasm between them. Bottom padding stays full-section so the rhythm
   between category sections remains breathable. */
.treat-cat-section:first-of-type { padding-top: var(--etc-space-7); }

/* ====================================================
   Treatment-detail — auto-cluster block
   ("Full {condition} care at Eternis" — pulls all treatments
   sharing the primary cluster tag of this treatment)
   ==================================================== */
.cluster-block {
  padding: clamp(2.5rem, 5vw, 4rem) 0;
  background: var(--etc-paper-soft);
  border-top: 1px solid var(--etc-line);
}
.cluster-block__head {
  margin-bottom: var(--etc-space-7);
}
.cluster-block__title {
  font-family: var(--etc-font-serif);
  font-size: clamp(1.5rem, 2.6vw, 2.05rem);
  line-height: 1.15;
  letter-spacing: -0.018em;
  color: var(--etc-ink);
  margin: var(--etc-space-3) 0 var(--etc-space-3);
}
.cluster-block__lead {
  color: var(--etc-mute);
  line-height: 1.65;
  max-width: 60ch;
  font-size: 0.95rem;
}

/* Clinic — Doctor credentials block (Training & affiliations) */
.doc-credentials {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--etc-space-6);
  margin-top: var(--etc-space-8);
}
@media (max-width: 800px) { .doc-credentials { grid-template-columns: 1fr; } }
.doc-credentials__card {
  border: 1px solid var(--etc-line);
  border-radius: var(--etc-radius-lg);
  padding: var(--etc-space-7);
  background: var(--etc-paper);
}
.doc-credentials__head {
  border-bottom: 1px solid var(--etc-line);
  padding-bottom: var(--etc-space-4);
  margin-bottom: var(--etc-space-5);
}
.doc-credentials__name {
  font-family: var(--etc-font-serif);
  font-size: 1.3rem;
  letter-spacing: -0.01em;
  color: var(--etc-ink);
}
.doc-credentials__since {
  margin-top: 4px;
  font-size: 0.78rem;
  color: var(--etc-mute-2);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.doc-credentials__group + .doc-credentials__group { margin-top: var(--etc-space-5); }
.doc-credentials__label {
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--etc-gold-deep);
  margin-bottom: var(--etc-space-3);
}
.doc-credentials__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--etc-mute);
}
/* Hanging indent: bullet sits in an absolute layer so wrapped lines stay
   aligned under the first character of text, not under the bullet glyph.
   (The previous `list-style: disc inside` broke wrap alignment — see screenshot
   2026-05-12 of doctor-credentials with (IADVL) and "patterns" falling back
   to the bullet column.) */
.doc-credentials__list li {
  position: relative;
  padding-left: 18px;
}
.doc-credentials__list li::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 0.62em;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--etc-gold-deep);
}

/* Reusable hanging-indent bullet list — drop-in replacement for any
   `list-style: disc inside` (which breaks wrap alignment by flowing the
   second line back to the bullet column). */
.bullet-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
.bullet-list li { position: relative; padding-left: 16px; }
.bullet-list li::before {
  content: "";
  position: absolute;
  left: 3px;
  top: 0.6em;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.55;
}

/* Treatment-detail — Clinical references block */
.refs {
  border-top: 1px solid var(--etc-line);
  padding-top: var(--etc-space-7);
}
.refs__lead {
  margin-top: var(--etc-space-3);
  margin-bottom: var(--etc-space-5);
  max-width: 60ch;
  color: var(--etc-mute);
  font-size: 0.92rem;
  line-height: 1.65;
}
.refs__list {
  list-style: none;
  counter-reset: ref;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--etc-space-3);
}
.refs__item {
  counter-increment: ref;
  position: relative;
  padding-left: 28px;
  font-size: 0.88rem;
  line-height: 1.55;
  color: var(--etc-mute);
}
/* Hanging-indent number: wrapped lines stay aligned under the title text,
   not under the "1." digit. */
.refs__item::before {
  content: counter(ref) ".";
  position: absolute;
  left: 0;
  top: 0;
  width: 22px;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
  color: var(--etc-gold-deep);
  font-weight: 500;
}
.refs__title {
  color: var(--etc-ink);
  font-weight: 500;
}
.refs__source {
  display: block;
  margin-top: 2px;
  font-style: italic;
  font-size: 0.82rem;
  color: var(--etc-mute-2);
}

/* ============================================================
   Before/After lightbox viewer (/before-after)
   Click any case card → fullscreen side-by-side at full resolution.
   Same idiom as .gallery-viewer; mobile stacks the panels vertically.
   ============================================================ */
.ba-card { transition: transform var(--etc-dur) var(--etc-ease), box-shadow var(--etc-dur) var(--etc-ease); }
.ba-card:hover { transform: translateY(-3px); box-shadow: 0 24px 50px -28px rgba(12,46,53,0.32); }
.ba-card:focus-visible { outline: 2px solid var(--etc-gold-deep); outline-offset: 4px; }
/* Wide-flat sources (eyebrow strips) — anchor the thumbnail crop to the left so
   one actual eyebrow is visible, instead of the centre "between-the-brows" slice. */
.ba-card--thumb-left img { object-position: 22% center !important; }

/* Caption typography — small gold eyebrow, serif headline, gold "View case →" CTA.
   Gives the case card the same hierarchy as the rest of the site (eyebrow → serif → arrow)
   instead of a flat block of muted text. */
.ba-card__caption {
  padding: var(--etc-space-5) var(--etc-space-6) var(--etc-space-6);
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
}
.ba-card__eyebrow {
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--etc-gold-deep);
  font-weight: 600;
}
.ba-card__line {
  font-family: var(--etc-font-serif);
  font-size: 1.08rem;
  line-height: 1.35;
  color: var(--etc-ink);
  letter-spacing: -0.005em;
  margin: 0;
}
.ba-card__view {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--etc-mute-2);
  font-weight: 500;
  margin-top: 2px;
  transition: color var(--etc-dur) var(--etc-ease), gap var(--etc-dur) var(--etc-ease);
}
.ba-card:hover .ba-card__view { color: var(--etc-gold-deep); gap: 10px; }

/* Journal subscribe tile (/blog 6th tile inside the article grid). */
.journal-sub {
  position: relative;
  display: flex; flex-direction: column;
  background: var(--etc-deep);
  color: var(--etc-canvas);
  border-radius: var(--etc-radius-lg);
  padding: var(--etc-space-7);
  overflow: hidden;
  margin: 0;
  isolation: isolate;
}
.journal-sub::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(110% 80% at 0% 0%, rgba(212,165,116,0.18), transparent 60%);
  pointer-events: none; z-index: 0;
}
.journal-sub > * { position: relative; z-index: 1; }
.journal-sub__eyebrow {
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--etc-gold);
  margin: 0 0 var(--etc-space-3);
}
.journal-sub__title {
  font-family: var(--etc-font-serif);
  font-size: clamp(1.45rem, 2vw, 1.7rem);
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin: 0 0 var(--etc-space-3);
  color: var(--etc-canvas);
}
.journal-sub__lead {
  font-size: 0.92rem;
  line-height: 1.55;
  color: rgba(255,255,255,0.75);
  margin: 0 0 var(--etc-space-5);
}
.journal-sub__form { display: flex; flex-direction: column; gap: var(--etc-space-3); }
.journal-sub .field { display: block; margin: 0; }
.journal-sub .field__label {
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin-bottom: 6px;
}
.journal-sub .field__hint {
  text-transform: none;
  letter-spacing: 0;
  color: rgba(255,255,255,0.5);
  font-size: 0.7rem;
}
.journal-sub .field__input {
  width: 100%;
  padding: 11px 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--etc-radius-md);
  color: var(--etc-canvas);
  font: inherit;
  font-size: 0.95rem;
  transition: border-color var(--etc-dur) var(--etc-ease), background var(--etc-dur) var(--etc-ease);
}
.journal-sub .field__input::placeholder { color: rgba(255,255,255,0.4); }
.journal-sub .field__input:focus { outline: none; border-color: var(--etc-gold); background: rgba(255,255,255,0.10); }
.journal-sub .field__error { display: block; font-size: 0.78rem; color: #ffb6b6; margin-top: 4px; min-height: 1em; }
.journal-sub__submit { margin-top: var(--etc-space-3); justify-content: center; }
.journal-sub__privacy {
  font-size: 0.74rem;
  color: rgba(255,255,255,0.55);
  margin: var(--etc-space-3) 0 0;
  line-height: 1.5;
}
.journal-sub__privacy a { color: var(--etc-gold); text-decoration: underline; }
/* The base .form-success has a cream background (for light-bg forms). On the dark
   teal journal card that left WHITE success text on a cream box = invisible. Override
   to a translucent glass panel that matches the card's inputs, so the text reads. */
.journal-sub .form-success {
  background: rgba(255,255,255,0.07);
  border-color: rgba(255,255,255,0.22);
  color: #fff;
}
.journal-sub .form-success p {
  color: rgba(255,255,255,0.82) !important;
}

.ba-viewer {
  position: fixed; inset: 0;
  z-index: var(--z-modal);
  background: rgba(12, 18, 22, 0.96);
  display: none;
  align-items: center; justify-content: center;
  padding: max(20px, env(safe-area-inset-top)) max(20px, env(safe-area-inset-right))
           max(20px, env(safe-area-inset-bottom)) max(20px, env(safe-area-inset-left));
}
.ba-viewer.is-open { display: flex; }
.ba-viewer__inner {
  display: flex;
  flex-direction: column;
  gap: var(--etc-space-5);
  max-width: 1400px;
  width: 100%;
}
.ba-viewer__panels {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--etc-space-4);
}
.ba-viewer__panel {
  position: relative;
  background: var(--etc-paper);
  border-radius: var(--etc-radius-lg);
  overflow: hidden;
  margin: 0;
  box-shadow: 0 24px 60px rgba(0,0,0,0.45);
}
.ba-viewer__img {
  width: 100%;
  max-height: 75vh;
  object-fit: contain;
  display: block;
  background: var(--etc-paper);
  touch-action: pan-y;
}
.ba-viewer__badge {
  position: absolute; top: 14px; left: 14px;
  background: rgba(255,255,255,0.95);
  color: var(--etc-ink);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
  z-index: 1;
}
.ba-viewer__badge--after { background: var(--etc-teal); color: #fff; }
.ba-viewer__meta {
  text-align: center;
  color: rgba(255,255,255,0.92);
}
.ba-viewer__treatment {
  display: inline-block;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--etc-gold);
  margin-bottom: 6px;
}
.ba-viewer__caption {
  font-size: 1rem;
  line-height: 1.5;
  margin: 0;
  color: rgba(255,255,255,0.88);
}
.ba-viewer__close,
.ba-viewer__nav {
  position: absolute;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.20);
  color: #fff;
  width: 44px; height: 44px;
  border-radius: 50%;
  display: grid; place-items: center;
  cursor: pointer;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: background var(--etc-dur) var(--etc-ease);
  z-index: 2;
}
.ba-viewer__close { top: 20px; right: 20px; }
.ba-viewer__nav { top: 50%; transform: translateY(-50%); }
.ba-viewer__nav--prev { left: 20px; }
.ba-viewer__nav--next { right: 20px; }
.ba-viewer__close:hover, .ba-viewer__nav:hover { background: rgba(255,255,255,0.18); }

@media (max-width: 760px) {
  .ba-viewer__panels { grid-template-columns: 1fr; gap: var(--etc-space-3); }
  .ba-viewer__img { max-height: 38vh; }
  .ba-viewer__nav { width: 38px; height: 38px; }
  .ba-viewer__nav--prev { left: 8px; }
  .ba-viewer__nav--next { right: 8px; }
}
