/* ============================================
   CLUB NÁUTICO VICHUQUÉN · Sistema de estilos
   Variación A: Navy + Dorado + Crudo
   ============================================ */

:root {
  /* Colores — paleta A */
  --navy-900: #061328;
  --navy-800: #0A1F3D;
  --navy-700: #112a52;
  --navy-600: #1a3a6b;
  --navy-500: #2d5489;
  --navy-300: #8aa3c4;
  --navy-100: #d8e1ee;

  --gold-600: #a88843;
  --gold-500: #C9A961;
  --gold-400: #d6be83;
  --gold-100: #f1e7cc;

  --cream-100: #F5F2EA;
  --cream-200: #ebe6d7;
  --cream-300: #ddd5bf;

  --ink: #0e1a2e;
  --ink-soft: #40516b;
  --ink-muted: #7b8a9f;
  --line: rgba(10, 31, 61, 0.12);
  --line-strong: rgba(10, 31, 61, 0.24);

  --ok: #2f7d5b;
  --warn: #b5791c;
  --bad: #a33a3a;

  /* Tipografía */
  --serif: "Fraunces", "Playfair Display", Georgia, serif;
  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: "JetBrains Mono", ui-monospace, Menlo, monospace;

  /* Layout */
  --container: 1280px;
  --radius-sm: 4px;
  --radius: 8px;
  --radius-lg: 14px;
  --shadow-sm: 0 1px 2px rgba(6, 19, 40, 0.06), 0 2px 6px rgba(6, 19, 40, 0.04);
  --shadow: 0 2px 6px rgba(6, 19, 40, 0.08), 0 12px 28px rgba(6, 19, 40, 0.08);
  --shadow-lg: 0 6px 16px rgba(6, 19, 40, 0.10), 0 24px 48px rgba(6, 19, 40, 0.14);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--cream-100);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }

a { color: inherit; text-decoration: none; }

h1, h2, h3, h4 {
  font-family: var(--serif);
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--navy-800);
  margin: 0;
  text-wrap: balance;
}

h1 { font-size: clamp(2.4rem, 5vw, 4.5rem); line-height: 1.02; }
h2 { font-size: clamp(1.8rem, 3.2vw, 2.8rem); line-height: 1.1; }
h3 { font-size: clamp(1.2rem, 1.8vw, 1.5rem); line-height: 1.2; }

p { margin: 0 0 1em; text-wrap: pretty; }

.bottom-0 { bottom: 0 }
.left-0 { left: 0 }
.right-0 { right: 0 }
.top-0 { top: 0 }
.margin-auto { margin: auto }
.margin-x-auto { margin-left: auto; margin-right: auto }
.margin-y-auto { margin-bottom: auto; margin-top: auto }
.margin-start-auto { margin-left: auto }
.margin-end-auto { margin-right: auto }
.margin-bottom-auto { margin-bottom: auto }
.margin-top-auto { margin-top: auto }

@media (max-width: 880px) {
}
@media (max-width: 576px) {
}
.historia-vid { min-height: 576px; border-radius: var(--radius-lg); }
#bg-video-playa {
	margin-top: -25%
}

.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 24px;
}

.eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold-600);
  font-weight: 500;
}

/* ============ NAV ============ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  backdrop-filter: blur(18px);
  background: rgba(245, 242, 234, 0.82);
  border-bottom: 1px solid var(--line);
  transition: background .3s;
}
.nav.on-dark {
  background: rgba(6, 19, 40, 0.35);
  border-bottom: 1px solid rgba(255,255,255,.1);
  color: var(--cream-100);
}
.nav.on-dark .nav-link { color: rgba(245, 242, 234, 0.85); }
.nav.on-dark .logo-text { color: var(--cream-100); }
.nav.on-dark .logo-mark { color: var(--gold-400); }

.nav-inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 14px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  width: 100%;
}
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--serif);
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.02em;
}
.logo-mark {
  width: 34px; height: 34px;
  color: var(--gold-600);
}
.logo-text { color: var(--navy-800); line-height: 1; }
.logo-text small {
  display: block;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  color: var(--ink-muted);
  font-weight: 400;
  margin-top: 3px;
}
.nav-links {
  display: flex; align-items: center; gap: 28px;
}
.nav-link {
  font-size: 13.5px;
  color: var(--ink-soft);
  font-weight: 500;
  position: relative;
  padding: 4px 0;
  transition: color .2s;
}
.nav-link:hover { color: var(--navy-800); }
.nav-link.active::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 2px;
  background: var(--gold-500);
}
.nav-cta {
  background: var(--navy-800);
  color: var(--cream-100);
  padding: 10px 18px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: background .2s;
}
.nav-cta:hover { background: var(--navy-700); }
.nav.on-dark .nav-cta {
  background: var(--gold-500);
  color: var(--navy-900);
}
.nav.on-dark .nav-cta:hover { background: var(--gold-400); }

/* ===== BURGUER ICON MENU ===== */
.burger { display: none; }
@media (max-width: 880px) {
  .nav-links { display: none; }
  .burger {
    display: flex; flex-direction: column; gap: 4px;
    background: none; border: 0; cursor: pointer; padding: 8px;
  }
  .burger span { width: 22px; height: 2px; background: currentColor; }
  .home .nav-links.show {
    background: var(--navy-600);
  }
  .page-template .nav-links.show, .archive .nav-links.show {
    background: var(--cream-300);
  }
  .nav-links.show {
    display: flex;
    position: absolute;
    right: 0;
    top: 65px;
    border-bottom: 1px solid rgba(255, 255, 255, .1);
    color: var(--cream-100);
    padding-left: 2rem;
    padding-right: 2rem;
    padding-top: .5rem;
    padding-bottom: .5rem;
    width: 100%;
  }
  .nav-links.show .nav-link, .nav-links.show .nav-cta {
    margin-left: auto;
  }
}

@media (max-width: 576px) {
  html.no-scroll, body.no-scroll {
    margin: 0;
    height: 100%;
    overflow: hidden;
  }
  html.no-scroll .nav-links, body.no-scroll .nav-links {
    /*height: 100vh;      /* Required: The div must have a defined height */
    overflow-y: auto; 
  }

  .nav-links { display: none; }
  .burger {
    display: flex; flex-direction: column; gap: 4px;
    background: none; border: 0; cursor: pointer; padding: 8px;
  }
  .burger span { width: 22px; height: 2px; background: currentColor; }
  .home .nav-links.show {
    background: var(--navy-600);
  }
  .page-template .nav-links.show, .archive .nav-links.show {
    background: var(--cream-300);
  }
  .nav-links.show {
    display: flex;
    position: absolute;
    right: 0;
    top: 65px;
    border-bottom: 1px solid rgba(255, 255, 255, .1);
    color: var(--cream-100);
    padding-left: 2rem;
    padding-right: 2rem;
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
    flex-wrap: wrap;
  }
  .nav-links.show .nav-link, .nav-links.show .nav-cta {
    flex: 1 1 100%;
  }
  .nav-links.show .nav-cta {
    margin-left: -1rem;
    margin-right: -1rem;
  }
  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 32px;
  }
}


/* ============ BUTTONS ============ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 26px;
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.02em;
  cursor: pointer;
  border: 0;
  transition: all .2s;
  font-family: inherit;
}
.btn-primary {
  background: var(--gold-500);
  color: var(--navy-900);
}
.btn-primary:hover { background: var(--gold-400); transform: translateY(-1px); }
.btn-ghost {
  background: transparent;
  color: var(--cream-100);
  border: 1px solid rgba(255,255,255,.4);
}
.btn-ghost:hover { border-color: var(--cream-100); background: rgba(255,255,255,.08); }
.btn-dark {
  background: var(--navy-800);
  color: var(--cream-100);
}
.btn-dark:hover { background: var(--navy-700); }
.btn-outline {
  background: transparent;
  color: var(--navy-800);
  border: 1px solid var(--line-strong);
}
.btn-outline:hover { border-color: var(--navy-800); }
.btn-wa {
  background: #25D366;
  color: white;
}
.btn-wa:hover { background: #1dbe57; }

/* ============ IMAGE ATTR (real imagery) ============ */
.img {
  position: relative;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  background-color: var(--navy-700);
}
.img::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(6,19,40,0) 40%, rgba(6,19,40,.35) 100%);
  pointer-events: none;
}
.img-flat::after { display: none; }

/* ============ PLACEHOLDER IMAGES ============ */
.ph {
  position: relative;
  overflow: hidden;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(10, 31, 61, 0.04) 0 12px,
      rgba(10, 31, 61, 0.08) 12px 13px
    ),
    var(--cream-200);
  color: var(--ink-soft);
  display: flex;
  align-items: center;
  justify-content: center;
}
.ph-dark {
  background:
    repeating-linear-gradient(
      135deg,
      rgba(255,255,255,0.04) 0 12px,
      rgba(255,255,255,0.08) 12px 13px
    ),
    var(--navy-800);
  color: rgba(255,255,255,.8);
}
.ph-label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 6px 10px;
  background: rgba(245, 242, 234, 0.85);
  border: 1px solid var(--line);
  border-radius: 2px;
}
.ph-dark .ph-label {
  background: rgba(6, 19, 40, 0.7);
  color: rgba(255,255,255,.85);
  border: 1px solid rgba(255,255,255,.18);
}
.ph::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px dashed rgba(10, 31, 61, 0.18);
  pointer-events: none;
}
.ph-dark::before { border-color: rgba(255,255,255,.18); }

/* ============ CARDS / MISC ============ */
.card {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.tag {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 2px;
  background: var(--navy-100);
  color: var(--navy-700);
}
.tag-gold {
  background: var(--gold-100);
  color: var(--gold-600);
}

/* ============ FOOTER ============ */
.footer {
  background: var(--navy-900);
  color: var(--navy-100);
  padding: 80px 0 32px;
  margin-top: 120px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.footer h4 {
  color: var(--cream-100);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: 18px;
}
.footer a { display: block; font-size: 14px; padding: 6px 0; opacity: .75; transition: opacity .2s; }
.footer a:hover { opacity: 1; color: var(--gold-400); }
.footer-bottom {
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: rgba(216, 225, 238, 0.5);
}
@media (max-width: 720px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer-bottom { flex-direction: column; gap: 12px; }
}

/* ============ UTIL ============ */
.section { padding: 96px 0; }
.section-sm { padding: 56px 0; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
@media (max-width: 880px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; gap: 32px; }
  .section { padding: 64px 0; }
}

.divider-ornament {
  display: flex; align-items: center; gap: 16px; color: var(--gold-500);
  font-size: 14px; letter-spacing: 0.3em;
}
.divider-ornament::before, .divider-ornament::after {
  content: ""; flex: 1; height: 1px; background: var(--gold-500); opacity: .4;
}


/* ============ MERGED INLINE STYLES FROM PROTOTYPE PAGES ============ */

/* ---- index.html ---- */

/* ===== HERO ===== */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: flex-end;
  color: var(--cream-100);
  overflow: hidden;
}
.hero-media {
  position: absolute; inset: 0; z-index: 0;
}
.hero-media::before { display: none; }
.hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(180deg, rgba(6,19,40,.55) 0%, rgba(6,19,40,.2) 30%, rgba(6,19,40,.85) 100%);
}
.hero-content {
  position: relative; z-index: 2;
  padding-bottom: 120px;
  padding-top: 160px;
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-400);
  margin-bottom: 32px;
}
.hero-eyebrow .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--gold-500);
  box-shadow: 0 0 0 4px rgba(201, 169, 97, 0.25);
}
.hero-title {
  color: var(--cream-100);
  font-size: clamp(3rem, 7.2vw, 6.5rem);
  line-height: 0.98;
  font-weight: 500;
  letter-spacing: -0.035em;
  max-width: 14ch;
}
.hero-title em {
  font-style: italic;
  color: var(--gold-400);
}
.hero-sub {
  color: rgba(245, 242, 234, 0.85);
  font-size: clamp(1rem, 1.25vw, 1.2rem);
  max-width: 52ch;
  margin: 32px 0 40px;
  line-height: 1.55;
}
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 80px; }

.hero-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
  padding-top: 32px;
  border-top: 1px solid rgba(255,255,255,.15);
  max-width: 720px;
}
.meta-item { display: flex; flex-direction: column; gap: 6px; }
.meta-num {
  font-family: var(--serif);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: 500;
  color: var(--cream-100);
  letter-spacing: -0.02em;
  line-height: 1;
}
.meta-label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(245, 242, 234, 0.65);
}
.hero-scroll {
  position: absolute;
  right: 40px;
  bottom: 40px;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(245,242,234,.6);
}
.hero-scroll .line { width: 60px; height: 1px; background: var(--gold-400); }

@media (max-width: 720px) {
  .hero-meta { grid-template-columns: 1fr; gap: 20px; }
  .hero-scroll { display: none; }
  .hero-content { padding: 140px 24px 80px; }
  /*.hero-content { padding: 60px 24px 80px; }*/
}

/* ===== HISTORIA ===== */
.historia-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.historia-img { aspect-ratio: 4/5; border-radius: var(--radius-lg); }
.historia-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
}
.historia-stats div { display: flex; flex-direction: column; gap: 4px; }
.historia-stats b {
  font-family: var(--serif);
  font-size: 2.2rem;
  color: var(--navy-800);
  font-weight: 500;
}
.historia-stats span {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
@media (max-width: 880px) {
  .historia-grid { grid-template-columns: 1fr; gap: 40px; }
  .historia-stats { grid-template-columns: 1fr 1fr; }
}

/* ===== EQUIPO ===== */
.equipo {
	padding: 0 var(--pad-x) 120px
}

.equipo-inner {
	max-width: var(--container);
	margin: 0 auto
}

.team {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	gap: 28px;
	margin-top: 40px;
}

.m-role {
    color: var(--bad);
}

@media (min-width: 576px) {
	.team {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 28px;
		margin-top: 40px;
	}
}
@media (min-width: 768px) {
	.team {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		gap: 28px;
		margin-top: 40px;
	}
}
@media (min-width: 992px) {
	.team {
		display: grid;
		grid-template-columns: repeat(5, 1fr);
		gap: 28px;
		margin-top: 40px;
	}
}

@media (min-width: 1200px) {
	.team {
		display: grid;
		grid-template-columns: repeat(5, 1fr);
		gap: 28px;
		margin-top: 40px;
	}
}

.member {
    -webkit-transition: background-color .5s, box-shadow .5s, color .5s;
       -moz-transition: background-color .5s, box-shadow .5s, color .5s;
         -o-transition: background-color .5s, box-shadow .5s, color .5s;
            transition: background-color .5s, box-shadow .5s, color .5s;
}

.member:hover {
	background-color: #fff7;
	box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

.member .img-prof {
	height: 128px; width: 128px; 
	background-position: center center;
	background-repeat: no-repeat; 
	background-size: 100%;
    -webkit-transition: background-size .5s;
       -moz-transition: background-size .5s;
         -o-transition: background-size .5s;
            transition: background-size .5s;
}
.member:hover .img-prof {
	background-size: 120%
}


/* ===== QUOTE ===== */
.quote-section {
  background: var(--cream-200);
  padding: 100px 0;
  text-align: center;
}
.quote-section .divider-ornament { max-width: 240px; margin: 0 auto 40px; }
.quote-section blockquote {
  font-family: var(--serif);
  font-size: clamp(1.5rem, 2.6vw, 2.3rem);
  line-height: 1.3;
  font-style: italic;
  max-width: 28ch;
  margin: 0 auto 24px;
  color: var(--navy-800);
  font-weight: 400;
}
.quote-section cite {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-style: normal;
}

/* ===== NOTICIAS ===== */
.section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 56px;
  gap: 24px;
  flex-wrap: wrap;
}
.link-arrow {
  display: inline-flex; gap: 10px; align-items: center;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--navy-800);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--gold-500);
}
.link-arrow:hover { color: var(--gold-600); }

.noticias-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: 28px;
}
.noticia-card {
  background: white;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  transition: transform .3s, box-shadow .3s;
  cursor: pointer;
}
.noticia-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.noticia-card.feature .noticia-img { aspect-ratio: 16/10; }
.noticia-card .noticia-img { aspect-ratio: 4/3; }
.noticia-body { padding: 28px; flex: 1; display: flex; flex-direction: column; gap: 14px; }
.noticia-body h3 { font-size: 1.25rem; line-height: 1.25; }
.noticia-card.feature .noticia-body h3 { font-size: 1.6rem; }
.noticia-body p { color: var(--ink-soft); font-size: 14.5px; margin: 0; }
.noticia-meta {
  margin-top: auto;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
@media (max-width: 880px) { .noticias-grid { grid-template-columns: 1fr; } }

/* ===== GALERÍA MOSAIC ===== */
.gallery-mosaic {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 200px;
  gap: 12px;
}
.gallery-mosaic .ph, .gallery-mosaic .img { border-radius: var(--radius); }
.gallery-mosaic .g-tall { grid-row: span 2; }
.gallery-mosaic .g-wide { grid-column: span 2; }
@media (max-width: 880px) {
  .gallery-mosaic { grid-template-columns: 1fr 1fr; grid-auto-rows: 160px; }
  .gallery-mosaic .g-tall, .gallery-mosaic .g-wide { grid-column: span 1; grid-row: span 1; }
}

/* ===== TESTIMONIOS ===== */
.testimonios {
  background: var(--navy-900);
  color: var(--cream-100);
  padding: 120px 0;
}
.testimonios h2 { font-size: clamp(2rem, 4vw, 3.2rem); }
.test-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.test-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-lg);
  padding: 36px;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.test-card blockquote {
  font-family: var(--serif);
  font-size: 1.15rem;
  line-height: 1.45;
  color: var(--cream-100);
  margin: 0;
  font-style: italic;
  font-weight: 400;
}
.test-card figcaption {
  display: flex; gap: 14px; align-items: center;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.test-card .avatar {
  width: 48px; height: 48px; border-radius: 50%;
  background-color: var(--navy-700);
  flex-shrink: 0;
}
.test-card .avatar::before { display: none; }
.test-card b { display: block; font-family: var(--sans); font-weight: 600; font-size: 14px; }
.test-card span {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--navy-300);
}
@media (max-width: 880px) { .test-grid { grid-template-columns: 1fr; } }

/* ===== CTA FINAL ===== */
.cta-final { text-align: center; padding: 120px 0; }
.section-light { background: var(--cream-200); }


/* ---- noticias.html ---- */

.page-head {
  padding: 160px 0 40px;
  background: var(--cream-100);
  border-bottom: 1px solid var(--line);
}
.page-head h1 em { font-style: italic; color: var(--gold-600); }

.filters {
  display: flex; gap: 10px; align-items: center;
  flex-wrap: wrap;
  padding: 20px 0;
  border-bottom: 1px solid var(--line);
}
.filter-btn {
  background: transparent;
  border: 1px solid var(--line);
  padding: 10px 18px;
  border-radius: 100px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  color: var(--ink-soft);
  font-family: inherit;
  transition: all .2s;
}
.filter-btn:hover { border-color: var(--navy-600); }
.filter-btn.active { background: var(--navy-800); color: var(--cream-100); border-color: var(--navy-800); }
.filter-search {
  margin-left: auto;
  display: flex; align-items: center; gap: 10px;
  background: white;
  border: 1px solid var(--line);
  border-radius: 100px;
  padding: 10px 18px;
  min-width: 260px;
  color: var(--ink-muted);
}
.filter-search input {
  border: 0; outline: 0; background: transparent;
  flex: 1; font-family: inherit; font-size: 13px;
}

.featured-story {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 56px;
  align-items: center;
}
.featured-img { aspect-ratio: 4/3; border-radius: var(--radius-lg); }
.featured-meta {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--ink-muted);
  display: flex; gap: 8px; flex-wrap: wrap;
  margin: 8px 0 4px;
}
@media (max-width: 880px) { .featured-story { grid-template-columns: 1fr; gap: 32px; } }

.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.news-card {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  transition: transform .3s, box-shadow .3s;
}
.news-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.news-img { aspect-ratio: 4/3; }
.news-body { padding: 24px; display: flex; flex-direction: column; gap: 12px; }
.news-body h3 { font-size: 1.15rem; line-height: 1.25; }
.news-body p { color: var(--ink-soft); font-size: 14px; margin: 0; }
.news-meta {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--ink-muted);
  margin-top: 8px;
}
@media (max-width: 880px) { .news-grid { grid-template-columns: 1fr; } }


/* ---- marketplace.html ---- */

.page-head { padding: 160px 0 60px; background: var(--cream-100); border-bottom: 1px solid var(--line); }
.page-head h1 em { font-style: italic; color: var(--gold-600); }

.mp-info {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 24px;
  min-width: 280px;
}
.mp-info-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
  font-size: 13.5px;
}
.mp-info-row:last-of-type { border-bottom: 0; }
.mp-info-row span { color: var(--ink-muted); font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; }
.mp-info-row b { font-family: var(--serif); font-size: 1.5rem; color: var(--navy-800); }

.mp-toolbar-wrap {
  position: sticky; top: 64px; z-index: 10;
  background: var(--cream-100);
  border-bottom: 1px solid var(--line);
}
.mp-toolbar {
  display: flex; justify-content: space-between; gap: 24px;
  padding: 20px 24px;
  align-items: center;
  flex-wrap: wrap;
}
.mp-cats { display: flex; gap: 8px; flex-wrap: wrap; }
.cat-chip {
  background: white;
  border: 1px solid var(--line);
  padding: 10px 18px;
  border-radius: 100px;
  font-size: 13px;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  display: inline-flex; gap: 8px; align-items: center;
  transition: all .2s;
}
.cat-chip em {
  font-style: normal;
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--ink-muted);
  background: var(--cream-200);
  padding: 2px 6px;
  border-radius: 3px;
}
.cat-chip.active { background: var(--navy-800); color: var(--cream-100); border-color: var(--navy-800); }
.cat-chip.active em { background: var(--navy-700); color: var(--gold-400); }
.mp-tools { display: flex; gap: 10px; align-items: center; }
.mp-sort {
  padding: 10px 18px;
  border-radius: 100px;
  border: 1px solid var(--line);
  background: white;
  font-family: inherit;
  font-size: 13px;
  color: var(--ink-soft);
}
.filter-search { background: white; border: 1px solid var(--line); border-radius: 100px; padding: 10px 16px; display: flex; align-items: center; gap: 10px; color: var(--ink-muted); }
.filter-search input { border: 0; outline: 0; background: transparent; font-family: inherit; font-size: 13px; width: 160px; }

.mp-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.mp-card {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .3s, box-shadow .3s;
}
.mp-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.mp-imgs { position: relative; }
.mp-imgs .ph { aspect-ratio: 16/10; }
.mp-dots {
  position: absolute;
  bottom: 12px; left: 50%;
  transform: translateX(-50%);
  display: flex; gap: 6px;
}
.mp-dots span { width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,.5); }
.mp-dots span.active { background: white; width: 18px; border-radius: 3px; }
.mp-cat {
  position: absolute;
  top: 14px; left: 14px;
  background: rgba(6, 19, 40, 0.85);
  color: var(--cream-100);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 3px;
  backdrop-filter: blur(8px);
}
.mp-body { padding: 20px 22px 22px; display: flex; flex-direction: column; gap: 14px; flex: 1; }
.mp-seller { display: flex; gap: 10px; align-items: center; }
.mp-avatar { width: 36px; height: 36px; border-radius: 50%; background-color: var(--navy-100); flex-shrink: 0; }
.mp-avatar::before { display: none; }
.mp-seller b { display: block; font-size: 13.5px; font-weight: 600; color: var(--navy-800); }
.mp-seller span { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-muted); }
.mp-title { font-size: 1.1rem; line-height: 1.25; }
.mp-desc { font-size: 13.5px; color: var(--ink-soft); margin: 0; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.mp-price {
  font-family: var(--serif);
  font-size: 1.8rem;
  font-weight: 500;
  color: var(--navy-800);
  letter-spacing: -0.01em;
  padding: 8px 0;
  border-top: 1px solid var(--line);
  margin-top: auto;
}
.mp-price span {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-left: 8px;
  font-weight: 400;
}
.mp-actions { display: flex; gap: 8px; }
.mp-btn-save {
  background: transparent;
  border: 1px solid var(--line);
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 500;
  cursor: pointer;
  display: inline-flex; gap: 8px; align-items: center;
  color: var(--ink-soft);
}
.mp-btn-save:hover { border-color: var(--navy-800); color: var(--navy-800); }
.mp-actions .btn-wa { flex: 1; justify-content: center; font-size: 13px; padding: 12px 16px; }

@media (max-width: 880px) {
  .mp-grid { grid-template-columns: 1fr; }
  .mp-info { width: 100%; }
}


/* ---- galeria.html ---- */

.page-head { padding: 160px 0 40px; background: var(--cream-100); border-bottom: 1px solid var(--line); }
.page-head h1 em { font-style: italic; color: var(--gold-600); }

.filters {
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
  padding: 20px 0;
  border-bottom: 1px solid var(--line);
}
.filter-btn {
  background: transparent; border: 1px solid var(--line);
  padding: 10px 18px; border-radius: 100px;
  font-size: 13px; font-weight: 500; cursor: pointer;
  color: var(--ink-soft); font-family: inherit;
  display: inline-flex; gap: 8px; align-items: center;
}
.filter-btn em { font-style: normal; font-family: var(--mono); font-size: 10px; color: var(--ink-muted); background: var(--cream-200); padding: 2px 6px; border-radius: 3px; }
.filter-btn.active { background: var(--navy-800); color: var(--cream-100); border-color: var(--navy-800); }
.filter-btn.active em { background: var(--navy-700); color: var(--gold-400); }
.mp-sort { padding: 10px 18px; border-radius: 100px; border: 1px solid var(--line); background: white; font-family: inherit; font-size: 13px; color: var(--ink-soft); }

.album-group { margin-bottom: 80px; }
.album-head {
  display: flex; justify-content: space-between;
  align-items: flex-end; gap: 24px; margin-bottom: 32px;
  padding-bottom: 20px; border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.album-head h2 { font-size: clamp(1.6rem, 2.4vw, 2rem); }
.album-meta {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-muted); display: flex; gap: 8px; flex-wrap: wrap;
}

.gallery-mosaic {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: 10px;
}
.gallery-mosaic .ph { border-radius: var(--radius); cursor: pointer; transition: transform .3s; }
.gallery-mosaic .ph:hover { transform: scale(0.98); }
.gallery-mosaic .g-tall { grid-row: span 2; }
.gallery-mosaic .g-wide { grid-column: span 2; }
@media (max-width: 880px) {
  .gallery-mosaic { grid-template-columns: 1fr 1fr; grid-auto-rows: 160px; }
  .gallery-mosaic .g-tall, .gallery-mosaic .g-wide { grid-column: span 1; grid-row: span 1; }
}


/* ---- socios-login.html ---- */

.login-layout {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  min-height: 100vh;
}
.login-brand {
  position: relative;
  overflow: hidden;
  display: flex; flex-direction: column;
  justify-content: center;
  padding: 80px;
}
.login-bg { position: absolute; inset: 0; z-index: 0; }
.login-brand::after {
  content: "";
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(140deg, rgba(6,19,40,.85) 0%, rgba(10,31,61,.75) 60%, rgba(17,42,82,.7) 100%);
}
.login-brand-content { position: relative; z-index: 2; }
.login-features {
  display: flex; flex-direction: column; gap: 20px;
  margin: 48px 0 40px;
  padding-top: 32px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.feat { display: flex; gap: 20px; align-items: flex-start; }
.feat-num {
  font-family: var(--serif);
  font-size: 2rem;
  color: var(--gold-400);
  opacity: .7;
  line-height: 1;
  min-width: 48px;
}
.feat b { color: var(--cream-100); font-size: 15px; display: block; font-weight: 600; }
.feat span { color: rgba(245,242,234,.6); font-size: 13.5px; display: block; margin-top: 3px; }
.login-back {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(245,242,234,.7);
  padding-bottom: 4px;
  border-bottom: 1px solid rgba(201,169,97,.5);
  display: inline-block;
}
.login-back:hover { color: var(--gold-400); }

.login-form-wrap {
  background: var(--cream-100);
  color: var(--ink);
  display: flex; align-items: center; justify-content: center;
  padding: 80px 56px;
}
.login-form { width: 100%; max-width: 440px; }

.field { display: block; margin-bottom: 18px; }
.field span {
  display: block; font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 8px;
}
.field input {
  width: 100%;
  padding: 14px 18px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  font-family: inherit;
  font-size: 15px;
  background: white;
  color: var(--ink);
  transition: border-color .2s;
}
.field input:focus { outline: 0; border-color: var(--gold-500); }

.form-row {
  display: flex; justify-content: space-between; align-items: center;
  margin: 8px 0 28px;
  font-size: 13px;
}
.check { display: flex; gap: 8px; align-items: center; color: var(--ink-soft); cursor: pointer; }
.forgot { color: var(--navy-800); border-bottom: 1px solid var(--line-strong); }
.forgot:hover { border-color: var(--gold-500); }

.login-help {
  margin-top: 24px;
  font-size: 13px;
  text-align: center;
  color: var(--ink-muted);
}
.login-help a { color: var(--navy-800); border-bottom: 1px solid var(--gold-500); margin-left: 6px; }

.login-note {
  background: var(--cream-200);
  padding: 20px;
  border-radius: var(--radius);
  text-align: center;
  font-size: 13.5px;
}
.login-note b { display: block; color: var(--navy-800); margin-bottom: 4px; font-size: 14px; }
.login-note span { color: var(--ink-soft); }

@media (max-width: 960px) {
  .login-layout { grid-template-columns: 1fr; }
  .login-brand { padding: 64px 32px; min-height: 60vh; }
  .login-form-wrap { padding: 56px 32px; }
}


/* ---- socios-dashboard.html ---- */

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

/* ========== SIDEBAR ========== */
.sidebar {
  background: var(--navy-900);
  color: var(--cream-100);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
}
.sidebar .logo-text small { color: var(--navy-300); }

.side-nav { padding: 16px 0; flex: 1; }
.side-group { margin-bottom: 20px; padding: 0 14px; }
.side-label {
  display: block;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(245,242,234,.35);
  padding: 10px 10px 6px;
}
.side-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 10px;
  border-radius: var(--radius-sm);
  font-size: 13.5px;
  color: rgba(245,242,234,.7);
  transition: all .2s;
  margin-bottom: 2px;
}
.side-link:hover { background: rgba(255,255,255,.05); color: var(--cream-100); }
.side-link.active {
  background: rgba(201,169,97,.15);
  color: var(--gold-400);
  border-left: 2px solid var(--gold-500);
  padding-left: 8px;
}

.side-user {
  display: flex; gap: 12px; align-items: center;
  padding: 20px 24px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.side-user .avatar { background-color: var(--navy-700); }
.side-user .avatar::before { display: none; }
.side-user b { display: block; font-size: 13px; font-weight: 600; color: var(--cream-100); }
.side-user span { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--navy-300); }

/* ========== MAIN ========== */
.main { background: var(--cream-100); min-width: 0; }

.topbar {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding: 32px 40px;
  background: white;
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
  gap: 20px;
}
.topbar-actions { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.period-select { display: flex; background: var(--cream-200); border-radius: var(--radius-sm); padding: 3px; }
.period-btn {
  background: transparent; border: 0;
  padding: 8px 14px;
  font-family: inherit; font-size: 12.5px;
  font-weight: 500; cursor: pointer;
  color: var(--ink-soft);
  border-radius: 4px;
}
.period-btn.active { background: white; color: var(--navy-800); box-shadow: var(--shadow-sm); }

.main-inner { padding: 40px; }

/* ========== KPIs ========== */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-bottom: 32px;
}
.kpi-card {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 24px;
  position: relative;
}
.kpi-label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.kpi-value {
  display: block;
  font-family: var(--serif);
  font-size: 2.2rem;
  color: var(--navy-800);
  font-weight: 500;
  letter-spacing: -0.02em;
  margin: 8px 0 4px;
  line-height: 1;
}
.kpi-trend {
  font-size: 12px;
  font-weight: 500;
}
.kpi-trend.up { color: var(--ok); }
.kpi-trend.down { color: var(--bad); }
.kpi-spark { margin-top: 14px; height: 40px; border-radius: 4px; }

/* ========== CHARTS ========== */
.charts-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 20px;
  margin-bottom: 32px;
}
.chart-card {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 28px;
}
.chart-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 28px; gap: 16px;
}
.chart-sub {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--ink-muted);
  display: block; margin-top: 4px;
}
.chart-legend {
  display: flex; gap: 16px;
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-soft);
  align-items: center;
}
.chart-legend span { display: inline-block; width: 10px; height: 10px; border-radius: 2px; margin-right: 4px; vertical-align: middle; }
.dot-ingresos { background: var(--navy-800); }
.dot-gastos { background: var(--gold-500); }

.bar-chart { width: 100%; height: 260px; }

.donut-wrap { display: flex; gap: 24px; align-items: center; }
.donut { width: 180px; height: 180px; flex-shrink: 0; }
.donut-legend { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; flex: 1; font-size: 12.5px; }
.donut-legend li { display: flex; align-items: center; gap: 10px; color: var(--ink-soft); }
.donut-legend li span { width: 10px; height: 10px; border-radius: 2px; flex-shrink: 0; }
.donut-legend li em { margin-left: auto; font-style: normal; font-family: var(--mono); font-size: 11px; color: var(--navy-800); font-weight: 600; }

/* ========== SUB GRID: TABLE + DOCS ========== */
.sub-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 20px;
  margin-bottom: 32px;
}
.card-block {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 28px;
}
.block-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 20px;
}
.movs { width: 100%; border-collapse: collapse; font-size: 13px; }
.movs th {
  text-align: left;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-weight: 500;
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
}
.movs td {
  padding: 14px 12px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}
.movs td b { display: block; color: var(--navy-800); font-weight: 600; font-size: 13.5px; }
.movs td span {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-top: 3px;
}
.pill {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 100px;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 500;
}
.pill-ingreso { background: rgba(47, 125, 91, 0.1); color: var(--ok); }
.pill-gasto { background: rgba(163, 58, 58, 0.08); color: var(--bad); }
.amount { font-family: var(--serif); font-size: 1.1rem; font-weight: 500; text-align: right; }
.amount.pos { color: var(--ok); }
.amount.neg { color: var(--bad); }

/* ========== UPLOAD & DOCS ========== */
.upload-zone {
  border: 1.5px dashed var(--line-strong);
  border-radius: var(--radius);
  padding: 32px 20px;
  text-align: center;
  margin-bottom: 20px;
  color: var(--ink-muted);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.upload-zone:hover { border-color: var(--gold-500); color: var(--navy-800); }
.upload-zone b { color: var(--navy-800); font-size: 14px; }
.upload-zone span { font-family: var(--mono); font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; }

.doc-list { list-style: none; padding: 0; margin: 0; }
.doc-list li {
  display: flex; gap: 14px; align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}
.doc-list li:last-child { border-bottom: 0; }
.doc-ico {
  width: 40px; height: 48px;
  border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: white;
  flex-shrink: 0;
}
.doc-ico.pdf { background: #c4454a; }
.doc-ico.xls { background: #1f7a4d; }
.doc-ico.doc { background: #2b5ca6; }
.doc-list li > div:nth-child(2) { flex: 1; min-width: 0; }
.doc-list li b { display: block; color: var(--navy-800); font-size: 13.5px; font-weight: 600; }
.doc-list li span { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-muted); margin-top: 3px; }
.doc-action { background: none; border: 0; font-size: 20px; color: var(--ink-muted); cursor: pointer; padding: 4px 10px; line-height: 1; }

/* ========== CONTENT ACTIONS ========== */
.content-actions { margin-bottom: 32px; }
.action-card {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 32px;
  display: block;
  transition: all .2s;
  cursor: pointer;
}
.action-card:hover { border-color: var(--gold-500); transform: translateY(-4px); box-shadow: var(--shadow); }
.action-ico {
  width: 56px; height: 56px;
  border-radius: var(--radius);
  background: var(--cream-200);
  color: var(--navy-800);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 20px;
}
.action-card b { display: block; font-family: var(--serif); font-size: 1.3rem; font-weight: 500; color: var(--navy-800); margin-bottom: 8px; }
.action-card > span { display: block; font-size: 13.5px; color: var(--ink-soft); margin-bottom: 20px; line-height: 1.5; }
.action-card em {
  font-style: normal;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-600);
  padding-bottom: 3px;
  border-bottom: 1px solid var(--gold-500);
}

.app-footer {
  display: flex; justify-content: space-between;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-muted);
  padding: 24px 0;
  border-top: 1px solid var(--line);
  margin-top: 32px;
}

/* ========== RESPONSIVE ========== */
@media (max-width: 1100px) {
  .app { grid-template-columns: 1fr; }
  .sidebar { position: relative; height: auto; }
  .side-nav { display: flex; overflow-x: auto; padding: 12px; gap: 4px; }
  .side-group { display: flex; gap: 4px; padding: 0; margin: 0; }
  .side-label { display: none; }
  .side-link { white-space: nowrap; padding: 8px 14px; }
  .side-user { display: none; }
}
@media (max-width: 880px) {
  .kpi-grid { grid-template-columns: 1fr 1fr; }
  .charts-grid, .sub-grid { grid-template-columns: 1fr; }
  .main-inner, .topbar { padding: 24px; }
  .donut-wrap { flex-direction: column; }
}


/* ===========================================
   MARKETPLACE PREVIEW (home)
   =========================================== */
.marketplace-grid-home {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.mp-card-home {
  background: white;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  transition: transform .3s, box-shadow .3s, border-color .3s;
  cursor: pointer;
}
.mp-card-home:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
  border-color: var(--gold-500);
}
.mp-card-img {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--cream-100, #fbf9f5);
}
.mp-card-tag {
  position: absolute;
  top: 12px;
  left: 12px;
  background: rgba(10, 31, 61, 0.88);
  color: white;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 3px;
  z-index: 2;
}
.mp-card-body {
  padding: 20px 22px 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mp-card-body h3 {
  font-size: 1.05rem;
  line-height: 1.3;
  color: var(--navy-800);
  margin: 0;
  /* Truncar a 2 líneas para mantener altura consistente */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.mp-card-loc {
  font-size: 13px;
  color: var(--ink-muted);
}
.mp-card-foot {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.mp-card-price {
  font-family: var(--display, 'Fraunces');
  font-weight: 500;
  font-size: 1.15rem;
  color: var(--navy-800);
}
.mp-card-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--gold-600);
  letter-spacing: 0.04em;
}

/* Estado vacío del marketplace */
.mp-empty-home {
  grid-column: 1 / -1;
}
.mp-empty-inner {
  background: white;
  border: 1px dashed var(--line);
  border-radius: var(--radius-lg);
  padding: 60px 32px;
  text-align: center;
  max-width: 560px;
  margin: 0 auto;
}
.mp-empty-icon {
  font-size: 3rem;
  margin-bottom: 16px;
  opacity: 0.6;
}
.mp-empty-inner h3 {
  font-size: 1.4rem;
  color: var(--navy-800);
  margin: 0 0 12px;
}
.mp-empty-inner p {
  color: var(--ink-soft);
  font-size: 15px;
  margin: 0 0 24px;
  line-height: 1.6;
}

@media (max-width: 1100px) {
  .marketplace-grid-home { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .marketplace-grid-home { grid-template-columns: 1fr; }
}

/* ===========================================
   PÁGINAS INTERNAS — hero, breadcrumb, paginación
   =========================================== */
.page-hero {
  padding: 140px 0 60px;
  /*padding: 60px 0 60px;*/
  background: linear-gradient(180deg, var(--cream-100, #fbf9f5) 0%, white 100%);
  border-bottom: 1px solid var(--line);
}
.page-hero .eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-600);
  margin-bottom: 16px;
}
.page-title {
  font-family: var(--display, 'Fraunces');
  font-weight: 400;
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  line-height: 1.05;
  color: var(--navy-800);
  margin: 0 0 20px;
  letter-spacing: -0.02em;
}
.page-subtitle {
  font-size: 1.1rem;
  color: var(--ink-soft);
  max-width: 56ch;
  line-height: 1.6;
}

.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 24px;
}
.breadcrumb a {
  color: var(--ink-soft);
  text-decoration: none;
  transition: color .2s ease;
}
.breadcrumb a:hover { color: var(--gold-600); }
.breadcrumb span { color: var(--ink-muted); opacity: 0.5; }

.cnv-pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 48px;
  flex-wrap: wrap;
}
.cnv-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 4px;
  font-size: 14px;
  color: var(--navy-800);
  text-decoration: none;
  background: white;
  transition: all .15s ease;
}
.cnv-pagination .page-numbers:hover {
  border-color: var(--navy-800);
}
.cnv-pagination .page-numbers.current {
  background: var(--navy-800);
  color: white;
  border-color: var(--navy-800);
}

/* ===========================================
   EMPTY STATE (genérico)
   =========================================== */
.empty-state {
  background: white;
  border: 1px dashed var(--line);
  border-radius: var(--radius-lg);
  padding: 80px 32px;
  text-align: center;
  max-width: 560px;
  margin: 0 auto;
}
.empty-icon {
  font-size: 3rem;
  margin-bottom: 16px;
  opacity: 0.6;
}
.empty-state h3 {
  font-family: var(--display, 'Fraunces');
  font-size: 1.5rem;
  color: var(--navy-800);
  margin: 0 0 12px;
}
.empty-state p {
  color: var(--ink-soft);
  font-size: 15px;
  margin: 0 0 28px;
  line-height: 1.6;
}

/* ===========================================
   ARCHIVE — GALERÍA (/galeria/)
   =========================================== */
.albums-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.album-archive-card {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.album-archive-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
  border-color: var(--gold-500);
}
.album-archive-cover {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--cream-100, #fbf9f5);
}
.album-archive-count {
  position: absolute;
  bottom: 12px;
  right: 12px;
  background: rgba(10, 31, 61, 0.88);
  color: white;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  padding: 5px 11px;
  border-radius: 999px;
}
.album-archive-body {
  padding: 22px 24px;
}
.album-archive-body h3 {
  font-family: var(--display, 'Fraunces');
  font-size: 1.25rem;
  margin: 0 0 6px;
  color: var(--navy-800);
  font-weight: 500;
}
.album-archive-date {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
@media (max-width: 880px) { .albums-archive-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .albums-archive-grid { grid-template-columns: 1fr; } }

/* ===========================================
   HOME — GALERÍA dinámica (álbumes)
   =========================================== */
.albums-home-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 240px;
  gap: 16px;
}
.albums-home-grid .album-home-card:nth-child(1) { grid-row: span 2; }
.albums-home-grid .album-home-card:nth-child(4) { grid-column: span 2; }
.album-home-card {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--radius-lg);
  text-decoration: none;
  cursor: pointer;
  background: var(--cream-100, #fbf9f5);
}
.album-home-cover {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.album-home-cover .img {
  transition: transform .6s ease;
}
.album-home-card:hover .album-home-cover .img {
  transform: scale(1.05);
}
.album-home-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
  background: linear-gradient(180deg, transparent 50%, rgba(6,19,40,0.85) 100%);
  color: white;
}
.album-home-title {
  font-family: var(--display, 'Fraunces');
  font-size: 1.3rem;
  font-weight: 500;
  margin-bottom: 6px;
  line-height: 1.2;
}
.album-home-count {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.85;
}
@media (max-width: 880px) {
  .albums-home-grid { grid-template-columns: repeat(2, 1fr); }
  .albums-home-grid .album-home-card:nth-child(1),
  .albums-home-grid .album-home-card:nth-child(4) { grid-row: auto; grid-column: auto; }
}
@media (max-width: 560px) {
  .albums-home-grid { grid-template-columns: 1fr; grid-auto-rows: 220px; }
}

/* ===========================================
   SINGLE ÁLBUM — Grid de fotos + lightbox
   =========================================== */
.album-photos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}
.album-photo {
  display: block;
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: 6px;
  cursor: pointer;
  background: var(--cream-100, #fbf9f5);
}
.album-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.album-photo:hover img { transform: scale(1.06); }

.cnv-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(6, 19, 40, 0.95);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .25s ease;
}
.cnv-lightbox[hidden] { display: none !important; }
.cnv-lightbox.open { opacity: 1; }
.cnv-lb-image-wrap {
  max-width: 90vw;
  max-height: 85vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cnv-lb-image-wrap img {
  max-width: 100%;
  max-height: 85vh;
  object-fit: contain;
  border-radius: 4px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}
.cnv-lb-close, .cnv-lb-prev, .cnv-lb-next {
  position: absolute;
  background: rgba(255, 255, 255, 0.1);
  color: white;
  border: 1px solid rgba(255, 255, 255, 0.2);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  font-size: 24px;
  cursor: pointer;
  transition: all .2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cnv-lb-close:hover, .cnv-lb-prev:hover, .cnv-lb-next:hover {
  background: rgba(255, 255, 255, 0.2);
}
.cnv-lb-close { top: 24px; right: 24px; }
.cnv-lb-prev { left: 24px; top: 50%; transform: translateY(-50%); font-size: 32px; }
.cnv-lb-next { right: 24px; top: 50%; transform: translateY(-50%); font-size: 32px; }
.cnv-lb-counter {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  color: rgba(255, 255, 255, 0.7);
}

/* ===========================================
   ARCHIVE — NOTICIAS (/noticias/)
   =========================================== */
.news-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.news-archive-card {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  transition: transform .3s, box-shadow .3s, border-color .3s;
  display: flex;
  flex-direction: column;
}
.news-archive-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
  border-color: var(--gold-500);
}
.news-archive-img {
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.news-archive-body {
  padding: 24px 26px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.news-archive-body .tag {
  align-self: flex-start;
}
.news-archive-body h3 {
  font-family: var(--display, 'Fraunces');
  font-size: 1.25rem;
  line-height: 1.3;
  color: var(--navy-800);
  margin: 0;
  font-weight: 500;
}
.news-archive-body p {
  color: var(--ink-soft);
  font-size: 14.5px;
  margin: 0;
  line-height: 1.55;
}
.news-archive-meta {
  margin-top: auto;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
@media (max-width: 880px) { .news-archive-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .news-archive-grid { grid-template-columns: 1fr; } }

/* ===========================================
   SECTION HEAD con múltiples acciones
   =========================================== */
.section-head-actions {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.btn-sm {
  padding: 10px 18px !important;
  font-size: 13.5px !important;
}

/* ===========================================
   FORMULARIO PÚBLICO DE PUBLICACIÓN (/publicar/)
   =========================================== */
.pub-form {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 40px;
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.pub-form fieldset {
  border: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.pub-form legend {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-600);
  padding: 0;
  margin-bottom: 8px;
}
.pub-form label {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pub-form label > span {
  font-size: 14px;
  font-weight: 500;
  color: var(--navy-800);
}
.pub-form label em {
  color: #c0392b;
  font-style: normal;
  margin-left: 2px;
}
.pub-form input[type="text"],
.pub-form input[type="email"],
.pub-form input[type="number"],
.pub-form input[type="file"],
.pub-form select,
.pub-form textarea {
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 6px;
  font-family: inherit;
  font-size: 15px;
  background: white;
  color: var(--navy-800);
  transition: border-color .15s ease;
}
.pub-form input:focus,
.pub-form select:focus,
.pub-form textarea:focus {
  outline: none;
  border-color: var(--gold-500);
}
.pub-form textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.5;
}
.pub-form small.muted {
  font-size: 12.5px;
  color: var(--ink-muted);
  line-height: 1.4;
}
.pub-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.pub-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.pub-error {
  background: #fdecea;
  color: #a02018;
  border: 1px solid #f5c2bd;
  padding: 14px 18px;
  border-radius: 6px;
  font-size: 14px;
  line-height: 1.5;
}
.pub-disclaimer {
  font-size: 12.5px;
  color: var(--ink-muted);
  line-height: 1.55;
  margin: 0;
  max-width: 64ch;
}
.pub-success {
  background: white;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 60px 40px;
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}
.pub-success-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: #d4edda;
  color: #2a7a40;
  font-size: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.pub-success h3 {
  font-family: var(--display, 'Fraunces');
  font-size: 1.7rem;
  color: var(--navy-800);
  margin: 0 0 16px;
}
.pub-success p {
  color: var(--ink-soft);
  font-size: 15.5px;
  line-height: 1.65;
  margin: 0 0 24px;
  max-width: 48ch;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 640px) {
  .pub-form { padding: 28px 22px; gap: 22px; }
  .pub-row { grid-template-columns: 1fr; }
  .pub-actions { flex-direction: column; }
  .pub-actions .btn { width: 100%; }
}

/* ===========================================
   AJUSTES VISUALES — header del marketplace
   =========================================== */
.market-head {
  display: flex;
  gap: 16px;
  align-items: flex-end;
  flex-wrap: wrap;
}
.market-head .market-filters {
  margin-bottom: 0 !important;
}
