/* WebPanel DNNS — Tema Claro estilo Loxone */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,sans-serif;background:#f5f6f8;color:#2c3e50;min-height:100vh}
.oculto{display:none!important}
.pantalla{min-height:100vh}

/* Login */
#pantallaLogin{display:flex;justify-content:center;align-items:center;background:#f5f6f8}
.login-caja{background:#fff;padding:44px 40px;border-radius:16px;width:400px;box-shadow:0 4px 24px rgba(0,0,0,.06);border:1px solid #e8eaed}
.login-caja h1{text-align:center;color:#69c350;margin-bottom:4px;font-size:22px;font-weight:700}
.subtitulo{text-align:center;color:#8e9aaf;margin-bottom:32px;font-size:13px;font-weight:400}
.campo{margin-bottom:18px}
.campo label{display:block;margin-bottom:6px;color:#5a6a7e;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.campo input,.campo select{width:100%;padding:11px 14px;background:#f8f9fb;border:1px solid #dfe3e8;border-radius:8px;color:#2c3e50;font-size:14px;outline:none;transition:border-color .2s;font-family:inherit}
.campo input:focus,.campo select:focus{border-color:#69c350;background:#fff;box-shadow:0 0 0 3px rgba(105,195,80,.1)}

/* Botones */
.btn-primario{width:100%;padding:12px;background:#69c350;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;font-family:inherit}
.btn-primario:hover{background:#5bb043}
.btn-secundario{padding:8px 16px;background:#fff;color:#5a6a7e;border:1px solid #dfe3e8;border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s;font-family:inherit}
.btn-secundario:hover{color:#2c3e50;border-color:#bcc3ce;background:#f8f9fb}
.btn-peligro{padding:6px 12px;background:#fff0f0;color:#dc3545;border:1px solid #fdd;border-radius:6px;font-size:12px;cursor:pointer;font-family:inherit}
.btn-peligro:hover{background:#fde5e5}
.btn-accion{padding:6px 12px;background:#f0f7ee;color:#4a9e36;border:1px solid #d4eacc;border-radius:6px;font-size:12px;cursor:pointer;margin-right:4px;font-family:inherit}
.btn-accion:hover{background:#e2f0dc}
.error{margin-top:15px;padding:10px;background:#fff5f5;border:1px solid #fcc;border-radius:8px;color:#dc3545;text-align:center;font-size:13px}

/* Cabecera */
.cabecera{display:flex;justify-content:space-between;align-items:center;padding:14px 28px;background:#fff;border-bottom:1px solid #e8eaed;box-shadow:0 1px 3px rgba(0,0,0,.03)}
.cabecera h2{color:#69c350;font-size:17px;font-weight:700}
.cabecera-der{display:flex;align-items:center;gap:12px}
#infoUsuario{color:#8e9aaf;font-size:13px}

/* Navegacion */
.nav-principal{display:flex;gap:0;background:#fff;padding:0 28px;border-bottom:1px solid #e8eaed}
.nav-btn{padding:12px 24px;background:transparent;color:#8e9aaf;border:none;border-bottom:2px solid transparent;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}
.nav-btn:hover{color:#2c3e50}
.nav-btn.activo{color:#69c350;border-bottom-color:#69c350}

/* Contenido */
.contenido{padding:28px;max-width:1200px;margin:0 auto}
.seccion-cabecera{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.seccion-cabecera h3{font-size:18px;color:#2c3e50;font-weight:700}
.seccion-cabecera .btn-primario{width:auto;padding:10px 20px}

/* Tablas */
.tabla-contenedor{overflow-x:auto}
table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.04);border:1px solid #e8eaed}
thead{background:#f8f9fb}
th{padding:11px 16px;text-align:left;font-size:11px;color:#8e9aaf;font-weight:600;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid #e8eaed}
td{padding:12px 16px;font-size:13px;border-top:1px solid #f2f3f5;color:#2c3e50}
tr:hover{background:#f8faf7}

/* Badges */
.badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600}
.badge-activo{background:#e8f5e2;color:#3d8c29}
.badge-inactivo{background:#fde8e8;color:#c0392b}
.badge-pendiente{background:#fff3e0;color:#e67e22}
.badge-admin{background:#eef2ff;color:#4466cc}
.badge-cliente{background:#f0f7ee;color:#5aa03e}
.badge-superadmin{background:#f3eeff;color:#7c4dff}

/* Modal */
.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.25);display:flex;justify-content:center;align-items:center;z-index:1000}
.modal-contenido{background:#fff;border-radius:14px;width:480px;max-height:80vh;overflow-y:auto;box-shadow:0 16px 48px rgba(0,0,0,.12);border:1px solid #e8eaed}
.modal-cabecera{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e8eaed}
.modal-cabecera h3{font-size:16px;color:#2c3e50;font-weight:700}
.modal-cerrar{background:none;border:none;color:#8e9aaf;font-size:22px;cursor:pointer;padding:4px 8px;border-radius:6px}
.modal-cerrar:hover{color:#dc3545;background:#fff0f0}
.modal-cuerpo{padding:24px}
.modal-pie{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid #e8eaed;background:#f8f9fb;border-radius:0 0 14px 14px}
.modal-pie .btn-primario{width:auto;padding:10px 24px}

/* File Manager */
.arch-selector{margin-bottom:16px}
.arch-selector select{padding:9px 14px;background:#fff;border:1px solid #dfe3e8;border-radius:8px;color:#2c3e50;font-size:13px;outline:none;min-width:260px;font-family:inherit}
.arch-selector select:focus{border-color:#69c350}
.arch-ruta{display:flex;align-items:center;gap:4px;margin-bottom:14px;flex-wrap:wrap}
.arch-ruta-item{padding:5px 12px;background:#e8f5e2;border-radius:6px;color:#3d8c29;font-size:12px;cursor:pointer;border:none;font-family:inherit;font-weight:500}
.arch-ruta-item:hover{background:#d4eacc}
.arch-ruta-sep{color:#ccc;font-size:12px}
.arch-btns{display:flex;gap:6px}
.arch-btns .btn-primario{width:auto;padding:8px 16px;font-size:12px}
.arch-fila{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid #f2f3f5;cursor:default;transition:background .12s}
.arch-fila:hover{background:#f8faf7}
.arch-fila-icono{font-size:18px;margin-right:12px;min-width:24px;text-align:center}
.arch-fila-nombre{flex:1;font-size:13px;color:#2c3e50;font-weight:500}
.arch-fila-tamano{font-size:11px;color:#8e9aaf;min-width:80px;text-align:right;margin-right:12px}
.arch-fila-fecha{font-size:11px;color:#a0aab5;min-width:90px;text-align:right;margin-right:12px}
.arch-fila-borrar{padding:4px 12px;border-radius:6px;font-size:11px;cursor:pointer;font-family:inherit;border:1px solid #dfe3e8;background:#fff;color:#5a6a7e}
.arch-fila-borrar:hover{background:#f8f9fb}
.arch-vacio{text-align:center;padding:40px;color:#8e9aaf;font-size:13px}
.arch-upload-zona{border:2px dashed #dfe3e8;border-radius:10px;padding:30px;text-align:center;color:#8e9aaf;font-size:13px;margin-top:16px;cursor:pointer;transition:all .2s;background:#fafbfc}
.arch-upload-zona:hover{border-color:#69c350;color:#3d8c29;background:#f8faf7}
.arch-upload-zona.arrastrando{border-color:#69c350;background:#f0f7ee}

/* Editor */
.editor-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;z-index:200}
.editor-box{background:#fff;border:1px solid #e8eaed;border-radius:14px;width:92%;max-width:950px;height:82vh;display:flex;flex-direction:column;box-shadow:0 16px 48px rgba(0,0,0,.12)}
.editor-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid #e8eaed;background:#f8f9fb;border-radius:14px 14px 0 0}
.editor-header h3{font-size:14px;color:#2c3e50;font-family:Consolas,'Courier New',monospace;font-weight:600}
.editor-header-btns{display:flex;gap:8px}
.editor-area{flex:1;position:relative}
.editor-area textarea{width:100%;height:100%;padding:18px;background:#1e1e2e;border:none;color:#d4d4d4;font-family:Consolas,'Courier New',monospace;font-size:13px;line-height:1.7;resize:none;outline:none;tab-size:4}
.editor-footer{padding:10px 20px;border-top:1px solid #e8eaed;display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#8e9aaf;background:#f8f9fb;border-radius:0 0 14px 14px}

@media(max-width:768px){.login-caja{width:92%;padding:30px 20px}.cabecera{padding:12px 16px}.contenido{padding:16px}.modal-contenido{width:95%}th,td{padding:8px 10px;font-size:12px}}
