/* Shared page-level components used by inner pages */

/* Page hero (dark) */
.page-hero {
  background: var(--color-bg-primary); color: #fff;
  padding: calc(var(--nav-h) + var(--sp-24)) 0 var(--sp-24);
  position: relative; overflow: hidden;
}
.page-hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30% 40%, rgba(154,150,170,0.12), transparent 55%);
}
.page-hero-inner { position: relative; z-index: 1; max-width: var(--container); margin: 0 auto; padding: 0 var(--sp-8); }
.page-hero .eyebrow { color: var(--color-accent); }
.page-hero h1 {
  font-size: clamp(2.25rem, 4.5vw, 4rem);
  font-weight: var(--fw-light); letter-spacing: -0.025em;
  max-width: 22ch; margin-top: var(--sp-6); color: #fff;
}
.page-hero h1 em { font-style: normal; font-weight: var(--fw-bold); color: var(--color-accent); }
.page-hero .lede { color: rgba(255,255,255,0.72); max-width: 60ch; margin-top: var(--sp-6); font-size: var(--fs-lg); line-height: var(--lh-relaxed); }

/* ---------- Sobre Nosotros ---------- */
.bio { padding: var(--sp-32) 0; background: #fff; }
.bio-inner { max-width: var(--container); margin: 0 auto; padding: 0 var(--sp-8); display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--sp-16); align-items: start; }
.bio-portrait {
  width: 150px;
  aspect-ratio: 1;
  position: sticky;
  top: calc(var(--nav-h) + 40px);
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: var(--color-bg-subtle-2);
}
.bio-portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.bio-meta { margin-top: var(--sp-6); display: flex; flex-direction: column; gap: var(--sp-2); }
.bio-name { font-size: var(--fs-xl); font-weight: var(--fw-semibold); color: var(--color-text-on-light); }
.bio-role { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); color: var(--color-accent-text); font-weight: var(--fw-semibold); }
.bio-body h2 { font-weight: var(--fw-light); letter-spacing: -0.02em; font-size: clamp(1.875rem, 3.4vw, 3rem); color: var(--color-text-on-light); }
.bio-body h2 em { font-style: normal; font-weight: var(--fw-bold); }
.bio-body p { font-size: var(--fs-lg); line-height: var(--lh-relaxed); color: var(--color-text-on-light-muted); margin-top: var(--sp-4); max-width: 60ch; }
.creds { margin-top: var(--sp-12); display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-6); border-top: 1px solid var(--color-border); padding-top: var(--sp-8); }
.cred-label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); color: var(--color-text-muted); font-weight: var(--fw-semibold); }
.cred-value { font-size: var(--fs-base); color: var(--color-text-on-light); font-weight: var(--fw-medium); margin-top: 6px; line-height: 1.4; }
.bio-social { margin-top: var(--sp-8); display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.bio-social a { padding: 10px 16px; border: 1px solid var(--color-border); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); font-weight: var(--fw-semibold); color: var(--color-text-on-light); transition: all 180ms ease; }
.bio-social a:hover { background: var(--color-text-on-light); color: #fff; border-color: var(--color-text-on-light); }
@media (max-width: 900px) { .bio-inner { grid-template-columns: 1fr; } .bio-portrait { position: static; max-width: 400px; } }

.timeline-s { padding: var(--sp-32) 0; background: var(--color-bg-subtle-2); }
.timeline-head { max-width: var(--container); margin: 0 auto var(--sp-12); padding: 0 var(--sp-8); }
.timeline-head h2 { font-weight: var(--fw-light); letter-spacing: -0.02em; font-size: clamp(1.875rem, 3vw, 2.5rem); color: var(--color-text-on-light); margin-top: var(--sp-3); }
.timeline-head h2 em { font-style: normal; font-weight: var(--fw-bold); }
.timeline-head p { max-width: 60ch; margin-top: var(--sp-4); color: var(--color-text-on-light-muted); font-size: var(--fs-lg); }
.timeline { max-width: var(--container); margin: 0 auto; padding: 0 var(--sp-8); display: grid; grid-template-columns: 1fr; gap: 0; border-top: 1px solid var(--color-border); }
.t-row { display: grid; grid-template-columns: 160px 1fr; gap: var(--sp-8); padding: var(--sp-8) 0; border-bottom: 1px solid var(--color-border); align-items: start; }
.t-year { font-size: var(--fs-xl); font-weight: var(--fw-light); color: var(--color-accent-text); letter-spacing: -0.01em; }
.t-title { font-size: var(--fs-xl); font-weight: var(--fw-semibold); color: var(--color-text-on-light); }
.t-body { margin-top: var(--sp-2); color: var(--color-text-on-light-muted); line-height: var(--lh-relaxed); max-width: 60ch; }
@media (max-width: 720px) { .t-row { grid-template-columns: 1fr; gap: var(--sp-2); } }

.lp-cta { padding: var(--sp-32) 0; background: var(--color-bg-primary); color: #fff; position: relative; overflow: hidden; }
.lp-cta::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 50%, rgba(154,150,170,0.15), transparent 55%); }
.lp-inner { position: relative; z-index: 1; max-width: var(--container); margin: 0 auto; padding: 0 var(--sp-8); display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--sp-16); align-items: center; }
.lp-inner .eyebrow { color: var(--color-accent); }
.lp-inner h2 { font-size: clamp(2rem, 3.6vw, 3rem); font-weight: var(--fw-light); letter-spacing: -0.02em; color: #fff; margin-top: var(--sp-4); }
.lp-inner h2 em { font-style: normal; font-weight: var(--fw-bold); color: var(--color-accent); }
.lp-inner > div > p { margin-top: var(--sp-4); color: rgba(255,255,255,0.72); font-size: var(--fs-lg); line-height: var(--lh-relaxed); max-width: 52ch; }
.lp-card { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); padding: var(--sp-10); }
.lp-card h3 { font-size: var(--fs-xl); font-weight: var(--fw-semibold); color: #fff; margin-top: var(--sp-3); }
.lp-card p { color: rgba(255,255,255,0.64); margin-top: var(--sp-3); font-size: var(--fs-sm); line-height: var(--lh-relaxed); }
.lp-card button { margin-top: var(--sp-6); width: 100%; background: var(--color-accent-text); color: #fff; border: 0; padding: 14px 20px; font-family: inherit; font-weight: var(--fw-semibold); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); cursor: pointer; transition: background 180ms ease; }
.lp-card button:hover { background: var(--color-accent-text-hover); }
@media (max-width: 900px) { .lp-inner { grid-template-columns: 1fr; } }

.modal-backdrop { position: fixed; inset: 0; background: rgba(20,20,24,0.72); backdrop-filter: blur(8px); z-index: 80; opacity: 0; pointer-events: none; transition: opacity 240ms ease; display: grid; place-items: center; padding: var(--sp-6); }
.modal-backdrop.open { opacity: 1; pointer-events: auto; }
.modal { background: #fff; max-width: 480px; width: 100%; padding: var(--sp-12); transform: translateY(12px); transition: transform 240ms ease; }
.modal-backdrop.open .modal { transform: translateY(0); }
.modal-eyebrow { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-eyebrow); color: var(--color-accent-text); font-weight: var(--fw-semibold); }
.modal h3 { font-size: var(--fs-2xl); font-weight: var(--fw-light); letter-spacing: -0.015em; margin-top: var(--sp-3); color: var(--color-text-on-light); }
.modal p { font-size: var(--fs-sm); color: var(--color-text-on-light-muted); line-height: var(--lh-relaxed); margin-top: var(--sp-3); }
.modal label { display: block; font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); color: var(--color-text-on-light); font-weight: var(--fw-semibold); margin-top: var(--sp-6); }
.modal input { width: 100%; border: 0; border-bottom: 1px solid var(--color-border); padding: 10px 0; font-family: inherit; font-size: var(--fs-base); margin-top: 4px; background: transparent; outline: none; transition: border-color 160ms ease; color: var(--color-text-on-light); }
.modal input:focus { border-color: var(--color-accent); }
.modal input[aria-invalid="true"] { border-color: #b42318; }
.lp-error { font-size: var(--fs-xs); color: #b42318; font-weight: var(--fw-medium); margin-top: 6px; }
[data-theme="dark"] .lp-error { color: #ff9d92; }
[data-theme="dark"] .modal input[aria-invalid="true"] { border-color: #ff9d92; }
.modal-actions { display: flex; gap: var(--sp-3); margin-top: var(--sp-8); }
.modal button.primary { background: var(--color-text-on-light); color: #fff; border: 0; padding: 12px 20px; font-family: inherit; font-weight: var(--fw-semibold); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); cursor: pointer; flex: 1; }
.modal button.ghost { background: transparent; color: var(--color-text-on-light); border: 1px solid var(--color-border); padding: 12px 20px; font-family: inherit; font-weight: var(--fw-semibold); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); cursor: pointer; }

/* ---------- Contacto ---------- */
.contact-grid { padding: var(--sp-32) 0; background: #fff; }
.contact-grid-inner { max-width: var(--container); margin: 0 auto; padding: 0 var(--sp-8); display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--sp-16); align-items: start; }
.contact-info h2 { font-weight: var(--fw-light); letter-spacing: -0.02em; font-size: clamp(1.875rem, 3.4vw, 3rem); color: var(--color-text-on-light); }
.contact-info h2 em { font-style: normal; font-weight: var(--fw-bold); }
.contact-info p { font-size: var(--fs-lg); line-height: var(--lh-relaxed); color: var(--color-text-on-light-muted); margin-top: var(--sp-4); max-width: 48ch; }
.contact-list { margin-top: var(--sp-12); display: grid; gap: var(--sp-6); border-top: 1px solid var(--color-border); padding-top: var(--sp-8); }
.ci-row { display: grid; grid-template-columns: 140px 1fr; gap: var(--sp-6); align-items: baseline; }
.ci-label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); color: var(--color-text-muted); font-weight: var(--fw-semibold); }
.ci-val { font-size: var(--fs-base); color: var(--color-text-on-light); font-weight: var(--fw-medium); line-height: 1.45; }
.ci-val a { color: var(--color-text-on-light); border-bottom: 1px solid var(--color-border); transition: border-color 160ms ease; }
.ci-val a:hover { border-color: var(--color-accent); }

.contact-form { background: var(--color-bg-subtle-2); padding: var(--sp-12); }
.cf-steps { display: flex; gap: 0; margin-bottom: var(--sp-10); border-bottom: 1px solid var(--color-border); }
.cf-step { flex: 1; padding: var(--sp-3) 0; font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); color: var(--color-text-muted); font-weight: var(--fw-semibold); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all 180ms ease; text-align: center; cursor: default; }
.cf-step.active { color: var(--color-text-on-light); border-bottom-color: var(--color-accent); }
.cf-step.done { color: var(--color-accent-text); }
.cf-panel { display: none; }
.cf-panel.active { display: block; }
.cf-panel h3 { font-size: var(--fs-2xl); font-weight: var(--fw-light); letter-spacing: -0.015em; color: var(--color-text-on-light); }
.cf-panel p { font-size: var(--fs-sm); color: var(--color-text-on-light-muted); line-height: var(--lh-relaxed); margin-top: var(--sp-2); }
.cf-options { margin-top: var(--sp-8); display: grid; gap: var(--sp-3); }
.cf-option { display: flex; align-items: flex-start; gap: var(--sp-4); padding: var(--sp-5); background: #fff; border: 1px solid var(--color-border); cursor: pointer; transition: all 180ms ease; }
.cf-option:hover { border-color: var(--color-accent); }
.cf-option.selected { border-color: var(--color-accent); background: var(--color-accent-soft); }
.cf-option input { display: none; }
.cf-option-title { font-size: var(--fs-base); font-weight: var(--fw-semibold); color: var(--color-text-on-light); }
.cf-option-desc { font-size: var(--fs-sm); color: var(--color-text-on-light-muted); margin-top: 4px; line-height: 1.5; }
.cf-field { margin-top: var(--sp-6); }
.cf-field label { display: block; font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); color: var(--color-text-on-light); font-weight: var(--fw-semibold); margin-bottom: var(--sp-2); }
.cf-field input, .cf-field textarea { width: 100%; border: 0; border-bottom: 1px solid var(--color-border); padding: 10px 0; font-family: inherit; font-size: var(--fs-base); background: transparent; outline: none; color: var(--color-text-on-light); transition: border-color 160ms ease; resize: vertical; }
.cf-field textarea { min-height: 100px; }
.cf-field input:focus, .cf-field textarea:focus { border-color: var(--color-accent); }
.cf-field input[aria-invalid="true"], .cf-field textarea[aria-invalid="true"] { border-color: #b42318; }
.cf-error { margin-top: var(--sp-2); font-size: var(--fs-xs); color: #b42318; font-weight: var(--fw-medium); }
[data-theme="dark"] .cf-error { color: #ff9d92; }
[data-theme="dark"] .cf-field input[aria-invalid="true"], [data-theme="dark"] .cf-field textarea[aria-invalid="true"] { border-color: #ff9d92; }
.cf-nav { margin-top: var(--sp-10); display: flex; gap: var(--sp-3); justify-content: space-between; }
.cf-btn { background: var(--color-text-on-light); color: #fff; border: 0; padding: 14px 24px; font-family: inherit; font-weight: var(--fw-semibold); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tr-label); cursor: pointer; transition: background 180ms ease; }
.cf-btn:hover { background: #000; }
.cf-btn.ghost { background: transparent; color: var(--color-text-on-light); border: 1px solid var(--color-border); }
.cf-btn.ghost:hover { background: transparent; border-color: var(--color-text-on-light); }
.cf-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.cf-success { text-align: center; padding: var(--sp-16) var(--sp-6); }
.cf-success-icon { width: 60px; height: 60px; margin: 0 auto; border: 2px solid var(--color-accent-text); border-radius: 50%; display: grid; place-items: center; color: var(--color-accent-text); }
.cf-success h3 { margin-top: var(--sp-6); font-size: var(--fs-2xl); font-weight: var(--fw-light); color: var(--color-text-on-light); }
.cf-success p { margin-top: var(--sp-3); color: var(--color-text-on-light-muted); line-height: var(--lh-relaxed); max-width: 44ch; margin-left: auto; margin-right: auto; }

@media (max-width: 900px) {
  .contact-grid-inner { grid-template-columns: 1fr; }
  .ci-row { grid-template-columns: 1fr; gap: var(--sp-1); }
}
