:root{--color-primary: #2c3e50;--color-accent: #228B22;--color-secondary: #FF6200;--color-background: #ffffff;--color-border: #ddd;--color-shadow: rgba(0,0,0,.1);--color-error: #dc3545;--color-success: #228B22;--color-warning: #ffc107;--color-text-light: #666;--color-entrada: #228B22;--color-salida: #dc3545}html,body{margin:0;padding:0;height:100%;overflow:hidden}@media (display-mode: standalone){html,body{overscroll-behavior-y:contain}}#root{height:100%;height:100dvh;overflow:hidden}.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;background:var(--color-background);padding:0;margin:0;position:relative}.auth-header{text-align:center;margin-top:10px;margin-bottom:30px}.auth-logo{max-width:300px;height:auto;margin-bottom:20px}.auth-title{color:var(--color-primary);font-size:24px;font-weight:700;margin:0}.trademark{font-size:14px}.auth-content{width:100%;max-width:500px;background:#fff;padding:30px;border-radius:12px;box-shadow:0 4px 12px var(--color-shadow)}.input-group{margin-bottom:20px}.input-group label{display:block;color:var(--color-primary);font-size:14px;font-weight:500;margin-bottom:6px}.input-group input,.input-group textarea{width:100%;padding:12px;border:2px solid var(--color-border);border-radius:6px;font-size:14px;transition:border-color .2s;font-family:inherit}.input-group input:focus,.input-group textarea:focus{outline:none;border-color:var(--color-accent)}.input-group input::placeholder,.input-group textarea::placeholder{color:#aaa}.password-container{display:flex;flex-direction:row;align-items:center;width:100%;gap:10px}.password-input{flex:1;padding:12px;border:2px solid var(--color-border);border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box;min-width:0;font-family:inherit}.password-input:focus{outline:none;border-color:var(--color-accent)}.password-input:disabled{background-color:#f0f0f0;cursor:not-allowed}.password-input::-ms-reveal,.password-input::-ms-clear{display:none}.password-show-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;width:40px;height:40px;border-radius:5px;transition:background-color .2s}.password-show-button:hover{background-color:#f0f0f0}.password-show-button:disabled{cursor:not-allowed;opacity:.5}.password-icon{width:20px;height:20px;fill:var(--color-accent)}.checkbox-group{display:flex;align-items:center;gap:8px;margin-bottom:20px}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-accent)}.checkbox-group label{color:var(--color-accent);font-size:14px;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none}.btn{padding:12px 30px;border:none;border-radius:6px;font-size:16px;font-weight:700;cursor:pointer;transition:background-color .2s,transform .1s;font-family:inherit}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-accept{background-color:var(--color-accent);color:#fff}.btn-accept:hover:not(:disabled){background-color:#1e7b1e}.btn-secondary{background-color:var(--color-secondary);color:#fff}.btn-secondary:hover:not(:disabled){background-color:#e55a00}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333}.btn-limpiar{background-color:#999;color:#fff;padding:8px 20px;margin-top:10px}.btn-limpiar:hover:not(:disabled){background-color:#777}.auth-buttons{display:flex;gap:10px;margin-top:20px;justify-content:center}.btn-config{position:fixed;bottom:30px;right:30px;width:50px;height:50px;background-color:#ff8c00;color:#fff;border:none;border-radius:50%;font-size:24px;cursor:pointer;box-shadow:0 2px 8px #0003;transition:background-color .2s,transform .2s;display:flex;align-items:center;justify-content:center;z-index:1000}.btn-config:hover{background-color:#e57c00;transform:scale(1.05)}.auth-footer{text-align:center;margin-top:20px}.version-info{color:var(--color-primary);font-size:11px;margin-bottom:5px;opacity:.6}.auth-footer a{color:var(--color-primary);text-decoration:none;font-size:12px;opacity:.7}.auth-footer a:hover{opacity:1}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}.loading-spinner-large{display:inline-block;width:40px;height:40px;border:4px solid rgba(34,139,34,.3);border-radius:50%;border-top-color:var(--color-accent);animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;justify-content:center;align-items:center;z-index:9999;pointer-events:none}.loading-overlay-spinner{width:50px;height:50px;border:6px solid rgba(34,139,34,.2);border-radius:50%;border-top-color:var(--color-accent);animation:spin .8s ease-in-out infinite}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:450px;box-shadow:0 4px 20px #0000004d;overflow:hidden}.modal-header-verde{background:var(--color-accent);color:#fff;padding:15px 20px;text-align:center}.modal-header-verde h3{margin:0;font-size:18px;font-weight:600}.modal-body{padding:20px}.modal-footer{display:flex;gap:10px;padding:15px 20px;background:#f9f9f9;border-top:1px solid #eee}.btn-guardar{flex:1;padding:12px;border:none;border-radius:6px;background:var(--color-accent);color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}.btn-guardar:hover:not(:disabled){background:#1e7b1e}.btn-guardar:disabled{background:#ccc;cursor:not-allowed}.modal-app{background:#fff;border-radius:12px;width:90%;max-width:400px;box-shadow:0 4px 20px #0000004d;overflow:hidden}.modal-header-app{background:var(--color-accent);color:#fff;padding:16px 20px;text-align:center}.modal-header-app h3{margin:0;font-size:18px;font-weight:600}.modal-header-app.modal-header-error{background:var(--color-error)}.modal-body-app{padding:25px 20px;text-align:center}.modal-body-app p{margin:0;font-size:16px;color:var(--color-text);line-height:1.5}.modal-footer-app{display:flex;gap:12px;padding:15px 20px;background:#f8f9fa;border-top:1px solid #e9ecef}.modal-btn{flex:1;padding:14px 16px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.modal-btn:active{transform:scale(.98)}.modal-btn-confirmar{background:var(--color-accent);color:#fff}.modal-btn-confirmar:hover{background:#1b7a1b}.modal-btn-cancelar{background:var(--color-secondary);color:#fff}.modal-btn-cancelar:hover{background:#e55a00}.btn-cancelar{flex:1;padding:12px;border:none;border-radius:6px;background:var(--color-secondary);color:#fff;font-size:14px;cursor:pointer;transition:all .2s}.btn-cancelar:hover{background:#e55800}.modal-config{max-width:350px}.modal-config-body{text-align:center;padding:30px 20px}.modal-config-body p{margin:0;font-size:16px;color:#333}.modal-config .modal-footer{justify-content:center}.main-container{height:100vh;height:100dvh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);display:flex;flex-direction:column;overflow:hidden}.main-content{max-width:800px;margin:0 auto;padding:15px 20px 20px;flex:1;overflow-y:auto;width:100%;box-sizing:border-box}.header-empresa{background:var(--color-accent);color:#fff;padding:12px 20px;display:flex;justify-content:center;align-items:center;flex-shrink:0;z-index:100;position:relative}.header-empresa-mobile{display:block;text-align:center}.header-empresa-desktop{display:none;width:100%;max-width:1200px;justify-content:space-between;align-items:center}.header-empresa-left{display:flex;align-items:center}.header-empresa-right-desktop{display:flex;align-items:center;gap:15px}.header-usuario-text{font-size:14px;color:#ffffffe6;font-weight:400}.header-empresa-logout-mobile{position:absolute;right:0;top:50%;transform:translateY(-50%)}.header-empresa-text{font-size:16px;font-weight:700;color:#fff}.btn-logout{background:transparent;border:none;color:#fff;padding:6px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-logout:hover{background:#ffffff26}.btn-logout svg{width:26px;height:26px}.header-titulo-pantalla{background:#e8f5e9;padding:14px 20px;flex-shrink:0;z-index:99}.header-titulo-pantalla-inner{display:flex;align-items:center;gap:12px}.btn-back{background:transparent;border:none;color:var(--color-accent);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.btn-back:hover{background:#228b221a}.btn-back svg{width:22px;height:22px}.titulo-pantalla-text{font-size:18px;font-weight:700;color:var(--color-accent);margin:0}.tabs-container-fixed{background:linear-gradient(135deg,#f5f7fa,#e4e8ec);padding:15px 20px 0;flex-shrink:0;z-index:98}.tabs-container{display:flex;gap:10px;background:#fff;padding:10px;border-radius:12px;box-shadow:0 2px 8px var(--color-shadow);width:100%;max-width:800px;margin:0 auto;box-sizing:border-box}.tab-button{flex:1;padding:12px 20px;border:none;border-radius:8px;background:#f0f0f0;color:var(--color-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.tab-button.tab-pendientes.active{background:var(--color-secondary);color:#fff}.tab-button.tab-firmados.active{background:var(--color-accent);color:#fff}.tab-button:hover:not(.active){background:#e0e0e0}.tab-button.refresh-btn{flex:0;padding:12px 16px;font-size:18px}.albaranes-list{display:flex;flex-direction:column;gap:15px;width:100%}.loading-container,.empty-container{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 40px;background:#fff;border-radius:12px;box-shadow:0 2px 8px var(--color-shadow);width:100%;box-sizing:border-box}.loading-container p,.empty-container p{color:var(--color-text-light);margin-top:15px}.albaran-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px var(--color-shadow);cursor:pointer;transition:transform .2s,box-shadow .2s;border-left:5px solid var(--color-secondary);display:flex;flex-direction:column;position:relative}.albaran-card.firmado{border-left-color:var(--color-accent)}.albaran-card.pendiente{border-left-color:var(--color-secondary)}.albaran-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--color-shadow)}.albaran-card:active{transform:scale(.99)}.albaran-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.albaran-info{display:flex;flex-direction:column;gap:4px}.albaran-numero{font-size:18px;font-weight:700;color:var(--color-primary)}.albaran-fecha{font-size:13px;color:var(--color-text-light)}.albaran-badge{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.albaran-badge.pendiente{background-color:#fff3e0;color:var(--color-secondary)}.albaran-badge.firmado{background-color:#e8f5e9;color:var(--color-accent)}.albaran-body{display:flex;flex-direction:column;gap:10px;flex:1}.albaran-row{display:flex;align-items:flex-start;gap:10px}.albaran-icon{width:16px;height:16px;color:var(--color-text-light);fill:var(--color-text-light);flex-shrink:0;margin-top:2px}.albaran-icon.location{fill:var(--color-accent);color:var(--color-accent)}.albaran-icon.location.clickable{cursor:pointer;transition:transform .2s,fill .2s,color .2s}.albaran-icon.location.clickable:hover{fill:#1e7b1e;color:#1e7b1e;transform:scale(1.15)}.albaran-cliente{font-size:15px;font-weight:600;color:var(--color-primary);line-height:1.3}.albaran-obra{font-size:14px;color:var(--color-primary);line-height:1.3}.albaran-direccion{font-size:13px;color:var(--color-text-light);line-height:1.3}.albaran-footer{display:flex;justify-content:flex-end;align-items:center;margin-top:16px}.albaran-chevron{width:20px;height:20px;color:#bbb;transition:transform .2s,color .2s}.albaran-card:hover .albaran-chevron{color:var(--color-accent);transform:translate(3px)}.detalle-container{height:100vh;height:100dvh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);display:flex;flex-direction:column;overflow:hidden}.detalle-content{max-width:600px;margin:0 auto;padding:20px;flex:1;width:100%;box-sizing:border-box;overflow-y:auto}.info-row-card{background:#fff;border-radius:8px;padding:16px;margin-bottom:12px;box-shadow:0 1px 3px var(--color-shadow)}.info-row-label{display:block;font-size:12px;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.info-row-content{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.info-row-value{flex:1;font-size:15px;color:var(--color-primary);font-weight:500;word-break:break-word}.info-row-value.empty{color:#999;font-style:italic}.info-row-actions{display:flex;gap:8px;flex-shrink:0}.action-btn{background:transparent;border:none;padding:6px;cursor:pointer;border-radius:6px;transition:background .2s,transform .2s;display:flex;align-items:center;justify-content:center}.action-btn:hover{background:#0000000d;transform:scale(1.1)}.action-btn svg{width:24px;height:24px}.action-btn.location svg{fill:var(--color-accent)}.action-btn.phone svg{fill:var(--color-accent)}.action-btn.whatsapp svg{fill:#25d366}.info-card-extra .info-extra-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.info-extra-item{display:flex;flex-direction:column;gap:4px}.info-extra-label{font-size:12px;color:var(--color-text-light)}.info-extra-value{font-size:16px;font-weight:600;color:var(--color-primary)}.info-extra-value.estado-firmado{color:var(--color-accent)}.info-extra-value.estado-pendiente{color:var(--color-secondary)}.detalle-footer{background:#fff;padding:16px 20px;border-top:1px solid #eee;flex-shrink:0}.btn-detalle{width:100%;max-width:600px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:10px;background:var(--color-accent);color:#fff;border:none;padding:16px 24px;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s}.btn-detalle:hover{background:#1e7b1e}.btn-detalle svg{fill:#fff}.lineas-card,.datos-firma-card,.firma-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px var(--color-shadow);margin-bottom:20px}.datos-firma-content{flex:1;display:flex;flex-direction:column;padding:20px;gap:15px;overflow:hidden}.datos-firma-content .input-group{margin-bottom:0}.datos-firma-content .input-group-flex{flex:1;display:flex;flex-direction:column;min-height:0}.datos-firma-content .textarea-flex{flex:1;min-height:100px;resize:none}.btn-whatsapp{background-color:#25d366;color:#fff;border:none;padding:4px 12px;border-radius:4px;font-size:12px;cursor:pointer}.btn-whatsapp:hover{background-color:#1da851}.btn-whatsapp-icon{background:transparent;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:transform .2s}.btn-whatsapp-icon svg{width:22px;height:22px;fill:#25d366}.btn-whatsapp-icon:hover{transform:scale(1.1)}.btn-whatsapp-icon:hover svg{fill:#1da851}.detalle-icon{width:16px;height:16px;fill:var(--color-accent);flex-shrink:0;margin-right:8px;vertical-align:middle}.detalle-observaciones{font-size:14px;color:var(--color-primary);font-style:italic}.detalle-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.info-item{display:flex;flex-direction:column}.info-label{font-size:12px;color:var(--color-text-light)}.info-value{font-size:16px;font-weight:500;color:var(--color-primary)}.info-value.estado-firmado{color:var(--color-accent)}.info-value.estado-pendiente{color:var(--color-secondary)}.detalle-buttons{display:flex;gap:15px}.detalle-buttons .btn{flex:1}.lineas-list{display:flex;flex-direction:column;gap:10px}.linea-card{background:#fff;border-radius:8px;padding:14px 16px;box-shadow:0 1px 3px var(--color-shadow);display:flex;justify-content:space-between;align-items:center;gap:12px}.linea-descripcion{flex:1;font-size:14px;color:var(--color-primary);line-height:1.4}.linea-cantidad{font-size:16px;font-weight:700;color:var(--color-secondary);flex-shrink:0;min-width:60px;text-align:right}.lineas-footer-container{background:#fff;border-top:1px solid #ccc;flex-shrink:0}.firma-section-fixed{padding:12px 20px;border-bottom:1px solid #eee;background:#fafafa}.firma-section-label{display:block;font-size:11px;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;text-align:center}.firma-image-container{min-height:80px;max-height:120px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:6px;padding:8px;border:1px solid #ccc}.firma-image{max-width:100%;max-height:100px;object-fit:contain}.firma-loading{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--color-text-light);font-size:12px}.firma-loading .loading-spinner-large{width:24px;height:24px;border-width:3px}.firma-nombre{display:block;margin-top:6px;font-size:13px;font-weight:500;color:var(--color-primary);text-align:center}.lineas-footer{padding:12px 20px;display:flex;gap:12px;justify-content:center}.lineas-footer button{flex:1;max-width:250px;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:background .2s,transform .1s}.lineas-footer button:active{transform:scale(.98)}.lineas-footer button svg{fill:#fff}.btn-fotos{background:var(--color-secondary);color:#fff}.btn-fotos:hover{background:#e55a00}.btn-firmar{background:var(--color-accent);color:#fff}.btn-firmar:hover{background:#1e7b1e}.fotos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.foto-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px var(--color-shadow);position:relative}.foto-image{width:100%;aspect-ratio:1;object-fit:cover;display:block}.foto-delete-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;background:var(--color-error);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s}.foto-delete-btn svg{fill:#fff}.foto-delete-btn:hover{background:#c82333;transform:scale(1.1)}.foto-nombre{display:block;padding:8px;font-size:12px;color:var(--color-text-light);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.foto-card-gallery{cursor:pointer;transition:border-color .2s,background .2s}.foto-card-gallery:hover{border-color:#28a745}.foto-card-gallery:hover .gallery-image-area{background:#f0fff4;border-color:#28a745}.gallery-image-area{width:100%;aspect-ratio:1;background:#f5f5f5;border:2px dashed #ccc;border-radius:6px 6px 0 0;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s}.gallery-add-btn{position:absolute;top:8px;right:8px;width:36px;height:36px;background:#28a745;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s;box-shadow:0 2px 6px #28a74566}.gallery-add-btn:hover{background:#218838;transform:scale(1.15)}.gallery-label{display:block;padding:8px;font-size:12px;color:#999;text-align:center}.empty-subtext{font-size:13px;color:#aaa;margin-top:8px}.fotos-footer{background:#fff;padding:12px 20px;border-top:1px solid #ccc;flex-shrink:0}.fotos-footer-inner{display:flex;gap:12px;justify-content:center}.fotos-footer button{flex:1;max-width:250px;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:background .2s,transform .1s}.fotos-footer button:active{transform:scale(.98)}.fotos-footer button svg{fill:#fff}.btn-hacer-foto{background:var(--color-secondary);color:#fff}.btn-hacer-foto:hover{background:#e55a00}.saving-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:1000;color:#fff;font-size:18px;font-weight:700}.lineas-table{width:100%}.lineas-header{display:flex;padding:10px 0;border-bottom:2px solid var(--color-accent);font-weight:700;color:var(--color-primary)}.linea-row{display:flex;padding:12px 0;border-bottom:1px solid #f0f0f0}.linea-row:last-child{border-bottom:none}.col-descripcion{flex:3;font-size:14px}.col-cantidad{flex:1;text-align:right;font-size:14px}.firma-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.firma-instrucciones{text-align:center;color:var(--color-text-light);font-size:18px;margin-bottom:25px}.canvas-container{width:100%;max-width:400px;border:2px solid var(--color-border);border-radius:10px;overflow:hidden;background:#fff;box-shadow:0 2px 8px var(--color-shadow)}.firma-canvas{width:100%;height:auto;display:block;touch-action:none;cursor:crosshair;background:#fff}.firma-datos-resumen{margin-top:20px;padding:15px;background:#fff;border-radius:8px;box-shadow:0 2px 8px var(--color-shadow);width:100%;max-width:400px}.firma-datos-resumen p{font-size:14px;color:var(--color-primary);margin-bottom:5px}.firma-datos-resumen p:last-child{margin-bottom:0}.firma-footer{padding:15px 20px;background:#fff;border-top:1px solid var(--color-border);flex-shrink:0}.firma-footer-inner{display:flex;gap:12px}.firma-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 12px;border:none;border-radius:8px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:opacity .2s,transform .1s}.firma-btn:active{transform:scale(.98)}.firma-btn:disabled{opacity:.6;cursor:not-allowed}.firma-btn-limpiar{background:var(--color-error)}.firma-btn-limpiar:hover:not(:disabled){background:#c82333}.firma-btn-datos{background:var(--color-secondary)}.firma-btn-datos:hover:not(:disabled){background:#e55a00}.firma-btn-confirmar{background:var(--color-accent)}.firma-btn-confirmar:hover:not(:disabled){background:#1e7a1e}.firma-btn-confirmar.disabled{background:#9ca3af}.saving-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000}.saving-overlay p{margin-top:15px;font-size:18px;color:#fff;font-weight:600}.upload-progress-container{display:flex;flex-direction:column;align-items:center;gap:16px}.upload-phase-text{color:#fff;font-size:16px;font-weight:500}.upload-progress-circle{position:relative;width:100px;height:100px}.upload-progress-circle svg{transform:rotate(-90deg);width:100%;height:100%}.upload-progress-bg{fill:none;stroke:#fff3;stroke-width:8}.upload-progress-fill{fill:none;stroke:#25d366;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .2s ease}.upload-progress-percent{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:22px;font-weight:700}@media (max-width: 768px){.desktop-only{display:none!important}.header-empresa-mobile{display:block}.header-empresa-desktop{display:none!important}.header-empresa-logout-mobile{display:block}.auth-content{padding:20px;margin:10px}.btn-config{bottom:20px;right:20px;width:45px;height:45px;font-size:20px}.header{padding:12px 15px}.header-titulo{font-size:16px}.header-usuario{display:none}.tabs-container-fixed{padding:12px 10px 0}.main-content{padding:10px 10px 15px}.albaran-card{padding:12px}.albaran-header{margin-bottom:10px}.albaran-body{gap:6px}.albaran-footer{margin-top:10px}.tabs-container{padding:6px;gap:0}.tab-button{padding:10px 15px;font-size:14px;font-weight:600;border-radius:6px}.tab-button.refresh-btn{display:none}.main-content{display:flex;flex-direction:column}.albaranes-list.albaranes-list-empty{flex:1;display:flex;min-height:0}.empty-container,.loading-container{background:transparent;box-shadow:none;border-radius:0;flex:1;justify-content:center;padding:0;min-height:0}.detalle-buttons{flex-direction:column}}@media (min-width: 769px){.header-empresa-mobile{display:none!important}.header-empresa-desktop{display:flex!important;max-width:1200px;margin:0 auto;width:100%}.header-empresa-logout-mobile{display:none!important}.header-empresa{padding:14px 40px}.header-empresa-text{font-size:18px}.header-usuario-text{font-size:15px}.header-titulo-pantalla{padding:14px 40px}.header-titulo-pantalla-inner{max-width:1200px;margin:0 auto;width:100%;display:flex;align-items:center;gap:12px}.titulo-pantalla-text{font-size:20px}.main-content{max-width:1200px;width:100%;padding:30px 40px;display:flex;flex-direction:column}.detalle-content{max-width:900px;padding:30px 40px}.datos-firma-content{max-width:600px;margin:0 auto;padding:30px 40px;width:100%;box-sizing:border-box}.tabs-container-fixed{padding:20px 40px 0}.tabs-container{padding:12px 15px;gap:12px;max-width:1200px;width:100%;box-sizing:border-box}.tab-button{padding:14px 30px;font-size:15px}.albaranes-list{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;width:100%;min-width:100%}.albaran-card{padding:20px}.albaran-numero{font-size:20px}.info-row-card{padding:20px;margin-bottom:16px}.info-row-label{font-size:13px;margin-bottom:10px}.info-row-value{font-size:16px}.linea-card{padding:18px 20px}.linea-descripcion{font-size:15px}.linea-cantidad{font-size:18px}.detalle-footer,.lineas-footer-container,.fotos-footer,.firma-footer{padding:16px 40px}.detalle-footer-inner,.lineas-footer-inner,.fotos-footer-inner{max-width:900px;margin:0 auto}.firma-footer-inner{max-width:600px;margin:0 auto}.lineas-footer button,.fotos-footer button{max-width:300px;padding:16px 24px;font-size:16px}.fotos-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.canvas-container{max-width:500px}.firma-instrucciones{font-size:20px}.albaranes-list-empty{display:flex!important;flex-direction:column;flex:1}.albaranes-list-empty .loading-container,.albaranes-list-empty .empty-container{padding:80px 60px;flex:1}.loading-container svg,.empty-container svg{width:80px;height:80px}}@media (min-width: 1400px){.main-content{max-width:1400px}.detalle-content{max-width:1000px}.fotos-grid{grid-template-columns:repeat(4,1fr)}}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;font-family:Segoe UI,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}
