:root{
  --vino:#7b1238;
  --vino-oscuro:#6f0c30;
  --vino-profundo:#4f001f;
  --dorado:#b08a57;
  --gris-fondo:#f2f2f2;
  --gris-texto:#4d4d4d;
  --gris-linea:#d4d4d4;
  --gris-panel:#e9e9e9;
  --blanco:#ffffff;
  --verde-bg:#e7f7ea;
  --verde-tx:#1d6a2a;
  --rojo-bg:#fde7e7;
  --rojo-tx:#9d2525;
  --shadow:0 14px 34px rgba(0,0,0,.07);
  --max:1180px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Montserrat',sans-serif;
  background:var(--gris-fondo);
  color:var(--gris-texto);
  line-height:1.65;
}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 24px;}

.topbar{background:var(--vino);color:#fff;}
.topbar-inner{
  max-width:var(--max);
  min-height:104px;
  margin:0 auto;
  padding:0 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand-wrap{display:flex;align-items:center;gap:16px;}
.logo-site{width:230px;height:auto;object-fit:contain;}
.brand-text{display:flex;flex-direction:column;line-height:1.05;}
.brand-small{font-size:14px;font-weight:500;opacity:.95;letter-spacing:.2px;}
.brand-big{font-size:30px;font-weight:700;}
.top-nav{display:flex;align-items:center;gap:36px;font-size:15px;font-weight:500;}
.top-nav a:hover{opacity:.85;}

.subbar{background:var(--vino-profundo);color:#fff;}
.subbar-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:18px 24px 22px;
  font-size:25px;
  font-weight:500;
}

.page{padding:56px 0 72px;}
.breadcrumb{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  font-size:16px;
  color:#565656;
  margin-bottom:44px;
}
.crumb-home{font-size:18px;line-height:1;}
.breadcrumb .active{font-weight:700;}

.hero-intro{margin-bottom:34px;}
.main-title{
  font-family:'Baloo 2',cursive;
  font-size:86px;
  line-height:.92;
  color:#404040;
  letter-spacing:.2px;
  margin-bottom:34px;
}

.steps{
  max-width:870px;
  height:104px;
  display:flex;
  background:var(--gris-panel);
  border-radius:8px;
  overflow:hidden;
}
.step{
  position:relative;
  min-width:260px;
  background:var(--vino);
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:18px 62px 18px 28px;
  z-index:1;
}
.step strong{font-size:22px;font-weight:800;line-height:1.08;}
.step span{font-size:16px;font-weight:500;}
.step::after{
  content:"";
  position:absolute;
  top:0;
  right:-52px;
  width:0;
  height:0;
  border-top:52px solid transparent;
  border-bottom:52px solid transparent;
  border-left:52px solid var(--vino);
  z-index:2;
}
.step.muted{flex:1;min-width:auto;background:var(--gris-panel);}
.step.muted::after{display:none;}

.consulta-shell,
.info-box,
.notice-box{
  background:var(--blanco);
  border-radius:22px;
  border:1px solid #ececec;
  box-shadow:var(--shadow);
}

.consulta-shell{
  padding:34px;
  margin-bottom:46px;
}

.section-title{
  font-family:'Baloo 2',cursive;
  font-size:58px;
  line-height:.95;
  color:#404040;
  margin-bottom:8px;
}
.gold-line{
  width:48px;
  height:6px;
  background:var(--dorado);
  border-radius:999px;
  margin-bottom:24px;
}
.section-desc{
  max-width:900px;
  font-size:18px;
  color:#5a5a5a;
  margin-bottom:20px;
}

.curp-form{
  display:grid;
  grid-template-columns:1fr 240px;
  gap:16px;
}
.curp-form input{
  width:100%;
  height:62px;
  border:1px solid #d8d8d8;
  border-radius:14px;
  background:#fcfcfc;
  padding:0 18px;
  font-size:17px;
  text-transform:uppercase;
  outline:none;
  transition:.2s;
}
.curp-form input:focus{
  border-color:var(--vino);
  box-shadow:0 0 0 4px rgba(123,18,56,.10);
  background:#fff;
}
.curp-form button{
  width:100%;
  min-height:62px;
  border:none;
  border-radius:14px;
  background:var(--vino);
  color:#fff;
  font-size:17px;
  font-weight:700;
  cursor:pointer;
  transition:.2s;
  box-shadow:0 10px 22px rgba(123,18,56,.18);
}
.curp-form button:hover{background:#691031;}
.curp-form button:disabled{opacity:.75;cursor:not-allowed;}

.mensaje{display:none;margin-top:18px;padding:14px 16px;border-radius:14px;font-weight:600;font-size:15px;}
.mensaje.ok{display:block;background:var(--verde-bg);color:var(--verde-tx);}
.mensaje.error{display:block;background:var(--rojo-bg);color:var(--rojo-tx);}

.resultado{display:none;margin-top:18px;background:#f8f8f8;border:1px solid #ececec;border-radius:16px;padding:18px;}
.resultado.show{display:block;}
.resultado-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.resultado-item{background:#fff;border:1px solid #ededed;border-radius:12px;padding:12px 14px;}
.resultado-item strong{display:block;font-size:13px;color:#7a7a7a;margin-bottom:4px;}
.resultado-item span{font-size:15px;color:#383838;font-weight:600;word-break:break-word;}

.mini-note{
  margin-top:28px;
  padding:16px 18px;
  background:#fbf7ee;
  border-left:4px solid var(--dorado);
  border-radius:12px;
  font-size:14px;
  color:#5b5449;
}

.content-section{margin-top:6px;}
.content-layout{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.info-box{padding:28px;}
.info-box h3{
  font-family:'Baloo 2',cursive;
  font-size:37px;
  line-height:1;
  color:#404040;
  margin-bottom:14px;
}
.info-box p{margin-bottom:14px;font-size:16px;color:#555;}
.info-box ul{padding-left:20px;}
.info-box li{margin-bottom:10px;color:#555;}
.full{grid-column:1 / -1;}

.notice-box{
  margin-top:30px;
  padding:30px;
  background:#fff8eb;
  border:1px solid #f0dfbd;
}
.notice-box p{margin-bottom:12px;color:#5a5349;}

.footer{background:var(--vino-profundo);color:#fff;margin-top:52px;}
.footer-inner{
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
  font-size:14px;
}

@media (max-width: 992px){
  .main-title{font-size:64px;}
  .section-title{font-size:46px;}
  .curp-form{grid-template-columns:1fr;}
  .content-layout{grid-template-columns:1fr;}
  .resultado-grid{grid-template-columns:1fr;}
  .steps{height:auto;flex-direction:column;border-radius:18px;}
  .step{min-width:100%;padding:20px 24px;}
  .step::after{display:none;}
}

@media (max-width: 768px){
  .topbar-inner{
    min-height:auto;
    padding:16px;
    flex-direction:column;
    align-items:flex-start;
  }
  .top-nav{gap:18px;flex-wrap:wrap;}
  .logo-site{width:190px;}
  .brand-big{font-size:24px;}
  .subbar-inner{padding:14px 16px 18px;font-size:20px;}
  .page{padding:30px 0 52px;}
  .container{padding:0 16px;}
  .breadcrumb{margin-bottom:28px;font-size:15px;}
  .main-title{font-size:49px;margin-bottom:24px;}
  .section-title{font-size:39px;}
  .consulta-shell,.info-box,.notice-box{padding:22px;}
  .curp-form button{
    min-height:66px;
    font-size:18px;
    width:100%;
  }
}

@media (max-width: 520px){
  .logo-site{width:165px;}
  .main-title{font-size:42px;}
  .section-title{font-size:34px;}
  .curp-form button{
    min-height:68px;
    font-size:18px;
    padding:0 18px;
  }
}
