*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f3f4f6;color:#1f2937;line-height:1.5}.min-h-screen{min-height:100vh}.bg-gray-50{background-color:#f3f4f6}main{max-width:1280px;margin:0 auto;padding:2rem}h1{font-size:2rem;font-weight:700;color:#111827;margin-bottom:.5rem}h2{font-size:1.25rem;font-weight:600;color:#374151;margin-bottom:.5rem}p{color:#6b7280;margin-bottom:1rem}.page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #1E293B}.page-header h1{margin-bottom:.25rem}.page-header p{color:#64748b;font-size:1rem;margin:0}.user-greeting-name{color:#1e90ff}.card{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;border:1px solid #E5E7EB}.card-header{border-bottom:1px solid #1E293B;padding-bottom:1rem;margin-bottom:1rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:1023px){.stats-grid,div.stats-grid,main .stats-grid{grid-template-columns:repeat(2,1fr)!important;gap:.75rem!important;margin-bottom:1rem!important}}@media(min-width:1280px){.stats-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem}}.stat-card{background:#fff;border-radius:.75rem;padding:1rem;box-shadow:0 1px 3px #0000001a;border:1px solid #E5E7EB;display:flex;align-items:center;gap:.75rem;transition:transform .2s,box-shadow .2s,border-color .2s;min-width:0}@media(min-width:1024px){.stat-card{padding:1.5rem;gap:1rem}}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a;border-color:#1e90ff}.stat-icon{width:2.5rem;height:2.5rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}@media(min-width:1024px){.stat-icon{width:3.5rem;height:3.5rem;border-radius:.75rem}}.stat-icon.purple{background:#1e90ff26;color:#1e90ff}.stat-icon.green{background:#22c55e26;color:#22c55e}.stat-icon.yellow{background:#eab30826;color:#eab308}.stat-icon.red{background:#ef444426;color:#ef4444}.stat-content{flex:1}.stat-value{font-size:1.25rem;font-weight:700;color:#111827;line-height:1;margin-bottom:.25rem}@media(min-width:1024px){.stat-value{font-size:1.75rem}}.stat-label{font-size:.75rem;color:#6b7280;font-weight:500}@media(min-width:1024px){.stat-label{font-size:.875rem}}.table-container{overflow-x:auto;border-radius:.75rem;background:#fff;box-shadow:0 1px 3px #0000001a;border:1px solid #E5E7EB}table{width:100%;border-collapse:collapse}th{background:#f9fafb;padding:1rem 1.5rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#6b7280;letter-spacing:.05em;border-bottom:1px solid #E5E7EB}td{padding:1rem 1.5rem;border-bottom:1px solid #E5E7EB;color:#374151}tr:hover{background:#f9fafb}tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:.375rem .875rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.badge-green{background:#22c55e26;color:#22c55e}.badge-red{background:#ef444426;color:#ef4444}.badge-yellow{background:#eab30826;color:#eab308}.badge-blue{background:#1e90ff26;color:#1e90ff}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;text-decoration:none}.btn-primary{background:linear-gradient(135deg,#1e90ff,#00bfff);color:#fff;box-shadow:0 4px 14px #1e90ff4d}.btn-primary:hover{background:linear-gradient(135deg,#00bfff,#1e90ff);transform:translateY(-1px);box-shadow:0 6px 20px #1e90ff66}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-page{min-height:100vh;background:#000;display:flex;align-items:center;justify-content:center;padding:1rem}@media(max-width:768px){.login-page{padding:.75rem}}.login-card{background:#0f172a;border-radius:1rem;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 25px 50px -12px #00000080;border:1px solid #1E293B}@media(max-width:640px){.login-card{padding:1.5rem;border-radius:.75rem}}.login-header{text-align:center;margin-bottom:2rem}@media(max-width:640px){.login-header{margin-bottom:1.5rem}}.login-header h1{color:#f8fafc;margin-bottom:.5rem;font-size:1.875rem}@media(max-width:640px){.login-header h1{font-size:1.5rem}}.login-header p{color:#64748b;font-size:1rem}@media(max-width:640px){.login-header p{font-size:.875rem}}.form-group{margin-bottom:1.25rem}@media(max-width:640px){.form-group{margin-bottom:1rem}}.form-group label{display:block;font-size:.875rem;font-weight:500;color:#94a3b8;margin-bottom:.5rem}@media(max-width:640px){.form-group label{font-size:.8125rem}}.form-group input{width:100%;padding:.875rem 1rem;border:1px solid #334155;border-radius:.5rem;font-size:1rem;transition:border-color .2s,box-shadow .2s;background:#1e293b;color:#f8fafc}@media(max-width:640px){.form-group input{padding:.75rem .875rem;font-size:16px}}.form-group input:focus{outline:none;border-color:#1e90ff;box-shadow:0 0 0 3px #1e90ff26;background:#0f172a}.form-group input::placeholder{color:#64748b}.alert{padding:.875rem 1rem;border-radius:.5rem;margin-bottom:1.25rem;font-size:.875rem}@media(max-width:640px){.alert{padding:.75rem;font-size:.8125rem;margin-bottom:1rem}}.alert-error{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.space-y-6>*+*{margin-top:1.5rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.mt-4{margin-top:1rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.text-sm{font-size:.875rem}.text-right{text-align:right}.text-gray-500{color:#64748b}.text-gray-600{color:#94a3b8}.font-medium{font-weight:500}.font-semibold{font-weight:600}.recent-notas{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid #E5E7EB;overflow:hidden}.recent-header{padding:1.25rem 1.5rem;border-bottom:1px solid #E5E7EB;display:flex;justify-content:space-between;align-items:center}.recent-header h3{font-size:1.125rem;font-weight:600;color:#111827}.recent-header span{font-size:.875rem;color:#6b7280}.nota-item{padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #F3F4F6;transition:background .2s}.nota-item:last-child{border-bottom:none}.nota-item:hover{background:#f9fafb}.nota-info{display:flex;align-items:center;gap:1rem}.nota-details h4{font-weight:600;color:#111827;margin-bottom:.25rem}.nota-details p{font-size:.875rem;color:#6b7280;margin:0}.nota-meta{text-align:right}.nota-meta .valor{font-weight:600;color:#111827;font-size:1.125rem;margin-bottom:.25rem}.empty-state{padding:3rem;text-align:center;color:#6b7280}.empty-state p{font-size:1rem}.login-container{display:flex;min-height:100vh;font-family:system-ui,-apple-system,sans-serif}.login-branding{flex:1;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;background:linear-gradient(135deg,#e8f4fd,#b8d4f0);color:#fff;padding:3rem}.login-branding-inner{text-align:center;max-width:500px}.login-branding-logo{width:380px;height:380px;margin-bottom:.5rem;object-fit:contain}.login-branding-title{font-size:1.5rem;font-weight:300;margin-bottom:.5rem;opacity:.9;color:#1e3a5f}.login-branding-subtitle{font-size:1.125rem;opacity:.7;margin-bottom:1rem;color:#1e3a5f}.login-branding-features{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;color:#1e3a5f}.login-branding-feature{display:flex;align-items:center;gap:.5rem;opacity:.9}.login-form-section{width:420px;background:#fff;display:flex;flex-direction:column;justify-content:flex-start;padding:2rem 3rem;box-shadow:-4px 0 20px #0000001a}.login-form-logo{width:220px;height:220px;object-fit:contain}@media(max-width:768px){.login-container{flex-direction:column}.login-branding{display:none}.login-form-section{width:100%;min-height:100vh;padding:1.5rem;box-shadow:none;justify-content:center}.login-form-logo{width:220px;height:220px}.login-branding-logo{width:200px;height:200px}}@media(max-width:480px){.login-form-section{padding:1rem}.login-form-logo{width:180px;height:180px}}.app-container{display:flex;min-height:100vh}.sidebar{width:280px;background:#fff!important;color:#374151;display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;border-right:1px solid #E5E7EB;box-shadow:4px 0 24px #00000014}.sidebar-logo{padding:1.5rem;display:flex;align-items:center;justify-content:center}.sidebar-logo img{width:100%;max-width:220px;height:auto;max-height:160px;object-fit:contain}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.5rem}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;color:#6b7280;text-decoration:none;border-radius:.5rem;transition:all .2s;font-weight:500}.sidebar-link:hover{background:#f3f4f6;color:#1e90ff}.sidebar-link.active{background:#1e90ff1a;color:#1e90ff}.sidebar-link svg{flex-shrink:0}.sidebar-footer{padding:1.25rem;border-top:1px solid #E5E7EB;background:#fff}.user-info{display:flex;align-items:center;gap:.75rem;padding:.75rem;margin-bottom:.75rem}.user-avatar{width:2.5rem;height:2.5rem;border-radius:.625rem;background:linear-gradient(135deg,#1e90ff,#00bfff);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;font-size:.875rem}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{font-weight:600;color:#111827;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75rem;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 0;background:transparent;color:#dc2626;border:none;font-weight:500;font-size:.875rem;transition:color .2s;cursor:pointer}.logout-btn:hover{color:#b91c1c}.main-content{flex:1;margin-left:280px;padding:1rem;background:#f3f4f6;min-height:100vh}@media(min-width:640px){.main-content{padding:1.5rem}}@media(min-width:1024px){.main-content{padding:2.5rem}}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:80px;background:#fff;border-bottom:1px solid #E5E7EB;z-index:90;align-items:center;justify-content:space-between;padding:0 1rem;box-shadow:0 2px 8px #00000014}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:.5rem;color:#374151;cursor:pointer;transition:background .2s}.mobile-menu-btn:hover{background:#f3f4f6}.mobile-logo{height:60px;width:auto;max-width:180px;object-fit:contain}@media(max-width:480px){.mobile-logo{height:50px;max-width:150px}}.mobile-header-spacer{width:40px}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:110;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.mobile-overlay.active{opacity:1;visibility:visible}.sidebar-desktop{display:flex}.sidebar-mobile{display:none;position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);transition:transform .3s ease;z-index:120}.sidebar-mobile.active{transform:translate(0)}.mobile-close-btn{position:absolute;top:1rem;right:1rem;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#f3f4f6;border:none;border-radius:.5rem;color:#374151;cursor:pointer;transition:background .2s;z-index:10}.mobile-close-btn:hover{background:#e5e7eb}.mobile-floating-menu-btn,.mobile-app-header,.mobile-bottom-nav{display:none}@media(max-width:1023px){.mobile-floating-menu-btn,.mobile-header{display:none!important}.mobile-app-header{display:flex;position:fixed;top:0;left:0;right:0;height:56px;background:#fff;border-bottom:1px solid #E5E7EB;z-index:95;align-items:center;justify-content:space-between;padding:0 1rem;box-shadow:0 1px 3px #0000000d}.mobile-header-menu-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:.5rem;color:#374151;cursor:pointer;transition:background .2s}.mobile-header-menu-btn:hover{background:#f3f4f6}.mobile-header-title{font-size:1.125rem;font-weight:600;color:#111827;flex:1;text-align:center;margin:0 .5rem}.mobile-header-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#1e90ff,#00bfff);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;font-size:.875rem;flex-shrink:0}.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;background:#fff;border-top:1px solid #E5E7EB;z-index:95;justify-content:space-around;align-items:center;padding:0 .5rem;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -2px 10px #0000000d}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem .75rem;color:#9ca3af;text-decoration:none;font-size:.75rem;font-weight:500;transition:color .2s;border-radius:.75rem;flex:1;max-width:80px}.mobile-nav-item.active{color:#1e90ff;background:#1e90ff1a}.mobile-nav-item:hover{color:#374151}.sidebar-desktop{display:none}.sidebar-mobile{display:flex;top:0;height:100vh;padding-top:1rem}.main-content{margin-left:0;padding-top:72px;padding-left:1rem;padding-right:1rem;padding-bottom:80px;min-height:100vh}.main-content.mobile{padding-top:72px;padding-bottom:80px}}@media(max-width:768px){.sidebar{width:85%;max-width:300px}.main-content{padding:1rem .5rem}}.stats-grid-mobile{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card-mobile{background:#fff;border-radius:.75rem;padding:.875rem;box-shadow:0 1px 3px #00000014;border:1px solid #E5E7EB}.stat-card-mobile-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.stat-card-mobile-header .text-blue-500{color:#1e90ff}.stat-card-mobile-header .text-xs{font-size:.75rem}.stat-card-mobile-header .text-gray-500{color:#6b7280}.stat-card-mobile-value{font-size:1.5rem;font-weight:700;color:#111827;line-height:1}.quick-actions-section{margin-top:1.5rem}.quick-actions-title{font-size:1rem;font-weight:600;color:#111827;margin-bottom:.75rem;padding-left:.25rem}.quick-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.quick-action-card{background:#fff;border-radius:.75rem;padding:1rem;box-shadow:0 1px 3px #00000014;border:1px solid #E5E7EB;display:flex;flex-direction:column;align-items:center;gap:.5rem;text-decoration:none;transition:transform .2s,box-shadow .2s;position:relative}.quick-action-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.quick-action-icon{width:40px;height:40px;border-radius:.625rem;background:#1e90ff1a;display:flex;align-items:center;justify-content:center}.quick-action-icon .text-blue-500{color:#1e90ff}.quick-action-label{font-size:.875rem;font-weight:600;color:#374151}.quick-action-badge{position:absolute;top:.5rem;right:.5rem;padding:.125rem .375rem;border-radius:9999px;font-size:.625rem;font-weight:700;letter-spacing:.02em;white-space:nowrap}.status-info-card{background:#fff;border-radius:.75rem;padding:1rem;box-shadow:0 1px 3px #00000014;border:1px solid #E5E7EB;margin-top:1rem}.status-info-title{font-size:.875rem;font-weight:600;color:#111827;display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #F3F4F6}.status-info-title .text-blue-500{color:#1e90ff}.status-info-content{color:#374151}.status-info-content .space-y-2>*+*{margin-top:.5rem}.status-info-content .text-sm{font-size:.875rem}.status-info-content .text-gray-500{color:#6b7280}.status-info-content .text-red-500{color:#ef4444}.status-info-content .text-gray-600{color:#4b5563}@media(min-width:1024px){.stats-grid-mobile{grid-template-columns:repeat(4,1fr);gap:1rem}.stat-card-mobile{padding:1rem}.stat-card-mobile-value{font-size:1.75rem}.quick-actions-grid{grid-template-columns:repeat(4,1fr)}}.dashboard-desktop{display:block}.dashboard-mobile{display:none}@media(max-width:1023px){.dashboard-desktop{display:none}.dashboard-mobile{display:block}}.quick-links-desktop{padding:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.mobile-greeting{padding:.5rem .25rem .75rem;margin-bottom:.5rem}.mobile-greeting-text{font-size:1.5rem;font-weight:600;color:#111827;line-height:1.2;margin-bottom:.25rem}.mobile-greeting-name{color:#1e90ff;font-weight:700}.mobile-greeting-subtitle{font-size:.875rem;color:#6b7280;margin:0}@media(max-width:480px){.mobile-greeting-text{font-size:1.25rem}.mobile-greeting-subtitle{font-size:.8125rem}}.quick-link-card{padding:1rem;border:1px solid #E5E7EB;border-radius:.5rem;text-decoration:none;color:#374151;display:flex;align-items:flex-start;gap:.75rem;background:#fff;transition:transform .2s,box-shadow .2s}.quick-link-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:#1e90ff}.quick-link-icon{width:40px;height:40px;border-radius:.5rem;background:#1e90ff1a;display:flex;align-items:center;justify-content:center;color:#1e90ff;flex-shrink:0}.quick-link-content{flex:1;min-width:0}.quick-link-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.25rem}.quick-link-title{font-weight:600;font-size:.9375rem;color:#111827}.quick-link-description{font-size:.875rem;color:#6b7280;line-height:1.4}.quick-link-badge{padding:.25rem .5rem;border-radius:9999px;font-size:.6875rem;font-weight:800;letter-spacing:.06em;white-space:nowrap;border:1px solid transparent}.table-scroll-container{overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 350px);-webkit-overflow-scrolling:touch}.credentials-card,.notas-card{max-width:100%}.credentials-table,.notas-table{min-width:600px}.credentials-table td,.notas-table td{word-break:break-word;max-width:300px}.credentials-table td code,.notas-table td code{word-break:break-all}@media(max-width:1023px){.table-scroll-container{max-height:calc(100vh - 280px);border-radius:0 0 .75rem .75rem}.credentials-card,.notas-card{width:100%;max-width:100vw;overflow:hidden}.credentials-table,.notas-table{min-width:650px}}@media(max-width:768px){.table-scroll-container{max-height:calc(100vh - 250px)}.credentials-table,.notas-table{min-width:600px}.credentials-table th,.credentials-table td,.notas-table th,.notas-table td{padding:.75rem 1rem}}@media(max-width:480px){.table-scroll-container{max-height:calc(100vh - 220px)}.credentials-table th,.credentials-table td,.notas-table th,.notas-table td{padding:.625rem .75rem;font-size:.8125rem}}
