/* =========================================================
   Luz para Venezuela — Sistema de diseño "Cielo de Venezuela"
   Paleta tomada del cielo real del 24/06. Cálido, suave, humano.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500&family=Nunito+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root {
  /* Base cálida */
  --cream:    #FBF3E8;
  --cream-2:  #F4E8D6;
  --paper:    #FFFBF3;
  --ink:      #2C2433;
  --ink-soft: #5E5564;
  --ink-faint:#8C8390;

  /* Luz dorada (sol del horizonte) */
  --luz:      #E89A2E;
  --luz-deep: #BE7016;
  --luz-soft: #FBE6C2;

  /* Azul del cielo (reemplaza el teal genérico) */
  --calma:      #3C5E8E;
  --calma-deep: #243F6B;
  --calma-soft: #DCE6F3;

  --coral:  #DE6E48;
  --peach:  #EBA983;
  --rose:   #C95F6E;
  --night:  #141C30;

  --line:    #EADDC9;
  --shadow:    22px 34px 60px -30px rgba(80, 50, 20, .40);
  --shadow-sm: 10px 18px 34px -20px rgba(80, 50, 20, .34);

  --r-xl: 36px;
  --r-lg: 28px;
  --r-md: 22px;
  --r-sm: 16px;

  --maxw: 1080px;
  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Nunito Sans', -apple-system, 'Segoe UI', system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-body);
  font-size: 1.125rem;
  line-height: 1.72;
  color: var(--ink);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* grano cálido sutil */
body::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 1; opacity: .04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 500; line-height: 1.14; letter-spacing: -.012em; color: var(--ink); }
h1 { font-size: clamp(2.4rem, 6vw, 4.1rem); }
h2 { font-size: clamp(1.85rem, 4vw, 2.7rem); }
h3 { font-size: clamp(1.25rem, 2.4vw, 1.6rem); font-weight: 600; }
p { color: var(--ink-soft); }
a { color: var(--calma-deep); }

.wrap { width: min(var(--maxw), 92vw); margin-inline: auto; position: relative; z-index: 2; }
.narrow { width: min(720px, 92vw); margin-inline: auto; }
section { padding: clamp(3.2rem, 7vw, 5.8rem) 0; position: relative; z-index: 2; }

/* ---------- Eyebrow: más humana, separada, sin la rayita pegada ---------- */
.eyebrow {
  display: inline-block;
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: 1.08rem; letter-spacing: 0; text-transform: none;
  color: var(--luz-deep);
  margin-bottom: 1rem;
}
.eyebrow::after { content: ""; display: block; width: 38px; height: 2px; border-radius: 2px;
  background: linear-gradient(90deg, var(--luz), transparent); margin-top: .5rem; }

.lead { font-size: clamp(1.14rem, 2.1vw, 1.38rem); color: var(--ink-soft); line-height: 1.66; }

/* ---------- Botones (cápsulas suaves) ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .6rem;
  font-family: var(--font-body); font-weight: 700; font-size: 1.05rem;
  padding: .95rem 1.7rem; border-radius: 999px;
  border: 1.5px solid transparent; cursor: pointer; text-decoration: none;
  min-height: 54px; transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s;
}
.btn:focus-visible { outline: 3px solid var(--calma); outline-offset: 3px; }
.btn-primary { background: linear-gradient(135deg, var(--luz), var(--coral)); color: #fff; box-shadow: 0 14px 28px -12px rgba(222,110,72,.6); }
.btn-primary:hover { transform: translateY(-2px); filter: brightness(1.05); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--luz); color: var(--luz-deep); transform: translateY(-2px); }
.btn-ghost-light { background: rgba(255,255,255,.10); color: #FBF4E6; border-color: rgba(255,255,255,.4); backdrop-filter: blur(4px); }
.btn-ghost-light:hover { background: rgba(255,255,255,.2); border-color:#FBC56B; color:#fff; transform: translateY(-2px); }
.btn-calma { background: var(--calma); color: #fff; }
.btn-calma:hover { background: var(--calma-deep); transform: translateY(-2px); }
.btn-soft { background: var(--paper); color: var(--ink); border-color: var(--line); box-shadow: var(--shadow-sm); }
.btn-soft:hover { transform: translateY(-2px); border-color: var(--luz); }
.btn-block { width: 100%; justify-content: center; }

/* ---------- Tarjetas: cálidas, redondeadas, sin frío de "examen" ---------- */
.card {
  background: linear-gradient(165deg, #FFFCF6 0%, #FBF1E0 100%);
  border-radius: var(--r-lg);
  padding: clamp(1.5rem, 3vw, 2.1rem);
  box-shadow: var(--shadow-sm);
  border: 1px solid rgba(190,112,22,.10);
}
.grid { display: grid; gap: 1.2rem; }
.grid-2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid-3 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }

/* ---------- Divisor orgánico (la montaña que sube y baja) ---------- */
.wave { display:block; width:100%; height:auto; position:relative; z-index:2; margin-bottom:-1px; }
.wave + section, .wave + footer { padding-top: clamp(1rem,3vw,2rem); }

/* ---------- Nav ---------- */
.nav { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(10px);
  background: color-mix(in srgb, var(--cream) 84%, transparent); border-bottom: 1px solid var(--line); }
.nav .wrap { display: flex; align-items: center; justify-content: space-between; padding: .8rem 0; }
.brand { display: flex; align-items: center; gap: .6rem; text-decoration: none; color: var(--ink); font-family: var(--font-display); font-weight: 600; font-size: 1.25rem; }
.brand .sun { width: 30px; height: 30px; flex: none; }
.brand .map-ve { height: 26px; width: auto; flex: none; display: block; }
.nav-links { display: flex; gap: 1.4rem; align-items: center; }
.nav-links a { text-decoration: none; color: var(--ink-soft); font-weight: 600; font-size: .98rem; padding: .3rem 0; border-bottom: 2px solid transparent; }
.nav-links a:hover { color: var(--ink); border-color: var(--luz); }
.nav-links a.cta { color: var(--luz-deep); }
@media (max-width: 720px){ .nav-links a.hide-sm { display: none; } }

/* ---------- Cinta superior ---------- */
.ribbon { background: var(--calma-soft); color: var(--calma-deep); font-size: .92rem; font-weight: 600; text-align: center; padding: .7rem 1rem; line-height: 1.45; }
.ribbon a { color: var(--calma-deep); font-weight: 800; }

/* ---------- Footer ---------- */
.footer { background: var(--night); color: #E9E2D6; padding: 3.4rem 0 2.4rem; position: relative; z-index: 2; }
.footer h4 { color: #fff; margin-bottom: .6rem; }
.footer p, .footer li, .footer a { color: #CBC4B8; font-size: .95rem; }
.footer a { color: #F2D9A8; }
.footer .cols { display: grid; gap: 2rem; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); }
.footer ul { list-style: none; }
.footer .fine { margin-top: 2rem; padding-top: 1.3rem; border-top: 1px solid rgba(255,255,255,.12); font-size: .85rem; color: #A49C8E; }

/* ---------- Utilidades ---------- */
.center { text-align: center; }
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.6rem}.mt-4{margin-top:2.4rem}
.tag { display:inline-block; font-size:.78rem; font-weight:800; letter-spacing:.03em; padding:.32rem .8rem; border-radius:999px; background:var(--luz-soft); color:var(--luz-deep); }
.note { font-size:.92rem; color:var(--ink-faint); }
.soft-list { list-style:none; display:grid; gap:.7rem; }
.soft-list li { position:relative; padding-left:1.9rem; color:var(--ink-soft); line-height:1.55; }
.soft-list li::before { content:""; position:absolute; left:.2rem; top:.62em; width:.62rem; height:.62rem; border-radius:50%;
  background: radial-gradient(circle at 35% 35%, var(--luz), var(--coral)); box-shadow:0 0 0 4px rgba(232,154,46,.12); }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
}
