:root{
  --mi-color-primary:#A1BF34;
  --mi-color-primary-hover:#38D0F2;
  --mi-color-dark:#0f172a;
  --mi-color-text:#1e293b;
  --mi-color-muted:#64748b;
  --mi-color-border:#e2e8f0;
  --mi-color-soft:#f8fafc;
  --mi-color-white:#ffffff;
  --mi-shadow-card:0 10px 30px rgba(0,0,0,.08);
  --mi-shadow-btn:0 8px 20px rgba(0,0,0,.15);
  --mi-shadow-btn-hover:0 12px 28px rgba(0,0,0,.2);
}

/* =========================
   Preview
========================= */
.mi-material-preview-wrap{
  width:100%;
  max-width:100%;
  margin:0 0 24px;
}

.mi-material-preview-card{
  width:100%;
  max-width:860px;
  margin:0 auto;
  border-radius:20px;
  overflow:hidden;
  background:var(--mi-color-white);
  box-shadow:var(--mi-shadow-card);
  border:1px solid rgba(0,0,0,.03);
}

.mi-material-preview-frame-wrap{
  width:100%;
  position:relative;
  background:#fff;
}

.mi-material-preview-frame{
  display:block;
  width:100%;
  min-height:420px;
  height:60vh;
  max-height:550px;
  border:0;
}

.mi-material-preview-fallback{
  position:relative;
  background:var(--mi-color-soft);
}

.mi-material-preview-thumb{
  display:block;
  width:100%;
  height:auto;
  max-height:560px;
  object-fit:cover;
}

.mi-material-preview-placeholder{
  min-height:340px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg, #eff6ff 0%, #f8fafc 100%);
  color:var(--mi-color-dark);
  font-size:32px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.mi-material-preview-notice{
  padding:24px;
  background:#fff;
  border-top:1px solid var(--mi-color-border);
}

.mi-material-preview-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(161,191,52,.15);
  color:var(--mi-color-dark);
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.mi-material-preview-notice h3{
  margin:0 0 10px;
  font-size:22px;
  line-height:1;
  color:var(--mi-color-dark);
}

.mi-material-preview-notice p{
  margin:0;
  color:var(--mi-color-muted);
  font-size:16px;
  line-height:1.6;
}

/* =========================
   Empty state
========================= */
.mi-material-empty-state{
  max-width:760px;
  margin:0 auto;
  padding:36px 28px;
  border-radius:20px;
  background:var(--mi-color-white);
  border:1px solid var(--mi-color-border);
  box-shadow:var(--mi-shadow-card);
  text-align:center;
}

.mi-material-empty-icon{
  width:64px;
  height:64px;
  margin:0 auto 16px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(56,208,242,.12);
  color:var(--mi-color-dark);
  font-size:28px;
  font-weight:800;
}

.mi-material-empty-state h3{
  margin:0 0 10px;
  font-size:24px;
  color:var(--mi-color-dark);
}

.mi-material-empty-state p{
  margin:0 0 18px;
  color:var(--mi-color-muted);
  line-height:1.6;
}

.mi-material-empty-link{
  color:var(--mi-color-primary-hover);
  font-weight:700;
  text-decoration:none;
}

.mi-material-empty-link:hover{
  text-decoration:underline;
}

/* =========================
   Buttons
========================= */
.mi-material-btn-wrap{
  margin:12px 0 24px;
}

.mi-material-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  width:auto;
  max-width:100%;
  min-height:54px;
  padding:14px 28px;
  border-radius:12px;
  border:none;
  text-decoration:none;
  cursor:pointer;
  font-weight:800;
  font-size:16px;
  letter-spacing:.04em;
  text-transform:uppercase;
  transition:all .25s ease;
  box-shadow:var(--mi-shadow-btn);
}

.mi-material-btn-primary{
  background-color:var(--mi-color-primary);
  color:var(--mi-color-white);
}

.mi-material-btn-primary:hover{
  background-color:var(--mi-color-primary-hover);
  color:var(--mi-color-white);
  transform:translateY(-2px);
  box-shadow:var(--mi-shadow-btn-hover);
}

.mi-material-btn-primary:active{
  transform:translateY(0);
}

.mi-material-btn-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
}

.mi-material-btn-icon svg{
  width:24px;
  height:24px;
  display:block;
  color:#fff;
}

/* =========================
   Modal no membership
========================= */
.mi-material-modal[hidden]{
  display:none !important;
}

.mi-material-modal{
  position:fixed;
  inset:0;
  z-index:99999;
}

.mi-material-modal-overlay{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.76);
  backdrop-filter:blur(3px);
}

.mi-material-modal-dialog{
  position:relative;
  z-index:2;
  width:min(560px, calc(100% - 32px));
  margin:6vh auto 0;
  background:#fff;
  border-radius:22px;
  box-shadow:0 30px 60px rgba(0,0,0,.22);
  overflow:hidden;
}

.mi-material-modal-content{
  padding:34px 28px 30px;
  text-align:center;
}

.mi-material-modal-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:6px 12px;
  margin-bottom:14px;
  border-radius:999px;
  background:rgba(56,208,242,.12);
  color:var(--mi-color-dark);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.mi-material-modal-content h3{
  margin:0 0 12px;
  font-size:28px;
  line-height:1.2;
  color:var(--mi-color-dark);
}

.mi-material-modal-content p{
  margin:0 0 22px;
  color:var(--mi-color-muted);
  line-height:1.7;
  font-size:16px;
}

.mi-material-modal-actions{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
}

.mi-material-login-link{
  color:var(--mi-color-primary-hover);
  font-weight:700;
  text-decoration:none;
}

.mi-material-login-link:hover{
  text-decoration:underline;
}

.mi-material-modal-close{
  position:absolute;
  top:12px;
  right:14px;
  width:40px;
  height:40px;
  border:none;
  border-radius:999px;
  background:rgba(15,23,42,.06);
  color:var(--mi-color-dark);
  font-size:28px;
  line-height:1;
  cursor:pointer;
}

/* =========================
   Responsive
========================= */
@media (max-width: 900px){
  .mi-material-preview-frame{
    min-height:540px;
    height:72vh;
  }
}

@media (max-width: 767px){
  .mi-material-btn{
    width:100%;
    padding:14px 18px;
    font-size:14px;
  }

  .mi-material-preview-card{
    border-radius:16px;
  }

  .mi-material-preview-frame{
    min-height:420px;
    height:68vh;
  }

  .mi-material-preview-notice{
    padding:18px;
  }

  .mi-material-preview-notice h3{
    font-size:21px;
  }

  .mi-material-preview-notice p{
    font-size:15px;
  }

  .mi-material-empty-state{
    padding:28px 18px;
    border-radius:16px;
  }

  .mi-material-empty-state h3{
    font-size:22px;
  }

  .mi-material-modal-dialog{
    width:min(560px, calc(100% - 20px));
    margin:50vh auto 0;
    transform:translateY(-50%);
    border-radius:18px;
  }

  .mi-material-modal-content{
    padding:28px 20px 24px;
  }

  .mi-material-modal-content h3{
    font-size:24px;
  }
}

/* =========================
   Formación Docente - Video Embed
========================= */
.mi-formacion-video-wrap{
  width:100%;
  max-width:100%;
  margin:0 0 24px;
}

.mi-formacion-video-card{
  width:100%;
  max-width:960px;
  margin:0 auto;
}

.mi-formacion-video-embed{
  position:relative;
  width:100%;
  background:#000;
  border-radius:20px;
  overflow:hidden;
  aspect-ratio:16 / 9;
}

.mi-formacion-video-embed iframe,
.mi-formacion-video-embed video,
.mi-formacion-video-embed .bunny-stream,
.mi-formacion-video-embed > div,
.mi-formacion-video-embed script + div{
  width:100% !important;
  height:100% !important;
  display:block;
}

.mi-formacion-video-embed iframe{
  border:0;
}

/* =========================
   Formación Docente - Fake Video Locked
========================= */
.mi-formacion-video-locked-card{
  overflow:hidden;
}

.mi-formacion-video-locked-trigger{
  display:block;
  width:100%;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
  text-align:left;
}

.mi-formacion-video-thumb-shell{
  position:relative;
  width:100%;
  aspect-ratio:16 / 9;
  background:linear-gradient(135deg, #eff6ff 0%, #f8fafc 100%);
  overflow:hidden;
}

.mi-formacion-video-thumb{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .35s ease;
}

.mi-formacion-video-thumb-placeholder{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--mi-color-dark);
  font-size:32px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.mi-formacion-video-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(15,23,42,.16) 0%, rgba(15,23,42,.55) 100%);
  backdrop-filter:blur(1px);
}

.mi-formacion-video-play{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:2;
  pointer-events:none;
}

.mi-formacion-video-play-icon{
  width:84px;
  height:84px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 14px 34px rgba(0,0,0,.18);
  position:relative;
  transition:transform .25s ease, background .25s ease;
}

.mi-formacion-video-play-icon::before{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-40%, -50%);
  width:0;
  height:0;
  border-top:14px solid transparent;
  border-bottom:14px solid transparent;
  border-left:24px solid #ffffff;
}

.mi-formacion-video-meta{
  position:absolute;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:2;
  color:#fff;
}

.mi-formacion-video-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  padding:6px 12px;
  margin-bottom:10px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.16);
  color:#ffffff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.mi-formacion-video-title{
  margin:0;
  color:#fff;
  font-size:26px;
  line-height:1.2;
  text-shadow:0 3px 12px rgba(0,0,0,.22);
}

.mi-formacion-video-locked-trigger:hover .mi-formacion-video-thumb{
  transform:scale(1.04);
}

.mi-formacion-video-locked-trigger:hover .mi-formacion-video-play-icon{
  transform:scale(1.05);
  background:rgba(161,191,52,.28);
}

@media (max-width: 767px){
  .mi-formacion-video-embed{
    border-radius:16px;
  }

  .mi-formacion-video-play-icon{
    width:72px;
    height:72px;
  }

  .mi-formacion-video-play-icon::before{
    border-top:12px solid transparent;
    border-bottom:12px solid transparent;
    border-left:20px solid #ffffff;
  }

  .mi-formacion-video-meta{
    left:16px;
    right:16px;
    bottom:16px;
  }

  .mi-formacion-video-title{
    font-size:20px;
  }
}