*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:Inter,system-ui,sans-serif}.dark{color-scheme:dark}body{min-height:100vh}.dark body{background:#0a0a0e;color:#fff}body{background:#f8f8fc;color:#111}.hidden{display:none!important}.min-h-screen{min-height:100vh}.flex{display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.text-center{text-align:center}.mx-auto{margin-left:auto;margin-right:auto}.mb-4{margin-bottom:1rem}.text-sm{font-size:.875rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.mt-20{margin-top:5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.w-full{width:100%}.w-8{width:2rem}.h-8{height:2rem}.h-6{height:1.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.max-w-sm{max-width:24rem}.max-w-4xl{max-width:56rem}.max-w-7xl{max-width:80rem}.max-w-none{max-width:none}.block{display:block}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.flex-1{flex:1 1 0%}.flex-col{flex-direction:column}.justify-between{justify-content:space-between}.sticky{position:sticky}.top-0{top:0}.top-14{top:3.5rem}.z-50{z-index:50}.overflow-y-auto{overflow-y:auto}.overflow-x-auto{overflow-x:auto}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-r{border-right-width:1px}.border-t-transparent{border-top-color:transparent}.space-y-1>*+*{margin-top:.25rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.select-none{user-select:none}.cursor-pointer{cursor:pointer}.text-xs{font-size:.75rem}.text-2xl{font-size:1.5rem}.uppercase{text-transform:uppercase}.tracking-wider{letter-spacing:.05em}.underline{text-decoration:underline}.no-underline{text-decoration:none}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.text-gray-400{color:#9ca3af}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-900{color:#111827}.text-red-400{color:#f87171}.text-red-500{color:#ef4444}.bg-red-500\/10{background:#ef44441a}.border-red-400\/20{border-color:#f8717133}.dark .text-gray-400,.dark .text-gray-500{color:#fff6}.dark .text-gray-600{color:#ffffff80}.dark .text-gray-700{color:#ffffffb3}.dark .text-gray-900{color:#fff}#auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}#auth-loading .spinner{width:2rem;height:2rem;border:2px solid #6C63FF;border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}#auth-loading p{font-size:.875rem;color:#6b7280}.dark #auth-loading p{color:#ffffff80}header.tech-header{position:sticky;top:0;z-index:50;height:3.5rem;display:flex;align-items:center;backdrop-filter:blur(12px);border-bottom:1px solid rgba(108,99,255,.1);padding:0 1.5rem}.dark header.tech-header{background:#111318f2}header.tech-header{background:#f5f5fbf2}header .header-inner{max-width:80rem;margin:0 auto;width:100%;display:flex;align-items:center;justify-content:space-between}header .logo-link{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:inherit}header .logo-link img{height:1.5rem}header .logo-link span{font-weight:700}header .badge-interno{font-size:.625rem;font-family:monospace;background:#ef44441a;color:#ef4444;padding:.125rem .5rem;border-radius:9999px}header .header-right{display:flex;align-items:center;gap:.75rem}header .header-right span{font-size:.875rem;color:#6b7280}.dark header .header-right span{color:#fff9}header .header-right a,header .header-right button{font-size:.75rem;background:none;border:none;cursor:pointer;color:#9ca3af}header .header-right a:hover{color:#6c63ff}.btn-logout{color:#f87171!important;font-weight:500}.btn-theme{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.375rem}.btn-theme:hover{background:#0000000d}.dark .btn-theme:hover{background:#ffffff0d}.btn-theme svg{width:1rem;height:1rem}.dark .sun-icon{display:block}.dark .moon-icon,.sun-icon{display:none}.moon-icon{display:block}aside.tech-sidebar{width:16rem;border-right:1px solid rgba(108,99,255,.08);min-height:calc(100vh - 3.5rem);position:sticky;top:3.5rem;overflow-y:auto;padding:1rem}.dark aside.tech-sidebar{background:#15171e;border-color:#ffffff0f}aside.tech-sidebar{background:#fafaff}aside h3{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#9ca3af;margin-bottom:.5rem}.dark aside h3{color:#ffffff4d}aside nav>div+div{margin-top:1.5rem}aside a{display:block;font-size:.875rem;padding:.25rem .5rem;border-radius:.375rem;color:#374151;text-decoration:none;transition:background .15s}.dark aside a{color:#ffffffb3}aside a:hover{background:#6c63ff0d}.dark aside a:hover{background:#ffffff0d}aside a.active{background:#6c63ff1a!important;color:#6c63ff!important;font-weight:600}main.tech-main{flex:1;max-width:56rem;margin:0 auto;padding:2.5rem 1.5rem}article h1{font-size:2rem;font-weight:800;margin-bottom:1.5rem;line-height:1.2}article h2{font-size:1.5rem;font-weight:700;margin-top:2.5rem;margin-bottom:1rem}article h3{font-size:1.125rem;font-weight:600;margin-top:2rem;margin-bottom:.75rem}article p{margin-bottom:1rem;line-height:1.7;color:#374151}.dark article p{color:#ffffffbf}article ul,article ol{margin-bottom:1rem;padding-left:1.5rem}article li{margin-bottom:.5rem;line-height:1.6;color:#374151}.dark article li{color:#ffffffb3}article a{color:#6c63ff;text-decoration:underline}article pre{border-radius:.75rem;padding:1rem;overflow-x:auto;font-size:.8rem;margin-bottom:1.5rem;font-family:JetBrains Mono,monospace}.dark article pre{background:#ffffff0a;color:#ffffffd9}article pre{background:#f1f1f8;color:#1a1a2e}article code{font-family:JetBrains Mono,monospace;font-size:.85em}article table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.875rem}article th{text-align:left;padding:.5rem .75rem;font-weight:600;border-bottom:2px solid rgba(108,99,255,.15)}article td{padding:.5rem .75rem;border-bottom:1px solid rgba(0,0,0,.05)}.dark article td{border-color:#ffffff0d}article .warning{background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:.75rem;padding:1rem;font-size:.875rem;margin-bottom:1.5rem}.grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.grid-3col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}.card{border:1px solid rgba(108,99,255,.1);border-radius:.75rem;padding:1.25rem}.dark .card{background:#ffffff05;border-color:#ffffff0f}.card{background:#6c63ff05}.card h4{font-weight:600;margin-bottom:.5rem}.card p{font-size:.875rem;margin:0}.tech-input{width:100%;padding:.75rem 1rem;border-radius:.75rem;border:1px solid rgba(108,99,255,.1);background:#6c63ff0a;font-size:.875rem;color:#111;outline:none;transition:border-color .15s}.dark .tech-input{background:#ffffff0d;border-color:#ffffff1a;color:#fff}.tech-input::placeholder{color:#9ca3af}.dark .tech-input::placeholder{color:#ffffff4d}.tech-input:focus{border-color:#6c63ff;box-shadow:0 0 0 1px #6c63ff}.tech-btn{width:100%;padding:.875rem;border-radius:.75rem;border:none;font-weight:700;font-size:.875rem;color:#fff;background:linear-gradient(90deg,#6c63ff,#ff6584);cursor:pointer}.tech-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.25rem}.dark .tech-label{color:#ffffffb3}.error-box{font-size:.875rem;color:#f87171;background:#f871711a;border:1px solid rgba(248,113,113,.2);border-radius:.75rem;padding:.75rem 1rem}@media(max-width:1024px){aside.tech-sidebar{display:none}}.mermaid{margin:1.5rem 0;text-align:center}.mermaid svg{max-width:100%}
