.trx-galeria { padding-block: clamp(var(--space-8), 10vw, var(--space-10)); background: var(--bg-base-soft); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }

/* ── Head ─────────────────────────────────────────────────────────── */
.trx-galeria__head { margin-bottom: var(--space-7); padding-bottom: var(--space-5); border-bottom: 1px solid var(--line); }
.trx-galeria__head-grid { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr); gap: var(--space-6); align-items: end; margin-top: var(--space-4); }
@media (max-width: 880px) { .trx-galeria__head-grid { grid-template-columns: 1fr; gap: var(--space-3); } }
.trx-galeria__title { font-family: var(--font-display); font-size: clamp(1.8rem, 3.6vw, 2.8rem); line-height: 1.1; letter-spacing: -0.02em; margin: 0; color: var(--ink-primary); max-width: 22ch; }
.trx-galeria__note { display: flex; align-items: flex-start; gap: 10px; color: var(--ink-muted); font-size: var(--fs-200); line-height: 1.55; margin: 0; max-width: 48ch; justify-self: end; }
@media (max-width: 880px) { .trx-galeria__note { justify-self: start; } }
.trx-galeria__note > span:first-child { color: var(--accent); font-family: var(--font-display); font-style: italic; font-size: var(--fs-400); line-height: 1; }

/* ── Grid ─────────────────────────────────────────────────────────── */
.trx-galeria__grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); grid-auto-rows: minmax(180px, auto); gap: var(--space-4); }
.trx-galeria__shot--wide   { grid-column: span 4; }
.trx-galeria__shot--tall   { grid-column: span 2; grid-row: span 2; }
.trx-galeria__shot--square { grid-column: span 3; }
@media (max-width: 1024px) { .trx-galeria__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } .trx-galeria__shot--wide { grid-column: span 4; } .trx-galeria__shot--tall { grid-column: span 2; grid-row: span 2; } .trx-galeria__shot--square { grid-column: span 2; } }
@media (max-width: 640px) { .trx-galeria__grid { grid-template-columns: 1fr; grid-auto-rows: auto; } .trx-galeria__shot { grid-column: 1 / -1 !important; grid-row: auto !important; } }

/* ── Shot ─────────────────────────────────────────────────────────── */
.trx-galeria__shot { margin: 0; display: flex; flex-direction: column; gap: var(--space-3); opacity: 0; transform: translateY(16px); transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out); transition-delay: calc(var(--i, 0) * 70ms); }
.trx-galeria__shot.is-revealed { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .trx-galeria__shot { opacity: 1; transform: none; transition: none; } }

.trx-galeria__shot-media { position: relative; padding: 0; margin: 0; border: 0; background: transparent; cursor: pointer; overflow: hidden; border-radius: var(--radius-md); aspect-ratio: 3/2; width: 100%; display: block; }
.trx-galeria__shot--tall .trx-galeria__shot-media { aspect-ratio: auto; height: 100%; min-height: 100%; }
.trx-galeria__shot--square .trx-galeria__shot-media { aspect-ratio: 1/1; }
.trx-galeria__shot-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 800ms var(--ease-out), filter var(--dur-base) var(--ease-out); }
.trx-galeria__shot-media:hover img { transform: scale(1.04); }
.trx-galeria__shot-veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,42,74,0.0) 55%, rgba(11,42,74,0.6) 100%); pointer-events: none; }
.trx-galeria__shot-zoom { position: absolute; top: var(--space-3); right: var(--space-3); width: 36px; height: 36px; border-radius: 999px; background: rgba(245,241,234,0.92); color: var(--ink-primary); display: inline-flex; align-items: center; justify-content: center; opacity: 0; transform: translateY(-4px); transition: opacity var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out), background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); backdrop-filter: blur(6px); }
.trx-galeria__shot-media:hover .trx-galeria__shot-zoom, .trx-galeria__shot-media:focus-visible .trx-galeria__shot-zoom { opacity: 1; transform: none; }
.trx-galeria__shot-media:hover .trx-galeria__shot-zoom { background: var(--accent); color: #fff; }
.trx-galeria__shot-stamp { position: absolute; bottom: var(--space-3); left: var(--space-3); display: inline-flex; align-items: center; gap: 8px; padding: 4px 10px; background: rgba(10,26,47,0.78); color: var(--bg-base); border-radius: var(--radius-pill); backdrop-filter: blur(6px); font-family: var(--font-mono); font-size: var(--fs-100); letter-spacing: 0.14em; line-height: 1; }
.trx-galeria__shot-num { color: var(--accent); }
.trx-galeria__shot-time { color: var(--bg-base); padding-left: 8px; border-left: 1px solid rgba(245,241,234,0.3); }

/* Caption */
.trx-galeria__shot-caption { display: flex; flex-direction: column; gap: 6px; font-size: var(--fs-200); line-height: 1.55; color: var(--ink-primary); padding: 0 2px; }
.trx-galeria__shot-meta { display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-4); font-family: var(--font-mono); font-size: var(--fs-100); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-muted); }
.trx-galeria__shot-place { color: var(--brand-primary); }
.trx-galeria__shot-person { display: inline-flex; align-items: center; gap: 6px; color: var(--accent); }
.trx-galeria__shot-person svg { color: var(--accent); }
.trx-galeria__shot-text { color: var(--ink-muted); }

/* ── Foot ─────────────────────────────────────────────────────────── */
.trx-galeria__foot { margin-top: var(--space-7); padding-top: var(--space-5); border-top: 1px dashed var(--line-strong); display: flex; align-items: flex-start; gap: var(--space-3); }
.trx-galeria__foot-icon { color: var(--accent); font-size: var(--fs-500); line-height: 1; flex-shrink: 0; }
.trx-galeria__foot-text { margin: 0; color: var(--ink-muted); font-size: var(--fs-200); line-height: 1.6; max-width: 72ch; }

/* ── Lightbox ─────────────────────────────────────────────────────── */
.trx-galeria__lightbox { position: fixed; inset: 0; z-index: 200; display: none; align-items: center; justify-content: center; padding: var(--space-5); }
.trx-galeria__lightbox.is-open { display: flex; }
.trx-galeria__lightbox-veil { position: absolute; inset: 0; background: rgba(10,26,47,0.86); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); border: 0; cursor: zoom-out; padding: 0; }
.trx-galeria__lightbox-frame { position: relative; max-width: 1100px; width: 100%; display: flex; flex-direction: column; gap: var(--space-3); animation: trx-lb-in 320ms var(--ease-out); }
@keyframes trx-lb-in { from { opacity: 0; transform: scale(0.98); } to { opacity: 1; transform: none; } }
.trx-galeria__lightbox-head { display: flex; align-items: center; justify-content: space-between; color: var(--bg-base); }
.trx-galeria__lightbox-counter { font-family: var(--font-mono); font-size: var(--fs-200); letter-spacing: 0.18em; color: var(--secondary-soft); }
.trx-galeria__lightbox-close { background: rgba(245,241,234,0.12); border: 1px solid rgba(245,241,234,0.24); color: var(--bg-base); padding: 8px; border-radius: 999px; cursor: pointer; transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.trx-galeria__lightbox-close:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
.trx-galeria__lightbox-figure { margin: 0; background: #000; border-radius: var(--radius-md); overflow: hidden; }
.trx-galeria__lightbox-figure img { width: 100%; height: auto; max-height: 70vh; object-fit: contain; display: block; }
.trx-galeria__lightbox-figure figcaption { padding: var(--space-4) var(--space-5); background: rgba(11,42,74,0.92); color: var(--bg-base); font-size: var(--fs-200); line-height: 1.55; min-height: 56px; display: flex; flex-direction: column; gap: 4px; }
.trx-galeria__lightbox-figure figcaption strong { color: var(--accent); font-weight: 500; font-family: var(--font-mono); font-size: var(--fs-100); letter-spacing: 0.12em; text-transform: uppercase; }
.trx-galeria__lightbox-nav { display: flex; justify-content: space-between; }
.trx-galeria__lightbox-nav button { background: rgba(245,241,234,0.12); border: 1px solid rgba(245,241,234,0.24); color: var(--bg-base); padding: 10px 14px; border-radius: var(--radius-pill); cursor: pointer; transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out); }
.trx-galeria__lightbox-nav button:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
body.trx-galeria-open { overflow: hidden; }
