/* ══════════════════════════════════════════════════════════════════════════
   Portal SPIKE Prime · Centro Colombo Americano × ROBOTSchool
   Sistema visual v2 — editorial / nivel plataforma de curso
   Alineado al RBS Design System. Iconografía de línea (no emoji de relleno).
   ══════════════════════════════════════════════════════════════════════════ */

:root {
  --font-display: 'Sora', system-ui, -apple-system, sans-serif;
  --font-body:    'Inter', system-ui, -apple-system, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  /* Marca */
  --teal: #009CCC; --teal-dark: #007aaa; --teal-light: #e0f5fb;
  --red: #E8302A; --red-dark: #c0201a; --red-light: #fde8e8;
  --colombo: #0B5CAB; --colombo-dark: #083f76; --colombo-light: #e7f0fb;

  /* Tinta / superficie (editorial, profundo) */
  --ink:       #0E1726;   /* casi-negro azulado para heros y texto fuerte */
  --ink-2:     #1B2638;
  --carbon:    #16202E;   /* texto principal */
  --gray-900: #111827; --gray-700: #374151; --gray-600:#4B5563;
  --gray-500: #6B7280; --gray-400: #9CA3AF; --gray-300: #D1D5DB;
  --gray-200: #E5E7EB; --gray-100: #F3F4F6;
  --paper:    #FBFAF7;   /* fondo de página, papel cálido */
  --surface:  #FFFFFF;
  --border:   #E7E3DA;
  --border-2: #EFECE4;

  --success:#16A34A; --success-light:#DCFCE7;
  --warning:#D97706; --warning-light:#FEF3C7;

  --rol-constructor:#E8302A; --rol-programador:#0B5CAB; --rol-pruebas:#16A34A;

  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:20px;
  --space-6:24px; --space-8:32px; --space-10:40px; --space-12:48px; --space-16:64px;

  --radius-sm:8px; --radius-md:12px; --radius-lg:16px; --radius-xl:22px; --radius-full:9999px;

  --shadow-xs:0 1px 2px rgba(16,23,38,.06);
  --shadow-sm:0 1px 3px rgba(16,23,38,.08),0 1px 2px rgba(16,23,38,.04);
  --shadow-md:0 6px 16px rgba(16,23,38,.08);
  --shadow-lg:0 18px 40px rgba(16,23,38,.12);

  --transition:180ms cubic-bezier(.4,0,.2,1);
  --sidebar-w:268px; --maxw:940px;
}

*,*::before,*::after{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:16px;line-height:1.65;color:var(--carbon);background:var(--paper);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.15;letter-spacing:-.022em;font-weight:700;color:var(--ink)}
a{color:var(--teal-dark);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
code,kbd{font-family:var(--font-mono);font-size:.88em}
svg{flex-shrink:0}

/* Iconografía de línea reutilizable */
.icon{width:20px;height:20px;stroke:currentColor;stroke-width:1.75;fill:none;stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:-4px}
.icon.sm{width:16px;height:16px}
.icon.lg{width:26px;height:26px}

/* ══════════ Layout ══════════ */
.app{display:flex;min-height:100vh}

.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);position:sticky;top:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column}
.sidebar__brand{padding:var(--space-6) var(--space-5) var(--space-5);border-bottom:1px solid var(--border-2)}
.brand-mark{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:800;font-size:15.5px;letter-spacing:-.02em;color:var(--ink)}
.brand-mark .dot{width:7px;height:7px;border-radius:50%;background:var(--teal)}
.brand-mark .x{color:var(--gray-300);font-weight:500}
.brand-sub{font-size:11px;color:var(--gray-500);margin-top:7px;letter-spacing:.1em;text-transform:uppercase;font-weight:600}
.sidebar__nav{padding:var(--space-4) var(--space-3);flex:1}
.nav-group-label{font-size:10.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--gray-400);padding:var(--space-5) var(--space-3) var(--space-2)}
.nav-link{display:flex;align-items:center;gap:11px;padding:9px var(--space-3);border-radius:var(--radius-sm);color:var(--gray-700);font-weight:500;font-size:14.5px;transition:var(--transition)}
.nav-link:hover{background:var(--gray-100);text-decoration:none;color:var(--ink)}
.nav-link.active{background:var(--ink);color:#fff;font-weight:600}
.nav-link.active .icon{stroke:#fff}
.nav-link .icon{color:var(--gray-500)}
.nav-link.active .num,.nav-link .num{width:22px;height:22px;border-radius:var(--radius-sm);background:var(--gray-100);color:var(--gray-600);font-size:12px;font-weight:700;display:grid;place-items:center;font-family:var(--font-display)}
.nav-link.active .num{background:rgba(255,255,255,.16);color:#fff}
.nav-link.done .num{background:var(--success);color:#fff}
.sidebar__foot{padding:var(--space-5);border-top:1px solid var(--border-2);font-size:11.5px;line-height:1.6;color:var(--gray-400)}

.main{flex:1;min-width:0}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-8);background:rgba(251,250,247,.82);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border-2)}
.topbar__crumbs{font-size:13px;color:var(--gray-500);display:flex;align-items:center;gap:8px}
.topbar__crumbs b{color:var(--ink);font-weight:600}
.topbar__crumbs .sep{color:var(--gray-300)}
.topbar__tools{display:flex;align-items:center;gap:var(--space-3)}

.segmented{display:inline-flex;background:var(--gray-100);border-radius:var(--radius-full);padding:3px;border:1px solid var(--border-2)}
.segmented button{border:0;background:transparent;cursor:pointer;font-family:var(--font-body);font-size:12.5px;font-weight:600;color:var(--gray-500);padding:6px 13px;border-radius:var(--radius-full);transition:var(--transition);display:flex;align-items:center;gap:6px}
.segmented button:hover{color:var(--ink)}
.segmented button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-xs)}
.segmented.role button.on[data-view="docente"]{color:var(--colombo-dark)}
.segmented.role button.on[data-view="estudiante"]{color:var(--teal-dark)}

.content{max-width:var(--maxw);margin:0 auto;padding:var(--space-10) var(--space-8) var(--space-16)}

/* ══════════ Tipografía de contenido ══════════ */
.kicker{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-dark)}
.kicker::before{content:"";width:22px;height:2px;background:var(--teal);border-radius:2px}
.page-title{font-size:42px;font-weight:800;letter-spacing:-.03em;margin:var(--space-3) 0}
.lead{font-size:18.5px;color:var(--gray-700);line-height:1.6;max-width:66ch}
.section{margin-top:var(--space-16)}
.section-head{margin-bottom:var(--space-6)}
.section-title{font-size:27px;letter-spacing:-.025em;margin-top:var(--space-2)}
h3.block-title{font-size:20px;margin:var(--space-8) 0 var(--space-3)}
.content p{margin-bottom:var(--space-4);max-width:72ch}
.content > ul,.content > ol{margin:0 0 var(--space-4) var(--space-5);max-width:72ch}
.content li{margin-bottom:var(--space-2)}
.muted{color:var(--gray-500)}

/* ══════════ Badges / tags ══════════ */
.tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 11px;border-radius:var(--radius-full);border:1px solid transparent}
.tag--level{background:var(--surface);border-color:var(--border);color:var(--gray-700)}
.tag--level .icon{color:var(--teal)}
.tag--teal{background:var(--teal-light);color:var(--teal-dark)}
.tag--colombo{background:var(--colombo-light);color:var(--colombo-dark)}
.tag--soft{background:var(--gray-100);color:var(--gray-600)}
.tag--time{background:var(--gray-100);color:var(--gray-700);font-family:var(--font-mono);font-size:11.5px}
.tag--warn{background:var(--warning-light);color:var(--warning)}
.tag--ok{background:var(--success-light);color:var(--success)}

/* ══════════ Botones ══════════ */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-body);font-weight:600;font-size:15px;padding:12px 22px;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:var(--transition);text-decoration:none;line-height:1}
.btn--primary{background:var(--teal);color:#fff}
.btn--primary:hover{background:var(--teal-dark);text-decoration:none;transform:translateY(-1px)}
.btn--dark{background:var(--ink);color:#fff}
.btn--dark:hover{background:var(--ink-2);text-decoration:none}
.btn--ghost{background:var(--surface);color:var(--ink);border-color:var(--border)}
.btn--ghost:hover{border-color:var(--gray-400);text-decoration:none}
.btn--link{background:var(--colombo);color:#fff}
.btn--link:hover{background:var(--colombo-dark);text-decoration:none}
.btn .icon{stroke-width:2}

/* ══════════ Cards / grid ══════════ */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-xs)}
.card-accent{border-top:3px solid var(--teal)}
.grid{display:grid;gap:var(--space-4)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.feature-card h3{font-size:18px;margin-bottom:var(--space-3);display:flex;align-items:center;gap:10px}
.feature-card h3 .icon{color:var(--teal)}
.feature-card p,.feature-card li{font-size:15px;color:var(--gray-700)}
.feature-card ul{margin:0 0 0 18px}
.feature-card li{margin-bottom:6px}

/* ══════════ HERO (editorial, oscuro) ══════════ */
.hero{position:relative;overflow:hidden;background:linear-gradient(150deg,var(--ink) 0%,#13233d 55%,var(--colombo-dark) 130%);color:#fff;border-radius:var(--radius-xl);padding:var(--space-12) var(--space-12) var(--space-10);box-shadow:var(--shadow-lg)}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);background-size:22px 22px;opacity:.5;pointer-events:none}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(0,156,204,.35),transparent 65%);pointer-events:none}
.hero > *{position:relative;z-index:1}
.hero .kicker{color:#7fd6ee}
.hero .kicker::before{background:var(--teal)}
.hero h1{font-size:46px;font-weight:800;letter-spacing:-.035em;color:#fff;max-width:18ch;margin:var(--space-4) 0}
.hero .lead{color:rgba(255,255,255,.82);font-size:18px;max-width:60ch}
.hero__stats{display:flex;flex-wrap:wrap;gap:var(--space-8);margin:var(--space-8) 0 0;padding-top:var(--space-6);border-top:1px solid rgba(255,255,255,.13)}
.stat .k{font-size:11px;text-transform:uppercase;letter-spacing:.09em;color:rgba(255,255,255,.55);font-weight:600;margin-bottom:3px}
.stat .v{font-family:var(--font-display);font-size:18px;font-weight:700;color:#fff}
.hero__cta{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-8)}
.hero .btn--primary{background:#fff;color:var(--ink)}
.hero .btn--primary:hover{background:#eef6f9}
.hero .btn--ghost{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.28)}
.hero .btn--ghost:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.5)}

/* ══════════ Currículo: tarjetas de módulo/sesión ══════════ */
.modules{display:flex;flex-direction:column;gap:var(--space-3)}
.module{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--space-6);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);transition:var(--transition)}
.module:hover{border-color:var(--ink);box-shadow:var(--shadow-md);text-decoration:none;transform:translateY(-1px)}
.module__n{font-family:var(--font-display);font-weight:800;font-size:15px;width:48px;height:48px;border-radius:var(--radius-md);display:grid;place-items:center;background:var(--ink);color:#fff}
.module__body h3{font-size:18.5px;margin-bottom:5px;color:var(--ink)}
.module__body p{font-size:14.5px;color:var(--gray-600);margin:0 0 9px;max-width:60ch}
.module__meta{display:flex;flex-wrap:wrap;gap:var(--space-2)}
.module__go{color:var(--gray-400);transition:var(--transition)}
.module:hover .module__go{color:var(--ink);transform:translateX(3px)}
.module__date{font-size:12px;color:var(--gray-400);font-weight:600;text-align:right;white-space:nowrap}

/* ══════════ Roles ══════════ */
.role-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.role-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);position:relative}
.role-card .rc-icon{width:46px;height:46px;border-radius:var(--radius-md);display:grid;place-items:center;color:#fff;margin-bottom:var(--space-4)}
.role-card.constructor .rc-icon{background:var(--rol-constructor)}
.role-card.programador .rc-icon{background:var(--rol-programador)}
.role-card.pruebas     .rc-icon{background:var(--rol-pruebas)}
.role-card .rc-icon .icon{stroke:#fff;width:24px;height:24px}
.role-card h3{font-size:18px;margin-bottom:4px}
.role-card .rc-tag{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-400)}
.role-card.constructor .rc-tag{color:var(--rol-constructor)}
.role-card.programador .rc-tag{color:var(--rol-programador)}
.role-card.pruebas .rc-tag{color:var(--rol-pruebas)}
.role-card ul{margin:var(--space-4) 0 0 16px;font-size:14.5px;color:var(--gray-700)}
.role-card li{margin-bottom:7px}

/* ══════════ Tabla de rotación ══════════ */
.rot-table{width:100%;border-collapse:collapse;margin-top:var(--space-4);font-size:14.5px;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.rot-table th,.rot-table td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--border-2)}
.rot-table thead th{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-500);background:var(--gray-100);font-weight:700}
.rot-table tbody tr:last-child td{border-bottom:0}
.rot-table tbody tr:hover{background:var(--paper)}
.rot-table .rol{font-weight:600;display:inline-flex;align-items:center;gap:7px}
.rot-table .swatch{width:9px;height:9px;border-radius:50%}

/* ══════════ PASOS ══════════ */
.steps{counter-reset:step;margin-top:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}
.step{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-6) var(--space-5) var(--space-12);box-shadow:var(--shadow-xs)}
.step::before{counter-increment:step;content:counter(step);position:absolute;left:18px;top:22px;width:30px;height:30px;border-radius:var(--radius-sm);background:var(--ink);color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;display:grid;place-items:center}
.step h4{font-size:17.5px;margin-bottom:var(--space-2);color:var(--ink)}
.step .step-goal{color:var(--gray-500);font-size:14px;margin-bottom:var(--space-3)}
.step-do{margin-bottom:var(--space-3);font-size:15px}
.step-check{display:flex;gap:9px;align-items:flex-start;background:var(--success-light);color:#15803d;padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;margin-bottom:var(--space-3)}
.step-check .icon{stroke:#15803d;width:18px;height:18px;margin-top:1px}
.step-links{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}
.chip-link{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;padding:7px 13px;border-radius:var(--radius-sm);background:var(--colombo-light);color:var(--colombo-dark);border:1px solid transparent;transition:var(--transition)}
.chip-link:hover{background:var(--colombo);color:#fff;text-decoration:none}
.chip-link .icon{width:15px;height:15px}

.teacher-tip{border-left:3px solid var(--colombo);background:var(--colombo-light);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:12px 16px;font-size:14px;color:var(--colombo-dark);margin-top:var(--space-3)}
.teacher-tip strong{display:flex;align-items:center;gap:7px;margin-bottom:4px;font-size:12px;text-transform:uppercase;letter-spacing:.05em}

/* ══════════ CONCEPTOS ══════════ */
.concept{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-5);box-shadow:var(--shadow-xs)}
.concept__head{display:flex;align-items:center;gap:var(--space-3);padding:16px 20px;border-bottom:1px solid var(--border-2)}
.concept__chip{font-family:var(--font-mono);font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:var(--radius-sm);background:var(--warning-light);color:#92600a;white-space:nowrap}
.concept__chip.motion{background:var(--teal-light);color:var(--teal-dark)}
.concept__chip.logic{background:#ede9fe;color:#5b21b6}
.concept__chip.sensor{background:var(--success-light);color:#15803d}
.concept__head h3{font-size:18px;margin:0}
.concept__body{padding:20px;display:grid;gap:16px}
.concept__row{display:grid;grid-template-columns:148px 1fr;gap:18px;align-items:start}
.concept__row dt{font-size:12px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;padding-top:2px}
.concept__row dd{font-size:15px;color:var(--gray-900)}
.concept__row.analogy dd{font-family:var(--font-mono);font-size:13.5px;background:var(--ink);color:#e6edf3;padding:12px 16px;border-radius:var(--radius-sm);line-height:1.7}
.concept__row.error dd{color:var(--red-dark)}

/* ══════════ Callouts ══════════ */
.callout{display:flex;gap:13px;padding:16px 20px;border-radius:var(--radius-md);margin:var(--space-5) 0;font-size:15px;line-height:1.55}
.callout .icon{width:22px;height:22px;margin-top:1px}
.callout--info{background:var(--teal-light);color:var(--teal-dark)}
.callout--warn{background:var(--warning-light);color:#92600a}
.callout--tip{background:var(--colombo-light);color:var(--colombo-dark)}
.callout strong{font-weight:700}

/* ══════════ Bloque de sesión: timeline docente ══════════ */
.timeline{border-left:2px solid var(--border);margin:var(--space-6) 0 0 9px;padding-left:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}
.tl-item{position:relative}
.tl-item::before{content:"";position:absolute;left:calc(-1 * var(--space-6) - 6px);top:5px;width:11px;height:11px;border-radius:50%;background:var(--surface);border:2px solid var(--teal)}
.tl-time{font-family:var(--font-mono);font-size:12.5px;color:var(--teal-dark);font-weight:600}
.tl-item h4{font-size:16.5px;margin:3px 0 4px}
.tl-item p{font-size:14.5px;color:var(--gray-600);margin:0;max-width:64ch}

/* ══════════ Progreso ══════════ */
.progress-wrap{display:flex;align-items:center;gap:11px}
.progress-bar{width:120px;height:6px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}
.progress-bar>i{display:block;height:100%;background:var(--success);border-radius:inherit;transition:width 300ms ease;width:0}
.progress-wrap span{font-size:12.5px;color:var(--gray-500);font-weight:600}
.step-done{width:18px;height:18px;accent-color:var(--success);cursor:pointer}
.step-toggle{display:flex;align-items:center;gap:9px;margin-top:var(--space-3);font-size:13px;color:var(--gray-500);font-weight:600;cursor:pointer;user-select:none}

/* ══════════ Vistas / i18n ══════════ */
body[data-view="estudiante"] .only-docente{display:none!important}
body[data-view="docente"] .only-estudiante{display:none!important}
body[data-lang="es"] [lang="en"]{display:none!important}
body[data-lang="en"] [lang="es"]{display:none!important}

/* ══════════ Mobile ══════════ */
.menu-btn{display:none}
.scrim{display:none}
@media(max-width:880px){
  .sidebar{position:fixed;left:0;top:0;z-index:50;transform:translateX(-100%);transition:transform var(--transition);box-shadow:var(--shadow-lg)}
  body.nav-open .sidebar{transform:translateX(0)}
  .menu-btn{display:inline-grid;place-items:center;width:40px;height:40px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer}
  body.nav-open .scrim{display:block;position:fixed;inset:0;background:rgba(14,23,38,.45);z-index:40}
  .grid-2,.grid-3,.role-cards{grid-template-columns:1fr}
  .module{grid-template-columns:auto 1fr;gap:var(--space-4)}
  .module__date,.module__go{display:none}
  .concept__row{grid-template-columns:1fr;gap:5px}
  .hero{padding:var(--space-8) var(--space-6)}
  .hero h1,.page-title{font-size:32px}
  .hero__stats{gap:var(--space-5)}
  .content{padding:var(--space-6) var(--space-5) var(--space-12)}
  .topbar{padding:var(--space-3) var(--space-5)}
  .codeboard{flex-direction:column;gap:18px}
}

/* ══════════ Bloques SPIKE (recreados, didáctico) ══════════ */
.codeboard{display:flex;flex-wrap:wrap;gap:22px;margin:22px 0;padding:22px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-lg)}
.blockstack{font-family:var(--font-body);font-weight:600;font-size:13px;color:#fff;min-width:228px}
.blockstack figcaption{font-size:11px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:9px}
.blk{display:flex;align-items:center;flex-wrap:wrap;gap:6px;padding:8px 12px;border-radius:7px;margin-bottom:3px;line-height:1.3;box-shadow:0 1px 0 rgba(0,0,0,.14)}
.blk--event{background:#f2b01e;color:#5b3d00}
.blk--motor{background:#2f86d8}
.blk--control{background:#ec9a29}
.blk--light{background:#8a5cf6}
.blk--sound{background:#cf63cf}
.blk--hat{border-top-left-radius:15px;border-top-right-radius:15px}
.blk .pill{background:#fff;color:#1f2937;border-radius:999px;padding:1px 9px;font-size:12px;font-weight:700;min-width:16px;text-align:center}
.blk .port{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;background:#fff;color:#1a5fa0;font-size:11px;font-weight:800}
.blk .lm{display:inline-grid;grid-template-columns:repeat(3,5px);gap:1.5px;padding:2px;background:rgba(0,0,0,.2);border-radius:3px}
.blk .lm i{width:5px;height:5px;border-radius:1px;background:rgba(255,255,255,.35)}
.blk .lm i.on{background:#fff}
.cblock{background:#ec9a29;border-radius:8px;margin-bottom:3px;box-shadow:0 1px 0 rgba(0,0,0,.14);overflow:hidden}
.cblock__head{color:#fff;display:flex;align-items:center;gap:7px;padding:8px 12px;font-weight:600}
.cblock__inner{padding:2px 8px 10px 16px}
.codecap{font-size:13px;color:var(--gray-600);margin-top:6px;max-width:62ch}

/* ══════════ Marca / co-brand ══════════ */
.brand-lock{display:flex;align-items:center;gap:10px}
.brand-lock img{width:30px;height:30px}
.brand-name{font-family:var(--font-display);font-weight:800;font-size:18px;letter-spacing:-.02em;color:var(--ink);line-height:1}
.cobrand{display:flex;align-items:center;gap:9px}
.cobrand img{width:32px;height:32px;border-radius:5px;background:#fff;flex-shrink:0;object-fit:contain}
.cobrand span{font-size:11px;color:var(--gray-500);line-height:1.4}
.cobrand span b{display:block;color:var(--gray-700);font-weight:700;font-size:9.5px;text-transform:uppercase;letter-spacing:.06em}
.cobrand-inline{display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap}
.cobrand-inline img{height:34px;width:auto}
.cobrand-inline .ci-owl{filter:brightness(0) invert(1)}
.cobrand-inline .x{color:rgba(255,255,255,.4);font-weight:300;font-size:20px}
.cobrand-inline .ci-colombo{background:#fff;border-radius:6px;padding:3px}

/* ══════════ Nav deshabilitado ══════════ */
.nav-link.disabled{color:var(--gray-300);cursor:default}
.nav-link.disabled .num{background:var(--gray-100);color:var(--gray-300)}
.nav-link.disabled:hover{background:transparent;color:var(--gray-300)}
.soon{margin-left:auto;font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-400);background:var(--gray-100);padding:2px 7px;border-radius:999px}

/* módulo deshabilitado en el currículo */
.module.disabled{opacity:.6;cursor:default;pointer-events:none}
.module.disabled .module__n{background:var(--gray-300)}

/* ══════════ Modal de acceso docente ══════════ */
.pw-overlay{position:fixed;inset:0;background:rgba(14,23,38,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}
.pw-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:360px;padding:28px;text-align:center}
.pw-card h3{font-size:20px;margin-bottom:6px}
.pw-card p{font-size:14px;color:var(--gray-500);margin-bottom:18px;line-height:1.5}
.pw-card input{width:100%;font-family:var(--font-body);font-size:20px;text-align:center;letter-spacing:.35em;padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:10px;outline:none}
.pw-card input:focus{border-color:var(--teal)}
.pw-err{color:var(--red);font-size:13px;font-weight:600;margin-bottom:12px;min-height:18px}
.pw-actions{display:flex;gap:10px}
.pw-actions .btn{flex:1;justify-content:center}
