.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}:root{--navy: #1F4E79;--blue: #2E75B6;--light: #BDD7EE;--yellow: #FFC000;--green: #375623;--red: #C00000;--gray: #F5F5F5;--border: #D0D7DE;--text: #1A1A2E;--muted: #6B7280;--text-muted: #6B7280;--bg-page: #EEF2F7;--bg-header: #E8ECF1;--bg-card: #FFFFFF;--primary: #1F4E79;--surface: #FFFFFF;--surface-alt: #F8F9FA;--sidebar-width: 240px;--header-height: 56px;--radius: 10px;--radius-sm: 7px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,Arial,sans-serif;background:var(--bg-page);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.font-mono{font-family:Cascadia Code,Consolas,monospace;font-size:13px}.font-bold{font-weight:600}.text-muted{color:var(--muted);font-size:13px}.text-nowrap{white-space:nowrap}.permisos-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy) 0%,#2E75B6 100%);padding:20px}.login-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:0 8px 32px #0003;padding:48px 40px;text-align:center;max-width:420px;width:100%}.login-logo{margin-bottom:32px}.login-logo-img{max-width:200px;height:auto;margin-bottom:12px}.login-subtitle{font-size:15px;color:var(--muted)}.login-button{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:14px 24px;background:var(--navy);color:#fff;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}.login-button:hover{background:#163a5c}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-hint{margin-top:12px;font-size:13px;color:var(--muted)}.login-error{margin:12px 0;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:13px;text-align:left}.login-footer{margin-top:32px;padding-top:16px;border-top:1px solid var(--border);font-size:12px;color:var(--muted)}.login-footer-nit{font-size:10px;opacity:.7;margin-top:2px}.app-layout{height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-body{display:flex;flex:1;padding-top:var(--header-height);min-height:0}.app-main{flex:1;margin-left:var(--sidebar-width);padding:24px;overflow-y:auto;transition:margin-left .3s}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--bg-header);border-bottom:1px solid #CDD5E0;display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:1100}.header-left{display:flex;align-items:center;gap:12px}.header-menu-btn{display:none;background:none;border:none;color:var(--navy);cursor:pointer;padding:6px;border-radius:6px}.header-menu-btn:hover{background:#1f4e791a}.header-brand{display:flex;align-items:center;gap:8px}.header-logo-img{height:32px;width:auto;object-fit:contain}.header-divider{color:var(--border);font-weight:300}.header-section{font-size:14px;color:var(--muted)}.header-right{display:flex;align-items:center;gap:8px}.header-icon-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:8px;border-radius:6px;transition:all .2s}.header-icon-btn:hover{background:#1f4e791a;color:var(--navy)}.header-user-container{position:relative}.header-user-btn{display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:background .2s}.header-user-btn:hover{background:#1f4e7914}.header-avatar{width:36px;height:36px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.header-user-info{text-align:left}.header-user-name{display:block;font-size:13px;font-weight:600;color:var(--text)}.header-user-role{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.header-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border-radius:var(--radius-sm);box-shadow:0 4px 16px #00000026;min-width:220px;padding:8px;z-index:200}.header-dropdown-info{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;color:var(--muted)}.header-dropdown hr{border:none;border-top:1px solid var(--border);margin:4px 0}.header-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;border-radius:6px;font-size:13px;color:var(--text);cursor:pointer;font-family:inherit;transition:background .15s}.header-dropdown-item:hover{background:var(--gray)}.sidebar{position:fixed;top:var(--header-height);left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;justify-content:space-between;z-index:90;transition:transform .3s}.sidebar-content{padding:12px 8px;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:var(--radius-sm);color:var(--muted);text-decoration:none;font-size:14px;font-weight:500;transition:all .15s}.sidebar-link:hover{background:var(--bg-page);color:var(--navy)}.sidebar-link--active{background:#1f4e791a;color:var(--navy);font-weight:600}.sidebar-footer{padding:16px;text-align:center;font-size:11px;color:var(--muted)}.sidebar-footer-nit{font-size:9px;opacity:.6;margin-top:2px;border-top:1px solid var(--border)}.sidebar-overlay{display:none}.page{max-width:1440px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header-left{display:flex;align-items:center;gap:12px;color:var(--navy)}.page-header-left h1{font-size:22px;font-weight:700;color:var(--navy)}.page-header-right{display:flex;align-items:center;gap:8px}.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--navy);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#163a5c}.btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--gray)}.filters-bar{display:flex;gap:12px;margin-bottom:16px}.search-input-wrapper{flex:1;display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:0 12px;color:var(--muted)}.search-input{flex:1;border:none;outline:none;padding:10px 0;font-size:14px;font-family:inherit;color:var(--text);background:transparent}.search-input::placeholder{color:var(--muted)}.search-clear{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;display:flex;align-items:center;border-radius:50%}.search-clear:hover{background:var(--gray);color:var(--text)}.btn-secondary.active{background:var(--light);border-color:var(--navy);color:var(--navy)}.filter-badge{width:8px;height:8px;border-radius:50%;background:var(--red);display:inline-block;margin-left:4px}.filters-panel{background:var(--bg-card);border-radius:var(--radius);padding:16px 20px;box-shadow:0 1px 4px #0000000f;margin-bottom:16px}.filters-row{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:4px;min-width:180px}.filter-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.filter-select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:#fff;color:var(--text);cursor:pointer}.filter-select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 2px #1f4e7926}.btn-text{background:none;border:none;color:var(--muted);font-size:13px;font-family:inherit;cursor:pointer;display:flex;align-items:center;gap:4px;padding:8px 4px}.btn-text:hover{color:var(--red)}.btn-icon{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;padding:8px;display:flex;align-items:center;transition:all .15s}.btn-icon:hover{background:var(--gray);color:var(--text)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.page-count{font-size:13px;color:var(--muted);background:var(--gray);padding:2px 10px;border-radius:12px;margin-left:8px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--muted)}.empty-state svg{margin-bottom:16px;opacity:.3}.empty-state h3{font-size:18px;font-weight:600;color:var(--text);margin-bottom:8px}.empty-state p{font-size:14px;margin-bottom:16px;max-width:360px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center;gap:16px}.loading-container p{color:var(--muted);font-size:15px}.error-message{color:var(--red);font-size:15px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:spin 1s linear infinite}.th-center,.td-center{text-align:center}.card-header-right{display:flex;align-items:center;gap:8px}.table-container{background:var(--bg-card);border-radius:var(--radius);box-shadow:0 1px 4px #0000001a;overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{background:var(--navy);color:#fff;padding:12px 16px;text-align:left;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.data-table th:first-child{border-radius:var(--radius) 0 0 0}.data-table th:last-child{border-radius:0 var(--radius) 0 0}.data-table td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:14px}.table-row-clickable{cursor:pointer;transition:background .15s}.table-row-clickable:hover{background:var(--gray)}.cards-container{display:none;flex-direction:column;gap:12px}.operation-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:0 1px 4px #0000001a;padding:16px;border-left:4px solid var(--navy);cursor:pointer;transition:box-shadow .2s}.operation-card:hover{box-shadow:0 4px 12px #00000026}.card-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.card-date{font-size:13px;color:var(--muted)}.card-vessel{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:2px}.card-cc{font-family:Cascadia Code,Consolas,monospace;font-size:13px;color:var(--muted);margin-bottom:8px}.card-detail{font-size:13px;color:var(--text);margin-bottom:2px}.status-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.frescura-indicator{display:inline-flex;align-items:center;gap:4px}.frescura-dot{display:inline-block;width:10px;height:10px;border-radius:50%}.frescura-label{font-size:12px;font-weight:600;white-space:nowrap}.placeholder-content{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;color:var(--muted)}.placeholder-content h2{margin-top:16px;font-size:20px;color:var(--navy)}.placeholder-content p{margin-top:8px;max-width:400px}.loading-screen,.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:var(--navy);gap:16px}.loading-spinner{width:40px;height:40px;border:4px solid var(--light);border-top-color:var(--navy);border-radius:50%;animation:spin .8s linear infinite}.error-screen h2{color:var(--red)}.dev-login{margin-top:8px}.dev-banner{background:var(--yellow);color:var(--navy);padding:6px 16px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:1px;margin-bottom:16px}.dev-hint{font-size:14px;color:var(--muted);margin-bottom:12px}.dev-role-grid{display:flex;flex-direction:column;gap:8px}.dev-role-btn{width:100%;padding:12px 20px;background:var(--bg-page);color:var(--navy);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}.dev-role-btn:hover{background:var(--navy);color:#fff;border-color:var(--navy)}.dev-role-switcher{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--yellow);color:var(--navy);border:none;border-radius:4px;font-size:11px;font-weight:700;font-family:inherit;cursor:pointer;letter-spacing:.5px}.dev-role-switcher:hover{opacity:.85}.notif-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.header-icon-btn{position:relative;background:none;border:none;color:var(--muted);cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center}.header-icon-btn:hover{background:var(--gray);color:var(--text)}.notif-panel{position:absolute;top:44px;right:0;width:380px;max-height:480px;background:#fff;border-radius:var(--radius);box-shadow:0 8px 30px #00000026;z-index:100;display:flex;flex-direction:column;overflow:hidden}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.notif-panel-header h3{font-size:15px;font-weight:700;color:var(--navy);margin:0}.notif-clear{background:none;border:none;color:var(--muted);font-size:12px;cursor:pointer;font-family:inherit}.notif-clear:hover{color:var(--red)}.notif-panel-body{overflow-y:auto;max-height:400px}.notif-empty{text-align:center;color:var(--muted);padding:32px 16px;font-size:14px}.notif-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid #F3F4F6;cursor:pointer;transition:background .15s}.notif-item:hover{background:var(--gray)}.notif-unread{background:#f8fafc;border-left:3px solid var(--navy)}.notif-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.notif-title{font-size:13px;font-weight:600;color:var(--text)}.notif-msg{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-time{font-size:11px;color:var(--muted);opacity:.7}.notif-dismiss{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:50%;opacity:0;transition:opacity .15s;flex-shrink:0}.notif-item:hover .notif-dismiss{opacity:1}.notif-dismiss:hover{background:var(--gray);color:var(--red)}.detail-header{margin-bottom:24px}.btn-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--muted);font-size:14px;font-family:inherit;cursor:pointer;padding:4px 0;margin-bottom:12px}.btn-back:hover{color:var(--navy)}.detail-title-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.detail-title-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.detail-title{font-size:24px;font-weight:700;color:var(--navy)}.detail-cc{font-family:Cascadia Code,Consolas,monospace;font-size:14px;color:var(--muted);background:var(--gray);padding:2px 10px;border-radius:4px}.detail-actions{display:flex;gap:8px;align-items:center}.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:#fef2f2;color:var(--red);border:1px solid #FECACA;border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.btn-danger:hover{background:var(--red);color:#fff}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.detail-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:0 1px 4px #00000014;overflow:visible}.detail-card-wide{grid-column:1 / -1}.detail-card-stack{display:flex;flex-direction:column;gap:20px}.detail-card-grow{flex:1;display:flex;flex-direction:column}.detail-card-grow .detail-card-body{flex:1}.detail-card-header{display:flex;align-items:center;gap:8px;padding:14px 20px;background:var(--bg-header);border-bottom:1px solid var(--border);font-size:15px;font-weight:600;color:var(--navy)}.detail-card-header h2{font-size:15px;font-weight:600;margin:0}.detail-card-edit{margin-left:auto;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--navy);font-size:12px;font-weight:600;font-family:inherit;padding:4px 12px;cursor:pointer;transition:all .15s}.detail-card-edit:hover{background:var(--navy);color:#fff}.detail-card-badge{margin-left:auto;background:var(--navy);color:#fff;font-size:12px;font-weight:700;padding:2px 10px;border-radius:12px}.detail-card-body{padding:16px 20px}.detail-field{display:flex;justify-content:space-between;align-items:baseline;padding:8px 0;border-bottom:1px solid #F3F4F6}.detail-field:last-child{border-bottom:none}.detail-label{font-size:13px;color:var(--muted);flex-shrink:0;min-width:120px}.detail-value{font-size:14px;font-weight:500;text-align:right;display:flex;align-items:center}.detail-value-highlight{font-weight:600;color:var(--navy)}.detail-field-separator{margin-top:8px;padding-top:12px;border-top:1px solid var(--border, #e2e8f0)}.detail-field.detail-field-port{background:var(--bg-header, #E8ECF1);margin:0 -16px;padding:14px 20px;border-top:1px solid var(--border, #e2e8f0)}.detail-label-port{font-size:15px;font-weight:600;color:var(--navy, #1F4E79);display:flex;align-items:center}.detail-value-port{font-size:15px;font-weight:600;color:var(--navy, #1F4E79)}.checklist{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px}.checklist-item{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fafafa;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;font-family:inherit;font-size:14px;text-align:left;width:100%}.checklist-item:hover{background:var(--gray)}.checklist-item:disabled{cursor:default;opacity:.7}.checklist-item.checked{background:#f0fdf4;border-color:#86efac}.check-icon-done{color:#16a34a}.check-icon-pending{color:var(--border)}.checklist-label{flex:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100;padding:20px}.modal-container{background:#fff;border-radius:var(--radius);width:100%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:20px;font-weight:700;color:var(--navy);margin:0}.modal-close{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:50%}.modal-close:hover{background:var(--gray);color:var(--text)}.modal-info-bar{display:flex;align-items:center;gap:12px;padding:12px 24px;background:var(--bg-page);border-bottom:1px solid var(--border);font-size:14px;color:var(--text)}.modal-body{padding:24px;overflow-y:auto;flex:1}.form-section-title{font-size:14px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;padding-bottom:6px;border-bottom:2px solid var(--light)}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;border-top:1px solid var(--border);margin-top:8px}.modal-lg{max-width:780px}.form-section-header{padding:12px 0 8px;border-bottom:2px solid var(--navy);margin-bottom:14px}.form-section-header h3{font-size:14px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.5px;margin:0}.form-section-collapsible{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none;margin-top:8px;transition:color .15s}.form-section-collapsible:hover h3{color:#2a6db0}.form-section-body{padding:4px 0 12px}.form-subsection{margin-bottom:18px}.form-subsection h4{font-size:13px;font-weight:600;color:var(--text);margin:0 0 10px}.form-subsection-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.form-subsection-header h4{margin:0}.btn-outline{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border:1px solid var(--navy);border-radius:var(--radius-sm);background:#fff;color:var(--navy);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.btn-outline:hover{background:var(--navy);color:#fff}.form-helper-text{font-size:12px;color:var(--text-light);margin:0;line-height:1.5}.form-label-optional{font-weight:400;font-size:12px;color:var(--text-light)}.mode-selector{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.mode-option{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);background:#fff;cursor:pointer;transition:all .15s;text-align:left}.mode-option:hover{border-color:var(--navy);background:#f5f8fb}.mode-option.active{border-color:var(--navy);background:#eef2f7}.mode-option.active svg{color:var(--navy)}.mode-option svg{flex-shrink:0;color:var(--text-light)}.mode-option-text{display:flex;flex-direction:column;gap:2px}.mode-option-title{font-size:14px;font-weight:600;color:var(--text)}.mode-option-desc{font-size:12px;color:var(--text-light);line-height:1.4}.form-section-commercial{margin-top:20px;border-top:2px solid var(--navy);padding-top:14px}.invoice-upload-container{margin-bottom:10px}.file-upload-large{min-height:80px;justify-content:center}.invoice-upload-info{display:flex;align-items:center;gap:12px;width:100%}.invoice-upload-info svg:first-child{flex-shrink:0;color:#27ae60}.invoice-upload-info>div{flex:1;min-width:0}.invoice-upload-name{font-weight:600;font-size:14px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invoice-upload-meta{font-size:12px;color:var(--text-light);margin-top:2px}.invoice-preview-section{margin-top:14px}.invoice-preview-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#27ae60;margin-bottom:10px}.invoice-preview-list{display:flex;flex-direction:column;gap:10px}.invoice-preview-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;background:#fafbfc}.invoice-preview-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.invoice-preview-fields{display:flex;gap:12px;align-items:flex-start}.invoice-preview-sheet{font-size:12px;color:var(--text-light)}.invoice-preview-sheet strong{color:var(--text)}.invoice-preview-stats{font-size:12px;color:var(--navy);font-weight:600}.oc-upload-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;margin-bottom:10px;background:#fafbfc}.oc-upload-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.oc-upload-card-label{font-size:12px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.5px}.oc-preview-badge{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#e8f5e9;border-radius:var(--radius-sm);font-size:12px;color:#2e7d32;margin-top:6px}.oc-preview-badge svg{flex-shrink:0}.oc-preview-error{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#fff3e0;border-radius:var(--radius-sm);font-size:12px;color:#e65100;margin-top:6px}.btn-icon-danger{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-light);cursor:pointer;transition:all .15s}.btn-icon-danger:hover{background:#fee2e2;color:#dc2626}.oc-upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.file-upload-zone{display:flex;align-items:center;justify-content:center;min-height:40px;border:2px dashed var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;padding:8px 12px}.file-upload-zone:hover{border-color:var(--navy);background:#f0f4f8}.file-upload-zone.file-uploaded{border-style:solid;border-color:#10b981;background:#ecfdf5}.file-upload-placeholder{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-light)}.file-upload-name{display:flex;align-items:center;gap:6px;font-size:12px;color:#065f46;font-weight:500}.form-row-inline{display:flex;gap:16px;align-items:flex-start}.form-group-sm{max-width:120px}.input-with-suffix{display:flex;align-items:center;position:relative}.input-with-suffix .form-input{padding-right:30px}.input-suffix{position:absolute;right:10px;font-size:13px;color:var(--text-light);pointer-events:none}.radio-group{display:flex;gap:16px;flex-wrap:wrap}.radio-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text);cursor:pointer}.radio-label input[type=radio]{accent-color:var(--navy);width:15px;height:15px;cursor:pointer}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.invoice-totals-row.costs{color:var(--text-light);font-style:italic}.invoice-factura-tab-dc .factura-tab-po{color:#92400e}.invoice-factura-tab-dc{border-left:3px solid #F59E0B}.factura-tab-icon{display:flex;align-items:center;color:var(--text-light)}.modal-entrega{max-width:520px;max-height:95vh;display:flex;flex-direction:column}.entrega-header{display:flex;align-items:center;gap:12px;padding:14px 20px;background:var(--navy);color:#fff;border-radius:var(--radius) var(--radius) 0 0}.entrega-header-title{font-size:16px;font-weight:700}.entrega-back{background:none;border:none;color:#fff;cursor:pointer;padding:4px;display:flex}.entrega-op-banner{padding:16px 20px;background:#fff;border-bottom:1px solid var(--border)}.entrega-op-top{display:flex;align-items:center;gap:12px;margin-bottom:6px}.entrega-op-vessel{font-size:20px;font-weight:800;color:var(--navy);margin:0}.entrega-op-meta{font-size:13px;color:var(--muted);margin:2px 0 0}.entrega-time-warning{display:flex;align-items:flex-start;gap:10px;padding:12px 20px;background:#eef2f7;border:1px solid var(--light);margin:12px 20px 0;border-radius:var(--radius-sm);font-size:13px;color:var(--navy)}.entrega-time-warning p{margin:0}.entrega-form{padding:8px 20px 24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:0}.entrega-section{padding:20px 0 16px;border-bottom:1px solid var(--border)}.entrega-section:last-of-type{border-bottom:none}.entrega-section-title{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:800;color:var(--navy);text-transform:uppercase;letter-spacing:.5px;margin:0 0 14px}.entrega-section-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--yellow);color:var(--navy);font-size:13px;font-weight:800;flex-shrink:0}.entrega-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.entrega-field-sublabel{font-size:13px;font-weight:600;color:var(--text)}.entrega-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:20px 16px;border:2px dashed var(--border);border-radius:var(--radius);background:var(--gray);cursor:pointer;transition:border-color .2s,background .2s}.entrega-dropzone:hover,.entrega-dropzone.drag-over{border-color:var(--navy);background:var(--light)}.entrega-dropzone-text{font-size:13px;color:var(--text);font-weight:500;margin:0}.entrega-dropzone-hint{font-size:12px;color:var(--muted);margin:0}.entrega-file-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.entrega-file-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--bg-page);border:1px solid var(--border);border-radius:20px;font-size:12px;color:var(--text);font-weight:500}.entrega-chip-remove{background:none;border:none;color:var(--muted);cursor:pointer;padding:0;display:flex;margin-left:2px}.entrega-chip-remove:hover{color:var(--red)}.entrega-disclaimer{display:flex;align-items:flex-start;gap:6px;font-size:13px;color:var(--muted);margin:4px 0 0}.entrega-textarea{width:100%;box-sizing:border-box;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text);resize:vertical;transition:border-color .15s;min-height:100px}.entrega-textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #1f4e791a}.entrega-error{color:var(--red);font-size:12px;margin:0}.cumplimiento-compact{display:flex;align-items:flex-start;gap:16px}.cumplimiento-compact .cumplimiento-input-row{flex-shrink:0}.cumplimiento-compact .cumplimiento-indicator{flex:1;margin-top:0;padding-top:4px}.cumplimiento-input-row{display:flex;align-items:center;gap:8px}.cumplimiento-input{width:120px;padding:12px 14px;font-size:28px;font-weight:800;color:var(--navy);border:2px solid var(--border);border-radius:var(--radius-sm);text-align:center;font-family:inherit}.cumplimiento-input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #1f4e791a}.cumplimiento-input.input-error{border-color:var(--red)}.cumplimiento-pct{font-size:20px;font-weight:700;color:var(--text)}.cumplimiento-indicator{margin-top:8px}.cumplimiento-zona{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:600;margin-bottom:4px}.cumplimiento-hint{font-size:12px;color:var(--muted);margin:0 0 6px}.cumplimiento-bar{position:relative;display:flex;height:10px;border-radius:5px;overflow:visible}.cumplimiento-segment{height:100%}.cumplimiento-rojo{flex:0 0 90%;background:#c00000;border-radius:5px 0 0 5px}.cumplimiento-naranja{flex:0 0 5%;background:#f59e0b}.cumplimiento-verde{flex:0 0 5%;background:#375623;border-radius:0 5px 5px 0}.cumplimiento-marker{position:absolute;top:-3px;width:4px;height:16px;background:var(--navy);border-radius:2px;transform:translate(-50%);transition:left .2s ease}.cumplimiento-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-top:4px}.cumplimiento-note{font-size:12px;color:var(--muted);margin:6px 0 0}.entrega-submit{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px;background:var(--navy);color:#fff;border:none;border-radius:var(--radius);font-size:16px;font-weight:700;font-family:inherit;cursor:pointer;margin-top:16px;transition:background .2s}.entrega-submit:hover{background:#163d5e}.entrega-submit:disabled{opacity:.6;cursor:not-allowed}.entrega-list-items{display:flex;flex-direction:column;gap:6px}.entrega-list-row{display:flex;align-items:center;gap:8px}.entrega-list-num{font-size:13px;font-weight:600;color:var(--muted);min-width:20px}.entrega-list-input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text);transition:border-color .15s}.entrega-list-input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #1f4e791a}.entrega-list-remove{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:4px;display:flex}.entrega-list-remove:hover{color:var(--red);background:#fef2f2}.entrega-list-add{background:none;border:1px dashed var(--border);border-radius:var(--radius-sm);padding:8px;font-size:13px;font-weight:600;color:var(--navy);cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s}.entrega-list-add:hover{background:var(--bg-page);border-color:var(--navy)}.regresados-list{border:1px solid #e5e7eb;border-radius:6px;overflow:hidden;margin-bottom:8px}.regresados-header{display:grid;grid-template-columns:1fr 60px 70px 80px 32px;gap:6px;padding:6px 10px;background:#f3f4f6;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:#6b7280}.regresados-row{display:grid;grid-template-columns:1fr 60px 70px 80px 32px;gap:6px;padding:8px 10px;align-items:center;border-top:1px solid #f3f4f6}.regresados-row:first-child{border-top:none}.regresados-col-desc{display:flex;flex-direction:column;gap:1px;min-width:0}.regresados-desc-en{font-size:12px;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.regresados-desc-es{font-size:10px;color:#9ca3af}.regresados-col-unit{text-align:center}.regresados-unit-badge{display:inline-block;background:#e8edf3;color:var(--navy);font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px}.regresados-col-qty{text-align:center;font-size:13px;font-weight:600}.regresados-qty-ref{color:#9ca3af}.regresados-qty-input{width:60px;padding:4px 6px;border:1px solid #d1d5db;border-radius:4px;font-size:13px;font-weight:600;text-align:center;color:var(--navy)}.regresados-qty-input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 2px #1f4e7926}.regresados-col-action{text-align:center}.regresados-search{position:relative}.regresados-search-input-wrap{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px dashed #d1d5db;border-radius:6px;color:#9ca3af;transition:border-color .15s}.regresados-search-input-wrap:focus-within{border-color:var(--navy);color:var(--navy)}.regresados-search-input{flex:1;border:none;outline:none;font-size:13px;background:transparent;color:#111827}.regresados-search-input::placeholder{color:#9ca3af}.regresados-dropdown{position:absolute;top:100%;left:0;right:0;z-index:20;background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 8px 24px #0000001f;max-height:240px;overflow-y:auto;margin-top:4px}.regresados-dropdown-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:8px 12px;border:none;background:none;cursor:pointer;text-align:left;font-size:12px;transition:background .1s;gap:8px}.regresados-dropdown-item:hover{background:#f0f4ff}.regresados-dd-desc{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.regresados-dd-meta{display:flex;align-items:center;gap:6px;flex-shrink:0;font-size:11px;color:#6b7280}.entrega-submit-note{text-align:center;font-size:12px;color:var(--muted);margin:8px 0 0}.programar-field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.programar-field:last-child{margin-bottom:0}.programar-field .form-input{width:100%;box-sizing:border-box}.input-error-border{border-color:var(--red)!important}.horario-row{display:flex;gap:8px}.horario-row .form-input{flex:1;box-sizing:border-box}.horario-row .horario-time{flex:0 0 110px}.rapida-frescura{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding:6px 10px;background:#f8f9fa;border-radius:8px}.horarios-permisos-row{display:flex;gap:6px;margin-top:8px}.horarios-permiso-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:1.5px solid}.horarios-permiso-icon.done{color:#16a34a;border-color:#bbf7d0;background:#f0fdf4}.horarios-permiso-icon.pending{color:#9ca3af;border-color:#e5e7eb;background:#f9fafb}.horarios-frescura-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-left:4px solid #DC2626;background:#f9fafb;margin:0 16px;border-radius:0 8px 8px 0}.horarios-frescura-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.horarios-frescura-text{font-size:13px;color:#374151}.horarios-section-title{font-size:13px;font-weight:700;color:#1f4e79;letter-spacing:.5px;margin-bottom:12px}.horarios-field-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #F3F4F6}.horarios-field-row:last-child{border-bottom:none}.horarios-field-label{display:flex;align-items:flex-start;gap:8px;min-width:140px;flex-shrink:0}.horarios-field-label strong{display:block;font-size:13px;color:#1f2937}.horarios-field-sub{display:block;font-size:11px;color:#9ca3af;margin-top:1px}.horarios-field-inputs{display:flex;gap:6px;flex:1}.horarios-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:10px;white-space:nowrap;flex-shrink:0}.horarios-badge.nuevo{color:#16a34a;background:#f0fdf4}.horarios-badge.indefinido{color:#92400e;background:#fffbeb}.horarios-compare-table{display:flex;flex-direction:column;gap:0}.horarios-compare-row{display:flex;align-items:center;padding:8px 0;border-bottom:1px solid #F3F4F6}.horarios-compare-row:last-child{border-bottom:none}.horarios-compare-label{display:flex;align-items:center;gap:6px;flex:1;font-size:13px;color:#6b7280}.horarios-compare-old{font-size:13px;color:#9ca3af;text-decoration:line-through;min-width:60px;text-align:right;margin-right:12px}.horarios-compare-new{font-size:14px;font-weight:700;color:#1f4e79;min-width:80px;text-align:right}.horarios-compare-new.changed{color:#1f4e79}.horarios-footer{display:flex;align-items:center;justify-content:space-between;padding:16px;border-top:1px solid #E5E7EB;gap:12px}.horarios-footer-note{font-size:11px;color:#9ca3af;flex:1}.horarios-footer-buttons{display:flex;gap:8px;flex-shrink:0}.programar-checklist{display:flex;flex-direction:column;gap:4px}.programar-check-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;cursor:pointer;font-size:14px;font-family:inherit;color:var(--text);text-align:left;transition:background .15s,border-color .15s}.programar-check-item:hover{background:var(--gray)}.programar-check-item.checked{background:#f0fdf4;border-color:#bbf7d0}.programar-check-item .check-icon-done{color:#16a34a}.programar-check-item .check-icon-pending{color:var(--border)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group.has-error .form-input{border-color:var(--red)}.form-label{font-size:13px;font-weight:600;color:var(--text)}.required{color:var(--red)}.form-input{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text);background:#fff;transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 2px #1f4e7926}.form-input:disabled{background:var(--gray);color:var(--muted);cursor:not-allowed}.form-error{font-size:12px;color:var(--red)}.form-error-banner{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;color:var(--red);border:1px solid #FECACA;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:0 1px 4px #00000014;padding:20px;display:flex;align-items:center;gap:16px}.kpi-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-content{display:flex;flex-direction:column}.kpi-value{font-size:28px;font-weight:800;color:var(--navy);line-height:1.1}.kpi-label{font-size:13px;color:var(--muted);margin-top:2px}.report-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.report-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:0 1px 4px #00000014;overflow:hidden}.report-card-title{display:flex;align-items:center;gap:8px;padding:14px 20px;background:var(--bg-header);border-bottom:1px solid var(--border);font-size:14px;font-weight:700;color:var(--navy);margin:0}.report-card-body{padding:16px 20px}.report-bar-row{display:flex;align-items:center;gap:12px;padding:6px 0}.report-bar-label{font-size:13px;min-width:110px;color:var(--text)}.report-bar-track{flex:1;height:8px;background:var(--gray);border-radius:4px;overflow:hidden}.report-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;min-width:4px}.report-bar-value{font-size:14px;font-weight:700;color:var(--navy);min-width:28px;text-align:right}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:16px;border-bottom:1px solid #F3F4F6;cursor:pointer;transition:background .15s;border-radius:var(--radius-sm);padding:16px 8px}.timeline-item:hover{background:var(--gray)}.timeline-dot{width:12px;height:12px;border-radius:50%;background:var(--navy);flex-shrink:0;margin-top:6px}.timeline-content{flex:1;min-width:0}.timeline-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.timeline-type{font-size:13px;font-weight:600;color:var(--text)}.timeline-date{font-size:12px;color:var(--muted);margin-left:auto}.timeline-body{display:flex;align-items:baseline;margin-bottom:4px}.timeline-desc{font-size:13px;color:var(--muted);margin:0}.timeline-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.week-nav{display:flex;align-items:center;gap:4px}.week-label{min-width:200px;text-align:center;font-weight:600}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;min-height:500px}.week-column{background:var(--bg-card);border-radius:var(--radius);box-shadow:0 1px 4px #0000000f;display:flex;flex-direction:column;overflow:hidden}.week-column-today{box-shadow:0 0 0 2px var(--navy),0 2px 8px #1f4e7926}.week-column-header{display:flex;flex-direction:column;align-items:center;padding:10px 8px;background:var(--bg-header);border-bottom:1px solid var(--border);gap:2px}.week-column-header.today{background:var(--navy);color:#fff}.week-day-name{font-size:11px;text-transform:uppercase;font-weight:600;letter-spacing:.5px;opacity:.7}.week-day-number{font-size:20px;font-weight:700}.today-number{color:#fff}.week-column-body{padding:8px;flex:1;display:flex;flex-direction:column;gap:8px;overflow-y:auto}.week-empty{text-align:center;color:var(--muted);font-size:12px;padding:20px 4px;opacity:.5}.week-card{padding:10px;background:#fafafa;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.week-card:hover{background:var(--light);border-color:var(--navy)}.week-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.week-card-vessel{font-size:13px;font-weight:700;color:var(--navy);margin:0;line-height:1.3}.week-card-cc{font-size:11px;font-family:Cascadia Code,Consolas,monospace;color:var(--muted);margin:2px 0 4px}.week-card-meta{font-size:11px;color:var(--muted);margin:2px 0}.week-card-time{font-size:12px;font-weight:600;color:var(--navy);margin:4px 0 0}@media (max-width: 768px){.app-main{margin-left:0;padding:16px}.sidebar{transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:80}.header-menu-btn{display:flex}.header-section,.header-user-info,.table-container{display:none}.cards-container{display:flex}.page-header-left h1{font-size:18px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.report-grid,.detail-grid{grid-template-columns:1fr}.detail-title-row{flex-direction:column;align-items:flex-start}.detail-title{font-size:20px}.form-grid{grid-template-columns:1fr}.modal-container{max-height:95vh}.week-grid{grid-template-columns:1fr;min-height:auto}.week-column-body{max-height:200px}.filters-row{flex-direction:column}.filter-group{min-width:100%}}@media (max-width: 480px){.header-logo-img{height:24px}.header-divider{display:none}.filters-bar{flex-direction:column}}.email-preview-modal{max-width:680px;width:95%;max-height:90vh;display:flex;flex-direction:column}.email-preview-meta{padding:14px 20px;background:#f9fafb;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.email-preview-meta-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.email-preview-meta-row strong{color:var(--navy);min-width:55px}.email-preview-meta-row span{color:var(--text);word-break:break-all}.email-preview-body{flex:1;min-height:0;padding:12px;overflow:auto}.email-preview-iframe{width:100%;min-height:500px;border:1px solid var(--border);border-radius:8px;background:#fff}.alerta-pendientes{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fef2f2;border:1px solid #FECACA;border-left:4px solid #EF4444;border-radius:var(--radius-sm);padding:10px 16px;margin-bottom:16px;cursor:pointer;transition:all .15s ease}.alerta-pendientes:hover{background:#fee2e2;border-color:#ef4444}.alerta-pendientes-left{display:flex;align-items:center;gap:10px;font-size:13px;color:#991b1b;min-width:0}.alerta-pendientes-left svg{color:#ef4444;flex-shrink:0}.alerta-pendientes-left span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.alerta-pendientes-right{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:#ef4444;white-space:nowrap;flex-shrink:0}.todo-panel{max-width:680px;margin:0 auto;background:var(--bg-card);border-radius:12px;border:1px solid var(--border);overflow:hidden}.todo-panel-header{background:var(--navy);color:#fff;padding:14px 20px;display:flex;align-items:center;justify-content:space-between}.todo-panel-title{font-weight:600;font-size:15px}.todo-panel-badge{background:var(--yellow);color:var(--navy);font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px}.todo-section{padding:16px 20px;border-bottom:1px solid var(--border)}.todo-section:last-child{border-bottom:none}.todo-section-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;margin:0 0 12px}.todo-section-count{background:var(--gray);color:var(--muted);font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.todo-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:all .15s ease;position:relative}.todo-card:last-child{margin-bottom:0}.todo-card:hover{border-color:var(--blue);box-shadow:0 2px 8px #1f4e7914}.todo-card-urgente{border-left:4px solid #EF4444;background:#fef2f2;border-color:#fecaca}.todo-card-urgente:hover{border-color:#ef4444;border-left-color:#ef4444}.todo-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:4px}.todo-card-vessel-row,.todo-card-status-row{display:flex;align-items:center;gap:8px;min-width:0}.todo-card-vessel{font-weight:700;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.todo-card-cc{font-size:12px;color:var(--muted);white-space:nowrap;flex-shrink:0}.todo-card-meta{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--muted);margin-bottom:8px}.todo-urgente-icon{color:#ef4444;flex-shrink:0}.todo-card-urgente-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.todo-urgente-time{font-size:12px;font-weight:600;color:#ef4444}.todo-btn-actualizar{background:var(--navy);color:#fff;border:none;border-radius:6px;padding:6px 16px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s ease}.todo-btn-actualizar:hover{background:var(--blue)}.todo-card-tareas{list-style:none;margin:6px 0 0;padding:0}.todo-tarea-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);padding:3px 0}.todo-tarea-dot{color:var(--yellow);flex-shrink:0}.todo-card-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--border);transition:color .15s ease}.todo-card:hover .todo-card-arrow{color:var(--blue)}.todo-empty{text-align:center;padding:32px 16px;color:var(--muted)}.todo-empty p{margin:8px 0 0;font-size:14px}.doc-menu-wrapper{position:relative;margin-left:auto}.doc-add-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:1.5px solid var(--navy);border-radius:var(--radius-sm);color:var(--navy);font-size:13px;font-weight:600;font-family:inherit;padding:5px 14px;cursor:pointer;transition:background .15s,color .15s}.doc-add-btn:hover{background:var(--navy);color:#fff}.doc-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:240px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0000001f;z-index:50;padding:6px 0;animation:doc-dropdown-in .12s ease-out}@keyframes doc-dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.doc-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;padding:9px 16px;font-size:13px;font-family:inherit;color:var(--text);cursor:pointer;transition:background .12s;text-align:left}.doc-dropdown-item:hover{background:var(--gray)}.doc-dropdown-otro{color:var(--muted);font-style:italic}.doc-dropdown-divider{height:1px;background:var(--border);margin:4px 0}.doc-dropdown-otro-input{display:flex;align-items:center;gap:6px;padding:6px 12px}.doc-dropdown-otro-input input{flex:1;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;font-size:13px;font-family:inherit;outline:none}.doc-dropdown-otro-input input:focus{border-color:var(--navy)}.doc-otro-confirm{background:var(--navy);color:#fff;border:none;border-radius:var(--radius-sm);padding:6px 12px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer}.doc-otro-confirm:disabled{opacity:.4;cursor:not-allowed}.doc-list{display:flex;flex-direction:column;gap:0}.doc-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #F3F4F6}.doc-row:last-child{border-bottom:none}.doc-row-icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--light);border-radius:var(--radius-sm);color:var(--navy);flex-shrink:0}.doc-row-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.doc-row-label{font-size:13px;font-weight:600;color:var(--navy)}.doc-row-file{font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-row-meta{font-size:11px;color:var(--muted)}.doc-row-actions{display:flex;gap:4px;flex-shrink:0}.doc-action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:var(--radius-sm);background:var(--gray);color:var(--muted);cursor:pointer;transition:background .15s,color .15s}.doc-action-btn:hover{background:var(--light);color:var(--navy)}.doc-action-delete:hover{background:#fef2f2;color:var(--red)}.doc-row-uploading{display:flex;align-items:center;gap:8px;padding:10px 0;color:var(--muted);font-size:13px}.doc-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}.doc-preview-modal{width:100%;max-width:900px;height:90vh;background:var(--bg-card);border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.doc-preview-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--navy);color:#fff;min-height:48px}.doc-preview-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;margin-right:12px}.doc-preview-actions{display:flex;align-items:center;gap:8px}.doc-preview-btn{background:#ffffff26;border:none;border-radius:6px;padding:6px;cursor:pointer;color:#fff;display:flex;align-items:center;transition:background .15s;text-decoration:none}.doc-preview-btn:hover{background:#ffffff4d}.doc-preview-close:hover{background:#ff505080}.doc-preview-body{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background:#1a1a2e}.doc-preview-image{max-width:100%;max-height:100%;object-fit:contain}.doc-preview-iframe{width:100%;height:100%;border:none}.doc-preview-loading{display:flex;flex-direction:column;align-items:center;gap:12px;color:#fff;font-size:14px}@media (max-width: 600px){.doc-preview-modal{height:100vh;max-width:100%;border-radius:0}.doc-preview-overlay{padding:0}}.doc-empty{text-align:center;color:var(--muted);font-size:13px;padding:16px 0;font-style:italic}.row-other{opacity:.45;transition:opacity .15s}.row-other:hover{opacity:.85}.card-other{opacity:.45;transition:opacity .15s}.card-other:hover{opacity:.85}.btn-entrega-reporte{display:inline-flex;align-items:center;gap:6px;background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 18px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.btn-entrega-reporte:hover{background:#2a4119}.alerta-documentos{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#eff6ff;border:1px solid #BFDBFE;border-left:4px solid var(--blue);border-radius:var(--radius-sm);padding:10px 16px;margin-bottom:16px;cursor:pointer;transition:all .15s ease}.alerta-documentos:hover{background:#dbeafe;border-color:var(--blue)}.alerta-documentos-left{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--navy);min-width:0}.alerta-documentos-left svg{color:var(--blue);flex-shrink:0}.alerta-documentos-left span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.alerta-documentos-right{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--blue);white-space:nowrap;flex-shrink:0}.crono-my-count{font-size:12px;font-weight:600;color:var(--navy);background:var(--light);padding:3px 10px;border-radius:12px;white-space:nowrap}.crono-legend{display:flex;gap:20px;margin-bottom:14px}.crono-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.crono-legend-dot{width:10px;height:10px;border-radius:3px}.crono-legend-mine{background:var(--navy)}.crono-legend-other{background:var(--border)}.crono-card{position:relative;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:transform .12s,box-shadow .12s;margin-bottom:6px;overflow:hidden}.crono-card:hover{transform:translateY(-1px);box-shadow:0 3px 10px #0000001a}.crono-card-mine{background:var(--bg-card);border:1.5px solid var(--navy);box-shadow:0 1px 4px #1f4e791f}.crono-card-accent{position:absolute;top:0;left:0;width:4px;height:100%;background:var(--navy);border-radius:4px 0 0 4px}.crono-card-other{background:var(--gray);border:1px solid var(--border);opacity:.7}.crono-card-other:hover{opacity:1}.crono-card-top{display:flex;align-items:center;gap:6px;margin-bottom:4px}.crono-card-vessel{font-size:13px;font-weight:700;color:var(--navy);margin:0;line-height:1.3}.crono-card-mine .crono-card-vessel{padding-left:6px}.crono-card-cc{font-family:Cascadia Code,Consolas,monospace;font-size:11px;color:var(--muted);margin:2px 0 0}.crono-card-meta{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--muted);margin:4px 0 0}.crono-card-time{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--text);margin:4px 0 0}.crono-card-role{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:#fff;background:var(--navy);padding:2px 8px;border-radius:10px;margin-top:6px}.enc-panel{max-width:680px;margin:0 auto;background:var(--bg-card);border-radius:12px;border:1px solid var(--border);overflow:hidden}.enc-panel-header{background:var(--navy);color:#fff;padding:14px 20px;display:flex;align-items:center;justify-content:space-between}.enc-panel-title{font-weight:600;font-size:15px}.enc-panel-badge{background:var(--yellow);color:var(--navy);font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px}.enc-section{padding:16px 20px;border-bottom:1px solid var(--border)}.enc-section:last-child{border-bottom:none}.enc-section-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;margin:0 0 12px}.enc-section-title-espera{color:#92400e}.enc-section-count{background:var(--gray);color:var(--muted);font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.enc-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:all .15s ease}.enc-card:last-child{margin-bottom:0}.enc-card:hover{border-color:var(--blue);box-shadow:0 2px 8px #1f4e7914}.enc-card-espera{background:#fffbeb;border-color:#fde68a}.enc-card-espera:hover{border-color:#f59e0b}.enc-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:4px}.enc-card-status-row{display:flex;align-items:center;gap:8px;min-width:0}.enc-card-vessel{font-weight:700;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.enc-card-cc{font-size:12px;font-family:Cascadia Code,Consolas,monospace;color:var(--muted);margin-bottom:4px}.enc-card-meta{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--muted);margin-bottom:2px}.enc-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px}.enc-card-arrow{color:var(--border);transition:color .15s}.enc-card:hover .enc-card-arrow{color:var(--blue)}.enc-card-espera-label{display:flex;align-items:center;gap:5px;font-size:12px;color:#92400e;font-style:italic;margin-top:8px}.enc-tipo-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px;white-space:nowrap;flex-shrink:0}.enc-tipo-prov{background:#dbeafe;color:var(--navy)}.enc-tipo-rep{background:#fef3c7;color:#92400e}.enc-btn-diligenciar{background:var(--navy);color:#fff;border:none;border-radius:6px;padding:7px 18px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.enc-btn-diligenciar:hover{background:var(--blue)}.enc-empty{text-align:center;padding:28px 16px;color:var(--muted)}.enc-empty p{margin:8px 0 0;font-size:14px}.enc-form-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--blue);cursor:pointer;margin-bottom:16px;transition:color .15s}.enc-form-back:hover{color:var(--navy)}.enc-form-header{margin-bottom:16px}.enc-form-header-top{display:flex;align-items:center;gap:10px}.enc-form-header-top h1{font-size:20px;font-weight:700;color:var(--navy);margin:0}.enc-form-tipo{color:var(--blue)}.enc-form-ship{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:16px}.enc-form-ship-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.enc-form-vessel{font-size:18px;font-weight:700;color:var(--navy);margin:0}.enc-form-ship-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--muted);margin-bottom:12px}.enc-form-ship-meta span{display:flex;align-items:center;gap:4px}.enc-form-legend{display:flex;flex-wrap:wrap;gap:12px;padding-top:10px;border-top:1px solid #F3F4F6}.enc-form-legend-item{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:4px}.enc-form-legend-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border);font-size:11px;font-weight:700;color:var(--muted)}.enc-form-body{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.enc-form-seccion{padding:0}.enc-form-seccion-titulo{background:var(--navy);color:#fff;font-size:12px;font-weight:700;letter-spacing:.5px;padding:10px 20px;margin:0}.enc-form-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;border-bottom:1px solid #F3F4F6}.enc-form-row:last-child{border-bottom:none}.enc-form-row-label{flex:1;font-size:14px;color:var(--text);line-height:1.4;display:flex;gap:6px}.enc-form-row-num{color:var(--muted);font-weight:600;flex-shrink:0}.enc-form-row-circles{display:flex;gap:8px;flex-shrink:0}.enc-circle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:2px solid var(--border);background:var(--bg-card);font-size:13px;font-weight:700;color:var(--muted);font-family:inherit;cursor:pointer;transition:all .15s}.enc-circle:hover{border-color:var(--yellow);color:var(--navy);background:#fffbeb}.enc-circle-active{background:var(--yellow);border-color:var(--yellow);color:var(--navy);box-shadow:0 1px 4px #ffc00059}.enc-circle-active:hover{background:var(--yellow)}.enc-form-promedio{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:2px solid var(--border);background:#f9fafb}.enc-form-promedio-label{font-size:14px;font-weight:700;color:var(--navy)}.enc-form-promedio-value{font-size:24px;font-weight:800;color:var(--navy);min-width:50px;text-align:center}.enc-form-comentarios{padding:16px 20px;border-top:1px solid var(--border)}.enc-form-comentarios-label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:8px}.enc-form-textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;font-family:inherit;line-height:1.5;resize:vertical;color:var(--text);background:var(--bg-card);outline:none;box-sizing:border-box}.enc-form-textarea:focus{border-color:var(--navy)}.enc-btn-guardar{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:var(--green);color:#fff;border:none;border-radius:0 0 var(--radius) var(--radius);font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:background .15s}.enc-btn-guardar:hover:not(:disabled){background:#2a4119}.enc-btn-guardar:disabled{background:#9ca3af;cursor:not-allowed}.enc-form-done{text-align:center;padding:60px 20px;color:var(--muted)}.enc-form-done h2{color:var(--navy);margin:16px 0 8px}.enc-circle-readonly{cursor:default}.enc-circle-readonly:hover{border-color:var(--border);color:var(--muted);background:var(--bg-card)}.enc-circle-readonly.enc-circle-active:hover{background:var(--yellow);border-color:var(--yellow);color:var(--navy)}.enc-form-comentarios-text{font-size:14px;color:var(--text);line-height:1.5;margin:0;padding:10px 14px;background:#f9fafb;border-radius:var(--radius-sm);border:1px solid #F3F4F6}.encres-card{overflow:hidden}.encres-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 18px;background:none;border:none;cursor:pointer;font-family:inherit;gap:10px;border-bottom:1px solid var(--border);transition:background .12s}.encres-header:hover{background:var(--gray)}.encres-header-left{display:flex;align-items:center;gap:8px}.encres-header-left h2{font-size:15px;font-weight:700;color:var(--navy);margin:0}.encres-header-left svg{color:var(--yellow)}.encres-tipo{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;background:#f3f4f6;color:var(--muted)}.encres-header-right{display:flex;align-items:center;gap:6px;color:var(--muted)}.encres-promedio{font-size:20px;font-weight:800}.encres-de5{font-size:13px;color:var(--muted);font-weight:500}.encres-body{animation:kpiq-fade-in .2s ease}.encres-seccion-titulo{background:var(--navy);color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;padding:8px 18px}.encres-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 18px;border-bottom:1px solid #F3F4F6}.encres-row:last-child{border-bottom:none}.encres-row-label{flex:1;font-size:13px;color:var(--text);line-height:1.3;display:flex;gap:5px}.encres-row-num{color:var(--muted);font-weight:600;flex-shrink:0}.encres-row-circles{display:flex;gap:5px;flex-shrink:0}.encres-circle{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);font-size:11px;font-weight:700;color:var(--muted);background:var(--bg-card)}.encres-circle-active{background:var(--yellow);border-color:var(--yellow);color:var(--navy)}.encres-promedio-row{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:2px solid var(--border);background:#f9fafb;font-size:13px;font-weight:700;color:var(--navy)}.encres-promedio-big{font-size:20px;font-weight:800}.encres-comentarios{padding:12px 18px;border-top:1px solid var(--border)}.encres-comentarios-label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px}.encres-comentarios-text{font-size:13px;color:var(--text);line-height:1.4;margin:0;padding:8px 12px;background:#f9fafb;border-radius:var(--radius-sm);border:1px solid #F3F4F6}.encres-fecha{padding:8px 18px 12px;font-size:11px;color:var(--muted);text-align:right;font-style:italic}.detail-kpi-badge{display:inline-flex;align-items:center;gap:4px;background:#fffbeb;border:1.5px solid var(--yellow);border-radius:16px;padding:4px 12px;font-size:14px;font-weight:800;color:var(--navy);font-family:inherit;cursor:pointer;transition:all .15s;white-space:nowrap}.detail-kpi-badge svg{color:var(--yellow)}.detail-kpi-badge:hover{background:var(--yellow);box-shadow:0 2px 8px #ffc0004d}.encres-modal{max-width:600px;width:95%;max-height:85vh;display:flex;flex-direction:column}.encres-modal-body{flex:1;overflow-y:auto;min-height:0}.encres-modal-summary{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#f9fafb;border-bottom:1px solid var(--border);gap:12px}.encres-modal-summary-left{display:flex;align-items:center;gap:10px;min-width:0}.encres-modal-vessel{font-size:15px;font-weight:700;color:var(--navy)}.encres-modal-cc{font-size:12px;font-family:Cascadia Code,Consolas,monospace;color:var(--muted)}.encres-modal-summary-right{display:flex;align-items:center;gap:6px;flex-shrink:0}@media (max-width: 768px){.encres-row{flex-direction:column;align-items:flex-start;gap:6px}.encres-row-circles{align-self:flex-end}.encres-circle{width:24px;height:24px;font-size:10px}}.kpiq-dashboard{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px}.kpiq-dash-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 20px;background:var(--navy);color:#fff;border:none;cursor:pointer;font-family:inherit;gap:12px}.kpiq-dash-toggle-left{display:flex;align-items:center;gap:10px}.kpiq-dash-toggle-title{font-size:15px;font-weight:600}.kpiq-dash-toggle-avg{font-size:14px;font-weight:700;background:#ffffff26;padding:3px 10px;border-radius:12px}.kpiq-dash-toggle-right{display:flex;align-items:center;gap:10px}.kpiq-timeframe-select{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:5px 10px;font-size:13px;font-family:inherit;cursor:pointer;outline:none}.kpiq-timeframe-select option{background:var(--navy);color:#fff}.kpiq-dash-body{padding:20px;animation:kpiq-fade-in .2s ease}@keyframes kpiq-fade-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.kpiq-summary-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}.kpiq-summary-card{background:#f9fafb;border:1px solid #F3F4F6;border-radius:var(--radius);padding:16px;text-align:center}.kpiq-summary-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px}.kpiq-summary-value{font-size:32px;font-weight:800;line-height:1.1}.kpiq-summary-sub{font-size:12px;color:var(--muted);margin-top:4px}.kpiq-summary-clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s;font-family:inherit}.kpiq-summary-clickable:hover{border-color:var(--blue);box-shadow:0 2px 8px #1f4e791a}.kpiq-summary-active{border-color:var(--navy);box-shadow:0 0 0 2px #1f4e7926}.kpiq-summary-clickable .kpiq-summary-label{display:flex;align-items:center;justify-content:center;gap:5px}.kpiq-detail-section{margin-bottom:20px}.kpiq-detail-animated{animation:kpiq-fade-in .2s ease}.kpiq-detail-section:last-child{margin-bottom:0}.kpiq-detail-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--navy);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #F3F4F6}.kpiq-bars{display:flex;flex-direction:column;gap:5px}.kpiq-bar-row{display:flex;align-items:center;gap:10px;max-width:620px}.kpiq-bar-label{font-size:12px;color:var(--text);flex:1;min-width:0;line-height:1.25}.kpiq-bar-track{width:250px;min-width:250px;height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden;flex-shrink:0}.kpiq-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;min-width:4px}.kpiq-bar-value{font-size:15px;font-weight:800;min-width:34px;text-align:right}.kpiq-scale{display:flex;align-items:flex-start;gap:10px;margin-top:6px;padding-top:4px;border-top:1px solid #F3F4F6;max-width:620px}.kpiq-scale-spacer{flex:1;min-width:0}.kpiq-scale-value-spacer{width:34px;min-width:34px;flex-shrink:0}.kpiq-scale-track{width:250px;min-width:250px;flex-shrink:0;position:relative;height:16px}.kpiq-scale-tick{position:absolute;transform:translate(-50%);font-size:10px;font-weight:600;color:var(--muted)}.kpiq-empty-dash{text-align:center;color:var(--muted);padding:24px;font-size:14px}.kpiq-list-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.kpiq-list-title{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:700;color:var(--navy);padding:14px 20px;margin:0;border-bottom:1px solid var(--border);background:var(--bg-header)}.kpiq-list-count{font-size:12px;font-weight:600;background:var(--gray);color:var(--muted);padding:2px 10px;border-radius:12px}.kpiq-list-empty{text-align:center;padding:40px 20px;color:var(--muted)}.kpiq-list-empty p{margin:12px 0 0;font-size:14px}.kpiq-table-wrap{overflow-x:auto}.kpiq-table{width:100%;border-collapse:collapse;font-size:13px}.kpiq-table thead th{text-align:left;padding:10px 14px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;background:var(--gray);border-bottom:1px solid var(--border);white-space:nowrap}.kpiq-table-row{cursor:pointer;transition:background .12s}.kpiq-table-row:hover{background:var(--gray)}.kpiq-table-row td{padding:12px 14px;border-bottom:1px solid #F3F4F6;vertical-align:middle;white-space:nowrap}.kpiq-cc{font-family:Cascadia Code,Consolas,monospace;font-size:12px;color:var(--muted)}.kpiq-vessel{font-weight:600;color:var(--navy)}.kpiq-avg-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:13px;font-weight:700}.kpiq-cards-mobile{display:none}.kpiq-card-mobile{padding:14px 16px;border-bottom:1px solid #F3F4F6;cursor:pointer;transition:background .12s}.kpiq-card-mobile:hover{background:var(--gray)}.kpiq-card-mobile:last-child{border-bottom:none}.kpiq-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:2px}.kpiq-card-vessel{font-weight:700;font-size:14px;color:var(--navy)}.kpiq-card-cc{font-size:12px;font-family:Cascadia Code,Consolas,monospace;color:var(--muted);margin-bottom:4px}.kpiq-card-meta{display:flex;flex-direction:column;gap:2px;font-size:12px;color:var(--muted);margin-bottom:6px}.kpiq-card-meta span{display:flex;align-items:center;gap:4px}.kpiq-card-bottom{display:flex;align-items:center;justify-content:space-between}.kpiq-card-date{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--muted)}@media (max-width: 768px){.enc-panel{border-radius:0;border-left:none;border-right:none}.enc-form-row{flex-direction:column;align-items:flex-start;gap:10px}.enc-form-row-circles{align-self:flex-end}.enc-circle{width:30px;height:30px;font-size:12px}.enc-form-ship-meta,.enc-form-legend{flex-direction:column;gap:6px}.todo-panel{border-radius:0;border-left:none;border-right:none}.kpiq-summary-row{grid-template-columns:1fr}.kpiq-bar-row{flex-direction:column;align-items:flex-start;gap:4px}.kpiq-bar-label{width:auto;min-width:auto}.kpiq-bar-track{width:100%}.kpiq-scale,.kpiq-table-wrap{display:none}.kpiq-cards-mobile{display:block}.kpiq-dash-toggle-left{flex-wrap:wrap}.kpiq-dash-toggle-avg{display:none}.kpiq-dashboard,.kpiq-list-section{border-radius:0;border-left:none;border-right:none}}.detail-tabs{display:flex;gap:2px;background:var(--border);border-radius:var(--radius);padding:3px;margin-bottom:16px;width:fit-content}.detail-tab{display:flex;align-items:center;gap:6px;padding:8px 18px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.detail-tab:hover{color:var(--text);background:#fff9}.detail-tab.active{background:var(--bg-card);color:var(--navy);box-shadow:0 1px 3px #00000014;font-weight:600}.tab-count{background:var(--navy);color:#fff;font-size:11px;font-weight:600;padding:1px 7px;border-radius:10px;min-width:20px;text-align:center}.detail-tab:not(.active) .tab-count{background:var(--muted)}.listado-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.listado-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:#fafbfc}.listado-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--navy);margin:0}.listado-meta{display:flex;align-items:center;gap:6px;margin-top:4px;font-size:13px;color:var(--muted)}.listado-meta-sep{color:var(--border)}.listado-header-actions{display:flex;gap:8px}.listado-progress-bar{display:flex;align-items:center;gap:0;margin-bottom:12px;padding:10px 0}.progress-step{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--radius-sm);border:2px solid var(--border);background:#fff;cursor:default;transition:all .2s;flex:1;min-width:0;position:relative}.progress-step.step-inactive{border-color:var(--border);opacity:.5}.progress-step.step-pending{border-color:#dc2626;background:#fef2f2;cursor:pointer}.progress-step.step-done{border-color:#16a34a;background:#f0fdf4}.progress-step.step-editing{border-color:#f59e0b;background:#fffbeb;box-shadow:0 0 0 2px #f59e0b33}.progress-step:hover:not(.step-inactive):not(.step-done){transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.step-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;flex-shrink:0}.step-inactive .step-icon{background:var(--border);color:var(--muted)}.step-pending .step-icon{background:#dc2626;color:#fff}.step-done .step-icon{background:#16a34a;color:#fff}.step-editing .step-icon{background:#f59e0b;color:#fff}.step-content{display:flex;flex-direction:column;min-width:0}.step-label{font-size:12px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.step-inactive .step-label{color:var(--muted)}.step-status{font-size:11px;color:var(--muted)}.step-pending .step-status{color:#dc2626;font-weight:500}.step-done .step-status{color:#16a34a;font-weight:500}.step-editing .step-status{color:#d97706;font-weight:500}.step-reopen{position:absolute;top:4px;right:4px;border:none;background:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:4px;opacity:0;transition:opacity .15s}.progress-step:hover .step-reopen{opacity:1}.step-reopen:hover{background:#0000000d;color:var(--text)}.progress-connector{width:24px;height:2px;background:var(--border);flex-shrink:0}.progress-connector.connector-active{background:#16a34a}.listado-editing-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-radius:var(--radius-sm);margin-bottom:12px;gap:12px}.listado-editing-bar.editing-inv{background:#fffbeb;border:1px solid #f59e0b}.listado-editing-bar.editing-ped{background:#eff6ff;border:1px solid #3b82f6}.listado-editing-bar.editing-ext{background:#fef3c7;border:1px solid #d97706}.editing-bar-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text)}.editing-inv .editing-bar-label{color:#d97706}.editing-ped .editing-bar-label{color:#1d4ed8}.editing-ext .editing-bar-label{color:#92400e}.editing-bar-actions{display:flex;gap:8px}.btn-workflow{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;background:#fff;color:var(--text)}.btn-workflow-confirm{background:#16a34a;color:#fff;border-color:#16a34a}.btn-workflow-confirm:hover{background:#15803d}.btn-workflow-save{background:#2563eb;color:#fff;border-color:#2563eb}.btn-workflow-save:hover{background:#1d4ed8}.btn-workflow-accent{background:#f59e0b;color:#000;border-color:#f59e0b;font-weight:600}.btn-workflow-accent:hover{background:#d97706}.btn-workflow-cancel{color:var(--muted);border-color:var(--border)}.btn-workflow-cancel:hover{color:var(--text);border-color:var(--text)}.btn-workflow:disabled{opacity:.6;cursor:not-allowed}.workflow-feedback{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:6px;font-size:13px;font-weight:500;animation:feedbackFadeIn .3s ease}.feedback-ok{background:#dcfce7;color:#15803d}.feedback-error{background:#fef2f2;color:#dc2626}@keyframes feedbackFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.spin-icon{animation:spin 1s linear infinite}.btn-xs{padding:3px 10px;font-size:11px;border-radius:4px;cursor:pointer;border:1px solid var(--border);background:var(--bg-card);color:var(--text)}.btn-xs.btn-primary{background:var(--navy);color:#fff;border-color:var(--navy)}.btn-xs.btn-secondary{background:var(--bg-card);color:var(--muted)}.buque-sugerencias-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 4px 16px #0000001f;max-height:260px;overflow-y:auto;margin-top:2px}.buque-sugerencia-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:background .1s}.buque-sugerencia-item:last-child{border-bottom:none}.buque-sugerencia-item:hover{background:#f0f5ff}.buque-sugerencia-item svg{color:var(--navy);flex-shrink:0}.buque-sugerencia-nombre{display:block;font-weight:600;font-size:13px;color:var(--text)}.buque-sugerencia-meta{display:block;font-size:11px;color:var(--muted)}.buque-crm-panel{margin:4px 0 16px;border:1px solid #d1e3f6;border-radius:var(--radius);background:linear-gradient(135deg,#f0f7ff,#fafbfe);overflow:hidden}.buque-crm-header{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--navy);color:#fff;font-size:13px;font-weight:600}.buque-crm-codigo{margin-left:8px;background:#fff3;padding:1px 8px;border-radius:4px;font-size:11px;font-weight:700}.buque-crm-kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:#e5e7eb}.buque-crm-kpi{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;background:#fff}.buque-crm-kpi svg{color:var(--navy);margin-top:1px;flex-shrink:0}.buque-crm-kpi-label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);font-weight:600}.buque-crm-kpi-value{display:block;font-size:13px;font-weight:700;color:var(--text);margin-top:2px}.buque-crm-kpi-sub{display:block;font-size:10px;color:var(--muted)}.buque-crm-ops-list{display:flex;flex-direction:column;gap:2px;margin-top:2px}.buque-crm-op-item{font-size:11px;color:var(--text);font-weight:500}.buque-crm-op-fecha{margin-left:6px;color:var(--muted);font-weight:400}.buque-crm-notas{padding:10px 14px;border-top:1px solid #e5e7eb;background:#fff}.buque-crm-notas-header{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px}.buque-crm-notas-edit{margin-left:auto;background:none;border:none;color:var(--blue);font-size:11px;cursor:pointer;text-decoration:underline}.buque-crm-notas-text{font-size:12px;color:var(--text);margin:0;line-height:1.5;font-style:italic}.buque-crm-notas-textarea{font-size:12px;min-height:40px;resize:vertical}@media (max-width: 640px){.buque-crm-kpis{grid-template-columns:1fr}}.notas-buque-badge{margin-left:auto;font-size:11px;font-weight:600;background:var(--navy);color:#fff;padding:2px 8px;border-radius:10px}.notas-operativas-body{display:flex;flex-direction:column;gap:8px}.notas-kpis-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#f0f4ff;border-radius:6px;flex-wrap:wrap}.notas-kpi{display:flex;align-items:center;gap:5px;font-size:12px;color:#374151}.notas-kpi-label{color:#6b7280;font-weight:500}.notas-kpi-value{font-weight:600;color:var(--navy)}.notas-kpi-sep{width:1px;height:16px;background:#cbd5e1}.notas-kpis-entregas{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;color:#6b7280}.notas-entrega-chip{background:#e8edf3;color:var(--navy);font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px}.notas-operativas-delete{background:none;border:none;color:#d1d5db;cursor:pointer;padding:2px;border-radius:4px;line-height:1;transition:color .15s;margin-left:auto}.notas-operativas-delete:hover{color:#ef4444}.notas-operativas-buque{background:#f0f4ff;border-left:3px solid var(--navy);padding:8px 12px;border-radius:4px}.notas-operativas-source{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--navy);display:block;margin-bottom:4px}.notas-operativas-list{display:flex;flex-direction:column;gap:8px}.notas-operativas-item{background:#fafbfc;border:1px solid #e5e7eb;border-radius:6px;padding:8px 12px}.notas-operativas-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.notas-operativas-autor{font-size:12px;font-weight:600;color:#1f4e79}.notas-operativas-fecha{font-size:11px;color:#9ca3af}.notas-operativas-text{font-size:13px;color:#374151;margin:0;line-height:1.4}.notas-operativas-empty{font-size:13px;color:#9ca3af;font-style:italic;margin:0}.notas-operativas-input{display:flex;flex-direction:column;gap:6px;border-top:1px solid #e5e7eb;padding-top:10px}.notas-operativas-input textarea{font-size:13px;min-height:48px;width:100%;resize:vertical;box-sizing:border-box}.notas-operativas-send{align-self:flex-end;display:flex;align-items:center;gap:6px;font-size:12px;padding:6px 14px}.mencion-highlight{color:#2563eb;font-weight:600;background:#eff6ff;padding:0 3px;border-radius:3px}.mencion-textarea-wrap{flex:1}.mencion-dropdown{position:absolute;bottom:100%;left:0;right:0;background:#fff;border:1px solid #D0D7DE;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:200px;overflow-y:auto;z-index:100;margin-bottom:4px}.mencion-dropdown-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;cursor:pointer;font-size:13px;transition:background .1s}.mencion-dropdown-item:hover,.mencion-dropdown-item--active{background:#eff6ff}.mencion-dropdown-name{font-weight:500;color:#1f2937}.mencion-dropdown-role{font-size:11px;color:#6b7280;background:#f3f4f6;padding:2px 8px;border-radius:10px}@media (max-width: 768px){.listado-progress-bar{flex-wrap:wrap;gap:8px}.progress-connector{display:none}.progress-step{flex:1 1 45%}}.col-editing{background:#fffbeb!important}th.col-editing{background:#fef3c7!important}.th-sub-active{color:#d97706;font-weight:700}.ext-auto{color:var(--muted);opacity:.5}.ext-auto.ext-on{color:#e65100;opacity:1}.financial-indicators-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:12px 16px;background:var(--bg-subtle, #f8f9fb);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px}.fin-indicator{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-radius:var(--radius-sm);background:#fff;border-left:3px solid var(--border);position:relative}.fin-indicator .fin-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.fin-indicator .fin-value{font-size:16px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.fin-indicator .fin-pct{font-size:11px;font-weight:600;color:var(--muted);position:absolute;top:10px;right:12px;background:var(--bg-subtle, #f0f1f3);padding:1px 6px;border-radius:8px}.fin-presupuesto{border-left-color:var(--navy, #1e3a5f)}.fin-presupuesto .fin-value{color:var(--navy, #1e3a5f)}.fin-inv{border-left-color:#2e7d32}.fin-inv .fin-value{color:#2e7d32}.fin-inv .fin-pct{color:#2e7d32;background:#e8f5e9}.fin-ped{border-left-color:#1565c0}.fin-ped .fin-value{color:#1565c0}.fin-ped .fin-pct{color:#1565c0;background:#e3f2fd}.fin-ext{border-left-color:#e65100}.fin-ext .fin-value{color:#e65100}.fin-ext .fin-pct{color:#e65100;background:#fff3e0}@media (max-width: 768px){.financial-indicators-bar{grid-template-columns:repeat(2,1fr);gap:8px}.fin-indicator .fin-value{font-size:14px}}.btn-filter{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--muted);font-size:13px;cursor:pointer;transition:all .15s}.btn-filter:hover,.btn-filter.active{border-color:var(--navy);color:var(--navy)}.listado-filters{display:flex;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);background:#f7f9fb}.listado-search{display:flex;align-items:center;gap:8px;flex:1;max-width:400px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--muted)}.listado-search input{border:none;outline:none;flex:1;font-size:13px;color:var(--text)}.listado-select{padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-size:13px;color:var(--text);cursor:pointer}.listado-table-wrapper{overflow-x:auto;max-height:calc(100vh - 300px);overflow-y:auto}.listado-table{width:100%;border-collapse:collapse;font-size:12px;white-space:nowrap}.listado-table thead{position:sticky;top:0;z-index:2}.listado-table thead tr{background:var(--navy);color:#fff}.listado-table th{padding:8px 6px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.02em;border-right:1px solid rgba(255,255,255,.15)}.listado-table th:last-child{border-right:none}.th-group{display:block;text-align:center;margin-bottom:2px;font-size:10px}.th-sub{display:flex;gap:2px;justify-content:center;font-size:9px;font-weight:500;opacity:.8}.th-sub span{width:28px;text-align:center}.listado-table td{padding:5px 6px;border-bottom:1px solid #F0F0F0;color:var(--text)}.listado-table tbody tr:hover{background:#f5f8fc}.listado-table tbody tr.row-checked{background:#f0f9f4}.listado-table tbody tr.row-partial{background:#fff9f0}.listado-table tbody tr.row-checked:hover{background:#e5f5ec}.col-line{width:32px;text-align:center;color:var(--muted)}.col-check{width:28px;text-align:center;padding:2px!important}.col-caja{width:44px}.col-code{width:80px}.col-desc{min-width:180px;max-width:260px;overflow:hidden;text-overflow:ellipsis}.col-desc-es{min-width:160px;max-width:240px;overflow:hidden;text-overflow:ellipsis}.col-notes{min-width:100px;max-width:200px;overflow:hidden;text-overflow:ellipsis;color:var(--muted);font-size:11px}.col-unit{width:44px;text-align:center}.col-qty{width:56px;text-align:center}.col-price{width:72px;text-align:right}.col-total{width:80px;text-align:right}.col-rsof{width:80px}.col-rsof.col-editing{background:#2563eb0f}.rsof-input{width:72px;padding:2px 4px;border:1px solid var(--border);border-radius:4px;font-family:SF Mono,Fira Code,monospace;font-size:.75rem;text-transform:uppercase;text-align:center;background:#fff;transition:border-color .15s}.rsof-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 2px #2e75b626}.col-costo{width:80px;text-align:right}.col-margen{width:64px;text-align:center}.check-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--border);cursor:pointer;border-radius:4px;transition:all .1s;padding:0}.check-btn:hover:not(:disabled){color:var(--navy);background:#1f4e7914}.check-btn.on{color:var(--green)}.check-btn:disabled{cursor:default;opacity:.5}.qty-bodega-input{width:51px;padding:3px;margin-top:2px;font-size:11px;text-align:center;border:1px solid var(--blue);border-radius:4px;background:#fff;color:var(--text);display:block}.qty-bodega-input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 2px #1f4e7926}.qty-bodega-badge{display:block;font-size:10px;text-align:center;margin-top:1px;font-weight:700;line-height:1}.qty-bodega-badge.qty-partial{color:var(--warning, #d97706)}.qty-bodega-badge.qty-ext{color:var(--red, #dc2626)}.col-check.col-editing{width:56px}.col-check.col-locked{background:repeating-linear-gradient(-45deg,transparent,transparent 3px,rgba(0,0,0,.03) 3px,rgba(0,0,0,.03) 6px)}.lock-badge{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--muted);opacity:.5}.caja-input,.qty-input,.costo-input{width:100%;padding:3px 4px;border:1px solid transparent;border-radius:4px;font-size:12px;text-align:center;background:transparent;color:var(--text);transition:border-color .15s}.caja-input:focus,.qty-input:focus,.costo-input:focus{outline:none;border-color:var(--blue);background:#fff}.caja-input:not(:disabled):hover,.qty-input:not(:disabled):hover,.costo-input:not(:disabled):hover{border-color:var(--border);background:#fff}.caja-input{max-width:40px}.qty-input{max-width:52px}.qty-input.partial{color:var(--red);font-weight:600}.costo-input{max-width:80px;text-align:right}.costo-input.costo-ok{border-color:#046c4e;background:#f0fff4}.costo-input.costo-over{border-color:var(--red);background:#fff5f5}.caja-input:disabled,.qty-input:disabled,.costo-input:disabled{cursor:default;background:transparent;color:var(--muted)}.text-translated{font-style:italic;color:#8b6914}.margen-badge{display:inline-block;padding:1px 6px;border-radius:8px;font-size:11px;font-weight:600}.margen-good{background:#def7ec;color:#046c4e}.margen-ok{background:#fef3c7;color:#92400e}.margen-low{background:#fee2e2;color:#991b1b}.listado-totals{background:#f0f4f8;font-weight:600}.listado-totals td{padding:10px 6px;border-top:2px solid var(--navy)}.totals-label{text-align:right;padding-right:12px!important;color:var(--navy);font-size:12px;letter-spacing:.05em}.listado-legend{display:flex;gap:20px;padding:10px 20px;border-top:1px solid var(--border);background:#fafbfc;font-size:12px;color:var(--muted)}.legend-item{display:flex;align-items:center;gap:6px}.legend-dot{width:10px;height:10px;border-radius:3px}.legend-checked{background:#def7ec;border:1px solid #046C4E}.legend-partial{background:#fef3c7;border:1px solid #92400E}.legend-translated{background:#fef3c7;border:1px solid #8B6914}.invoice-section{display:flex;flex-direction:column;gap:0}.invoice-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#f7f9fb;border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0}.invoice-toolbar-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);font-weight:500}.btn-print{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text);font-size:13px;cursor:pointer;transition:all .15s}.btn-print:hover{border-color:var(--navy);color:var(--navy)}.invoice-sin-precios-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280;cursor:pointer;padding:4px 10px;border:1px solid #e5e7eb;border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;transition:all .15s}.invoice-sin-precios-toggle:has(input:checked){border-color:var(--navy);color:var(--navy);background:#f0f4ff;font-weight:600}.invoice-sin-precios-toggle input{accent-color:var(--navy)}.invoice-document{background:#fff;border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:40px 48px;max-width:900px;font-family:Segoe UI,Calibri,Arial,sans-serif}.invoice-doc-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:20px;border-bottom:3px solid var(--navy);margin-bottom:24px}.invoice-logo{height:40px;width:auto;margin-bottom:8px;display:block}.invoice-company-name{font-size:18px;font-weight:700;color:var(--navy);margin:0 0 4px}.invoice-company p{margin:1px 0;font-size:12px;color:var(--muted)}.invoice-doc-type{text-align:right}.invoice-doc-type h2{font-size:24px;font-weight:700;color:var(--navy);margin:0;letter-spacing:.04em}.invoice-doc-number{display:block;font-size:12px;color:var(--muted);margin-top:4px;font-family:monospace}.invoice-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:28px}.invoice-info-block h3{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--navy);margin:0 0 8px;padding-bottom:4px;border-bottom:1px solid var(--border)}.invoice-info-rows{display:flex;flex-direction:column;gap:3px}.invoice-info-row{display:flex;gap:8px;font-size:13px}.info-label{color:var(--muted);min-width:100px}.info-value{color:var(--text)}.invoice-header-edit-btn{background:none;border:1px solid var(--border);border-radius:4px;padding:2px 6px;cursor:pointer;color:var(--muted);display:inline-flex;align-items:center;transition:all .15s}.invoice-header-edit-btn:hover{color:var(--accent);border-color:var(--accent)}.invoice-header-edit-actions{display:flex;align-items:center;gap:8px;margin-bottom:8px}.invoice-header-save-btn{background:var(--navy);color:#fff;border:none;border-radius:6px;padding:6px 14px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600}.invoice-header-save-btn:hover{opacity:.9}.invoice-header-cancel-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:6px 10px;cursor:pointer;color:var(--muted);font-size:13px;display:inline-flex;align-items:center}.invoice-header-cancel-btn:hover{color:var(--danger);border-color:var(--danger)}.invoice-header-input{flex:1;border:1px solid var(--accent);border-radius:4px;padding:2px 6px;font-size:13px;font-family:inherit;color:var(--text);background:var(--bg-card);outline:none;min-width:0}.invoice-header-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #2563eb1a}@media print{.invoice-header-edit-btn,.invoice-header-edit-actions,.invoice-header-save-btn,.invoice-header-cancel-btn{display:none!important}}.invoice-table-wrapper{margin-bottom:20px}.invoice-table{width:100%;border-collapse:collapse;font-size:12px}.invoice-table thead tr{background:var(--navy);color:#fff}.invoice-table th{padding:8px 10px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.03em}.invoice-table td{padding:6px 10px;border-bottom:1px solid #F0F0F0;color:var(--text)}.invoice-table tbody tr:nth-child(2n){background:#fafbfc}.inv-col-line{width:36px;text-align:center}.inv-col-desc{min-width:240px}.inv-col-notes{min-width:120px;color:var(--muted);font-size:11px}.inv-col-unit,.inv-col-qty{width:50px;text-align:center}.inv-col-price{width:80px;text-align:right}.inv-col-total{width:90px;text-align:right;font-weight:600}.invoice-totals{display:flex;flex-direction:column;align-items:flex-end;gap:4px;margin-bottom:32px}.invoice-totals-row{display:flex;justify-content:space-between;width:280px;padding:6px 10px;font-size:13px;color:var(--text)}.invoice-totals-row.discount{color:var(--red)}.invoice-totals-row.total{border-top:2px solid var(--navy);font-size:16px;font-weight:700;color:var(--navy);padding-top:8px;margin-top:4px}.invoice-amount{font-family:monospace;font-weight:600}.invoice-totals-row.editable{width:auto;min-width:400px}.invoice-totals-edit-group{display:flex;align-items:center;gap:6px}.inv-totals-input{width:70px!important;text-align:right}.inv-totals-select{width:auto!important;min-width:120px;font-size:11px!important;padding:3px 6px!important}.inv-add-cost-btn{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--blue);background:none;border:1px dashed var(--border);border-radius:4px;padding:4px 10px;cursor:pointer;transition:all .15s}.inv-add-cost-btn:hover{background:var(--bg-hover);border-color:var(--blue)}.invoice-totals-row.costs-type-toggle{justify-content:flex-end;margin-top:2px}.invoice-totals-row.discount-note{font-size:11px;color:var(--text-light);font-style:italic}.invoice-footer{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding-top:20px;border-top:1px solid var(--border);margin-bottom:36px}.invoice-footer h3{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--navy);margin:0 0 8px}.invoice-terms p{font-size:11px;color:var(--muted);margin:2px 0;line-height:1.5}.invoice-signatures{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding-top:24px}.invoice-sig-block{text-align:center}.invoice-sig-line{height:1px;background:var(--text);margin-bottom:6px}.invoice-sig-block span{font-size:11px;color:var(--muted)}.invoice-edit-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:8px 0;border-bottom:1px dashed var(--border)}.btn-edit-invoice{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);cursor:pointer;transition:all .15s}.btn-edit-invoice:hover{border-color:var(--navy);color:var(--navy)}.btn-edit-invoice.active{background:var(--navy);color:#fff;border-color:var(--navy)}.invoice-edit-hint{font-size:11px;color:var(--muted)}.inv-row-editable{cursor:pointer;transition:background .1s}.inv-row-editable:hover{background:#1f4e790a}.inv-row-editing{background:#1f4e790f!important}.inv-row-added{background:#10b9810a}.inv-row-adding{background:#10b9810f}.inv-edit-input{width:100%;padding:4px 6px;font-size:12px;border:1px solid var(--border);border-radius:4px;background:#fff;color:var(--text);font-family:inherit}.inv-edit-input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 2px #1f4e791a}.inv-edit-sm{width:70px;text-align:center}.inv-edit-translate{margin-top:4px;font-style:italic;color:var(--muted);font-size:11px}.inv-edit-translate::placeholder{font-style:italic}.inv-col-actions{width:60px;text-align:center;white-space:nowrap}.inv-action-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:4px;cursor:pointer;transition:all .15s;padding:0}.inv-save-btn{background:#10b9811a;color:#059669}.inv-save-btn:hover{background:#10b98133}.inv-cancel-btn{background:#6b72801a;color:#6b7280;margin-left:2px}.inv-cancel-btn:hover{background:#6b728033}.inv-delete-btn{background:#ef444414;color:#dc2626}.inv-delete-btn:hover{background:#ef444429}.inv-add-btn{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:6px 12px;font-size:12px;font-weight:500;color:var(--navy);background:#1f4e790d;border:1px dashed var(--navy);border-radius:var(--radius);cursor:pointer;transition:all .15s}.inv-add-btn:hover{background:#1f4e791a}.invoice-changelog{margin-top:16px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.invoice-changelog-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 14px;font-size:12px;font-weight:600;background:var(--bg-secondary);border:none;cursor:pointer;color:var(--text)}.invoice-changelog-list{padding:8px 14px;max-height:240px;overflow-y:auto}.changelog-entry{display:flex;align-items:baseline;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:11px;line-height:1.4}.changelog-entry:last-child{border-bottom:none}.changelog-icon{font-size:12px;flex-shrink:0}.changelog-label{font-weight:600;color:var(--navy);min-width:60px;flex-shrink:0}.changelog-item{color:var(--text);font-weight:500;flex-shrink:0}.changelog-detail{color:var(--muted);flex:1}.changelog-meta{color:var(--muted);font-size:10px;flex-shrink:0;white-space:nowrap}.changelog-eliminar .changelog-label{color:#dc2626}.changelog-agregar .changelog-label{color:#059669}.invoice-toolbar-actions{display:flex;align-items:center;gap:8px}.btn-agregar-factura{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;border:1px solid var(--navy);border-radius:var(--radius);background:#fff;color:var(--navy);cursor:pointer;transition:all .15s}.btn-agregar-factura:hover,.btn-agregar-factura.active{background:var(--navy);color:#fff}.invoice-upload-panel{border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:16px;background:var(--bg-secondary)}.invoice-upload-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:6px}.invoice-upload-hint{font-size:12px;color:var(--muted);margin:0 0 12px}.invoice-upload-form{display:flex;flex-direction:column;gap:8px}.invoice-upload-form .form-group{margin:0}.invoice-upload-form .form-input{max-width:300px}.row-deleted{opacity:.5}.row-deleted td{text-decoration:line-through;text-decoration-color:#dc2626}.row-deleted .col-line,.row-deleted .col-check,.row-deleted .col-caja,.row-deleted .col-sel{text-decoration:none}.row-added{background:#10b98108}.item-badge{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;font-size:9px;font-weight:700;border-radius:50%;margin-left:3px;vertical-align:middle}.item-badge-new{background:#10b981;color:#fff}.legend-deleted{background:#dc2626}.legend-added{background:#10b981}.invoice-factura-count{font-size:12px;color:var(--text-light);margin-left:8px;font-weight:400}.invoice-factura-tabs{display:flex;gap:6px;padding:12px 16px 0;background:#fff;border-bottom:1px solid var(--border);overflow-x:auto}.invoice-factura-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 18px;border:1px solid var(--border);border-bottom:none;border-radius:8px 8px 0 0;background:#f8fafc;cursor:pointer;transition:all .15s;min-width:140px}.invoice-factura-tab:hover{background:#eef2f7}.invoice-factura-tab.active{background:#fff;border-color:var(--navy);border-bottom:2px solid white;margin-bottom:-1px;position:relative;z-index:1}.factura-tab-po{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600;color:var(--navy)}.factura-tab-items{font-size:11px;color:var(--text-light)}.factura-tab-total{font-size:12px;font-weight:600;color:var(--text)}.factura-tab-delete{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:transparent;color:var(--text-light);cursor:pointer;transition:all .15s;margin-left:4px;flex-shrink:0}.factura-tab-delete:hover{background:#dc354520;color:#dc3545}.btn-eliminar-factura{display:flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid #dc3545;background:transparent;color:#dc3545;border-radius:6px;font-size:13px;cursor:pointer;transition:all .15s}.btn-eliminar-factura:hover{background:#dc3545;color:#fff}.modal-confirm-delete{max-width:440px}.modal-header-danger{border-bottom-color:#dc354530}.modal-header-danger h2{color:#dc3545;display:flex;align-items:center;gap:8px;font-size:18px}.confirm-delete-warning{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;background:#fff3f3;border:1px solid #dc354525;border-radius:8px;color:#dc3545}.confirm-delete-warning>div p:first-child{color:var(--text)}.btn-danger{display:flex;align-items:center;gap:6px;background:#dc3545;color:#fff;border:none;padding:8px 18px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-danger:hover{background:#c82333}.btn-danger:disabled{opacity:.6;cursor:wait}.col-po{width:56px;text-align:center}.po-tag{display:inline-block;background:#eef2f7;color:var(--navy);font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;max-width:50px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-pend{width:64px;text-align:center;position:relative}.pend-qty{display:inline-block;background:#fef3c7;color:#92400e;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;padding:2px 6px;border-radius:4px}.pend-ok{color:#059669;font-weight:700;font-size:13px}.excluido-badge{display:inline-flex;align-items:center;gap:2px;background:#fee2e2;color:#991b1b;font-size:10px;font-weight:600;padding:2px 5px;border-radius:4px}.excluir-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border:1px solid #D1D5DB;border-radius:4px;background:#fff;color:#6b7280;cursor:pointer;margin-left:4px;padding:0;transition:all .15s}.excluir-btn:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5}.excluir-btn.excluido-on{background:#dcfce7;color:#16a34a;border-color:#86efac}.excluir-btn.excluido-on:hover{background:#bbf7d0}.row-excluido td{opacity:.55}.row-excluido .col-pend{opacity:1}.excluido-lock{color:#dc2626}.col-precio-obj{width:100px;text-align:right}.precio-obj{font-size:11px;color:var(--muted);font-family:monospace}.col-sel{width:32px;text-align:center;padding:2px!important}.check-btn-header{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#fffc;cursor:pointer;padding:0}.check-btn-header:hover{color:#fff}.row-selected{background:#ebf5ff!important}.row-selected:hover{background:#dbeafe!important}.btn-emitir-oc{display:flex;align-items:center;gap:6px;padding:7px 14px;border:none;border-radius:var(--radius-sm);background:var(--navy);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-emitir-oc:hover{background:var(--blue)}.btn-packing{display:flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--green);border-radius:var(--radius-sm);background:#fff;color:var(--green);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.btn-packing:hover{background:#f0f9f4}.btn-packing-pallet{border-color:#7c3aed;color:#7c3aed}.btn-packing-pallet:hover{background:#f5f3ff}.legend-selected{background:#dbeafe;border:1px solid #2563EB}.oc-modal{max-width:780px;width:95vw}.packing-modal{max-width:680px;width:95vw}.oc-modal-body{padding:20px;max-height:60vh;overflow-y:auto}.oc-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.oc-form-field{display:flex;flex-direction:column;gap:4px}.oc-form-field.full{grid-column:1 / -1}.oc-form-field label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.oc-form-field input{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text)}.oc-form-field input:focus{outline:none;border-color:var(--blue)}.oc-info-bar{display:flex;gap:20px;padding:10px 14px;background:#f0f4f8;border-radius:var(--radius-sm);font-size:13px;color:var(--text);margin-bottom:12px}.oc-warning{padding:8px 14px;background:#fef3c7;border:1px solid #F59E0B;border-radius:var(--radius-sm);font-size:13px;color:#92400e;margin-bottom:12px}.oc-items-preview{max-height:300px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}.oc-preview-table{width:100%;border-collapse:collapse;font-size:12px}.oc-preview-table thead tr{background:#f0f4f8}.oc-preview-table th{padding:6px 8px;text-align:left;font-weight:600;font-size:11px;color:var(--navy);border-bottom:1px solid var(--border)}.oc-preview-table td{padding:5px 8px;border-bottom:1px solid #F0F0F0}.oc-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border);background:#fafbfc}.btn-secondary{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.btn-secondary:hover{border-color:var(--navy);color:var(--navy)}.oc-tracking-panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}.oc-tracking-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;background:#f8fafc;border-bottom:1px solid var(--border);transition:background .15s}.oc-tracking-header:hover{background:#f0f4f8}.oc-tracking-title{display:flex;align-items:center;gap:8px}.oc-tracking-title h3{font-size:14px;font-weight:600;color:var(--navy);margin:0}.oc-tracking-count{background:var(--navy);color:#fff;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.oc-tracking-summary{display:flex;align-items:center;gap:12px}.oc-tracking-total{font-size:13px;font-weight:600;color:var(--text)}.oc-status-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:10px}.badge-emitida{background:#fef3c7;color:#92400e}.badge-recibida{background:#d1fae5;color:#065f46}.oc-tracking-body{padding:12px 16px;display:flex;flex-direction:column;gap:10px}.oc-card{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:box-shadow .15s}.oc-card:hover{box-shadow:0 2px 8px #0000000f}.oc-card-emitida{border-left:3px solid #F59E0B}.oc-card-recibida{border-left:3px solid #10B981}.oc-card-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;background:#fff;transition:background .1s}.oc-card-header:hover{background:#fafbfc}.oc-card-info{display:flex;align-items:center;gap:12px}.oc-card-numero{font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600;color:var(--navy)}.oc-card-proveedor{font-size:13px;color:var(--text);font-weight:500}.oc-card-meta{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--text-light)}.oc-card-items{color:var(--text-light)}.oc-card-total{font-weight:600;color:var(--text)}.oc-card-detail{border-top:1px solid var(--border);padding:14px;background:#fafbfc}.oc-detail-row{font-size:12px;color:var(--text);margin:4px 0}.oc-detail-row .info-label{color:var(--text-light);margin-right:4px}.oc-recepcion-info{background:#d1fae5;border-radius:var(--radius-sm);padding:8px 12px;margin:8px 0}.oc-recepcion-info .oc-detail-row{color:#065f46}.oc-detail-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:10px}.oc-detail-table th{background:#e8eef4;color:var(--navy);padding:6px 8px;text-align:left;font-weight:600;font-size:11px}.oc-detail-table td{padding:5px 8px;border-bottom:1px solid #F0F0F0}.oc-card-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.btn-sm{padding:5px 12px!important;font-size:12px!important}.recepcion-ok{color:#065f46;font-weight:600;font-size:12px}.recepcion-parcial{color:#dc2626;font-weight:600;font-size:12px}.recepcion-extra{color:#2563eb;font-weight:600;font-size:12px}@media print{.invoice-toolbar,.detail-header,.detail-tabs,.detail-title-row,.detail-back-btn,.app-header,.sidebar,.sidebar-overlay,.notif-error-toast,.detail-card:not(.invoice-card),.detail-grid,.detail-summary,.detail-section:not(.invoice-section){display:none!important}html,body{margin:0!important;padding:0!important}.app-layout,.app-body,.app-main,.page{margin:0!important;padding:0!important;overflow:visible!important}.invoice-document{border:none;padding:20px;max-width:100%;box-shadow:none}.invoice-totals-row.discount-note{display:none!important}.invoice-table tr{page-break-inside:avoid}}.trm-page{max-width:700px;margin:0 auto}.trm-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px}.trm-header-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#1f4e79,#2a6db0);color:#fff;flex-shrink:0}.trm-title{font-size:22px;font-weight:700;color:var(--navy);margin:0 0 4px}.trm-subtitle{font-size:13px;color:var(--text-light);margin:0;line-height:1.5}.trm-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px}.trm-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px}.trm-card-main{border-left:3px solid var(--navy)}.trm-card-ref{border-left:3px solid #9CA3AF}.trm-card-label{font-size:12px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.trm-card-value{display:flex;align-items:baseline;gap:4px;margin-bottom:10px}.trm-currency{font-size:18px;color:var(--text-light)}.trm-amount{font-size:28px;font-weight:700;color:var(--navy);font-family:JetBrains Mono,monospace}.trm-card-ref .trm-amount{color:var(--text)}.trm-unit{font-size:12px;color:var(--text-light);margin-left:4px}.trm-card-meta{display:flex;flex-direction:column;gap:4px}.trm-card-meta span{font-size:11px;color:var(--text-light);display:flex;align-items:center;gap:4px}.trm-form-section{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px}.trm-form-title{font-size:16px;font-weight:600;color:var(--navy);margin:0 0 6px}.trm-form-desc{font-size:13px;color:var(--text-light);margin:0 0 16px}.trm-form{display:flex;gap:12px;align-items:center}.trm-input-group{display:flex;align-items:center;border:2px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;flex:1;transition:border-color .15s}.trm-input-group:focus-within{border-color:var(--navy)}.trm-input-prefix,.trm-input-suffix{padding:10px 12px;background:#f8fafc;font-size:14px;color:var(--text-light);font-weight:500;white-space:nowrap}.trm-input{flex:1;border:none;padding:10px 14px;font-size:20px;font-weight:600;font-family:JetBrains Mono,monospace;color:var(--navy);outline:none;min-width:0}.trm-input::-webkit-outer-spin-button,.trm-input::-webkit-inner-spin-button{-webkit-appearance:none}.trm-btn{padding:12px 20px!important;font-size:14px!important;white-space:nowrap}.trm-btn-saved{background:#10b981!important;border-color:#10b981!important}.trm-info-note{background:#fffbeb;border:1px solid #FDE68A;border-radius:var(--radius-sm);padding:12px 16px;font-size:12px;color:#92400e;line-height:1.5}.trm-info-note strong{color:#78350f}.financiero-page{padding:24px;max-width:1400px;margin:0 auto}.financiero-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:16px}.financiero-title{display:flex;align-items:center;gap:10px;font-size:22px;font-weight:700;color:var(--navy);margin:0}.financiero-subtitle{color:var(--muted);font-size:13px;margin:4px 0 0}.financiero-vista-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.fin-toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:#fff;color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.fin-toggle-btn:not(:last-child){border-right:1px solid var(--border)}.fin-toggle-btn.active{background:var(--navy);color:#fff}.fin-toggle-btn:hover:not(.active){background:var(--bg-subtle, #f8f9fb)}.financiero-totales{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.fin-total-card{display:flex;flex-direction:column;gap:4px;padding:16px 20px;border-radius:var(--radius);background:#fff;border:1px solid var(--border);border-left:4px solid var(--border);position:relative}.fin-total-card svg{position:absolute;top:16px;right:16px;color:var(--muted);opacity:.4}.fin-total-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.fin-total-value{font-size:20px;font-weight:700;font-variant-numeric:tabular-nums}.fin-total-count{font-size:11px;color:var(--muted)}.fin-total-pct{font-size:12px;font-weight:600;color:var(--muted)}.fin-total-presupuesto{border-left-color:var(--navy)}.fin-total-presupuesto .fin-total-value{color:var(--navy)}.fin-total-inv{border-left-color:#2e7d32}.fin-total-inv .fin-total-value{color:#2e7d32}.fin-total-ped{border-left-color:#1565c0}.fin-total-ped .fin-total-value{color:#1565c0}.fin-total-ext{border-left-color:#e65100}.fin-total-ext .fin-total-value{color:#e65100}.financiero-search-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.financiero-search-input{display:flex;align-items:center;gap:8px;flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff}.financiero-search-input input{border:none;outline:none;flex:1;font-size:13px;background:transparent}.fin-clear-search{border:none;background:none;cursor:pointer;color:var(--muted);padding:2px}.financiero-result-count{font-size:12px;color:var(--muted);white-space:nowrap}.financiero-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:#fff}.financiero-table{width:100%;border-collapse:collapse;font-size:13px}.financiero-table thead{background:var(--bg-subtle, #f8f9fb)}.financiero-table th{padding:10px 14px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap}.fin-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.fin-th-sortable:hover{color:var(--navy)}.fin-th-right{text-align:right!important}.fin-th-center{text-align:center!important}.financiero-table td{padding:10px 14px;border-bottom:1px solid var(--border-light, #f0f0f0);vertical-align:middle}.fin-row:hover{background:var(--bg-subtle, #f8f9fb)}.fin-cell-vessel{display:flex;align-items:center;gap:6px;font-weight:600;color:var(--navy)}.fin-cell-cc{font-family:monospace;font-size:12px;color:var(--muted)}.fin-cell-date{font-size:12px;color:var(--text)}.fin-cell-money{text-align:right;font-variant-numeric:tabular-nums;font-weight:500}.fin-cell-presupuesto{font-weight:700;color:var(--navy)}.fin-cell-inv{color:#2e7d32}.fin-cell-ped{color:#1565c0}.fin-cell-ext{color:#e65100}.fin-cell-count{text-align:center;color:var(--muted)}.fin-btn-ver{display:flex;align-items:center;justify-content:center;padding:6px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--muted);cursor:pointer;transition:all .15s}.fin-btn-ver:hover{border-color:var(--navy);color:var(--navy)}.fin-empty{text-align:center;padding:40px 20px!important;color:var(--muted);font-style:italic}@media (max-width: 768px){.financiero-totales{grid-template-columns:repeat(2,1fr)}.financiero-header{flex-direction:column}.fin-total-value{font-size:16px}}.fondos-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.fondos-popup{background:#fff;border-radius:12px;width:480px;max-width:90vw;box-shadow:0 20px 60px #0003;overflow:hidden;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.fondos-popup-header{background:linear-gradient(135deg,#d97706,#b45309);color:#fff;padding:20px 24px;display:flex;align-items:center;gap:12px}.fondos-popup-header h3{margin:0;font-size:18px;font-weight:600}.fondos-popup-body{padding:24px}.fondos-msg{margin:0 0 16px;font-size:14px;color:#555;line-height:1.5}.fondos-valor{background:#fffbeb;border:2px solid #d97706;border-radius:8px;padding:16px;text-align:center;margin-bottom:20px}.fondos-valor-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#92400e;margin-bottom:4px}.fondos-valor-amount{display:block;font-size:28px;font-weight:700;color:#d97706}.fondos-detail{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.fondos-detail-row{display:flex;justify-content:space-between;font-size:13px;padding:6px 0;border-bottom:1px solid #f0f0f0}.fondos-detail-row span{color:#888}.fondos-detail-row strong{color:#1a1a1a}.fondos-note{display:flex;align-items:center;gap:8px;font-size:12px;color:#888;background:#f9fafb;border-radius:6px;padding:10px 12px;margin:0}.fondos-popup-actions{display:flex;gap:12px;padding:16px 24px;background:#f9fafb;border-top:1px solid #e5e7eb}.btn-fondos-cancel{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#555;font-size:13px;cursor:pointer;transition:background .2s}.btn-fondos-cancel:hover{background:#f3f4f6}.btn-fondos-confirm{flex:2;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:none;border-radius:6px;background:linear-gradient(135deg,#d97706,#b45309);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-fondos-confirm:hover{opacity:.9}.step-pdf-btn{position:absolute;bottom:-2px;right:16px;background:#d97706;color:#fff;border:2px solid white;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:10px;transition:transform .2s}.step-pdf-btn:hover{transform:scale(1.15);background:#b45309}.fondos-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.3px}.fondos-badge-confirmed{background:#dcfce7;color:#166534;border:1px solid #86efac}.fondos-badge-pending{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.step-camera-btn{position:absolute;bottom:-2px;left:16px;background:#2563eb;color:#fff;border:2px solid white;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s}.step-camera-btn:hover{transform:scale(1.15);background:#1d4ed8}.step-camera-badge{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;font-size:9px;font-weight:700;border-radius:50%;width:14px;height:14px;display:flex;align-items:center;justify-content:center}.editing-bar-camera{display:inline-flex;align-items:center;gap:4px;margin-left:12px;padding:4px 10px;background:#fff3;border:1px solid rgba(255,255,255,.4);border-radius:4px;color:inherit;font-size:12px;cursor:pointer;transition:background .2s}.editing-bar-camera:hover{background:#ffffff4d}.fotodoc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:stretch;justify-content:flex-end;z-index:1100;animation:fadeIn .2s ease}.fotodoc-panel{background:#fff;width:440px;max-width:100vw;display:flex;flex-direction:column;box-shadow:-4px 0 30px #00000026;animation:slideInRight .3s ease;position:relative}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@media (max-width: 600px){.fotodoc-panel{width:100vw}}.fotodoc-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb;background:#1a1a1a;color:#fff}.fotodoc-header-left{display:flex;align-items:center;gap:12px}.fotodoc-header-left h3{margin:0;font-size:16px;font-weight:600}.fotodoc-subtitle{font-size:12px;color:#9ca3af}.fotodoc-header-right{display:flex;align-items:center;gap:8px}.fotodoc-btn-report{display:flex;align-items:center;gap:4px;padding:6px 12px;background:transparent;border:1px solid rgba(255,255,255,.3);border-radius:4px;color:#fff;font-size:12px;cursor:pointer;transition:background .2s}.fotodoc-btn-report:hover{background:#ffffff1a}.fotodoc-btn-close{background:none;border:none;color:#fff;cursor:pointer;padding:4px;opacity:.7;transition:opacity .2s}.fotodoc-btn-close:hover{opacity:1}.fotodoc-tabs{display:flex;border-bottom:1px solid #e5e7eb}.fotodoc-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;background:#fff;border:none;border-bottom:2px solid transparent;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.fotodoc-tab.active{color:#2563eb;border-bottom-color:#2563eb}.fotodoc-tab:hover:not(.active){background:#f9fafb}.fotodoc-tab-badge{background:#2563eb;color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px}.fotodoc-body{flex:1;overflow-y:auto;padding:0}.fotodoc-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#9ca3af;text-align:center}.fotodoc-empty p{margin:12px 0 4px;font-size:15px;font-weight:500;color:#6b7280}.fotodoc-empty span{font-size:13px}.fotodoc-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:20px;color:#6b7280;font-size:14px}.fotodoc-loading .spin,.fotodoc-btn-save .spin{animation:fotodoc-spin 1s linear infinite}@keyframes fotodoc-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fotodoc-error{padding:12px 16px;margin:8px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:13px}.fotodoc-caja-list{display:flex;flex-direction:column}.fotodoc-caja-card{border-bottom:1px solid #f0f0f0}.fotodoc-caja-card.selected{background:#f0f7ff}.fotodoc-caja-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;cursor:pointer;transition:background .15s}.fotodoc-caja-header:hover{background:#f9fafb}.fotodoc-caja-title{display:flex;align-items:center;gap:8px;font-size:14px}.fotodoc-caja-count{font-size:12px;color:#9ca3af}.fotodoc-caja-badges{display:flex;align-items:center;gap:8px}.fotodoc-foto-count{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:#2563eb;background:#eff6ff;padding:2px 8px;border-radius:10px}.fotodoc-caja-detail{padding:0 20px 16px}.fotodoc-caja-items{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #e5e7eb;font-size:12px}.fotodoc-caja-item{display:flex;align-items:center;gap:8px;padding:3px 0}.fotodoc-item-num{font-size:11px;color:#9ca3af;font-weight:600;min-width:28px}.fotodoc-item-name{flex:1;color:#374151}.fotodoc-item-qty{font-size:11px;font-weight:600;color:#6b7280}.fotodoc-thumbs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.fotodoc-thumb{position:relative;width:72px;height:72px;border-radius:6px;overflow:hidden;border:2px solid #e5e7eb;cursor:pointer;transition:border-color .2s}.fotodoc-thumb:hover{border-color:#2563eb}.fotodoc-thumb img{width:100%;height:100%;object-fit:cover}.fotodoc-thumb-delete{position:absolute;top:2px;right:2px;background:#ef4444e6;color:#fff;border:none;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s}.fotodoc-thumb:hover .fotodoc-thumb-delete{opacity:1}@media (max-width: 768px){.fotodoc-thumb-delete{opacity:.85!important}}.fotodoc-thumb-comment{position:absolute;bottom:2px;left:2px;background:#0009;color:#fff;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.fotodoc-btn-capture{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.fotodoc-btn-capture:hover{background:#1d4ed8}.fotodoc-search{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.fotodoc-search input{flex:1;border:none;background:none;font-size:14px;outline:none}.fotodoc-search button{background:none;border:none;color:#9ca3af;cursor:pointer}.fotodoc-item-list{display:flex;flex-direction:column}.fotodoc-item-card{padding:10px 20px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .15s}.fotodoc-item-card:hover{background:#f9fafb}.fotodoc-item-card.selected{background:#f0f7ff}.fotodoc-item-row{display:flex;align-items:center;gap:10px}.fotodoc-item-info{flex:1;min-width:0}.fotodoc-item-info .fotodoc-item-name{display:block;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fotodoc-item-detail{font-size:11px;color:#9ca3af}.fotodoc-item-actions{display:flex;align-items:center}.fotodoc-item-expanded{padding:10px 0 4px}.fotodoc-footer{border-top:1px solid #e5e7eb;padding:10px 20px;background:#f9fafb}.fotodoc-footer-toggle{display:flex;align-items:center;gap:6px;background:none;border:none;color:#6b7280;font-size:12px;cursor:pointer;width:100%;justify-content:center}.fotodoc-preview-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10;padding:20px}.fotodoc-preview-panel{background:#fff;border-radius:12px;width:100%;max-width:380px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.fotodoc-preview-img{background:#000;display:flex;align-items:center;justify-content:center;max-height:280px;overflow:hidden}.fotodoc-preview-img img{width:100%;max-height:280px;object-fit:contain}.fotodoc-preview-info{padding:16px}.fotodoc-preview-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#eff6ff;color:#2563eb;border-radius:6px;font-size:12px;font-weight:600;margin-bottom:12px}.fotodoc-preview-comment{width:100%;padding:10px;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;resize:none;font-family:inherit;outline:none}.fotodoc-preview-comment:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.fotodoc-preview-actions{display:flex;gap:10px;padding:12px 16px;background:#f9fafb;border-top:1px solid #e5e7eb}.fotodoc-btn-cancel{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#555;font-size:13px;cursor:pointer}.fotodoc-btn-cancel:hover{background:#f3f4f6}.fotodoc-btn-save{flex:2;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border:none;border-radius:6px;background:#2563eb;color:#fff;font-size:13px;font-weight:600;cursor:pointer}.fotodoc-btn-save:hover{background:#1d4ed8}.fotodoc-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1200;padding:20px}.fotodoc-viewer{position:relative;max-width:90vw;max-height:90vh}.fotodoc-viewer img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px}.fotodoc-viewer-info{position:absolute;bottom:-40px;left:0;right:0;text-align:center;color:#fff;font-size:12px}.fotodoc-viewer-info p{margin:4px 0;font-style:italic}.fotodoc-viewer-time{display:inline-flex;align-items:center;gap:4px;opacity:.7}.fotodoc-viewer-close{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;cursor:pointer;opacity:.7;transition:opacity .2s}.fotodoc-viewer-close:hover{opacity:1}.fotodoc-item-check{background:none;border:none;padding:0;cursor:pointer;color:#d1d5db;flex-shrink:0;display:flex;align-items:center}.fotodoc-item-check.checked{color:#2563eb}.fotodoc-check-empty{display:block;width:18px;height:18px;border:2px solid #d1d5db;border-radius:50%;transition:border-color .15s}.fotodoc-item-card:hover .fotodoc-check-empty{border-color:#9ca3af}.fotodoc-item-card.selected .fotodoc-item-name{color:#2563eb;font-weight:600}.fotodoc-item-thumbs-inline{display:flex;gap:6px;padding:6px 0 2px 28px;flex-wrap:wrap}.fotodoc-thumb-mini{position:relative;width:44px;height:44px;border-radius:4px;overflow:hidden;border:1px solid #e5e7eb;cursor:pointer}.fotodoc-thumb-mini img{width:100%;height:100%;object-fit:cover}.fotodoc-thumb-multi{position:absolute;bottom:1px;right:1px;background:#2563ebe6;color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:3px}.fotodoc-capture-bar{position:sticky;bottom:0;background:#fff;border-top:2px solid #2563eb;padding:12px 20px;box-shadow:0 -4px 12px #00000014;z-index:5}.fotodoc-capture-bar-info{display:flex;align-items:center;gap:6px;font-size:12px;color:#2563eb;margin-bottom:10px}.fotodoc-capture-bar-clear{display:inline-flex;align-items:center;gap:3px;margin-left:auto;background:none;border:1px solid #d1d5db;border-radius:4px;padding:2px 8px;font-size:11px;color:#6b7280;cursor:pointer}.fotodoc-capture-bar-clear:hover{background:#f3f4f6}.fotodoc-preview-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.fotodoc-preview-tags .fotodoc-preview-tag{margin-bottom:0;font-size:11px;padding:3px 8px}.config-page{max-width:1400px}.config-tabs{display:flex;gap:4px;overflow-x:auto;padding-bottom:2px;margin-bottom:16px;border-bottom:2px solid var(--border)}.config-tab{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:none;border:none;border-bottom:3px solid transparent;font-size:13px;font-family:inherit;font-weight:500;color:var(--muted);cursor:pointer;white-space:nowrap;transition:all .2s;margin-bottom:-2px}.config-tab:hover{color:var(--navy);background:#1f4e790a}.config-tab--active{color:var(--navy);border-bottom-color:var(--navy);font-weight:600}.config-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--gray);border-radius:10px;font-size:11px;font-weight:600;color:var(--muted)}.config-tab--active .config-tab-count{background:var(--light);color:var(--navy)}.config-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.config-search-wrap{flex:1;display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--muted)}.config-search{flex:1;border:none;outline:none;font-size:13px;font-family:inherit;background:transparent;color:var(--text)}.config-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}.config-table{width:100%;border-collapse:collapse;font-size:13px}.config-table thead{background:var(--bg-header);position:sticky;top:0;z-index:1}.config-th{padding:10px 14px;text-align:left;font-weight:600;color:var(--navy);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.config-th:hover{background:#1f4e790f}.config-th span{margin-right:4px}.config-th-num{padding:10px 12px;text-align:center;width:48px;font-weight:600;color:var(--muted)}.config-th-actions{padding:10px 12px;text-align:center;width:100px;font-weight:600;color:var(--navy)}.config-table tbody tr{border-top:1px solid var(--border);transition:background .15s}.config-table tbody tr:hover{background:#1f4e7905}.config-table td{padding:8px 14px;vertical-align:middle}.config-td-num{text-align:center;color:var(--muted);font-size:12px}.config-td-actions{text-align:center;display:flex;align-items:center;justify-content:center;gap:4px}.config-row-editing{background:#fffde7!important}.config-row-new{background:#e8f5e9!important}.config-new-badge{display:inline-block;padding:2px 6px;background:var(--green);color:#fff;font-size:10px;font-weight:700;border-radius:4px;letter-spacing:.5px}.config-input{width:100%;padding:6px 8px;border:1px solid var(--blue);border-radius:4px;font-size:13px;font-family:inherit;background:#fff;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s}.config-input:focus{border-color:var(--navy);box-shadow:0 0 0 2px #1f4e7926}.config-input-num{width:90px;text-align:right}.config-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:6px;cursor:pointer;transition:all .2s;background:transparent}.config-btn-edit{color:var(--blue)}.config-btn-edit:hover{background:var(--light);color:var(--navy)}.config-btn-delete{color:#999}.config-btn-delete:hover{background:#fde8e8;color:var(--red)}.config-btn-save{color:var(--green)}.config-btn-save:hover{background:#e8f5e9}.config-btn-cancel{color:var(--muted)}.config-btn-cancel:hover{background:var(--gray);color:var(--text)}.config-estado{display:inline-block;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.3px}.estado-activo{background:#e8f5e9;color:#2e7d32}.estado-inactivo{background:#fde8e8;color:var(--red)}.import-usuario-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:280px;background:var(--card);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #0000001f;z-index:100;overflow:hidden}.import-usuario-option{display:flex;flex-direction:column;gap:2px;width:100%;padding:10px 14px;border:none;background:none;text-align:left;cursor:pointer;transition:background .12s;font-size:13px}.import-usuario-option:hover{background:var(--hover)}.config-empty{text-align:center;padding:40px 20px!important;color:var(--muted);font-style:italic}.config-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.config-modal{background:var(--bg-card);border-radius:var(--radius);padding:32px;max-width:420px;width:90%;text-align:center;box-shadow:0 12px 40px #0003}.config-modal-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:#fff3e0;color:#e65100;margin-bottom:16px}.config-modal h3{font-size:18px;color:var(--text);margin-bottom:8px}.config-modal p{font-size:14px;margin-bottom:6px}.config-modal-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}.config-btn-confirm-delete{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--red);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}.config-btn-confirm-delete:hover{background:#a00000}@media (max-width: 768px){.config-tabs{gap:2px}.config-tab{padding:8px 10px;font-size:12px}.config-tab span,.config-tab-count{display:none}.config-toolbar{flex-direction:column;gap:8px}.config-toolbar .btn-primary{width:100%;justify-content:center}}.permisos-editor-dropdown{position:absolute;z-index:100;background:var(--card-bg, #fff);border:1px solid var(--border-color, #d0d7de);border-radius:8px;box-shadow:0 4px 12px #00000026;padding:8px;width:260px;max-height:320px;overflow-y:auto}.permisos-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.permisos-editor-list{display:flex;flex-direction:column;gap:2px}.permisos-item{display:flex;align-items:center;gap:6px;padding:3px 4px;border-radius:4px;cursor:pointer;-webkit-user-select:none;user-select:none}.permisos-item:hover{background:var(--hover-bg, #f3f4f6)}.permisos-badge{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:4px;font-size:12px;font-weight:700;flex-shrink:0}.perm-granted{background:#dcfce7;color:#16a34a}.perm-denied{background:#fee2e2;color:#dc2626}.perm-default{background:#f3f4f6;color:#9ca3af}.btn-nuevo-buque{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;margin-top:4px;background:none;color:var(--accent, #2563eb);border:1px dashed var(--accent, #2563eb);border-radius:var(--radius-sm, 6px);font-size:12px;font-family:inherit;cursor:pointer;transition:all .2s}.btn-nuevo-buque:hover{background:#2563eb0f;border-style:solid}.nuevo-buque-panel{margin-top:8px;padding:12px;background:#f0f7ff;border:1px solid #bfdbfe;border-radius:var(--radius-sm, 6px)}.nuevo-buque-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.nuevo-buque-header h4{margin:0;font-size:13px;font-weight:600;color:var(--navy, #1e3a5f)}.nuevo-buque-header span{flex:1;margin-left:6px;font-size:13px;font-weight:600;color:var(--navy, #1e3a5f)}.nuevo-buque-close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:none;border:none;border-radius:4px;cursor:pointer;color:var(--text-muted, #6b7280);transition:all .15s}.nuevo-buque-close:hover{background:#dbeafe;color:var(--navy, #1e3a5f)}.nuevo-buque-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.nuevo-buque-field label{display:block;font-size:11px;font-weight:600;color:var(--text-muted, #6b7280);margin-bottom:3px;text-transform:uppercase;letter-spacing:.3px}.nuevo-buque-field input{width:100%;padding:6px 8px;font-size:13px;font-family:inherit;border:1px solid var(--border, #d1d5db);border-radius:4px;background:#fff;transition:border-color .15s}.nuevo-buque-field input:focus{outline:none;border-color:var(--accent, #2563eb);box-shadow:0 0 0 2px #2563eb1a}.btn-confirmar-buque{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--accent, #2563eb);color:#fff;border:none;border-radius:var(--radius-sm, 6px);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}.btn-confirmar-buque:hover{background:#1d4ed8}.btn-confirmar-buque:disabled{opacity:.5;cursor:not-allowed}.nuevo-buque-notif-section{margin-top:8px;padding-top:8px;border-top:1px solid #bfdbfe;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.nuevo-buque-notif-label{font-size:11px;font-weight:600;color:var(--navy, #1e3a5f);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.nuevo-buque-notif-chips{display:flex;flex-wrap:wrap;gap:4px}.notif-chip-toggle{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:#fff;border:1px solid #bfdbfe;border-radius:4px;font-size:11px;font-family:inherit;color:var(--muted, #6b7280);cursor:pointer;transition:all .15s}.notif-chip-toggle:hover{border-color:var(--blue, #2E75B6)}.notif-chip-toggle.active{background:#dbeafe;border-color:var(--blue, #2E75B6);color:var(--navy, #1e3a5f);font-weight:600}.buque-notif-crm{margin-top:10px;padding:8px 10px;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-sm, 6px);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.buque-notif-crm-label{font-size:11px;font-weight:600;color:#92400e;white-space:nowrap}.buque-notif-crm-chips{display:flex;flex-wrap:wrap;gap:4px}.buque-notif-chip{font-size:10px;padding:2px 6px;border-radius:3px;background:#fff;border:1px solid #fde68a;color:#78350f}.buque-notif-chip.on{background:#fef3c7;font-weight:600}.buque-notif-chip.off{opacity:.5;text-decoration:line-through}@media (max-width: 600px){.nuevo-buque-fields{grid-template-columns:1fr}.nuevo-buque-notif-section{flex-direction:column;align-items:flex-start}}.col-qty-final{min-width:70px;max-width:90px;text-align:center}.listado-table thead .col-qty-final,.listado-table thead .col-caja{background:#fbbf24;color:#000;font-weight:700}.col-qty-final.col-editing{background:#a855f70f}.col-qty-final .qty-input{width:60px;text-align:center}.col-qty-final .qty-input.partial,.qty-diff{color:#dc2626;font-weight:600}.editing-rec{background:linear-gradient(135deg,#f5f3ff,#ede9fe)!important;border-color:#a855f7!important}.editing-rec .editing-bar-label{color:#7c3aed}.kpi-sc-page{padding:24px;max-width:1400px;margin:0 auto}.kpi-sc-header{margin-bottom:20px}.kpi-sc-title-row{display:flex;align-items:center;gap:10px;color:var(--navy)}.kpi-sc-title-row h1{font-size:1.5rem;font-weight:700;margin:0}.kpi-sc-subtitle{color:var(--muted);font-size:.85rem;margin-top:4px}.kpi-sc-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.kpi-sc-card{display:flex;align-items:center;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.kpi-sc-card-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;flex-shrink:0}.kpi-sc-card-value{font-size:1.15rem;font-weight:700;color:var(--text)}.kpi-sc-card-label{font-size:.75rem;color:var(--muted)}.kpi-sc-card-quadrants{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0!important;overflow:hidden}.kpi-sc-quadrant{padding:8px 10px}.kpi-sc-quadrant-low{background:#f0fdf4;border-right:1px solid #e5e7eb;border-radius:10px 0 0 10px}.kpi-sc-quadrant-high{background:#fef2f2;border-radius:0 10px 10px 0}.kpi-sc-quadrant-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;margin-bottom:4px}.kpi-sc-quadrant-low .kpi-sc-quadrant-title{color:#375623}.kpi-sc-quadrant-high .kpi-sc-quadrant-title{color:#c00000}.kpi-sc-quadrant-row{display:flex;justify-content:space-between;align-items:center}.kpi-sc-quadrant-row .font-mono{font-size:.75rem;font-weight:600;color:var(--navy)}.kpi-sc-quadrant-pct{font-weight:700;font-size:.78rem}.kpi-sc-quadrant-pct.low{color:#375623}.kpi-sc-quadrant-pct.high{color:#c00000}.kpi-sc-quadrant-name{font-size:.65rem;color:var(--muted);margin-top:1px}.kpi-sc-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.kpi-sc-filter-group{display:flex;align-items:center;gap:6px;color:var(--muted)}.kpi-sc-select{padding:5px 8px;border:1px solid var(--border);border-radius:6px;font-size:.8rem;background:#fff}.kpi-sc-search{padding:5px 10px;border:1px solid var(--border);border-radius:6px;font-size:.8rem;width:200px}.kpi-sc-search:focus,.kpi-sc-select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 2px #2e75b626}.kpi-sc-sort-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;background:#fff;cursor:pointer;font-weight:600;display:flex;align-items:center;justify-content:center}.kpi-sc-sort-btn:hover{background:var(--gray)}.kpi-sc-empty{text-align:center;padding:60px 20px;color:var(--muted)}.kpi-sc-empty p{margin:8px 0}.kpi-sc-table-wrap{overflow-x:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:10px}.kpi-sc-table{width:100%;border-collapse:collapse;font-size:.82rem}.kpi-sc-table thead th{background:var(--bg-header);padding:10px 12px;text-align:left;font-weight:600;color:var(--navy);border-bottom:2px solid var(--border);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.kpi-sc-table tbody td{padding:8px 12px;border-bottom:1px solid #f0f0f0}.kpi-sc-row{cursor:pointer;transition:background .15s}.kpi-sc-row:hover{background:#f8fafc}.kpi-sc-row.expanded{background:#ebf5ff}.kpi-sc-table .col-expand{width:32px;text-align:center;color:var(--muted)}.kpi-sc-table .col-code{min-width:100px;font-weight:600;color:var(--navy)}.kpi-sc-table .col-name{min-width:160px}.kpi-sc-table .col-qty{text-align:center;min-width:70px}.kpi-sc-table .col-price{text-align:right;min-width:100px}.kpi-sc-table .col-spread{text-align:center;min-width:80px}.kpi-sc-table .col-orders{text-align:center;min-width:60px}.kpi-sc-table .col-total{text-align:right;min-width:110px}.spread-badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:.75rem;font-weight:600}.spread-ok{background:#f0fdf4;color:#375623}.spread-high{background:#fef2f2;color:#c00000}.kpi-sc-detail-row td{padding:0!important;background:#fafbfd}.kpi-sc-detail{padding:12px 16px 16px;margin:0 12px 8px;background:#fff;border:1px solid var(--border);border-radius:8px}.kpi-sc-detail-header{display:flex;align-items:center;gap:6px;margin-bottom:10px;font-size:.82rem;color:var(--navy)}.kpi-sc-detail-table{width:100%;border-collapse:collapse;font-size:.78rem}.kpi-sc-detail-table thead th{background:var(--bg-header);padding:6px 10px;text-align:left;font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);border-bottom:1px solid var(--border)}.kpi-sc-detail-table tbody td{padding:6px 10px;border-bottom:1px solid #f5f5f5}.kpi-sc-detail-table .text-center{text-align:center}.kpi-sc-detail-table .text-right{text-align:right}@media (max-width: 768px){.kpi-sc-page{padding:12px}.kpi-sc-cards{grid-template-columns:1fr}.kpi-sc-filters{flex-direction:column;align-items:stretch}.kpi-sc-search{width:100%}}.cotizador-launch{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 56px);padding:32px 16px;background:var(--bg-secondary, #F8FAFC)}.cotizador-launch__card{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;padding:48px 40px;max-width:420px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.cotizador-launch__icon{color:var(--navy, #1F4E79);margin-bottom:4px}.cotizador-launch__title{font-size:24px;font-weight:700;color:var(--navy, #1F4E79);margin:0}.cotizador-launch__subtitle{font-size:13px;font-weight:500;color:var(--muted, #6B7280);letter-spacing:.3px;margin:0}.cotizador-launch__desc{font-size:14px;color:#4b5563;line-height:1.6;margin:8px 0 4px}.cotizador-launch__btn{display:inline-flex;align-items:center;gap:8px;background:var(--navy, #1F4E79);color:#fff;border-radius:8px;padding:12px 28px;font-size:15px;font-weight:600;text-decoration:none;margin-top:8px;transition:background .15s}.cotizador-launch__btn:hover{background:#163960}.cotizador-launch__note{font-size:11px;color:#9ca3af;margin-top:4px}.notif-destinatarios-field{position:relative}.notif-chips-container{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-height:42px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);cursor:text}.notif-chips-container:focus-within{border-color:var(--navy);box-shadow:0 0 0 2px #1f4e791f}.notif-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 6px 3px 10px;background:#e8f0fe;border:1px solid #c4d9f2;border-radius:16px;font-size:12px;color:var(--navy);white-space:nowrap}.notif-chip-name{font-weight:600}.notif-chip-rol{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.notif-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:50%;padding:0;transition:background .15s,color .15s}.notif-chip-remove:hover{background:#d1423f;color:#fff}.notif-search-input{flex:1;min-width:180px;border:none;outline:none;background:transparent;font-size:13px;color:var(--text);padding:4px 0}.notif-search-input::placeholder{color:var(--muted)}.notif-sugerencias-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 4px 16px #0000001f;max-height:220px;overflow-y:auto;margin-top:2px}.notif-sugerencia-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:background .1s}.notif-sugerencia-item:last-child{border-bottom:none}.notif-sugerencia-item:hover{background:#f0f5ff}.notif-sugerencia-info{display:flex;flex-direction:column;gap:1px}.notif-sugerencia-nombre{font-weight:600;font-size:13px;color:var(--text)}.notif-sugerencia-email{font-size:11px;color:var(--muted)}.notif-sugerencia-rol{font-size:10px;font-weight:700;color:var(--navy);background:#e8f0fe;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.notif-error-toast{position:fixed;bottom:24px;right:24px;background:#fef2f2;border:1px solid #FECACA;color:#991b1b;padding:12px 16px;border-radius:8px;display:flex;align-items:center;gap:10px;font-size:13px;box-shadow:0 4px 12px #00000026;z-index:10000;max-width:440px;animation:notif-toast-in .3s ease;cursor:pointer}@keyframes notif-toast-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.notif-error-icon{font-size:18px;flex-shrink:0}.notif-error-close{background:none;border:none;color:#991b1b;cursor:pointer;font-size:14px;padding:0 0 0 8px;flex-shrink:0;opacity:.6}.notif-error-close:hover{opacity:1}.compras-ext-mobile{display:flex;flex-direction:column;height:100%;min-height:0;background:#f8fafc;overflow:hidden}.compras-ext-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#1f4e79;color:#fff;flex-shrink:0}.compras-ext-back{background:none;border:none;color:#fff;cursor:pointer;padding:4px;display:flex;align-items:center}.compras-ext-header-info{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px}.compras-ext-title{font-size:15px}.compras-ext-banner{padding:12px 16px;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0}.compras-ext-banner-top{display:flex;align-items:center;justify-content:space-between}.compras-ext-banner-top strong{font-size:14px;color:#1e293b}.compras-ext-badge{background:#dbeafe;color:#1d4ed8;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.compras-ext-banner-sub{font-size:12px;color:#64748b;margin:2px 0 0}.compras-ext-summary{display:flex;gap:16px;padding:10px 16px;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0}.compras-ext-summary-item{flex:1;display:flex;flex-direction:column}.compras-ext-summary-label{font-size:10px;text-transform:uppercase;color:#94a3b8;letter-spacing:.5px}.compras-ext-summary-value{font-size:15px;font-weight:700;color:#1e293b}.compras-ext-items{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 12px 80px;display:flex;flex-direction:column;gap:8px}.compras-ext-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#94a3b8;text-align:center}.compras-ext-empty p{margin-top:8px;font-size:13px}.compras-ext-card{background:#fff;border-radius:8px;border:1px solid #e2e8f0;overflow:hidden;flex-shrink:0}.compras-ext-card.over-budget{border-color:#fca5a5;background:#fef2f2}.compras-ext-card-row1{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer}.compras-ext-card-num{font-size:11px;color:#94a3b8;font-weight:600;min-width:20px}.compras-ext-card-desc{flex:1;min-width:0;display:flex;flex-direction:column}.compras-ext-card-en{font-size:13px;font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compras-ext-card-es{font-size:11px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compras-ext-card-qty{display:flex;flex-direction:column;align-items:center;min-width:40px}.compras-ext-card-uom{font-size:9px;color:#94a3b8;text-transform:uppercase}.compras-ext-card-qty-val{font-size:15px;font-weight:700;color:#1d4ed8}.compras-ext-card-row2{display:flex;gap:8px;padding:6px 12px 10px;border-top:1px solid #f1f5f9;align-items:flex-end}.compras-ext-field{flex:1;display:flex;flex-direction:column;gap:2px}.compras-ext-field label{font-size:9px;text-transform:uppercase;color:#94a3b8;letter-spacing:.3px}.compras-ext-readonly{font-size:12px;color:#475569;font-weight:500}.compras-ext-input{width:100%;padding:4px 6px;border:1px solid #cbd5e1;border-radius:4px;font-size:13px;font-weight:500;background:#fff;color:#1e293b}.compras-ext-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.compras-ext-input.input-over{border-color:#f87171;background:#fef2f2;color:#dc2626}.compras-ext-total{font-size:12px;font-weight:700;color:#1e293b}.compras-ext-total.text-over{color:#dc2626}.compras-ext-comprado{border-left:3px solid #16a34a;background:#f0fdf4}.compras-ext-card-expanded{padding:8px 12px 10px;border-top:1px solid #f1f5f9;background:#f8fafc}.compras-ext-comprado-toggle{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-bottom:8px;border-radius:8px;background:#f1f5f9;cursor:pointer;font-size:13px;font-weight:500;color:#64748b;transition:all .2s}.compras-ext-comprado-toggle.active{background:#dcfce7;color:#16a34a;font-weight:600}.compras-ext-check-empty{width:20px;height:20px;border-radius:50%;border:2px solid #cbd5e1;flex-shrink:0}.compras-ext-notes{font-size:12px;color:#64748b;margin:0 0 8px;font-style:italic}.compras-ext-expanded-fields{display:flex;gap:12px}.compras-ext-footer{flex-shrink:0;padding:12px 16px;background:#fff;border-top:1px solid #e2e8f0;box-shadow:0 -2px 8px #0000000f;display:flex;gap:8px}.compras-ext-save{flex:1;padding:12px;border:none;border-radius:8px;background:#1f4e79;color:#fff;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}.compras-ext-save:hover:not(:disabled){background:#163a5c}.compras-ext-save:disabled{opacity:.5;cursor:not-allowed}.compras-ext-save.saved{background:#16a34a}.compras-ext-finalizar{flex:1;padding:12px;border:2px solid #16a34a;border-radius:8px;background:#fff;color:#16a34a;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.compras-ext-finalizar:hover:not(:disabled){background:#f0fdf4}.compras-ext-finalizar:disabled{opacity:.5;cursor:not-allowed}.compras-ext-completed-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#f0fdf4;border:2px solid #86efac;border-radius:8px;color:#16a34a;font-weight:600;font-size:14px}.compras-ext-confirm-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:10;padding:20px}.compras-ext-confirm-dialog{background:#fff;border-radius:12px;padding:24px;max-width:340px;text-align:center;box-shadow:0 8px 24px #00000026}.compras-ext-confirm-dialog h3{margin:12px 0 8px;font-size:16px;color:#1e293b}.compras-ext-confirm-dialog p{font-size:13px;color:#64748b;margin:0 0 16px;line-height:1.5}.compras-ext-confirm-warn{color:#d97706!important;font-size:12px!important;font-style:italic}.compras-ext-confirm-actions{display:flex;gap:8px}.compras-ext-confirm-cancel{flex:1;padding:10px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;color:#64748b;font-size:13px;font-weight:500;cursor:pointer}.compras-ext-confirm-cancel:hover{background:#f8fafc}.compras-ext-confirm-ok{flex:1;padding:10px;border:none;border-radius:6px;background:#16a34a;color:#fff;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}.compras-ext-confirm-ok:hover:not(:disabled){background:#15803d}.compras-ext-confirm-ok:disabled{opacity:.6;cursor:not-allowed}.doc-foto-modal{display:flex;flex-direction:column}.doc-foto-modal .fotodoc-overlay{position:relative;flex:1;min-height:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.doc-foto-modal .fotodoc-panel{position:relative;height:100%;border-radius:0}.doc-foto-footer{flex-shrink:0}.doc-foto-completa{border-left:3px solid #16a34a;opacity:.75}.compras-page-grid{display:grid;gap:12px}.compras-page-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px;display:flex;align-items:center;gap:16px;transition:box-shadow .15s}.compras-page-card:hover{box-shadow:0 2px 8px #00000014}.compras-page-card-info{flex:1;min-width:0}.compras-page-cc{font-size:15px;font-weight:600;color:#1e293b;margin:0}.compras-page-meta{font-size:13px;color:#64748b;margin:2px 0 0}.compras-page-stats{display:flex;gap:16px;align-items:center}.compras-page-stat{text-align:center}.compras-page-stat-label{display:block;font-size:10px;text-transform:uppercase;color:#94a3b8;letter-spacing:.3px}.compras-page-stat-value{display:block;font-size:14px;font-weight:700;color:#1e293b}.compras-page-stat-value.ext-value{color:#d97706}.compras-page-actions{display:flex;gap:8px}.compras-page-btn{padding:8px 14px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;color:#475569;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s}.compras-page-btn:hover{background:#f8fafc;border-color:#cbd5e1}.compras-page-btn.btn-compras-open{background:#1f4e79;color:#fff;border-color:#1f4e79}.compras-page-btn.btn-compras-open:hover{background:#163a5c}.compras-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center}.compras-modal-container{width:100%;max-width:480px;height:90vh;max-height:800px;background:#f8fafc;border-radius:12px;overflow:hidden;display:flex;flex-direction:column}@media (max-width: 640px){.compras-modal-container{max-width:100%;height:100vh;max-height:100vh;border-radius:0}}.tesoreria-page{padding:20px 24px;max-width:1200px;margin:0 auto}.tesoreria-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:20px}.tesoreria-header-left{flex:1 1 auto}.tesoreria-title{display:flex;align-items:center;gap:10px;font-size:1.4rem;font-weight:700;color:#1e293b;margin:0}.tesoreria-subtitle{color:#64748b;font-size:.85rem;margin:4px 0 0}.tesoreria-tabs{display:flex;gap:4px;background:#f1f5f9;border-radius:8px;padding:3px}.tes-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:transparent;border-radius:6px;font-size:.82rem;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s;white-space:nowrap}.tes-tab:hover{color:#1e293b;background:#fff9}.tes-tab.active{background:#fff;color:#0369a1;box-shadow:0 1px 3px #00000014}.tes-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;font-size:.7rem;font-weight:600;background:#fbbf24;color:#78350f}.tes-tab-count-ok{background:#86efac;color:#14532d}.tesoreria-metricas{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:20px}.tes-metric{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:4px}.tes-metric-warn{border-left:3px solid #f59e0b}.tes-metric-ok{border-left:3px solid #22c55e}.tes-metric-danger{border-left:3px solid #ef4444}.tes-metric-label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.3px;font-weight:500}.tes-metric-value{font-size:1.3rem;font-weight:700;color:#1e293b}.tes-metric-sub{font-size:.75rem;color:#94a3b8}.tesoreria-search{display:flex;align-items:center;gap:12px;margin-bottom:12px}.tesoreria-search-input{display:flex;align-items:center;gap:8px;flex:1;padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff}.tesoreria-search-input input{flex:1;border:none;outline:none;font-size:.85rem;background:transparent;color:#1e293b}.tesoreria-search-input svg{color:#94a3b8}.tes-clear-search{background:none;border:none;cursor:pointer;padding:2px;color:#94a3b8;display:flex}.tes-clear-search:hover{color:#ef4444}.tesoreria-result-count{font-size:.8rem;color:#94a3b8;white-space:nowrap}.tesoreria-table-wrap{overflow-x:auto;background:#fff;border:1px solid #e2e8f0;border-radius:10px}.tesoreria-table{width:100%;border-collapse:collapse;font-size:.82rem}.tesoreria-table thead th{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:10px 12px;text-align:left;font-weight:600;color:#475569;font-size:.75rem;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.tes-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.tes-th-sortable:hover{color:#0369a1}.tes-th-sortable svg{display:inline;vertical-align:middle;margin-left:2px}.tes-th-right{text-align:right!important}.tes-th-center{text-align:center!important}.tesoreria-table tbody td{padding:10px 12px;border-bottom:1px solid #f1f5f9;color:#334155;vertical-align:middle}.tes-row:hover{background:#f8fafc}.tes-row-current{background:#eff6ff}.tes-row-current:hover{background:#dbeafe}.tes-cell-vessel .tes-vessel-name{display:flex;align-items:center;gap:6px;font-weight:600;color:#1e293b}.tes-cell-vessel .tes-vessel-sub{display:block;font-size:.72rem;color:#94a3b8;margin-top:2px;margin-left:20px}.tes-cell-money{text-align:right;font-variant-numeric:tabular-nums;font-weight:500}.tes-cell-valor{font-weight:600;color:#1e293b}.tes-cell-ok{color:#16a34a}.tes-cell-parcial{color:#d97706}.tes-cell-danger{color:#dc2626}.tes-cell-fecha{white-space:nowrap}.tes-fecha-sub{display:block;font-size:.7rem;color:#94a3b8}.tes-cell-cc{color:#64748b;font-size:.78rem}.tes-cell-comprador{font-size:.8rem;color:#475569}.tes-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:12px;font-size:.72rem;font-weight:500;white-space:nowrap}.tes-badge-pendiente{background:#fef3c7;color:#92400e}.tes-badge-parcial{background:#fef9c3;color:#854d0e}.tes-badge-completo{background:#dcfce7;color:#14532d}.tes-badge-cancelado{background:#f1f5f9;color:#64748b}.tes-dot{width:7px;height:7px;border-radius:50%}.tes-dot-pendiente{background:#f59e0b}.tes-dot-parcial{background:#eab308}.tes-dot-completo{background:#22c55e}.tes-dot-cancelado{background:#94a3b8}.tes-actions{display:flex;gap:6px;justify-content:flex-end}.tes-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.72rem;font-weight:500;cursor:pointer;background:#fff;color:#475569;transition:all .15s;white-space:nowrap;min-width:82px;justify-content:center}.tes-btn:hover{background:#f1f5f9}.tes-btn:disabled{opacity:.5;cursor:not-allowed}.tes-btn-ok{border-color:#bbf7d0;background:#f0fdf4;color:#15803d}.tes-btn-ok:hover{background:#dcfce7}.tes-btn-parcial{border-color:#fde68a;background:#fffbeb;color:#b45309}.tes-btn-parcial:hover{background:#fef3c7}.tes-btn-cancel{border-color:#fecaca;background:#fef2f2;color:#dc2626}.tes-btn-cancel:hover{background:#fee2e2}.tes-empty{text-align:center;padding:40px 20px!important;color:#94a3b8;font-style:italic}.tesoreria-flujo{margin-top:4px}.tes-flujo-title{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:600;color:#1e293b;margin:0 0 16px}.tes-flujo-chart{margin-bottom:16px}.tes-flujo-legend{display:flex;gap:16px;margin-bottom:12px;font-size:.78rem;color:#64748b}.tes-legend-item{display:flex;align-items:center;gap:5px}.tes-legend-dot{width:10px;height:10px;border-radius:3px}.tes-legend-sol{background:#0ea5e9}.tes-legend-des{background:#22c55e}.tes-legend-pen{background:#f59e0b}.tes-flujo-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.tes-flujo-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:4px}.tes-flujo-card-label{font-size:.75rem;color:#64748b;font-weight:500}.tes-flujo-card-value{font-size:1.2rem;font-weight:700}.tes-flujo-sol{color:#0369a1}.tes-flujo-des{color:#16a34a}.tes-flujo-pen{color:#d97706}.tes-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.tes-popup{background:#fff;border-radius:12px;width:95%;max-width:460px;box-shadow:0 20px 40px #00000026;overflow:hidden}.tes-popup-title{padding:16px 20px;margin:0;font-size:1rem;font-weight:600;color:#1e293b;border-bottom:1px solid #e2e8f0;background:#f8fafc}.tes-popup-body{padding:20px;display:flex;flex-direction:column;gap:14px}.tes-popup-field label{display:block;font-size:.75rem;font-weight:500;color:#64748b;margin-bottom:4px}.tes-popup-field input{width:100%;padding:8px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;color:#1e293b;box-sizing:border-box}.tes-popup-field input:disabled{background:#f8fafc;color:#94a3b8}.tes-popup-field input:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 2px #0ea5e926}.tes-popup-saldo{font-weight:600}.tes-popup-full{grid-column:span 2}.tes-popup-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:8px;border-top:1px solid #f1f5f9}@media (max-width: 768px){.tesoreria-page{padding:16px}.tesoreria-header{flex-direction:column}.tesoreria-tabs{width:100%;overflow-x:auto}.tesoreria-metricas{grid-template-columns:1fr 1fr}.tesoreria-search{flex-direction:column;align-items:stretch}.tes-actions{flex-direction:column;gap:4px}.tes-btn{min-width:unset}.tes-flujo-summary{grid-template-columns:1fr}}@media (max-width: 480px){.tesoreria-metricas{grid-template-columns:1fr}}.vessel-tracking-card{overflow:hidden}.vessel-tracking-header{display:flex;align-items:center;gap:8px}.vessel-tracking-status{margin-left:auto;display:flex;align-items:center}.vessel-status-live{display:inline-flex;align-items:center;gap:4px;background:#e6f4ea;color:#1e7e34;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:10px;letter-spacing:.5px;text-transform:uppercase}.vessel-status-live svg{animation:vessel-pulse 2s ease-in-out infinite}.vessel-status-error{display:inline-flex;align-items:center;gap:4px;background:#fde8e8;color:#c62828;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:10px}.vessel-status-connecting{display:inline-flex;align-items:center;gap:4px;background:#fff3e0;color:#e65100;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:10px}.vessel-status-cached{display:inline-flex;align-items:center;gap:4px;background:#e3f2fd;color:#1565c0;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:10px}.vessel-toggle-btn{background:none;border:none;cursor:pointer;color:var(--text-muted, #6b7280);padding:4px;border-radius:4px;display:flex;align-items:center;margin-left:4px}.vessel-toggle-btn:hover{background:var(--bg-hover, #f0f2f5)}.vessel-tracking-body{padding:0!important}.vessel-map-container{position:relative;width:100%;height:220px;border-bottom:1px solid var(--border, #D0D7DE)}.vessel-map{width:100%;height:100%;z-index:1}.vessel-marker-icon{background:none!important;border:none!important}.vessel-map-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffd9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--navy, #1F4E79);font-size:.85rem;z-index:10}.vessel-map-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-muted, #6b7280);font-size:.85rem;background:#f5f7fa}.vessel-mmsi-display{font-size:.75rem;color:var(--text-muted, #999);font-family:monospace}.vessel-popup-content{font-size:.8rem;line-height:1.5}.vessel-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-bottom:1px solid var(--border, #D0D7DE)}.vessel-info-cell{display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 8px;border-right:1px solid var(--border, #D0D7DE);border-bottom:1px solid var(--border, #D0D7DE)}.vessel-info-cell:nth-child(2n){border-right:none}.vessel-info-cell:nth-child(n+3){border-bottom:none}.vessel-info-cell svg{color:var(--navy, #1F4E79)}.vessel-info-cell-label{font-size:.65rem;color:var(--text-muted, #6b7280);text-transform:uppercase;letter-spacing:.3px;font-weight:600}.vessel-info-cell-value{font-size:.82rem;font-weight:700;color:var(--text-primary, #1a1a2e);text-align:center;line-height:1.2}.vessel-last-signal-bar{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:.75rem;color:var(--text-muted, #6b7280);border-top:1px dashed var(--border, #D0D7DE)}.vessel-last-signal-bar svg{flex-shrink:0;color:var(--navy, #1F4E79)}.vessel-no-mmsi{display:flex;align-items:center;gap:6px;color:var(--text-muted, #6b7280);font-size:.82rem;padding:8px 0;margin:0}.vessel-no-mmsi-panel{display:flex;flex-direction:column;gap:8px;padding:4px 0}.vessel-add-mmsi-btn{align-self:flex-start;background:var(--navy, #1F4E79);color:#fff;border:none;border-radius:6px;padding:6px 14px;font-size:.78rem;font-weight:600;cursor:pointer;transition:background .15s}.vessel-add-mmsi-btn:hover{background:#163a5c}.vessel-mmsi-editor{display:flex;flex-direction:column;gap:6px;padding:4px 0}.vessel-mmsi-editor label{font-size:.78rem;font-weight:600;color:var(--text-primary, #1a1a2e)}.vessel-mmsi-input-row{display:flex;gap:6px;align-items:center}.vessel-mmsi-input-row .form-input{flex:1;font-family:SF Mono,Fira Code,monospace;font-size:.85rem;letter-spacing:1px}.vessel-mmsi-save-btn{background:var(--navy, #1F4E79);color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap}.vessel-mmsi-save-btn:disabled{opacity:.5;cursor:not-allowed}.vessel-mmsi-cancel-btn{background:none;border:1px solid var(--border, #D0D7DE);border-radius:6px;padding:6px 10px;font-size:.75rem;color:var(--text-muted, #6b7280);cursor:pointer;white-space:nowrap}.vessel-mmsi-cancel-btn:hover{background:var(--bg-hover, #f0f2f5)}.vessel-mmsi-hint{font-size:.7rem;color:var(--text-muted, #6b7280);font-style:italic}.fleet-map-panel{position:relative;z-index:0;background:var(--bg-card, #fff);border-radius:var(--radius, 8px);box-shadow:0 1px 4px #00000014;margin-bottom:20px;overflow:hidden}.fleet-map-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--bg-header, #F8FAFC);border-bottom:1px solid var(--border, #D0D7DE)}.fleet-map-title{font-size:15px;font-weight:600;color:var(--navy, #1F4E79)}.fleet-map-count{font-size:12px;font-weight:500;color:var(--text-muted, #6b7280);background:var(--bg-hover, #f0f2f5);padding:2px 10px;border-radius:12px}.fleet-missing-count{color:var(--text-muted, #9ca3af);font-weight:400}.fleet-fetch-btn{font-size:11px;padding:3px 10px;border:1px solid var(--navy, #1F4E79);background:transparent;color:var(--navy, #1F4E79);border-radius:12px;cursor:pointer;white-space:nowrap;transition:background .15s}.fleet-fetch-btn:hover:not(:disabled){background:var(--navy, #1F4E79);color:#fff}.fleet-fetch-btn:disabled{opacity:.5;cursor:wait}.fleet-fetch-result{font-size:11px;color:var(--success, #16a34a);font-weight:500}.fleet-map-container{height:320px}.fleet-map-loading{display:flex;align-items:center;justify-content:center;background:var(--bg-hover, #F8F9FA);border-radius:0 0 var(--radius, 8px) var(--radius, 8px)}.fleet-map{width:100%;height:100%}.fleet-marker-icon{background:none!important;border:none!important}.fleet-popup{display:flex;flex-direction:column;gap:6px;min-width:160px}.fleet-popup-name{font-size:14px;font-weight:600;color:var(--navy, #1F4E79)}.fleet-popup-estado{display:inline-block;align-self:flex-start;font-size:11px;font-weight:600;color:#fff;padding:2px 8px;border-radius:10px}.fleet-popup-dest,.fleet-popup-speed{font-size:12px;color:var(--text-muted, #6b7280)}.fleet-popup-link{background:none;border:1px solid var(--border, #D0D7DE);border-radius:var(--radius-sm, 4px);padding:4px 10px;font-size:12px;font-weight:600;font-family:inherit;color:var(--navy, #1F4E79);cursor:pointer;text-align:left;transition:all .15s}.fleet-popup-link:hover{background:var(--navy, #1F4E79);color:#fff}@media (max-width: 768px){.fleet-map-container{height:240px}}@keyframes vessel-pulse{0%,to{opacity:1}50%{opacity:.4}}.vessel-spin{animation:vessel-rotate 1.5s linear infinite}@keyframes vessel-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.vessel-map-container{height:180px}.vessel-info-cell{padding:8px 6px}.vessel-info-cell-value{font-size:.75rem}}.sep-inv-mobile{display:flex;flex-direction:column;height:100%;max-height:100dvh;background:var(--surface);font-family:Segoe UI,system-ui,sans-serif}.sep-inv-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--primary);color:#fff}.sep-inv-back{background:none;border:none;color:#fff;cursor:pointer;padding:4px;display:flex}.sep-inv-header-info{display:flex;align-items:center;gap:6px;flex:1}.sep-inv-edit-btn{display:flex;align-items:center;gap:4px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;margin-left:auto;flex-shrink:0}.sep-inv-edit-btn.active{background:#ffffffe6;color:var(--primary);border-color:transparent}.sep-inv-title{font-size:.875rem;font-weight:600}.sep-inv-banner{padding:10px 14px;background:var(--surface-alt);border-bottom:1px solid var(--border)}.sep-inv-banner-top{display:flex;align-items:center;gap:8px}.sep-inv-banner-top strong{font-size:.9rem}.sep-inv-badge{background:#e6f1fb;color:#185fa5;font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:600}.sep-inv-banner-sub{font-size:.75rem;color:var(--text-muted);margin-top:2px}.sep-inv-summary{display:flex;padding:10px 14px;border-bottom:1px solid var(--border);gap:4px}.sep-inv-summary-item{flex:1;text-align:center}.sep-inv-summary-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted)}.sep-inv-summary-value{font-size:1rem;font-weight:700;color:var(--text);margin-top:2px}.sep-inv-green{color:#0f6e56}.sep-inv-items{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 10px;display:flex;flex-direction:column;gap:6px}.sep-inv-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 20px;color:var(--text-muted);text-align:center}.sep-inv-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .15s,background .15s;flex-shrink:0}.sep-inv-card.sep-inv-checked{border-color:#0f6e56;background:#e1f5ee}.sep-inv-card.sep-inv-partial{border-color:#d97706;background:#faeeda}.sep-inv-card-row1{display:flex;align-items:center;padding:8px 10px;gap:8px;cursor:pointer}.sep-inv-card-check{flex-shrink:0;color:var(--text-muted);cursor:pointer;display:flex}.sep-inv-card-check.on{color:#0f6e56}.sep-inv-card-desc{flex:1;min-width:0}.sep-inv-card-en{display:block;font-size:.8rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sep-inv-card-es{display:block;font-size:.7rem;color:var(--text-muted)}.sep-inv-card-right{text-align:right;flex-shrink:0}.sep-inv-card-qty-val{font-size:.95rem;font-weight:700;color:var(--text)}.sep-inv-card-uom{font-size:.6rem;color:var(--text-muted);text-transform:uppercase}.sep-inv-card-expanded{padding:0 10px 10px;border-top:1px solid var(--border)}.sep-inv-exp-fields{display:flex;gap:8px;margin-top:8px}.sep-inv-exp-field{flex:1}.sep-inv-exp-field label{font-size:.6rem;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:2px;letter-spacing:.3px}.sep-inv-input{width:100%;height:32px;border:1px solid var(--border);border-radius:6px;padding:0 8px;font-size:.85rem;background:#fff;color:var(--text);box-sizing:border-box}.sep-inv-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #1f4e7926}.sep-inv-readonly{font-size:.85rem;font-weight:600;color:var(--text)}.sep-inv-remaining{margin-top:8px;padding:6px 8px;background:var(--surface-alt);border-radius:6px;font-size:.75rem;color:var(--text-muted)}.sep-inv-remaining strong{color:var(--text)}.sep-inv-notes{font-size:.75rem;color:var(--text-muted);margin-top:6px;padding:4px 0;font-style:italic}.sep-inv-notas-field{margin-top:8px;width:100%}.sep-inv-notas-field label{display:block;font-size:.7rem;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.sep-inv-notas-input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:.85rem;font-family:inherit;resize:vertical;background:var(--surface);color:var(--text);min-height:48px}.sep-inv-notas-input:focus{outline:none;border-color:#0f6e56;box-shadow:0 0 0 2px #0f6e5626}.sep-inv-notas-input:disabled{opacity:.6;cursor:not-allowed}.compras-ext-notas-field{margin-top:8px;padding:0 4px}.compras-ext-notas-field label{display:block;font-size:.7rem;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.compras-ext-notas-input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:.85rem;font-family:inherit;resize:vertical;background:var(--surface);color:var(--text);min-height:48px}.compras-ext-notas-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}.qty-with-nota{display:flex;align-items:center;gap:2px}.qty-with-nota .qty-input{flex:1;min-width:0}.nota-bodega-btn{background:none;border:none;cursor:pointer;color:#d97706;padding:2px;display:flex;align-items:center;flex-shrink:0}.nota-bodega-btn:hover{color:#b45309}.nota-popup{max-width:400px}.sep-inv-card-partial-badge{padding:2px 10px 6px;font-size:.7rem;color:#854f0b;font-weight:600}.sep-inv-footer{padding:10px 14px;border-top:1px solid var(--border);display:flex;gap:8px;background:var(--surface)}.sep-inv-save{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:8px;font-size:.85rem;font-weight:600;border:1px solid var(--border);background:var(--surface-alt);color:var(--text);cursor:pointer}.sep-inv-save:disabled{opacity:.5;cursor:not-allowed}.sep-inv-save.saved{background:#e1f5ee;color:#0f6e56;border-color:#0f6e56}.sep-inv-confirm-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:8px;font-size:.85rem;font-weight:600;border:none;background:#0f6e56;color:#fff;cursor:pointer}.sep-inv-confirm-btn:disabled{opacity:.5;cursor:not-allowed}.sep-inv-completed-banner{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:#e1f5ee;border-radius:8px;color:#0f6e56;font-weight:600;font-size:.85rem}.sep-inv-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1200;display:flex;align-items:center;justify-content:center;padding:20px}.sep-inv-confirm-dialog{background:var(--surface);border-radius:12px;padding:24px;max-width:340px;width:100%;text-align:center}.sep-inv-confirm-dialog h3{margin:12px 0 8px;font-size:1rem}.sep-inv-confirm-dialog p{font-size:.8rem;color:var(--text-muted);margin:0 0 8px}.sep-inv-confirm-warn{color:#d97706;font-weight:600}.sep-inv-confirm-actions{display:flex;gap:8px;margin-top:16px}.sep-inv-confirm-cancel{flex:1;padding:10px;border-radius:8px;border:1px solid var(--border);background:var(--surface-alt);color:var(--text);cursor:pointer;font-weight:600}.sep-inv-confirm-ok{flex:1;padding:10px;border-radius:8px;border:none;background:#0f6e56;color:#fff;cursor:pointer;font-weight:600;display:flex;align-items:center;justify-content:center;gap:6px}.sep-inv-page-grid{display:flex;flex-direction:column;gap:10px;margin-top:12px}.sep-inv-page-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-wrap:wrap;align-items:center;gap:12px}.sep-inv-page-card.sep-inv-done{opacity:.7}.sep-inv-page-card-info{flex:1;min-width:200px}.sep-inv-page-cc{font-weight:700;font-size:.95rem;margin:0;display:flex;align-items:center;gap:8px}.sep-inv-page-done-badge{font-size:.65rem;background:#e1f5ee;color:#0f6e56;padding:2px 8px;border-radius:4px;font-weight:700}.sep-inv-page-meta{font-size:.78rem;color:var(--text-muted);margin:2px 0 0}.sep-inv-page-stats{display:flex;gap:20px}.sep-inv-page-stat-label{font-size:.65rem;text-transform:uppercase;color:var(--text-muted)}.sep-inv-page-stat-value{font-size:.95rem;font-weight:700}.sep-inv-page-progress{width:100%;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.sep-inv-page-progress-bar{height:100%;background:#0f6e56;border-radius:2px;transition:width .3s}.sep-inv-page-actions{display:flex;gap:6px}.sep-inv-page-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 14px;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface-alt);color:var(--text-muted)}.sep-inv-page-btn-open{background:var(--primary);color:#fff;border-color:var(--primary)}.sep-inv-page-btn-print{padding:6px 10px}.sep-inv-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:var(--surface);display:flex;flex-direction:column;overflow:hidden}@media (min-width: 768px){.sep-inv-fullscreen{max-width:480px;margin:0 auto;inset:20px auto;border-radius:16px;box-shadow:0 8px 30px #00000040;height:calc(100vh - 40px)}}.verif-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:var(--surface);display:flex;flex-direction:column;overflow:hidden}@media (min-width: 768px){.verif-fullscreen{max-width:480px;margin:0 auto;inset:20px auto;border-radius:16px;box-shadow:0 8px 30px #00000040;height:calc(100vh - 40px)}}.verif-mobile{display:flex;flex-direction:column;height:100%;background:#f5f5f5;overflow:hidden}.verif-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#1a1a2e;color:#fff}.verif-back{background:none;border:none;color:#fff;cursor:pointer;padding:4px;border-radius:6px}.verif-back:hover{background:#ffffff1a}.verif-header-info{display:flex;align-items:center;gap:8px;flex:1}.verif-title{font-weight:600;font-size:15px}.verif-banner{padding:12px 16px;background:#fff;border-bottom:1px solid #e5e7eb}.verif-banner-top{display:flex;justify-content:space-between;align-items:center}.verif-badge{font-size:12px;background:#e0f2fe;color:#0369a1;padding:2px 8px;border-radius:10px;font-weight:500}.verif-banner-sub{font-size:13px;color:#6b7280;margin-top:4px}.verif-search-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;border-bottom:1px solid #e5e7eb}.verif-search-bar input{flex:1;border:none;outline:none;font-size:14px;background:transparent}.verif-search-bar svg{color:#9ca3af;flex-shrink:0}.verif-search-clear{background:none;border:none;color:#9ca3af;cursor:pointer;padding:2px}.verif-filter-row{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;border-bottom:1px solid #e5e7eb}.verif-filter-caja{display:flex;align-items:center;gap:6px;flex:1}.verif-filter-caja svg{color:#6b7280;flex-shrink:0}.verif-filter-caja select{flex:1;border:1px solid #d1d5db;border-radius:8px;padding:6px 10px;font-size:13px;background:#fff;cursor:pointer}.verif-foto-caja-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border:none;border-radius:8px;background:#0f6e56;color:#fff;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap}.verif-foto-caja-btn:hover{background:#0d5e49}.verif-foto-caja-btn.disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed}.verif-items{flex:1;overflow-y:auto;padding:8px 12px;-webkit-overflow-scrolling:touch}.verif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 16px;text-align:center;color:#9ca3af}.verif-empty svg{margin-bottom:12px}.verif-card{background:#f3f4f6;border-radius:10px;margin-bottom:8px;border:1.5px solid #d1d5db;overflow:hidden;transition:all .15s}.verif-card.verif-checked{background:#f0fdf4;border-color:#10b981;border-width:2px}.verif-card-row1{display:flex;align-items:center;gap:8px;padding:12px;cursor:pointer}.verif-card-desc{flex:1;min-width:0}.verif-card-en{display:block;font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.verif-card-es{display:block;font-size:12px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.verif-card-notes{display:block;font-size:11px;color:#0f6e56;font-style:italic;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.verif-card-right{text-align:right;flex-shrink:0}.verif-card-qty-val{display:block;font-weight:600;font-size:15px}.verif-card-uom{display:block;font-size:11px;color:#9ca3af}.verif-card-badges{display:flex;gap:6px;padding:0 12px 8px}.verif-badge-sm{font-size:11px;background:#f3f4f6;color:#4b5563;padding:2px 8px;border-radius:6px}.verif-card-expanded{padding:0 12px 12px;border-top:1px solid #f3f4f6}.verif-qty-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:10px}.verif-qty-field label{display:block;font-size:11px;color:#6b7280;margin-bottom:4px;font-weight:500}.verif-readonly{display:block;font-size:14px;font-weight:500;padding:6px 8px;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb;color:#374151}.verif-input{width:100%;font-size:14px;padding:6px 8px;border:1px solid #d1d5db;border-radius:6px;outline:none;box-sizing:border-box}.verif-input:focus{border-color:#0f6e56;box-shadow:0 0 0 2px #0f6e5626}.verif-detail-row{display:flex;gap:12px;margin-top:10px;align-items:stretch}.verif-detail-fields{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:8px}.verif-detail-field label{display:block;font-size:11px;color:#6b7280;margin-bottom:4px;font-weight:500}.verif-save-item{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;margin-top:8px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;background:#0f6e56;color:#fff}.verif-save-item:active{transform:scale(.98)}.verif-save-item:disabled{opacity:.6;cursor:not-allowed}.verif-save-item.saved{background:#10b981}.verif-save-item.already-saved{background:#e5e7eb;color:#6b7280}.verif-badge-confirmed{background:#dcfce7!important;color:#166534!important;font-weight:600}.verif-foto-item-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-width:72px;padding:12px 8px;border:2px dashed #d1d5db;border-radius:10px;background:#f9fafb;color:#6b7280;cursor:pointer;font-size:12px;font-weight:500;transition:all .15s;position:relative}.verif-foto-item-btn-sm{min-width:48px;padding:8px 6px;font-size:0;gap:2px}.verif-foto-item-btn:hover{border-color:#0f6e56;color:#0f6e56;background:#ecfdf5}.verif-foto-count{position:absolute;top:-6px;right:-6px;background:#0f6e56;color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.verif-footer{padding:12px 16px;background:#fff;border-top:1px solid #e5e7eb;display:flex;gap:10px}.verif-save{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;background:#1a1a2e;color:#fff}.verif-save:hover{background:#2a2a4e}.verif-save:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed}.verif-save.saved{background:#0f6e56}.notif-inline-wrapper{margin-top:4px;padding-top:8px;border-top:1px solid var(--border)}.notif-inline-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s;color:var(--muted)}.notif-inline-btn:hover{background:var(--surface-alt)}.notif-inline-btn-label{flex:1;font-size:13px;font-weight:500}.notif-inline-body{display:flex;flex-direction:column;gap:14px;padding:14px 0 4px}.notif-emails{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 600px){.notif-emails{grid-template-columns:1fr}}.notif-email-field{display:flex;flex-direction:column;gap:4px}.notif-email-input{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;background:var(--surface);color:var(--text);transition:border-color .15s}.notif-email-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 2px #2e75b626}.notif-toggles{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.notif-toggle-row{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:var(--radius-sm);border:1px solid var(--border, #e2e8f0);background:var(--surface-alt, #f8fafc);transition:background .12s}.notif-toggle-row:hover{background:var(--surface, #f1f5f9)}.notif-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.notif-toggle-info{flex:1;min-width:0}.notif-toggle-label{font-size:11px;font-weight:500;color:var(--text);line-height:1.2}.notif-toggle-desc,.notif-enviado-badge{display:none}.notif-switch{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0;cursor:pointer}.notif-switch input{opacity:0;width:0;height:0;position:absolute}.notif-switch-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#d1d5db;border-radius:20px;transition:background .2s}.notif-switch-slider:before{content:"";position:absolute;width:16px;height:16px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 2px #00000026}.notif-switch input:checked+.notif-switch-slider{background:var(--blue)}.notif-switch input:checked+.notif-switch-slider:before{transform:translate(16px)}.notif-panel-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:8px;border-top:1px solid var(--border)}.notif-panel-note{font-size:11px;color:var(--muted);font-style:italic}
