/* ============================================================
   Reparo Venezuela — Hoja de estilos
   Mobile-first. Paleta institucional: azul, dorado, blanco, gris.
   ============================================================ */

:root{
  /* Color */
  --navy:        #17375E;   /* azul institucional (marca) */
  --navy-deep:   #0E2440;   /* fondo oscuro profundo */
  --gold:        #C9A34A;   /* dorado institucional (acento) */
  --gold-deep:   #9C7C2E;   /* dorado oscuro (hover/contraste) */
  --ink:         #1B2A3A;   /* texto sobre claro */
  --gray:        #6E7781;   /* texto secundario */
  --paper:       #F7F6F1;   /* off-white cálido para alternar */
  --line:        #E6E2D8;   /* línea fina cálida */
  --line-cool:   #E4E7EB;   /* línea fina fría */
  --white:       #FFFFFF;
  --on-navy:     #EAF0F7;   /* texto claro sobre azul */
  --on-navy-dim: #A9BBD0;   /* texto claro atenuado sobre azul */

  /* Tipografía */
  --serif: "Newsreader", Georgia, "Times New Roman", serif;
  --sans:  "Libre Franklin", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono:  "IBM Plex Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  /* Medidas */
  --container: 1180px;
  --gutter: clamp(1.25rem, 5vw, 3rem);
  --section-y: clamp(3.75rem, 9vw, 7rem);
  --radius: 4px;

  /* Estrella dorada (marca decorativa) como data-URI */
  --star: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 64 64"><path d="M32 12 36.47 24.85 50.07 25.13 39.23 33.35 43.17 46.37 32 38.6 20.83 46.37 24.77 33.35 13.93 25.13 27.53 24.85Z" fill="%23C9A34A"/></svg>');
}

/* ----------------------- Reset base ----------------------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:1.0625rem;
  line-height:1.65;
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3{ margin:0; font-weight:500; letter-spacing:-0.01em; }
p{ margin:0; }
button{ font:inherit; cursor:pointer; }

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation:none !important; transition:none !important; }
}

/* ----------------------- Utilidades ----------------------- */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--gutter);
}
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}
.skip-link{
  position:absolute; left:50%; top:-100%; transform:translateX(-50%);
  background:var(--navy); color:#fff; padding:.6rem 1rem; border-radius:0 0 6px 6px;
  z-index:200; transition:top .2s ease;
}
.skip-link:focus{ top:0; }

:where(a,button,input,select,textarea):focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
  border-radius:2px;
}

.hide-mobile{ display:none; }

/* Placeholder visible para datos pendientes */
.ph{
  font-family:var(--mono);
  font-size:.82em;
  color:var(--gold-deep);
  background:rgba(201,163,74,.10);
  padding:.05em .4em;
  border-radius:3px;
  white-space:nowrap;
}
.section--navy .ph{ color:var(--gold); background:rgba(201,163,74,.14); }

/* Eyebrow (etiqueta superior con estrella) */
.eyebrow{
  display:flex; align-items:center; gap:.6rem;
  font-family:var(--mono);
  font-size:.74rem;
  font-weight:500;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--gray);
  margin:0 0 1.1rem;
}
.eyebrow::before{
  content:""; width:14px; height:14px; flex:none;
  background:var(--star) center/contain no-repeat;
}
.eyebrow--light{ color:var(--on-navy-dim); }

/* ----------------------- Botones ----------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.85rem 1.5rem;
  font-family:var(--sans); font-weight:600; font-size:.95rem; letter-spacing:.01em;
  border-radius:var(--radius);
  border:1px solid transparent;
  transition:background-color .2s ease, color .2s ease, border-color .2s ease, transform .15s ease;
}
.btn:hover{ transform:translateY(-1px); }
.btn--gold{ background:var(--gold); color:var(--navy-deep); }
.btn--gold:hover{ background:#d8b461; }
.btn--navy{ background:var(--navy); color:#fff; }
.btn--navy:hover{ background:var(--navy-deep); }
.btn--ghost-light{ background:transparent; color:var(--on-navy); border-color:rgba(234,240,247,.35); }
.btn--ghost-light:hover{ background:rgba(234,240,247,.08); border-color:var(--on-navy); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.9);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line-cool);
}
.site-header__inner{
  display:flex; align-items:center; justify-content:space-between;
  min-height:72px;
}
.brand{ display:inline-flex; align-items:center; }
.brand__logo{ width:auto; height:46px; }

.nav__toggle{
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; background:transparent; border:1px solid var(--line-cool);
  border-radius:var(--radius);
}
.nav__toggle-bars,
.nav__toggle-bars::before,
.nav__toggle-bars::after{
  content:""; display:block; width:20px; height:2px; background:var(--navy);
  transition:transform .25s ease, opacity .2s ease;
}
.nav__toggle-bars{ position:relative; }
.nav__toggle-bars::before{ position:absolute; top:-6px; left:0; }
.nav__toggle-bars::after{ position:absolute; top:6px; left:0; }
.nav__toggle[aria-expanded="true"] .nav__toggle-bars{ background:transparent; }
.nav__toggle[aria-expanded="true"] .nav__toggle-bars::before{ transform:translateY(6px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] .nav__toggle-bars::after{ transform:translateY(-6px) rotate(-45deg); }

.nav__menu{
  position:absolute; left:0; right:0; top:100%;
  display:grid; gap:.25rem;
  background:var(--white);
  border-bottom:1px solid var(--line-cool);
  box-shadow:0 18px 40px -24px rgba(14,36,64,.4);
  padding:.75rem var(--gutter) 1.25rem;
  max-height:0; overflow:hidden; opacity:0; visibility:hidden;
  transition:max-height .3s ease, opacity .25s ease, visibility .25s;
}
.nav__menu.is-open{ max-height:80vh; opacity:1; visibility:visible; }
.nav__menu a{
  display:block; padding:.75rem .25rem;
  font-weight:500; color:var(--navy);
  border-bottom:1px solid var(--line);
}
.nav__menu a:hover{ color:var(--gold-deep); }
.nav__cta{
  margin-top:.5rem; color:var(--navy) !important;
  border:1px solid var(--navy) !important; border-radius:var(--radius);
  text-align:center; font-weight:600;
}
.nav__cta:hover{ background:var(--navy); color:#fff !important; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(120% 90% at 85% 0%, #1c4576 0%, var(--navy) 45%, var(--navy-deep) 100%);
  color:var(--on-navy);
  padding-block:clamp(4rem,14vw,8rem);
}
.hero__motif{
  position:absolute; top:-6%; right:-22%;
  width:min(560px,90vw); aspect-ratio:1; pointer-events:none;
  opacity:.9;
}
.hero__motif svg{ width:100%; height:100%; }
.hero__inner{ position:relative; max-width:860px; }
.hero__title{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.25rem,7.5vw,4.4rem);
  line-height:1.06;
  letter-spacing:-0.02em;
  color:#fff;
  margin:0 0 1.4rem;
}
.hero__title em{ font-style:italic; color:var(--gold); }
.hero__lead{
  font-size:clamp(1.05rem,2.4vw,1.3rem);
  color:var(--on-navy);
  max-width:48ch;
  margin:0 0 2rem;
}
.hero__actions{ display:flex; flex-wrap:wrap; gap:.85rem; margin-bottom:2.75rem; }
.hero__actions .btn{ flex:1 1 auto; min-width:220px; }
.hero__tagline{
  font-family:var(--serif); font-style:italic;
  font-size:1.05rem; color:var(--on-navy-dim);
  padding-top:1.5rem; border-top:1px solid rgba(201,163,74,.35);
  max-width:30ch;
}

/* ============================================================
   SECCIONES — base
   ============================================================ */
.section{ padding-block:var(--section-y); }
.section--paper{ background:var(--paper); border-block:1px solid var(--line); }
.section--navy{
  background:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 100%);
  color:var(--on-navy);
}
.section__title{
  font-family:var(--serif);
  font-size:clamp(1.7rem,4.2vw,2.55rem);
  line-height:1.14;
  color:var(--navy);
  max-width:20ch;
}
.section__title--light{ color:#fff; }
.section__head{ max-width:680px; margin-bottom:clamp(2.5rem,5vw,3.75rem); }
.section__intro{
  margin-top:1.1rem; font-size:1.075rem; color:var(--gray);
  max-width:54ch;
}
.section--navy .section__intro{ color:var(--on-navy-dim); }

.prose p + p{ margin-top:1.1rem; }
.prose{ color:var(--ink); font-size:1.075rem; }

/* Layout de dos columnas (apilado en móvil) */
.grid-2{ display:grid; gap:2rem; }

/* ============================================================
   MISIÓN
   ============================================================ */
.mision{ max-width:760px; }
.mision__quote{ margin:0 0 1.5rem; }
.mision__quote p{
  font-family:var(--serif);
  font-size:clamp(1.9rem,6vw,3.1rem);
  line-height:1.12; color:#fff; font-weight:500;
}
.mision__body{
  font-size:clamp(1.05rem,2.2vw,1.25rem);
  color:var(--on-navy); max-width:60ch;
}

/* ============================================================
   ÁREAS DE TRABAJO — tarjetas
   ============================================================ */
.cards{ display:grid; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.card{
  background:var(--white);
  padding:clamp(1.5rem,4vw,2.1rem);
  transition:background-color .2s ease;
}
.card:hover{ background:#fcfbf8; }
.card__mark{
  display:block; width:18px; height:18px; margin-bottom:1.1rem;
  background:var(--star) center/contain no-repeat;
}
.card__title{
  font-family:var(--serif); font-size:1.3rem; line-height:1.2;
  color:var(--navy); margin-bottom:.6rem;
}
.card__text{ color:var(--gray); font-size:1rem; }

/* ============================================================
   CASOS / HISTORIAS
   ============================================================ */
.stories{ display:grid; gap:1.25rem; }
.story{
  background:var(--white);
  border:1px solid var(--line);
  border-left:3px solid var(--gold);
  border-radius:var(--radius);
  padding:clamp(1.4rem,4vw,1.9rem);
}
.story__label{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--gold-deep); margin-bottom:.9rem;
}
.story__quote{
  margin:0; font-family:var(--serif); font-style:italic;
  font-size:1.2rem; line-height:1.4; color:var(--ink);
}
.story__meta{ margin-top:1rem; font-size:.9rem; color:var(--gray); }
.note{
  margin-top:2rem; font-size:1rem; color:var(--gray);
}
.note a{ color:var(--navy); font-weight:600; border-bottom:1px solid var(--gold); }
.note a:hover{ color:var(--gold-deep); }

/* ============================================================
   ARCHIVO / INFORMES — índice
   ============================================================ */
.archive{ border-top:1px solid var(--line); }
.archive__row{
  display:grid; gap:.35rem .5rem;
  grid-template-columns:1fr auto;
  grid-template-areas:
    "name   status"
    "date   type";
  padding:1.25rem .25rem;
  border-bottom:1px solid var(--line);
  align-items:baseline;
}
.archive__name{ grid-area:name; font-family:var(--serif); font-size:1.15rem; color:var(--navy); }
.archive__date{ grid-area:date; font-family:var(--mono); font-size:.78rem; color:var(--gray); letter-spacing:.04em; }
.archive__type{ grid-area:type; font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--gold-deep); }
.archive__status{
  grid-area:status; justify-self:end;
  font-size:.78rem; color:var(--gray);
  border:1px solid var(--line); border-radius:100px; padding:.15rem .7rem; white-space:nowrap;
}

/* ============================================================
   CÓMO AYUDAR
   ============================================================ */
.help{ display:grid; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.help__item{ background:var(--paper); padding:clamp(1.4rem,4vw,1.9rem); }
.help__title{
  font-family:var(--serif); font-size:1.2rem; color:var(--navy); margin-bottom:.5rem;
}
.help__item p{ color:var(--gray); font-size:1rem; }
.help__cta{ margin-top:2.25rem; }

/* ============================================================
   CONTACTO
   ============================================================ */
.contact__intro{ margin-top:1.1rem; color:var(--on-navy-dim); max-width:48ch; }
.advisory{
  margin-top:1.75rem;
  background:rgba(201,163,74,.10);
  border:1px solid rgba(201,163,74,.35);
  border-left:3px solid var(--gold);
  border-radius:var(--radius);
  padding:1.1rem 1.25rem;
  color:var(--on-navy);
  font-size:.95rem;
}
.advisory__title{ font-weight:600; color:#fff; margin-bottom:.35rem; }
.contact__channels{ margin-top:1.75rem; display:grid; gap:.85rem; }
.contact__channels li{
  display:grid; gap:.15rem;
  padding-bottom:.85rem; border-bottom:1px solid rgba(234,240,247,.14);
}
.contact__k{ font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; color:var(--on-navy-dim); }
.contact__v{ color:#fff; }

/* Formulario visual: no envía datos */
.form{
  background:var(--white); color:var(--ink);
  border-radius:var(--radius);
  padding:clamp(1.5rem,5vw,2.25rem);
  box-shadow:0 30px 60px -40px rgba(0,0,0,.6);
}
.field{ margin-bottom:1.1rem; }
.field label{
  display:block; font-size:.82rem; font-weight:600; letter-spacing:.02em;
  color:var(--navy); margin-bottom:.4rem;
}
.field input,.field select,.field textarea{
  width:100%; font:inherit; font-size:.98rem; color:var(--ink);
  background:#fff; border:1px solid var(--line-cool); border-radius:var(--radius);
  padding:.7rem .85rem; transition:border-color .2s ease, box-shadow .2s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none; border-color:var(--navy); box-shadow:0 0 0 3px rgba(23,55,94,.12);
}
.field textarea{ resize:vertical; min-height:110px; }
.form__submit{ width:100%; margin-top:.25rem; }
.form__note{
  margin-top:.9rem; font-size:.86rem; color:var(--gray);
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:.7rem .85rem;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--navy-deep); color:var(--on-navy-dim); padding-top:clamp(3rem,7vw,4.5rem); }
.footer__inner{ display:grid; gap:2.5rem; padding-bottom:2.5rem; }
.wordmark{ line-height:1; }
.wordmark__main{
  display:block; font-family:var(--sans); font-weight:700;
  font-size:1.6rem; letter-spacing:.14em; color:#fff;
}
.wordmark__sub{
  display:block; margin-top:.4rem;
  font-family:var(--mono); font-size:.8rem; letter-spacing:.42em;
  text-transform:uppercase; color:var(--gold);
}
.footer__tagline{ margin-top:1rem; font-family:var(--serif); font-style:italic; color:var(--on-navy-dim); }
.footer__nav{ display:grid; gap:2rem; }
.footer__heading{
  font-family:var(--mono); font-size:.72rem; text-transform:uppercase;
  letter-spacing:.12em; color:var(--gold); margin-bottom:.9rem;
}
.footer__col a,.footer__ph{ display:block; padding:.35rem 0; color:var(--on-navy-dim); }
.footer__col a:hover{ color:#fff; }
.footer__bottom{
  display:grid; gap:.5rem;
  padding-block:1.5rem 2.5rem;
  border-top:1px solid rgba(234,240,247,.12);
  font-size:.85rem; color:var(--on-navy-dim);
}
.footer__bottom .ph{ background:rgba(201,163,74,.14); }

/* ============================================================
   ANIMACIÓN DE APARICIÓN (reveal)
   ============================================================ */
.reveal{ opacity:1; transform:none; transition:opacity .25s ease; }
.reveal.is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; }
}

/* ============================================================
   BREAKPOINTS
   ============================================================ */

/* — Pequeño (≥560px) — */
@media (min-width:560px){
  .stories{ gap:1.5rem; }
  .footer__nav{ grid-template-columns:repeat(3,1fr); }
}

/* — Mediano: tablet (≥768px) — */
@media (min-width:768px){
  .hide-mobile{ display:inline; }
  .cards{ grid-template-columns:repeat(2,1fr); }
  .help{ grid-template-columns:repeat(2,1fr); }
  .stories{ grid-template-columns:repeat(3,1fr); }
  .archive__row{
    grid-template-columns:8.5rem 1fr 10rem 9rem;
    grid-template-areas:"date name type status";
    align-items:center;
    padding-block:1.4rem;
  }
  .archive__type{ justify-self:start; }
  .hero__actions .btn{ flex:0 0 auto; }
  .footer__inner{ grid-template-columns:1fr 2fr; gap:3rem; align-items:start; }
}

/* — Grande: desktop (≥980px) — */
@media (min-width:980px){
  .site-header__inner{ min-height:84px; }
  .brand__logo{ height:54px; }

  /* Navegación horizontal */
  .nav__toggle{ display:none; }
  .nav__menu{
    position:static; display:flex; align-items:center; gap:.35rem;
    max-height:none; overflow:visible; opacity:1; visibility:visible;
    background:transparent; border:0; box-shadow:none; padding:0;
  }
  .nav__menu a{
    border:0; padding:.5rem .9rem; font-size:.95rem; color:var(--navy);
  }
  .nav__menu a:hover{ color:var(--gold-deep); }
  .nav__cta{ margin-top:0; margin-left:.5rem; padding:.55rem 1.1rem !important; }

  .grid-2{ grid-template-columns:5fr 6fr; gap:clamp(3rem,6vw,5.5rem); align-items:start; }
  .grid-2--contact{ grid-template-columns:1fr 1fr; align-items:start; }
  .cards{ grid-template-columns:repeat(3,1fr); }
}

/* — Extra grande (≥1200px) — */
@media (min-width:1200px){
  .help{ grid-template-columns:repeat(4,1fr); }
}
