.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.login-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:450px;padding:2.5rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.8rem;margin-bottom:.5rem;color:#333}.login-header p{color:#666;font-size:1rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{font-weight:600;color:#333;font-size:.95rem}.form-group input,.form-group select{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:all .3s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled,.form-group select:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.form-group small{color:#666;font-size:.85rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:.5rem}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-primary:active:not(:disabled){transform:translateY(0)}.login-footer{text-align:center;margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.login-footer p{color:#666;font-size:.95rem}.login-footer a{color:#667eea;font-weight:600;text-decoration:none}.login-footer a:hover{text-decoration:underline}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:6px;padding:.875rem;color:#c33;font-size:.95rem;text-align:center}.success-message{background-color:#efe;border:1px solid #cfc;border-radius:6px;padding:.875rem;color:#3c3;font-size:.95rem;text-align:center}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.empresa-fields{background-color:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;padding:1.5rem;margin-top:.5rem}.empresa-fields-header{font-weight:600;color:#495057;margin-bottom:1rem;font-size:.95rem}@media (max-width: 600px){.login-page{padding:1rem}.login-container{padding:2rem 1.5rem}.form-row{grid-template-columns:1fr}.login-header h1{font-size:1.5rem}}.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}}.clientes-tab{padding:20px}.map-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;margin-bottom:20px}.map-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.map-header h3{margin:0;font-size:16px;color:#333}.map-total{font-size:14px;color:#666;background:#f0f0f0;padding:4px 12px;border-radius:16px}.leaflet-map-wrapper{height:350px;border-radius:8px;overflow:hidden;border:1px solid #e0e0e0}.leaflet-map{height:100%;width:100%;z-index:1}.map-warning{color:#ff9800;font-size:12px}.map-geocode-notice{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fff3cd;border-radius:8px;margin-top:12px;font-size:14px;color:#856404}.btn-geocode{background:#ffc107;color:#333;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:background .2s}.btn-geocode:hover{background:#e0a800}.cluster-marker{background:none;border:none}.cluster-marker-inner{background:linear-gradient(135deg,#4285f4,#1a56db);color:#fff;font-weight:700;font-size:14px;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid white;box-shadow:0 2px 8px #0000004d}.cliente-popup .leaflet-popup-content-wrapper{border-radius:12px;padding:0}.cliente-popup .leaflet-popup-content{margin:0;min-width:200px;max-width:280px}.popup-content{padding:16px}.popup-single h4,.popup-multiple h4{margin:0 0 8px;font-size:15px;color:#333;font-weight:600}.popup-fantasia{margin:0 0 8px;font-size:13px;color:#666;font-style:italic}.popup-cuit,.popup-location,.popup-email{margin:4px 0;font-size:13px;color:#555}.popup-btn{width:100%;margin-top:12px;padding:8px 16px;background:linear-gradient(135deg,#4285f4,#3367d6);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:transform .2s,box-shadow .2s}.popup-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4285f44d}.popup-list{list-style:none;padding:0;margin:8px 0 0;max-height:150px;overflow-y:auto}.popup-list li{padding:4px 0;border-bottom:1px solid #eee}.popup-list li:last-child{border-bottom:none}.popup-link{background:none;border:none;color:#4285f4;cursor:pointer;font-size:13px;padding:0;text-align:left;width:100%}.popup-link:hover{text-decoration:underline}.popup-more{color:#888;font-style:italic;font-size:12px}.map-empty{text-align:center;padding:60px 20px;color:#888;font-style:italic;background:#f8f9fa;border-radius:8px}.filters-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;margin-bottom:20px}.filter-group label{font-size:13px;font-weight:500;margin-bottom:6px;color:#555}.filter-group input,.filter-group select{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#4285f4;box-shadow:0 0 0 2px #4285f41a}.checkbox-filter{justify-content:flex-end}.checkbox-filter .checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#555}.checkbox-filter input[type=checkbox]{width:16px;height:16px;cursor:pointer}.filters-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid #eee}.btn-primary{background:linear-gradient(135deg,#4285f4,#3367d6);color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;white-space:nowrap;transition:transform .2s,box-shadow .2s}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #4285f44d}.btn-secondary{background-color:#f5f5f5;color:#333;border:1px solid #ddd;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;transition:background .2s}.btn-secondary:hover{background-color:#e0e0e0}.clientes-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.table-info{padding:12px 16px;background:#f8f9fa;border-bottom:1px solid #eee;font-size:14px;color:#666}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-state p{margin:8px 0}.empty-state .hint{font-size:14px;color:#999}.clientes-table{width:100%;border-collapse:collapse}.clientes-table thead{background-color:#f5f5f5;border-bottom:2px solid #ddd}.clientes-table th{padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:#555}.clientes-table th.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.clientes-table th.sortable-header:hover{background-color:#e8e8e8}.sort-indicator{color:#4285f4;font-weight:700}.clientes-table td{padding:12px 16px;border-bottom:1px solid #eee;font-size:14px}.clientes-table tbody tr:hover{background-color:#f9f9f9}.clientes-table tbody tr.inactive{opacity:.5;background-color:#fafafa}.clientes-table .subtitle{font-size:12px;color:#888;margin-top:2px}.clientes-table .actions{display:flex;gap:8px}.btn-icon{background:none;border:none;cursor:pointer;font-size:18px;padding:4px 8px;border-radius:4px;transition:background-color .2s}.btn-icon:hover{background-color:#f0f0f0}.btn-icon.danger:hover{background-color:#ffe0e0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #eee}.modal-header h2{margin:0;font-size:20px;color:#333}.btn-close{background:none;border:none;font-size:24px;cursor:pointer;color:#999;padding:0;width:30px;height:30px;border-radius:50%}.btn-close:hover{background-color:#f0f0f0;color:#333}.modal-body,.modal-body.view-mode{padding:24px}.form-section{margin-bottom:24px}.form-section h3{margin:0 0 16px;font-size:16px;color:#555;border-bottom:1px solid #eee;padding-bottom:8px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:13px;font-weight:500;margin-bottom:6px;color:#555}.form-group input,.form-group select,.form-group textarea{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#4285f4}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;margin-top:24px;border-top:1px solid #eee}.detail-section{margin-bottom:24px}.detail-section h3{margin:0 0 16px;font-size:16px;color:#555;border-bottom:1px solid #eee;padding-bottom:8px}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{font-size:12px;color:#888;font-weight:500}.detail-item span{font-size:14px;color:#333}.saldo-section{background-color:#f9f9f9;padding:20px;border-radius:8px}.saldo-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.saldo-card{background:#fff;padding:16px;border-radius:8px;border-left:4px solid #ddd;box-shadow:0 2px 4px #0000000d}.saldo-card.pending{border-left-color:#ff9800}.saldo-card.facturas{border-left-color:#2196f3}.saldo-card.vencidas{border-left-color:#f44336}.saldo-label{font-size:12px;color:#888;margin-bottom:8px}.saldo-value{font-size:24px;font-weight:700;color:#333}.loading{text-align:center;padding:40px;color:#666}.error-container button{background-color:#4285f4;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer}@media (max-width: 768px){.filters-grid{grid-template-columns:1fr}.filters-actions{flex-direction:column}.filters-actions button{width:100%}.clientes-table{font-size:12px}.clientes-table th,.clientes-table td{padding:8px 10px}.form-grid,.detail-grid,.saldo-cards{grid-template-columns:1fr}.modal-content{max-width:100%}.leaflet-map-wrapper{height:250px}.map-geocode-notice{flex-direction:column;gap:8px;text-align:center}}.facturas-tab{padding:20px}.filters-section{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.filter-group{display:flex;flex-direction:column}.filter-group label{font-size:12px;font-weight:500;margin-bottom:6px;color:#555}.filter-group select,.filter-group input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.filters-actions{display:flex;justify-content:flex-end;gap:12px}.facturas-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.facturas-table{width:100%;border-collapse:collapse;min-width:900px}.facturas-table thead{background-color:#f5f5f5;border-bottom:2px solid #ddd}.facturas-table th{padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:#555}.facturas-table td{padding:12px 16px;border-bottom:1px solid #eee;font-size:14px}.facturas-table tbody tr:hover{background-color:#f9f9f9}.facturas-table .subtitle{font-size:11px;color:#888;margin-top:2px}.vencimiento-badge{display:inline-block;background-color:#ff9800;color:#fff;font-size:11px;padding:2px 8px;border-radius:10px;margin-top:4px}.estado-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.badge-pending{background-color:#fff3cd;color:#856404}.badge-partial{background-color:#d1ecf1;color:#0c5460}.badge-paid{background-color:#d4edda;color:#155724}.badge-overdue{background-color:#f8d7da;color:#721c24}.badge-uncollectible{background-color:#e2e3e5;color:#383d41}.actions{display:flex;gap:8px}.modal-content.large{max-width:1100px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.items-list{display:flex;flex-direction:column;gap:12px}.item-row{background-color:#f9f9f9;padding:12px;border-radius:6px}.item-fields{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:12px;align-items:center}.item-fields input,.item-fields select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.totales-section{background-color:#f5f5f5;padding:20px;border-radius:8px}.totales-grid{display:grid;gap:12px}.total-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.total-item.total{border-top:2px solid #333;padding-top:12px;margin-top:8px;font-size:18px;font-weight:700}.total-amount{color:#4caf50;font-size:20px}.factura-header-info{background-color:#f9f9f9;padding:16px;border-radius:8px;margin-bottom:20px}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.items-detail-table,.pagos-table{width:100%;border-collapse:collapse;margin-top:12px}.items-detail-table th,.pagos-table th{background-color:#f5f5f5;padding:10px;text-align:left;font-size:13px;border-bottom:2px solid #ddd}.items-detail-table td,.pagos-table td{padding:10px;border-bottom:1px solid #eee;font-size:14px}.totales-detail{background-color:#f9f9f9;padding:20px;border-radius:8px}.totales-detail .totales-grid{display:flex;flex-direction:column;gap:12px}.totales-detail .totales-grid>div{display:flex;justify-content:space-between;padding:8px 0}.total-final{border-top:2px solid #333;padding-top:12px;margin-top:8px;font-size:18px;font-weight:700}.saldo-final{background-color:#fff3cd;padding:12px;border-radius:6px;margin-top:8px}.totales-detail .amount{font-size:18px;color:#4caf50}.pago-info{background-color:#f9f9f9;padding:16px;border-radius:8px;margin-bottom:20px}.info-item{display:flex;justify-content:space-between;align-items:center}.saldo-amount{font-size:24px;font-weight:700;color:#ff9800}.loading,.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-state button{margin-top:20px;background-color:#4caf50;color:#fff;border:none;padding:10px 24px;border-radius:6px;cursor:pointer}.error-container{text-align:center;padding:40px}.error{color:#f44336;margin-bottom:20px}.error-container button{background-color:#4caf50;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer}.badge-info{background-color:#d1ecf1;color:#0c5460;border:1px solid #bee5eb;padding:.35rem .65rem;font-size:.85rem;font-weight:600;line-height:1;border-radius:6px;white-space:nowrap;display:inline-block}.badge-warning{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7;padding:.35rem .65rem;font-size:.85rem;font-weight:600;line-height:1;border-radius:6px;white-space:nowrap;display:inline-block}.badge-secondary{background-color:#e2e3e5;color:#383d41;border:1px solid #d6d8db;padding:.35rem .65rem;font-size:.85rem;font-weight:600;line-height:1;border-radius:6px;white-space:nowrap;display:inline-block}.highlight-so{background-color:#fff3cd;color:#856404;padding:.2rem .4rem;border-radius:4px;font-weight:600;border:1px solid #ffeaa7}.highlight-oc{background-color:#e2e3e5;color:#383d41;padding:.2rem .4rem;border-radius:4px;font-weight:600;border:1px solid #d6d8db}@media (max-width: 768px){.filters-grid,.item-fields,.info-grid{grid-template-columns:1fr}.facturas-table-container{overflow-x:scroll}}.cuentas-por-cobrar-tab{padding:1rem}.filtro-parciales{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.toggle-parciales{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.95rem;color:#333}.toggle-parciales input[type=checkbox]{width:18px;height:18px;cursor:pointer}.toggle-parciales .hint{color:#888;font-size:.85rem;font-style:italic}.fiscal-year-indicator{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#e3f2fd;border-left:4px solid #2196F3;border-radius:6px;margin-bottom:1.5rem;font-size:.95rem;color:#1565c0}.fiscal-year-indicator .icon{font-size:1.25rem}.fiscal-year-indicator strong{color:#0d47a1}.view-selector{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e0e0e0;padding-bottom:.5rem}.view-selector button{padding:.75rem 1.5rem;border:none;background:transparent;cursor:pointer;font-size:1rem;color:#666;border-radius:8px 8px 0 0;transition:all .2s}.view-selector button:hover{background:#f5f5f5;color:#333}.view-selector button.active{background:var(--primary-color, #4CAF50);color:#fff;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card-large{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #ddd;transition:transform .2s}.stat-card-large:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-card-large.success{border-left-color:#4caf50}.stat-card-large.warning{border-left-color:#ff9800}.stat-card-large.danger{border-left-color:#f44336}.stat-icon{font-size:2.5rem}.stat-content{flex:1}.stat-label{font-size:.875rem;color:#666;margin-bottom:.25rem}.stat-value{font-size:1.35rem;font-weight:700;color:#333;margin-bottom:.25rem;word-break:break-word}.stat-detail{font-size:.875rem;color:#999}.cobranza-info{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.cobranza-info h3{margin-top:0;margin-bottom:1.5rem;color:#333}.indicadores-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.indicador{text-align:center;padding:1rem;background:#f9f9f9;border-radius:8px}.indicador-label{font-size:.875rem;color:#666;margin-bottom:.5rem}.indicador-value{font-size:1.5rem;font-weight:700;color:var(--primary-color, #4CAF50)}.aging-content{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.aging-content h3{margin-top:0;margin-bottom:1.5rem;color:#333}.aging-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.aging-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;transition:all .2s}.aging-card.clickable:hover{transform:translateY(-4px);box-shadow:0 6px 16px #0003;opacity:.95}.aging-card.warning{border-color:#ffc107;background:#fff9e6}.aging-card.alert{border-color:#ff9800;background:#fff3e0}.aging-card.danger{border-color:#f44336;background:#ffebee}.aging-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.aging-icon{font-size:1.5rem}.aging-title{font-weight:600;color:#333}.aging-stats{text-align:center}.aging-monto{font-size:1.5rem;font-weight:700;color:#333;margin-bottom:.5rem}.aging-cantidad{font-size:.875rem;color:#666}.aging-detail-section{margin-top:2rem;padding-top:2rem;border-top:2px solid #e0e0e0}.aging-detail-section h4{margin-top:0;margin-bottom:1rem;color:#333}.facturas-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.facturas-table thead{background:#f5f5f5}.facturas-table th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.facturas-table th[style*="cursor: pointer"]:hover{background:#e8e8e8;color:#000}.facturas-table td{padding:1rem;border-bottom:1px solid #f0f0f0}.facturas-table tbody tr:hover{background:#f9f9f9}.facturas-table tbody tr.row-vencida{background:#ffebee}.facturas-table tbody tr.row-vencida:hover{background:#ffcdd2}.text-bold{font-weight:600}.text-danger{color:#f44336}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge-pendiente{background:#fff3e0;color:#f57c00}.badge-parcial{background:#e3f2fd;color:#1976d2}.badge-cobrada{background:#e8f5e9;color:#388e3c}.badge-vencida{background:#ffebee;color:#c62828}.empty-state{text-align:center;padding:3rem;color:#666;font-size:1.125rem}.btn-small{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary-color, #4CAF50);color:#fff}.btn-primary:hover{background:#45a049;transform:translateY(-1px)}.loading{text-align:center;padding:3rem;font-size:1.125rem;color:#666}.pendientes-content,.vencidas-content{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.pendientes-content h3,.vencidas-content h3{margin-top:0;margin-bottom:1.5rem;color:#333}@media (max-width: 768px){.stats-grid,.aging-grid,.indicadores-grid{grid-template-columns:1fr}.facturas-table{font-size:.875rem}.facturas-table th,.facturas-table td{padding:.75rem .5rem}.view-selector{flex-wrap:wrap}.view-selector button{flex:1;min-width:120px}}.colppy-tab{padding:1.5rem}.loading-indicator{text-align:center;padding:3rem}.colppy-header{margin-bottom:2rem}.colppy-header h2{margin:0 0 .5rem;color:#2c3e50}.colppy-header p{margin:0;color:#7f8c8d}.message{padding:1rem;border-radius:8px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.message pre{margin:0;white-space:pre-wrap;font-family:inherit}.connection-status{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.connection-status.connected{background-color:#d4edda;border:1px solid #c3e6cb}.connection-status.disconnected{background-color:#f8d7da;border:1px solid #f5c6cb}.status-icon{font-size:1.5rem}.stat-box{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:12px;text-align:center;box-shadow:0 4px 6px #0000001a}.stat-box .stat-icon{font-size:2rem;margin-bottom:.5rem}.stat-box .stat-label{font-size:.9rem;opacity:.9;margin-bottom:.5rem}.stat-box .stat-value{font-size:2.5rem;font-weight:700;margin:.5rem 0}.stat-box .stat-detail{font-size:.85rem;opacity:.8}.config-section{background:#f8f9fa;padding:2rem;border-radius:12px;margin-bottom:2rem}.config-section h3{margin:0 0 1.5rem;color:#2c3e50}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#2c3e50}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-actions{margin-top:2rem}.form-actions button{padding:.75rem 2rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.form-actions button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.form-actions button:disabled{opacity:.6;cursor:not-allowed}.import-section{background:#fff;padding:2rem;border-radius:12px;border:2px solid #e9ecef;margin-bottom:2rem}.import-section h3{margin:0 0 1.5rem;color:#2c3e50}.sync-mode-selector{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.sync-mode-selector .checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;margin-bottom:.5rem}.sync-mode-selector input[type=checkbox]{width:20px;height:20px;cursor:pointer}.sync-mode-selector .default-badge{display:inline-block;margin-left:.5rem;padding:.25rem .5rem;background:#667eea;color:#fff;font-size:.75rem;font-weight:600;border-radius:4px}.sync-mode-selector .hint{display:block;color:#6c757d;font-size:.9rem;margin-left:2rem}.import-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.import-btn{padding:1rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}.import-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.import-btn:disabled{opacity:.6;cursor:not-allowed}.import-btn.primary{background:#667eea;color:#fff}.import-btn.primary:hover:not(:disabled){background:#5568d3}.import-btn.secondary{background:#6c757d;color:#fff}.import-btn.secondary:hover:not(:disabled){background:#5a6268}.import-btn.success{background:#28a745;color:#fff}.import-btn.success:hover:not(:disabled){background:#218838}.importing-indicator{text-align:center;padding:2rem}.spinner{border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.config-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:1px solid #e9ecef}.btn-secondary,.btn-danger{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.btn-secondary:disabled,.btn-danger:disabled{opacity:.6;cursor:not-allowed}.info-panel{background:#e7f3ff;border-left:4px solid #667eea;padding:1.5rem;border-radius:8px;margin-top:2rem}.info-panel h4{margin:0 0 1rem;color:#2c3e50}.info-panel ul{margin:0;padding-left:1.5rem}.info-panel li{margin-bottom:.5rem;color:#495057;line-height:1.6}.badge{display:inline-block;padding:.35rem .65rem;font-size:.85rem;font-weight:600;line-height:1;border-radius:6px;white-space:nowrap}.badge-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.badge-warning{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7}.badge-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.badge-info{background-color:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.badge-secondary{background-color:#e2e3e5;color:#383d41;border:1px solid #d6d8db}.table-responsive{overflow-x:auto;margin-top:1rem}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000000d}.data-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.data-table thead th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.data-table tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .2s}.data-table tbody tr:hover{background-color:#f8f9fa}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody td{padding:1rem;color:#495057;font-size:.95rem}.data-table tbody td strong{color:#2c3e50}.message.warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}@media (max-width: 768px){.stats-grid,.import-actions{grid-template-columns:1fr}.config-actions{flex-direction:column}.data-table{font-size:.85rem}.data-table thead th,.data-table tbody td{padding:.75rem .5rem}}.recordatorios-tab{padding:1.5rem}.loading-indicator{text-align:center;padding:3rem;color:#7f8c8d}.recordatorios-header{margin-bottom:1.5rem}.recordatorios-header h2{margin:0 0 .5rem;color:#2c3e50}.recordatorios-header p{margin:0;color:#7f8c8d}.message{padding:1rem;border-radius:8px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.message.warning{background-color:#fff3cd;border:1px solid #ffc107;color:#856404}.message button{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:0;color:inherit;opacity:.6}.message button:hover{opacity:1}.scheduler-status{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.scheduler-status.running{background-color:#d4edda;border:1px solid #c3e6cb}.scheduler-status.stopped{background-color:#f8d7da;border:1px solid #f5c6cb}.scheduler-status.paused{background-color:#fff3cd;border:1px solid #ffc107}.scheduler-status .status-icon{font-size:1.2rem}.scheduler-status .status-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.scheduler-status .status-info span{font-size:.85rem;color:#666}.scheduler-status .paused-warning{color:#856404;font-weight:500}.btn-scheduler-toggle{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;font-weight:500;transition:all .2s;white-space:nowrap}.btn-scheduler-toggle.btn-pause{background:#ffc107;color:#333}.btn-scheduler-toggle.btn-pause:hover:not(:disabled){background:#e0a800}.btn-scheduler-toggle.btn-resume{background:#28a745;color:#fff}.btn-scheduler-toggle.btn-resume:hover:not(:disabled){background:#218838}.btn-scheduler-toggle:disabled{opacity:.6;cursor:not-allowed}.section-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:2px solid #e0e0e0}.section-tabs button{padding:.75rem 1.5rem;border:none;background:none;cursor:pointer;font-size:.95rem;color:#666;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.section-tabs button:hover{color:#3498db}.section-tabs button.active{color:#3498db;border-bottom-color:#3498db;font-weight:500}.section-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.section-card h3{margin:0 0 1rem;color:#2c3e50;font-size:1.1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#2c3e50}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3498db}.form-group textarea{resize:vertical;font-family:inherit}.field-hint{display:block;margin-top:.25rem;font-size:.8rem;color:#888;font-style:italic}.form-row{margin-bottom:1rem}.form-row.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;margin:0}.checkbox-label h3{margin:0}.button-row{margin-top:1rem}.button-row.main-actions{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3498db4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#f8f9fa;color:#2c3e50;border:1px solid #ddd;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s}.btn-secondary:hover:not(:disabled){background:#e9ecef}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-link{background:none;border:none;color:#3498db;cursor:pointer;padding:0;font-size:.9rem;text-decoration:underline}.btn-link:hover{color:#2980b9}.btn-test{background:#f39c12;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.85rem;cursor:pointer;transition:background .2s}.btn-test:hover:not(:disabled){background:#e67e22}.btn-test:disabled{opacity:.6;cursor:not-allowed}.template-card{border-left:4px solid #3498db}.template-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.variables-help{margin-bottom:1.5rem}.variables-list{background:#f8f9fa;padding:1rem;border-radius:6px;font-size:.85rem;margin-top:.5rem;white-space:pre-wrap;color:#666}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.preview-actions{display:flex;gap:.5rem}.preview-explanation{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:1rem;margin-bottom:1.5rem;font-size:.9rem}.preview-explanation p{margin:0 0 .5rem;color:#555}.preview-explanation p:last-child{margin-bottom:0;color:#888;font-style:italic}.preview-explanation ul{margin:.5rem 0;padding-left:1.5rem}.preview-explanation li{margin-bottom:.25rem;color:#666}.preview-summary{color:#666;margin-bottom:1rem}.preview-list{display:flex;flex-direction:column;gap:1rem}.preview-item{border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.preview-item-header{background:#f8f9fa;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e0e0}.preview-item-header .factura{font-weight:500;color:#2c3e50}.preview-item-content{padding:1rem}.preview-item-content p{margin:0 0 .5rem;font-size:.9rem}.preview-item-content p:last-child{margin-bottom:0}.tipo-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:uppercase}.tipo-badge.previo{background:#e3f2fd;color:#1565c0}.tipo-badge.dia_vencimiento{background:#fff3e0;color:#ef6c00}.tipo-badge.primer{background:#fce4ec;color:#c2185b}.tipo-badge.posterior{background:#f3e5f5;color:#7b1fa2}.tipo-badge.pago_recibido{background:#e8f5e9;color:#2e7d32}.template-description{background:#f0f7ff;border:1px solid #b3d7ff;border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;color:#06c}.historial-table{width:100%;border-collapse:collapse}.historial-table th,.historial-table td{padding:.75rem;text-align:left;border-bottom:1px solid #e0e0e0}.historial-table th{background:#f8f9fa;font-weight:500;color:#2c3e50}.historial-table tr:last-child td{border-bottom:none}.historial-table tr.error{background:#fff5f5}.status-success{color:#27ae60;font-weight:500}.status-error{color:#e74c3c;font-weight:500;cursor:help}.no-data{text-align:center;color:#7f8c8d;padding:2rem}@media (max-width: 768px){.form-row.two-cols{grid-template-columns:1fr}.section-tabs{flex-wrap:wrap}.section-tabs button{flex:1;min-width:100px}.preview-header{flex-direction:column;gap:1rem;align-items:stretch}.preview-actions{justify-content:flex-end}.historial-table{font-size:.85rem}.historial-table th,.historial-table td{padding:.5rem}}.facturacion-page{padding:2rem;max-width:1400px;margin:0 auto}.facturacion-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #ecf0f1;padding-bottom:0}.facturacion-tabs .tab{padding:1rem 1.5rem;background:none;border:none;font-size:1rem;font-weight:500;color:#7f8c8d;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s ease;position:relative;bottom:-2px}.facturacion-tabs .tab:hover{color:#3498db;background:#f8f9fa}.facturacion-tabs .tab.active{color:#3498db;border-bottom-color:#3498db;font-weight:600}.facturacion-content{background:#fff;border-radius:8px;padding:3rem;box-shadow:0 2px 4px #0000001a;min-height:400px}.placeholder-content{text-align:center;max-width:800px;margin:0 auto}.placeholder-icon{font-size:5rem;margin-bottom:1.5rem;opacity:.8}.placeholder-content h2{font-size:2rem;color:#2c3e50;margin-bottom:1rem}.placeholder-content>p{font-size:1.1rem;color:#7f8c8d;margin-bottom:2rem}.feature-list{text-align:left;max-width:600px;margin:2rem auto;background:#f8f9fa;padding:2rem;border-radius:8px}.feature-item{display:flex;align-items:flex-start;gap:1rem;padding:.75rem 0;border-bottom:1px solid #ecf0f1}.feature-item:last-child{border-bottom:none}.feature-item .icon{font-size:1.2rem;flex-shrink:0}.feature-item span:last-child{color:#34495e;line-height:1.6}.coming-soon{margin-top:2rem;padding:1rem 2rem;background:#fff3cd;border-left:4px solid #ffc107;color:#856404;font-weight:500;border-radius:4px}.quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:2rem}.stat-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:1rem;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.stat-icon{font-size:2.5rem;opacity:.8}.stat-info{flex:1}.stat-label{font-size:.85rem;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.stat-value{font-size:1.8rem;font-weight:700;color:#2c3e50;margin-bottom:.25rem}.stat-period{font-size:.85rem;color:#95a5a6}.info-footer{margin-top:3rem;padding:2rem;background:#e8f4f8;border-left:4px solid #3498db;border-radius:4px}.info-footer p{margin-bottom:.75rem;color:#2c3e50;line-height:1.6}.info-footer p:last-child{margin-bottom:0}.info-footer a{color:#3498db;text-decoration:none;font-weight:600}.info-footer a:hover{text-decoration:underline}@media (max-width: 768px){.facturacion-page{padding:1rem}.facturacion-tabs{flex-wrap:wrap}.facturacion-tabs .tab{flex:1;min-width:120px}.facturacion-content{padding:1.5rem}.placeholder-icon{font-size:3rem}.quick-stats{grid-template-columns:1fr}}.pdf-uploader{display:flex;flex-direction:column;gap:30px}.upload-section{display:flex;flex-direction:column;gap:20px}.upload-section h2{color:#333;margin-bottom:10px}.file-input-wrapper{position:relative}.file-input{display:none}.file-input-label{display:inline-block;padding:15px 30px;background:#667eea;color:#fff;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #667eea4d}.file-input-label:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn{padding:12px 24px;border:none;border-radius:6px;font-weight:600;font-size:1rem;transition:all .3s;box-shadow:0 2px 8px #0000001a}.btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#667eea;color:#fff}.btn-secondary{background:#6c757d;color:#fff}.btn-success{background:#28a745;color:#fff}.btn-small{padding:6px 12px;font-size:.875rem}.btn-large{padding:16px 32px;font-size:1.1rem}.analysis-section{display:flex;flex-direction:column;gap:20px}.help-text{color:#6c757d;font-size:.95rem;margin-bottom:10px}.analyzed-files{display:flex;flex-direction:column;gap:20px}.analyzed-file-card{border:2px solid #e9ecef;border-radius:8px;padding:20px;background:#f8f9fa;transition:all .3s}.analyzed-file-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.file-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.file-info{display:flex;align-items:center;gap:15px}.file-info h3{color:#333;font-size:1.1rem;margin:0}.confidence-badge{padding:4px 12px;border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;text-transform:uppercase}.file-details{display:flex;flex-direction:column;gap:12px}.detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #dee2e6}.detail-row .label{font-weight:600;color:#495057}.detail-row .value{color:#212529}.detail-row .amount{font-weight:600;color:#28a745}.detail-row .amount.highlight{font-size:1.1rem;color:#dc3545}.error-message{padding:15px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24}.info-message{padding:10px;background:#d1ecf1;border:1px solid #bee5eb;border-radius:6px;color:#0c5460;font-size:.9rem}.edit-form{display:grid;grid-template-columns:1fr 1fr;gap:15px;padding:15px;background:#fff;border-radius:6px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group input,.form-group select{padding:8px 12px;border:2px solid #dee2e6;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.confirmation-actions{margin-top:15px;padding-top:15px;border-top:2px solid #dee2e6}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:600;color:#495057}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.process-actions{display:flex;justify-content:center;margin-top:20px}.results-section{display:flex;flex-direction:column;gap:20px}.results-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.summary-stat{padding:20px;border-radius:8px;text-align:center;box-shadow:0 2px 8px #0000001a}.summary-stat.success{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.summary-stat.error{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff}.summary-stat.skipped{background:linear-gradient(135deg,#6c757d,#5a6268);color:#fff}.stat-value{display:block;font-size:2.5rem;font-weight:700;margin-bottom:5px}.stat-label{display:block;font-size:.9rem;opacity:.9}.results-list{display:flex;flex-direction:column;gap:15px}.result-card{padding:15px;border-radius:6px;border:2px solid}.result-card.success{background:#d4edda;border-color:#c3e6cb}.result-card.error{background:#f8d7da;border-color:#f5c6cb}.result-card.skipped{background:#e2e3e5;border-color:#d6d8db}.result-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.result-icon{font-size:1.5rem}.result-filename{font-weight:600;color:#333}.result-details{margin-left:35px;color:#495057}.result-details p{margin:5px 0}.result-message{margin-left:35px;color:#721c24;font-size:.9rem}.chat-analytics{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:1.5rem;margin-bottom:2rem;color:#fff}.chat-analytics h3{margin:0 0 1rem;font-size:1.25rem;display:flex;align-items:center;gap:.5rem}.chat-input-container{display:flex;gap:.5rem;margin-bottom:1rem}.chat-input{flex:1;padding:.75rem 1rem;border:none;border-radius:8px;font-size:1rem;background:#fffffff2;color:#333}.chat-input::placeholder{color:#888}.chat-input:focus{outline:none;box-shadow:0 0 0 3px #ffffff4d}.chat-send-btn{padding:.75rem 1.25rem;border:none;border-radius:8px;background:#fff;color:#667eea;font-weight:600;cursor:pointer;transition:all .2s}.chat-send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #0003}.chat-send-btn:disabled{opacity:.6;cursor:not-allowed}.chat-categories{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.chat-category-btn{padding:.4rem .8rem;border:1px solid rgba(255,255,255,.4);border-radius:20px;background:transparent;color:#fff;font-size:.85rem;cursor:pointer;transition:all .2s}.chat-category-btn:hover{background:#fff3}.chat-category-btn.active{background:#ffffff4d;border-color:#fff}.chat-suggestions{display:flex;gap:.5rem;flex-wrap:wrap}.chat-suggestion{padding:.5rem .75rem;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;font-size:.85rem;cursor:pointer;transition:all .2s}.chat-suggestion:hover{background:#ffffff40;border-color:#fff}.chat-history{margin-top:1rem;max-height:400px;overflow-y:auto}.chat-message{padding:1rem;border-radius:8px;margin-bottom:.75rem}.chat-message.user{background:#ffffff26;margin-left:2rem}.chat-message.assistant{background:#fffffff2;color:#333;margin-right:2rem}.chat-message-header{display:flex;align-items:center;gap:.5rem;font-weight:600;margin-bottom:.5rem;font-size:.85rem}.chat-message.user .chat-message-header{color:#fffc}.chat-message.assistant .chat-message-header{color:#667eea}.chat-message-content{line-height:1.5}.chat-message-content strong{font-weight:600}.chat-source{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e0e0e0;font-size:.8rem;color:#666}.chat-source-toggle{display:flex;align-items:center;gap:.25rem;cursor:pointer;color:#667eea;font-weight:500}.chat-source-toggle:hover{text-decoration:underline}.chat-source-details{margin-top:.5rem;padding:.5rem;background:#f5f5f5;border-radius:4px;font-size:.75rem}.chat-warnings{margin-top:.5rem;padding:.5rem;background:#fff3cd;border-radius:4px;font-size:.8rem;color:#856404}.chat-loading{display:flex;align-items:center;gap:.5rem;padding:1rem;background:#fffffff2;border-radius:8px;color:#667eea;margin-right:2rem}.chat-loading-dots{display:flex;gap:4px}.chat-loading-dots span{width:8px;height:8px;background:#667eea;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.chat-loading-dots span:nth-child(1){animation-delay:-.32s}.chat-loading-dots span:nth-child(2){animation-delay:-.16s}.chat-loading-dots span:nth-child(3){animation-delay:0}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chat-confidence{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;margin-left:.5rem}.chat-confidence.high{background:#d4edda;color:#155724}.chat-confidence.medium{background:#fff3cd;color:#856404}.chat-confidence.low{background:#f8d7da;color:#721c24}@media (max-width: 768px){.chat-analytics{padding:1rem}.chat-input-container{flex-direction:column}.chat-message.user{margin-left:0}.chat-message.assistant{margin-right:0}}.tab-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#7f8c8d}.tab-loading .spinner{width:40px;height:40px;border:4px solid #ecf0f1;border-top-color:#3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.tab-header{margin-bottom:2rem}.tab-header h2{font-size:1.5rem;color:#2c3e50;margin-bottom:.5rem}.tab-header p{color:#7f8c8d}.message{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-radius:4px;margin-bottom:1.5rem}.message.success{background:#d4edda;border-left:4px solid #28a745;color:#155724}.message.error{background:#f8d7da;border-left:4px solid #dc3545;color:#721c24}.message.warning{background:#fff3cd;border-left:4px solid #ffc107;color:#856404}.message .close-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;opacity:.5;padding:0 .5rem}.message .close-btn:hover{opacity:1}.connection-status{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-radius:8px;margin-bottom:2rem}.connection-status.connected{background:#e8f5e9;border:1px solid #a5d6a7}.connection-status.disconnected{background:#ffebee;border:1px solid #ef9a9a}.status-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.status-dot.connected{background:#4caf50;box-shadow:0 0 8px #4caf5080}.status-dot.disconnected{background:#f44336}.status-info{flex:1}.status-info small{color:#7f8c8d}.config-form,.filter-form{max-width:500px;margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:#2c3e50}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 2px #3498db33}.form-group small{display:block;margin-top:.25rem;color:#7f8c8d;font-size:.85rem}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn-primary:hover:not(:disabled){background:#2980b9}.btn-primary:disabled{background:#bdc3c7;cursor:not-allowed}.btn-secondary{padding:.75rem 1.5rem;background:#ecf0f1;color:#2c3e50;border:1px solid #bdc3c7;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s ease}.btn-secondary:hover:not(:disabled){background:#dfe6e9}.btn-danger{padding:.75rem 1.5rem;background:#e74c3c;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s ease}.btn-danger:hover:not(:disabled){background:#c0392b}.btn-success{padding:.75rem 1.5rem;background:#27ae60;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s ease}.btn-success:hover:not(:disabled){background:#219a52}.config-actions{margin-top:2rem}.current-config{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8f9fa;border-radius:4px;margin-bottom:1rem}.current-config code{background:#e9ecef;padding:.25rem .5rem;border-radius:4px;font-family:monospace}.action-buttons{display:flex;gap:1rem}.info-panel{margin-top:2rem;padding:1.5rem;background:#e8f4f8;border-left:4px solid #3498db;border-radius:4px}.info-panel h4{margin-bottom:.75rem;color:#2c3e50}.info-panel ul{margin:0;padding-left:1.5rem;color:#34495e}.info-panel li{margin-bottom:.5rem}.info-panel code{background:#3498db1a;padding:.125rem .375rem;border-radius:3px;font-family:monospace;font-size:.9rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;border-left:4px solid #3498db}.stat-card.positive{border-left-color:#27ae60}.stat-card.negative{border-left-color:#e74c3c}.stat-card.warning{border-left-color:#f39c12}.stat-card .stat-label{font-size:.85rem;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.stat-card .stat-value{font-size:2rem;font-weight:700;color:#2c3e50}.stat-card .stat-detail{font-size:.85rem;color:#95a5a6;margin-top:.25rem}.data-table{width:100%;border-collapse:collapse;margin-top:1rem}.data-table th,.data-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #ecf0f1}.data-table th{background:#f8f9fa;font-weight:600;color:#2c3e50;text-transform:uppercase;font-size:.8rem;letter-spacing:.5px}.data-table tr:hover{background:#f8f9fa}.data-table .status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500}.data-table .status-badge.active{background:#d4edda;color:#155724}.data-table .status-badge.inactive,.data-table .status-badge.shutoff{background:#f8d7da;color:#721c24}.data-table .status-badge.pending{background:#fff3cd;color:#856404}.resource-section{margin-bottom:2rem}.resource-section h3{font-size:1.25rem;color:#2c3e50;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.resource-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.resource-card{background:#fff;border:1px solid #ecf0f1;border-radius:8px;padding:1rem;transition:box-shadow .2s ease}.resource-card:hover{box-shadow:0 4px 8px #0000001a}.resource-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.resource-card-name{font-weight:600;color:#2c3e50;word-break:break-word}.resource-card-details{font-size:.9rem;color:#7f8c8d}.resource-card-details p{margin:.25rem 0}.resource-card-details strong{color:#34495e}.date-filters{display:flex;gap:1rem;align-items:flex-end;margin-bottom:2rem;flex-wrap:wrap}.date-filters .form-group{margin-bottom:0}.date-filters input[type=date],.date-filters input[type=month]{width:auto}.column-filters{display:flex;gap:1rem;align-items:flex-end;margin-bottom:1rem;flex-wrap:wrap}.column-filter{display:flex;align-items:center;gap:.5rem}.column-filter label{font-size:.85rem;font-weight:500;color:#7f8c8d;white-space:nowrap}.column-filter select{padding:.4rem .5rem;border:1px solid #ddd;border-radius:4px;font-size:.85rem;max-width:240px}.sortable-table .sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sortable-table .sortable-th:hover{background:#ecf0f1}.costos-summary-table{max-width:600px}.costos-summary-table tfoot td{border-top:2px solid #2c3e50}.sync-actions{display:flex;gap:1rem;align-items:center;margin-bottom:2rem}.sync-logs{margin-top:2rem}.sync-logs h3{margin-bottom:1rem;color:#2c3e50}.sync-log-entry{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-bottom:1px solid #ecf0f1}.sync-log-entry:last-child{border-bottom:none}.sync-log-icon{font-size:1.5rem}.sync-log-details{flex:1}.sync-log-details .timestamp{font-size:.85rem;color:#7f8c8d}.sync-log-details .status{font-weight:500;margin:.25rem 0}.sync-log-details .status.success{color:#27ae60}.sync-log-details .status.error{color:#e74c3c}.sync-log-details .info{font-size:.9rem;color:#7f8c8d}.empty-state{text-align:center;padding:3rem;color:#7f8c8d}.empty-state .icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state p{margin-bottom:.5rem}.resource-type-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.5rem;background:#f8f9fa;border-radius:8px}.resource-type-tabs button{padding:.75rem 1.5rem;background:transparent;border:none;border-radius:6px;font-size:.95rem;font-weight:500;color:#7f8c8d;cursor:pointer;transition:all .2s ease}.resource-type-tabs button:hover{background:#ecf0f1;color:#2c3e50}.resource-type-tabs button.active{background:#3498db;color:#fff}.trend{font-size:.9rem;font-weight:500}.trend.up{color:#e74c3c}.trend.down{color:#27ae60}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr}.date-filters{flex-direction:column;align-items:stretch}.date-filters .form-group,.date-filters input[type=date]{width:100%}.data-table{display:block;overflow-x:auto}.resource-cards{grid-template-columns:1fr}.action-buttons{flex-direction:column}.sync-actions{flex-direction:column;align-items:stretch}}.infraestructura-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;margin-bottom:.5rem;color:#2c3e50}.page-header .subtitle{color:#7f8c8d;font-size:1rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#7f8c8d}.loading-container .spinner{width:40px;height:40px;border:4px solid #ecf0f1;border-top-color:#3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.infraestructura-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #ecf0f1;padding-bottom:0}.infraestructura-tabs .tab{padding:1rem 1.5rem;background:none;border:none;font-size:1rem;font-weight:500;color:#7f8c8d;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s ease;position:relative;bottom:-2px}.infraestructura-tabs .tab:hover:not(:disabled){color:#3498db;background:#f8f9fa}.infraestructura-tabs .tab.active{color:#3498db;border-bottom-color:#3498db;font-weight:600}.infraestructura-tabs .tab:disabled{color:#bdc3c7;cursor:not-allowed}.infraestructura-content{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a;min-height:400px}.needs-config-message{text-align:center;padding:4rem 2rem}.needs-config-message .config-icon{font-size:4rem;color:#bdc3c7;margin-bottom:1rem}.needs-config-message h3{font-size:1.5rem;color:#2c3e50;margin-bottom:.5rem}.needs-config-message p{color:#7f8c8d;margin-bottom:1.5rem;max-width:400px;margin-left:auto;margin-right:auto}.btn-primary{padding:.75rem 1.5rem;background:#3498db;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s ease}.btn-primary:hover{background:#2980b9}@media (max-width: 768px){.infraestructura-page{padding:1rem}.infraestructura-tabs{flex-wrap:wrap}.infraestructura-tabs .tab{flex:1;min-width:100px;font-size:.9rem;padding:.75rem 1rem}.infraestructura-content{padding:1.5rem}}.rentab-tab .tab-header{margin-bottom:2rem}.rentab-tab .tab-header h2{font-size:1.5rem;color:#2c3e50;margin-bottom:.5rem}.rentab-tab .tab-header p{color:#7f8c8d}.rentab-tab .tab-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#7f8c8d}.rentab-tab .tab-loading .spinner{width:40px;height:40px;border:4px solid #ecf0f1;border-top-color:#3498db;border-radius:50%;animation:rentab-spin 1s linear infinite;margin-bottom:1rem}@keyframes rentab-spin{to{transform:rotate(360deg)}}.rentab-tab .message{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-radius:4px;margin-bottom:1.5rem}.rentab-tab .message.success{background:#d4edda;border-left:4px solid #28a745;color:#155724}.rentab-tab .message.error{background:#f8d7da;border-left:4px solid #dc3545;color:#721c24}.rentab-tab .message .close-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;opacity:.5;padding:0 .5rem}.rentab-tab .message .close-btn:hover{opacity:1}.rentab-tab .form-group{margin-bottom:1.5rem}.rentab-tab .form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:#2c3e50}.rentab-tab .form-group input,.rentab-tab .form-group select,.rentab-tab .form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.rentab-tab .form-group input:focus,.rentab-tab .form-group select:focus,.rentab-tab .form-group textarea:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 2px #3498db33}.rentab-tab .form-group small{display:block;margin-top:.25rem;color:#7f8c8d;font-size:.85rem}.rentab-tab .form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.rentab-tab .form-row .form-group{margin-bottom:0}.rentab-tab .form-actions{display:flex;gap:1rem;margin-top:1.5rem}.rentab-tab .btn-primary{padding:.75rem 1.5rem;background:#3498db;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s ease}.rentab-tab .btn-primary:hover:not(:disabled){background:#2980b9}.rentab-tab .btn-primary:disabled{background:#bdc3c7;cursor:not-allowed}.rentab-tab .btn-secondary{padding:.75rem 1.5rem;background:#ecf0f1;color:#2c3e50;border:1px solid #bdc3c7;border-radius:4px;font-size:1rem;cursor:pointer}.rentab-tab .btn-secondary:hover:not(:disabled){background:#dfe6e9}.rentab-tab .btn-danger{padding:.5rem 1rem;background:#e74c3c;color:#fff;border:none;border-radius:4px;font-size:.9rem;cursor:pointer}.rentab-tab .btn-danger:hover{background:#c0392b}.rentab-tab .btn-success{padding:.75rem 1.5rem;background:#27ae60;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.rentab-tab .btn-success:hover{background:#219a52}.rentab-tab .btn-sm{padding:.4rem .8rem;font-size:.85rem}.rentab-tab .data-table{width:100%;border-collapse:collapse;margin-top:1rem}.rentab-tab .data-table th,.rentab-tab .data-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #ecf0f1}.rentab-tab .data-table th{background:#f8f9fa;font-weight:600;color:#2c3e50;text-transform:uppercase;font-size:.8rem;letter-spacing:.5px}.rentab-tab .data-table tr:hover{background:#f8f9fa}.rentab-tab .data-table .actions-cell{white-space:nowrap;display:flex;gap:.5rem}.rentab-tab .badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500}.rentab-tab .badge.premium{background:#e8d5f5;color:#6c3483}.rentab-tab .badge.flex{background:#d5f5e3;color:#1e8449}.rentab-tab .badge.go{background:#fdebd0;color:#d35400}.rentab-tab .badge.activo{background:#d4edda;color:#155724}.rentab-tab .badge.ignorar{background:#e2e3e5;color:#383d41}.rentab-tab .badge.churn{background:#f8d7da;color:#721c24}.rentab-tab .pricing-subtabs{display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.5rem;background:#f8f9fa;border-radius:8px}.rentab-tab .pricing-subtabs button{padding:.75rem 1.5rem;background:transparent;border:none;border-radius:6px;font-size:.95rem;font-weight:500;color:#7f8c8d;cursor:pointer;transition:all .2s ease}.rentab-tab .pricing-subtabs button:hover{background:#ecf0f1;color:#2c3e50}.rentab-tab .pricing-subtabs button.active{background:#3498db;color:#fff}.rentab-tab .inline-input{padding:.4rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;width:100px}.rentab-tab .inline-input:focus{border-color:#3498db;outline:none}.rentab-tab .empty-state{text-align:center;padding:3rem;color:#7f8c8d}.rentab-tab .empty-state .icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.rentab-tab .stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.rentab-tab .stat-card{background:#fff;border-radius:8px;padding:1.25rem;box-shadow:0 2px 4px #0000001a;border-left:4px solid #3498db}.rentab-tab .stat-card .stat-label{font-size:.8rem;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.rentab-tab .stat-card .stat-value{font-size:1.75rem;font-weight:700;color:#2c3e50;margin-top:.25rem}.rentab-tab .config-form{max-width:600px}.rentab-tab .toolbar{display:flex;gap:1rem;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap}.rentab-tab .toolbar select{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.rentab-tab .add-form-panel{background:#f8f9fa;border:1px solid #ecf0f1;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.rentab-tab .add-form-panel h3{margin-bottom:1rem;color:#2c3e50}@media (max-width: 768px){.rentab-tab .form-row{grid-template-columns:1fr}.rentab-tab .data-table{display:block;overflow-x:auto}.rentab-tab .stats-row{grid-template-columns:1fr}.rentab-tab .toolbar{flex-direction:column;align-items:stretch}.rentab-tab .pricing-subtabs{flex-wrap:wrap}}.rentabilidad-page{padding:2rem;max-width:1400px;margin:0 auto}.rentabilidad-page .page-header{margin-bottom:2rem}.rentabilidad-page .page-header h1{font-size:2rem;margin-bottom:.5rem;color:#2c3e50}.rentabilidad-page .page-header .subtitle{color:#7f8c8d;font-size:1rem}.rentabilidad-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #ecf0f1;padding-bottom:0}.rentabilidad-tabs .tab{padding:1rem 1.5rem;background:none;border:none;font-size:1rem;font-weight:500;color:#7f8c8d;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s ease;position:relative;bottom:-2px}.rentabilidad-tabs .tab:hover{color:#3498db;background:#f8f9fa}.rentabilidad-tabs .tab.active{color:#3498db;border-bottom-color:#3498db;font-weight:600}.rentabilidad-content{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a;min-height:400px}@media (max-width: 768px){.rentabilidad-page{padding:1rem}.rentabilidad-tabs{flex-wrap:wrap}.rentabilidad-tabs .tab{flex:1;min-width:80px;font-size:.9rem;padding:.75rem 1rem}.rentabilidad-content{padding:1.5rem}}.simulacion-tab{padding:1rem}.simulacion-header{margin-bottom:1.5rem}.simulacion-warning{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px dashed #f59e0b;border-radius:12px;color:#92400e;font-weight:600;font-size:1rem}.warning-icon{font-size:1.5rem}.escenarios-section{margin-bottom:2rem}.escenarios-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.escenarios-header h3{margin:0;color:#374151}.escenarios-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.escenario-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease}.escenario-card:hover{box-shadow:0 4px 12px #0000001a}.escenario-card.active{border-width:3px;box-shadow:0 4px 12px #00000026}.escenario-color{width:8px;height:100%;min-height:50px;border-radius:4px}.escenario-info{flex:1}.escenario-info h4{margin:0 0 .25rem;color:#1f2937}.escenario-info p{margin:0;font-size:.85rem;color:#6b7280}.escenario-actions{display:flex;gap:.25rem}.escenario-actions button{padding:.25rem .5rem;background:none;border:none;cursor:pointer;font-size:1rem;opacity:.6;transition:opacity .2s}.escenario-actions button:hover{opacity:1}.proyeccion-section{padding:1.5rem;background:#fff;border:3px solid;border-radius:12px;margin-bottom:2rem}.proyeccion-section h3{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;color:#374151}.color-dot{width:12px;height:12px;border-radius:50%}.proyeccion-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.proyeccion-card{padding:1rem;background:#f9fafb;border-radius:8px;text-align:center}.proyeccion-label{font-size:.85rem;color:#6b7280;margin-bottom:.5rem}.proyeccion-value{font-size:1.75rem;font-weight:700}.proyeccion-value.positive{color:#059669}.proyeccion-value.negative{color:#dc2626}.proyeccion-secondary{font-size:.9rem;color:#10b981;margin-top:.25rem}.gastos-simulados-section{margin-bottom:2rem}.gastos-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.gastos-header h3{margin:0;color:#374151}.badge{display:inline-block;padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:600}.badge.recurrente{background:#dbeafe;color:#1e40af}.badge.unico{background:#f3f4f6;color:#6b7280}.monto-ars{font-weight:700;color:#06b6d4}.monto-usd{font-size:.85rem;color:#10b981}.monto-clp{font-size:.85rem;color:#f59e0b}.action-buttons{display:flex;gap:.25rem;justify-content:center}.btn-convertir{padding:.25rem .5rem;background:#10b981;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:600;transition:background .2s}.btn-convertir:hover{background:#059669}.btn-edit{padding:.25rem .5rem;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer}.btn-delete{padding:.25rem .5rem;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer}.color-picker{display:flex;gap:.5rem;flex-wrap:wrap}.color-option{width:32px;height:32px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .2s,border-color .2s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:#1f2937}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.recurrencia-section{padding:1rem;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin-top:.5rem}.modal-wide{max-width:600px}.empty-state{text-align:center;padding:2rem;background:#f9fafb;border-radius:8px;color:#6b7280}@media (max-width: 768px){.escenarios-grid,.proyeccion-cards{grid-template-columns:1fr}.form-row{flex-direction:column}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f7fa;color:#333}.app{display:flex;flex-direction:column;min-height:100vh}.main-nav{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem 2rem;box-shadow:0 4px 12px #0000001a;display:flex;flex-wrap:wrap;align-items:center;gap:1.5rem}.main-nav h1{font-size:1.8rem;margin-right:auto}.nav-links{display:flex;gap:1.5rem;flex-wrap:wrap}.nav-links a{color:#fff;text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:background .3s}.nav-links a:hover{background:#fff3}.main-content{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:2rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h2{font-size:2rem;color:#333}.month-selector{display:flex;align-items:center;gap:1rem;background:#fff;padding:.5rem 1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.month-selector button{background:#667eea;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:1.2rem;transition:background .3s}.month-selector button:hover{background:#5568d3}.month-selector span{font-weight:600;font-size:1.1rem;color:#333}.btn-primary{background:#667eea;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary:hover{background:#5568d3;transform:translateY(-2px)}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 12px #00000014;transition:transform .3s}.card:hover{transform:translateY(-4px)}.card h3{font-size:1rem;color:#666;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.card .amount{font-size:2.5rem;font-weight:700;margin:0}.card.ingresos .amount{color:#28a745}.card.gastos .amount{color:#dc3545}.card.balance.positive .amount{color:#28a745}.card.balance.negative .amount{color:#dc3545}.table-container{background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:#f8f9fa}.data-table th{padding:1rem;text-align:left;font-weight:600;color:#495057;border-bottom:2px solid #dee2e6}.data-table td{padding:1rem;border-bottom:1px solid #f1f3f5}.data-table tbody tr:hover{background:#f8f9fa}.data-table .amount{font-weight:600}.data-table .positive{color:#28a745}.data-table .negative{color:#dc3545}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.badge.pendiente{background:#fff3cd;color:#856404}.badge.pagado{background:#d4edda;color:#155724}.badge.adeudado{background:#f8d7da;color:#721c24}.badge.active{background:#d4edda;color:#155724}.badge.inactive{background:#e2e3e5;color:#6c757d}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.tarjeta-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #00000014;transition:transform .3s}.tarjeta-card:hover{transform:translateY(-4px)}.tarjeta-card h3{color:#667eea;margin-bottom:.5rem}.tarjeta-card .banco{color:#666;font-size:.9rem;margin-bottom:.5rem}.tarjeta-card .cuenta{font-family:monospace;font-size:.9rem;color:#999}.empty-state{text-align:center;padding:3rem;color:#999;font-size:1.1rem}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#667eea}.quick-stats{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 12px #00000014}.quick-stats h3{margin-bottom:1rem;color:#333}.quick-stats ul{list-style:none}.quick-stats li{padding:.75rem 0;border-bottom:1px solid #f1f3f5;font-size:1.05rem}.quick-stats li:last-child{border-bottom:none}.summary-box{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;text-align:center}.summary-box h3{margin-bottom:.5rem;font-size:1rem;opacity:.9}.summary-box .total-amount{font-size:3rem;font-weight:700;margin:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e9ecef}.modal-header h3{margin:0;font-size:1.5rem;color:#333}.close-btn{background:none;border:none;font-size:2rem;color:#999;cursor:pointer;padding:0;line-height:1;transition:color .3s}.close-btn:hover{color:#333}.form{padding:2rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#495057;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:2px solid #dee2e6;border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e9ecef}.btn-secondary{background:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.btn-secondary:hover{background:#5a6268}.error-message{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;padding:.75rem 1rem;border-radius:6px;margin-top:1rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;color:#333}#root{min-height:100vh}button{cursor:pointer;font-family:inherit}input{font-family:inherit}
