.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}:root{--bg-main:#0f172a;--bg-card:#1e293b;--accent:#38bdf8;--accent-glow:#38bdf840;--text-main:#f8fafc;--text-dim:#94a3b8;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--sidebar:#0b1120;--transition:.3s ease;--radius:14px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-main);min-height:100vh;transition:background-color var(--transition), color var(--transition);font-family:Poppins,sans-serif;display:flex}.container{width:100%;display:flex}.sidebar{background-color:var(--sidebar);border-right:1px solid #1e293b;flex-direction:column;width:260px;height:100vh;padding:36px 18px;display:flex;position:sticky;top:0}.profile-box{text-align:center;border-bottom:1px solid #1e293b;margin-bottom:28px;padding-bottom:24px}.profile-box h3{margin:8px 0 2px;font-size:1rem;font-weight:600}.profile-box p{color:var(--text-dim);font-size:.75rem}.avatar{background:linear-gradient(135deg, var(--accent), #818cf8);color:#0f172a;width:64px;height:64px;box-shadow:0 0 20px var(--accent-glow);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 12px;font-size:1.3rem;font-weight:700;display:flex}.badge-aprende{background:var(--accent-glow);border:1px solid var(--accent);color:var(--accent);letter-spacing:1px;border-radius:50px;margin-top:8px;padding:3px 12px;font-size:.65rem;font-weight:700;display:inline-block}nav{flex-direction:column;flex:1;gap:6px;display:flex}.nav-btn{color:var(--text-dim);text-align:left;cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:10px;width:100%;padding:11px 14px;font-family:Poppins,sans-serif;font-size:.85rem;font-weight:500}.nav-btn:hover{background:var(--accent-glow);color:var(--accent)}.nav-btn.active{background:var(--accent-glow);color:var(--accent);font-weight:700}.main-content{flex:1;padding:36px 40px;overflow-y:auto}header{margin-bottom:28px}header h1{font-size:1.5rem;font-weight:700}header p{color:var(--text-dim);margin-top:4px;font-size:.8rem}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid #33415599;margin-bottom:24px;padding:24px;box-shadow:0 4px 20px #00000026}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;margin-bottom:24px;display:grid}.stat-card{background:linear-gradient(145deg, var(--bg-card), #0f1a2e);border-radius:var(--radius);text-align:center;transition:transform var(--transition), border-color var(--transition);border:1px solid #334155;padding:20px}.stat-card:hover{border-color:var(--accent);transform:translateY(-4px)}.stat-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:.7rem;display:block}.stat-card h2{font-size:1.5rem;font-weight:700}.grid-inputs{grid-template-columns:2fr 1fr 1fr 1fr auto;align-items:start;gap:12px;margin-top:16px;display:grid}.input-group{flex-direction:column;gap:4px;display:flex}input,select{background:var(--bg-main);color:var(--text-main);transition:border-color var(--transition);border:1px solid #334155;border-radius:10px;outline:none;width:100%;padding:11px 14px;font-family:Poppins,sans-serif;font-size:.85rem}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}input.input-error{border-color:var(--danger)!important}.field-error{color:var(--danger);padding-left:2px;font-size:.7rem}.form-actions{align-items:flex-start;gap:8px;display:flex}button{background:var(--accent);color:#0f172a;cursor:pointer;transition:var(--transition);white-space:nowrap;border:none;border-radius:10px;padding:11px 18px;font-family:Poppins,sans-serif;font-size:.85rem;font-weight:700}button:hover{filter:brightness(1.1);box-shadow:0 0 18px var(--accent-glow)}button:disabled{opacity:.4;cursor:not-allowed;filter:none;box-shadow:none}.btn-cancelar{color:var(--text-dim);background:0 0;border:1px solid #334155}.btn-cancelar:hover{border-color:var(--danger);color:var(--danger);box-shadow:none}.btn-edit{color:var(--accent);background:0 0;padding:6px 10px;font-size:1rem}.btn-delete{color:var(--danger);background:0 0;padding:6px 10px;font-size:1rem}.btn-edit:hover,.btn-delete:hover{box-shadow:none;filter:none;transform:scale(1.2)}.dashboard-body{grid-template-columns:2fr 1fr;gap:20px;display:grid}.list-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.search-bar-group{gap:10px;display:flex}.search-bar-group input{width:200px}.search-bar-group select{width:160px}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:500px}th{text-align:left;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #334155;padding:10px 12px;font-size:.75rem}td{border-bottom:1px solid #33415566;padding:14px 12px;font-size:.85rem}tr:last-child td{border-bottom:none}tr:hover td{background:#38bdf808}.warning-row td{background:#ef44440d}.badge-danger{color:#fca5a5;background:#ef444426;border-radius:6px;margin-left:4px;padding:2px 6px;font-size:.7rem}.cat-badge{background:var(--accent-glow);color:var(--accent);border-radius:4px;margin-top:2px;padding:2px 7px;font-size:.68rem;display:inline-block}.chart-container{flex-direction:column;align-items:center;display:flex}.paginacion{color:var(--text-dim);border-top:1px solid #334155;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:16px;padding-top:12px;font-size:.8rem;display:flex}.pag-btns{gap:8px;display:flex}.pag-btns button{color:var(--text-dim);background:0 0;border:1px solid #334155;padding:6px 12px;font-size:.8rem;font-weight:500}.pag-btns button:hover{border-color:var(--accent);color:var(--accent);box-shadow:none}.log-list{color:#cbd5e1;background:#070e1a;border-radius:10px;max-height:160px;padding:14px;font-family:Courier New,monospace;font-size:.8rem;overflow-y:auto}.log-item{border-left:2px solid var(--accent);margin-bottom:7px;padding-left:10px}.log-item span{color:var(--accent);font-weight:700}.toast{color:var(--text-main);border-left:4px solid var(--success);opacity:0;z-index:9999;background:#1e293b;border-radius:12px;max-width:380px;padding:14px 22px;font-size:.88rem;font-weight:500;transition:opacity .35s,transform .35s;position:fixed;bottom:28px;right:28px;transform:translateY(20px);box-shadow:0 8px 32px #0000004d}.toast.visible{opacity:1;transform:translateY(0)}.toast-danger{border-left-color:var(--danger)}.toast-info{border-left-color:var(--warning)}.toast-success{border-left-color:var(--success)}.text-danger{color:#ef4444}.text-success{color:#22c55e}.text-dim{color:#94a3b8}.alerta-stock-banner{border-radius:var(--radius);color:#fca5a5;background:#ef44441a;border:1px solid #ef444466;margin-bottom:20px;padding:12px 18px;font-size:.85rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#334155;border-radius:10px}body.light-mode{--bg-main:#f1f5f9;--bg-card:#fff;--text-main:#1e293b;--text-dim:#64748b;--sidebar:#fff;--accent:#0284c7;--accent-glow:#0284c726}body.light-mode input,body.light-mode select{color:#1e293b;background:#f8fafc;border-color:#e2e8f0}body.light-mode .stat-card{background:linear-gradient(145deg,#fff,#f1f5f9)}body.light-mode td{border-bottom-color:#f1f5f9}body.light-mode .log-list{color:#1e293b;background:#e2e8f0}body.light-mode .card{border-color:#e2e8f0}body.light-mode .sidebar{border-right-color:#e2e8f0}@media (width<=1100px){.dashboard-body{grid-template-columns:1fr}}@media (width<=900px){.container{flex-direction:column}.sidebar{flex-direction:row;align-items:center;width:100%;height:auto;padding:16px 20px;position:relative}nav{flex-direction:row;flex:1;justify-content:flex-end;gap:6px}.grid-inputs{grid-template-columns:1fr 1fr}.form-actions{grid-column:span 2}}@media (width<=600px){.main-content{padding:20px 16px}.stats-grid{grid-template-columns:1fr 1fr}.grid-inputs{grid-template-columns:1fr}.form-actions{flex-direction:column;grid-column:span 1}.list-header{flex-direction:column;align-items:flex-start}.search-bar-group{flex-direction:column;width:100%}.search-bar-group input,.search-bar-group select{width:100%}.toast{max-width:none;left:16px;right:16px}}.sidebar-footer{border-top:1px solid #1e293b;flex-direction:column;gap:12px;margin-top:auto;padding-top:16px;display:flex}.sistema-info{flex-direction:column;gap:4px;display:flex}.sistema-info p{color:var(--text-dim);font-size:.75rem}.sidebar-links{flex-direction:column;gap:6px;display:flex}.sidebar-links a{color:var(--accent);transition:var(--transition);border-radius:8px;padding:6px 10px;font-size:.8rem;text-decoration:none}.sidebar-links a:hover{background:var(--accent-glow)}.modal-overlay{z-index:9998;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-card);border-radius:var(--radius);text-align:center;border:1px solid #334155;width:90%;max-width:480px;padding:36px;position:relative;box-shadow:0 20px 60px #0006}.modal-cerrar{color:var(--text-dim);background:0 0;padding:4px 10px;font-size:1rem;position:absolute;top:16px;right:16px}.modal-cerrar:hover{color:var(--danger);box-shadow:none;filter:none}.modal-avatar{background:linear-gradient(135deg, var(--accent), #818cf8);color:#0f172a;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;font-size:1.3rem;font-weight:700;display:flex}.modal-box h2{margin-bottom:4px;font-size:1.3rem;font-weight:700}.modal-subtitulo{color:var(--text-dim);margin-bottom:20px;font-size:.85rem}.modal-descripcion{background:var(--bg-main);color:var(--text-dim);text-align:left;border-radius:10px;margin-bottom:16px;padding:14px;font-size:.85rem;line-height:1.6}.modal-caso{text-align:left;background:#38bdf80d;border:1px solid #38bdf833;border-radius:10px;margin-bottom:16px;padding:14px}.modal-caso h4{color:var(--accent);margin-bottom:8px;font-size:.85rem}.modal-caso p{color:var(--text-dim);font-size:.82rem;line-height:1.6}.modal-stack{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:16px;display:flex}.modal-stack span{background:var(--accent-glow);color:var(--accent);border:1px solid var(--accent);border-radius:50px;padding:3px 12px;font-size:.72rem;font-weight:600}.modal-links{justify-content:center;gap:12px;margin-bottom:16px;display:flex}.modal-links a{color:var(--accent);border:1px solid var(--accent);transition:var(--transition);border-radius:8px;padding:8px 16px;font-size:.85rem;text-decoration:none}.modal-links a:hover{background:var(--accent-glow)}.modal-autor{color:var(--text-dim);font-size:.78rem}
