:root{--ocean:#1A6FBF;--sky:#3B9EE8;--foam:#E8F4FD;--sun:#F5A623;--coral:#E85D2F;--mint:#2DBD8E;--ink:#1A2332;--slate:#4A5568;--mist:#A0AEC0;--cloud:#F0F4F8;--white:#FFFFFF;--radius:14px;--shadow:0 4px 24px rgba(26,47,64,.10);--shadow-lg:0 12px 48px rgba(26,47,64,.16);--font-head:'Fraunces',Georgia,serif;--font-body:'Nunito',sans-serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);background:var(--cloud);color:var(--ink);min-height:100vh;line-height:1.6}
.hidden{display:none!important}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:700;padding:12px 24px;border-radius:50px;border:none;cursor:pointer;transition:all .2s;text-decoration:none}
.btn-primary{background:var(--ocean);color:#fff}.btn-primary:hover{background:#1559A0;transform:translateY(-1px);box-shadow:0 6px 20px rgba(26,111,191,.35)}
.btn-secondary{background:var(--foam);color:var(--ocean);border:2px solid var(--ocean)}.btn-secondary:hover{background:var(--ocean);color:#fff}
.btn-ghost{background:transparent;color:var(--slate)}.btn-ghost:hover{background:var(--cloud)}
.btn-sm{padding:8px 18px;font-size:13px}.btn-full{width:100%}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}
.chip{display:inline-flex;align-items:center;font-size:12px;font-weight:700;padding:4px 12px;border-radius:50px;text-transform:uppercase;letter-spacing:.5px}
.chip-blue{background:var(--foam);color:var(--ocean)}.chip-green{background:#D1FAE5;color:#065F46}.chip-orange{background:#FEF3C7;color:#92400E}
.input-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.input-group label{font-size:12px;font-weight:800;color:var(--slate);text-transform:uppercase;letter-spacing:.6px}
.input-group input,.input-group select,.input-group textarea{padding:12px 16px;border:2px solid #E2E8F0;border-radius:10px;font-family:var(--font-body);font-size:15px;color:var(--ink);transition:border-color .2s;outline:none;background:#fff}
.input-group input:focus,.input-group select:focus,.input-group textarea:focus{border-color:var(--ocean)}
.alert{padding:12px 16px;border-radius:10px;font-size:14px;font-weight:600;margin-bottom:16px}
.alert-error{background:#FEE2E2;color:#9B1C1C}.alert-success{background:#D1FAE5;color:#065F46}.alert-info{background:var(--foam);color:var(--ocean)}

.msg-user{align-self:flex-end;background:var(--ocean);color:#fff;padding:8px 14px;border-radius:14px 14px 4px 14px;font-size:13px;max-width:80%}
.msg-ai{align-self:flex-start;background:var(--white);border:1px solid #E2E8F0;color:var(--ink);padding:8px 14px;border-radius:14px 14px 14px 4px;font-size:13px;max-width:85%}
.msg-loading{align-self:flex-start;color:var(--mist);font-size:13px;padding:4px 0}

/* ICONOS CURRICULARES — forzar horizontal */
.icono{display:inline-block!important;width:22px!important;height:22px!important;
  vertical-align:middle!important;margin:2px 3px!important;border-radius:4px!important}
/* LOADING */
#loading-screen{position:fixed;inset:0;background:var(--ocean);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999}
#loading-screen img{max-width:220px;margin-bottom:16px}
#loading-screen p{color:rgba(255,255,255,.7);font-size:14px}
.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;margin-top:24px}
@keyframes spin{to{transform:rotate(360deg)}}
/* AUTH */
#page-login,#page-register{min-height:100vh;display:flex}
.auth-left{flex:1;background:linear-gradient(160deg,#FFFDF7 0%,#F0F8FF 55%,#F5F0FF 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden;border-right:1px solid #EAE8F5}
.auth-left::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(245,166,35,.15) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(59,158,232,.12) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(130,100,230,.07) 0%,transparent 60%)}
.auth-tagline{color:var(--slate);font-size:16px;margin-top:16px;text-align:center;position:relative;z-index:1;max-width:320px}
.auth-right{width:480px;background:var(--white);display:flex;flex-direction:column;justify-content:center;padding:48px;overflow-y:auto}
.auth-right h2{font-family:var(--font-head);font-size:28px;font-weight:900;color:var(--ink);margin-bottom:6px}
.auth-right p.subtitle{color:var(--slate);font-size:14px;margin-bottom:28px}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0}
.auth-divider span{color:var(--mist);font-size:13px;white-space:nowrap}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:#E2E8F0}
.auth-link{text-align:center;margin-top:20px;font-size:14px;color:var(--slate)}
.auth-link a{color:var(--ocean);font-weight:700;text-decoration:none}
.password-wrapper{position:relative}
.password-wrapper input{padding-right:48px;width:100%}
.password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--mist);font-size:18px}
@media(max-width:768px){#page-login,#page-register{flex-direction:column}.auth-left{padding:32px;min-height:180px}.auth-right{width:100%;padding:32px 24px}}
/* APP */
#app{display:flex;min-height:100vh}
#sidebar{width:240px;background:var(--white);display:flex;flex-direction:column;border-right:1px solid #E2E8F0;position:fixed;top:0;left:0;height:100vh;z-index:100;transition:transform .3s}
.sidebar-logo{padding:14px 20px;border-bottom:1px solid #E2E8F0}
.sidebar-logo img{max-height:44px}
nav{flex:1;padding:16px 12px}
.nav-section{font-size:10px;font-weight:800;color:var(--mist);text-transform:uppercase;letter-spacing:1.5px;padding:0 8px;margin:16px 0 6px}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;font-size:14px;font-weight:600;color:var(--slate);cursor:pointer;transition:all .15s;margin-bottom:2px;border:none;background:none;width:100%;text-align:left}
.nav-item:hover{background:var(--foam);color:var(--ocean)}.nav-item.active{background:var(--foam);color:var(--ocean)}
.nav-item .icon{font-size:18px;width:24px;text-align:center}
.sidebar-footer{padding:16px 12px;border-top:1px solid #E2E8F0}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--ocean);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;flex-shrink:0}
.user-badge{display:flex;align-items:center;gap:10px;padding:10px 12px}
/* FIX 1b: user-info max-width para evitar overflow */
.user-info{min-width:0;flex:1}
.user-info .name{font-size:13px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.user-info .plan{font-size:11px;color:var(--mint);font-weight:700}
#main{margin-left:240px;flex:1;min-height:100vh}
.topbar{background:var(--white);border-bottom:1px solid #E2E8F0;padding:0 32px;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.topbar h1{font-family:var(--font-head);font-size:22px;font-weight:900;color:var(--ink)}
.page-content{padding:32px;overflow-x:hidden}
.menu-toggle{display:none;background:none;border:none;font-size:22px;cursor:pointer;color:var(--ink)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:99}
.sidebar-overlay.visible{display:block}
@media(max-width:768px){#sidebar{transform:translateX(-100%)}#sidebar.open{transform:translateX(0)}#main{margin-left:0}.topbar{padding:0 16px}.page-content{padding:16px}.menu-toggle{display:block}}
/* DASHBOARD */
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}
.stat-card{background:var(--white);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow)}
.stat-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.stat-icon.blue{background:var(--foam)}.stat-icon.green{background:#D1FAE5}.stat-icon.orange{background:#FEF3C7}
.stat-value{font-family:var(--font-head);font-size:32px;font-weight:900;color:var(--ink);line-height:1}
.stat-label{font-size:13px;color:var(--slate);font-weight:600;margin-top:2px}
.welcome-banner{background:linear-gradient(135deg,var(--ocean) 0%,#2980D9 100%);border-radius:var(--radius);padding:28px 32px;margin-bottom:28px;display:flex;align-items:center;justify-content:space-between;gap:20px;box-shadow:var(--shadow-lg)}
.welcome-banner h2{font-family:var(--font-head);font-size:22px;font-weight:900;color:#fff;margin-bottom:6px}
.welcome-banner p{color:rgba(255,255,255,.8);font-size:14px;max-width:460px}
.plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.plan-card{background:var(--white);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);cursor:pointer;transition:all .2s;border:2px solid transparent}
.plan-card:hover{border-color:var(--ocean);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.plan-card h4{font-size:15px;font-weight:800;color:var(--ink);margin:10px 0 4px}
.plan-card .meta{font-size:12px;color:var(--mist)}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.section-header h3{font-family:var(--font-head);font-size:18px;font-weight:900;color:var(--ink)}
@media(max-width:600px){.stats-grid{grid-template-columns:1fr}.welcome-banner{flex-direction:column}}
/* PROFILE */
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.tipo-selector{display:flex;gap:12px;margin-top:4px}
.tipo-btn{flex:1;padding:14px;border-radius:12px;border:2px solid #E2E8F0;font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;background:var(--white);text-align:center}
.tipo-btn:hover{border-color:var(--ocean)}.tipo-btn.selected{background:var(--foam);border-color:var(--ocean);color:var(--ocean)}
@media(max-width:700px){.profile-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════
   EXPEDIENTE PEDAGÓGICO INTELIGENTE
══════════════════════════════════ */



/* ══════════════════════════════════
   VISTA ESTUDIANTES
══════════════════════════════════ */
/* Panel de historial por niño */



@media(max-width:768px){
}

/* ══════════════════════════════════
   LISTA DE COTEJO
══════════════════════════════════ */

/* Tabla wrapper con scroll horizontal en móvil */

/* Encabezado de tabla */
/* Sub-cabeceras I / EP / A / N·E */

/* Filas de estudiantes */

/* Celda con nombre del alumno */

/* Celda de calificación */

/* Botones de calificación */

/* Estado: inactivo */

/* Estado: activo */

/* Barra de progreso de cada columna */

/* Footer de acciones */

/* Barra resumen de arriba */

@media(max-width:768px){
}
#page-planner{min-height:100vh;background:linear-gradient(135deg,#0F2442 0%,#1A6FBF 100%);display:flex;align-items:stretch;overflow:hidden}
/* ── CONVERSATORIO SPLIT LAYOUT ── */
.conv-layout{display:flex;width:100%;height:100vh}
.conv-left{width:420px;flex-shrink:0;display:flex;flex-direction:column;height:100vh;overflow:hidden;background:rgba(255,255,255,0.04);backdrop-filter:blur(10px);border-right:1px solid rgba(255,255,255,0.12)}
.conv-right{flex:1;background:#F8F9FB;display:flex;flex-direction:column;overflow:hidden}
.conv-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,0.1)}
.conv-brand{display:flex;align-items:center;gap:10px}
.conv-brand-icon{width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;font-size:20px}
.conv-brand-name{font-size:14px;font-weight:800;color:#fff;letter-spacing:-.3px}
.conv-brand-sub{font-size:11px;color:rgba(255,255,255,.6);margin-top:1px}
.conv-close{background:rgba(255,255,255,0.1);border:none;color:rgba(255,255,255,.7);width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.conv-close:hover{background:rgba(255,255,255,0.2);color:#fff}
.conv-messages{flex:1;overflow-y:auto;padding:20px 16px;display:flex;flex-direction:column;gap:14px;scroll-behavior:smooth}
.conv-messages::-webkit-scrollbar{width:4px}
.conv-messages::-webkit-scrollbar-track{background:transparent}
.conv-messages::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.2);border-radius:4px}
.conv-bubble-bot{display:flex;gap:10px;max-width:92%}
.conv-avatar{width:32px;height:32px;border-radius:10px;background:var(--ocean);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:0 4px 12px rgba(26,111,191,0.4)}
.conv-text{background:rgba(255,255,255,0.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.15);color:#fff;padding:12px 16px;border-radius:4px 16px 16px 16px;font-size:13.5px;line-height:1.6;animation:msgIn .25s ease-out}
.conv-text strong{color:#fff}
.conv-text small{color:rgba(255,255,255,.6)}
.conv-bubble-user{display:flex;justify-content:flex-end;max-width:92%;align-self:flex-end}
.conv-bubble-user .conv-text{background:linear-gradient(135deg,rgba(255,255,255,0.22),rgba(255,255,255,0.15));border:1px solid rgba(255,255,255,0.25);border-radius:16px 4px 16px 16px;color:#fff}
.conv-chips{flex-shrink:0;display:flex;flex-wrap:wrap;gap:8px;padding:12px 16px;border-top:1px solid rgba(255,255,255,0.08);max-height:200px;overflow-y:auto;align-items:flex-start}
.conv-chips::-webkit-scrollbar{width:3px}
.conv-chips::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.2);border-radius:4px}
.conv-chip{background:rgba(255,255,255,0.1);border:1.5px solid rgba(255,255,255,0.25);color:#fff;padding:7px 14px;border-radius:20px;font-size:13px;font-weight:700;cursor:pointer;transition:all .18s;white-space:nowrap;font-family:var(--font-body)}
.conv-chip:hover{background:rgba(255,255,255,0.22);border-color:rgba(255,255,255,0.5);transform:translateY(-1px)}
.conv-chip.chip-destreza{border-radius:10px;white-space:normal;text-align:left;line-height:1.4;font-size:12px;font-weight:600;max-width:100%;display:block;width:100%}
.conv-chip.chip-destreza:hover{background:rgba(255,255,255,0.22)}
.conv-input-row{flex-shrink:0;display:flex;gap:8px;padding:12px 16px;border-top:1px solid rgba(255,255,255,0.08)}
.conv-input{flex:1;background:rgba(255,255,255,0.1);border:1.5px solid rgba(255,255,255,0.2);color:#fff;padding:10px 14px;border-radius:20px;font-family:var(--font-body);font-size:14px;outline:none;transition:border-color .2s}
.conv-input::placeholder{color:rgba(255,255,255,.4)}
.conv-input:focus{border-color:rgba(255,255,255,0.5);background:rgba(255,255,255,0.14)}
.conv-send{width:38px;height:38px;background:var(--ocean);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}
.conv-send:hover{background:#1559A0;transform:scale(1.05)}
/* ── PANEL DERECHO ── */
.conv-right-top{padding:20px 24px 16px;border-bottom:1px solid #E2E8F0;background:#fff}
.conv-right-top h3{font-family:var(--font-head);font-size:17px;font-weight:900;color:var(--ink);margin-bottom:2px}
.conv-right-top p{font-size:12px;color:var(--mist)}
.conv-right-body{flex:1;overflow-y:auto;padding:20px 24px}
.conv-right-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--mist);text-align:center;gap:12px}
.conv-right-empty .icon{font-size:52px;opacity:.4}
.conv-right-empty p{font-size:14px;font-weight:600;opacity:.6}
/* Tarjetas de resumen */
.plan-summary-card{background:#fff;border:1.5px solid #E2E8F0;border-radius:14px;padding:16px 18px;margin-bottom:12px;transition:all .2s}
.plan-summary-card.done{border-color:#BBF7D0;background:#F0FDF4}
.plan-summary-card.active{border-color:var(--ocean);box-shadow:0 0 0 3px rgba(26,111,191,.1)}
.plan-day-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--mist);margin-bottom:8px}
.plan-ambito-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:6px}
.plan-ambito-dot{width:8px;height:8px;border-radius:50%;background:var(--ocean);flex-shrink:0;margin-top:5px}
.plan-ambito-name{font-size:13px;font-weight:700;color:var(--ink)}
.plan-destreza-text{font-size:11.5px;color:var(--mist);line-height:1.4;margin-top:2px}
.plan-header-card{background:linear-gradient(135deg,var(--ocean),#2980D9);border-radius:14px;padding:16px 18px;margin-bottom:16px;color:#fff}
.plan-header-card h4{font-family:var(--font-head);font-size:16px;font-weight:900;margin-bottom:6px}
.plan-header-meta{font-size:12px;opacity:.8;display:flex;flex-direction:column;gap:3px}
/* Resultado final */
.conv-result{padding:20px 24px;display:flex;flex-direction:column;gap:12px}
.conv-result-success{background:linear-gradient(135deg,#065F46,#059669);border-radius:14px;padding:20px;color:#fff;text-align:center}
.conv-result-success h3{font-family:var(--font-head);font-size:20px;font-weight:900;margin-bottom:8px}
.conv-result-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:50px;font-family:var(--font-body);font-size:14px;font-weight:800;cursor:pointer;text-decoration:none;border:none;transition:all .2s}
/* loading dots */
.typing-dots{display:flex;gap:4px;align-items:center;padding:4px 0}
.typing-dots span{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.5);animation:typingDot .8s infinite}
.typing-dots span:nth-child(2){animation-delay:.15s}
.typing-dots span:nth-child(3){animation-delay:.3s}
@keyframes typingDot{0%,80%,100%{transform:scale(0.7);opacity:.5}40%{transform:scale(1);opacity:1}}
@keyframes msgIn{0%{opacity:0;transform:translateY(8px)}100%{opacity:1;transform:translateY(0)}}
@media(max-width:768px){
  .conv-layout{flex-direction:column;height:auto}
  .conv-left{width:100%;height:60vh;border-right:none;border-bottom:1px solid rgba(255,255,255,0.12)}
  .conv-right{min-height:40vh}
}
.planner-header{text-align:center;margin-bottom:24px}
.planner-header h2{font-family:var(--font-head);font-size:26px;font-weight:900;color:var(--ink)}
.planner-header p{color:var(--slate);font-size:14px;margin-top:4px}
.progress-bar-wrap{background:#E2E8F0;border-radius:50px;height:8px;margin-bottom:8px;overflow:hidden}
.progress-bar-fill{height:100%;background:var(--ocean);border-radius:50px;transition:width .4s ease}
.progress-label{font-size:13px;color:var(--slate);font-weight:600;text-align:right;margin-bottom:24px}
.steps-indicator{display:flex;align-items:center;justify-content:center;margin-bottom:32px;overflow-x:auto;padding-bottom:4px}
.step-dot{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:60px}
.step-dot .dot{width:34px;height:34px;border-radius:50%;border:3px solid #E2E8F0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:var(--mist);background:var(--white);transition:all .3s}
.step-dot .dot.done{background:var(--mint);border-color:var(--mint);color:#fff}
.step-dot .dot.active{background:var(--ocean);border-color:var(--ocean);color:#fff}
.step-dot span{font-size:10px;font-weight:700;color:var(--mist);white-space:nowrap;text-align:center}
.step-line{flex:1;height:3px;background:#E2E8F0;min-width:16px;max-width:60px;transition:background .3s}
.step-line.done{background:var(--mint)}
.step-heading{margin-bottom:20px}
.step-heading h3{font-family:var(--font-head);font-size:20px;font-weight:900;color:var(--ink)}
.step-heading p{font-size:14px;color:var(--slate);margin-top:4px}
/* Age */
.age-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.age-card{border:2px solid #E2E8F0;border-radius:14px;padding:20px 12px;text-align:center;cursor:pointer;transition:all .2s;background:var(--white)}
.age-card:hover{border-color:var(--sky)}.age-card.selected{border-color:var(--ocean);background:var(--foam)}
.age-card .emoji{font-size:34px;display:block;margin-bottom:8px}
.age-card .label{font-size:13px;font-weight:700;color:var(--ink)}
/* Ambito */
.ambito-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.ambito-card{border:2px solid #E2E8F0;border-radius:12px;padding:14px 16px;cursor:pointer;transition:all .2s;background:var(--white);display:flex;align-items:center;gap:12px}
.ambito-card:hover:not(.locked):not(.disabled){border-color:var(--sky)}
.ambito-card.selected{border-color:var(--ocean);background:var(--foam)}
.ambito-card.locked{border-color:var(--ocean);background:var(--foam);cursor:not-allowed}
.ambito-card.disabled{opacity:.4;cursor:not-allowed}
.ambito-check{width:22px;height:22px;border-radius:6px;border:2px solid #E2E8F0;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s}
.ambito-card.selected .ambito-check,.ambito-card.locked .ambito-check{background:var(--ocean);border-color:var(--ocean);color:#fff}
.ambito-label{font-size:13px;font-weight:700;color:var(--ink);line-height:1.3}
.ambito-counter{text-align:right;font-size:13px;color:var(--slate);font-weight:600;margin-top:10px}
/* Day tabs */
.day-tabs{display:flex;gap:8px;margin-bottom:20px;overflow-x:auto;padding-bottom:4px}
.day-tab{padding:8px 18px;border-radius:50px;border:2px solid #E2E8F0;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .2s;background:var(--white);color:var(--slate)}
.day-tab:hover{border-color:var(--sky)}.day-tab.active{background:var(--ocean);border-color:var(--ocean);color:#fff}
.day-tab.done{border-color:var(--mint);color:var(--mint)}
.day-tab.active.done{background:var(--mint);border-color:var(--mint);color:#fff}
/* Destrezas */
.destreza-list{display:flex;flex-direction:column;gap:8px;max-height:380px;overflow-y:auto;padding-right:4px}
.destreza-card{border:2px solid #E2E8F0;border-radius:12px;padding:12px 16px;cursor:pointer;transition:all .2s;background:var(--white);display:flex;align-items:flex-start;gap:12px}
.destreza-card:hover{border-color:var(--sky)}.destreza-card.selected{border-color:var(--ocean);background:var(--foam)}
.destreza-check{width:22px;height:22px;border-radius:6px;border:2px solid #E2E8F0;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .2s}
.destreza-card.selected .destreza-check{background:var(--ocean);border-color:var(--ocean);color:#fff}
.destreza-text{font-size:13px;color:var(--ink);line-height:1.4}
.destreza-ambito-tag{font-size:11px;color:var(--mist);font-weight:700;margin-top:2px}
.destreza-counter{text-align:right;font-size:13px;color:var(--slate);font-weight:600;margin-top:8px}
/* Summary */
.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
.summary-item{background:var(--cloud);border-radius:10px;padding:12px 16px}
.summary-item .s-label{font-size:11px;font-weight:800;color:var(--mist);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.summary-item .s-value{font-size:14px;font-weight:700;color:var(--ink)}
.day-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid #E2E8F0}
.day-row:last-child{border:none}
.day-badge{font-size:11px;font-weight:800;background:var(--foam);color:var(--ocean);padding:3px 10px;border-radius:20px;white-space:nowrap;margin-top:2px;flex-shrink:0}
/* S4 day ambito+destreza */
.s4-ambito-section{margin-bottom:20px}
.s4-ambito-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.s4-ambito-title{font-size:13px;font-weight:800;color:var(--ink)}
.s4-ambito-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:6px}
.s4-ambito-pick{border:2px solid #E2E8F0;border-radius:10px;padding:10px 14px;cursor:pointer;transition:all .2s;background:var(--white);display:flex;align-items:center;gap:10px;font-size:13px;font-weight:700;color:var(--ink)}
.s4-ambito-pick:hover:not(.locked):not(.disabled){border-color:var(--sky)}
.s4-ambito-pick.selected{border-color:var(--ocean);background:var(--foam)}
.s4-ambito-pick.locked{border-color:var(--ocean);background:var(--foam);cursor:not-allowed}
.s4-ambito-pick.disabled{opacity:.4;cursor:not-allowed}
.s4-check{width:20px;height:20px;border-radius:5px;border:2px solid #E2E8F0;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .2s}
.s4-ambito-pick.selected .s4-check,.s4-ambito-pick.locked .s4-check{background:var(--ocean);border-color:var(--ocean);color:#fff}
.s4-destreza-panel{background:var(--cloud);border-radius:12px;padding:14px;margin-top:6px}
.s4-destreza-panel h5{font-size:12px;font-weight:800;color:var(--slate);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.s4-day-counter{text-align:right;font-size:13px;color:var(--slate);font-weight:600;margin-top:12px;padding-top:10px;border-top:1px solid #E2E8F0}
.s4-friday{background:#FEF3C7;border:2px solid #F59E0B;border-radius:14px;padding:28px;text-align:center}
.s4-friday .icon{font-size:48px;margin-bottom:12px}
.s4-friday h3{font-family:var(--font-head);font-size:22px;font-weight:900;color:#92400E}
.s4-friday p{color:#78350F;font-size:14px;margin-top:6px}
/* Generating */
.gen-wrap{text-align:center;padding:32px 0}
.gen-wrap .big-icon{font-size:64px;animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.gen-wrap h3{font-family:var(--font-head);font-size:22px;font-weight:900;color:var(--ink);margin-top:20px}
.dots span{animation:blink 1.4s infinite;display:inline-block}
.dots span:nth-child(2){animation-delay:.2s}.dots span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:0}40%{opacity:1}}
.planner-footer{display:flex;justify-content:space-between;align-items:center;margin-top:28px;padding-top:24px;border-top:1px solid #E2E8F0}
@media(max-width:500px){.age-grid{grid-template-columns:repeat(2,1fr)}.ambito-grid{grid-template-columns:1fr}.planner-modal{padding:20px 14px}.summary-grid{grid-template-columns:1fr}}
@keyframes floatLogo{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
@keyframes spinTimon{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes whirlpool{
  0%  {transform:rotate(0deg) scale(1);opacity:1}
  25% {transform:rotate(360deg) scale(1.2);opacity:1;filter:drop-shadow(0 0 20px rgba(0,194,255,0.9))}
  50% {transform:rotate(900deg) scale(1.4);opacity:1;filter:drop-shadow(0 0 35px rgba(245,176,65,0.9))}
  75% {transform:rotate(1260deg) scale(0.8);opacity:0.9;filter:drop-shadow(0 0 60px rgba(255,215,0,1))}
  90% {transform:rotate(1440deg) scale(0.2);opacity:0.6;filter:drop-shadow(0 0 80px rgba(255,255,255,1))}
  100%{transform:rotate(1440deg) scale(0);opacity:0;filter:none}
}
@keyframes goldenFlash{
  0%  {opacity:0}
  50% {opacity:1;background:radial-gradient(circle,rgba(255,215,0,0.6) 0%,rgba(255,140,0,0.3) 40%,transparent 70%)}
  100%{opacity:0}
}
@keyframes fadeOutPage{0%{opacity:1}100%{opacity:0;pointer-events:none}}
@keyframes timonExplode{
  0%  {opacity:0;transform:rotate(0deg) scale(0.2)}
  10% {opacity:1;transform:rotate(270deg) scale(1)}
  50% {transform:rotate(1440deg) scale(3);filter:drop-shadow(0 0 30px rgba(255,200,0,0.9))}
  80% {transform:rotate(2520deg) scale(10);filter:drop-shadow(0 0 60px rgba(255,215,0,1));opacity:1}
  100%{transform:rotate(3240deg) scale(25);opacity:0}
}
@media(max-width:968px){#page-login>div{flex-direction:column-reverse!important;padding:2rem!important}#page-login>div>div:last-child{padding-left:0!important;align-items:center!important;text-align:center!important;margin-bottom:3rem}}

/* UPGRADE MODAL & PRICING TIERS */
.upgrade-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.85);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity 0.3s ease;}
.upgrade-overlay.visible{opacity:1;pointer-events:auto;}
.upgrade-modal{background:var(--white);border-radius:24px;width:100%;max-width:900px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px rgba(0,0,0,0.5);position:relative;}
.upgrade-header{padding:40px 40px 20px;text-align:center;}
.upgrade-header h2{font-family:var(--font-head);font-size:32px;font-weight:900;color:var(--ink);margin-bottom:12px;line-height:1.2;}
.upgrade-header p{color:var(--slate);font-size:16px;max-width:500px;margin:0 auto;}
.tiers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:20px 40px 40px;}
.tier-box{border:2px solid #E2E8F0;border-radius:20px;padding:32px 24px;display:flex;flex-direction:column;position:relative;background:#fff;transition:all 0.3s;}
.tier-box:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(0,0,0,0.08);}
.tier-box.popular{border-color:var(--ocean);box-shadow:0 8px 24px rgba(26,111,191,0.15);}
.tier-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--ocean);color:#fff;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;padding:4px 12px;border-radius:20px;white-space:nowrap;}
.tier-name{font-size:18px;font-weight:800;color:var(--ink);margin-bottom:8px;}
.tier-price{font-family:var(--font-head);font-size:36px;font-weight:900;color:var(--ink);margin-bottom:24px;line-height:1;}
.tier-price span{font-size:16px;color:var(--mist);font-weight:500;font-family:var(--font-body);}
.tier-features{flex:1;margin-bottom:32px;}
.tier-feature{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;font-size:14px;color:var(--slate);line-height:1.4;}
.tier-feature i{color:var(--mint);font-size:16px;font-style:normal;font-weight:bold;}
.tier-btn{width:100%;padding:14px;border-radius:12px;font-size:15px;font-weight:800;border:none;cursor:pointer;transition:all 0.2s;}
.tier-btn-outline{background:#fff;border:2px solid var(--ocean);color:var(--ocean);}
.tier-btn-outline:hover{background:var(--foam);}
.tier-btn-solid{background:var(--ocean);color:#fff;}
.tier-btn-solid:hover{background:#1559A0;box-shadow:0 4px 12px rgba(26,111,191,0.3);}
.close-upgrade{position:absolute;top:20px;right:20px;background:none;border:none;font-size:24px;color:var(--mist);cursor:pointer;transition:color 0.2s;}
.close-upgrade:hover{color:var(--ink);}

/* PAYMENT SUCCESS CELEBRATION */
#payment-success-overlay{position:fixed;inset:0;z-index:99999;background:linear-gradient(135deg,#1A6FBF 0%,#3B9EE8 50%,#0EA5E9 100%);display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .5s ease}
#payment-success-overlay.visible{opacity:1;pointer-events:auto}
.success-card{background:rgba(255,255,255,0.15);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.3);border-radius:28px;padding:48px 40px;max-width:500px;width:100%;text-align:center;box-shadow:0 32px 80px rgba(0,0,0,0.3);animation:successCardIn .6s cubic-bezier(0.34,1.56,0.64,1) forwards}
@keyframes successCardIn{from{transform:scale(0.7) translateY(40px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.success-logo{max-width:140px;margin:0 auto 20px;filter:drop-shadow(0 4px 16px rgba(0,0,0,0.3))}
.success-title{font-family:var(--font-head);font-size:32px;font-weight:900;color:#fff;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;text-shadow:0 2px 8px rgba(0,0,0,0.2)}
.success-msg{font-size:17px;color:rgba(255,255,255,0.92);margin-bottom:32px;line-height:1.5;font-weight:600}
.success-btn{background:#fff;color:var(--ocean);border:none;border-radius:50px;padding:16px 36px;font-family:var(--font-body);font-size:16px;font-weight:800;cursor:pointer;transition:all .2s;box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.success-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,0.25)}
#confetti-canvas{position:fixed;inset:0;z-index:99998;pointer-events:none}
/* ══════════════════════════════════
   KIT DE RECURSOS PEDAGÓGICOS
══════════════════════════════════ */
.kit-hero{background:linear-gradient(135deg,#0F4C81 0%,#1A6FBF 45%,#2DBD8E 100%);border-radius:var(--radius);padding:28px 32px;margin-bottom:24px;display:flex;align-items:center;justify-content:space-between;gap:24px;box-shadow:var(--shadow-lg)}
.kit-hero-label{font-size:11px;font-weight:800;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px}
.kit-hero-title{font-family:var(--font-head);font-size:24px;font-weight:900;color:#fff;margin-bottom:6px}
.kit-hero-sub{color:rgba(255,255,255,.8);font-size:14px;max-width:420px;line-height:1.5}
.kit-hero-plan-selector{min-width:240px;max-width:380px;flex:1;display:flex;flex-direction:column;gap:6px}
.kit-plan-label{font-size:11px;font-weight:800;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.8px}
.kit-select{padding:12px 16px;border-radius:10px;border:none;font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--ink);background:#fff;outline:none;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,.2)}

/* TABS */
.kit-tabs{display:flex;gap:8px;margin-bottom:24px;background:var(--white);border-radius:12px;padding:6px;box-shadow:var(--shadow);width:fit-content}
.kit-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:9px;border:none;background:transparent;font-family:var(--font-body);font-size:14px;font-weight:700;color:var(--slate);cursor:pointer;transition:all .2s}
.kit-tab:hover{background:var(--cloud);color:var(--ink)}
.kit-tab.active{background:var(--ocean);color:#fff;box-shadow:0 4px 14px rgba(26,111,191,.30)}
.kit-tab-icon{font-size:16px}
.kit-tab-badge{background:rgba(255,255,255,.25);color:inherit;font-size:11px;font-weight:800;padding:2px 8px;border-radius:20px;min-width:20px;text-align:center}
.kit-tab:not(.active) .kit-tab-badge{background:var(--ocean);color:#fff}

/* SECCIÓN FÍSICA */
.kit-section-intro{margin-bottom:20px;color:var(--slate);font-size:14px}
.kit-fisicos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.kit-categoria-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.kit-cat-header{display:flex;align-items:center;gap:14px;padding:18px 20px;border-bottom:1px solid #F0F4F8}
.kit-cat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.kit-cat-title{font-weight:800;font-size:15px;color:var(--ink)}
.kit-cat-sub{font-size:12px;color:var(--mist);margin-top:2px}
.kit-cat-progress{margin-left:auto;font-size:12px;font-weight:800;color:var(--mint);white-space:nowrap;background:#D1FAE5;padding:4px 12px;border-radius:20px}
.kit-checklist{padding:16px 20px;display:flex;flex-direction:column;gap:10px}
.kit-check-item{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px 10px;border-radius:8px;transition:background .15s}
.kit-check-item:hover{background:var(--cloud)}
.kit-check-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--mint);cursor:pointer;flex-shrink:0}
.kit-check-item span{font-size:13px;font-weight:600;color:var(--slate)}
.kit-check-item:has(input:checked) span{text-decoration:line-through;color:var(--mist)}

/* SECCIÓN DIGITAL */
.kit-empty-state{text-align:center;padding:64px 24px;color:var(--mist)}
.kit-empty-icon{font-size:56px;margin-bottom:16px}
.kit-empty-title{font-family:var(--font-head);font-size:20px;font-weight:900;color:var(--ink);margin-bottom:8px}
.kit-empty-sub{font-size:14px;max-width:380px;margin:0 auto;line-height:1.6}

.kit-resources-intro{display:flex;align-items:center;gap:16px;background:var(--foam);border-radius:12px;padding:16px 20px;margin-bottom:24px;border:1px solid rgba(26,111,191,.15)}
.kit-ri-icon{font-size:28px;flex-shrink:0}
.kit-ri-title{font-weight:800;font-size:15px;color:var(--ink)}
.kit-ri-sub{font-size:13px;color:var(--slate);margin-top:2px}

.kit-recursos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}

/* TARJETA DE RECURSO */
.kit-recurso-card{background:var(--white);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;transition:all .2s;border:2px solid transparent}
.kit-recurso-card:hover{box-shadow:var(--shadow-lg);border-color:rgba(26,111,191,.15);transform:translateY(-2px)}
.kit-recurso-top{padding:20px 20px 16px;display:flex;align-items:flex-start;gap:14px}
.kit-recurso-type-icon{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.kit-recurso-info{flex:1;min-width:0}
.kit-recurso-type-label{font-size:10px;font-weight:800;color:var(--mist);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.kit-recurso-name{font-weight:800;font-size:15px;color:var(--ink);line-height:1.35}
.kit-recurso-desc{font-size:12px;color:var(--slate);margin-top:4px;line-height:1.45}

.kit-recurso-body{padding:0 20px 20px}
.kit-recurso-placeholder{background:var(--cloud);border-radius:12px;min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;border:2px dashed #CBD5E0;position:relative;overflow:hidden;transition:all .3s}
.kit-recurso-placeholder.loading{background:linear-gradient(90deg,#F0F4F8 25%,#E2E8F0 50%,#F0F4F8 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.kit-placeholder-icon{font-size:36px;opacity:.35}
.kit-placeholder-text{font-size:12px;font-weight:700;color:var(--mist)}

/* Estado: imagen generada (placeholder visual) */
.kit-recurso-placeholder.generated{background:linear-gradient(135deg,#E8F4FD 0%,#D1FAE5 100%);border:2px solid #2DBD8E;min-height:180px}
.kit-generated-img-mock{width:100%;height:160px;border-radius:10px;background:linear-gradient(135deg,#a8edea,#fed6e3,#d7f5da,#fce4ec);display:flex;align-items:center;justify-content:center;font-size:40px;position:relative;overflow:hidden}
.kit-generated-img-mock::after{content:'✅ Listo para imprimir';position:absolute;bottom:8px;left:50%;transform:translateX(-50%);font-size:10px;font-weight:800;color:var(--mint);background:rgba(255,255,255,.85);padding:3px 12px;border-radius:20px;white-space:nowrap}

.kit-recurso-actions{padding:0 20px 20px;display:flex;flex-direction:column;gap:10px}
.kit-btn-generar{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 20px;background:linear-gradient(135deg,var(--ocean) 0%,var(--mint) 100%);color:#fff;border:none;border-radius:50px;font-family:var(--font-body);font-size:14px;font-weight:800;cursor:pointer;box-shadow:0 6px 20px rgba(26,111,191,.28);transition:all .2s}
.kit-btn-generar:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(26,111,191,.38)}
.kit-btn-generar:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}
.kit-btn-generar .spark{font-size:16px}
.kit-btn-generar.loading-state{background:linear-gradient(135deg,var(--slate) 0%,#4A5568 100%)}

.kit-action-row{display:flex;gap:8px}
.kit-btn-secondary{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 14px;border-radius:50px;font-family:var(--font-body);font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;border:2px solid #E2E8F0;background:var(--white);color:var(--slate)}
.kit-btn-secondary:hover{border-color:var(--ocean);color:var(--ocean);background:var(--foam)}

/* TYPE COLORS */
.kit-type-colorear{background:#FFF7ED;color:#EA580C}
.kit-type-trazos{background:#F0FDF4;color:#16A34A}
.kit-type-canto{background:#FDF4FF;color:#9333EA}
.kit-type-cuento{background:#EFF6FF;color:#2563EB}
.kit-type-mensaje{background:#FFF1F2;color:#E11D48}
.kit-type-actividad{background:#FEFCE8;color:#CA8A04}

@media(max-width:900px){.kit-fisicos-grid{grid-template-columns:1fr}}
@media(max-width:600px){.kit-hero{flex-direction:column}.kit-hero-plan-selector{width:100%}.kit-tabs{width:100%}.kit-tab{flex:1;justify-content:center}.kit-recursos-grid{grid-template-columns:1fr}}

.kit-plan-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--white);border-radius:var(--radius);padding:18px 22px;box-shadow:var(--shadow);margin-bottom:16px}
.kit-plan-info{}
.kit-plan-semana{font-family:var(--font-head);font-size:17px;font-weight:900;color:var(--ink);margin-bottom:3px}
.kit-plan-progreso{font-size:13px;color:var(--mist);font-weight:600}
.kit-btn-whatsapp{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#25D366;color:#fff;border:none;border-radius:50px;font-family:var(--font-body);font-size:14px;font-weight:800;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px rgba(37,211,102,.3);white-space:nowrap}
.kit-btn-whatsapp:hover{background:#1EBE5D;transform:translateY(-1px);box-shadow:0 6px 18px rgba(37,211,102,.4)}
.kit-barra-wrap{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.kit-barra-outer{flex:1;height:8px;background:#E2E8F0;border-radius:20px;overflow:hidden}
.kit-barra-fill{height:100%;background:linear-gradient(90deg,var(--ocean),var(--mint));border-radius:20px;transition:width .4s ease}
.kit-barra-pct{font-size:13px;font-weight:800;color:var(--mint);min-width:36px;text-align:right}
.kit-whatsapp-nota{font-size:12px;color:var(--slate);background:#F0FDF4;border:1px solid #BBF7D0;border-radius:10px;padding:10px 14px;margin-bottom:20px;line-height:1.5}
.kit-materiales-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.kit-mat-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:all .2s;border:2px solid transparent}
.kit-mat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.kit-mat-card.completado{border-color:#BBF7D0;background:#F0FDF4}
.kit-mat-header{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid #F0F4F8}
.kit-mat-dia{font-size:10px;font-weight:800;color:var(--white);padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}
.kit-mat-ambito{font-size:12px;font-weight:700;color:var(--mist);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kit-mat-body{padding:14px 18px}
.kit-mat-lista{display:flex;flex-direction:column;gap:8px}
.kit-mat-item{display:flex;align-items:flex-start;gap:10px;cursor:pointer;padding:6px 8px;border-radius:8px;transition:background .15s}
.kit-mat-item:hover{background:var(--cloud)}
.kit-mat-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--mint);cursor:pointer;flex-shrink:0;margin-top:2px}
.kit-mat-item span{font-size:13px;font-weight:600;color:var(--slate);line-height:1.4}
.kit-mat-item:has(input:checked) span{text-decoration:line-through;color:var(--mist)}
@media(max-width:600px){.kit-plan-header{flex-direction:column;align-items:flex-start}.kit-materiales-grid{grid-template-columns:1fr}}
.doc-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;display:flex;flex-direction:column;gap:12px;transition:all .2s;border:2px solid transparent}
.doc-card:hover{box-shadow:var(--shadow-lg);border-color:rgba(26,111,191,.15);transform:translateY(-2px)}
.doc-icon{font-size:36px}
.doc-info{flex:1}
.doc-title{font-family:var(--font-head);font-size:16px;font-weight:900;color:var(--ink);margin-bottom:4px}
.doc-meta{font-size:11px;font-weight:800;color:var(--mist);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.doc-desc{font-size:13px;color:var(--slate);line-height:1.5}
.doc-btn{display:inline-flex;align-items:center;padding:9px 18px;background:var(--ocean);color:#fff;border-radius:50px;font-family:var(--font-body);font-size:13px;font-weight:800;text-decoration:none;transition:all .2s;align-self:flex-start}
.doc-btn:hover{background:#1559A0;transform:translateY(-1px)}
.kit-recurso-card-fabrica{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;transition:all .2s;border:2px solid transparent}
.kit-recurso-card-fabrica:hover{box-shadow:var(--shadow-lg);border-color:rgba(26,111,191,.15);transform:translateY(-2px)}
.kit-fab-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.kit-fab-name{font-weight:800;font-size:15px;color:var(--ink)}
.kit-fab-desc{font-size:12px;color:var(--mist);line-height:1.4}
.bot-sugerencia{padding:5px 10px;border-radius:20px;border:1px solid #E2E8F0;background:#fff;font-family:var(--font-body);font-size:11px;font-weight:700;color:var(--slate);cursor:pointer;transition:all .15s;white-space:nowrap}
.bot-sugerencia:hover{border-color:var(--ocean);color:var(--ocean);background:var(--foam)}
.msg-user{align-self:flex-end;background:linear-gradient(135deg,var(--ocean),#2980D9);color:#fff;padding:9px 14px;border-radius:16px 16px 4px 16px;font-size:13px;max-width:85%;line-height:1.45;word-break:break-word}
.msg-ai{align-self:flex-start;background:#fff;border:1px solid #E2E8F0;color:var(--ink);padding:9px 14px;border-radius:16px 16px 16px 4px;font-size:13px;max-width:90%;line-height:1.5;box-shadow:0 2px 8px rgba(0,0,0,.06);word-break:break-word}
.msg-thinking{align-self:flex-start;color:var(--mist);font-size:12px;padding:4px 0;display:flex;align-items:center;gap:6px}
.msg-thinking .dots span{display:inline-block;animation:dotBounce .8s infinite;font-size:16px;line-height:1}
.msg-thinking .dots span:nth-child(2){animation-delay:.15s}
.msg-thinking .dots span:nth-child(3){animation-delay:.3s}
@keyframes dotBounce{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-4px)}}
@keyframes flashUpdate{0%{box-shadow:0 0 0 3px rgba(45,189,142,.0)}30%{box-shadow:0 0 0 4px rgba(45,189,142,.6);background:rgba(45,189,142,.08)}100%{box-shadow:0 0 0 0 rgba(45,189,142,.0)}}
.plan-updated{animation:flashUpdate 1.5s ease forwards}
.freemium-banner{background:#FEF3C7;border:1px solid #F59E0B;border-radius:12px;padding:16px 20px;margin-bottom:24px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.freemium-text{display:flex;align-items:center;gap:12px;color:#92400E;font-size:14px;font-weight:600;}
.freemium-icon{font-size:20px;}
@media(max-width:900px){.tiers-grid{grid-template-columns:1fr;padding:20px;}.freemium-banner{flex-direction:column;text-align:center;}}