@import url('https://fonts.cdnfonts.com/css/astonpoliz');
@import url('https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&family=Inter:wght@400;500;600;700;800&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

:root{
  --brand:    #0eb2f1;
  --brand-dk: #0899d4;
  --brand-lt: #e8f7fd;
  --brand-md: #b3e5f8;
  --bg:       #f4faff;
  --sf:       #ffffff;
  --sf2:      #f8fbff;
  --bd:       #e2eef8;
  --bd2:      #cde0f0;
  --tx:       #2c3a4a;
  --tx2:      #4a5c6e;
  --dim:      #8ba3ba;
  --ac2:      #e84c6a;
  --ac4:      #6366f1;
  --ui:       'Inter', sans-serif;
  --mono:     'Space Mono', monospace;
  --r:        10px;
  --shadow-sm: 0 1px 4px rgba(44,58,74,.06);
  --shadow:    0 4px 16px rgba(44,58,74,.08);
  --shadow-lg: 0 12px 40px rgba(14,178,241,.10);
}

html,body{height:100%;background:var(--bg);color:var(--tx);font-family:var(--ui);overflow:hidden;-webkit-font-smoothing:antialiased;}

/* ══════════════════════════════════════════
   MARCA
══════════════════════════════════════════ */
.logo-name{font-family:'AstonPoliz',sans-serif;font-size:21px;line-height:1;color:var(--tx);}
.logo-name .xi,.login-app-name .xi{color:var(--brand);}
.login-app-name{font-family:'AstonPoliz',sans-serif;font-size:32px;line-height:1;color:var(--tx);}

/* ══════════════════════════════════════════
   HEADER — delgado, blanco, sombra mínima
══════════════════════════════════════════ */
header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;height:54px;
  background:var(--sf);
  border-bottom:1px solid var(--bd);
  box-shadow:var(--shadow-sm);
  z-index:10;gap:12px;
}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}

/* Ícono: cuadrícula 2×2 con color marca */
.logo-mark{
  width:30px;height:30px;
  background:var(--brand);
  border-radius:8px;
  display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;
  gap:3px;padding:6px;
  box-shadow:0 2px 8px rgba(14,178,241,.25);
}
.logo-mark span{border-radius:2px;background:rgba(255,255,255,.9);display:block;}

/* Badge ejercicio activo */
#exBadge{
  display:none;align-items:center;gap:6px;
  background:var(--brand-lt);
  border:1px solid var(--brand-md);
  border-radius:20px;
  padding:4px 12px;
  font-size:11px;font-weight:600;color:var(--brand-dk);
}
#exBadge.on{display:flex;}
#exBadge span{font-size:10px;color:var(--dim);font-weight:400;}

/* User badge */
#userBadge{
  display:none;align-items:center;gap:6px;
  background:var(--brand-lt);border:1px solid var(--brand-md);
  border-radius:20px;padding:4px 12px;
  font-size:11px;font-weight:600;color:var(--brand-dk);
}

/* ══════════════════════════════════════════
   BOTONES — más limpios, menos borde
══════════════════════════════════════════ */
.hbtns{display:flex;align-items:center;gap:5px;flex-wrap:wrap;}
.btn{
  padding:6px 14px;border-radius:8px;
  font-family:var(--ui);font-size:11px;font-weight:600;
  cursor:pointer;border:none;
  transition:all .15s;
  display:flex;align-items:center;gap:5px;
  white-space:nowrap;letter-spacing:.2px;
}

/* Ghost — sin borde visible, solo fondo al hover */
.btn-g{background:transparent;color:var(--dim);border:1px solid transparent;}
.btn-g:hover{color:var(--tx);background:var(--sf2);border-color:var(--bd);}

/* Primary — brand sólido */
.btn-p{background:var(--brand);color:#fff;box-shadow:0 2px 6px rgba(14,178,241,.2);}
.btn-p:hover{background:var(--brand-dk);box-shadow:0 4px 12px rgba(14,178,241,.3);transform:translateY(-1px);}

/* Danger */
.btn-d{background:transparent;color:var(--ac2);border:1px solid rgba(232,76,106,.25);}
.btn-d:hover{background:rgba(232,76,106,.06);border-color:var(--ac2);}

/* Secondary */
.btn-v{background:var(--brand-lt);color:var(--brand-dk);border:1px solid var(--brand-md);}
.btn-v:hover{background:var(--brand-md);color:var(--brand-dk);}

/* Indicador de ejecución */
.run-ind{display:none;align-items:center;gap:6px;color:var(--brand-dk);font-size:11px;font-weight:600;}
.run-ind.on{display:flex;}
.rdot{width:6px;height:6px;border-radius:50%;background:var(--brand);animation:pu .9s ease infinite;}
@keyframes pu{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

/* ══════════════════════════════════════════
   LAYOUT
══════════════════════════════════════════ */
.ide-layout{display:grid;grid-template-columns:75% 25%;height:calc(100vh - 54px - 22px);}

/* Panel Blockly */
.blk-panel{position:relative;overflow:hidden;border-right:1px solid var(--bd);background:var(--bg);}
.panel-lbl{
  position:absolute;top:12px;left:16px;
  font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--dim);opacity:.7;z-index:5;pointer-events:none;
}
#blocklyDiv{width:100%;height:100%;}

/* ══════════════════════════════════════════
   PANEL DERECHO
══════════════════════════════════════════ */
.right{display:flex;flex-direction:column;overflow:hidden;background:var(--sf);}

/* Cabecera de sección */
.ph{
  padding:9px 14px;
  font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--dim);
  background:var(--sf2);
  border-bottom:1px solid var(--bd);
  flex-shrink:0;display:flex;align-items:center;gap:6px;
}
.ph .dot{width:4px;height:4px;border-radius:50%;background:var(--brand);}

/* Código generado */
.code-panel{flex:0 0 auto;max-height:35%;border-bottom:1px solid var(--bd);display:flex;flex-direction:column;overflow:hidden;}
.code-panel.hidden{display:none!important;}
#codeOut{
  flex:1;overflow:auto;padding:12px;
  font-family:var(--mono);font-size:10px;line-height:1.8;
  color:var(--tx2);background:var(--sf);white-space:pre;
}

/* Scrollbars */
#codeOut::-webkit-scrollbar,#termOut::-webkit-scrollbar{width:3px;}
#codeOut::-webkit-scrollbar-thumb,#termOut::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px;}

/* ══════════════════════════════════════════
   CONSOLA
══════════════════════════════════════════ */
.term-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;}
.term-hdr{
  padding:9px 14px;
  font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--dim);background:var(--sf2);border-bottom:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0;
}
.term-hdr-l{display:flex;align-items:center;gap:8px;}
.tdots{display:flex;gap:4px;}
.tdots span{width:8px;height:8px;border-radius:50%;}
.tr{background:#ff5f57;}.ty{background:#febc2e;}.tg{background:#27c840;}

#termOut{
  flex:1;overflow-y:auto;
  padding:14px;
  font-family:var(--mono);font-size:12px;line-height:2;
  background:var(--sf);color:var(--tx);
  min-height:0;
}
.tl{display:flex;align-items:flex-start;gap:8px;animation:fi .12s ease;}
@keyframes fi{from{opacity:0;transform:translateY(2px)}to{opacity:1;transform:none}}
.tp{color:var(--brand);flex-shrink:0;user-select:none;font-size:11px;}
.to{color:var(--tx);}
.ta{color:#c2410c;}
.te{color:var(--ac2);font-weight:600;}
.ts{color:var(--dim);font-style:italic;font-size:11px;}

/* Input area */
.inp-area{
  padding:8px 12px;background:var(--sf2);
  border-top:1px solid var(--bd);
  display:none;align-items:center;gap:8px;flex-shrink:0;
}
.inp-area.on{display:flex;}
#uIn{flex:1;background:transparent;border:none;outline:none;color:var(--tx);font-family:var(--mono);font-size:12px;}
#uOk{
  background:var(--brand);color:#fff;border:none;
  border-radius:6px;padding:5px 14px;font-size:11px;font-weight:600;cursor:pointer;
}
#uOk:hover{background:var(--brand-dk);}

/* ══════════════════════════════════════════
   STATUS BAR — minimalista
══════════════════════════════════════════ */
.sbar{
  height:22px;
  background:var(--sf);
  border-top:1px solid var(--bd);
  color:var(--dim);
  font-size:10px;font-weight:500;letter-spacing:.3px;
  display:flex;align-items:center;padding:0 16px;gap:12px;
}
.sbar .sep{color:var(--bd2);}

/* ══════════════════════════════════════════
   LOADING
══════════════════════════════════════════ */
#ov{
  position:fixed;inset:0;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:18px;z-index:999;
}
.spin{
  width:32px;height:32px;
  border:2px solid var(--bd);border-top-color:var(--brand);
  border-radius:50%;animation:sp .7s linear infinite;
}
@keyframes sp{to{transform:rotate(360deg)}}
#ov p{font-family:var(--ui);color:var(--dim);font-size:13px;font-weight:500;}

/* ══════════════════════════════════════════
   MODAL — estilo "Activity Details"
══════════════════════════════════════════ */
.modal-bg{
  position:fixed;inset:0;
  background:rgba(44,58,74,.2);
  z-index:500;display:none;align-items:center;justify-content:center;
  backdrop-filter:blur(6px);
}
.modal-bg.on{display:flex;}

.modal{
  background:var(--sf);
  border:1px solid var(--bd);
  border-radius:18px;
  width:680px;max-width:95vw;max-height:90vh;
  display:flex;flex-direction:column;overflow:hidden;
  box-shadow:var(--shadow-lg);
}

/* Header modal */
.modal-hdr{
  padding:18px 22px 16px;
  border-bottom:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;
}
.modal-hdr h2{font-size:15px;font-weight:700;color:var(--tx);letter-spacing:-.2px;}
.modal-hdr h2 em{color:var(--brand);font-style:normal;}

.modal-close{
  background:var(--sf2);border:1px solid var(--bd);color:var(--dim);
  border-radius:8px;cursor:pointer;padding:4px 9px;font-size:13px;
  transition:all .15s;
}
.modal-close:hover{color:var(--ac2);border-color:rgba(232,76,106,.3);background:rgba(232,76,106,.04);}

.modal-body{padding:20px 22px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px;}
.modal-footer{
  padding:14px 22px;
  border-top:1px solid var(--bd);
  display:flex;gap:8px;justify-content:flex-end;
  flex-shrink:0;background:var(--sf2);
}

/* ══════════════════════════════════════════
   TABS — línea fina bajo el activo
══════════════════════════════════════════ */
.tabs{
  display:flex;gap:0;
  border-bottom:1px solid var(--bd);
  flex-shrink:0;padding:0 22px;
  background:var(--sf);
}
.tab{
  padding:12px 16px;
  font-size:12px;font-weight:600;cursor:pointer;
  color:var(--dim);
  border:none;background:transparent;
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
  transition:all .15s;
}
.tab:hover{color:var(--tx2);}
.tab.on{color:var(--brand);border-bottom-color:var(--brand);}
.tab-body{display:none;flex-direction:column;gap:14px;}
.tab-body.on{display:flex;}

/* ══════════════════════════════════════════
   FORM FIELDS
══════════════════════════════════════════ */
.field{display:flex;flex-direction:column;gap:6px;}
.field label{
  font-size:10px;font-weight:700;
  color:var(--dim);letter-spacing:1px;text-transform:uppercase;
}
.field input,.field textarea,.field select{
  background:var(--sf2);
  border:1px solid var(--bd);
  border-radius:8px;
  color:var(--tx);font-family:var(--mono);font-size:12px;
  padding:9px 12px;outline:none;
  transition:all .15s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  border-color:var(--brand);
  background:#fff;
  box-shadow:0 0 0 3px rgba(14,178,241,.10);
}
.field textarea{resize:vertical;min-height:80px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* ══════════════════════════════════════════
   LISTA DE ITEMS (ejercicios, trabajos)
══════════════════════════════════════════ */
.ex-item{
  display:flex;align-items:center;gap:12px;
  background:var(--sf);
  border:1px solid var(--bd);
  border-radius:10px;
  padding:11px 14px;
  transition:all .15s;
}
.ex-item:hover{
  border-color:var(--brand-md);
  box-shadow:0 2px 10px rgba(14,178,241,.08);
  transform:translateY(-1px);
}
.ex-item.active{border-color:var(--brand);background:var(--brand-lt);}
.ex-item-info{flex:1;min-width:0;}
.ex-item-name{
  font-size:13px;font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  color:var(--tx);
}
.ex-item-id{font-size:10px;color:var(--dim);font-family:var(--mono);margin-top:2px;}
.ex-item-btns{display:flex;gap:4px;flex-shrink:0;}

/* ══════════════════════════════════════════
   CATS CHECK
══════════════════════════════════════════ */
.cats-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.cat-chk{
  display:flex;align-items:center;gap:8px;
  background:var(--sf2);border:1px solid var(--bd);border-radius:8px;
  padding:8px 12px;cursor:pointer;user-select:none;transition:all .15s;
}
.cat-chk:hover{border-color:var(--brand-md);background:var(--brand-lt);}
.cat-chk input{accent-color:var(--brand);width:14px;height:14px;cursor:pointer;}
.cat-chk span{font-size:12px;font-weight:500;color:var(--tx2);}

/* ══════════════════════════════════════════
   TOAST — notificación flotante
══════════════════════════════════════════ */
#toast{
  position:fixed;bottom:36px;left:50%;
  transform:translateX(-50%) translateY(12px);
  background:#fff;
  border:1px solid var(--bd);
  border-radius:12px;
  padding:10px 20px;
  font-size:13px;font-weight:600;
  opacity:0;transition:all .25s cubic-bezier(.34,1.56,.64,1);
  z-index:9999;pointer-events:none;
  box-shadow:var(--shadow);
}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
#toast.ok{border-color:var(--brand-md);color:var(--brand-dk);}
#toast.err{border-color:rgba(232,76,106,.3);color:var(--ac2);}

/* ══════════════════════════════════════════
   LOGIN MODAL
══════════════════════════════════════════ */
#modalLogin .modal{max-width:400px;border-radius:22px;}
.login-logo{display:flex;flex-direction:column;align-items:center;gap:14px;padding:16px 0 8px;}
.login-logo .logo-mark-lg{
  width:60px;height:60px;
  background:var(--brand);border-radius:16px;
  display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;
  gap:5px;padding:10px;
  box-shadow:0 8px 28px rgba(14,178,241,.28);
}
.login-logo .logo-mark-lg span{border-radius:3px;background:rgba(255,255,255,.92);display:block;}
.login-logo p{
  font-size:12px;color:var(--dim);
  text-align:center;max-width:220px;line-height:1.7;font-weight:400;
}

.login-input-wrap input{
  width:100%;
  background:var(--sf2);
  border:1px solid var(--bd);border-radius:12px;
  color:var(--tx);font-family:var(--mono);
  font-size:20px;font-weight:700;
  padding:14px 16px;outline:none;
  text-align:center;letter-spacing:5px;text-transform:uppercase;
  transition:all .2s;
}
.login-input-wrap input:focus{
  border-color:var(--brand);background:#fff;
  box-shadow:0 0 0 4px rgba(14,178,241,.12);
}
.login-input-wrap input.err{border-color:var(--ac2);animation:shake .3s ease;}
@keyframes shake{0%,100%{transform:none}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.login-hint{font-size:11px;color:var(--dim);text-align:center;line-height:1.7;}

/* ══════════════════════════════════════════
   DIRTY INDICATOR
══════════════════════════════════════════ */
#btnGuardarCambios.dirty{
  background:var(--brand-lt);
  border:1px solid var(--brand-md)!important;
  color:var(--brand-dk)!important;
}
