/* ===== Base ===== */
*{box-sizing:border-box;margin:0;padding:0}
body{
  margin-top:60px;
  font-family:'Rubik',Arial,sans-serif;
  padding:10px;
  background-color:#f0f0f0;
  line-height:1.6;
}

/* Cuando ya se eligió escuela → pegar la tarjeta arriba (igual que PAGOS) */
body.compacto{
  margin-top:20px;
}

/* Icon pack (Material Symbols) */
.mi{
  font-family:'Material Symbols Rounded';
  font-weight:normal;
  font-style:normal;
  font-size:1.2em;
  line-height:1;
  display:inline-block;
  vertical-align:-0.2em;
  user-select:none;
}
.mi-title{font-size:1.3em;margin-right:.35em}

/* Colores por bloque */
.mi-info{color:#906717}   /* libro / título principal */
.mi-level{color:#3B82F6}
.mi-cal{color:#F97316}
.mi-noph{color:#DC2626}
.mi-box{color:#7C3AED}
.mi-pay{color:#16A34A}

/* Contenedor principal */
.container{
  background:#fff;
  padding:20px;
  border-radius:12px;
  box-shadow:0 4px 18px rgba(0,0,0,.08);
  max-width:480px;
  margin:0 auto;
}

/* Encabezado */
.title-container{text-align:center;margin-bottom:10px}
h1,h2{color:#000}

/* Título principal con icono libro (marrón, como en PAGOS) */
.title-main{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  color:#906717; /* Título y libro en marrón */
}
.title-main .mi-title{
  color:#906717;
}
h1{font-size:22px;margin-bottom:1px}

/* Tipografía Pacifico solo para “La Foto” */
.pacifico-font{
  font-family:'Pacifico','Comic Sans MS',cursive;
}

/* Segunda línea: La Foto · Recuerdo Escolar → dorado (igual PAGOS) */
.header-subtitle{
  display:flex;
  justify-content:center;
  align-items:baseline;
  gap:6px;
  margin-top:4px;
  font-size:15px;
  color:#906717;  /* dorado, reforzando el bloque La Foto */
}
.header-subtitle .pacifico-font{
  font-size:18px;
}
.subtitle-separator{
  font-size:16px;
  line-height:1;
}
.subtitle-rest{
  font-family:'Rubik',Arial,sans-serif;
  font-weight:400;
}

/* Tercera línea: Cartelera Virtual con icono forum negro (bold + cursiva) */
.header-breadcrumb{
  margin-top:6px;
  font-size:14.5px;
  color:#000;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}
.breadcrumb-form{
  font-family:'Rubik',Arial,sans-serif;
  font-weight:700;
  font-style:italic;
}
.mi-breadcrumb{
  font-size:18px;
  color:#000;
}

/* Buscador */
input,button{font-family:'Rubik',Arial,sans-serif;font-size:14px}
input{
  background:#f7f7f7;width:100%;padding:10px;border:1px solid #ddd;border-radius:8px;margin-bottom:10px
}
.btn{
  background:#fff;border:1px solid #ddd;border-radius:999px;padding:10px 12px;cursor:pointer;width:100%;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 2px 8px rgba(0,0,0,.02);
  transition:background .15s ease,transform .05s ease,box-shadow .15s ease;
}
.btn:hover{background:#f9f9f9}
.btn:active{transform:translateY(1px);box-shadow:0 1px 2px rgba(0,0,0,.08)}
.btn-primary{
  color:#fff;
  background:#25D366;
  border:1px solid #20bf59;
}
.btn-primary:hover{filter:brightness(.96)}
.btn-primary:active{transform:translateY(1px)}

/* Autocompletado */
.search{position:relative}
.suggestions{
  position:absolute;left:0;right:0;top:100%;
  background:#fff;border:1px solid #ddd;border-top:none;z-index:20;
  max-height:260px;overflow:auto;border-radius:0 0 8px 8px;display:none
}
.suggestions button{
  width:100%;text-align:left;background:#fff;border:0;padding:10px;cursor:pointer
}
.suggestions button:hover{background:#f7f7f7}
.suggestions button.active{background:#efefef}

/* Tarjetas */
.card{
  border:1px solid #ededed;border-radius:12px;padding:12px;margin:10px 0;background:#fff
}
.card>h3{text-align:left}
.content-center{text-align:center}

/* Header escuela */
.school-header{
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.school-logo{
  max-height:90px;max-width:300px;object-fit:contain;margin-bottom:6px;
}
.school-title-row{
  width:100%;display:flex;align-items:center;justify-content:center;position:relative;
}
.school-title{font-size:18px;font-weight:700;text-align:center}

/* Share (SVG) */
.share-btn{
  position:absolute;right:0;top:50%;transform:translateY(-50%);
  display:inline-grid;place-items:center;width:28px;height:28px;
  border-radius:50%;border:1px solid #e2e2e2;background:#f7f7f7;color:#444;cursor:pointer;
}
.share-btn:hover{background:#efefef}
.share-btn svg{width:16px;height:16px;fill:none;stroke:#555;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* Cronograma – filas de turnos y cursos */
.turn-row{
  display:flex;
  align-items:center;
  gap:8px;
  margin:4px 0;
  justify-content:center;
}
.turn-label{
  display:inline-block;
  font-size:12px;
  color:#666;
  min-width:32px;
  text-transform:uppercase;
  text-align:right;
}
.turn-courses{font-weight:600}

/* Nota "Único día de la foto grupal" (debajo de la fecha) */
.cronogram-note{
  font-style:italic;
  font-size:12px;
  color:#444;
  margin-top:2px;
  text-align:center;
}

/* Línea punteada TM/TT */
.tt-sep{
  width:50%;
  border-top:1px dotted #aaa;
  margin:6px auto;
}

/* Divider entre días + fecha subrayada */
.date-line{
  border-top:1px solid #ddd;  /* un poco más presente */
  padding-top:6px;
  margin-top:8px;
  width:70%;                  /* 70% del ancho de la tarjeta */
  margin-left:auto;
  margin-right:auto;
}
.date-line b{
  display:block;
  text-decoration:underline;
  margin-bottom:2px;
  font-size:17px;
}
.date-line.first{border-top:none}

/* Bloques de nivel dentro de Cronograma */
.cron-level-block{
  margin-top:10px;
  padding-top:10px;
  position:relative;
}

/* Línea separadora fina antes de cada nivel de Cronograma */
.cron-level-block::before{
  content:'';
  display:block;
  width:70%;                 /* 70% del ancho de la tarjeta */
  height:2px;
  margin:2px auto 8px auto;
  background:rgba(59,130,246,.35);  /* azul suave */
  border-radius:999px;
}

/* Título de nivel dentro de Cronograma (ícono + texto) */
.cron-level-title{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  font-size:14px;
  font-weight:700;
  color:#3B82F6;
  margin-bottom:4px;
  text-align:center;
}

/* Subtítulos de grupos / niveles (valores y contenido) */
.sublevels{
  font-size:12.5px;
  font-weight:700;
  color:#222;
  margin-top:-4px;
  margin-bottom:6px;
  text-align:center;
}

/* Línea separadora en Valores (mantiene el color verde) */
.sublevels-valores{
  color:#16A34A;
  position:relative;
  padding-top:8px;
}
.sublevels-valores::before{
  content:'';
  display:block;
  width:70%;
  height:2px;
  margin:2px auto 8px auto;
  background:rgba(22,163,74,.35);
  border-radius:999px;
}

/* Línea separadora en Contenido (mantiene el violeta) */
.sublevels-contenido{
  color:#7C3AED;
  position:relative;
  padding-top:8px;
}
.sublevels-contenido::before{
  content:'';
  display:block;
  width:70%;
  height:2px;
  margin:2px auto 8px auto;
  background:rgba(124,58,237,.35);
  border-radius:999px;
}

/* Valores y plazos */
.price-list{margin:6px 0}
.price-line{
  display:flex;
  justify-content:center;
  gap:8px;
  margin:2px 0;
  flex-wrap:wrap;
}
.price-line .lbl{font-weight:600}
.price-line .val{font-weight:700}
.price-note{font-style:italic;font-weight:400;font-size:12px;color:#444}
.price-note-block{
  font-style:italic;
  font-size:12px;
  color:#444;
  margin-top:-2px;
  line-height:1.3;
  text-align:center;
}

/* Deadlines */
.deadline-line{margin:2px 0;text-align:center}
.deadline-line strong.underline{text-decoration:underline}
.deadline-line strong.red{color:#DC2626}

/* Lista de “Contenido de la carpeta” */
.detail-list{margin-top:6px;text-align:center}
.detail-item{
  display:flex;
  gap:6px;
  margin:2px 0;
  justify-content:center;
}
.detail-item .tag{font-weight:600}

/* Lema */
.lema-wrap{margin-top:10px;text-align:center}
.lema{font-size:13px;color:#333}

/* Botón pago electrónico */
.btn-pay{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;
  border:1px solid #20bf59;border-radius:999px;
  background:#25D366;color:#fff;text-decoration:none;cursor:pointer;
  box-shadow:0 2px 10px rgba(37,211,102,.25),0 1px 2px rgba(0,0,0,.07);
  transition:filter .15s ease,transform .05s ease,box-shadow .2s ease;
}
.btn-pay:hover{filter:brightness(.96)}
.btn-pay:active{transform:translateY(1px);box-shadow:0 1px 4px rgba(0,0,0,.12)}
.btn-pay .mi{vertical-align:middle;font-size:1.1em}

/* ===== FAQ ===== */
.faq-wrap{
  margin-top:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.faq-link{
  background:transparent;
  border:none;
  padding:0;
  box-shadow:none;
  color:#3a3a3a;
  text-decoration:none;
  font-size:14px;
}
.faq-link:hover{text-decoration:underline;background:transparent}
.faq-icon{
  width:22px;height:22px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;
  background:#666;
  border:none;
  color:#fff;
  text-decoration:none;
  font-weight:400;
  font-size:12px;
  line-height:1;
}
.faq-icon:hover{filter:brightness(.95)}

/* ===== + INFO (acordeón) — botón rojo ===== */
.info-acc-wrap{margin-top:8px}
.info-acc-btn{
  display:inline-flex;align-items:center;gap:8px;justify-content:center;
  width:100%;
  padding:8px 12px;border-radius:999px;
  border:1px solid #DC2626;
  background:#fff;
  color:#DC2626;
  font-weight:700;
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 2px 8px rgba(0,0,0,.02);
  cursor:pointer;transition:background .15s ease,transform .05s ease,box-shadow .15s ease;
}
.info-acc-btn .mi{ color:inherit; }
.info-acc-btn:hover{ background:#f9f9f9; }
.info-acc-btn:active{ transform:translateY(1px); box-shadow:0 1px 2px rgba(0,0,0,.08); }

/* Panel del acordeón */
.info-panel{
  overflow:hidden;
  max-height:0;
  transition:max-height .28s ease;
}
.info-sec{padding:8px 10px}
.info-sec h4{font-size:14px;margin:6px 0 4px 0}
.info-text{
  font-size:13.5px;
  color:#333;
  line-height:1.45;
  text-align:left;
  white-space:pre-wrap;
}
.info-text .info-line{display:block}

/* Footer – ajustado para que el logo quede cerca del recuadro blanco (igual criterio que PAGOS) */
.footer{
  text-align:center;
  margin-top:20px;
  background-color:#f0f0f0;
  padding:10px 0 20px;
}
.footer-content{display:flex;flex-direction:column;align-items:center}
.logo{transform:scale(1.1);width:105.6px;margin-bottom:10px}
.company-info a{font-size:14px;font-weight:bold;color:#000;text-decoration:none}
.company-info p{font-size:12px;color:#666;margin:3px 0}

/* Toast */
.toast{
  position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(20px);
  background:#222;color:#fff;padding:10px 14px;border-radius:10px;
  box-shadow:0 8px 18px rgba(0,0,0,.2);opacity:0;pointer-events:none;
  transition:.25s ease;z-index:9999;font-size:13.5px
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Fade-in */
.fade-in{animation:fadeInUp .28s ease-out both}
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}

/* Responsive */
@media(max-width:768px){
  h1{font-size:22px}
  h2{font-size:16.2px}
  input{font-size:14px}
}

/* Nota aclaratoria bajo "Ausentes" */
.abs-note{
  font-size:12px;
  color:#444;
  margin-top:-2px;
  line-height:1.3;
  text-align:center;
}
