.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b);position:relative;overflow:hidden}.login-background{position:absolute;inset:0;overflow:hidden;z-index:0}.login-circle{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(52,91,255,.1) 0%,transparent 70%);animation:float 20s infinite ease-in-out}.login-circle-1{width:500px;height:500px;top:-250px;right:-250px;animation-delay:0s}.login-circle-2{width:400px;height:400px;bottom:-200px;left:-200px;animation-delay:5s}.login-circle-3{width:300px;height:300px;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:10s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.login-container{display:grid;grid-template-columns:1fr 1fr;width:90%;max-width:1100px;background:#fff;border-radius:24px;overflow:hidden;box-shadow:0 20px 60px #0000004d;position:relative;z-index:1;min-height:550px}.login-branding{background:linear-gradient(135deg,#00b4d8,#0096c7);padding:40px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}.login-branding:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.3}.login-branding-content{position:relative;z-index:1;text-align:center}.login-logo{width:180px;height:auto;margin-bottom:20px;filter:brightness(0) invert(1)}.login-module-badge{display:inline-flex;align-items:center;gap:8px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 16px;border-radius:50px;margin-bottom:24px;border:1px solid rgba(255,255,255,.2)}.module-roman{font-size:20px;font-weight:700;color:#fff;font-family:Georgia,serif}.module-text{font-size:10px;font-weight:600;color:#ffffffe6;letter-spacing:1.5px}.login-branding-title{font-size:24px;font-weight:700;color:#fff;margin-bottom:12px;line-height:1.3}.login-branding-description{font-size:15px;color:#ffffffd9;line-height:1.5}.login-form-panel{padding:40px;display:flex;flex-direction:column;justify-content:center;background:#fafafa}.login-form-container{max-width:380px;margin:0 auto;width:100%}.login-form-header{margin-bottom:28px}.login-title{font-size:28px;font-weight:700;color:#0f172a;margin-bottom:6px}.login-subtitle{font-size:14px;color:#64748b}.login-error{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fee2e2;border:1px solid #FCA5A5;border-radius:8px;color:#991b1b;font-size:14px;margin-bottom:24px}.login-error svg{flex-shrink:0}.login-form{display:flex;flex-direction:column;gap:20px}.login-input-group{display:flex;flex-direction:column;gap:8px}.login-label{font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.login-input-wrapper{position:relative}.login-input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.login-input{width:100%;padding:14px 14px 14px 44px;border:2px solid #E5E7EB;border-radius:10px;font-size:15px;color:#0f172a;background:#fff;transition:all .2s}.login-input:focus{outline:none;border-color:#00b4d8;box-shadow:0 0 0 3px #00b4d81a}.login-input::placeholder{color:#9ca3af}.login-button{width:100%;padding:14px 24px;background:linear-gradient(135deg,#00b4d8,#0096c7);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 12px #00b4d84d}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00b4d866}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.login-footer{margin-top:32px;padding-top:24px;border-top:1px solid #E5E7EB;text-align:center}.login-footer p{font-size:12px;color:#9ca3af}@media(max-width:968px){.login-container{grid-template-columns:1fr;max-width:500px}.login-branding{padding:40px 30px;min-height:auto}.login-logo{width:150px}.login-branding-title{font-size:24px}.login-features{display:none}.login-form-panel{padding:40px 30px}}@media(max-width:640px){.login-page{padding:20px}.login-container{width:100%}.login-branding,.login-form-panel{padding:30px 20px}.login-title{font-size:28px}}.dashboard-page{padding:20px 24px;background:#fff;min-height:100vh}.dash-greeting{font-size:13px;color:#64748b;margin-bottom:2px;font-weight:500}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f1f5f9}.dashboard-header h1{font-size:26px;font-weight:800;color:#0f172a;margin:0;line-height:1.2}.dashboard-header .text-blue{color:#345bff}.dashboard-header p{margin:4px 0 0;font-size:13px;color:#94a3b8}.date-filters{display:flex;align-items:center;gap:8px;background:#f8faff;border:1px solid #e2e8f0;border-radius:10px;padding:6px 12px}.date-input{padding:4px 6px;border:none;background:transparent;font-size:13px;color:#0f172a;outline:none;cursor:pointer}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.kpi-card{background:#fff;border-radius:12px;padding:16px 18px;border:1px solid #e8edf5;box-shadow:0 2px 8px #345bff0d;display:flex;align-items:center;gap:14px;transition:box-shadow .2s,transform .2s}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #345bff1f}.kpi-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;flex-shrink:0}.kpi-content{flex:1;min-width:0}.kpi-label{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.6px;margin:0 0 2px}.kpi-value{font-size:24px;font-weight:800;color:#0f172a;margin:0;line-height:1.1}.kpi-money{font-size:18px}.kpi-sub{font-size:11px;color:#94a3b8;margin-top:2px;display:block}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:16px}.chart-card{background:#fff;border-radius:12px;padding:18px 20px;border:1px solid #e8edf5;box-shadow:0 2px 8px #0000000a}.chart-title{font-size:14px;font-weight:700;color:#0f172a;margin:0 0 14px}.chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:220px;gap:10px;color:#64748b;font-size:14px;font-weight:500}.tables-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.table-card{background:#fff;border-radius:12px;padding:18px 20px;border:1px solid #e8edf5;box-shadow:0 2px 8px #0000000a}.table-title{font-size:14px;font-weight:700;color:#0f172a;margin:0 0 12px}.table-container{overflow-x:auto}.dashboard-table{width:100%;border-collapse:collapse}.dashboard-table thead{background:#f8faff;border-radius:8px}.dashboard-table th{padding:9px 12px;text-align:left;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e8edf5}.dashboard-table td{padding:9px 12px;font-size:13px;color:#0f172a;border-bottom:1px solid #f1f5f9}.dashboard-table tbody tr:last-child td{border-bottom:none}.dashboard-table tbody tr:hover{background:#f8faff}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:capitalize}.badge-borrador{background:#e0e7ff;color:#3730a3}.badge-pendiente_control{background:#fef3c7;color:#92400e}.badge-pendiente_actualizacion{background:#fce7f3;color:#9f1239}.badge-aprobado{background:#dcfce7;color:#15803d}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:12px;background:#fff}.dashboard-loading p{font-size:14px;color:#64748b}@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.charts-grid,.tables-grid{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-header{flex-direction:column;gap:12px}.kpi-grid{grid-template-columns:1fr}.date-filters{flex-wrap:wrap}}.up-page{padding:24px;background:#fff;min-height:100vh;font-family:Inter,Segoe UI,sans-serif}.up-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin-bottom:24px}.up-title{font-size:26px;font-weight:800;color:#1e293b;margin:0 0 4px}.up-title span{color:#3b82f6}.up-subtitle{font-size:13px;color:#64748b;margin:0}.up-btn-new{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #3b82f659;transition:transform .15s,box-shadow .15s}.up-btn-new:hover{transform:translateY(-2px);box-shadow:0 6px 18px #3b82f666}.up-kpis{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:20px}.up-kpi{flex:1 1 130px;background:#fff;border:1px solid #f1f5f9;border-radius:14px;padding:16px 20px;box-shadow:0 2px 8px #0000000d;text-align:center;transition:transform .15s}.up-kpi:hover{transform:translateY(-2px)}.up-kpi-val{font-size:30px;font-weight:900;line-height:1.1}.up-kpi-lbl{font-size:11px;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.up-filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:12px 16px;margin-bottom:20px}.up-search{flex:1 1 220px;display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;padding:8px 12px;transition:border-color .15s}.up-search:focus-within{border-color:#3b82f6}.up-search input{flex:1;border:none;outline:none;font-size:13.5px;color:#1e293b;background:transparent}.up-filter-select{border:1.5px solid #e2e8f0;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;color:#475569;background:#fff;cursor:pointer;outline:none;min-width:150px}.up-filter-select:focus{border-color:#3b82f6}.up-filter-clear{background:none;border:1.5px solid #e2e8f0;border-radius:8px;padding:8px 14px;font-size:13px;color:"#64748b";cursor:pointer;font-weight:600;transition:background .15s}.up-filter-clear:hover{background:#f1f5f9}.up-result-count{font-size:12px;color:#94a3b8;font-weight:500;margin-left:auto;white-space:nowrap}.up-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.up-table{width:100%;border-collapse:collapse;font-size:13.5px}.up-table thead tr{background:#f8fafc;border-bottom:2px solid #e2e8f0}.up-table th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.6px}.up-table td{padding:14px 16px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.up-table tbody tr:last-child td{border-bottom:none}.up-table tbody tr:hover td{background:#f8fafc}.up-row-inactive td{opacity:.55}.up-user-name{font-weight:700;color:#1e293b;font-size:14px}.up-user-email{font-size:12px;color:#64748b;margin-top:2px}.up-muted{color:#94a3b8;font-size:13px}.up-acceso{font-size:12px}.up-status{display:inline-flex;align-items:center;gap:6px;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700}.up-status-active{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.up-status-inactive{background:#f9fafb;color:#6b7280;border:1px solid #e5e7eb}.up-status-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.up-almacenes{display:flex;flex-wrap:wrap;gap:4px}.up-alm-chip{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;border-radius:12px;padding:2px 9px;font-size:11px;font-weight:600}.up-actions{display:flex;gap:6px;justify-content:flex-end;align-items:center}.up-btn{display:inline-flex;align-items:center;gap:5px;border:none;border-radius:8px;padding:7px 12px;font-size:12.5px;font-weight:600;cursor:pointer;transition:transform .12s,opacity .12s;white-space:nowrap}.up-btn:hover{opacity:.85;transform:translateY(-1px)}.up-btn-wh{background:#eff6ff;color:#1d4ed8}.up-btn-edit{background:#f1f5f9;color:#475569}.up-btn-deact{background:#fef2f2;color:#dc2626}.up-btn-act{background:#f0fdf4;color:#16a34a}.up-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;color:#94a3b8;font-size:14px}.up-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.up-modal-overlay{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.up-modal{background:#fff;border-radius:18px;max-width:540px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000038;animation:slideUp .2s ease}.up-modal-wide{max-width:700px}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:none;opacity:1}}.up-modal-hdr{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid #f1f5f9;position:sticky;top:0;background:#fff;z-index:1}.up-modal-hdr h2{font-size:18px;font-weight:800;color:#1e293b;margin:0}.up-modal-close{background:#f1f5f9;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:14px;color:#64748b;display:flex;align-items:center;justify-content:center;transition:background .15s}.up-modal-close:hover{background:#e2e8f0}.up-modal-body{padding:20px 24px 24px}.up-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.up-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.up-form-group label{font-size:13px;font-weight:600;color:#374151}.up-form-group input,.up-form-group select{border:1.5px solid #e2e8f0;border-radius:8px;padding:9px 12px;font-size:13.5px;color:#1e293b;outline:none;transition:border-color .15s;background:#fff}.up-form-group input:focus,.up-form-group select:focus{border-color:#3b82f6}.up-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.up-btn-cancel{background:#f1f5f9;color:#475569;border:none;border-radius:9px;padding:10px 20px;font-weight:600;font-size:14px;cursor:pointer;transition:background .15s}.up-btn-cancel:hover{background:#e2e8f0}.up-btn-save{background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;border:none;border-radius:9px;padding:10px 22px;font-weight:700;font-size:14px;cursor:pointer;box-shadow:0 4px 12px #3b82f659;transition:transform .15s}.up-btn-save:hover{transform:translateY(-1px)}.up-alm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.up-alm-item{border:1.5px solid #e2e8f0;border-radius:10px;padding:12px;transition:border-color .15s,background .15s}.up-alm-assigned{border-color:#3b82f6;background:#eff6ff}.up-alm-check,.up-coord-check{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13.5px}.up-alm-check input,.up-coord-check input{accentColor:#3b82f6;cursor:pointer}.up-alm-name{font-weight:600;color:#1e293b}.up-coord-check{margin-top:8px;padding-top:8px;border-top:1px solid #bfdbfe;font-size:12px;color:#1d4ed8}@media(max-width:640px){.up-form-row{grid-template-columns:1fr}.up-kpi{flex:1 1 calc(50% - 7px)}.up-table thead{display:none}.up-table td{display:block;text-align:right;padding:8px 16px}.up-table td:before{content:attr(data-label);float:left;font-weight:700;color:#64748b}}.aclaraciones-table-container{border-radius:14px!important;overflow-x:auto!important;border:1px solid var(--border)!important}.estado-cell{text-align:center!important;padding:10px 8px!important}.badge-estado{display:inline-block;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.badge-rechazado{background:#fee2e2;color:#dc2626;border:1px solid #FCA5A5}.badge-pendiente{background:#fef3c7;color:#d97706;border:1px solid #FDE68A}.badge-aprobado{background:#d1fae5;color:#059669;border:1px solid #6EE7B7}.badge-borrador{background:#e5e7eb;color:#6b7280;border:1px solid #D1D5DB}.input-cell{width:70px!important;height:34px!important;border-radius:8px!important;border:1px solid #c7d2fe!important;text-align:center!important;font-size:14px!important;font-weight:600!important;padding:0 8px!important;transition:all .2s!important}.input-cell:hover{border-color:var(--blue)!important;background:var(--blue-soft)!important}.input-cell:focus{outline:none!important;border-color:var(--blue)!important;box-shadow:0 0 0 3px #345bff1a!important}.input-text{width:130px!important;height:34px!important;border-radius:8px!important;border:1px solid #c7d2fe!important;text-align:left!important;padding:0 10px!important;font-size:13px!important}.btn-ver,.btn-ok{width:32px;height:32px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:all .2s;box-shadow:0 2px 4px #0000001a}.btn-ver{background:#f97316!important;color:#fff}.btn-ver:hover{background:#ea580c;transform:scale(1.1);box-shadow:0 4px 8px #f973164d}.btn-ver:disabled{background:#cbd5e1;cursor:not-allowed;transform:none}.btn-ok{background:#22c55e!important;color:#fff}.btn-ok:hover{background:#16a34a;transform:scale(1.1);box-shadow:0 4px 8px #22c55e4d}.btn-ok:active,.btn-ver:active{transform:scale(.95)}.action-cell{text-align:center!important;padding:10px 8px!important}.action-buttons-row{display:flex!important;gap:8px!important;justify-content:center!important;align-items:center!important}.btn-enviar-todo{background:#3b82f6!important;color:#fff!important;border:none!important;padding:10px 20px!important;border-radius:8px!important;font-size:14px!important;font-weight:600!important;cursor:pointer!important;transition:all .2s!important;box-shadow:0 2px 4px #3b82f633!important;display:flex!important;align-items:center!important;gap:8px!important}.btn-enviar-todo:hover{background:#2563eb!important;transform:translateY(-2px)!important;box-shadow:0 4px 8px #3b82f64d!important}.btn-enviar-todo:active{transform:translateY(0)!important}.btn-aprobar,.btn-rechazar{width:32px!important;height:32px!important;border-radius:50%!important;border:none!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;font-size:16px!important;transition:all .2s!important;box-shadow:0 2px 4px #0000001a!important}.btn-aprobar{background:#22c55e!important;color:#fff!important}.btn-aprobar:hover{background:#16a34a!important;transform:scale(1.1)!important;box-shadow:0 4px 8px #22c55e4d!important}.btn-rechazar{background:#ef4444!important;color:#fff!important}.btn-rechazar:hover{background:#dc2626!important;transform:scale(1.1)!important;box-shadow:0 4px 8px #ef44444d!important}.btn-aprobar-todo,.btn-rechazar-todo{padding:10px 20px!important;border-radius:8px!important;font-size:14px!important;font-weight:600!important;cursor:pointer!important;transition:all .2s!important;border:none!important;display:flex!important;align-items:center!important;gap:8px!important;box-shadow:0 2px 4px #0000001a!important}.btn-aprobar-todo{background:#22c55e!important;color:#fff!important}.btn-aprobar-todo:hover{background:#16a34a!important;transform:translateY(-2px)!important;box-shadow:0 4px 8px #22c55e4d!important}.btn-rechazar-todo{background:#ef4444!important;color:#fff!important}.btn-rechazar-todo:hover{background:#dc2626!important;transform:translateY(-2px)!important;box-shadow:0 4px 8px #ef44444d!important}.modal-overlay{position:fixed!important;inset:0!important;background:#00000080!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:1000!important}.modal-content{background:#fff!important;border-radius:12px!important;padding:24px!important;width:90%!important;max-width:500px!important;box-shadow:0 10px 40px #0003!important}.modal-content h2{margin:0 0 8px!important;font-size:24px!important;color:#1f2937!important}.modal-subtitle{color:#6b7280!important;font-size:14px!important;margin:0 0 20px!important}.form-group{margin-bottom:20px!important}.form-group label{display:block!important;margin-bottom:8px!important;font-weight:600!important;color:#374151!important;font-size:14px!important}.form-group textarea{width:100%!important;padding:12px!important;border:1px solid #d1d5db!important;border-radius:8px!important;font-size:14px!important;font-family:inherit!important;resize:vertical!important;min-height:100px!important}.form-group textarea:focus{outline:none!important;border-color:#3b82f6!important;box-shadow:0 0 0 3px #3b82f61a!important}.modal-actions{display:flex!important;gap:12px!important;justify-content:flex-end!important}.btn-cancel,.btn-confirm-reject{padding:10px 20px!important;border-radius:8px!important;font-size:14px!important;font-weight:600!important;cursor:pointer!important;transition:all .2s!important;border:none!important}.btn-cancel{background:#f3f4f6!important;color:#374151!important}.btn-cancel:hover{background:#e5e7eb!important}.btn-confirm-reject{background:#ef4444!important;color:#fff!important}.btn-confirm-reject:hover{background:#dc2626!important;transform:translateY(-2px)!important;box-shadow:0 4px 8px #ef44444d!important}.checkbox-cell{text-align:center;width:80px}.checkbox-cell input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--blue)}.codigo-cell{font-family:Courier New,monospace;font-weight:600;color:var(--text)}.cotizaciones-mo-page{margin:0;background:#fff;color:var(--text);font-family:system-ui,sans-serif;padding:24px;min-height:100vh}.cotizaciones-header{margin-bottom:24px;background:transparent;border:none;padding:0;box-shadow:none}.cotizaciones-header h1{margin:0;font-size:32px;font-weight:800;color:#000;background:none}.cotizaciones-header h1 .text-blue{color:var(--blue);font-weight:700}.cotizaciones-header p{margin:6px 0 0;font-size:14px;color:var(--muted)}.cotizaciones-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:16px}.cotizaciones-filters{display:flex;gap:12px;align-items:center;flex:1}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-group label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.filter-select,.filter-input{padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:#fff;color:var(--text);min-width:180px;transition:all .2s}.filter-select:focus,.filter-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #345bff1a}.btn-nueva-cotizacion{padding:10px 20px;background:var(--blue);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;white-space:nowrap}.btn-nueva-cotizacion:hover{background:#2847cc;transform:translateY(-1px);box-shadow:0 4px 12px #345bff4d}.btn-nueva-cotizacion i{font-size:16px}.cotizaciones-table-container{background:#fff;border:1px solid var(--border);border-radius:12px;overflow-x:auto;box-shadow:0 1px 3px #0000000d}.cotizaciones-table{width:100%;border-collapse:collapse}.cotizaciones-table thead{background:#f8fafc;border-bottom:2px solid var(--border)}.cotizaciones-table th{padding:14px 16px;text-align:left;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.cotizaciones-table tbody tr{border-bottom:1px solid var(--border);transition:background .15s}.cotizaciones-table tbody tr:hover{background:#f8fafc}.cotizaciones-table td{padding:14px 16px;font-size:14px;color:var(--text)}.cotizaciones-table th:nth-child(1),.cotizaciones-table td:nth-child(1){width:100px;white-space:nowrap}.cotizaciones-table th:nth-child(2),.cotizaciones-table td:nth-child(2){width:140px;white-space:nowrap}.cotizaciones-table th:nth-child(3),.cotizaciones-table td:nth-child(3){width:140px}.cotizaciones-table th:nth-child(4),.cotizaciones-table td:nth-child(4){width:120px}.cotizaciones-table th:nth-child(5),.cotizaciones-table td:nth-child(5){width:140px}.cotizaciones-table th:nth-child(6),.cotizaciones-table td:nth-child(6){width:120px;font-weight:600;color:var(--blue);white-space:nowrap}.cotizaciones-table th:nth-child(7),.cotizaciones-table td:nth-child(7){width:130px}.cotizaciones-table th:nth-child(8),.cotizaciones-table td:nth-child(8){width:100px;text-align:center}.cotizaciones-table th:nth-child(9),.cotizaciones-table td:nth-child(9){width:120px;position:sticky;right:0;background:#fff;box-shadow:-2px 0 4px #0000000d}.cotizaciones-table thead th:nth-child(9){position:sticky;right:0;background:#f8fafc;z-index:11;box-shadow:-2px 0 4px #0000000d}.cotizaciones-table tbody tr:hover td:nth-child(9){background:#f8fafc}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.badge-borrador{background:#fef3c7;color:#92400e}.badge-enviado{background:#dbeafe;color:#1e40af}.badge-aprobado{background:#d1fae5;color:#065f46}.badge-rechazado{background:#fee2e2;color:#991b1b}.badge-cancelado{background:#f3f4f6;color:#4b5563}.badge i{font-size:10px}.action-buttons{display:flex;gap:8px}.action-buttons{display:flex;gap:8px;align-items:center;justify-content:center}.btn-action{padding:8px 12px;border:none;cursor:pointer;transition:all .2s ease;font-size:14px;display:inline-flex;align-items:center;justify-content:center;min-width:36px;min-height:36px;border-radius:8px;position:relative}.btn-action.btn-view{background:var(--blue-soft);color:var(--blue)}.btn-action.btn-view:hover{background:var(--blue);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #345bff33}.btn-action.btn-edit{background:#fff7ed;color:var(--orange)}.btn-action.btn-edit:hover{background:var(--orange);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #f9731633}.btn-action.btn-pdf{background:#fef2f2;color:var(--red)}.btn-action.btn-pdf:hover{background:var(--red);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #ef444433}.btn-action.btn-send{background:#f0fdf4;color:#16a34a}.btn-action.btn-send:hover{background:#16a34a;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #16a34a33}.btn-action.btn-delete{background:#fecaca;color:#dc2626}.btn-action.btn-delete:hover{background:#dc2626;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #dc262633}.btn-action:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-action:disabled:hover{background:var(--blue-soft)}.btn-action i{font-size:16px}.modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;padding:0 16px 16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);margin-left:240px;transition:margin-left .3s ease}.sidebar.collapsed~.main-wrapper .modal-overlay{margin-left:70px}body:has(.modal-overlay) .header{display:none!important}.modal-wizard{background:#fff;border-radius:16px;width:100%;max-width:1400px;max-height:calc(100vh - 96px);display:flex;flex-direction:column;box-shadow:0 24px 60px #00000080;margin:0 auto;overflow:hidden}.wizard-header{background:linear-gradient(135deg,#345bff,#5b7cff);padding:14px 22px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex-shrink:0;border-bottom:3px solid rgba(255,255,255,.15)}.wizard-title{font-size:19px;font-weight:700;color:#fff;margin:0;line-height:1.2}.wizard-subtitle{font-size:11px;color:#ffffffe6;margin:3px 0 0;line-height:1.3}.wizard-steps{display:flex;flex-direction:row;gap:24px;align-items:center}.wizard-step{display:flex;align-items:center;gap:10px;position:relative;cursor:default;transition:all .2s}.wizard-step:after{content:"";position:absolute;right:-20px;width:16px;height:2px;background:#ffffff40}.wizard-step:last-child:after{display:none}.step-number{width:32px;height:32px;border-radius:50%;background:#ffffff26;border:2px solid rgba(255,255,255,.3);color:#ffffffb3;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;transition:all .3s;flex-shrink:0}.wizard-step.active .step-number{background:#fff;color:var(--blue);border-color:#fff;box-shadow:0 4px 12px #fff6;transform:scale(1.1)}.wizard-step.completed .step-number{background:#22c55e;border-color:#22c55e;color:#fff}.step-label{font-size:13px;font-weight:600;color:#ffffffbf;line-height:1.2;white-space:nowrap}.wizard-step.active .step-label{color:#fff;font-weight:700}.wizard-step.completed .step-label{color:#fffffff2}.step-description{display:none}.wizard-body{flex:1;display:flex;flex-direction:column;background:#f8fafc;overflow:hidden}.wizard-content-wrapper{flex:1;overflow-y:auto;padding:18px 24px}.wizard-step-content{display:none;animation:slideInRight .3s ease}.wizard-step-content.active{display:block}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.paso-seleccion{max-width:100%}.paso-title{font-size:20px;font-weight:700;color:var(--text);margin:0 0 6px}.paso-subtitle{font-size:13px;color:var(--muted);margin:0 0 18px}.filtros-mo{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;background:#fff;padding:16px;border-radius:12px;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;font-weight:600;color:var(--text)}.form-group label .required{color:var(--red);margin-left:2px}.form-control{padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;background:#fff;color:var(--text);transition:all .2s}.form-control:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #345bff1a}.consolidar-checkbox{display:flex;align-items:center;gap:10px;padding:14px 18px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:10px;margin-bottom:20px;border:1px solid #C7D2FE;transition:all .2s}.consolidar-checkbox:hover{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);border-color:#a5b4fc}.consolidar-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--blue)}.consolidar-checkbox label{font-size:14px;font-weight:600;color:#3730a3;cursor:pointer;margin:0;-webkit-user-select:none;user-select:none}.mo-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb;overflow:hidden;overflow-y:auto}.mo-table{width:100%;border-collapse:collapse}.mo-table thead{background:linear-gradient(180deg,#f8fafc,#f1f5f9);position:sticky;top:0;z-index:10}.mo-table th{padding:14px 16px;text-align:left;font-size:11px;font-weight:700;color:#475569;text-transform:uppercase;border-bottom:2px solid #e5e7eb;letter-spacing:.5px}.mo-table tbody tr{border-bottom:1px solid #f1f5f9;transition:all .2s}.mo-table tbody tr:hover{background:#f8fafc}.mo-table td{padding:14px 16px;font-size:13px;color:var(--text)}.mo-table input[type=checkbox]{width:17px;height:17px;cursor:pointer;accent-color:var(--blue)}.paso-datos{max-width:100%}.form-section{background:#fff;padding:20px;border-radius:12px;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb;margin-bottom:20px}.section-title{font-size:17px;font-weight:700;color:var(--text);margin:0 0 18px;padding-bottom:10px;border-bottom:2px solid #e5e7eb;display:flex;align-items:center;gap:8px}.form-row{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:16px}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-help{font-size:12px;color:var(--muted);margin-top:4px}.paso-resumen{max-width:100%}.resumen-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:20px}.resumen-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb}.resumen-card-title{font-size:17px;font-weight:700;color:var(--text);margin:0 0 18px;display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:2px solid #e5e7eb}.resumen-card-title i{color:var(--blue);font-size:18px}.resumen-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}.resumen-item:last-child{border-bottom:none}.resumen-label{font-size:13px;font-weight:600;color:var(--muted)}.resumen-value{font-size:13px;color:var(--text);font-weight:500}.consolidado-table{width:100%;border-collapse:collapse}.consolidado-table thead{background:linear-gradient(180deg,#f8fafc,#f1f5f9)}.consolidado-table th{padding:12px 14px;text-align:left;font-size:11px;font-weight:700;color:#475569;text-transform:uppercase;border-bottom:2px solid #e5e7eb;letter-spacing:.5px}.consolidado-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .15s}.consolidado-table tbody tr:hover{background:#f8fafc}.consolidado-table td{padding:12px 14px;font-size:14px;color:var(--text)}.consolidado-table tfoot{border-top:2px solid #e5e7eb}.consolidado-table tfoot td{padding:12px 14px;font-weight:600}.total-row{background:linear-gradient(180deg,#f8fafc,#f1f5f9);color:#1e293b;border-top:3px solid #e5e7eb}.total-row td{font-size:17px;font-weight:700;padding:14px}.wizard-footer{padding:10px 22px;border-top:2px solid #E5E7EB;display:flex;justify-content:space-between;align-items:center;background:#fff;box-shadow:0 -4px 12px #0000000f;flex-shrink:0}.wizard-footer-left,.wizard-footer-right{display:flex;gap:8px}.btn{padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;border:none;white-space:nowrap}.btn i{font-size:12px}.btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.btn-secondary:hover{background:#e2e8f0;border-color:#94a3b8;color:#334155;transform:translateY(-1px)}.btn-primary{background:var(--blue);color:#fff;box-shadow:0 2px 6px #345bff33}.btn-primary:hover{background:#2847cc;transform:translateY(-1px);box-shadow:0 4px 12px #345bff59}.btn-success{background:#22c55e;color:#fff;box-shadow:0 2px 6px #22c55e33}.btn-success:hover{background:#16a34a;transform:translateY(-1px);box-shadow:0 4px 12px #22c55e59}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.loading-container,.empty-state{text-align:center;padding:60px 20px}.loading-container i,.empty-state i{font-size:48px;color:var(--muted);margin-bottom:16px}.loading-container p,.empty-state p{font-size:16px;color:var(--muted);margin:0}@media(max-width:1024px){.cotizaciones-controls{flex-direction:column;align-items:stretch}.cotizaciones-filters{flex-wrap:wrap}.resumen-layout{grid-template-columns:1fr}}@media(max-width:768px){.filtros-mo,.form-row-2{grid-template-columns:1fr}.wizard-steps{flex-direction:column;gap:12px}.wizard-step:after{display:none}}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:capitalize;white-space:nowrap}.badge i{font-size:11px}.badge-borrador{background:#f3f4f6;color:#6b7280}.badge-pendiente{background:#fef3c7;color:#d97706}.badge-actualizacion{background:#dbeafe;color:#2563eb}.badge-aprobado{background:#d1fae5;color:#059669}.badge-rechazado{background:#fee2e2;color:#dc2626}.badge-cancelado{background:#f3f4f6;color:#9ca3af}.motivo-rechazo-tooltip{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-left:8px;background:#fee2e2;border-radius:50%;cursor:help;transition:all .2s ease}.motivo-rechazo-tooltip i{font-size:12px;color:#dc2626}.motivo-rechazo-tooltip:hover{background:#fecaca;transform:scale(1.1)}.comentario-actualizacion-section{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:8px;padding:12px 16px;margin:12px 24px;box-shadow:0 2px 8px #f59e0b26}.comentario-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.comentario-header i{font-size:14px;color:#d97706}.comentario-header h4{margin:0;font-size:14px;font-weight:700;color:#92400e}.comentario-header .required{color:#dc2626;font-size:14px;font-weight:700}.comentario-help{margin:0 0 8px;font-size:11px;color:#78350f;font-style:italic;line-height:1.3}.textarea-comentario{width:100%;padding:8px 10px;border:2px solid #fbbf24;border-radius:6px;font-size:13px;font-family:inherit;resize:vertical;transition:all .2s ease;background:#ffffffe6;min-height:60px}.textarea-comentario:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a;background:#fff}.textarea-comentario::placeholder{color:#a16207;opacity:.6}.btn-action.btn-info{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-action.btn-info:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.modal-motivo-rechazo{background:#fff;border-radius:16px;width:90%;max-width:600px;box-shadow:0 20px 60px #0000004d;animation:slideDown .3s ease-out}.modal-header-rechazo{background:linear-gradient(135deg,#dc2626,#b91c1c);padding:20px 24px;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;align-items:center}.modal-header-rechazo h2{margin:0;color:#fff;font-size:22px;font-weight:700;display:flex;align-items:center;gap:12px}.modal-header-rechazo h2 i{font-size:24px}.modal-header-rechazo .close-modal{background:#fff3;border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-header-rechazo .close-modal:hover{background:#ffffff4d;transform:rotate(90deg)}.modal-body-rechazo{padding:32px 24px}.motivo-content{display:flex;gap:16px;align-items:flex-start;background:#fef2f2;border-left:4px solid #dc2626;padding:20px;border-radius:8px}.motivo-content i{font-size:24px;color:#dc2626;margin-top:2px;flex-shrink:0}.motivo-content p{margin:0;font-size:15px;line-height:1.6;color:#991b1b;font-weight:500}.modal-footer-rechazo{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:12px}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.mo-cotizaciones-semana-page{padding:2rem;max-width:1600px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.header-left{display:flex;align-items:center;gap:1rem}.header-left svg{color:#3b82f6}.page-header h1{margin:0;font-size:1.75rem;color:#1f2937}.page-header p{margin:.25rem 0 0;color:#6b7280;font-size:.875rem}.btn-export{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#10b981;color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-weight:500;transition:all .2s}.btn-export:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.btn-export:disabled{background:#d1d5db;cursor:not-allowed}.filters-section{display:none}.table-container{background:#fff;border-radius:.75rem;border:1px solid #e5e7eb;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.data-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.data-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background .2s}.data-table tbody tr:hover{background:#f9fafb}.data-table td{padding:.875rem 1rem;font-size:.875rem;color:#374151}.data-table tfoot{background:#f9fafb;border-top:2px solid #e5e7eb}.data-table tfoot td{padding:1rem;font-size:.9375rem}.text-right{text-align:right!important}.font-mono{font-family:Courier New,monospace}.font-bold{font-weight:600}.totals-row{background:#eff6ff!important}.totals-row td{color:#1e40af;font-size:1rem!important}.loading{padding:4rem;text-align:center;color:#6b7280;font-size:1.125rem}.no-data{padding:4rem;text-align:center;color:#9ca3af}.no-data svg{margin:0 auto 1rem;opacity:.5}.no-data p{font-size:1.125rem;margin:.5rem 0}.no-data small{font-size:.875rem;color:#d1d5db}.results-summary{padding:1rem 1.5rem;background:#f9fafb;border-top:1px solid #e5e7eb;text-align:right;font-size:.875rem;color:#6b7280}@media(max-width:1024px){.table-container{overflow-x:auto}.data-table{min-width:1200px}}@media(max-width:768px){.mo-cotizaciones-semana-page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.filters-section{grid-template-columns:1fr}}:root{--blue: #345BFF;--blue-soft: #EEF2FF;--border: #E5E7EB;--text: #0f172a;--muted: #64748b;--green: #22C55E;--orange: #F97316;--cyan: #06b6d4;--red: #ef4444;--yellow: #f59e0b}.control-presupuestal-page{margin:0;background:#fff;color:var(--text);font-family:system-ui,sans-serif;padding:24px;min-height:100vh}.container{max-width:1600px;margin:0 auto;padding:0}.control-header{margin-bottom:24px}.control-header h1{margin:0;font-size:32px;font-weight:800;color:#000}.control-header h1 .text-blue{color:var(--blue);font-weight:700}.control-header p{margin:6px 0 0;font-size:14px;color:var(--muted)}.solicitudes-table-container{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden}.solicitudes-table{width:100%;border-collapse:collapse}.solicitudes-table thead{background:var(--blue-soft)}.solicitudes-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border)}.solicitudes-table td{padding:16px;border-bottom:1px solid var(--border);font-size:14px;color:var(--text)}.solicitudes-table tbody tr:hover{background:#f9fafb}.solicitudes-table tbody tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.badge.pendiente{background:#fef3c7;color:#92400e}.formato-badge{display:inline-block;background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#6b21a8;padding:3px 8px;border-radius:5px;font-size:10px;font-weight:700;margin-bottom:10px}.btn-validar{padding:8px 16px;background:var(--blue);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px}.btn-validar:hover{background:#2847cc;transform:translateY(-1px);box-shadow:0 4px 12px #345bff4d}.btn-pdf{padding:8px 12px;background:#dc2626;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn-pdf:hover{background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.modal-content-control{background:#fff;border-radius:16px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header-control{padding:14px 18px;background:linear-gradient(135deg,var(--blue) 0%,#5B7CFF 100%);color:#fff;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10;box-shadow:0 2px 8px #0000001a}.modal-header-control h2{margin:0;font-size:17px;font-weight:700;letter-spacing:-.3px}.btn-close{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:16px}.btn-close:hover{background:#ffffff4d}.resumen-section{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;border-radius:10px;padding:10px;margin:20px 24px 16px}.resumen-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:8px}.resumen-item{display:flex;flex-direction:column;gap:2px}.resumen-item label{display:block;font-size:8px;font-weight:700;color:#0369a1;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.resumen-item .value{font-size:11px;font-weight:700;color:#0c4a6e}.total-box{background:#fff;border:2px solid var(--green);border-radius:8px;padding:8px 12px;display:flex;justify-content:space-between;align-items:center}.total-box label{font-size:9px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.total-box .value{font-size:18px;color:var(--green);font-weight:800}.modal-body-control{padding:20px 24px;max-height:70vh;overflow-y:auto;border-radius:0}.modal-body-control::-webkit-scrollbar{width:6px}.modal-body-control::-webkit-scrollbar-track{background:transparent;border-radius:0}.modal-body-control::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.modal-body-control::-webkit-scrollbar-thumb:hover{background:#0000004d}.formato-solicitud-box{background:#f8f9fa;border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:16px}.formato-solicitud-box h3{margin:0 0 12px;font-size:11px;color:var(--text);font-weight:700;text-transform:uppercase;letter-spacing:.8px;padding-bottom:8px;border-bottom:2px solid var(--border)}.info-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:8px 0;border-bottom:1px solid #f3f4f6}.info-row:last-child{margin-bottom:0;border-bottom:none}.info-col{display:flex;flex-direction:column;gap:4px}.info-item label{display:block;font-size:9px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.info-col span{font-size:13px;color:var(--text);font-weight:600}.id-sap-section{margin-bottom:16px}.id-sap-section label{display:block;font-size:11px;font-weight:700;color:var(--text);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.id-sap-section .required{color:var(--red)}.input-sap{width:100%;padding:10px 12px;border:2px solid var(--border);border-radius:8px;font-size:14px;font-weight:600;transition:all .2s;background:#fff}.input-sap:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.rechazo-section{margin-bottom:16px}.rechazo-section label{display:block;font-size:11px;font-weight:700;color:var(--text);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.textarea-rechazo{width:100%;padding:10px 12px;border:2px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;resize:vertical;transition:all .2s;background:#fff}.textarea-rechazo:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.modal-footer-control{padding:16px 20px;background:#fff;border-top:1px solid var(--border);border-radius:0 0 16px 16px;display:flex;gap:10px;justify-content:flex-end;align-items:center}.btn-control{padding:10px 18px!important;border:none!important;border-radius:6px!important;font-size:13px!important;font-weight:600!important;cursor:pointer;transition:all .2s ease;display:inline-flex!important;align-items:center;justify-content:center;gap:6px;letter-spacing:.2px;position:relative;overflow:hidden;width:130px!important;min-width:130px!important;max-width:130px!important;white-space:nowrap;box-sizing:border-box}.btn-control:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-control:hover:before{width:300px;height:300px}.btn-control i{font-size:14px;position:relative;z-index:1}.btn-control:disabled{opacity:.5;cursor:not-allowed}.btn-control:disabled:before{display:none}.btn-asignar{background:linear-gradient(135deg,#345bff,#5b7cff)!important;color:#fff!important;box-shadow:0 2px 8px #345bff40!important}.btn-asignar:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #345bff59!important}.btn-asignar:active:not(:disabled){transform:translateY(0)}.btn-rechazar{background:linear-gradient(135deg,#ef4444,#dc2626)!important;color:#fff!important;box-shadow:0 2px 8px #ef444440!important}.btn-rechazar:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ef444459!important}.btn-rechazar:active:not(:disabled){transform:translateY(0)}.btn-cancelar{background:linear-gradient(135deg,#6c757d,#5a6268)!important;color:#fff!important;border:none!important;box-shadow:0 2px 8px #6c757d40!important}.btn-cancelar:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #6c757d59!important}.btn-cancelar:active:not(:disabled){transform:translateY(0)}@media(max-width:768px){.modal-content-control{width:95%;max-height:95vh}.resumen-grid,.info-row{grid-template-columns:1fr}.modal-footer-control{flex-direction:column;gap:10px}.btn-control{width:100%;min-width:unset}}.loading-container{display:flex;justify-content:center;align-items:center;padding:60px;color:var(--muted);font-size:15px}.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}.empty-state i{font-size:48px;margin-bottom:16px;opacity:.5}.actualizacion-badge{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #2563eb;border-radius:12px;padding:16px 20px;margin:0 24px 20px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #2563eb26}.actualizacion-badge i{font-size:20px;color:#2563eb;animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.actualizacion-badge span{font-weight:700;color:#1e40af;font-size:14px;letter-spacing:.5px}.actualizacion-badge .motivo-previo{margin-left:auto;padding:8px 12px;background:#fffc;border-radius:6px;font-size:12px;color:#dc2626}.actualizacion-badge .motivo-previo strong{color:#991b1b;margin-right:6px}.actualizacion-badge .comentario-actualizacion-display{width:100%;margin-top:12px;padding:10px 14px;background:#fffffff2;border-left:4px solid #2563eb;border-radius:6px;font-size:13px;color:#1e40af;line-height:1.5}.actualizacion-badge .comentario-actualizacion-display strong{color:#1e3a8a;margin-right:8px;display:inline-block}:root{--blue: #345BFF;--blue-soft: #EEF2FF;--border: #E5E7EB;--text: #0f172a;--muted: #64748b;--green: #22C55E;--orange: #F97316}*{box-sizing:border-box}.aclaraciones-mo-page{margin:0;background:#fff;color:var(--text);font-family:system-ui,sans-serif;padding:0;min-height:100vh}.container{max-width:1600px;margin:30px auto;padding:0}.aclaraciones-header{margin-bottom:18px;margin-left:24px;margin-right:24px;background:transparent;border:none;padding:0;box-shadow:none}.aclaraciones-header h1{margin:0;font-size:32px;font-weight:800;color:#000;background:none}.aclaraciones-header h1 .text-blue{color:var(--blue);font-weight:700}.aclaraciones-header p{margin:6px 0 0;font-size:14px;color:var(--muted)}.header-stats{display:none}.aclaraciones-page{margin:0;background:#fff;color:var(--text);font-family:system-ui,sans-serif;padding:24px;min-height:100vh}.aclaraciones-title{margin-bottom:18px}.aclaraciones-title h1{margin:0;font-size:32px;font-weight:800;color:#000}.aclaraciones-title h1 .text-blue{color:var(--blue);font-weight:700}.aclaraciones-title p{margin:6px 0 0;font-size:14px;color:var(--muted)}.aclaraciones-filters{display:flex;gap:10px;align-items:center;margin-bottom:20px}.aclaraciones-filters select{height:36px;padding:0 12px;border-radius:8px;border:2px solid var(--blue);background:#fff;font-size:14px;color:var(--text);font-weight:500;cursor:pointer;transition:all .2s}.aclaraciones-filters select:hover{border-color:#1e3a8a;background:var(--blue-soft)}.aclaraciones-filters select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #345bff1a}.btn-limpiar{height:36px;padding:0 20px;border-radius:8px;border:none;background:var(--blue);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-limpiar:hover{background:#1e3a8a;transform:translateY(-1px);box-shadow:0 4px 12px #345bff4d}.btn-limpiar:active{transform:translateY(0)}.aclaraciones-filters-advanced{display:flex;gap:12px;align-items:center;margin-bottom:20px}.multi-select-dropdown{position:relative;min-width:200px}.multi-select-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px;display:block}.multi-select-trigger{height:36px;padding:0 12px;border-radius:8px;border:2px solid var(--blue);background:#fff;font-size:14px;color:var(--text);font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:space-between;gap:8px}.multi-select-trigger:hover{border-color:#1e3a8a;background:var(--blue-soft)}.multi-select-dropdown-menu{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:2px solid var(--blue);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:300px;overflow-y:auto}.multi-select-search{padding:8px;border-bottom:1px solid var(--border)}.multi-select-search input{width:100%;height:32px;padding:0 10px;border:1px solid var(--border);border-radius:6px;font-size:13px}.multi-select-options{padding:4px}.multi-select-option{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;border-radius:6px;transition:background .15s}.multi-select-option:hover{background:var(--blue-soft)}.multi-select-option input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--blue)}.checkbox-filter{display:flex;align-items:center}.checkbox-filter label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text);font-weight:500}.checkbox-filter input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--blue)}.action-buttons{display:flex;gap:12px;margin-bottom:20px;justify-content:flex-end}.btn-guardar,.btn-enviar{height:40px;padding:0 24px;border-radius:10px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.btn-guardar{background:var(--orange);color:#fff}.btn-guardar:hover{background:#ea580c;transform:translateY(-2px);box-shadow:0 4px 12px #f973164d}.btn-guardar:disabled{background:#cbd5e1;cursor:not-allowed;transform:none}.btn-enviar{background:var(--green);color:#fff}.btn-enviar:hover{background:#16a34a;transform:translateY(-2px);box-shadow:0 4px 12px #22c55e4d}.btn-enviar:active,.btn-guardar:active{transform:translateY(0)}.multiselect-container{position:relative;min-width:220px}.multiselect-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px;display:block}.multiselect-trigger{height:38px;padding:0 14px;border-radius:8px;border:2px solid var(--blue);background:#fff;font-size:14px;color:var(--text);font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:space-between;gap:10px}.multiselect-trigger:hover{border-color:#1e3a8a;background:var(--blue-soft)}.multiselect-trigger .placeholder{color:var(--muted)}.multiselect-trigger .selected-text{color:var(--text);font-weight:600}.multiselect-trigger .arrow{font-size:10px;transition:transform .2s;color:var(--blue)}.multiselect-trigger .arrow.open{transform:rotate(180deg)}.multiselect-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:2px solid var(--blue);border-radius:10px;box-shadow:0 6px 16px #00000026;z-index:1000;max-height:320px;overflow:hidden;display:flex;flex-direction:column}.multiselect-search{padding:10px;border-bottom:1px solid var(--border);background:var(--blue-soft)}.multiselect-search input{width:100%;height:34px;padding:0 12px;border:1px solid var(--border);border-radius:6px;font-size:13px}.multiselect-search input:focus{outline:none;border-color:var(--blue)}.multiselect-options{padding:6px;overflow-y:auto;max-height:220px}.multiselect-option{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;border-radius:6px;transition:background .15s;font-size:14px}.multiselect-option:hover{background:var(--blue-soft)}.multiselect-option input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--blue)}.multiselect-footer{padding:8px 10px;border-top:1px solid var(--border);background:var(--blue-soft)}.multiselect-footer .clear-btn{width:100%;height:32px;border:none;background:var(--blue);color:#fff;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.multiselect-footer .clear-btn:hover{background:#1e3a8a}.no-results{padding:20px;text-align:center;color:var(--muted);font-size:13px}.filters{display:flex;gap:10px;align-items:center;margin-bottom:14px;margin-left:24px;margin-right:24px}.filter-select{height:32px;padding:0 10px;border-radius:8px;border:1px solid var(--border);background:#fff;font-size:13px;color:var(--text);cursor:pointer}.filter-btn{height:32px;padding:0 14px;border-radius:8px;border:none;background:var(--blue);color:#fff;font-size:13px;cursor:pointer;font-weight:600}.filter-btn:hover{background:#2847cc}.table-wrapper{border:1px solid var(--border);border-radius:14px;overflow:hidden;margin:0 24px;padding:0;background:#fff}.aclaraciones-table{width:100%;border-collapse:collapse;text-align:center}.aclaraciones-table thead th{background:var(--blue);color:#fff;padding:12px 6px;font-size:12px;text-transform:uppercase;border:none;text-align:center;font-weight:700;letter-spacing:.5px;white-space:nowrap}.aclaraciones-table thead .weeks th{background:var(--blue-soft);color:#1e3a8a;font-size:11px;font-weight:600;padding:8px 6px;line-height:1.4}.aclaraciones-table tbody td{padding:10px 6px;border-bottom:1px solid #f1f5f9;font-size:13px;color:var(--text);font-weight:500}.input-cell{width:70px;height:32px;border-radius:8px;border:1px solid #c7d2fe;text-align:center;font-size:14px;background:#fff;color:var(--text);font-weight:600}.input-cell:focus{outline:none;border-color:var(--blue)}.input-cell::placeholder{color:#9ca3af}.input-text{width:90px;height:32px;border-radius:8px;border:1px solid #c7d2fe;text-align:left;padding:0 8px;font-size:13px}.total-badge{background:#e0e7ff;padding:6px 10px;border-radius:10px;font-weight:700;display:inline-block;color:var(--text)}.td-center{text-align:center}.actions{display:flex;justify-content:center;gap:8px}.btn-ver-comentarios,.btn-corregir{width:28px;height:26px;border-radius:8px;border:none;color:#fff;font-size:11px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1}.btn-ver-comentarios{background:var(--orange)}.btn-ver-comentarios:hover{background:#ea580c}.btn-corregir{background:var(--green)}.btn-corregir:hover:not(:disabled){background:#16a34a}.btn-corregir:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:16px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:24px 28px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:var(--blue-soft)}.modal-header h3{margin:0;font-size:20px;font-weight:700;color:var(--text)}.modal-close{width:32px;height:32px;border-radius:8px;background:#fee2e2;border:none;color:#dc2626;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#fecaca}.modal-body{padding:28px;max-height:calc(80vh - 100px);overflow-y:auto}.modal-info{background:var(--blue-soft);padding:16px 20px;border-radius:10px;margin-bottom:20px;border-left:3px solid var(--blue)}.modal-info p{margin:6px 0;font-size:14px;color:var(--text);font-weight:500}.modal-info strong{color:var(--text);font-weight:700}.modal-comentarios{background:#fef2f2;border-left:3px solid #ef4444;padding:16px 20px;border-radius:10px;font-size:15px;line-height:1.6;color:#7f1d1d;font-weight:600;white-space:pre-wrap;word-wrap:break-word}.loading-state{text-align:center;padding:80px}.spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 20px}.loading-state p{font-size:16px;color:var(--muted);font-weight:600}.empty-state{text-align:center;padding:80px;background:#fff;border:1px solid var(--border);border-radius:12px;margin:40px}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h3{margin:0 0 12px;font-size:22px;font-weight:700;color:var(--text)}.empty-state p{margin:0;font-size:15px;color:var(--muted);font-weight:500}.table-wrapper::-webkit-scrollbar,.modal-body::-webkit-scrollbar{width:12px;height:12px}.table-wrapper::-webkit-scrollbar-track,.modal-body::-webkit-scrollbar-track{background:#f3f4f6}.table-wrapper::-webkit-scrollbar-thumb,.modal-body::-webkit-scrollbar-thumb{background:#9ca3af;border-radius:6px;border:3px solid #f3f4f6}.table-wrapper::-webkit-scrollbar-thumb:hover,.modal-body::-webkit-scrollbar-thumb:hover{background:#6b7280}.filter-panel{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:16px 20px;margin-bottom:18px;box-shadow:0 2px 8px #345bff0d}.filter-row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.filter-field{display:flex;flex-direction:column;gap:5px;min-width:120px}.filter-field label,.filter-field .filter-field-label{font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:#64748b}.filter-field select{height:38px;padding:0 10px;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;font-size:13px;color:#0f172a;font-weight:500;cursor:pointer;transition:border-color .15s;appearance:auto}.filter-field select:focus,.filter-field select:hover{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #345bff14}.filter-period-pair{display:flex;gap:6px}.filter-period-pair select{min-width:90px}.btn-filter-clear{height:38px;padding:0 18px;border-radius:8px;border:1.5px solid #e2e8f0;background:#fff;color:#64748b;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;align-self:flex-end;display:flex;align-items:center;gap:6px}.btn-filter-clear:hover{border-color:#ef4444;color:#ef4444;background:#fef2f2}.msd-wrap{position:relative;min-width:160px;display:flex;flex-direction:column;gap:5px}.msd-label{font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:#64748b}.msd-trigger{height:38px;padding:0 12px;border-radius:8px;border:1.5px solid #e2e8f0;background:#fff;font-size:13px;color:#0f172a;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:border-color .15s,box-shadow .15s;-webkit-user-select:none;user-select:none}.msd-trigger:hover,.msd-trigger.open{border-color:var(--blue);box-shadow:0 0 0 3px #345bff14}.msd-ph{color:#94a3b8}.msd-sel{color:#0f172a;font-weight:600}.msd-right{display:flex;align-items:center;gap:5px;flex-shrink:0}.msd-badge{background:var(--blue);color:#fff;border-radius:20px;font-size:10px;font-weight:700;padding:1px 7px;line-height:1.6}.msd-arrow{font-size:12px;color:#94a3b8;transition:transform .2s;display:inline-block}.msd-arrow.up{transform:rotate(180deg)}.msd-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:220px;width:max-content;max-width:320px;background:#fff;border:1.5px solid var(--blue);border-radius:12px;box-shadow:0 8px 24px #345bff24;z-index:2000;overflow:hidden;animation:msdIn .15s ease}@keyframes msdIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.msd-search{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid #f1f5f9;background:#f8faff}.msd-search-icon{font-size:14px;flex-shrink:0}.msd-search input{flex:1;height:30px;border:1.5px solid #e2e8f0;border-radius:6px;padding:0 10px;font-size:13px;color:#0f172a;outline:none;transition:border-color .15s}.msd-search input:focus{border-color:var(--blue)}.msd-actions{display:flex;gap:6px;padding:8px 12px;border-bottom:1px solid #f1f5f9}.msd-btn-all,.msd-btn-none{flex:1;height:26px;border-radius:6px;border:1.5px solid;font-size:10px;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 6px;min-width:0}.msd-btn-all{border-color:var(--blue);color:var(--blue);background:var(--blue-soft)}.msd-btn-all:hover{background:var(--blue);color:#fff}.msd-btn-none{border-color:#e2e8f0;color:#64748b;background:#fff}.msd-btn-none:hover{border-color:#ef4444;color:#ef4444;background:#fef2f2}.msd-options{padding:6px;max-height:220px;overflow-y:auto}.msd-option{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;cursor:pointer;font-size:13px;color:#0f172a;transition:background .12s}.msd-option:hover{background:#f0f4ff}.msd-option.checked{background:#eef2ff;font-weight:600}.msd-option input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:var(--blue);flex-shrink:0}.msd-empty{padding:20px;text-align:center;color:#94a3b8;font-size:13px}.msd-options::-webkit-scrollbar{width:6px}.msd-options::-webkit-scrollbar-track{background:transparent}.msd-options::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.catalogos-tabs-container{background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}.catalogos-tabs{display:flex;border-bottom:2px solid var(--border);background:#fafafa;overflow-x:auto;gap:0}.catalogos-tab{padding:14px 24px;background:none;border:none;border-bottom:3px solid transparent;color:var(--muted);font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;white-space:nowrap;position:relative;margin-bottom:-2px}.catalogos-tab:hover{color:var(--text);background:#345bff0d}.catalogos-tab.active{color:var(--blue);border-bottom-color:var(--blue);background:#fff;font-weight:700}.catalogos-content{padding:24px;background:#fff}.catalogos-tabs::-webkit-scrollbar{height:4px}.catalogos-tabs::-webkit-scrollbar-track{background:#f1f1f1}.catalogos-tabs::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.catalogos-tabs::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media(max-width:768px){.catalogos-tab{padding:12px 16px;font-size:13px}.catalogos-content{padding:16px}}.bloqueo-semanas-page{padding:24px;max-width:1400px;margin:0 auto}.bloqueo-header{margin-bottom:24px}.bloqueo-header h1{margin:0;font-size:32px;font-weight:800;color:#000}.bloqueo-header h1 .text-blue{color:#345bff;font-weight:700}.bloqueo-header p{margin:6px 0 0;font-size:14px;color:#64748b}.bloqueo-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid #E5E7EB}.bloqueo-tabs .tab{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;font-size:14px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.bloqueo-tabs .tab:hover{color:#345bff}.bloqueo-tabs .tab.active{color:#345bff;border-bottom-color:#345bff}.bloqueo-content{display:flex;flex-direction:column;gap:24px}.bloqueo-section{background:#fff;border:1px solid #E5E7EB;border-radius:12px;padding:24px}.bloqueo-section h3{margin:0 0 20px;font-size:18px;font-weight:700;color:#0f172a}.bloqueo-form{margin-bottom:20px}.bloqueo-form:last-child{margin-bottom:0}.bloqueo-form label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:#0f172a}.form-row{display:flex;gap:12px;align-items:center}.input-semana{flex:1;max-width:200px;height:40px;padding:0 12px;border:2px solid #345BFF;border-radius:8px;font-size:14px;font-weight:500;color:#0f172a}.input-semana:focus{outline:none;border-color:#1e3a8a;box-shadow:0 0 0 3px #345bff1a}.btn{height:40px;padding:0 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:#345bff;color:#fff}.btn-primary:hover{background:#1e3a8a;transform:translateY(-1px);box-shadow:0 4px 12px #345bff4d}.btn-secondary{background:#64748b;color:#fff}.btn-secondary:hover{background:#475569}.btn-sm{height:32px;padding:0 16px;font-size:13px}.table-container{overflow-x:auto;border-radius:8px;border:1px solid #E5E7EB}.table{width:100%;border-collapse:collapse}.table thead th{background:#345bff;color:#fff;padding:12px 16px;font-size:13px;font-weight:700;text-align:left;text-transform:uppercase;letter-spacing:.5px}.table tbody td{padding:12px 16px;border-bottom:1px solid #f1f5f9;font-size:14px;color:#0f172a}.table tbody tr:hover{background:#f8fafc}.badge{display:inline-block;padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600}.badge-bloqueada{background:#fee2e2;color:#991b1b}.badge-desbloqueada{background:#dcfce7;color:#15803d}.loading{text-align:center;padding:40px;color:#64748b;font-size:14px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.modal-content{background:#fff;border-radius:12px;padding:24px;max-width:500px;width:90%;box-shadow:0 20px 25px -5px #0000001a}.modal-content h3{margin:0 0 12px;font-size:20px;font-weight:700;color:#0f172a}.modal-content p{margin:0 0 20px;font-size:14px;color:#64748b}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:#0f172a}.textarea{width:100%;padding:12px;border:2px solid #E5E7EB;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical}.textarea:focus{outline:none;border-color:#345bff;box-shadow:0 0 0 3px #345bff1a}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.progress-dashboard-page{padding:24px;min-height:100vh;background:#fff;font-family:Inter,Segoe UI,sans-serif}.pd-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px;margin-bottom:24px}.pd-title{font-size:26px;font-weight:800;color:#1e293b;margin:0 0 4px}.pd-title span{color:#3b82f6}.pd-subtitle{font-size:13px;color:#64748b;margin:0}.pd-week-selector{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;padding:10px 16px;box-shadow:0 1px 4px #0000000f;flex-wrap:wrap}.pd-week-label{font-size:13px;font-weight:600;color:#475569;display:flex;align-items:center;gap:6px}.pd-week-label i{color:#3b82f6}.pd-select{border:1.5px solid #e2e8f0;border-radius:8px;padding:6px 10px;font-size:13.5px;font-weight:600;color:#1e293b;background:#fff;cursor:pointer;outline:none;min-width:70px}.pd-select:focus{border-color:#3b82f6}.pd-iso-badge{font-size:13px;font-weight:700;color:#3b82f6;background:#eff6ff;border:1px solid #bfdbfe;border-radius:20px;padding:3px 12px}.pd-refresh-btn{width:36px;height:36px;border-radius:50%;border:none;background:#3b82f6;color:#fff;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s}.pd-refresh-btn:hover{background:#2563eb;transform:rotate(180deg)}.pd-kpis{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px}.pd-kpi-card{flex:1 1 140px;background:#fff;border-radius:14px;padding:16px 20px;box-shadow:0 2px 8px #0000000f;border:1px solid #f1f5f9;text-align:center;transition:transform .15s}.pd-kpi-card:hover{transform:translateY(-2px)}.pd-kpi-value{font-size:28px;font-weight:900;line-height:1.1}.pd-kpi-label{font-size:12px;color:#64748b;font-weight:600;margin-top:4px;text-transform:uppercase;letter-spacing:.4px}.pd-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:80px 0;color:#64748b}.pd-spinner{width:48px;height:48px;border:5px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.pd-empty{text-align:center;padding:80px 20px;color:#94a3b8}.pd-empty-icon{font-size:56px;margin-bottom:12px}.pd-empty h3{font-size:20px;color:#475569;margin:0 0 6px}.pd-empty p{font-size:14px;margin:0}.pd-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.pd-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:16px;padding:20px;box-shadow:0 2px 10px #0000000d;transition:transform .15s,box-shadow .15s}.pd-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001a}.pd-card-clickable{cursor:pointer}.pd-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.pd-card-name{font-size:15px;font-weight:700;color:#1e293b;margin:0;line-height:1.3;max-width:170px}.pd-card-badge{font-size:13px;font-weight:800;color:#fff;border-radius:20px;padding:3px 12px;flex-shrink:0}.pd-card-body{display:flex;align-items:center;gap:20px;margin-bottom:18px}.pd-gauge{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.pd-gauge-label{font-size:11px;color:#94a3b8;font-weight:500;text-transform:uppercase;letter-spacing:.4px}.pd-stats{display:flex;flex-direction:column;gap:12px;flex:1}.pd-stat{display:flex;flex-direction:column;gap:1px}.pd-stat-num{font-size:22px;font-weight:800;line-height:1}.pd-stat-lbl{font-size:11px;color:#94a3b8;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.pd-cap-section{border-top:1px solid #f1f5f9;padding-top:14px;margin-bottom:10px}.pd-cap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.pd-cap-title{font-size:12px;font-weight:600;color:#475569}.pd-cap-nums{font-size:12px;color:#475569}.pd-cap-nums strong{color:#1e293b}.pd-cap-bar-bg{height:8px;background:#f1f5f9;border-radius:8px;overflow:hidden;margin-bottom:5px}.pd-cap-bar-fill{height:100%;border-radius:8px;transition:width .7s ease}.pd-cap-pct{font-size:11px;font-weight:600;text-align:right}.pd-card-hint{font-size:11.5px;color:#64748b;text-align:center;padding:6px;background:#00000008;border-radius:8px;margin-top:4px}.pd-modal-overlay{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.pd-modal{background:#fff;border-radius:18px;padding:0;max-width:600px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}.pd-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 14px;border-bottom:1px solid #f1f5f9}.pd-modal-header h2{font-size:18px;font-weight:800;color:#1e293b;margin:0}.pd-modal-close{background:#f1f5f9;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:14px;color:#64748b;display:flex;align-items:center;justify-content:center;transition:background .15s}.pd-modal-close:hover{background:#e2e8f0}.pd-modal-sub{font-size:13px;color:#64748b;padding:10px 24px 0;margin:0}.pd-modal-body{overflow-y:auto;padding:16px 24px 24px;flex:1}.pd-modal-table{width:100%;border-collapse:collapse;font-size:13.5px}.pd-modal-table th{text-align:left;padding:9px 12px;background:#f8fafc;color:#475569;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid #e2e8f0}.pd-modal-table td{padding:9px 12px;border-bottom:1px solid #f1f5f9;color:#1e293b}.pd-modal-table tr:last-child td{border-bottom:none}.pd-modal-table tr:hover td{background:#f8fafc}@media(max-width:640px){.progress-dashboard-page{padding:16px}.pd-header{flex-direction:column}.pd-grid{grid-template-columns:1fr}.pd-kpi-card{flex:1 1 calc(50% - 7px)}}.api-keys-page{padding:2rem;max-width:1400px;margin:0 auto}.page-title{margin-bottom:2rem}.page-title h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.page-title .text-blue{color:#3b82f6}.page-title p{color:#6b7280;font-size:1rem}.tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #e5e7eb}.tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:#6b7280;transition:all .2s}.tab:hover{color:#3b82f6}.tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.action-buttons{margin-bottom:1.5rem;display:flex;gap:1rem}.btn-crear{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-crear:hover{background:#2563eb}.table-container{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.api-keys-table{width:100%;border-collapse:collapse}.api-keys-table thead{background:#f9fafb}.api-keys-table th{padding:1rem;text-align:left;font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.api-keys-table td{padding:1rem;border-top:1px solid #e5e7eb;font-size:.875rem}.api-keys-table tbody tr:hover{background:#f9fafb}.key-name{font-weight:600;color:#111827}.api-key-cell{display:flex;align-items:center;gap:.5rem}.api-key-cell code{background:#f3f4f6;padding:.25rem .5rem;border-radius:.25rem;font-family:Courier New,monospace;font-size:.75rem}.btn-copy{padding:.25rem .5rem;background:#e5e7eb;border:none;border-radius:.25rem;cursor:pointer;font-size:.875rem;transition:background .2s}.btn-copy:hover{background:#d1d5db}.description{color:#6b7280;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;display:inline-block}.badge-active{background:#d1fae5;color:#065f46}.badge-inactive{background:#fee2e2;color:#991b1b}.actions-cell{display:flex;gap:.5rem}.actions-cell button{padding:.5rem;border:none;border-radius:.375rem;cursor:pointer;font-size:1rem;transition:all .2s}.btn-stats{background:#dbeafe}.btn-stats:hover{background:#bfdbfe}.btn-logs{background:#e0e7ff}.btn-logs:hover{background:#c7d2fe}.btn-revoke{background:#fee2e2}.btn-revoke:hover{background:#fecaca}.btn-activate{background:#d1fae5}.btn-activate:hover{background:#a7f3d0}.btn-delete{background:#fef3c7}.btn-delete:hover{background:#fde68a}.stats-panel{margin-top:2rem;padding:1.5rem;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.stats-panel h3{margin-bottom:1rem;font-size:1.25rem;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.stat-card{padding:1.5rem;background:#f9fafb;border-radius:.5rem;text-align:center}.stat-value{font-size:2rem;font-weight:700;color:#3b82f6;margin-bottom:.5rem}.stat-label{font-size:.875rem;color:#6b7280;font-weight:500}.btn-close-stats{padding:.5rem 1rem;background:#e5e7eb;border:none;border-radius:.375rem;cursor:pointer;font-weight:500}.btn-close-stats:hover{background:#d1d5db}.logs-table{width:100%;border-collapse:collapse}.logs-table thead{background:#f9fafb}.logs-table th{padding:1rem;text-align:left;font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase}.logs-table td{padding:.75rem 1rem;border-top:1px solid #e5e7eb;font-size:.875rem}.logs-table tbody tr:hover{background:#f9fafb}.method-badge{padding:.25rem .5rem;background:#dbeafe;color:#1e40af;border-radius:.25rem;font-size:.75rem;font-weight:600}.status-badge{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.status-2xx{background:#d1fae5;color:#065f46}.status-4xx{background:#fef3c7;color:#92400e}.status-5xx{background:#fee2e2;color:#991b1b}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:.75rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h2{margin-bottom:1.5rem;font-size:1.5rem;font-weight:600}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn-cancel{padding:.75rem 1.5rem;background:#e5e7eb;border:none;border-radius:.375rem;font-weight:500;cursor:pointer}.btn-cancel:hover{background:#d1d5db}.btn-submit{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.375rem;font-weight:600;cursor:pointer}.btn-submit:hover{background:#2563eb}.loading-state{padding:3rem;text-align:center}.spinner{width:3rem;height:3rem;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{padding:3rem;text-align:center;color:#6b7280}:root{--color-primary: #0f172a;--color-primary-light: #1e293b;--color-primary-dark: #020617;--color-accent: #06b6d4;--color-accent-light: #22d3ee;--color-accent-dark: #0891b2;--color-bg: #f8fafc;--color-surface: #ffffff;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--color-text: #0f172a;--color-text-muted: #64748b;--color-text-light: #94a3b8;--color-success: #10b981;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-error: #ef4444;--color-error-light: #fee2e2;--color-info: #3b82f6;--color-info-light: #dbeafe;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--sidebar-width: 240px;--header-height: 64px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body,h1,h2,h3,h4,h5,h6,p,figure,blockquote,dl,dd{margin:0}ul,ol{list-style:none;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh;text-rendering:optimizeSpeed;line-height:1.5;font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text);background-color:#fff}img,picture,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}button{background:none;border:none;cursor:pointer;padding:0}a{text-decoration:none;color:inherit}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-border-light)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.app-container{display:flex;height:100vh;overflow:hidden;background:#fff}.sidebar{width:var(--sidebar-width);background:#fff;color:#0f172a;display:flex;flex-direction:column;flex-shrink:0;box-shadow:2px 0 8px #0000001a;z-index:var(--z-fixed);transition:width .3s ease;position:relative;border-right:1px solid #E5E7EB}.sidebar.collapsed{width:70px}.sidebar-toggle{position:absolute;top:12px;right:-12px;width:24px;height:24px;background:#345bff;border:2px solid #ffffff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:100;box-shadow:0 2px 8px #00000026}.sidebar-toggle:hover{background:#1e3a8a;transform:scale(1.1)}.sidebar-toggle svg{width:14px;height:14px;color:#fff}.sidebar-header{height:var(--header-height);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);border-bottom:1px solid #E5E7EB}.sidebar-logo{display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .3s ease;padding:0 8px;width:100%;overflow:hidden}.sidebar.collapsed .sidebar-logo{justify-content:center}.sidebar-logo-image{width:100%;max-width:100px;height:auto;object-fit:contain;transition:all .3s ease}.sidebar-logo-image-small{width:30px;height:auto;object-fit:contain}.sidebar-module-text{font-size:9px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.sidebar.collapsed .sidebar-module-text{opacity:0;width:0}.sidebar-logo-icon{width:32px;height:32px;color:var(--color-accent)}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--spacing-lg) var(--spacing-md)}.sidebar-section{margin-bottom:var(--spacing-xl)}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:var(--spacing-sm);padding:0 var(--spacing-sm)}.sidebar-menu{display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:#0f172a;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-base);cursor:pointer}.sidebar.collapsed .sidebar-link{justify-content:center;padding:var(--spacing-sm)}.sidebar-link span:not(.sidebar-link-icon){transition:opacity .2s ease}.sidebar.collapsed .sidebar-link span:not(.sidebar-link-icon){opacity:0;width:0;overflow:hidden}.sidebar-link:hover{background:#eef2ff;color:#345bff}.sidebar-link.active{background:#345bff;color:#fff;box-shadow:0 2px 4px #345bff33;font-weight:600}.sidebar-link-icon{width:20px;height:20px;flex-shrink:0}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid #E5E7EB}.sidebar-user{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-md);transition:background var(--transition-base)}.sidebar-user:hover{background:#ffffff0d}.sidebar-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-dark));display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);flex-shrink:0}.sidebar-user-info{flex:1;min-width:0;transition:opacity .2s ease}.sidebar.collapsed .sidebar-user-info{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .sidebar-user{justify-content:center}.sidebar-user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:var(--font-size-xs);color:#64748b;text-transform:capitalize}.sidebar-logout{color:#64748b;transition:color var(--transition-base)}.sidebar-logout:hover{color:var(--color-error)}.main-wrapper{flex:1;display:flex;flex-direction:column;min-width:0;background:#fff}.header{height:var(--header-height);background:#fff;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-xl);flex-shrink:0;box-shadow:var(--shadow-sm);z-index:var(--z-sticky)}.header-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text)}.header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.header-status{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-success-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-success)}.header-status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-success);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.content{flex:1;overflow-y:auto;padding:var(--spacing-xl);background:#fff}.content-container{max-width:1400px;margin:0 auto}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);transition:transform var(--transition-base)}.sidebar.open{transform:translate(0)}.main-wrapper{width:100%}.header{padding:0 var(--spacing-md)}.content{padding:var(--spacing-md)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-base);cursor:pointer;border:none;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-accent-dark);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-accent)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;box-shadow:var(--shadow-md)}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-xs)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-base)}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);overflow:hidden}.card-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-bg)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);margin-bottom:var(--spacing-sm)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text);background:var(--color-surface);transition:all var(--transition-base)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #06b6d41a}.form-input::placeholder{color:var(--color-text-light)}.form-textarea{resize:vertical;min-height:100px}.form-error{font-size:var(--font-size-xs);color:var(--color-error);margin-top:var(--spacing-xs)}.form-help{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-error{background:var(--color-error-light);color:var(--color-error)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.table{width:100%;border-collapse:collapse;background:var(--color-surface)}.table thead{background:var(--color-bg);border-bottom:2px solid var(--color-border)}.table th{padding:var(--spacing-md);text-align:left;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.table td{padding:var(--spacing-md);border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-sm)}.table tbody tr:hover{background:var(--color-bg)}.table tbody tr:last-child td{border-bottom:none}.alert{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);border-left:4px solid;font-size:var(--font-size-sm)}.alert-success{background:var(--color-success-light);border-color:var(--color-success);color:var(--color-success)}.alert-warning{background:var(--color-warning-light);border-color:var(--color-warning);color:#92400e}.alert-error{background:var(--color-error-light);border-color:var(--color-error);color:#991b1b}.alert-info{background:var(--color-info-light);border-color:var(--color-info);color:#1e40af}.grid{display:grid;gap:var(--spacing-lg)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media(max-width:768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-muted{color:var(--color-text-muted)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:500px;max-height:90vh;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-header h3{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text)}.modal-close{background:none;border:none;font-size:24px;color:var(--color-text-muted);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-base)}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-body{padding:var(--spacing-lg);max-height:calc(90vh - 140px);overflow-y:auto}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-bg)}� �{}
