/* ============================================================
   OCEANAVAL — Formulario de contacto, mapas y páginas legales
   ============================================================ */

/* ============ Layout contacto ============ */
.contact__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-7); align-items: start; }

.contact__aside h3 { font-family: var(--f-mono); font-size: var(--t-small); font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; color: var(--c-cyan); margin-bottom: 1rem; }
.contact__channels { display: flex; flex-direction: column; gap: 1.75rem; margin-bottom: var(--s-5); }
.channel { display: flex; flex-direction: column; gap: 0.35rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--c-line); }
.channel__label { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-slate); }
.channel__value { font-family: var(--f-display); font-weight: 600; font-size: clamp(1.25rem, 2.5vw, 1.75rem); color: var(--c-paper); transition: color var(--d-fast); }
.channel a.channel__value:hover { color: var(--c-cyan); }

/* Delegaciones */
.offices { display: grid; gap: var(--s-3); }
.office {
  border: 1px solid var(--c-line); border-radius: var(--radius);
  padding: clamp(1.5rem, 3vw, 2rem); background: var(--c-deep);
  position: relative; overflow: hidden;
}
.office__tag { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-cyan); }
.office__city { font-family: var(--f-display); font-weight: 600; font-size: var(--t-h3); color: var(--c-paper); margin-block: 0.4rem 0.75rem; }
.office__addr { font-style: normal; color: var(--c-mist); line-height: 1.7; font-size: 1rem; }
.office__pin { position: absolute; top: 1.25rem; right: 1.25rem; color: var(--c-cyan); opacity: 0.5; }

/* ============ Formulario ============ */
.form { display: grid; gap: 1.5rem; }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.field { position: relative; display: flex; flex-direction: column; }
.field label {
  font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--c-slate); margin-bottom: 0.6rem;
}
.field label .req { color: var(--c-cyan); }
.field input, .field textarea {
  font-family: var(--f-serif); font-size: 1.05rem; color: var(--c-paper);
  background: transparent; border: none; border-bottom: 1px solid var(--c-field-border);
  padding: 0.7rem 0; transition: border-color var(--d-base) var(--ease-out);
  width: 100%; border-radius: 0;
}
.field input::placeholder, .field textarea::placeholder { color: var(--c-placeholder); opacity: 1; }
.field input[aria-invalid="true"], .field textarea[aria-invalid="true"] { border-color: oklch(70% 0.16 25); }
.field__error { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: 0.05em; color: oklch(72% 0.16 25); margin-top: 0.5rem; min-height: 1em; }
.field__hint { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: 0.05em; color: var(--c-slate); margin-top: 0.45rem; }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--c-cyan); }
.field textarea { resize: vertical; min-height: 7rem; line-height: 1.6; }

.form__consent { display: flex; gap: 0.75rem; align-items: flex-start; font-size: 0.9rem; color: var(--c-slate); }
.form__consent input { margin-top: 0.25rem; accent-color: var(--c-cyan); width: 1.1rem; height: 1.1rem; flex-shrink: 0; }
.form__consent a { color: var(--c-cyan); }
.form__actions { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.form__note { font-family: var(--f-mono); font-size: var(--t-micro); color: var(--c-slate); letter-spacing: 0.05em; }

.form-status { font-family: var(--f-mono); font-size: var(--t-small); padding: 1rem 1.25rem; border-radius: var(--radius); display: none; }
.form-status.is-ok { display: block; color: var(--c-cyan); border: 1px solid var(--c-cyan-deep); background: oklch(78% 0.13 215 / 0.08); }
.form-status.is-err { display: block; color: oklch(70% 0.16 25); border: 1px solid oklch(50% 0.16 25); background: oklch(50% 0.16 25 / 0.08); }

/* ============ Páginas legales ============ */
.legal { max-width: 52rem; }
.legal__meta { font-family: var(--f-mono); font-size: var(--t-small); color: var(--c-slate); letter-spacing: 0.08em; margin-bottom: var(--s-4); padding-bottom: var(--s-3); border-bottom: 1px solid var(--c-line); }
.legal h2 { font-family: var(--f-display); font-weight: 600; font-size: var(--t-h3); color: var(--c-paper); margin-top: var(--s-5); margin-bottom: 1rem; letter-spacing: -0.01em; }
.legal h2:first-of-type { margin-top: 0; }
.legal h3 { font-family: var(--f-display); font-weight: 600; font-size: 1.15rem; color: var(--c-paper); margin-top: var(--s-3); margin-bottom: 0.5rem; }
.legal p { color: var(--c-mist); margin-bottom: 1.25rem; line-height: 1.75; }
.legal strong { color: var(--c-paper); font-weight: 600; }
.legal a { color: var(--c-cyan); border-bottom: 1px solid oklch(78% 0.13 215 / 0.3); }
.legal ul.legal-list { display: flex; flex-direction: column; gap: 0.65rem; margin-bottom: 1.5rem; }
.legal ul.legal-list li { color: var(--c-mist); padding-left: 1.5rem; position: relative; }
.legal ul.legal-list li::before { content: ""; position: absolute; left: 0; top: 0.65em; width: 0.5rem; height: 1px; background: var(--c-cyan); }
.legal__card { border: 1px solid var(--c-line); border-radius: var(--radius); padding: var(--s-3); background: var(--c-deep); margin-bottom: 1.5rem; font-family: var(--f-mono); font-size: 0.9rem; color: var(--c-mist); line-height: 1.9; }
.legal__card a { border: none; }

/* TOC legal */
.legal-layout { display: grid; grid-template-columns: 16rem 1fr; gap: var(--s-6); align-items: start; }
.legal-toc { position: sticky; top: calc(var(--header-h) + 2rem); }
.legal-toc h4 { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-cyan); margin-bottom: 1rem; }
.legal-toc ul { display: flex; flex-direction: column; gap: 0.5rem; border-left: 1px solid var(--c-line); }
.legal-toc a { font-size: 0.9rem; color: var(--c-slate); padding: 0.25rem 0 0.25rem 1rem; margin-left: -1px; border-left: 1px solid transparent; transition: color var(--d-fast), border-color var(--d-fast); display: block; }
.legal-toc a:hover, .legal-toc a.is-active { color: var(--c-paper); border-left-color: var(--c-cyan); }

/* ============ Responsive ============ */
@media (max-width: 900px) {
  .contact__grid { grid-template-columns: 1fr; gap: var(--s-5); }
  .legal-layout { grid-template-columns: 1fr; }
  .legal-toc { position: static; margin-bottom: var(--s-3); }
  .legal-toc ul { flex-direction: row; flex-wrap: wrap; border-left: none; gap: 0.75rem; }
  .legal-toc a { border: 1px solid var(--c-line); padding: 0.4rem 0.8rem; }
}
@media (max-width: 560px) {
  .form__row { grid-template-columns: 1fr; }
}
