.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#e9f2fa,#d4e3f0 40%,#f0f4f8);position:relative;overflow:hidden;font-family:Inter,Segoe UI,system-ui,sans-serif;padding:2rem}.bubble-container{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}@keyframes float-up{0%{transform:translateY(0) translate(0) rotate(0) scale(1);opacity:.08}to{transform:translateY(-120vh) translate(30px) rotate(360deg) scale(.4);opacity:0}}.peace-bubble{position:absolute;background:radial-gradient(circle at 30% 30%,#a3c6e6,#5f9ea0);border-radius:30% 70% 70% 30%/30% 30% 70% 70%;animation:float-up linear infinite;filter:blur(1px)}.page-loader-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(145deg,#e9f2fa,#d4e3f0 40%,#f0f4f8);display:flex;align-items:center;justify-content:center;z-index:200;opacity:1;transition:opacity .4s ease}.page-loader-overlay.hidden{opacity:0;pointer-events:none}.loader{width:50px;aspect-ratio:1;--c: no-repeat radial-gradient(farthest-side, #2d6a9f 92%, #0000);background:var(--c) 50% 0,var(--c) 50% 100%,var(--c) 100% 50%,var(--c) 0 50%;background-size:10px 10px;animation:l18 1s infinite;position:relative}.loader:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;margin:3px;background:repeating-conic-gradient(#0000 0,#0000 35deg,#2d6a9f 0,#2d6a9f 90deg);-webkit-mask:radial-gradient(farthest-side,#0000 calc(100% - 3px),#000 0);border-radius:50%}@keyframes l18{to{transform:rotate(.5turn)}}.login-panel{display:flex;width:960px;max-width:95vw;min-height:560px;background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:2.5rem;box-shadow:0 30px 60px #00143226,0 0 0 1px #ffffff80;overflow:hidden;z-index:2;opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease}.login-panel.visible{opacity:1;transform:translateY(0)}.panel-left{width:42%;background:linear-gradient(135deg,#1a4b6e,#2d6a9f);display:flex;align-items:center;justify-content:center;position:relative;padding:2.5rem;color:#fff}.panel-left-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image: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:.6}.brand-content{text-align:center;position:relative;z-index:1}.logo-wrapper{margin-bottom:2rem}.brand-logo{width:120px;height:120px;border-radius:24px;object-fit:cover;box-shadow:0 20px 35px #0000004d;border:2px solid rgba(255,255,255,.2);background:#fff}.logo-placeholder{width:120px;height:120px;background:#ffffff26;border-radius:24px;display:flex;align-items:center;justify-content:center;margin:0 auto;color:#fff}.brand-name{font-size:2.4rem;font-weight:600;letter-spacing:3px;margin:0 0 1rem;text-shadow:0 2px 10px rgba(0,0,0,.3)}.brand-divider{width:50px;height:3px;background:#fff9;margin:0 auto 1.2rem;border-radius:2px}.brand-slogan{font-size:1rem;font-weight:400;opacity:.9;margin:0 0 .5rem;line-height:1.4}.brand-mission{font-size:.85rem;font-style:italic;opacity:.7;margin:0}.panel-right{width:58%;display:flex;align-items:center;justify-content:center;padding:3rem}.form-wrapper{width:100%;max-width:360px}.form-header{margin-bottom:2.5rem}.form-title{font-size:2rem;font-weight:600;color:#1a2b3c;margin:0 0 .5rem}.form-subtitle{color:#5a6d7e;font-size:.95rem;margin:0}.field-group{margin-bottom:1.5rem}.field-label{display:block;font-size:.85rem;font-weight:500;color:#1e3b4f;margin-bottom:.5rem;letter-spacing:.3px}.input-icon-group{display:flex;align-items:center;gap:10px}.input-icon{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#f0f6fce6;border:1px solid rgba(0,0,0,.07);border-radius:12px;color:#5a7a96}.input-icon svg{width:20px;height:20px;display:block}.form-input{flex:1;padding:14px 16px;background:#f0f6fccc;border:1px solid rgba(0,0,0,.05);border-radius:14px;font-size:.95rem;color:#1a2b3c;outline:none;transition:all .25s ease;box-shadow:0 2px 6px #00000005}.form-input:focus{background:#fff;border-color:#2d6a9f;box-shadow:0 0 0 4px #2d6a9f26}.form-input::placeholder{color:#a0b3c9}.input-with-toggle{position:relative;flex:1;display:flex;align-items:center}.input-with-toggle .form-input{width:100%;padding-right:44px}.toggle-password{position:absolute;right:12px;background:none;border:none;font-size:1.2rem;cursor:pointer;opacity:.6;transition:opacity .2s;padding:4px}.toggle-password:hover{opacity:1}.error-message{background:#fff0f0;color:#c44545;padding:12px 16px;border-radius:12px;font-size:.85rem;margin-bottom:1.5rem;border-left:4px solid #c44545}.submit-button{width:100%;padding:15px;background:linear-gradient(135deg,#1a4b6e,#2d6a9f);color:#fff;border:none;border-radius:14px;font-size:1rem;font-weight:600;letter-spacing:.4px;cursor:pointer;transition:all .3s ease;margin-top:.8rem;box-shadow:0 8px 20px #1a4b6e4d;display:flex;align-items:center;justify-content:center;gap:.5rem}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 15px 30px #1a4b6e66;background:linear-gradient(135deg,#1e5880,#3477ad)}.submit-button:disabled{opacity:.7;cursor:wait}.form-footer{margin-top:2rem;text-align:center;font-size:.75rem;color:#7c8b99}@media (max-width: 768px){.login-panel{flex-direction:column;max-width:420px}.panel-left{width:100%;padding:2.5rem 1.5rem}.panel-right{width:100%;padding:2rem 1.5rem}.brand-logo{width:80px;height:80px}.brand-name{font-size:1.8rem}}.events-container{padding:28px 24px;background:#f8fafc;min-height:100vh;font-family:Segoe UI,system-ui,sans-serif;max-width:100%;overflow-x:hidden}.sticky-header{position:sticky;top:0;z-index:50;background:#fff;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:16px 24px;border-radius:14px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;margin-bottom:20px;border-bottom:3px solid #3b82f6;gap:12px}.sticky-header h1{margin:0;font-size:1.3rem;color:#0f172a;font-weight:700;letter-spacing:-.3px}.sticky-header p{margin:2px 0 0;font-size:.8rem;color:#94a3b8}.mode-selector-btn{display:flex;align-items:center;gap:6px;background:#f8fafc;border:1px solid #e2e8f0;padding:8px 14px;border-radius:8px;font-weight:500;font-size:.85rem;color:#475569;cursor:pointer;transition:background .15s}.mode-selector-btn:hover{background:#f1f5f9}.exchange-card{display:flex;align-items:center;gap:8px;background:#eff6ff;padding:8px 14px;border-radius:8px;border:1px solid #dbeafe;font-weight:600;font-size:.85rem;color:#1d4ed8}.exchange-card input{width:80px;border:none;background:transparent;color:#1d4ed8;font-weight:700;font-size:.95rem;border-bottom:1.5px solid #93c5fd;padding:2px 0;outline:none}.btn-export{background:#2563eb;color:#fff;border:none;padding:9px 22px;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .15s,transform .15s;white-space:nowrap}.btn-export:hover{background:#1d4ed8;transform:translateY(-1px)}.final-export-actions{display:flex;justify-content:flex-end;padding:16px 0 8px}.tabs-container{display:flex;gap:6px;margin-bottom:20px;background:#fff;padding:6px;border-radius:12px;box-shadow:0 1px 3px #0000000f;width:fit-content;border:1px solid #f1f5f9}.tab-button{padding:9px 28px;border:none;background:transparent;border-radius:8px;font-weight:600;font-size:.9rem;color:#64748b;cursor:pointer;transition:all .15s;letter-spacing:.1px}.tab-button:hover:not(.active){background:#f8fafc;color:#334155}.tab-button.active{background:#2563eb;color:#fff;box-shadow:0 2px 4px #2563eb4d}.tab-button:last-child.active{background:#d97706;box-shadow:0 2px 4px #d977064d;color:#fff}.section-header h2{font-size:1rem;color:#1e293b;font-weight:700;margin:0;display:flex;align-items:center;gap:8px}.section-header h2:before{content:"";display:inline-block;width:4px;height:18px;background:#3b82f6;border-radius:4px;flex-shrink:0}.section-divider{border:none;border-top:1px solid #f1f5f9;margin:0 0 20px}.icon-blue{color:#3b82f6}.icon-yellow{color:#d97706}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-bottom:20px}.input-group{display:flex;flex-direction:column;gap:5px}.input-group label{font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.input-group input,.input-group textarea{padding:9px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;background:#fff;color:#1e293b;transition:border-color .15s,box-shadow .15s;font-family:inherit}.input-group input:focus,.input-group textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.dual-input{display:flex;gap:10px;flex-wrap:nowrap;min-width:0;flex-direction:column;gap:4px}.dual-input input{flex:1}.full-width{grid-column:1 / -1}.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:12px}.meta-card{background:#f8fafc;border:1px solid #f1f5f9;border-radius:12px;padding:16px 20px}.meta-title{display:flex;align-items:center;gap:7px;color:#334155;font-weight:600;font-size:.85rem;margin-bottom:14px;text-transform:uppercase;letter-spacing:.4px}.meta-content{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end}.meta-field{display:flex;flex-direction:column;gap:4px}.meta-field label{font-size:.68rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.3px}.meta-field input{padding:8px 10px;border:1px solid #e2e8f0;border-radius:7px;font-size:.88rem;background:#fff;color:#1e293b;transition:border-color .15s}.meta-field input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.total-badge{background:#2563eb;color:#fff;padding:7px 16px;border-radius:20px;font-weight:700;font-size:.85rem;white-space:nowrap;letter-spacing:.2px}.moneda-selector{display:flex;gap:12px;align-items:center;padding:4px 0}.moneda-option{display:flex;align-items:center;gap:8px;padding:9px 18px;border:1.5px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .15s;font-size:.9rem;font-weight:500;color:#475569;background:#fff}.moneda-option.selected{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8;font-weight:600}.moneda-option input[type=radio]{width:16px;height:16px;accent-color:#2563eb}.rows-container{display:flex;flex-direction:column;gap:14px;margin-bottom:16px}.row-card{background:#fafbfc;border:1px solid #e9eef4;border-left:3px solid #3b82f6;border-radius:10px;padding:18px 20px;transition:border-color .2s,box-shadow .2s}.row-card:hover{border-color:#c7d7ed;border-left-color:#2563eb;box-shadow:0 4px 12px #0000000a}.row-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.row-number{font-weight:700;color:#2563eb;font-size:.78rem;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:6px}.row-number:before{content:"";display:inline-block;width:6px;height:6px;background:#3b82f6;border-radius:50%}.btn-del{border:none;background:transparent;color:#94a3b8;padding:5px 8px;border-radius:6px;cursor:pointer;display:flex;align-items:center;transition:all .15s}.btn-del:hover:not(:disabled){background:#fee2e2;color:#ef4444}.row-body{display:flex;flex-direction:column;gap:14px}.form-row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.form-group{display:flex;flex-direction:column;gap:4px;flex:1 1 170px}.form-group.large{flex:2 1 280px}.form-group label{font-size:.68rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px}.form-group input,.form-group select{width:100%;padding:8px 11px;border:1px solid #e2e8f0;border-radius:7px;font-size:.88rem;background:#fff;color:#1e293b;transition:border-color .15s,box-shadow .15s;font-family:inherit}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-group input[readonly]{background:#f8fafc;color:#475569;cursor:default}.form-group select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.categoria-selector{display:flex;gap:7px;flex-wrap:wrap}.categoria-selector select{flex:1 1 130px}.costs-row{background:#f8fafc;border:1px solid #f1f5f9;padding:14px 16px;border-radius:10px;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.cost-group{display:flex;flex-direction:column;gap:4px;flex:1 1 130px}.cost-group label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.cost-group.colones label{color:#059669}.cost-group.dollars label{color:#2563eb}.cost-group input{padding:8px 10px;border:1px solid #e2e8f0;border-radius:7px;font-size:.88rem;background:#fff;transition:border-color .15s}.cost-group input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.cost-group input[readonly]{background:#f1f5f9;color:#64748b}.checkbox-row{align-items:flex-start;gap:20px}.checkbox-group{display:flex;flex-direction:column;gap:7px;flex:1 1 180px}.checkbox-group>label{font-size:.68rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px}.checkbox-list{display:flex;flex-wrap:wrap;gap:8px}.checkbox-list label{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid #e2e8f0;border-radius:20px;font-size:.82rem;font-weight:500;color:#475569;cursor:pointer;transition:all .15s;background:#fff;text-transform:none;-webkit-user-select:none;user-select:none}.checkbox-list label:has(input:checked){background:#eff6ff;border-color:#93c5fd;color:#1d4ed8;font-weight:600}.checkbox-list input[type=checkbox]{width:14px;height:14px;accent-color:#2563eb}.obs-input{width:100%;margin-top:8px;border:1px dashed #e2e8f0;border-radius:8px;padding:12px 14px;min-height:72px;font-size:.88rem;font-family:inherit;resize:vertical;color:#475569;background:#fafbfc;transition:border-color .15s}.obs-input::placeholder{color:#cbd5e1}.obs-input:focus{border-color:#3b82f6;border-style:solid;outline:none;box-shadow:0 0 0 3px #3b82f614}.proveedor-search-block{background:#f0f9ff;border:1px solid #bae6fd;border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:10px}.proveedor-search-label{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:4px}.proveedor-search-label span:first-child{font-weight:700;color:#0369a1;font-size:.82rem;text-transform:uppercase;letter-spacing:.3px}.proveedor-search-hint{font-size:.73rem;color:#94a3b8;font-style:italic}.cedula-search-row{display:flex;gap:8px;align-items:center}.cedula-input{flex:1;padding:9px 12px;border:1px solid #7dd3fc;border-radius:7px;font-size:.9rem;background:#fff;color:#1e293b;transition:border-color .15s;font-family:inherit}.cedula-input:focus{border-color:#0284c7;outline:none;box-shadow:0 0 0 3px #0284c71f}.cedula-input:disabled{background:#e0f2fe;color:#0369a1;font-weight:600}.cedula-input.cedula-found{border-color:#4ade80;background:#f0fdf4;color:#166534}.btn-buscar-proveedor{background:#0284c7;color:#fff;border:none;padding:9px 20px;border-radius:7px;font-weight:600;cursor:pointer;font-size:.85rem;white-space:nowrap;transition:background .15s}.btn-buscar-proveedor:hover{background:#0369a1}.btn-cambiar-proveedor{background:transparent;color:#94a3b8;border:1px solid #e2e8f0;padding:9px 14px;border-radius:7px;font-weight:500;cursor:pointer;font-size:.82rem;white-space:nowrap;transition:all .15s}.btn-cambiar-proveedor:hover{background:#fee2e2;border-color:#fca5a5;color:#ef4444}.proveedor-info-badge{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:9px 14px}.proveedor-info-row{display:flex;flex-wrap:wrap;gap:14px}.proveedor-info-item{font-size:.82rem;color:#166534}.proveedor-info-item strong{color:#14532d}.btn-add{background:#fff;color:#16a34a;border:1px solid #bbf7d0;padding:8px 16px;border-radius:20px;cursor:pointer;font-weight:600;font-size:.82rem;display:flex;align-items:center;gap:6px;transition:all .15s;white-space:nowrap}.btn-add:hover:not(:disabled){background:#f0fdf4;border-color:#86efac}.collapsible-header{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:10px;transition:background .15s}.collapse-toggle{background:none;border:1px solid #e2e8f0;border-radius:8px;padding:5px 8px;cursor:pointer;color:#64748b;display:flex;align-items:center;transition:all .15s;flex-shrink:0}.row-count-badge{font-size:.72rem;font-weight:600;background:#f1f5f9;color:#64748b;padding:2px 8px;border-radius:20px;border:1px solid #e2e8f0}.mode-selector-btn.mode-automatic{background:#f5f3ff;border-color:#c4b5fd;color:#6d28d9}.mode-selector-btn.mode-individual{background:#fff7ed;border-color:#fed7aa;color:#c2410c}.mode-selector-btn.mode-manual{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.mode-selector-btn:hover{filter:brightness(.96)}.mode-pill{font-size:.67rem;font-weight:700;padding:2px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}.mode-pill-automatic{background:#ede9fe;color:#6d28d9;border:1px solid #c4b5fd}.mode-pill-individual{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}.mode-pill-manual{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.mode-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.mode-modal{background:#fff;border-radius:20px;padding:32px 28px 24px;max-width:600px;width:100%;box-shadow:0 20px 60px #0003;animation:modal-in .22s ease}@keyframes modal-in{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.mode-modal-header{margin-bottom:24px;text-align:center}.mode-modal-header h3{margin:0 0 6px;font-size:1.2rem;font-weight:700;color:#0f172a}.mode-modal-header p{margin:0;font-size:.85rem;color:#94a3b8}.mode-modal-cards{display:flex;gap:14px;margin-bottom:24px}.mode-card{flex:1;border:2px solid #e2e8f0;border-radius:14px;padding:20px 16px;cursor:pointer;transition:all .18s;position:relative;text-align:center}.mode-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0000001a}.mode-card-icon{margin-bottom:10px;display:flex;justify-content:center}.mode-card-label{font-size:.95rem;font-weight:700;margin-bottom:8px}.mode-card-desc{font-size:.78rem;line-height:1.45;color:#64748b}.mode-card-check{position:absolute;top:10px;right:12px;font-size:.85rem;font-weight:800}.mode-card-automatic .mode-card-icon{color:#7c3aed}.mode-card-automatic .mode-card-label{color:#5b21b6}.mode-card-automatic:hover{border-color:#a78bfa;background:#faf5ff}.mode-card-automatic.selected{border-color:#7c3aed;background:#f5f3ff;box-shadow:0 0 0 3px #7c3aed26}.mode-card-automatic.selected .mode-card-check{color:#7c3aed}.mode-card-individual .mode-card-icon{color:#ea580c}.mode-card-individual .mode-card-label{color:#c2410c}.mode-card-individual:hover{border-color:#fdba74;background:#fff7ed}.mode-card-individual.selected{border-color:#ea580c;background:#fff7ed;box-shadow:0 0 0 3px #ea580c26}.mode-card-individual.selected .mode-card-check{color:#ea580c}.mode-card-manual .mode-card-icon{color:#16a34a}.mode-card-manual .mode-card-label{color:#15803d}.mode-card-manual:hover{border-color:#86efac;background:#f0fdf4}.mode-card-manual.selected{border-color:#16a34a;background:#f0fdf4;box-shadow:0 0 0 3px #16a34a26}.mode-card-manual.selected .mode-card-check{color:#16a34a}.mode-modal-footer{display:flex;gap:10px;justify-content:flex-end}.mode-modal-cancel{background:transparent;border:1px solid #e2e8f0;color:#64748b;padding:10px 20px;border-radius:9px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s}.mode-modal-cancel:hover{background:#f8fafc}.mode-modal-confirm{background:#2563eb;color:#fff;border:none;padding:10px 24px;border-radius:9px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,transform .15s}.mode-modal-confirm:hover{background:#1d4ed8;transform:translateY(-1px)}@media (max-width: 580px){.mode-modal-cards{flex-direction:column}.mode-modal{padding:24px 16px 20px}}@media (max-width: 768px){.sticky-header{flex-direction:column;align-items:flex-start;gap:12px}.action-area{width:100%}.form-row{flex-direction:column;align-items:stretch}.dual-input{flex-direction:column}.meta-content{flex-direction:column;align-items:stretch}.total-badge{align-self:flex-start}.tabs-container{width:100%}.tab-button{flex:1;text-align:center;padding:9px 12px}.costs-row,.checkbox-row,.cedula-search-row{flex-direction:column}.cedula-search-row .cedula-input{width:100%}}.admin-dashboard{max-width:100%;margin:0 auto;padding:16px 24px;height:calc(100vh - 80px);overflow-y:auto;display:flex;flex-direction:column;gap:16px}.carousel{position:relative;height:140px;border-radius:20px;overflow:hidden;box-shadow:0 8px 20px #0000000d}.slide{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;transition:opacity .8s ease;display:flex;align-items:center;justify-content:center;color:#fff;text-align:center}.slide.active{opacity:1}.slide-content h1{font-size:1.6rem;margin-bottom:4px;font-weight:700}.slide-content p{font-size:.95rem;max-width:600px;margin:0 auto}.carousel-dots{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:8px}.dot{width:8px;height:8px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:transparent;cursor:pointer}.dot.active{background:#fff;border-color:#fff;transform:scale(1.2)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stat-card{background:#fff;border-radius:18px;padding:14px 16px;display:flex;align-items:center;gap:10px;box-shadow:0 4px 12px #00000005;border:1px solid #f1f5f9}.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff}.users-icon{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.active-icon{background:linear-gradient(135deg,#10b981,#059669)}.total-reports-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.month-reports-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-label{color:#64748b;font-size:11px;font-weight:500;margin-bottom:2px}.stat-number{color:#0f172a;font-size:24px;font-weight:700;line-height:1}.dashboard-main{display:grid;grid-template-columns:2fr 1fr;gap:16px;flex:1;min-height:0}.calendar-card{background:#fff;border-radius:20px;padding:16px;box-shadow:0 4px 12px #00000005;border:1px solid #f1f5f9;display:flex;flex-direction:column;height:100%}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.calendar-header h2{font-size:16px;font-weight:600;margin:0;text-transform:capitalize}.calendar-nav{display:flex;gap:6px}.nav-btn{width:30px;height:30px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.nav-btn:hover{background:#f1f5f9}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:6px;text-align:center;color:#64748b;font-weight:600;font-size:11px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;flex:1;grid-auto-rows:1fr}.calendar-day{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff;border-radius:8px;font-size:12px;font-weight:500;color:#1e293b;height:100%;min-height:30px}.calendar-day.empty{background:transparent}.calendar-day.today{background:#eff6ff;color:#1e40af;font-weight:700}.day-number{display:block}.day-dots{display:flex;gap:2px;margin-top:2px}.dot{width:1px;height:2px;border-radius:10%}.start-dot{background:#10b981}.end-dot{background:#ef4444}.calendar-legend{display:flex;gap:12px;margin-top:8px;padding-top:6px;border-top:1px solid #f1f5f9;font-size:10px;color:#64748b}.legend-item{display:flex;align-items:center;gap:4px}.today-dot{background:#1e40af;width:7px;height:7px}.upcoming-card{background:#fff;border-radius:20px;padding:16px;box-shadow:0 4px 12px #00000005;border:1px solid #f1f5f9;display:flex;flex-direction:column;height:100%}.upcoming-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.upcoming-header h2{font-size:15px;font-weight:600;margin:0}.badge{background:#f1f5f9;color:#475569;padding:3px 8px;border-radius:30px;font-size:10px}.upcoming-list{list-style:none;padding:0;margin:0;flex:1;overflow-y:auto}.upcoming-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f1f5f9}.upcoming-item:last-child{border-bottom:none}.item-icon{width:32px;height:32px;background:#f8fafc;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#3b82f6;font-size:14px}.item-info{flex:1;display:flex;flex-direction:column}.item-title{font-weight:600;color:#0f172a;font-size:13px}.item-code{font-size:10px;color:#64748b}.item-date{font-size:10px;color:#475569;display:flex;align-items:center;gap:3px}.item-status{padding:2px 6px;border-radius:30px;font-size:10px;font-weight:600;white-space:nowrap}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:16px;color:#64748b}.empty-upcoming{display:flex;flex-direction:column;align-items:center;padding:16px;color:#94a3b8}.upcoming-footer{margin-top:6px;text-align:right}.view-all-link{color:#3b82f6;text-decoration:none;font-size:11px;display:inline-flex;align-items:center;gap:3px}.quick-actions-card{background:#fff;border-radius:20px;padding:14px 16px;box-shadow:0 4px 12px #00000005;border:1px solid #f1f5f9}.quick-actions-card h2{font-size:15px;font-weight:600;margin:0 0 10px}.quick-actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.quick-action{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0;text-decoration:none;transition:all .2s;gap:4px}.quick-action:hover{background:#fff;border-color:#94a3b8;transform:translateY(-1px)}.action-icon{font-size:20px}.quick-action span:last-child{color:#334155;font-weight:500;font-size:11px}@media (max-width: 1000px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-main{grid-template-columns:1fr}.quick-actions-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 600px){.stats-grid,.quick-actions-grid{grid-template-columns:1fr}}.users-container{max-width:1400px;margin:0 auto;padding:20px}.users-header{display:grid;grid-template-columns:1fr auto;gap:30px;margin-bottom:30px;align-items:start}.header-content h1{color:#1e293b;margin-bottom:8px;font-size:28px;font-weight:700}.header-stats{display:flex;gap:15px}.stat-card{display:flex;align-items:center;gap:12px;padding:15px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;border:1px solid #e2e8f0}.users-icon{background:#dbeafe;color:#1d4ed8}.active-icon{background:#dcfce7;color:#16a34a}.alert{padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px;position:relative}.alert-error{background-color:#fef2f2;color:#dc2626;border:1px solid #fecaca}.alert-success{background-color:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.users-content{display:grid;grid-template-columns:400px 1fr;gap:30px;align-items:start}.user-form-card,.users-list-card{background:#fff;border-radius:16px;box-shadow:0 4px 12px #00000014;border:1px solid #e2e8f0;overflow:hidden}.card-header{padding:20px 25px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.btn-cancel{background:#64748b;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:6px}.btn-cancel:hover{background:#475569}.user-form{padding:25px}.form-grid{display:grid;gap:20px;margin-bottom:20px}.form-group label{font-weight:500;color:#374151;margin-bottom:8px;font-size:14px}.form-group input,.form-group select{padding:12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:all .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.checkbox-group{flex-direction:row;align-items:center}.checkbox-label{display:flex;align-items:center;cursor:pointer;gap:8px;font-weight:400;margin:0}.checkmark{width:18px;height:18px;border:2px solid #d1d5db;border-radius:4px;display:inline-block;position:relative}.checkbox-label input[type=checkbox]{display:none}.checkbox-label input[type=checkbox]:checked+.checkmark{background:#3b82f6;border-color:#3b82f6}.checkbox-label input[type=checkbox]:checked+.checkmark:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px}.form-actions{display:flex;justify-content:flex-end}.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:500;display:flex;align-items:center;gap:8px;transition:all .2s}.header-actions{display:flex;align-items:center;gap:15px}.search-box i{position:absolute;left:12px;color:#64748b}.search-box input{padding:10px 12px 10px 36px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;width:250px}.search-box input:focus{outline:none;border-color:#3b82f6}.users-count{color:#64748b;font-size:14px}.empty-state i{font-size:48px;margin-bottom:16px;opacity:.5}.table-container{max-height:545px;overflow-y:auto;border-radius:8px}.users-table{width:100%;border-collapse:collapse;font-size:14px}.users-table th{background-color:#f8fafc;padding:16px;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.users-table td{padding:16px;border-bottom:1px solid #f1f5f9}.users-table tr:hover{background-color:#f8fafc}.users-table tr.inactive{opacity:.7}.user-info{display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:18px;line-height:1;text-transform:uppercase;font-family:Segoe UI,Arial,sans-serif}.user-name{font-weight:500;color:#1e293b}.user-id{font-size:12px;color:#64748b;display:none}.badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500}.badge-admin{background-color:#fef3c7;color:#92400e}.badge-editor{background-color:#dbeafe;color:#1e40af}.badge-user{background-color:#dcfce7;color:#166534}.status-badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;border:none;cursor:pointer;display:flex;align-items:center;gap:4px;transition:opacity .2s}.badge-active{background-color:#dcfce7;color:#166534}.badge-inactive{background-color:#f3f4f6;color:#374151}.btn-action{padding:8px;border:none;border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s}.btn-edit{background-color:#dbeafe;color:#1e40af}.btn-edit:hover{background-color:#bfdbfe}.btn-deactivate{background-color:#fef3c7;color:#b45309}.btn-deactivate:hover{background-color:#fde68a}.btn-activate{background-color:#d1fae5;color:#065f46}.btn-activate:hover{background-color:#a7f3d0}.btn-delete{background-color:#fee2e2;color:#dc2626}.btn-delete:hover:not(:disabled){background-color:#fecaca}.btn-delete:disabled{opacity:.5;cursor:not-allowed}.form-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #f1f5f9}.form-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section-title{font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px;display:flex;align-items:center;gap:6px}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}.required{color:#ef4444}.password-field{position:relative}.password-field input{width:100%;padding-right:40px}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#9ca3af;padding:4px;display:flex;align-items:center;line-height:1;transition:color .15s}.password-toggle:hover{color:#374151}.toggle-group{justify-content:flex-start;padding-left:20px;border-left:2px solid #f1f5f9}.toggle-switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;margin-top:6px;-webkit-user-select:none;user-select:none}.toggle-switch input[type=checkbox]{display:none}.toggle-slider{position:relative;width:42px;height:23px;background:#d1d5db;border-radius:12px;transition:background .2s;flex-shrink:0}.toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:17px;height:17px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider:after{transform:translate(19px)}.toggle-label{font-size:14px;color:#374151;font-weight:500}@media (max-width: 1200px){.users-content{grid-template-columns:1fr}.users-header{grid-template-columns:1fr;gap:20px}}@media (max-width: 768px){.form-row-2{grid-template-columns:1fr}.users-container{padding:15px}.header-stats{flex-direction:column}.stat-card{width:100%}.search-box input{width:200px}.header-actions{flex-direction:column;align-items:flex-start;gap:10px}.card-header{flex-direction:column;align-items:flex-start;gap:15px}.users-table{font-size:12px}.user-info{flex-direction:column;align-items:flex-start;gap:6px}.user-avatar{width:32px;height:32px;font-size:12px}}.merge-container{max-width:860px;margin:0 auto;padding:24px 20px 48px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.merge-header{text-align:center;margin-bottom:32px}.merge-header h1{margin:0 0 8px;font-size:30px;font-weight:700;color:#1f2937}.merge-header p{margin:0;color:#6b7280;font-size:15px}.tools-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}.tool-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 10px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:center}.tool-card:hover{border-color:var(--tc, #4f46e5);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.tool-card-active{border-color:var(--tc, #4f46e5);background:color-mix(in srgb,var(--tc, #4f46e5) 5%,#fff);box-shadow:0 4px 16px color-mix(in srgb,var(--tc, #4f46e5) 20%,transparent)}.tool-card-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tool-card-label{font-size:13px;font-weight:600;color:#1f2937;line-height:1.2}.tool-card-desc{font-size:11px;color:#9ca3af;margin:0;line-height:1.4}.tool-panel-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#f9fafb;border-left:4px solid #4f46e5;border-radius:0 8px 8px 0;margin-bottom:20px;font-weight:600;font-size:15px}.alert{display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border-radius:8px;margin-bottom:16px;font-size:14px}.alert button{background:none;border:none;cursor:pointer;opacity:.7;display:flex}.alert button:hover{opacity:1}.progress-container{margin-bottom:16px}.progress-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:6px}.progress-fill{height:100%;background:#10b981;border-radius:4px;transition:width .3s ease}.progress-text{font-size:13px;color:#6b7280;display:block;text-align:center}.tool-panel{display:flex;flex-direction:column;gap:16px}.drop-area{border:2px dashed #d1d5db;border-radius:12px;padding:36px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;background:#f9fafb;transition:all .3s ease}.drop-area:hover{border-color:#9ca3af;background:#f3f4f6}.drop-area.dragover{background:#e0e7ff;border-color:#6366f1;transform:scale(1.01)}.drop-area.has-files{padding:18px 20px}.drop-content{text-align:center}.drop-icon{color:#9ca3af;margin-bottom:12px;transition:color .3s}.drop-area.dragover .drop-icon{color:#6366f1}.drop-text{font-size:16px;font-weight:500;color:#374151;margin:0 0 6px}.drop-subtext{font-size:13px;color:#6b7280;margin:0}.file-list-header{margin-bottom:12px}.file-list-header h3{margin:0 0 2px;font-size:16px;color:#1f2937}.file-list-header span{font-size:13px;color:#6b7280}.file-list{display:flex;flex-direction:column;gap:8px}.file-item{display:flex;align-items:center;padding:11px 14px;background:#fff;border-radius:8px;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0000000d;transition:box-shadow .2s}.file-item:hover{box-shadow:0 3px 8px #00000014}.file-item-single{margin-bottom:4px}.file-icon{color:#ef4444;margin-right:12px;flex-shrink:0}.file-info{flex:1;min-width:0}.file-name{font-weight:500;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px;font-size:14px}.file-details{display:flex;gap:10px;font-size:12px;color:#6b7280}.file-pages{display:flex;align-items:center}.file-actions{display:flex;gap:4px;margin-left:8px}.action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;color:#4b5563;transition:all .2s}.action-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.action-btn:disabled{opacity:.35;cursor:not-allowed}.action-btn.remove{color:#ef4444}.action-btn.remove:hover{background:#fef2f2;border-color:#fecaca}.action-buttons{display:flex;gap:10px;flex-wrap:wrap;padding-top:4px}.btn{display:flex;align-items:center;gap:7px;padding:10px 18px;border-radius:8px;font-weight:500;font-size:14px;cursor:pointer;transition:all .2s;border:1px solid transparent}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:#4f46e5;color:#fff}.btn-primary:hover:not(:disabled){background:#4338ca}.btn-secondary{background:#fff;color:#4f46e5;border-color:#4f46e5}.btn-secondary:hover:not(:disabled){background:#f5f3ff}.btn-ghost{background:transparent;color:#6b7280;border-color:#e5e7eb}.btn-ghost:hover:not(:disabled){background:#f9fafb;color:#374151}.form-section{display:flex;flex-direction:column;gap:14px}.form-row-group{display:flex;gap:16px;flex-wrap:wrap}.form-row-group .form-group{flex:1;min-width:160px}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:13px;font-weight:500;color:#374151}.form-input{padding:9px 12px;border:1px solid #d1d5db;border-radius:7px;font-size:14px;color:#1f2937;background:#fff;outline:none;transition:border-color .2s}.form-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.form-select{padding:9px 12px;border:1px solid #d1d5db;border-radius:7px;font-size:14px;color:#1f2937;background:#fff;outline:none;transition:border-color .2s;cursor:pointer}.form-select:focus{border-color:#6366f1}.form-textarea{padding:9px 12px;border:1px solid #d1d5db;border-radius:7px;font-size:14px;color:#1f2937;background:#fff;outline:none;resize:vertical;font-family:inherit;transition:border-color .2s}.form-textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.form-range{width:100%;accent-color:#6366f1;cursor:pointer}.form-hint{font-size:12px;color:#9ca3af;margin:2px 0 0}.color-picker-wrap{display:flex;align-items:center;gap:10px}.color-picker{width:44px;height:36px;border:1px solid #d1d5db;border-radius:7px;padding:2px;cursor:pointer;background:none}.mode-tabs{display:flex;gap:4px;background:#f3f4f6;padding:4px;border-radius:10px;width:fit-content}.mode-tab{display:flex;align-items:center;gap:6px;padding:7px 16px;border-radius:7px;border:none;background:transparent;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s}.mode-tab:hover{color:#1f2937;background:#fff9}.mode-tab-active{background:#fff;color:#1f2937;box-shadow:0 1px 4px #0000001a}.info-box{display:flex;align-items:flex-start;gap:9px;padding:11px 14px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;font-size:13px;color:#1d4ed8}.info-box-warn{background:#fffbeb;border-color:#fde68a;color:#92400e}.img-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.img-preview-card{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#fff;display:flex;flex-direction:column;transition:box-shadow .2s}.img-preview-card:hover{box-shadow:0 4px 12px #0000001a}.img-thumb{width:100%;height:100px;object-fit:cover;display:block}.img-preview-info{padding:6px 8px;display:flex;flex-direction:column;gap:2px}.img-preview-name{font-size:11px;font-weight:500;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.img-preview-size{font-size:11px;color:#9ca3af}.img-preview-actions{display:flex;justify-content:center;gap:4px;padding:4px 6px 6px;border-top:1px solid #f3f4f6}.canvas-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}.sign-canvas{border:2px solid #d1d5db;border-radius:10px;background:#fafafa;cursor:crosshair;touch-action:none;max-width:100%}.canvas-hint{font-size:12px;color:#9ca3af;margin:0}.bccr-panel{background:#f8faff;border:1px solid #c7d2fe;border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:16px}.bccr-header{display:flex;align-items:flex-start;gap:14px}.bccr-icon{color:#4f46e5;flex-shrink:0;margin-top:2px}.bccr-header h3{margin:0 0 4px;font-size:16px;color:#1f2937}.bccr-header p{margin:0;font-size:13px;color:#6b7280}.bccr-requirements,.bccr-steps{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:14px 16px}.bccr-requirements h4,.bccr-steps h4{margin:0 0 10px;font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.04em}.bccr-requirements ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:7px}.bccr-requirements li{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:#4b5563}.req-dot{width:6px;height:6px;border-radius:50%;background:#4f46e5;flex-shrink:0;margin-top:5px}.bccr-steps ol{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px}.bccr-steps li{font-size:13px;color:#4b5563}.bccr-btn{background:#4f46e5;color:#fff}.bccr-btn:hover:not(:disabled){background:#4338ca}.compress-result{display:flex;align-items:center;gap:16px;padding:14px 18px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;flex-wrap:wrap}.compress-stat{display:flex;flex-direction:column;gap:2px}.compress-label{font-size:11px;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.compress-value{font-size:16px;font-weight:600;color:#1f2937}.compress-arrow{font-size:20px;color:#9ca3af}.compress-badge{margin-left:auto;padding:5px 12px;border-radius:20px;font-size:14px;font-weight:600}.pass-input-wrap{position:relative;display:flex;align-items:center}.pass-input-wrap .form-input{flex:1;padding-right:40px}.pass-eye{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:#9ca3af;display:flex;padding:0}.pass-eye:hover{color:#4b5563}@media (max-width: 700px){.tools-grid{grid-template-columns:repeat(2,1fr);gap:8px}.tool-card{padding:12px 8px}.tool-card-icon{width:44px;height:44px}.tool-card-desc{display:none}.merge-header h1{font-size:24px}.drop-area{padding:24px 16px}.form-row-group,.action-buttons{flex-direction:column}.btn{justify-content:center}.img-preview-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}@media (max-width: 400px){.tools-grid{grid-template-columns:repeat(2,1fr)}.merge-container{padding:12px}}.historial-container{max-width:1400px;margin:0 auto;padding:24px}.historial-header{display:grid;grid-template-columns:1fr auto;gap:30px;margin-bottom:32px;align-items:start}.header-content h1{color:#0f172a;margin-bottom:8px;font-size:30px;font-weight:800}.header-content p{color:#64748b;font-size:16px;margin:0}.header-stats{display:flex;gap:16px}.stat-card{display:flex;align-items:center;gap:14px;padding:16px 24px;background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000008;border:1px solid #f1f5f9}.stat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px}.total-icon{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.stat-number{font-size:24px;font-weight:700;color:#0f172a}.stat-label{font-size:13px;color:#64748b}.tabs-container{display:flex;gap:10px;margin-bottom:24px}.tab-btn{padding:12px 28px;border:none;border-radius:14px;background:#fff;font-weight:600;font-size:15px;color:#64748b;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0000000a;display:flex;align-items:center;gap:8px}.tab-btn.active{background:#0f172a;color:#fff;box-shadow:0 8px 20px #0f172a33}.tab-btn:hover:not(.active){background:#f1f5f9;color:#0f172a}.filtros-card,.solicitudes-card{background:#fff;border-radius:24px;box-shadow:0 10px 30px #0000000d;border:1px solid #f1f5f9;overflow:hidden;margin-bottom:32px}.card-header{padding:20px 28px;border-bottom:1px solid #f8fafc;display:flex;justify-content:space-between;align-items:center}.card-header h2{color:#0f172a;font-size:18px;font-weight:600;margin:0}.results-count{color:#64748b;font-size:14px;font-weight:500;background:#f8fafc;padding:6px 12px;border-radius:30px}.filtros-content{padding:28px}.filtros-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;margin-bottom:24px}.form-group label{font-weight:600;color:#334155;margin-bottom:8px;font-size:14px}.form-group input,.select-estado{padding:12px 14px;border:1.5px solid #e2e8f0;border-radius:12px;font-size:14px;background:#fafcfc}.filtros-actions{display:flex;gap:14px}.btn-primary,.btn-secondary,.btn-state-modal{padding:12px 20px;border:none;border-radius:12px;cursor:pointer;font-weight:600;display:flex;align-items:center;gap:10px;transition:all .2s;font-size:14px}.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.btn-primary:hover{transform:translateY(-2px)}.btn-secondary{background:#fff;color:#334155;border:1.5px solid #e2e8f0}.btn-secondary:hover{background:#f8fafc}.table-container{overflow-x:auto;border-radius:0 0 24px 24px}.solicitudes-table{width:100%;border-collapse:collapse;font-size:14px}.solicitudes-table th{background:#f8fafc;padding:18px 16px;text-align:left;font-weight:700;color:#334155;border-bottom:2px solid #e2e8f0;font-size:13px;text-transform:uppercase}.solicitudes-table td{padding:18px 16px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.solicitudes-table tr:hover{background:#fafcff}.comentario-cell{max-width:200px;font-style:italic;color:#475569}.project-info{display:flex;align-items:center;gap:14px}.project-avatar{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#3b82f6,#1e40af);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.project-name{font-weight:600;color:#0f172a}.codigo-badge{background:#f1f5f9;padding:6px 12px;border-radius:30px;font-size:12px;font-weight:500}.badge{padding:6px 14px;border-radius:30px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:6px}.badge-pendiente{background:#fff3cd;color:#856404}.badge-aprobada{background:#d1e7dd;color:#0f5132}.badge-rechazada{background:#f8d7da;color:#842029}.badge-completada{background:#dbeafe;color:#1e40af}.action-buttons{display:flex;gap:10px;flex-wrap:wrap}.btn-action{width:38px;height:38px;border:none;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-view{background:#eff6ff;color:#2563eb}.btn-view:hover{background:#dbeafe}.btn-download{background:#e6f7e6;color:#0b5e42}.btn-download:hover{background:#c8f0c8}.btn-state{background:#f3e8ff;color:#7e22ce}.btn-state:hover{background:#e9d5ff}.btn-recibos:hover{background:#a7f3d0!important}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px 24px;gap:12px;color:#94a3b8}.empty-state i{font-size:42px;color:#cbd5e1}.empty-state h3{font-size:16px;font-weight:600;color:#64748b;margin:0}.empty-state p{font-size:14px;margin:0;color:#94a3b8}.loading-state{display:flex;align-items:center;justify-content:center;gap:12px;padding:48px 24px;color:#64748b;font-size:15px}.loading-state i{font-size:22px;color:#3b82f6}.usuario-badge{display:inline-block;font-size:13px;color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;padding:3px 10px;border-radius:20px;white-space:nowrap}.recibos-relacionados-row td{padding:0;background:#f9fafb}.recibos-relacionados-container{padding:16px 24px}.recibos-relacionados-container h4{margin:0 0 12px;color:#065f46;font-size:15px;display:flex;align-items:center;gap:8px}.mini-tabla-recibos{width:100%;border-collapse:collapse;font-size:13px;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000008}.mini-tabla-recibos th{background:#ecfdf5;padding:10px 14px;text-align:left;font-weight:600;color:#065f46}.mini-tabla-recibos td{padding:10px 14px;border-bottom:1px solid #d1fae5}.recibo-num{font-family:Courier New,monospace;font-weight:700;color:#0f172a}.btn-mini-download{background:none;border:1px solid #d1d5db;border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#374151}.btn-mini-download:hover{background:#f3f4f6}.sin-recibos{color:#9ca3af;font-style:italic;margin:8px 0}.recibo-num-grande{font-family:Courier New,monospace;font-weight:700;font-size:15px;color:#0f172a}.pagination{display:flex;justify-content:center;gap:8px;padding:24px 20px}.pagination-btn{min-width:42px;height:42px;border-radius:12px;border:1.5px solid #e2e8f0;background:#fff;color:#334155;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer}.pagination-btn.active{background:#0f172a;color:#fff;border-color:transparent}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-container{background:#fff;border-radius:28px;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:800px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{padding:22px 28px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.modal-close{background:#f1f5f9;border:none;width:38px;height:38px;border-radius:12px;cursor:pointer}.modal-content{padding:28px;overflow-y:auto}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px}.detail-group{display:flex;flex-direction:column}.detail-group.full-width{grid-column:1 / -1}.detail-group label{font-weight:600;color:#475569;margin-bottom:6px;font-size:13px;text-transform:uppercase}.detail-group span{color:#0f172a;font-size:15px;font-weight:500;background:#f8fafc;padding:10px 14px;border-radius:12px;border:1px solid #f1f5f9}.days-remaining{color:#0b5e42!important;background:#e6f7e6!important}.days-late{color:#991b1b!important;background:#fee2e2!important}.modal-actions{padding:20px 28px;border-top:1px solid #f1f5f9;display:flex;gap:14px;justify-content:flex-end}@media (max-width: 768px){.historial-header,.filtros-grid{grid-template-columns:1fr}.action-buttons{flex-wrap:wrap}}.prov-container{padding:30px;background:#f8fafc;min-height:100vh}.prov-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:25px;flex-wrap:wrap;gap:20px}.prov-header h1{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 4px}.prov-header p{color:#64748b;font-size:14px;margin:0}.header-stats{display:flex;gap:15px;flex-wrap:wrap}.stat-card{display:flex;align-items:center;gap:12px;background:#fff;padding:14px 18px;border-radius:12px;box-shadow:0 2px 8px #0000000f;border:1px solid #e2e8f0}.stat-icon{width:45px;height:45px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.prov-icon{background:#dbeafe;color:#1d4ed8}.juridica-icon{background:#fef3c7;color:#d97706}.natural-icon{background:#dcfce7;color:#16a34a}.stat-info{display:flex;flex-direction:column}.stat-number{font-size:20px;font-weight:700;color:#1e293b}.stat-label{font-size:12px;color:#64748b}.alert{padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px}.alert-error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.alert-success{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.alert-close{margin-left:auto;background:none;border:none;cursor:pointer;color:inherit;opacity:.7}.alert-close:hover{opacity:1}.prov-list-card{background:#fff;border-radius:16px;box-shadow:0 4px 12px #00000014;border:1px solid #e2e8f0;overflow:hidden}.card-header{padding:20px 25px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.card-header h2{color:#1e293b;font-size:18px;font-weight:600;margin:0}.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-box{position:relative;display:flex;align-items:center}.search-box i{position:absolute;left:12px;color:#64748b;font-size:13px}.search-box input{padding:9px 12px 9px 34px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;width:220px}.search-box input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-select{padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background:#fff;cursor:pointer}.filter-select:focus{outline:none;border-color:#3b82f6}.btn-export{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0;padding:9px 14px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all .2s}.btn-export:hover:not(:disabled){background:#dcfce7;transform:translateY(-1px);box-shadow:0 2px 8px #16a34a26}.btn-export:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;display:flex;align-items:center;gap:8px;transition:all .2s}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;display:flex;align-items:center;gap:8px;transition:all .2s}.btn-secondary:hover{background:#e2e8f0}.table-container{overflow-x:auto}.prov-table{width:100%;border-collapse:collapse;font-size:14px}.prov-table th{background:#f8fafc;padding:14px 16px;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.prov-table td{padding:14px 16px;border-bottom:1px solid #f1f5f9}.prov-table tr:hover{background:#f8fafc}.prov-table tr.inactive{opacity:.65}.prov-info{display:flex;align-items:center;gap:12px}.prov-avatar{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.avatar-juridica{background:#fef3c7;color:#d97706}.avatar-natural{background:#dbeafe;color:#1d4ed8}.prov-name{font-weight:500;color:#1e293b}.codigo-badge{font-family:monospace;font-size:13px;background:#f1f5f9;color:#475569;padding:3px 8px;border-radius:4px}.badge{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500}.badge-juridica{background:#fef3c7;color:#92400e}.badge-natural{background:#dbeafe;color:#1e40af}.status-badge{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;border:none;cursor:pointer;display:flex;align-items:center;gap:4px;transition:opacity .2s}.status-badge:hover{opacity:.8}.badge-active{background:#dcfce7;color:#166534}.badge-inactive{background:#f3f4f6;color:#374151}.action-buttons{display:flex;gap:8px}.btn-action{padding:7px 9px;border:none;border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s;display:flex;align-items:center;gap:4px}.btn-edit{background:#dbeafe;color:#1e40af}.btn-edit:hover{background:#bfdbfe}.btn-delete{background:#fee2e2;color:#dc2626}.btn-delete:hover{background:#fecaca}.btn-view{background:#e0e7ff;color:#4338ca}.btn-view:hover{background:#c7d2fe}.loading-state,.empty-state{padding:60px 20px;text-align:center;color:#64748b}.loading-state{display:flex;flex-direction:column;align-items:center;gap:10px}.empty-state i{font-size:48px;margin-bottom:16px;opacity:.4}.empty-state h3{margin-bottom:8px;color:#374151}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;padding:20px;border-top:1px solid #f1f5f9}.pagination-btn{padding:8px 12px;border:1px solid #d1d5db;background:#fff;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.pagination-btn:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6}.pagination-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-container{background:#fff;border-radius:20px;width:100%;max-width:760px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003;overflow:hidden}.view-modal{max-width:950px}.export-modal{max-width:520px}.modal-header{padding:22px 28px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:flex-start;flex-shrink:0}.modal-header h2{color:#1e293b;font-size:20px;font-weight:700;margin:0 0 4px}.modal-codigo{font-size:13px;color:#64748b}.modal-codigo i{margin-right:4px}.modal-close{background:#f1f5f9;border:none;width:34px;height:34px;border-radius:8px;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s}.modal-close:hover{background:#e2e8f0;color:#1e293b}.stepper{display:flex;align-items:center;padding:18px 28px;border-bottom:1px solid #f1f5f9;flex-shrink:0;overflow-x:auto}.step{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:default;flex-shrink:0}.step-circle{width:34px;height:34px;border-radius:50%;background:#f1f5f9;color:#94a3b8;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;transition:all .3s}.step-label{font-size:11px;color:#94a3b8;font-weight:500;white-space:nowrap;transition:color .3s}.step-active .step-circle{background:#3b82f6;color:#fff;box-shadow:0 0 0 4px #3b82f633}.step-active .step-label{color:#3b82f6;font-weight:600}.step-done .step-circle{background:#10b981;color:#fff}.step-done .step-label{color:#10b981}.step-done{cursor:pointer}.step-line{flex:1;height:2px;background:#e2e8f0;margin:0 8px 20px;min-width:20px;transition:background .3s}.step-line-done{background:#10b981}.modal-body{padding:28px;overflow-y:auto;flex:1}.view-body{padding:20px 30px;background:#f9fafb}.modal-footer{padding:18px 28px;border-top:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.export-options{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}.export-option-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s;text-align:left;width:100%;font-family:inherit}.export-option-card:hover:not(:disabled){border-color:#16a34a;background:#f0fdf4;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a1a}.export-option-card:disabled{opacity:.5;cursor:not-allowed}.export-option-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.export-icon-all{background:#dbeafe;color:#1d4ed8}.export-icon-juridica{background:#fef3c7;color:#d97706}.export-icon-natural{background:#dcfce7;color:#16a34a}.export-option-info{flex:1;display:flex;flex-direction:column}.export-option-info strong{font-size:15px;color:#1e293b;font-weight:600;margin-bottom:2px}.export-option-info span{font-size:13px;color:#64748b}.export-option-arrow{color:#94a3b8;font-size:14px;transition:transform .2s}.export-option-card:hover:not(:disabled) .export-option-arrow{color:#16a34a;transform:translate(3px)}.export-info-note{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;font-size:13px;color:#64748b}.export-info-note i{color:#3b82f6;font-size:15px;flex-shrink:0}.form-section-title{font-size:15px;font-weight:600;color:#1e293b;margin:0 0 18px;padding-bottom:10px;border-bottom:2px solid #f1f5f9;display:flex;align-items:center;gap:8px}.form-section-title i{color:#3b82f6}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin-bottom:18px}.form-grid-1{display:grid;grid-template-columns:1fr;gap:18px;margin-bottom:18px}.col-span-2{grid-column:span 2}.col-span-3{grid-column:span 3}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:500;color:#374151;margin-bottom:6px;font-size:13px}.form-group label span.req{color:#ef4444;margin-left:2px}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:all .2s;background:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background:#f8fafc;color:#94a3b8}.form-group textarea{resize:vertical;min-height:70px}.char-counter{display:block;text-align:right;font-size:.65rem;color:#9ca3af;margin-top:2px;line-height:1;pointer-events:none;-webkit-user-select:none;user-select:none}.codigo-display{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe;border-radius:10px;padding:16px 20px;display:flex;align-items:center;gap:14px;margin-top:10px}.codigo-display i{font-size:22px;color:#3b82f6}.codigo-display-text{flex:1}.codigo-display-label{font-size:12px;color:#64748b;margin-bottom:3px}.codigo-display-value{font-size:20px;font-weight:700;color:#1d4ed8;font-family:monospace}.codigo-display-empty{font-size:14px;color:#94a3b8;font-style:italic}.tipo-selector{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}.tipo-card{border:2px solid #e2e8f0;border-radius:12px;padding:18px;cursor:pointer;transition:all .2s;text-align:center}.tipo-card:hover{border-color:#93c5fd}.tipo-card.selected-juridica{border-color:#f59e0b;background:#fffbeb}.tipo-card.selected-natural{border-color:#3b82f6;background:#eff6ff}.tipo-card i{font-size:28px;margin-bottom:8px;display:block}.tipo-card.selected-juridica i{color:#d97706}.tipo-card.selected-natural i{color:#2563eb}.tipo-card-label{font-weight:600;font-size:14px;color:#374151;margin-bottom:3px}.tipo-card-desc{font-size:12px;color:#64748b}.cumplimiento-card{border:1px solid #e2e8f0;border-radius:12px;padding:20px;margin-bottom:16px;display:flex;align-items:flex-start;gap:16px;transition:all .2s}.cumplimiento-card.checked-ue{border-color:#6366f1;background:#f5f3ff}.cumplimiento-card.checked-usa{border-color:#ef4444;background:#fef2f2}.cumplimiento-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.icon-ue{background:#ede9fe;color:#7c3aed}.icon-usa{background:#fee2e2;color:#dc2626}.cumplimiento-info{flex:1}.cumplimiento-info strong{display:block;color:#1e293b;font-size:14px;margin-bottom:3px}.cumplimiento-info p{color:#64748b;font-size:13px;margin:0}.toggle-switch{position:relative;width:46px;height:26px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#d1d5db;border-radius:26px;cursor:pointer;transition:.3s}.toggle-slider:before{content:"";position:absolute;width:20px;height:20px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background:#3b82f6}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.estado-toggle{display:flex;align-items:center;gap:12px;padding:14px 18px;border:1px solid #e2e8f0;border-radius:10px;margin-top:8px}.estado-toggle span{font-size:14px;color:#374151;font-weight:500;flex:1}.view-detail-card{background:#fff;border-radius:16px;box-shadow:0 2px 10px #0000000a;margin-bottom:20px;overflow:hidden}.view-detail-card .card-title{background:#f0f4ff;padding:14px 20px;font-weight:600;color:#1e40af;display:flex;align-items:center;gap:10px;font-size:15px}.view-detail-card .card-body{padding:18px 20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px 20px}.view-detail-item{display:flex;flex-direction:column}.view-detail-item .label{font-size:12px;color:#64748b;margin-bottom:3px;font-weight:500}.view-detail-item .value{font-size:14px;color:#1e293b;word-break:break-word}.value-highlight{background:#f1f5f9;padding:2px 8px;border-radius:4px;font-family:monospace;display:inline-block}.badge-estado{display:inline-flex;align-items:center;gap:4px;font-size:13px}*{box-sizing:border-box}.recibo-container{padding:28px 24px;background:#f8fafc;min-height:100vh;font-family:Segoe UI,system-ui,sans-serif;max-width:100%;overflow-x:hidden}.sticky-header{position:sticky;top:0;z-index:50;background:#fff;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:16px 24px;border-radius:14px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;margin-bottom:20px;border-bottom:3px solid #2d6a4f;gap:12px}.sticky-header h1{margin:0;font-size:1.3rem;color:#0f172a;font-weight:700;letter-spacing:-.3px;display:flex;align-items:center}.sticky-header p{margin:8px 0 0;font-size:.8rem;color:#64748b}.action-area{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.exchange-card{display:flex;align-items:center;gap:6px;background:#f0fdf4;padding:8px 14px;border-radius:8px;border:1px solid #bbf7d0;font-weight:600;font-size:.85rem;color:#15803d}.tc-refresh{background:none;border:none;cursor:pointer;color:#15803d;padding:2px;display:flex;align-items:center;transition:transform .3s}.tc-refresh:hover{transform:rotate(180deg)}.btn-export{border:none;padding:9px 22px;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .15s,transform .15s,opacity .15s;white-space:nowrap}.btn-export:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.btn-generar{background:#2d6a4f;color:#fff}.btn-generar:hover:not(:disabled){background:#1e4d38;transform:translateY(-1px)}.btn-export.large{padding:12px 32px;font-size:1rem;border-radius:10px}.autocomplete-wrapper{position:relative;width:100%}.autocomplete-wrapper input{width:100%;padding:9px 13px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.9rem;color:#1e293b;outline:none;transition:border-color .15s}.autocomplete-wrapper input:focus{border-color:#2d6a4f;box-shadow:0 0 0 3px #2d6a4f1f}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #cbd5e1;border-top:none;border-radius:0 0 8px 8px;max-height:200px;overflow-y:auto;z-index:20;list-style:none;padding:0;margin:0;box-shadow:0 4px 6px #0000000d}.autocomplete-dropdown li{padding:8px 14px;cursor:pointer;font-size:.9rem;color:#1e293b;transition:background .1s}.autocomplete-dropdown li:hover{background:#f0fdf4}.section-card{background:#fff;padding:22px 24px;border-radius:14px;margin-bottom:20px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000d}.section-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:20px;gap:12px}.collapsible-header{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:10px;transition:background .15s;padding:4px 6px;margin:-4px -6px}.collapsible-header:hover{background:#f8fafc}.section-header h2{font-size:1rem;color:#1e293b;font-weight:700;margin:0 0 5px;display:flex;align-items:center;gap:8px}.section-header h2:before{content:"";display:inline-block;width:4px;height:18px;background:#2d6a4f;border-radius:4px;flex-shrink:0}.section-header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.collapse-toggle{background:none;border:1px solid #e2e8f0;border-radius:8px;padding:5px 8px;cursor:pointer;color:#64748b;display:flex;align-items:center;transition:all .15s}.collapse-toggle:hover{background:#f1f5f9;color:#1e293b}.icon-green{color:#16a34a}.provider-badge,.row-count-badge{font-size:.72rem;font-weight:600;padding:2px 9px;border-radius:20px;border:1px solid #bbf7d0;background:#f0fdf4;color:#16a34a}.row-count-badge{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}.alert-banner{display:flex;align-items:flex-start;gap:10px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:12px 16px;color:#92400e;font-size:.875rem;margin-bottom:18px}.alert-banner svg{flex-shrink:0;margin-top:2px;color:#f59e0b}.cedula-search-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.cedula-input{flex:1;min-width:220px;padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:.95rem;color:#1e293b;background:#fff;outline:none;transition:border-color .15s}.cedula-input:focus{border-color:#2d6a4f;box-shadow:0 0 0 3px #2d6a4f1f}.btn-buscar{display:flex;align-items:center;gap:7px;background:#2d6a4f;color:#fff;border:none;padding:10px 22px;border-radius:10px;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .15s}.btn-buscar:hover:not(:disabled){background:#1e4d38}.btn-buscar:disabled{opacity:.5;cursor:not-allowed}.proveedor-card{background:#f0fdf4;border:1.5px solid #86efac;border-radius:12px;padding:16px 20px}.proveedor-card-header{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.proveedor-avatar{width:48px;height:48px;background:#dcfce7;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#16a34a;flex-shrink:0}.proveedor-card-info{flex:1;min-width:0}.proveedor-nombre{font-size:1.05rem;font-weight:700;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proveedor-apellidos{font-size:.88rem;color:#334155;margin-top:2px}.proveedor-meta{font-size:.8rem;color:#64748b;margin-top:5px;display:flex;gap:10px;flex-wrap:wrap}.btn-cambiar-proveedor{display:flex;align-items:center;gap:6px;background:#fff;border:1.5px solid #e2e8f0;color:#475569;padding:8px 16px;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer}.btn-cambiar-proveedor:hover{border-color:#ef4444;color:#ef4444;background:#fff5f5}.persona-grid,.encabezado-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;align-items:start}.option-block{display:flex;flex-direction:column;gap:8px}.option-block-label{font-size:.7rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.tc-note{font-size:.72rem;color:#64748b;margin:4px 0 0;font-style:italic}.rcb-toggle-group{display:flex;gap:6px;border:none;border-radius:0;overflow:visible;width:fit-content}.rcb-toggle-group.small .rcb-toggle-btn{font-size:.78rem;padding:7px 16px}.rcb-toggle-btn{background-color:#e6e6e6!important;border:1.5px solid #cbd5e1;padding:11px 18px;min-width:80px;min-height:30px;font-weight:700;font-size:.86rem;cursor:pointer;color:#334155;border-radius:10px;transition:all .15s ease;white-space:normal;line-height:1.15}.rcb-toggle-btn:hover:not(.rcb-active-colones):not(.rcb-active-dolares):not(.rcb-active-egreso):not(.rcb-active-ingreso){background-color:#e2e8f0!important;border-color:#94a3b8}.rcb-active-colones{background:linear-gradient(135deg,#16a34a,#22c55e)!important;color:#fff!important;border-color:#15803d!important;box-shadow:0 8px 16px #16a34a38}.rcb-active-dolares{background:linear-gradient(135deg,#2563eb,#3b82f6)!important;color:#fff!important;border-color:#1d4ed8!important;box-shadow:0 8px 16px #2563eb38}.rcb-active-egreso{background:linear-gradient(135deg,#dc2626,#ef4444)!important;color:#fff!important;border-color:#b91c1c!important;box-shadow:0 8px 16px #dc262638}.rcb-active-ingreso{background:linear-gradient(135deg,#16a34a,#22c55e)!important;color:#fff!important;border-color:#15803d!important;box-shadow:0 8px 16px #16a34a38}.rcb-toggle-group.rcb-expand-buttons{display:flex;width:100%;gap:8px}.rcb-toggle-group.rcb-expand-buttons .rcb-toggle-btn{flex:1;min-width:0;white-space:normal;padding:12px 10px;display:flex;justify-content:center;align-items:center;text-align:center;min-height:56px}.input-block{display:flex;flex-direction:column;gap:6px}.input-block-wide{grid-column:1 / -1;max-width:400px}.input-block label{font-size:.7rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.input-block input{padding:9px 13px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.9rem;color:#1e293b;background:#fff;outline:none;transition:border-color .15s}.input-block input:focus{border-color:#2d6a4f;box-shadow:0 0 0 3px #2d6a4f1f}.numero-recibo-display{display:flex;align-items:center;gap:10px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;padding:9px 13px;font-size:.95rem;font-weight:700;color:#1e293b;font-family:Courier New,monospace}.auto-badge{font-size:.65rem;font-weight:700;background:#eff6ff;color:#2563eb;padding:2px 7px;border-radius:20px;border:1px solid #bfdbfe;font-family:Segoe UI,sans-serif;text-transform:uppercase;letter-spacing:.3px}.items-container{display:flex;flex-direction:column;gap:0}.items-header-row{display:grid;grid-template-columns:34px 1fr 90px 160px 160px 38px;gap:8px;padding:8px 10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px 10px 0 0;font-size:.7rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.4px}.item-row{display:grid;grid-template-columns:34px 1fr 90px 160px 160px 38px;gap:8px;padding:8px 10px;border:1px solid #e2e8f0;border-top:none;align-items:center;transition:background .1s}.item-row:last-of-type{border-radius:0 0 10px 10px}.item-row:hover{background:#fafbfc}.item-num-badge{width:26px;height:26px;background:#f1f5f9;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#64748b}.item-row input{width:100%;padding:7px 10px;border:1.5px solid #e2e8f0;border-radius:7px;font-size:.875rem;color:#1e293b;background:#fff;outline:none;transition:border-color .15s}.item-row input:focus{border-color:#2d6a4f;box-shadow:0 0 0 2px #2d6a4f1a}.currency-input{display:flex;align-items:center;border:1.5px solid #e2e8f0;border-radius:7px;overflow:hidden;background:#fff;transition:border-color .15s}.currency-input:focus-within{border-color:#2d6a4f;box-shadow:0 0 0 2px #2d6a4f1a}.currency-symbol{padding:0 8px;font-size:.85rem;font-weight:700;color:#64748b;background:#f8fafc;border-right:1px solid #e2e8f0;height:100%;display:flex;align-items:center;min-width:30px;justify-content:center}.currency-input input{border:none!important;box-shadow:none!important;border-radius:0!important;flex:1;min-width:0}.total-display{display:flex;align-items:center;gap:5px;font-weight:700;color:#1e293b;font-size:.9rem;padding:7px 4px}.total-display span:first-child{color:#64748b;font-weight:400}.btn-del{background:none;border:1px solid #f1f5f9;color:#94a3b8;border-radius:6px;padding:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.btn-del:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5;color:#ef4444}.btn-del:disabled{opacity:.3;cursor:not-allowed}.btn-add{display:flex;align-items:center;gap:6px;background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d;padding:7px 14px;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer}.btn-add:hover:not(:disabled){background:#dcfce7}.btn-add:disabled{opacity:.4;cursor:not-allowed}.btn-add-inline{align-self:flex-start;display:flex;align-items:center;gap:6px;background:transparent;border:1.5px dashed #cbd5e1;color:#64748b;padding:8px 18px;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer;margin-top:8px}.btn-add-inline:hover{border-color:#2d6a4f;color:#2d6a4f;background:#f0fdf4}.totales-layout{display:grid;grid-template-columns:1fr auto;gap:28px;align-items:start}.tax-config-panel{background:#fffbeb;border:1px solid #fde68a;border-radius:12px;padding:18px 20px;display:flex;flex-direction:column;gap:16px}.tax-config-title{display:flex;align-items:center;gap:7px;font-size:.8rem;font-weight:700;color:#92400e;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}.tax-mode-group{display:flex;flex-direction:column;gap:8px}.tax-mode-label{font-size:.7rem;font-weight:700;color:#64748b;text-transform:uppercase}.tax-mode-hint{font-size:.75rem;color:#92400e;margin:0;font-style:italic}.tax-pct-row{display:flex;flex-direction:column;gap:6px}.tax-pct-row label{font-size:.7rem;font-weight:700;color:#64748b;text-transform:uppercase}.tax-pct-input{display:flex;align-items:center;gap:8px}.tax-pct-input input{width:70px;padding:7px 10px;border:1.5px solid #e2e8f0;border-radius:7px;font-size:.95rem;font-weight:600;text-align:center;outline:none;transition:border-color .15s}.tax-pct-input input.locked{background:#f8fafc;color:#64748b}.tax-pct-input input.unlocked{background:#fff;border-color:#f59e0b;color:#1e293b}.tax-pct-input input.unlocked:focus{box-shadow:0 0 0 3px #f59e0b26}.pct-symbol{font-size:1rem;color:#64748b;font-weight:600}.btn-lock{display:flex;align-items:center;gap:5px;background:#f1f5f9;border:1px solid #e2e8f0;color:#64748b;padding:6px 10px;border-radius:7px;cursor:pointer;font-size:.82rem;font-weight:600}.btn-lock.active{background:#fef3c7;border-color:#fcd34d;color:#d97706}.btn-lock:hover{background:#e2e8f0}.unlocked-warning{font-size:.75rem;color:#b45309;margin:0;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:6px 10px}.totales-table{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:20px 24px;min-width:280px;display:flex;flex-direction:column;gap:0}.total-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0}.total-label{font-size:.9rem;color:#475569;font-weight:500}.total-value{font-size:.95rem;color:#1e293b;font-weight:600}.total-divider{border:none;border-top:2px solid #e2e8f0;margin:8px 0}.grand-total .total-label{font-size:1rem;font-weight:700;color:#0f172a}.grand-total .total-value.grand{font-size:1.2rem;font-weight:800;color:#2d6a4f}.items-summary{margin:10px 0 0;font-size:.75rem;color:#94a3b8;text-align:center}.firmas-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.final-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:8px;flex-wrap:wrap}@media (max-width: 768px){.sticky-header{flex-direction:column;align-items:flex-start}.action-area{width:100%}.persona-grid,.encabezado-grid{grid-template-columns:1fr}.input-block-wide{max-width:100%}.items-header-row,.item-row{grid-template-columns:28px 1fr 70px 130px 120px 34px}.totales-layout{grid-template-columns:1fr}.final-actions{justify-content:stretch}.final-actions .btn-export{flex:1;justify-content:center}}@media (max-width: 580px){.items-header-row{display:none}.item-row{grid-template-columns:1fr;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:8px;padding:12px;gap:10px}.item-col-num{display:none}}:root{--accent:#1167b1;--muted:#f4f6f8;--card:#ffffff}*{box-sizing:border-box;font-family:Inter,Arial,Helvetica,sans-serif}body{margin:0;background:linear-gradient(180deg,#f6fbff,#eef6ff);min-height:100vh;color:#1f2937}.container{max-width:1100px;margin:36px auto;padding:18px}.card{background:var(--card);border-radius:12px;box-shadow:0 6px 18px #091e4214;padding:18px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.brand{display:flex;align-items:center;gap:12px}.logo{width:48px;height:48px;border-radius:8px;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.h1{font-size:20px;font-weight:700}.login-box{width:420px;margin:80px auto;padding:28px}.input{width:100%;padding:10px 12px;margin:8px 0;border-radius:8px;border:1px solid #e6eef8}.button{background:var(--accent);color:#fff;padding:10px 14px;border-radius:10px;border:0;cursor:pointer}.nav{display:flex;gap:12px;flex-direction:column;width:220px}.nav a{padding:10px;border-radius:8px;text-decoration:none;color:#123;color:font-weight:600}.main{display:flex;gap:24px}.content{flex:1}.table{width:100%;border-collapse:collapse;margin-top:12px}.table th,.table td{padding:8px;border-bottom:1px solid #eee;text-align:left}.event-form{display:grid;grid-template-columns:1fr 1fr;gap:8px}.rubro-row{display:flex;gap:8px;align-items:center}.total-bar{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding:12px;background:#fbfcff;border-radius:8px;border:1px solid #eef3ff}
