/* ============================================================
   tenergetico.css — Titikaka Energético 2025 · DREM Puno
   Paleta: #30B1D8 sky · #01D2B3 teal · #FB9B08 amber · #14365C navy
   Breakpoints: xs<480 · sm<640 · md<768 · lg<1024 · xl≥1280
   ============================================================ */

/* ─── VARIABLES ──────────────────────────────────────────── */
:root {
  --navy:      #14365C;
  --navy-d:    #0c2240;
  --navy-mid:  #0d3050;
  --sky:       #30B1D8;
  --sky-d:     #209ec5;
  --teal:      #01D2B3;
  --amber:     #FB9B08;
  --amber-d:   #e88900;
  --white:     #ffffff;
  --off:       #f0f7fc;
  --text:      #1a2e42;
  --muted:     #5a7a94;
  --border:    #cce3f0;
  --error:     #dc2626;
  --success:   #0a9b6e;
  --shadow:    0 8px 32px rgba(20,54,92,.14);
  --shadow-sm: 0 2px 12px rgba(20,54,92,.08);
  --shadow-lg: 0 16px 48px rgba(20,54,92,.2);
  --radius:    12px;
  --radius-lg: 18px;

  /* Fluid spacing */
  --sp-xs:  clamp(8px,  1.5vw,  12px);
  --sp-sm:  clamp(12px, 2vw,    16px);
  --sp-md:  clamp(16px, 3vw,    24px);
  --sp-lg:  clamp(24px, 4vw,    40px);
  --sp-xl:  clamp(32px, 5vw,    64px);

  /* Container */
  --container: 1280px;
  --gutter:    clamp(16px, 4vw, 32px);
}

/* ─── RESET ──────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:'Source Sans 3',sans-serif;
  color:var(--text);
  background:var(--white);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img  { max-width:100%; height:auto; display:block; }
a    { color:inherit; text-decoration:none; }
button { font-family:inherit; }

/* ─── SKIP LINK ───────────────────────────────────────────── */
.skip-link {
  position:absolute; top:-40px; left:0;
  background:var(--navy); color:#fff; padding:8px 16px;
  border-radius:0 0 8px 0; transition:top .2s; z-index:9999;
}
.skip-link:focus { top:0; }

/* ─── HEADER ─────────────────────────────────────────────── */
.tene-header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:var(--navy);
  border-bottom:3px solid var(--teal);
  transition:box-shadow .3s;
}
.tene-header.scrolled { box-shadow:0 4px 24px rgba(20,54,92,.35); }
.tene-header-inner {
  max-width:var(--container); margin:0 auto; padding:0 var(--gutter);
  height:72px; display:flex; align-items:center; justify-content:space-between; gap:16px;
}

/* Logo DREM */
.tene-logo-drem { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.tene-logo-drem .logo-img { width:44px; height:44px; object-fit:contain; }
.drem-txt { display:flex; flex-direction:column; line-height:1.15; }
.drem-title { font-family:'Barlow Condensed',sans-serif; font-size:17px; font-weight:800; color:#fff; text-transform:uppercase; letter-spacing:.04em; }
.drem-sub   { font-size:10px; color:var(--teal); text-transform:uppercase; letter-spacing:.07em; font-weight:600; }

/* Nav */
.tene-nav { display:flex; align-items:center; gap:4px; }
.nav-link {
  font-family:'Barlow Condensed',sans-serif; font-size:15px; font-weight:600;
  letter-spacing:.05em; text-transform:uppercase; color:rgba(255,255,255,.78);
  padding:6px 16px; border-radius:6px; transition:all .22s; white-space:nowrap;
}
.nav-link:hover, .nav-link.active { color:#fff; background:rgba(48,177,216,.2); }
.nav-link.nav-cta {
  background:var(--amber); color:var(--navy); font-weight:700; padding:7px 20px;
}
.nav-link.nav-cta:hover { background:var(--amber-d); transform:translateY(-1px); }

/* Logo evento */
.tene-logo-evt { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.evt-txt { display:flex; flex-direction:column; line-height:1.2; text-align:right; }
.evt-name { font-family:'Barlow Condensed',sans-serif; font-size:15px; font-weight:800; color:var(--amber); text-transform:uppercase; letter-spacing:.05em; }
.evt-sub  { font-size:10px; color:var(--sky); text-transform:uppercase; letter-spacing:.08em; font-weight:600; }
.evt-icon-wrap {
  width:40px; height:40px; border-radius:8px;
  background:rgba(251,155,8,.15); border:1px solid rgba(251,155,8,.3);
  display:flex; align-items:center; justify-content:center;
  color:var(--amber); font-size:18px; flex-shrink:0;
}

/* Hamburguesa */
.tene-hamburger {
  display:none; flex-direction:column; gap:5px;
  background:transparent; border:none; cursor:pointer; padding:8px;
  border-radius:6px; transition:background .2s;
}
.tene-hamburger:hover { background:rgba(255,255,255,.08); }
.tene-hamburger span {
  display:block; width:22px; height:2px; background:#fff;
  border-radius:2px; transition:all .25s ease;
}
.tene-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.tene-hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.tene-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ─── HERO ───────────────────────────────────────────────── */
.tene-hero {
  position:relative; min-height:100vh; padding-top:72px;
  display:flex; align-items:center; overflow:hidden;
}
.hero-bg-overlay {
  position:absolute; inset:0;
  background: linear-gradient(160deg,
    rgba(12,34,64,.82) 0%,
    rgba(20,54,92,.72) 60%,
    rgba(13,48,80,.80) 100%);
}
.geo { position:absolute; border-radius:50%; pointer-events:none; }
.geo-1 { width:clamp(180px,28vw,360px); height:clamp(180px,28vw,360px); border:1.5px solid rgba(48,177,216,.15); top:-60px; right:8%; }
.geo-2 { width:clamp(100px,14vw,180px); height:clamp(100px,14vw,180px); border:1.5px solid rgba(1,210,179,.12); bottom:16%; left:3%; }

.hero-grid {
  position:relative; z-index:2; display:grid;
  grid-template-columns:1fr 400px; gap:clamp(32px,5vw,64px);
  align-items:center; padding:clamp(48px,8vh,96px) var(--gutter);
  max-width:var(--container); margin:0 auto; width:100%;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(1,210,179,.12); border:1px solid rgba(1,210,179,.35);
  border-radius:100px; padding:6px 16px 6px 10px; margin-bottom:22px;
}
.badge-dot {
  width:8px; height:8px; border-radius:50%; background:var(--teal);
  animation: badgepulse 2.4s ease-in-out infinite;
}
@keyframes badgepulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.45; transform:scale(1.55); }
}
.hero-badge span:last-child {
  font-size:12px; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:var(--teal);
}

.hero-title {
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(48px,8vw,92px);
  font-weight:800; line-height:.92; color:#fff;
  text-transform:uppercase; letter-spacing:-.01em; margin-bottom:18px;
}
.hero-title em { color:var(--sky); font-style:normal; }
.hero-desc {
  font-size:clamp(15px,1.6vw,17px); color:rgba(255,255,255,.65);
  line-height:1.68; max-width:520px; margin-bottom:36px; font-weight:300;
}
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; }

/* Hero card */
.hero-card {
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border-radius:var(--radius-lg); padding:clamp(22px,3vw,36px);
  display:flex; flex-direction:column; gap:18px;
}
.hcard-label { font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--teal); }
.hcard-item {
  display:flex; align-items:flex-start; gap:12px;
  padding-bottom:14px; border-bottom:1px solid rgba(255,255,255,.07);
}
.hcard-item:last-child { border-bottom:none; padding-bottom:0; }
.hcard-icon {
  width:38px; height:38px; border-radius:9px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; font-size:16px;
}
.hcard-icon.sky   { background:rgba(48,177,216,.2);  color:var(--sky); }
.hcard-icon.teal  { background:rgba(1,210,179,.2);   color:var(--teal); }
.hcard-icon.amber { background:rgba(251,155,8,.2);   color:var(--amber); }
.hcard-key  { font-size:11px; font-weight:600; letter-spacing:.07em; text-transform:uppercase; color:rgba(255,255,255,.45); margin-bottom:2px; }
.hcard-val  { font-family:'Barlow Condensed',sans-serif; font-size:16px; font-weight:700; color:#fff; line-height:1.25; }
.hcard-val small { display:block; font-size:12px; opacity:.6; font-family:'Source Sans 3',sans-serif; font-weight:400; }

.hero-wave { position:absolute; bottom:-2px; left:0; right:0; pointer-events:none; width:100%; }

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn-primary {
  background:var(--amber); color:var(--navy);
  font-family:'Barlow Condensed',sans-serif; font-size:16px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase; padding:13px 32px;
  border-radius:8px; border:none; cursor:pointer;
  display:inline-flex; align-items:center; gap:8px;
  transition:all .22s; box-shadow:0 4px 18px rgba(251,155,8,.3);
  text-decoration:none; white-space:nowrap;
}
.btn-primary:hover { background:var(--amber-d); transform:translateY(-2px); box-shadow:0 8px 26px rgba(251,155,8,.42); }
.btn-primary.big   { font-size:18px; padding:16px 40px; }
.btn-outline {
  background:transparent; color:#fff;
  font-family:'Barlow Condensed',sans-serif; font-size:16px; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase; padding:12px 28px;
  border-radius:8px; border:2px solid rgba(255,255,255,.3);
  display:inline-flex; align-items:center; gap:8px;
  transition:all .22s; text-decoration:none; white-space:nowrap;
}
.btn-outline:hover { border-color:var(--sky); color:var(--sky); transform:translateY(-2px); }
.btn-outline-light {
  background:transparent; color:rgba(255,255,255,.8);
  font-family:'Barlow Condensed',sans-serif; font-size:16px; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase; padding:12px 28px;
  border-radius:8px; border:2px solid rgba(255,255,255,.25);
  display:inline-flex; align-items:center; gap:8px;
  transition:all .22s; text-decoration:none;
}
.btn-outline-light:hover { border-color:var(--sky); color:var(--sky); }
.btn-download {
  display:flex; align-items:center; justify-content:center; gap:8px;
  width:100%; margin-top:20px; padding:13px;
  background:var(--amber); color:var(--navy); border-radius:8px;
  font-family:'Barlow Condensed',sans-serif; font-size:14px; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase; transition:all .22s;
}
.btn-download:hover { background:var(--amber-d); transform:translateY(-2px); }

/* ─── SECTIONS ───────────────────────────────────────────── */
.tene-section { padding:clamp(56px,9vh,96px) 0; }
.bg-off   { background:var(--off); }
.bg-white { background:var(--white); }
.bg-dark  {
  background:linear-gradient(160deg, var(--navy-d) 0%, var(--navy) 100%);
  position:relative; overflow:hidden;
}
.tene-container { max-width:var(--container); margin:0 auto; padding:0 var(--gutter); }

.section-head { margin-bottom:clamp(32px,5vh,56px); }
.section-tag  { display:inline-block; font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--sky); margin-bottom:10px; }
.section-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(30px,4.5vw,54px); font-weight:800;
  color:var(--navy); text-transform:uppercase; line-height:1; margin-bottom:16px;
}
.section-title.white { color:#fff; }
.section-desc { font-size:clamp(14px,1.5vw,16px); color:var(--muted); line-height:1.72; max-width:640px; }
.section-desc.light { color:rgba(255,255,255,.62); }
.divider { width:52px; height:4px; background:linear-gradient(90deg,var(--sky),var(--teal)); border-radius:4px; margin:14px 0 24px; }
.divider.amber { background:linear-gradient(90deg,var(--amber),#ffd56b); }

/* ─── MISIÓN Y VISIÓN ────────────────────────────────────── */
.mv-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; margin-bottom:40px; }
.mv-card {
  background:var(--white); border-radius:var(--radius); padding:clamp(24px,3.5vw,40px);
  box-shadow:var(--shadow-sm); position:relative; overflow:hidden;
  transition:transform .3s, box-shadow .3s;
}
.mv-card:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
.mv-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; }
.mv-card.mision::before { background:linear-gradient(90deg,var(--sky),var(--teal)); }
.mv-card.vision::before  { background:linear-gradient(90deg,var(--amber),#ffd56b); }
.mv-icon {
  width:56px; height:56px; border-radius:12px;
  display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:18px;
}
.mv-card.mision .mv-icon { background:linear-gradient(135deg,rgba(48,177,216,.15),rgba(1,210,179,.15)); color:var(--sky); }
.mv-card.vision  .mv-icon { background:linear-gradient(135deg,rgba(251,155,8,.12),rgba(255,213,107,.12)); color:var(--amber); }
.mv-card h3 { font-family:'Barlow Condensed',sans-serif; font-size:clamp(20px,2.5vw,26px); font-weight:700; color:var(--navy); text-transform:uppercase; margin-bottom:12px; }
.mv-card p  { font-size:clamp(13px,1.4vw,15px); color:#4a6378; line-height:1.78; }

.objetivos-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.obj-card { text-align:center; padding:clamp(20px,3vw,32px) clamp(14px,2vw,24px); border-radius:var(--radius); background:var(--white); box-shadow:var(--shadow-sm); transition:transform .3s; }
.obj-card:hover { transform:translateY(-3px); }
.obj-num {
  font-family:'Barlow Condensed',sans-serif; font-size:clamp(36px,5vw,48px);
  font-weight:800; line-height:1; margin-bottom:6px;
  background:linear-gradient(135deg,var(--sky),var(--teal));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.obj-card h4 { font-family:'Barlow Condensed',sans-serif; font-size:clamp(14px,1.8vw,18px); font-weight:700; text-transform:uppercase; color:var(--navy); margin-bottom:8px; }
.obj-card p  { font-size:clamp(12px,1.3vw,14px); color:var(--muted); line-height:1.6; }

/* ─── REGLAMENTO ─────────────────────────────────────────── */
.regl-layout { display:grid; grid-template-columns:1fr 360px; gap:60px; align-items:start; }
.regl-item   { display:flex; gap:18px; padding:22px 0; border-bottom:1px solid #e8f4fa; }
.regl-item:last-child { border-bottom:none; }
.regl-num  { font-family:'Barlow Condensed',sans-serif; font-size:clamp(30px,4vw,40px); font-weight:800; color:rgba(48,177,216,.18); line-height:1; flex-shrink:0; width:48px; text-align:center; }
.regl-body h4 { font-family:'Barlow Condensed',sans-serif; font-size:clamp(16px,2vw,20px); font-weight:700; color:var(--navy); text-transform:uppercase; margin-bottom:5px; }
.regl-body p  { font-size:clamp(12px,1.4vw,14px); color:var(--muted); line-height:1.7; }
.regl-card { background:var(--navy); border-radius:var(--radius-lg); padding:clamp(20px,3vw,36px); color:#fff; position:sticky; top:90px; }
.regl-card h3 { font-family:'Barlow Condensed',sans-serif; font-size:20px; font-weight:700; text-transform:uppercase; color:var(--amber); margin-bottom:18px; }
.regl-dl dt { font-size:10px; font-weight:700; letter-spacing:.09em; text-transform:uppercase; color:var(--teal); }
.regl-dl dd { font-size:14px; color:rgba(255,255,255,.8); line-height:1.5; margin:3px 0 12px; padding-bottom:12px; border-bottom:1px solid rgba(255,255,255,.08); }
.regl-dl dd:last-child { border-bottom:none; }

/* ─── INSCRIPCIÓN ────────────────────────────────────────── */
.inscr-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,6vw,72px); align-items:center; position:relative; z-index:1; }
.inscr-steps { list-style:none; margin:24px 0 32px; display:flex; flex-direction:column; gap:12px; counter-reset:step; }
.inscr-steps li {
  display:flex; align-items:center; gap:14px;
  font-size:clamp(13px,1.5vw,15px); color:rgba(255,255,255,.75); line-height:1.4;
  counter-increment:step;
}
.inscr-steps li::before {
  content:counter(step); flex-shrink:0; width:32px; height:32px; border-radius:50%;
  border:2px solid var(--sky); background:rgba(48,177,216,.15);
  display:flex; align-items:center; justify-content:center;
  font-family:'Barlow Condensed',sans-serif; font-size:15px; font-weight:700; color:var(--sky);
}
.inscr-actions { display:flex; gap:12px; flex-wrap:wrap; }
.inscr-right {
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-radius:var(--radius-lg); padding:clamp(20px,3vw,40px);
}
.inscr-right h3 { font-family:'Barlow Condensed',sans-serif; font-size:20px; font-weight:700; text-transform:uppercase; color:var(--teal); margin-bottom:18px; }
.cat-row { display:flex; justify-content:space-between; align-items:center; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.07); }
.cat-row:last-of-type { border-bottom:none; }
.cat-label { display:flex; align-items:center; gap:8px; font-size:14px; color:rgba(255,255,255,.8); }
.cat-dot { width:8px; height:8px; border-radius:50%; }
.cat-dot.sky   { background:var(--sky); }
.cat-dot.teal  { background:var(--teal); }
.cat-dot.amber { background:var(--amber); }
.cat-badge { font-family:'Barlow Condensed',sans-serif; font-size:13px; font-weight:700; padding:4px 12px; border-radius:20px; }
.cat-badge.free  { background:rgba(1,210,179,.2);  color:var(--teal); }
.cat-badge.acred { background:rgba(48,177,216,.2); color:var(--sky); }
.inscr-note { margin-top:20px; padding-top:16px; border-top:1px solid rgba(255,255,255,.08); font-size:13px; color:rgba(255,255,255,.45); }
.inscr-note a { color:var(--sky); }

/* ─── FOOTER ─────────────────────────────────────────────── */
.tene-footer { background:var(--navy-d); border-top:1px solid rgba(255,255,255,.07); padding:clamp(20px,4vh,36px) 0; }
.footer-inner { display:flex; flex-direction:column; gap:16px; }
.footer-brand { display:flex; align-items:flex-start; gap:16px; color:rgba(255,255,255,.7); font-size:13px; line-height:1.6; }
.footer-brand strong { color:#fff; font-size:14px; }
.footer-links { display:flex; gap:20px; flex-wrap:wrap; }
.footer-links a { font-size:13px; color:rgba(255,255,255,.5); transition:color .2s; }
.footer-links a:hover { color:var(--sky); }
.footer-legal { font-size:12px; color:rgba(255,255,255,.3); }
.footer-legal a { color:var(--sky); }

/* ─── REGISTRO / CONSULTAR (sub-páginas) ─────────────────── */
.reg-header {
  background:rgba(12,34,64,.95); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:2px solid rgba(1,210,179,.3); padding:0 var(--gutter);
  height:64px; display:flex; align-items:center; justify-content:space-between;
  position:sticky; top:0; z-index:100;
}
.reg-logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.reg-logo img { width:36px; height:36px; object-fit:contain; }
.reg-logo .rl-txt { display:flex; flex-direction:column; line-height:1.2; }
.reg-logo .rl-title { font-family:'Barlow Condensed',sans-serif; font-size:15px; font-weight:800; color:#fff; text-transform:uppercase; }
.reg-logo .rl-sub   { font-size:10px; color:var(--teal); text-transform:uppercase; letter-spacing:.07em; font-weight:600; }
.reg-back { font-family:'Barlow Condensed',sans-serif; font-size:13px; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:rgba(255,255,255,.55); display:flex; align-items:center; gap:6px; transition:color .2s; }
.reg-back:hover { color:var(--sky); }

/* Layout registro — dos columnas */
.reg-body {
  min-height:calc(100vh - 64px);
  background:linear-gradient(160deg, var(--navy-d) 0%, var(--navy) 60%, #0d3458 100%);
  display:grid; grid-template-columns:1fr 440px;
}

/* Panel formulario */
.form-panel { padding:clamp(28px,5vw,56px) clamp(20px,5.5vw,56px); overflow-y:auto; }
.form-head { margin-bottom:32px; }
.form-head .ftag { display:inline-block; font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--teal); margin-bottom:10px; }
.form-head h1 { font-family:'Barlow Condensed',sans-serif; font-size:clamp(30px,5vw,44px); font-weight:800; color:#fff; text-transform:uppercase; line-height:.95; margin-bottom:10px; }
.form-head h1 span { color:var(--amber); }
.form-head p { font-size:clamp(13px,1.5vw,15px); color:rgba(255,255,255,.6); line-height:1.6; }

/* Progress */
.progress-bar { display:flex; gap:6px; margin-bottom:28px; align-items:center; }
.step-circ { width:28px; height:28px; border-radius:50%; border:2px solid rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; font-family:'Barlow Condensed',sans-serif; font-size:13px; font-weight:700; color:rgba(255,255,255,.35); transition:all .3s; flex-shrink:0; }
.step-circ.active { border-color:var(--sky); background:rgba(48,177,216,.2); color:var(--sky); }
.step-circ.done   { border-color:var(--teal); background:var(--teal); color:var(--navy); }
.step-lbl { font-size:11px; font-weight:600; letter-spacing:.07em; text-transform:uppercase; color:rgba(255,255,255,.3); }
.step-lbl.active  { color:var(--sky); }
.step-div { flex:1; height:1px; background:rgba(255,255,255,.1); }

/* Form card */
.form-card { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:14px; padding:clamp(20px,3vw,32px); display:none; }
.form-card.active { display:block; }
.form-sec-title { font-family:'Barlow Condensed',sans-serif; font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--teal); margin-bottom:20px; padding-bottom:10px; border-bottom:1px solid rgba(1,210,179,.2); }

/* Inputs */
.fg { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.fg label { font-size:11px; font-weight:600; letter-spacing:.07em; text-transform:uppercase; color:rgba(255,255,255,.55); }
.fg label .req { color:var(--amber); margin-left:2px; }
.fg input, .fg select, .fg textarea {
  background:rgba(255,255,255,.08); border:1.5px solid rgba(255,255,255,.13);
  border-radius:8px; padding:11px 14px; font-size:15px;
  font-family:'Source Sans 3',sans-serif; color:#fff;
  transition:all .22s; -webkit-appearance:none; appearance:none;
}
.fg input::placeholder, .fg textarea::placeholder { color:rgba(255,255,255,.25); }
.fg input:focus, .fg select:focus, .fg textarea:focus {
  outline:none; border-color:var(--sky); background:rgba(48,177,216,.1);
  box-shadow:0 0 0 3px rgba(48,177,216,.12);
}
.fg input.is-error { border-color:var(--error); }
.fg select option { background:var(--navy); color:#fff; }
.fg textarea { resize:vertical; min-height:72px; }
.fg-row { display:grid; gap:14px; }
.fg-row.c2 { grid-template-columns:1fr 1fr; }
.fg-row.c3 { grid-template-columns:1fr 1fr 1fr; }

/* Tipo tabs */
.tipo-tabs { display:flex; gap:10px; margin-bottom:20px; }
.tipo-tab {
  flex:1; padding:clamp(10px,2vw,14px); border-radius:10px;
  border:2px solid rgba(255,255,255,.13); background:transparent;
  cursor:pointer; text-align:center; transition:all .22s; color:rgba(255,255,255,.55);
}
.tipo-tab .tab-icon { font-size:clamp(16px,2.5vw,22px); margin-bottom:4px; }
.tipo-tab .tab-lbl { font-family:'Barlow Condensed',sans-serif; font-size:clamp(11px,1.5vw,13px); font-weight:700; letter-spacing:.05em; text-transform:uppercase; display:block; }
.tipo-tab.sel { border-color:var(--sky); background:rgba(48,177,216,.14); color:#fff; }

/* Alerts */
.alert { border-radius:8px; padding:12px 16px; font-size:13px; display:none; margin-bottom:14px; align-items:flex-start; gap:8px; line-height:1.5; }
.alert.show { display:flex; }
.alert.err  { background:rgba(220,38,38,.14);  border:1px solid rgba(220,38,38,.35);  color:#fca5a5; }
.alert.ok   { background:rgba(10,155,110,.14); border:1px solid rgba(10,155,110,.35); color:#6ee7b7; }
.alert.info { background:rgba(48,177,216,.12); border:1px solid rgba(48,177,216,.28); color:var(--sky); }
.alert.warn { background:rgba(251,155,8,.12);  border:1px solid rgba(251,155,8,.28);  color:var(--amber); }

/* Botones form */
.form-nav { display:flex; gap:10px; margin-top:24px; justify-content:flex-end; flex-wrap:wrap; }
.btn-back {
  background:transparent; border:1.5px solid rgba(255,255,255,.2); color:rgba(255,255,255,.65);
  padding:11px 26px; border-radius:8px; font-family:'Barlow Condensed',sans-serif;
  font-size:15px; font-weight:600; letter-spacing:.05em; text-transform:uppercase;
  cursor:pointer; transition:all .22s;
}
.btn-back:hover { border-color:var(--sky); color:var(--sky); }
.btn-next {
  background:var(--sky); border:none; color:var(--navy); padding:11px 32px;
  border-radius:8px; font-family:'Barlow Condensed',sans-serif;
  font-size:15px; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  cursor:pointer; display:flex; align-items:center; gap:7px; transition:all .22s;
}
.btn-next:hover { background:var(--sky-d); transform:translateY(-1px); }
.btn-submit {
  background:var(--amber); border:none; color:var(--navy); padding:13px 36px;
  border-radius:8px; font-family:'Barlow Condensed',sans-serif;
  font-size:16px; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  cursor:pointer; display:flex; align-items:center; gap:9px; transition:all .22s;
  box-shadow:0 4px 18px rgba(251,155,8,.28);
}
.btn-submit:hover:not(:disabled) { background:var(--amber-d); transform:translateY(-2px); }
.btn-submit:disabled { opacity:.5; cursor:not-allowed; }

/* Resumen */
.resumen-row { display:flex; justify-content:space-between; gap:12px; padding:9px 0; border-bottom:1px solid rgba(255,255,255,.06); font-size:14px; }
.resumen-key { font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:rgba(255,255,255,.4); white-space:nowrap; }
.resumen-val { color:rgba(255,255,255,.82); text-align:right; }
.recaptcha-wrap { display:flex; justify-content:center; margin:18px 0; }

/* Éxito */
.success-screen { text-align:center; padding:clamp(24px,4vw,40px) 16px; display:none; }
.success-screen.show { display:block; }
.success-icon { width:72px; height:72px; border-radius:50%; background:rgba(10,155,110,.18); border:2px solid var(--teal); display:flex; align-items:center; justify-content:center; font-size:30px; margin:0 auto 20px; color:var(--teal); }
.success-screen h2 { font-family:'Barlow Condensed',sans-serif; font-size:clamp(24px,4vw,32px); font-weight:800; color:#fff; text-transform:uppercase; margin-bottom:10px; }
.success-screen p { color:rgba(255,255,255,.62); line-height:1.65; font-size:15px; margin-bottom:6px; }
.code-box { font-family:monospace; font-size:clamp(16px,2.5vw,22px); color:var(--amber); background:rgba(251,155,8,.1); border:1px solid rgba(251,155,8,.3); border-radius:8px; padding:13px 24px; margin:18px auto; display:inline-block; letter-spacing:.1em; word-break:break-all; }
.success-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:24px; }

/* Panel branding – derecha */
.brand-panel {
  background:rgba(0,0,0,.22); border-left:1px solid rgba(255,255,255,.07);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:clamp(32px,4vw,56px) clamp(20px,3vw,40px); text-align:center;
  position:relative; overflow:hidden;
}
.brand-panel::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg,var(--sky),var(--teal),var(--amber)); }
.brand-divider { width:1px; height:48px; background:linear-gradient(180deg,transparent,rgba(255,255,255,.2),transparent); margin:28px auto; }
.big-drem { display:flex; flex-direction:column; align-items:center; gap:12px; }
.big-drem img { width:clamp(64px,8vw,88px); height:clamp(64px,8vw,88px); object-fit:contain; }
.big-drem .bd-name { font-family:'Barlow Condensed',sans-serif; font-size:clamp(20px,2.5vw,28px); font-weight:800; text-transform:uppercase; color:#fff; letter-spacing:.04em; }
.big-drem .bd-full { font-size:13px; color:rgba(255,255,255,.5); line-height:1.5; max-width:200px; }
.big-drem .bd-gov  { font-size:10px; color:var(--teal); text-transform:uppercase; letter-spacing:.09em; font-weight:700; }
.big-evt { display:flex; flex-direction:column; align-items:center; gap:12px; }
.evt-logo-circle { width:88px; height:88px; border-radius:50%; border:2px solid rgba(251,155,8,.3); background:rgba(251,155,8,.08); display:flex; align-items:center; justify-content:center; font-size:36px; color:var(--amber); }
.big-evt .be-name { font-family:'Barlow Condensed',sans-serif; font-size:clamp(20px,2.5vw,26px); font-weight:800; text-transform:uppercase; color:var(--amber); line-height:1.1; }
.big-evt .be-sub  { font-size:11px; color:rgba(255,255,255,.45); text-transform:uppercase; letter-spacing:.08em; }
.info-chips { display:flex; flex-direction:column; gap:9px; margin-top:28px; width:100%; }
.chip { display:flex; align-items:center; gap:9px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.07); border-radius:7px; padding:9px 13px; font-size:12px; color:rgba(255,255,255,.6); }

/* ─── ANIMATE (scroll reveal) ────────────────────────────── */
[data-animate] {
  opacity:0; transform:translateY(28px);
  transition:opacity .72s ease, transform .72s ease;
}
[data-animate].visible { opacity:1; transform:none; }

/* ============================================================
   RESPONSIVE — Mobile-first de abajo hacia arriba
   xs: <480px | sm: 480-639px | md: 640-767px
   lg: 768-1023px | xl: 1024-1279px | 2xl: ≥1280px
   ============================================================ */

/* ── LG (tablets horizontales y laptops pequeñas) ────────── */
@media (max-width:1024px) {
  .hero-grid    { grid-template-columns:1fr; max-width:700px; }
  .hero-card    { display:none; }
  .mv-grid      { grid-template-columns:1fr 1fr; }
  .objetivos-grid { grid-template-columns:repeat(3,1fr); }
  .regl-layout  { grid-template-columns:1fr; gap:36px; }
  .regl-card    { position:static; }
  .inscr-grid   { grid-template-columns:1fr; gap:36px; }
  .reg-body     { grid-template-columns:1fr; }
  .brand-panel  { display:none; }
  .tene-header-inner { gap:12px; }
}

/* ── MD (tablets verticales) ─────────────────────────────── */
@media (max-width:768px) {
  /* Header */
  .tene-header-inner { height:60px; }
  .tene-hero   { padding-top:60px; }
  .drem-txt    { display:none; }
  .evt-txt     { display:none; }

  /* Nav mobile */
  .tene-nav {
    display:none;
    flex-direction:column;
    gap:0;
    position:absolute;
    top:60px; left:0; right:0;
    background:var(--navy-d);
    border-bottom:2px solid var(--teal);
    box-shadow:0 8px 24px rgba(0,0,0,.3);
    overflow:hidden;
    max-height:0;
    transition:max-height .35s ease, opacity .3s ease;
    opacity:0;
  }
  .tene-nav.open {
    display:flex;
    max-height:300px;
    opacity:1;
  }
  .nav-link {
    padding:14px 20px; border-radius:0;
    border-bottom:1px solid rgba(255,255,255,.07);
    font-size:16px;
  }
  .nav-link.nav-cta { margin:8px 16px 12px; border-radius:8px; border-bottom:none; text-align:center; justify-content:center; }
  .tene-hamburger { display:flex; }

  /* Secciones */
  .tene-section { padding:48px 0; }
  .mv-grid { grid-template-columns:1fr; gap:20px; }
  .objetivos-grid { grid-template-columns:1fr 1fr; gap:14px; }

  /* Registro */
  .reg-header { height:56px; padding:0 16px; }
  .reg-logo .rl-sub { display:none; }
  .form-panel { padding:24px 16px 40px; }

  /* form cols */
  .fg-row.c2, .fg-row.c3 { grid-template-columns:1fr; }

  /* Hero */
  .hero-actions { gap:10px; }
  .btn-primary.big, .btn-primary { padding:12px 24px; font-size:15px; }
  .btn-outline  { padding:11px 20px; font-size:15px; }
}

/* ── SM (móviles grandes: 480–639px) ─────────────────────── */
@media (max-width:640px) {
  .objetivos-grid { grid-template-columns:1fr; }
  .tipo-tabs { flex-direction:column; gap:8px; }
  .tipo-tab  { padding:12px 16px; display:flex; align-items:center; gap:12px; text-align:left; }
  .tipo-tab .tab-icon { font-size:20px; margin-bottom:0; }
  .tipo-tab .tab-lbl  { font-size:14px; }

  .hero-title  { font-size:clamp(42px,11vw,60px); }
  .hero-actions { flex-direction:column; align-items:flex-start; gap:10px; }
  .btn-primary, .btn-outline { width:100%; justify-content:center; }

  .form-nav { flex-direction:column-reverse; }
  .btn-back, .btn-next, .btn-submit { width:100%; justify-content:center; }

  .success-actions { flex-direction:column; align-items:center; }
  .success-actions a, .success-actions button { width:100%; justify-content:center; }

  .progress-bar { gap:4px; }
  .step-lbl { display:none; }

  .inscr-actions { flex-direction:column; }
  .inscr-actions a { justify-content:center; }

  .recaptcha-wrap { transform:scale(.88); transform-origin:left center; }

  .footer-links { gap:12px; }
}

/* ── XS (móviles pequeños: <480px) ──────────────────────── */
@media (max-width:480px) {
  :root { --gutter: 14px; }

  .tene-header-inner { height:56px; }
  .tene-hero   { padding-top:56px; min-height:100svh; }
  .tene-logo-drem .logo-img { width:36px; height:36px; }
  .nav-link.nav-cta { margin:6px 12px 10px; }

  .hero-title   { font-size:clamp(38px,12vw,54px); }
  .hero-badge   { padding:5px 12px 5px 8px; }
  .hero-badge span:last-child { font-size:11px; }

  .form-head h1 { font-size:clamp(26px,8vw,36px); }
  .form-card    { padding:16px; }
  .form-panel   { padding:18px 14px 36px; }

  .code-box { font-size:14px; padding:10px 16px; }
  .success-screen h2 { font-size:clamp(22px,6vw,28px); }

  .reg-header { height:52px; }
  .tene-nav   { top:56px; }

  .mv-card    { padding:20px 16px; }
  .obj-card   { padding:18px 12px; }

  .regl-item  { gap:12px; padding:16px 0; }
  .regl-num   { font-size:28px; width:36px; }

  .chip       { padding:8px 10px; font-size:11px; }
  .hcard-val  { font-size:14px; }

  /* Quitar wave en muy pequeño para no cortar */
  .hero-wave  { display:none; }
}

/* ─── LANDSCAPE MÓVIL ────────────────────────────────────── */
@media (max-width:768px) and (orientation:landscape) and (max-height:500px) {
  .tene-hero     { min-height:auto; padding:clamp(70px,12vh,90px) var(--gutter) clamp(32px,6vh,48px); }
  .hero-title    { font-size:clamp(36px,6vw,52px); }
  .hero-desc     { display:none; }
  #pantalla-carga { align-items:center; }
}

/* ─── IMPRESIÓN ──────────────────────────────────────────── */
@media print {
  #pantalla-carga, .tene-header, .tene-nav, .tene-hamburger,
  .hero-wave, .geo, .btn-primary, .btn-outline, .inscr-actions { display:none !important; }
  body { background:#fff; color:#000; }
  .tene-section { padding:24px 0; }
  .bg-dark { background:#f5f5f5 !important; color:#000 !important; }
}