body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74d3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-container-width:fit-content;--toastify-toast-width:320px;--toastify-toast-offset:16px;--toastify-toast-top:max(var(--toastify-toast-offset),env(safe-area-inset-top));--toastify-toast-right:max(var(--toastify-toast-offset),env(safe-area-inset-right));--toastify-toast-left:max(var(--toastify-toast-offset),env(safe-area-inset-left));--toastify-toast-bottom:max(var(--toastify-toast-offset),env(safe-area-inset-bottom));--toastify-toast-background:#fff;--toastify-toast-padding:14px;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-toast-bd-radius:6px;--toastify-toast-shadow:0px 4px 12px #0000001a;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error);--toastify-color-progress-bgo:0.2}.Toastify__toast-container{box-sizing:border-box;color:#fff;display:flex;flex-direction:column;position:fixed;-webkit-transform:translateZ(9999);-webkit-transform:translateZ(var(--toastify-z-index));width:-webkit-fit-content;width:fit-content;width:var(--toastify-container-width);z-index:9999;z-index:var(--toastify-z-index)}.Toastify__toast-container--top-left{left:max(16px,env(safe-area-inset-left));left:var(--toastify-toast-left);top:max(16px,env(safe-area-inset-top));top:var(--toastify-toast-top)}.Toastify__toast-container--top-center{align-items:center;left:50%;top:max(16px,env(safe-area-inset-top));top:var(--toastify-toast-top);transform:translateX(-50%)}.Toastify__toast-container--top-right{align-items:end;right:max(16px,env(safe-area-inset-right));right:var(--toastify-toast-right);top:max(16px,env(safe-area-inset-top));top:var(--toastify-toast-top)}.Toastify__toast-container--bottom-left{bottom:max(16px,env(safe-area-inset-bottom));bottom:var(--toastify-toast-bottom);left:max(16px,env(safe-area-inset-left));left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{align-items:center;bottom:max(16px,env(safe-area-inset-bottom));bottom:var(--toastify-toast-bottom);left:50%;transform:translateX(-50%)}.Toastify__toast-container--bottom-right{align-items:end;bottom:max(16px,env(safe-area-inset-bottom));bottom:var(--toastify-toast-bottom);right:max(16px,env(safe-area-inset-right));right:var(--toastify-toast-right)}.Toastify__toast{--y:0;align-items:center;border-radius:6px;border-radius:var(--toastify-toast-bd-radius);box-shadow:0 4px 12px #0000001a;box-shadow:var(--toastify-toast-shadow);box-sizing:border-box;display:flex;flex:1 1 auto;font-family:sans-serif;font-family:var(--toastify-font-family);margin-bottom:1rem;max-height:800px;max-height:var(--toastify-toast-max-height);min-height:64px;min-height:var(--toastify-toast-min-height);padding:14px;padding:var(--toastify-toast-padding);position:relative;touch-action:none;width:320px;width:var(--toastify-toast-width);word-break:break-word;z-index:0}@media only screen and (max-width:480px){.Toastify__toast-container{left:env(safe-area-inset-left);margin:0;width:100vw}.Toastify__toast-container--top-center,.Toastify__toast-container--top-left,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translateX(0)}.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translateX(0)}.Toastify__toast-container--rtl{left:auto;right:env(safe-area-inset-right)}.Toastify__toast{--toastify-toast-width:100%;border-radius:0;margin-bottom:0}}.Toastify__toast-container[data-stacked=true]{width:320px;width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s;width:100%}.Toastify__toast--stacked[data-collapsed] .Toastify__close-button,.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{bottom:100%;content:"";height:calc(var(--g)*1px);left:0;position:absolute;right:0}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{bottom:0;content:"";height:100%;left:0;position:absolute;right:0;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{-webkit-margin-end:10px;display:flex;flex-shrink:0;margin-inline-end:10px;width:22px}.Toastify--animate{animation-duration:.5s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}.Toastify__toast-theme--dark{background:#121212;background:var(--toastify-color-dark);color:#fff;color:var(--toastify-text-color-dark)}.Toastify__toast-theme--colored.Toastify__toast--default,.Toastify__toast-theme--light{background:#fff;background:var(--toastify-color-light);color:#757575;color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{background:#3498db;background:var(--toastify-color-info);color:#fff;color:var(--toastify-text-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{background:#07bc0c;background:var(--toastify-color-success);color:#fff;color:var(--toastify-text-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{background:#f1c40f;background:var(--toastify-color-warning);color:#fff;color:var(--toastify-text-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{background:#e74d3c;background:var(--toastify-color-error);color:#fff;color:var(--toastify-text-color-error)}.Toastify__progress-bar-theme--light{background:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:#bb86fc;background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:#3498db;background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:#07bc0c;background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:#f1c40f;background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:#e74d3c;background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning{background:#ffffffb3;background:var(--toastify-color-transparent)}.Toastify__close-button{background:#0000;border:none;color:#fff;cursor:pointer;opacity:.7;outline:none;padding:0;position:absolute;right:6px;top:6px;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:auto}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:focus,.Toastify__close-button:hover{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{bottom:0;height:100%;left:0;opacity:.7;position:absolute;transform-origin:left;width:100%;z-index:1}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{border-bottom-left-radius:0;left:auto;right:0;transform-origin:right}.Toastify__progress-bar--wrp{border-bottom-left-radius:6px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:6px;border-bottom-right-radius:var(--toastify-toast-bd-radius);bottom:0;height:5px;left:0;overflow:hidden;position:absolute;width:100%}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{height:100%;opacity:.2;opacity:var(--toastify-color-progress-bgo);width:100%}.Toastify__spinner{animation:Toastify__spin .65s linear infinite;border:2px solid #e0e0e0;border-color:var(--toastify-spinner-color-empty-area);border-radius:100%;border-right-color:#616161;border-right-color:var(--toastify-spinner-color);box-sizing:border-box;height:20px;width:20px}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--bottom-left,.Toastify__bounce-enter--top-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--bottom-right,.Toastify__bounce-enter--top-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--bottom-left,.Toastify__bounce-exit--top-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--bottom-right,.Toastify__bounce-exit--top-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{animation-timing-function:ease-in;opacity:0;transform:perspective(400px) rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px) rotateX(-20deg)}60%{opacity:1;transform:perspective(400px) rotateX(10deg)}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{opacity:1;transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg)}to{opacity:0;transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg)}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(110%,var(--y),0);visibility:hidden}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(-110%,var(--y),0);visibility:hidden}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(0,500px,0);visibility:hidden}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(0,-500px,0);visibility:hidden}}.Toastify__slide-enter--bottom-left,.Toastify__slide-enter--top-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--bottom-right,.Toastify__slide-enter--top-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--bottom-left,.Toastify__slide-exit--top-left{animation-duration:.3s;animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in}.Toastify__slide-exit--bottom-right,.Toastify__slide-exit--top-right{animation-duration:.3s;animation-name:Toastify__slideOutRight;animation-timing-function:ease-in}.Toastify__slide-exit--top-center{animation-duration:.3s;animation-name:Toastify__slideOutUp;animation-timing-function:ease-in}.Toastify__slide-exit--bottom-center{animation-duration:.3s;animation-name:Toastify__slideOutDown;animation-timing-function:ease-in}@keyframes Toastify__spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.emergency-indicator{align-items:center;border-radius:6px;box-shadow:0 2px 8px #0000001a;display:flex;font-size:12px;gap:8px;padding:8px 12px;position:fixed;right:10px;top:10px;transition:all .3s ease;z-index:9999}.emergency-normal{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border:1px solid #4caf50;color:#2e7d32}.emergency-active{animation:emergency-pulse 2s infinite;background:linear-gradient(135deg,#ffebee,#ffcdd2);border:1px solid #f44336;color:#c62828}@keyframes emergency-pulse{0%,to{box-shadow:0 2px 8px #f443364d}50%{box-shadow:0 4px 16px #f4433699}}.emergency-icon{font-size:16px;font-weight:700}.emergency-text{line-height:1.2}.emergency-text strong{font-weight:600}.emergency-text small{font-size:10px;opacity:.8}.alt-key-counter{animation:fade-in .2s ease;background:#333;border-radius:4px;color:#fff;font-size:12px;padding:6px 12px;position:fixed;right:10px;top:60px;z-index:10000}@keyframes fade-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.emergency-modal-overlay{align-items:center;animation:modal-fade-in .3s ease;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:99999}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.emergency-modal{animation:modal-slide-in .3s ease;background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:80vh;max-width:500px;overflow:auto;width:90%}@keyframes modal-slide-in{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.emergency-modal-header{background:linear-gradient(135deg,#f44336,#d32f2f);border-radius:12px 12px 0 0;color:#fff;padding:20px;text-align:center}.emergency-modal-header h2{font-size:24px;font-weight:700;margin:0}.emergency-modal-body{line-height:1.6;padding:24px}.emergency-modal-body p{margin:0 0 16px}.emergency-modal-body ul{margin:16px 0;padding-left:20px}.emergency-modal-body li{margin:8px 0}.emergency-modal-actions{border-top:1px solid #eee;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.emergency-confirm-btn{background:linear-gradient(135deg,#f44336,#d32f2f);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;min-width:160px;padding:12px 24px;transition:all .2s ease}.emergency-confirm-btn:hover:not(:disabled){background:linear-gradient(135deg,#d32f2f,#b71c1c);box-shadow:0 4px 12px #f443364d;transform:translateY(-1px)}.emergency-confirm-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.emergency-cancel-btn{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s ease}.emergency-cancel-btn:hover:not(:disabled){background:#e0e0e0;border-color:#bbb}.emergency-cancel-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.emergency-modal{margin:20px;width:95%}.emergency-modal-actions{flex-direction:column}.emergency-cancel-btn,.emergency-confirm-btn{width:100%}.emergency-indicator{font-size:11px;padding:6px 8px;right:5px;top:5px}.emergency-icon{font-size:14px}}.navigation-menu{background:#fff;border-right:1px solid #e5e7eb;box-shadow:0 0 15px #00000014;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;height:100vh;overflow-y:auto;padding:0;width:280px}.navigation-menu::-webkit-scrollbar{width:6px}.navigation-menu::-webkit-scrollbar-track{background:#f1f5f9}.navigation-menu::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.navigation-menu::-webkit-scrollbar-thumb:hover{background:#94a3b8}.menu-header-section{background:#fff;border-bottom:1px solid #e5e7eb;padding:16px 20px}.menu-header-section h3{color:#111827;font-size:1.1em;font-weight:600;letter-spacing:-.025em;margin:0 0 8px}.user-info{background:#f9fafb;border-radius:8px;display:flex;flex-direction:column;gap:6px;margin-top:12px;padding:12px 16px}.user-name{color:#6b7280;font-size:.875em}.super-admin-badge{align-self:flex-start;background:#ef4444;border-radius:12px;color:#fff;font-size:.75em;font-weight:600;letter-spacing:.5px;padding:3px 8px;text-transform:uppercase}.menu-list{list-style:none;margin:0;padding:8px 0 16px}.menu-item+.menu-item{margin-top:0}.menu-item[data-section=true]{margin-top:24px;position:relative}.menu-item[data-section=true]:before{background:#e5e7eb;content:"";height:1px;left:16px;position:absolute;right:16px;top:-12px}.menu-item{border-bottom:none;border-radius:0;margin:0;overflow:hidden}.menu-header,.menu-link{align-items:center;border-left:3px solid #0000;border-radius:0;color:#4b5563;cursor:pointer;display:flex;font-size:.875em;font-weight:400;margin:0;padding:9px 16px;text-decoration:none;transition:all .15s ease}.menu-header:hover,.menu-link:hover{background:#f3f4f6;color:#1f2937}.menu-header.active,.menu-link.active{background:#e0e7ff;border-left:3px solid #4f46e5;color:#4f46e5;font-weight:500}.menu-icon{font-size:1em;margin-right:12px;text-align:center;transition:color .15s ease;width:18px}.menu-icon,.menu-item .menu-icon{color:#6b7280}.menu-header.active .menu-icon,.menu-link.active .menu-icon{color:#4f46e5}.menu-label{flex:1 1;font-weight:500}.expand-icon{color:#9ca3af;font-size:.7em;font-weight:700;margin-left:12px;transition:transform .15s ease}.expand-icon.expanded{color:#6b7280;transform:rotate(180deg)}.submenu{border-left:2px solid #e5e7eb;list-style:none;margin:0 0 0 16px;overflow:hidden;padding:0}.submenu,.submenu .menu-link{background:#f9fafb;border-radius:0}.submenu .menu-link{border-left:3px solid #0000;color:#6b7280;font-size:.8125em;margin:0;padding:8px 16px 8px 40px}.submenu .menu-link:hover{background:#f3f4f6;color:#374151}.submenu .menu-link.active{background:#dbeafe;border-left:3px solid #3b82f6;color:#1e40af;font-weight:500}.submenu .menu-icon{color:#9ca3af;font-size:.875em}.submenu .menu-link.active .menu-icon{color:#3b82f6}.level-1 .menu-link{padding-left:60px}.no-access-message{color:#9ca3af;font-size:.875em;font-style:italic;padding:24px 20px;text-align:center}.menu-list>.menu-item:first-child .menu-header{color:#9ca3af;cursor:default;font-size:.75em;font-weight:700;letter-spacing:1px;margin-top:8px;padding:8px 16px 4px;text-transform:uppercase}.menu-list>.menu-item:first-child .menu-header:hover{background:#0000;transform:none}.submenu{animation:slideIn .2s ease-out}.no-access-message p{margin:5px 0}@media (max-width:768px){.navigation-menu{height:auto;position:relative;width:100%}.menu-list{display:none}.menu-list.mobile-open{display:block}}.header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;box-sizing:border-box;display:flex;height:70px;justify-content:space-between;left:280px!important;padding:0 20px;position:fixed!important;right:0!important;top:0!important;transition:left .3s ease;z-index:999}.header.sidebar-collapsed{left:70px!important}.header-left{gap:15px}.sidebar-toggle{background:none;border:none;border-radius:6px;color:#4b5563;cursor:pointer;font-size:18px;padding:8px;transition:all .2s ease}.sidebar-toggle:hover{background:#f3f4f6;color:#374151}.page-title{color:#1f2937}.header-right{align-items:center;display:flex}.header-actions{gap:10px}.header-btn{align-items:center;background:none;border:none;border-radius:8px;color:#4b5563;cursor:pointer;display:flex;font-size:16px;gap:8px;padding:10px;transition:all .2s ease}.header-btn:hover{background:#f3f4f6;color:#374151}.notification-btn{position:relative}.notification-badge{background:#ef4444;border-radius:10px;color:#fff;font-size:10px;font-weight:700;min-width:16px;padding:2px 6px;position:absolute;right:5px;text-align:center;top:5px}.user-menu{align-items:center;border-left:1px solid #e5e7eb;display:flex;gap:5px;margin-left:10px;padding-left:15px}.user-btn{font-size:14px}.user-name{color:#374151;font-weight:500}.logout-btn{color:#dc2626}.logout-btn:hover{background:#fef2f2;color:#dc2626}@media (max-width:768px){.header{left:0}.page-title{font-size:18px}.user-name{display:none}}.layout{background:#fff;display:flex;min-height:100vh;position:relative;width:100%}.sidebar{flex-shrink:0;min-height:100vh;transition:width .3s ease;width:280px}.sidebar.collapsed{width:70px}.main-content{display:flex;flex:1 1;flex-direction:column;height:100vh;min-height:100vh;overflow:hidden}.content,.main-content{padding:0;position:relative}.content{background:#f8fafc;box-sizing:border-box;flex:1 1;height:calc(100vh - 70px);margin-top:70px;min-height:0;overflow:auto;width:100%}.content-wrapper{height:100%;max-width:none;min-height:0;width:100%}@media (max-width:768px){.sidebar{transform:translateX(-100%);width:100%}.sidebar.open{transform:translateX(0)}.main-content,.main-content.sidebar-collapsed{margin-left:0;width:100%}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;color:#000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}.App{background:#f8fafc;min-height:100vh;width:100vw}.coming-soon{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;color:#6b7280;display:flex;font-size:18px;font-weight:500;justify-content:center;min-height:400px}.text-center{text-align:center}.text-left{text-align:left}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mt-0{margin-top:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.hidden-mobile{display:block}.hidden-desktop{display:none}@media (max-width:768px){.hidden-mobile{display:none}.hidden-desktop{display:block}}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #3b82f6;outline-offset:2px}.fade-in{animation:fadeIn .3s ease-in-out}.slide-in-left{animation:slideInLeft .3s ease-in-out}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.success-text{color:#16a34a}.warning-text{color:#d97706}.info-text{color:#2563eb}.spinner{border:2px solid #f3f4f6;border-top-color:#3b82f6;display:inline-block;height:20px;width:20px}.card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.card-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:20px 24px}.card-body{padding:24px}.card-footer{background:#f9fafb;border-top:1px solid #e5e7eb;padding:16px 24px}h1,h2,h3,h4,h5,h6{color:#1f2937;font-weight:600;line-height:1.4}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{color:#4b5563;margin-bottom:1rem}a{color:#2563eb;text-decoration:none;transition:color .2s ease}a:hover{color:#1d4ed8;text-decoration:underline}.form-control{border:1px solid #d1d5db;border-radius:8px;font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.form-control:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}@media print{.header,.no-print,.sidebar{display:none!important}.main-content{margin-left:0!important}.content{margin-top:0!important;padding:0!important}}*{-webkit-user-select:none;user-select:none}[contenteditable=true],input,select,textarea{-webkit-user-select:text;user-select:text}*,img{-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none}img{pointer-events:none}a,button,input,option,select,textarea{pointer-events:auto;-webkit-user-select:auto;user-select:auto}::selection{background:#0000}::-moz-selection{background:#0000}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#555}body{position:relative}@media print{*{display:none!important}}.add-booking-page{margin:0 auto;max-width:100%;padding:15px;width:100%}.page-header{padding-bottom:10px}.page-header h1{color:#1565c0}.success-message{background-color:#e8f5e8;border:1px solid #a5d6a7;color:#2e7d32;gap:10px;margin-bottom:15px;padding:12px 15px}.booking-form-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;max-width:none;overflow:hidden;width:100%}.booking-form{padding:20px;width:100%}.form-section{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;padding:15px}.form-section h3{align-items:center;border-bottom:2px solid #e3f2fd;color:#1565c0;display:flex;font-size:18px;font-weight:600;gap:10px;margin:0 0 15px;padding-bottom:8px}.section-header{margin-bottom:15px}.section-header h3{border-bottom:none;padding-bottom:0}.form-row{margin-bottom:12px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{box-shadow:0 0 0 3px #1976d21a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f5f5f5;color:#666}.form-group small{color:#666;font-size:12px;margin-top:4px}.checkbox-label{align-items:center;cursor:pointer;display:flex!important;flex-direction:row!important;gap:8px;margin-top:10px}.checkbox-label input[type=checkbox]{margin:0!important;width:auto!important}.search-input-container{width:100%}.search-input-container .search-icon{color:#7f8c8d}.search-input-container input{padding-left:35px}.dropdown-options{border:2px solid #1976d2;border-radius:0 0 6px 6px;box-shadow:0 4px 6px #0000001a;max-height:200px}.dropdown-option{padding:10px 12px}.dropdown-option:hover{background:#e3f2fd}.unit-number{color:#1565c0;font-size:14px}.unit-option .unit-details{color:#7f8c8d;font-size:12px}.unit-details{background:#e8f5e8!important;border-color:#a5d6a7!important}.unit-details-table{background:#fff;border:2px solid #2e7d32;border-radius:8px;overflow:hidden}.unit-details-row{display:flex;flex-wrap:nowrap}.unit-detail-cell{border-right:1px solid #a5d6a7;display:flex;flex:1 1;flex-direction:column;gap:6px;min-width:0;padding:12px 15px}.unit-detail-cell:last-child{border-right:none}.unit-detail-cell label{color:#2e7d32;font-size:13px;font-weight:600;white-space:nowrap}.unit-detail-cell span{color:#1b5e20;font-weight:500;word-break:break-word}.unit-info-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-item label{color:#2e7d32}.info-item span{color:#1b5e20}.info-item .amount{color:#2e7d32;font-family:Courier New,monospace;font-weight:600}.applicant-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:15px;padding:15px}.applicant-header{border-bottom:1px solid #e0e0e0;margin-bottom:12px;padding-bottom:8px}.applicant-header h4{color:#1565c0;margin:0}.payment-plan-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:15px;padding:15px}.plan-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:8px}.plan-header h4{color:#1565c0;font-size:16px;margin:0}.no-plans-message{background:#f8f9fa;border-radius:6px;color:#7f8c8d;font-style:italic;margin:0;padding:20px;text-align:center}.plan-details{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr;margin-top:12px}.plan-details .form-group{margin-bottom:0}.total-amount{background:#e3f2fd;border:2px solid #1976d2;border-radius:6px;margin-top:15px;padding:12px 15px;text-align:center}.total-amount,.total-amount strong{color:#1565c0;font-size:18px}.form-actions{border-top:1px solid #e0e0e0;margin-top:20px;padding-top:15px}.btn-primary:hover:not(:disabled){background:#1565c0;box-shadow:0 4px 8px #1976d24d}.btn-secondary:hover:not(:disabled){background:#616161;box-shadow:0 4px 8px #7575754d;transform:translateY(-1px)}.btn-danger{background:#d32f2f}.btn-danger:hover:not(:disabled){background:#c62828;box-shadow:0 4px 8px #d32f2f4d;transform:translateY(-1px)}.btn-small{padding:8px 16px}.error{color:#d32f2f;font-size:12px}.error-message{margin-bottom:15px;padding:12px 15px}.form-footer{background:#f8f9fa;border-radius:0 0 12px 12px;border-top:1px solid #e0e0e0;display:flex;gap:15px;justify-content:flex-end;margin:20px -20px -20px;padding:15px 20px}@media (max-width:768px){.add-booking-page{padding:10px}.page-header{align-items:flex-start;flex-direction:column;gap:10px}.form-row{gap:10px;grid-template-columns:1fr}.form-section{padding:12px}.unit-info-grid{grid-template-columns:1fr}.unit-details-row{flex-direction:column}.unit-detail-cell{border-bottom:1px solid #a5d6a7;border-right:none}.unit-detail-cell:last-child{border-bottom:none}.form-actions{flex-direction:column}.btn{justify-content:center}.section-header{align-items:flex-start;flex-direction:column;gap:10px}.applicant-header,.plan-header{align-items:flex-start;flex-direction:column;gap:8px}.plan-details{gap:10px;grid-template-columns:1fr}.form-footer{flex-direction:column;gap:10px}}.radio-group{flex-wrap:wrap}.radio-label{border:1px solid #ddd;border-radius:4px;font-weight:400;padding:8px 12px;transition:all .2s ease}.radio-label:hover{background-color:#f8f9fa;border-color:#007bff}.radio-label:has(input[type=radio]:checked){background-color:#e7f3ff;border-color:#007bff;color:#007bff}.radio-label:has(input[type=radio]:disabled){cursor:not-allowed;opacity:.7}.radio-label:has(input[type=radio]:disabled):hover{background-color:initial;border-color:#ddd}.radio-label:has(input[type=radio]:disabled:checked){background-color:#e7f3ff;border-color:#007bff;color:#007bff;opacity:1}.loan-details{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-top:12px;padding:16px}.loan-details .form-row{margin-bottom:12px}.loan-details .form-group{margin-bottom:8px}.add-booking-page .form-section{margin-bottom:20px!important;padding:16px!important}.add-booking-page .form-row{margin-bottom:12px!important}.add-booking-page .form-group{margin-bottom:8px!important}.add-booking-page .form-group label{margin-bottom:4px!important}.add-booking-page .applicant-section,.add-booking-page .payment-plan-section{margin-bottom:16px!important;padding:12px!important}.add-booking-page .section-header{margin-bottom:12px!important}.add-booking-page .applicant-header,.add-booking-page .plan-header{margin-bottom:8px!important}.add-booking-page .form-row{align-items:flex-start;display:flex;gap:15px}.add-booking-page .form-row .form-group{flex:1 1;min-width:0}.add-booking-page .form-row .form-group:first-child,.add-booking-page .form-row .form-group:nth-child(2),.add-booking-page .form-row .form-group:nth-child(3){flex:1 1}.add-booking-page .applicant-section .form-row .form-group{flex:1 1;min-width:200px}.form-section.compact-section{margin-bottom:16px;padding:12px 15px}.form-section.compact-section h3{font-size:16px;margin-bottom:10px}.form-row.compact-row{gap:12px;margin-bottom:8px}.form-row.compact-row .form-group{margin-bottom:0}.form-row.compact-row .form-group label{font-size:13px;margin-bottom:4px}.form-row.compact-row .form-group input,.form-row.compact-row .form-group select{font-size:13px;padding:8px 10px}.form-row.compact-row .form-group small{font-size:11px;margin-top:2px}.form-section.compact-section .form-row.compact-row{grid-template-columns:1fr 1fr 1fr}.applicant-section.compact-applicant{background:#fff;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:12px;padding:12px}.applicant-section.applicant-card{border:2px solid #1976d2;box-shadow:0 2px 4px #0000001a}.applicant-section.compact-applicant .applicant-header{margin-bottom:8px}.applicant-section.compact-applicant .applicant-header h4{font-size:14px;margin:0}.form-row.amounts-row,.form-row.applicant-details-row{gap:10px;grid-template-columns:repeat(5,1fr)}.form-row.amounts-row .form-group input{font-size:13px}.form-row.amounts-row .form-group:only-child{grid-column:span 1}@media (max-width:1400px){.form-row.amounts-row,.form-row.applicant-details-row{grid-template-columns:repeat(3,1fr)}}@media (max-width:1024px){.form-row.compact-row{grid-template-columns:1fr}.form-row.amounts-row,.form-row.applicant-details-row{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.form-row.amounts-row,.form-row.applicant-details-row{grid-template-columns:1fr}}.phone-numbers-section{margin-bottom:12px;margin-top:12px}.phone-numbers-section .section-label{color:#333;display:block;font-size:13px;font-weight:600;margin-bottom:8px}.phone-input-group{align-items:center;display:flex;gap:8px;margin-bottom:8px}.country-code-select{background:#fff;border:2px solid #e0e0e0;border-radius:6px;flex:0 0 180px;font-size:13px;padding:8px 10px;transition:all .3s ease}.country-code-select:focus{border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a;outline:none}.phone-number-input{background:#fff;border:2px solid #e0e0e0;border-radius:6px;flex:1 1;font-size:13px;padding:8px 10px;transition:all .3s ease}.phone-number-input:focus{border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a;outline:none}.btn-icon.add-phone{align-items:center;background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;justify-content:center;padding:8px 12px;transition:all .2s}.btn-icon.add-phone:hover{background:#059669}.btn-icon.remove-phone{align-items:center;background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;justify-content:center;padding:8px 12px;transition:all .2s}.btn-icon.remove-phone:hover{background:#dc2626}.btn-icon:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.phone-input-group{flex-wrap:wrap}.country-code-select{flex:0 0 100%}.phone-number-input{flex-basis:calc(100% - 50px);flex-grow:1;flex-shrink:1}}.btn{box-shadow:0 1px 2px #0000000d;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.4;min-height:40px}.btn:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.btn-primary{background:#4f46e5;border:1px solid #4f46e5}.btn-primary:hover{background:#4338ca;border-color:#4338ca}.btn-secondary{background:#fff}.btn-secondary:hover{background:#f9fafb}.btn-success{background:#10b981;border:1px solid #10b981;color:#fff}.btn-success:hover{background:#059669;border-color:#059669}.btn-danger{background:#ef4444;border:1px solid #ef4444}.btn-danger:hover{background:#dc2626;border-color:#dc2626}.btn-warning{background:#f59e0b;border:1px solid #f59e0b;color:#fff}.btn-warning:hover{background:#d97706;border-color:#d97706}.btn-info{background:#3b82f6;border:1px solid #3b82f6;color:#fff}.btn-info:hover{background:#2563eb;border-color:#2563eb}.btn-sm{min-height:32px}.btn-lg{font-size:16px;min-height:48px;padding:16px 32px}.standard-table{background:#fff;border:none;border-collapse:collapse;border-radius:0;border-top:1px solid #e5e7eb;box-shadow:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden;width:100%}.standard-table th{background:#f8fafc;border-bottom:1px solid #e5e7eb;color:#374151;font-size:13px;font-weight:600;letter-spacing:.025em;padding:12px 16px;text-align:left;white-space:nowrap}.standard-table td{border-bottom:1px solid #f3f4f6;color:#374151;font-size:14px;line-height:1.5;padding:16px;vertical-align:middle}.standard-table tr{transition:background-color .15s ease}.standard-table tbody tr:hover{background:#e5e7eb}.standard-table tr:last-child td{border-bottom:none}.table-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.table-actions .btn{font-size:14px;justify-content:center;min-height:36px;min-width:36px;padding:8px;width:auto}.table-actions .btn svg{margin:0}.status-badge{align-items:center;display:inline-flex;font-size:11px;padding:4px 8px}.status-active{background:#dcfce7;color:#166534}.status-inactive{background:#fee2e2;color:#991b1b}.status-ready{background:#dbeafe;color:#1e40af}.status-shipped{background:#e0f2fe;color:#0369a1}.status-paid{background:#dcfce7;color:#166534}.status-expired{background:#fee2e2;color:#991b1b}.form-input{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;padding:12px 16px;transition:all .2s ease;width:100%}.form-input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.form-input::placeholder{color:#9ca3af}.form-select{border:1px solid #d1d5db;border-radius:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;padding:12px 16px;transition:all .2s ease}.form-select:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.form-textarea{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;min-height:100px;padding:12px 16px;resize:vertical;transition:all .2s ease;width:100%}.form-textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.form-textarea::placeholder{color:#9ca3af}.form-label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:6px}.page-container{background:#f8fafc;min-height:100%;width:100%}.page-header{border-bottom:none}.page-title{align-items:center;color:#fff;display:flex;font-size:24px;font-weight:600;gap:10px;margin:0}.page-subtitle{font-size:14px;font-weight:400;margin:4px 0 0;opacity:.9}.page-header .page-icon,.page-header .page-subtitle,.page-header .page-title,.page-header h1,.page-subtitle{color:#fff!important}.page-header .page-stats,.page-header .stat-item{color:#fffffff2!important}.page-header .stat-item strong{color:#fff!important}.page-header .btn,.page-header .btn-primary,.page-header button{background:#fff!important;border:2px solid #fff!important;color:#667eea!important;font-weight:600;transition:all .3s ease}.page-header .btn-primary:hover,.page-header .btn:hover,.page-header button:hover{background:#ffffffe6!important;box-shadow:0 4px 12px #00000026;color:#764ba2!important;transform:translateY(-1px)}.page-header .btn-primary:active,.page-header .btn:active,.page-header button:active{transform:translateY(0)}.content-section{background:#fff;overflow-x:auto;padding:24px 32px}.content-section,.filters-section{border:none;border-radius:0;border-top:1px solid #e5e7eb;box-shadow:none;margin:0}.filters-section{padding:20px 32px}.filters-row{align-items:center;display:flex;flex-wrap:wrap;gap:16px}.filters-row .form-input,.filters-row .form-select{flex:1 1;min-width:200px}.filters-row .btn{flex-shrink:0}.filter-toggle-btn{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;min-height:36px;padding:8px 16px;transition:all .2s ease}.filter-toggle-btn:hover{background:#f9fafb;border-color:#9ca3af}.filter-toggle-btn.active{background:#4f46e5;border-color:#4f46e5;color:#fff}.filter-toggle-btn.active:hover{background:#4338ca;border-color:#4338ca}.text-black{color:#000!important}.text-gray-600{color:#4b5563!important}.text-gray-900{color:#111827!important}.text-red{color:#dc2626!important}.text-green{color:#059669!important}.bg-white{background-color:#fff!important}.bg-gray-50{background-color:#f9fafb!important}.full-width{max-width:none!important;width:100%!important}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.p-2{padding:8px}.p-4{padding:16px}.p-6{padding:24px}.px-2{padding-left:8px;padding-right:8px}.px-4{padding-left:16px;padding-right:16px}.py-2{padding-bottom:8px;padding-top:8px}.py-4{padding-bottom:16px;padding-top:16px}.rounded{border-radius:8px}.rounded-lg{border-radius:12px}.shadow{box-shadow:0 1px 3px #0000001a}.shadow-md{box-shadow:0 4px 6px #0000001a}.border{border:1px solid #e5e7eb}.border-gray-200{border-color:#e5e7eb}.w-full{width:100%}.h-full{height:100%}.search-input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m21 21-6-6m2-5a7 7 0 1 1-14 0 7 7 0 0 1 14 0z'/%3E%3C/svg%3E");background-position:12px;background-repeat:no-repeat;background-size:16px;padding-left:40px}.avatar{border-radius:50%;height:32px;object-fit:cover;width:32px}.avatar-sm{height:24px;width:24px}.avatar-lg{height:48px;width:48px}.form-input,.form-select,input:not([type=checkbox]):not([type=radio]):not([type=file]),select:not(.no-style),textarea{background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;min-height:42px;outline:none;padding:10px 14px;transition:all .2s ease;width:100%}.form-input:focus,.form-select:focus,input:not([type=checkbox]):not([type=radio]):not([type=file]):focus,select:not(.no-style):focus,textarea:focus{background:#f8fafc;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder,input::placeholder,textarea::placeholder{color:#9ca3af;font-style:italic}.form-select,select:not(.no-style){-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;cursor:pointer;padding-right:40px}.form-input.error,.form-select.error,input.error,select.error,textarea.error{background:#fef2f2;border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-input:hover:not(:focus),.form-select:hover:not(:focus),input:hover:not(:focus):not([type=checkbox]):not([type=radio]),select:hover:not(:focus):not(.no-style),textarea:hover:not(:focus){border-color:#cbd5e1}.form-input:disabled,.form-select:disabled,input:disabled,select:disabled,textarea:disabled{background:#f3f4f6;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.search-input-container .search-icon{color:#6b7280;font-size:14px;pointer-events:none;top:50%;transform:translateY(-50%)}.search-input-container input{padding-left:40px!important}select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.summary-section{margin:20px 0}.summary-cards{display:flex;gap:16px;margin-bottom:20px}.summary-card{border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;flex:1 1;gap:16px;transition:all .2s ease}.summary-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.summary-icon{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:12px;color:#fff;display:flex;font-size:20px;height:48px;justify-content:center;width:48px}.summary-content{flex:1 1}.summary-label{color:#6b7280;font-size:14px;margin-bottom:4px}.summary-value{color:#1f2937;font-size:24px;font-weight:700;line-height:1.2}.summary-breakdown{background:#fff;border:1px solid #e5e7eb;border-radius:12px;display:flex;gap:32px;padding:20px}.breakdown-section{flex:1 1}.breakdown-section h3{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 16px}.breakdown-items{display:flex;flex-direction:column;gap:12px}.breakdown-item{align-items:center;background:#f9fafb;border:1px solid #f3f4f6;border-radius:8px;display:flex;justify-content:space-between;padding:12px}.breakdown-name{color:#374151;font-weight:500}.breakdown-stats{color:#6b7280;font-size:14px;font-weight:500}@media (max-width:768px){.summary-breakdown,.summary-cards{flex-direction:column}.summary-breakdown{gap:20px}}.income-actions{justify-content:center}.action-buttons .action-button,.income-actions .btn-icon{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:18px;justify-content:center;min-height:36px;min-width:36px;padding:8px;transition:all .2s ease}.action-buttons .action-button.view,.income-actions .btn-icon.view{color:#4f46e5}.action-buttons .action-button.view:hover,.income-actions .btn-icon.view:hover{background:#eef2ff;transform:scale(1.1)}.action-buttons .action-button.approve,.income-actions .btn-icon.approve{color:#10b981}.action-buttons .action-button.approve:hover,.income-actions .btn-icon.approve:hover{background:#d1fae5;transform:scale(1.1)}.action-buttons .action-button.reject,.income-actions .btn-icon.reject{color:#ef4444}.action-buttons .action-button.reject:hover,.income-actions .btn-icon.reject:hover{background:#fee2e2;transform:scale(1.1)}.add-expenses-container{display:flex;flex-direction:column;gap:25px;margin:0 auto;padding:20px}.add-expenses-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;box-shadow:0 4px 6px #0000001a;color:#fff;display:flex;gap:15px;padding:20px}.add-expenses-header .page-icon{font-size:2rem}.add-expenses-header h1{font-size:1.8rem;font-weight:600;margin:0}.form-container{padding:25px}.form-container h2{border-bottom:2px solid #e5e7eb;color:#1f2937;font-size:1.3rem;margin:0 0 20px;padding-bottom:10px}.project-selection{display:flex;flex-direction:column;gap:20px}.project-search-bar{align-items:center;display:flex}.project-search-bar svg{color:#9ca3af;font-size:1rem;left:12px}.project-search-bar input{border:2px solid #e5e7eb;padding:12px 12px 12px 40px;transition:border-color .2s ease}.project-search-bar input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.project-list{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.project-item{background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;padding:20px;transition:all .2s ease}.project-item:hover{background:#eff6ff;border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.project-info h3{color:#1f2937;font-weight:600}.selected-project-info{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b98133;color:#fff;padding:20px}.selected-project-info h3{font-size:1.2rem;font-weight:600}.change-project-btn{background:#fff3;border:1px solid #ffffff4d;padding:8px 16px;transition:all .2s ease}.change-project-btn:hover{background:#ffffff4d}.no-projects{color:#6b7280;padding:40px}.expense-head-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.add-expense-head-btn{align-items:center;background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s ease}.add-expense-head-btn:hover{background:#5a67d8;transform:translateY(-1px)}.new-expense-head-form{background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;margin-top:15px;padding:20px}.form-row{grid-gap:15px;gap:15px;grid-template-columns:1fr 1fr auto}.form-group{gap:5px}.form-actions{gap:10px}.btn-cancel,.btn-save{align-items:center;border-radius:6px;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s ease}.btn-save{background:#10b981}.btn-save:hover{background:#059669}.btn-cancel{border:1px solid #d1d5db}.btn-cancel:hover{background:#e5e7eb}.expense-entries-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.add-row-btn{background:#059669;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s ease}.add-row-btn:hover{background:#047857;transform:translateY(-1px)}.expense-table-container{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:20px;overflow-x:auto}.expense-table{border-collapse:collapse;min-width:800px;width:100%}.expense-table th{background:#f8fafc;border-bottom:2px solid #e5e7eb;color:#374151;font-size:13px;font-weight:600;letter-spacing:.025em;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.expense-table td{border-bottom:1px solid #f3f4f6;padding:12px 16px;vertical-align:middle}.expense-table tbody tr.error-row{background:#fef2f2}.expense-table input,.expense-table select,.standard-table input,.standard-table select,input[type=date],input[type=number],input[type=text],select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;min-height:42px;outline:none;padding:10px 14px;transition:all .2s ease;width:100%}.expense-table input:focus,.expense-table select:focus,.standard-table input:focus,.standard-table select:focus,input[type=date]:focus,input[type=number]:focus,input[type=text]:focus,select:focus{background:#f8fafc;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.expense-table input::placeholder,.standard-table input::placeholder,input[type=number]::placeholder,input[type=text]::placeholder{color:#9ca3af;font-style:italic}.expense-table select,.standard-table select,select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;cursor:pointer;padding-right:40px}.expense-table input.error,.expense-table select.error,.standard-table input.error,.standard-table select.error,input.error,select.error{background:#fef2f2;border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.expense-table input:hover:not(:focus),.expense-table select:hover:not(:focus),.standard-table input:hover:not(:focus),.standard-table select:hover:not(:focus),input:hover:not(:focus),select:hover:not(:focus){border-color:#cbd5e1}.expense-table input:disabled,.expense-table select:disabled,.standard-table input:disabled,.standard-table select:disabled,input:disabled,select:disabled{background:#f3f4f6;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.expense-table .btn-icon.delete{background:#fee2e2;border:none;border-radius:4px;color:#dc2626;cursor:pointer;padding:6px;transition:all .2s ease}.expense-table .btn-icon.delete:hover:not(:disabled){background:#fecaca}.expense-table .btn-icon.delete:disabled{cursor:not-allowed;opacity:.5}.expense-table tfoot .total-row{background:#f0f9ff;font-weight:600}.expense-table tfoot .total-row td{border-bottom:none;border-top:2px solid #0ea5e9;color:#0c4a6e;padding:12px}.form-errors{margin-top:15px}.row-errors{margin-bottom:10px}.row-errors strong{color:#dc2626}.row-errors ul{margin:5px 0 0;padding-left:20px}.row-errors li{color:#991b1b;font-size:.9rem}.summary-section{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin-bottom:20px;padding:20px}.summary-section h3{color:#0c4a6e;font-size:1.2rem;margin:0 0 15px}.summary-item{border:1px solid #e0f2fe;padding:10px 15px}.summary-label{color:#374151}.summary-value{color:#0c4a6e}.summary-value.amount{color:#059669}@media (max-width:1200px){.form-row{gap:15px;grid-template-columns:1fr}.form-actions{justify-content:stretch}.form-actions .btn-cancel,.form-actions .btn-save{flex:1 1}}@media (max-width:768px){.add-expenses-container,.add-expenses-header{padding:15px}.form-container{padding:20px}.project-list{grid-template-columns:1fr}.selected-project-info{flex-direction:column;gap:15px;text-align:center}.expense-entries-header,.expense-head-header{align-items:stretch;flex-direction:column;gap:15px}.expense-table-container{border-radius:0;margin:0 -20px}.summary-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}}@media (max-width:480px){.add-expenses-header{flex-direction:column;gap:10px;text-align:center}.back-btn{align-self:flex-start}}.tab-navigation{background:#f8f9fa;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:4px}.tab-button{border-radius:6px;color:#666;padding:12px 20px}.tab-button:hover{background:#e9ecef;color:#333}.tab-button.active{background:#007bff;box-shadow:0 2px 8px #007bff4d;color:#fff}.search-section{border-radius:12px;box-shadow:0 4px 20px #00000014;padding:30px}.search-form .form-row{align-items:end;display:flex;gap:20px;margin-bottom:20px}.search-form .form-group.flex-grow{flex:1 1}.search-button{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .3s ease}.search-button:hover{background:#218838;box-shadow:0 4px 12px #28a7454d;transform:translateY(-2px)}.search-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.bookings-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));margin-top:20px}.booking-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 16px #00000014;transition:all .3s ease}.booking-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-4px)}.booking-header{border-bottom:1px solid #e9ecef;padding-bottom:15px}.booking-header h4{font-size:1.2rem}.unit-ref{background:#007bff;border-radius:20px;color:#fff;font-size:.9rem;font-weight:500;padding:4px 12px}.booking-date{font-size:.9rem;margin-bottom:20px}.hidden-amounts{display:flex;flex-direction:column;gap:12px}.amount-item{background:#f8f9fa;border-left:4px solid #007bff;padding:12px}.amount-label{color:#333;font-weight:500}.amount-value{color:#28a745;font-size:1.1rem;font-weight:600}.create-income-btn{border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;padding:6px 12px;transition:all .3s ease}.create-income-btn.charges{background:#e74c3c}.create-income-btn.charges:hover{background:#c0392b}.create-income-btn.terrace{background:#3498db}.create-income-btn.terrace:hover{background:#2980b9}.create-income-btn.other-work{background:#f39c12}.create-income-btn.other-work:hover{background:#e67e22}.create-income-btn.banakhat{background:#16a085}.create-income-btn.banakhat:hover{background:#138d75}.create-income-btn.custom{background:#9b59b6}.create-income-btn.custom:hover{background:#8e44ad}.manage-section{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;padding:30px}.section-header{border-bottom:2px solid #e9ecef;padding-bottom:20px}.section-header h3{color:#333;font-size:1.5rem;margin:0}.refresh-button{background:#17a2b8;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .3s ease}.refresh-button:hover{background:#138496;box-shadow:0 4px 12px #17a2b84d;transform:translateY(-2px)}.refresh-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.income-table{border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.income-table table{background:#fff;border-collapse:collapse;width:100%}.income-table th{background:#f8f9fa;border-bottom:2px solid #dee2e6;color:#333;font-size:.9rem;padding:15px 12px}.income-table td{border-bottom:1px solid #e9ecef;color:#555;padding:15px 12px}.income-table tr:hover{background:#e5e7eb}.income-type-badge{border-radius:20px;color:#fff;display:inline-block;font-size:.85rem;font-weight:500;padding:4px 12px;text-transform:capitalize}.status.approved{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.status.pending{background:#fff3cd;border:1px solid #ffeaa7}.booking-info{margin-bottom:25px}.booking-info p{color:#555;margin:8px 0}.booking-info strong{color:#333}.modal-footer{background:#f8f9fa;gap:15px}.cancel-button{border-radius:6px}.cancel-button,.submit-button{font-weight:500;padding:12px 24px;transition:all .3s ease}.submit-button{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer}.submit-button:hover{background:#218838;box-shadow:0 4px 12px #28a7454d;transform:translateY(-2px)}.no-data{padding:60px 20px}@media (max-width:768px){.search-form .form-row{flex-direction:column;gap:15px}.bookings-grid{grid-template-columns:1fr}.amount-item,.booking-header{align-items:flex-start;flex-direction:column;gap:10px}.income-table{font-size:.9rem}.income-table td,.income-table th{padding:10px 8px}.modal-content{margin:20px;width:95%}.modal-body,.modal-footer,.modal-header{padding:20px}}.transaction-modal{max-height:90vh;max-width:900px;overflow-y:auto}.booking-info{background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;margin-bottom:20px;padding:20px}.booking-info h4{color:#007bff;font-size:1.3rem;margin:0 0 10px}.booking-info p{color:#666;font-size:.95rem;margin:5px 0}.installment-description{background:#fff;border:1px solid #e9ecef;color:#666;font-style:italic;padding:8px 10px}.payment-item,.transaction-item{background:#fafafa;border:1px solid #f0f0f0;border-radius:6px;margin-bottom:10px;padding:15px;transition:all .2s ease}.payment-item:hover,.transaction-item:hover{background:#f5f5f5;border-color:#e0e0e0}.payment-amount,.transaction-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.transaction-amount{color:#007bff;font-size:1.1rem;font-weight:600}.transaction-type{background:#e9ecef;border-radius:4px;color:#495057}.payment-details,.transaction-details{color:#666;display:flex;flex-wrap:wrap;font-size:.9rem;gap:15px;margin-bottom:8px}.payment-remarks,.transaction-description{background:#fff;border:1px solid #e9ecef;border-radius:4px;color:#666;font-size:.9rem;font-style:italic;margin-top:8px;padding:8px 10px}.transaction-status{border-top:1px solid #f0f0f0;color:#888;display:flex;font-size:.85rem;gap:15px;margin-top:8px;padding-top:8px}@media (max-width:768px){.transaction-modal{margin:10px;max-width:95%}.summary-grid{grid-template-columns:1fr}.payment-details,.transaction-details{flex-direction:column;gap:5px}.payment-amount,.transaction-header{align-items:flex-start;flex-direction:column;gap:5px}.installment-status,.transaction-status{flex-direction:column;gap:5px}.installment-header{align-items:flex-start;flex-direction:column;gap:8px}.income-type-summary{flex-direction:column;gap:5px}}.filters-section{border:1px solid #e9ecef}.filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:15px}.filter-group label{margin-bottom:5px}.filter-input,.filter-select{border-radius:4px;font-size:.9rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.filter-input:focus,.filter-select:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.clear-filters-btn{border-radius:4px;font-size:.9rem;padding:8px 16px;transition:background-color .15s ease-in-out}.clear-filters-btn:hover:not(:disabled){background:#5a6268}.clear-filters-btn:disabled{cursor:not-allowed;opacity:.6}.results-summary{border-top:1px solid #dee2e6;color:#6c757d;font-size:.9rem;padding-top:10px}.pagination-controls{gap:10px}.pagination-btn{border:1px solid #dee2e6;color:#495057;font-size:.9rem;min-width:80px;transition:all .15s ease-in-out}.pagination-btn:hover:not(:disabled){background:#e9ecef;border-color:#adb5bd}.pagination-info{color:#495057;margin:0 15px}.no-data p{font-size:1.1rem;margin-bottom:15px}.no-data .clear-filters-btn{margin-top:10px}@media (max-width:768px){.filter-row{flex-direction:column;gap:15px}.filter-group{min-width:0;min-width:auto;width:100%}.pagination-controls{flex-wrap:wrap;gap:5px}.pagination-btn{font-size:.8rem;min-width:60px;padding:6px 8px}.pagination-info{margin:5px 0;text-align:center;width:100%}}.project-info{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:6px;margin:8px 0;padding:8px 12px}.project-label{color:#1976d2;font-weight:600;margin-right:8px}.project-name{color:#0d47a1;font-weight:500}.booking-details{margin:12px 0}.booking-details>div{color:#666;font-size:.9rem;margin:6px 0}.booking-id,.contact-number,.total-amount{font-weight:500}.total-amount{color:#2e7d32;font-weight:600}.action-buttons{justify-content:center}.delete-btn,.edit-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:18px;padding:8px;transition:all .2s ease}.edit-btn:hover{background:#e3f2fd;transform:scale(1.1)}.delete-btn:hover{background:#ffebee;transform:scale(1.1)}.pagination-controls{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;justify-content:space-between;margin:20px 0;padding:15px}.pagination-info{font-size:.9rem;gap:20px}.items-per-page{align-items:center;display:flex;gap:8px}.items-per-page select{background:#fff;border:1px solid #ddd;border-radius:4px;padding:4px 8px}.pagination-buttons{align-items:center;display:flex;gap:10px}.pagination-btn{border:1px solid #ddd;border-radius:4px;padding:8px 12px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#007bff;border-color:#007bff;color:#fff}.pagination-btn:disabled{background:#f8f9fa;color:#6c757d}.page-info{color:#495057;font-weight:500;margin:0 10px}.filters-section{background:#f8f9fa;border:1px solid #dee2e6;padding:20px}.filters-header h4{color:#495057;font-size:16px;font-weight:600;margin:0 0 15px}.filters-form .form-row{align-items:end;display:flex;flex-wrap:wrap;gap:15px}.filters-form .form-group{display:flex;flex-direction:column;min-width:180px}.filters-form .form-group:last-child{flex-direction:row;gap:10px;min-width:auto}.filters-form label{color:#495057;font-size:14px;font-weight:500;margin-bottom:5px}.filters-form input,.filters-form select{background:#fff;border:1px solid #ced4da;border-radius:4px;font-size:14px;padding:8px 12px}.filters-form input:focus,.filters-form select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.apply-filters-btn,.clear-filters-btn{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.apply-filters-btn{background:#007bff;color:#fff}.apply-filters-btn:hover:not(:disabled){background:#0056b3}.apply-filters-btn:disabled{background:#6c757d;cursor:not-allowed}@media (max-width:768px){.filters-form .form-row{align-items:stretch;flex-direction:column}.filters-form .form-group:last-child{flex-direction:row;justify-content:center}}.shared-filter-container{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 2px 4px #0000000d}.shared-filter-content{animation:slideDown .2s ease-out;background:#fff;padding:20px 24px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-inputs-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px}.filter-field{display:flex;flex-direction:column;gap:6px}.filter-field label{color:#374151;font-size:13px;font-weight:500;margin:0}.filter-input{background:#fff;border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;color:#1f2937;font-size:14px;outline:none;padding:9px 12px;transition:all .2s ease;width:100%}.filter-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.filter-input::placeholder{color:#9ca3af}.filter-actions-row{display:flex;gap:12px;padding-top:4px}.btn-apply,.btn-clear{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;justify-content:center;padding:10px 24px;transition:all .2s ease}.btn-apply{background:#6366f1}.btn-apply:hover{background:#4f46e5;box-shadow:0 2px 4px #6366f14d}.btn-apply:active{background:#4338ca}.btn-clear{background:#fff;border:1px solid #d1d5db;color:#6b7280}.btn-clear:hover{background:#f9fafb;border-color:#9ca3af;color:#374151}.btn-clear:active{background:#f3f4f6}@media (max-width:1200px){.filter-inputs-row{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.shared-filter-content{padding:16px}.filter-inputs-row{gap:12px;grid-template-columns:repeat(2,1fr);margin-bottom:12px}.filter-toggle-btn{padding:12px 16px}.filter-actions-row{flex-direction:column}.btn-apply,.btn-clear{width:100%}}@media (max-width:480px){.filter-inputs-row{grid-template-columns:1fr}}.add-income-page{width:100%}.page-header{border-bottom:2px solid #e0e6ed;padding-bottom:1rem}.back-btn{border:none;border-radius:4px;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s}.header-title h1{color:#2c3e50;font-size:1.8rem;margin:0 0 .25rem}.header-title p{color:#666;font-size:1rem;margin:0}.search-type-tabs{border-bottom:1px solid #e9ecef;display:flex;gap:.5rem;margin-bottom:1.5rem}.tab-btn{align-items:center;display:flex;gap:.5rem;padding:1rem 1.5rem;transition:all .2s}.tab-btn:hover{color:#3498db}.tab-btn.active{background:#f8f9fa}.search-controls{align-items:end;display:flex;gap:1rem}.project-selector{min-width:200px}.project-dropdown{background:#fff;border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;width:100%}.dropdown-container{position:relative;width:100%}.dropdown-input{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:1rem;padding:.75rem;width:100%}.dropdown-input:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.dropdown-list{background:#fff;border:1px solid #ddd;border-radius:0 0 4px 4px;border-top:none;box-shadow:0 4px 6px #0000001a;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.dropdown-item{border-bottom:1px solid #f1f2f6;cursor:pointer;padding:.75rem;transition:background-color .2s}.dropdown-item:hover{background:#f8f9fa}.dropdown-item.selected{background:#e3f2fd;color:#3498db}.dropdown-item:last-child{border-bottom:none}.search-bar{gap:.5rem}.search-btn{white-space:nowrap}.search-results{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:1rem}.search-results h3{border-bottom:2px solid #3498db;padding-bottom:.5rem}.results-table{overflow-x:auto}.results-table table{border-collapse:collapse;font-size:.9rem;width:100%}.results-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#2c3e50;font-weight:600;padding:10px 12px;text-align:left}.results-table td{border-bottom:1px solid #f1f2f6;padding:8px 12px;vertical-align:middle}.results-table tr:hover{background:#e5e7eb}.add-income-page .search-results .content-section{padding:0!important}.standard-table.slim td,.standard-table.slim th{padding:8px 10px!important}.amount-main{color:#059669;font-size:13px;font-weight:600}.amount-systems{color:#6b7280;font-size:11px}.customer-info{gap:.25rem}.add-income-page .results-table td:first-child,.add-income-page .results-table th:first-child{text-align:left!important}.add-income-page .results-table td:first-child .customer-info{align-items:flex-start!important;width:100%}.add-income-page .customer-name,.add-income-page .customer-phone{text-align:left!important}.add-income-page .standard-table td:first-child .customer-info .customer-name,.add-income-page .standard-table td:first-child .customer-info .customer-phone{align-self:flex-start!important;justify-content:flex-start!important;width:100%!important}.customer-name{font-size:14px;text-align:left}.customer-phone{color:#666;font-size:12px}.booking-id{background:#0000;border:none;border-radius:0;color:#111827;font-size:14px;padding:0}.add-income-page .booking-id{box-shadow:none!important}.add-income-page .booking-id,.add-income-page .standard-table td .booking-id{background:#0000!important;border:none!important;color:#111827!important;padding:0!important}.add-income-page .standard-table td .booking-id{border-radius:0!important;font-size:14px!important;line-height:1.2!important}.add-income-page .standard-table td:first-child,.add-income-page .standard-table th:first-child{text-align:left!important}.add-income-page .standard-table td .customer-name{font-size:14px!important;text-align:left!important}.project-info{align-items:center;color:#2c3e50;display:flex;gap:.5rem}.unit-info{gap:.25rem}.unit-number{color:#2c3e50!important;font-size:12px!important;font-weight:500!important}.unit-type{display:none}.amount{color:#27ae60;font-size:1.1rem}.date-text{color:#4b5563;font-size:12px}.add-payment-btn{background:#10b981;border:1px solid #10b981;border-radius:6px;display:inline-flex;font-size:12px;gap:6px;line-height:1;min-height:30px;padding:6px 10px;transition:background-color .15s,transform .05s;white-space:nowrap}.add-payment-btn:hover{background:#059669}.add-payment-btn.icon-only{height:30px;justify-content:center;padding:0;width:30px}.payment-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:2rem}.selected-booking{border-bottom:2px solid #e9ecef;margin-bottom:2rem;padding-bottom:1.5rem}.selected-booking h3{color:#2c3e50;margin-bottom:1rem}.booking-summary{grid-gap:1rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));padding:1.5rem}.summary-item .label{color:#555;font-weight:600}.summary-item .value{color:#2c3e50;font-weight:500}.payment-history-section{border-bottom:2px solid #e9ecef;margin-bottom:2rem;padding-bottom:1.5rem}.payment-history-section h3{align-items:center;color:#2c3e50;display:flex;gap:.5rem;margin-bottom:1rem}.no-payments{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;padding:2rem}.payments-table{margin-top:1rem}.payment-form-section h3{color:#2c3e50;margin-bottom:1rem}.form-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem}.form-group .field-note{color:#666;font-size:.9rem;font-style:italic;font-weight:400}.form-group .error-text{color:#e74c3c;font-size:.875rem;margin-top:.25rem}.form-group input,.form-group select,.form-group textarea{transition:border-color .2s}.submit-btn{font-size:1rem;padding:.75rem 2rem}.submit-btn:disabled{background:#bdc3c7;cursor:not-allowed}.cancel-btn{font-size:1rem;padding:.75rem 2rem}@media (max-width:1200px){.booking-summary,.form-grid{grid-template-columns:1fr}}@media (max-width:768px){.header-left{align-items:flex-start;flex-direction:column;gap:.5rem}.search-controls{align-items:stretch}.search-controls,.search-type-tabs{flex-direction:column}.tab-btn{justify-content:center}.results-table{font-size:.85rem}.results-table td,.results-table th{padding:.5rem .25rem}.form-actions{flex-direction:column}.cancel-btn,.submit-btn{justify-content:center}}@media (max-width:480px){.header-title h1{font-size:1.5rem}.booking-summary{padding:1rem}.summary-item{align-items:flex-start;flex-direction:column;gap:.25rem}}.add-other-income-container{background:#f8f9fa;min-height:100vh;padding:2rem}.add-other-income-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;gap:1rem;margin-bottom:2rem;padding:1.5rem 2rem}.add-other-income-header h1{color:#2c3e50;font-size:2rem;font-weight:600;margin:0}.form-container h2{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.project-selection{margin-bottom:2rem}.project-info h3{margin:0}.selected-project-info{align-items:center;display:flex;justify-content:space-between}.selected-project-info h3{margin:0}.change-project-btn{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .3s ease}.change-project-btn:hover{background:#545b62}.income-head-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.add-income-head-btn{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.5rem 1rem;transition:all .3s ease}.add-income-head-btn:hover{background:#1e7e34}.new-income-head-form{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:1rem;padding:1rem}.form-row{align-items:end;display:flex;gap:1rem}.form-group{flex:1 1}.form-group input{border:2px solid #e9ecef;font-size:1rem;outline:none;padding:.75rem 1rem;transition:all .3s ease}.form-group input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-actions{gap:.5rem}.btn-save{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:all .3s ease}.btn-save:hover{background:#1e7e34}.btn-cancel{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:all .3s ease}.btn-cancel:hover{background:#c82333}.income-entries-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.add-row-btn{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.5rem 1rem;transition:all .3s ease}.add-row-btn:hover{background:#0056b3}.income-table-container{border:1px solid #e9ecef;border-radius:8px;margin-bottom:1rem}.income-table{background:#fff}.income-table th{background:#f8fafc;border-bottom:2px solid #e5e7eb;color:#374151;font-size:13px;letter-spacing:.025em;padding:12px 16px;white-space:nowrap}.income-table td{border-bottom:1px solid #f3f4f6;padding:12px 16px}.income-table tr.error-row{background:#fff5f5}.income-table input,.income-table select,.standard-table input,.standard-table select,input[type=date],input[type=number],input[type=text],select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;min-height:42px;outline:none;padding:10px 14px;transition:all .2s ease;width:100%}.income-table input:focus,.income-table select:focus,.standard-table input:focus,.standard-table select:focus,input[type=date]:focus,input[type=number]:focus,input[type=text]:focus,select:focus{background:#f8fafc;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.income-table input::placeholder,.standard-table input::placeholder,input[type=number]::placeholder,input[type=text]::placeholder{color:#9ca3af;font-style:italic}.income-table select,.standard-table select,select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;cursor:pointer;padding-right:40px}.income-table input.error,.income-table select.error,.standard-table input.error,.standard-table select.error,input.error,select.error{background:#fef2f2;border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.income-table input:hover:not(:focus),.income-table select:hover:not(:focus),.standard-table input:hover:not(:focus),.standard-table select:hover:not(:focus),input:hover:not(:focus),select:hover:not(:focus){border-color:#cbd5e1}.income-table input:disabled,.income-table select:disabled,.standard-table input:disabled,.standard-table select:disabled,input:disabled,select:disabled{background:#f3f4f6;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.income-table tfoot{background:#f8f9fa;font-weight:600}.total-row td{border-top:2px solid #e9ecef;padding:1rem .75rem}.btn-icon.delete:disabled{cursor:not-allowed;opacity:.5}.form-errors{background:#f8d7da;border:1px solid #f5c6cb;margin-top:1rem;padding:1rem}.form-errors h4{color:#721c24;margin:0 0 .5rem}.row-errors{margin-bottom:.5rem}.row-errors strong{color:#721c24}.row-errors ul{color:#721c24;margin:.25rem 0 0 1rem}.summary-section{margin-bottom:2rem}.summary-section h3{color:#2c3e50;margin-bottom:1rem}.summary-item{background:#f8f9fa;border:1px solid #e9ecef;padding:.75rem}.summary-value.amount{color:#28a745}.form-container .form-actions{align-items:center;border-top:1px solid #e9ecef;display:flex;gap:1rem;justify-content:space-between;margin-top:2rem;padding-top:1.5rem}.btn-secondary{border:none}.btn-primary,.btn-secondary{border-radius:8px;font-size:1rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#0056b3,#004085);box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}.btn-primary:disabled{box-shadow:none!important;opacity:.6;transform:none!important}@media (max-width:768px){.add-other-income-container,.form-container{padding:1rem}.form-actions,.form-row{align-items:stretch;flex-direction:column}.income-table-container{overflow-x:auto}.income-table{min-width:700px}.summary-grid{grid-template-columns:1fr}}.add-partner-income-container{background:#f8f9fa;min-height:100vh;padding:2rem}.add-partner-income-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;gap:1rem;margin-bottom:2rem;padding:1.5rem 2rem}.back-btn{background:none;border:1px solid #dee2e6;border-radius:8px;color:#6c757d;padding:.5rem}.back-btn:hover{background:#f8f9fa;border-color:#007bff;color:#007bff}.add-partner-income-header h1{color:#2c3e50;font-size:2rem;font-weight:600;margin:0}.stepper-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:2rem}.stepper{justify-content:center;margin-bottom:2rem}.step,.stepper{align-items:center;display:flex}.step{flex:1 1;flex-direction:column;max-width:200px;position:relative}.step-number{align-items:center;border-radius:50%;display:flex;font-size:1.1rem;font-weight:600;height:40px;justify-content:center;margin-bottom:.5rem;transition:all .3s ease;width:40px}.step.active .step-number{background:#007bff;color:#fff}.step.completed .step-number{background:#28a745;color:#fff}.step:not(.active):not(.completed) .step-number{background:#e9ecef;color:#6c757d}.step-title{color:#495057;font-size:.9rem;font-weight:500;text-align:center}.step.active .step-title{color:#007bff;font-weight:600}.step.completed .step-title{color:#28a745}.step-connector{background:#e9ecef;height:2px;left:50%;position:absolute;top:20px;width:100%;z-index:-1}.step.completed .step-connector{background:#28a745}.step:last-child .step-connector{display:none}.form-container{border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:2rem}.step-content h2{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.project-search-container{margin-bottom:2rem}.project-search-bar{margin-bottom:1rem;position:relative}.project-search-bar input{border:2px solid #e9ecef;border-radius:8px;font-size:1rem;outline:none;padding:.75rem 1rem .75rem 2.5rem;transition:all .3s ease;width:100%}.project-search-bar input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.project-search-bar svg{color:#6c757d;left:.75rem;position:absolute;top:50%;transform:translateY(-50%)}.project-list{border:1px solid #e9ecef;border-radius:8px;max-height:400px;overflow-y:auto}.project-item{align-items:center;border-bottom:1px solid #f1f2f6;cursor:pointer;display:flex;justify-content:space-between;padding:1rem;transition:all .3s ease}.project-item:last-child{border-bottom:none}.project-item:hover{background:#f8f9fa}.project-item.selected{background:#e3f2fd;border-color:#007bff}.project-info h3{color:#2c3e50;font-size:1.1rem;margin:0 0 .25rem}.project-info p{color:#6c757d;font-size:.9rem;margin:0}.project-meta{color:#6c757d;font-size:.85rem;text-align:right}.no-projects{color:#6c757d;font-style:italic;padding:2rem;text-align:center}.partner-selection-container{margin-bottom:2rem}.selected-project-info{background:#e3f2fd;border:1px solid #007bff;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.selected-project-info h3{color:#007bff;font-size:1.1rem;margin:0 0 .5rem}.selected-project-info p{color:#495057;font-size:.9rem;margin:0}.partner-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.partner-card{background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;padding:1.25rem;transition:all .3s ease}.partner-card:hover{background:#f8f9fa;border-color:#007bff}.partner-card.selected{background:#e3f2fd;border-color:#007bff}.partner-card h3{color:#2c3e50;font-size:1.1rem;margin:0 0 .5rem}.partner-card p{color:#6c757d;font-size:.9rem;margin:.25rem 0}.partner-card .phone{color:#007bff;font-weight:500}.no-partners{color:#6c757d;font-style:italic;grid-column:1/-1;padding:2rem;text-align:center}.transaction-form{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.form-group label{color:#495057}.form-group input,.form-group select,.form-group textarea{border:2px solid #e9ecef;outline:none;padding:.75rem 1rem;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-group textarea{min-height:100px}.form-group.error input,.form-group.error select,.form-group.error textarea{border-color:#dc3545}.error-message{color:#dc3545;font-size:.85rem;margin-top:.25rem}.transaction-type-buttons{display:flex;gap:1rem;margin-bottom:1rem}.type-button{background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;flex:1 1;padding:1rem;text-align:center;transition:all .3s ease}.type-button:hover{background:#f8f9fa;border-color:#007bff}.type-button.selected{background:#e3f2fd;border-color:#007bff;color:#007bff}.type-button.income.selected{background:#d4edda;border-color:#28a745;color:#155724}.type-button.disbursement.selected{background:#f8d7da;border-color:#dc3545;color:#721c24}.type-button h3{font-size:1.1rem;margin:0 0 .5rem}.type-button p{color:#6c757d;font-size:.9rem;margin:0}.type-button.selected p{color:inherit}.transaction-summary{background:#f8f9fa;border:1px solid #e9ecef;margin-bottom:2rem;padding:1.5rem}.transaction-summary h3{color:#2c3e50;font-size:1.2rem;margin:0 0 1rem}.summary-grid{grid-gap:1rem;gap:1rem}.summary-item{border-bottom:1px solid #dee2e6;padding:.5rem 0}.summary-item:last-child{border-bottom:none}.summary-label{color:#495057;font-weight:500}.summary-value{color:#2c3e50;font-weight:600}.summary-value.amount{font-size:1.1rem}.summary-value.income{color:#28a745}.summary-value.disbursement{color:#dc3545}.form-actions{align-items:center;border-top:1px solid #e9ecef;justify-content:space-between;margin-top:2rem;padding-top:1.5rem}.action-left,.action-right{display:flex;gap:.5rem}.btn{font-size:1rem;gap:.5rem;padding:.75rem 1.5rem}.btn-secondary:hover{background:#545b62}.btn-outline{background:#0000;border:1px solid #6c757d;color:#6c757d}.btn-outline:hover{background:#6c757d;color:#fff}.btn-primary{background:linear-gradient(135deg,#007bff,#0056b3)}.btn-primary:hover{background:linear-gradient(135deg,#0056b3,#004085);box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}.btn:disabled{box-shadow:none!important;transform:none!important}.spinner{margin:0 auto 1rem}@media (max-width:768px){.add-partner-income-container,.stepper-container{padding:1rem}.stepper{flex-direction:column;gap:1rem}.step{flex-direction:row;max-width:none;width:100%}.step-connector{display:none}.partner-grid,.transaction-form{grid-template-columns:1fr}.form-actions,.transaction-type-buttons{flex-direction:column}.form-actions{align-items:stretch}.action-left,.action-right,.btn{justify-content:center}}.add-role-container{display:flex;flex-direction:column;gap:25px;margin:0 auto;max-width:1200px;padding:20px}.add-role-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;box-shadow:0 4px 6px #0000001a;color:#fff;display:flex;gap:15px;padding:20px}.back-btn{background:#fff3;border:1px solid #ffffff4d;justify-content:center;padding:10px;transition:all .3s ease}.back-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.add-role-header .page-icon{font-size:2rem}.add-role-header h1{font-size:1.8rem;font-weight:600;margin:0}.form-container{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:30px}.form-section{margin-bottom:30px}.form-section h2{border-bottom:2px solid #e5e7eb;color:#1f2937;font-size:1.3rem;padding-bottom:10px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group{gap:8px}.form-group input{border-radius:6px;font-size:.9rem;padding:10px 12px;transition:border-color .2s ease}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error{background:#fef2f2;border-color:#dc2626}.permissions-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.permissions-summary{align-items:center;color:#6b7280;display:flex;font-size:.9rem;gap:8px}.summary-icon{color:#f59e0b}.permissions-container{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.permission-module{border-bottom:1px solid #e5e7eb}.permission-module:last-child{border-bottom:none}.module-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e5e7eb;display:flex;gap:15px;padding:15px 20px}.module-toggle{background:none;border:none;color:#6b7280;cursor:pointer;font-size:.8rem;transition:all .2s ease}.toggle-icon{display:inline-block;transition:transform .2s ease}.toggle-icon.expanded{transform:rotate(90deg)}.module-info{flex:1 1}.module-info h3{color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 5px}.module-count{color:#6b7280;font-size:.8rem}.module-select-btn{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.module-select-btn:hover{background:#e5e7eb}.module-select-btn.all{background:#fef3c7;border-color:#f59e0b;color:#d97706}.module-select-btn.partial{background:#e0f2fe;border-color:#0ea5e9;color:#0369a1}.permissions-grid{grid-gap:10px;background:#fff;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));padding:20px}.permission-item{border:1px solid #e5e7eb;border-radius:6px;overflow:hidden;transition:all .2s ease}.permission-item:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.permission-checkbox{align-items:center;cursor:pointer;display:flex;gap:12px;margin:0;padding:15px}.permission-checkbox input[type=checkbox]{display:none}.checkmark{border:2px solid #d1d5db;border-radius:3px;flex-shrink:0;height:18px;position:relative;transition:all .2s ease;width:18px}.permission-checkbox input[type=checkbox]:checked+.checkmark{background:#667eea;border-color:#667eea}.permission-checkbox input[type=checkbox]:checked+.checkmark:after{color:#fff;content:"✓";font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.permission-info{flex:1 1;min-width:0}.permission-name{color:#1f2937;display:block;font-size:.9rem;font-weight:500;margin-bottom:4px}.permission-description{color:#6b7280;font-size:.8rem;line-height:1.3}.form-errors{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:20px;padding:15px}.form-errors h4{color:#dc2626;font-size:1rem;margin:0 0 10px}.form-errors ul{margin:0;padding-left:20px}.form-errors li{color:#991b1b;font-size:.9rem;margin-bottom:5px}.form-actions{gap:15px;padding-top:20px}.btn-primary,.btn-secondary{align-items:center;display:flex;font-size:1rem;gap:8px;padding:12px 24px;transition:all .2s ease}.btn-primary{background:#667eea}.btn-primary:hover:not(:disabled){background:#5a67d8;transform:translateY(-1px)}.btn-primary:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.btn-secondary{background:#f3f4f6}.btn-secondary:hover{background:#e5e7eb}.loading{font-size:1.1rem}@media (max-width:768px){.add-role-container,.add-role-header{padding:15px}.form-container{padding:20px}.form-row,.permissions-grid{grid-template-columns:1fr}.permissions-grid{padding:15px}.module-header{padding:12px 15px}.form-actions{flex-direction:column}}.add-system-user-container{background-color:var(--background-color);min-height:100vh;padding:24px}.add-system-user-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:16px}.add-system-user-header .header-left{align-items:center;display:flex;gap:12px}.add-system-user-header .page-icon{color:var(--primary-color);font-size:24px}.add-system-user-header h1{color:var(--text-primary);font-size:28px;font-weight:600;margin:0}.add-system-user-header .header-actions{display:flex;gap:12px}.add-system-user-content{margin:0 auto;max-width:800px}.user-form{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.form-section{border-bottom:1px solid var(--border-color);padding:24px}.form-section:last-child{border-bottom:none}.form-section h2{color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 20px}.form-field{display:flex;flex-direction:column}.form-field.full-width{grid-column:1/-1}.form-field label{color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:6px}.form-field input,.form-field select{border:1px solid var(--border-color);border-radius:4px;font-size:14px;padding:10px 12px;transition:border-color .2s ease}.form-field input:focus,.form-field select:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(var(--primary-color-rgb),.1);outline:none}.form-field input.error,.form-field select.error{border-color:var(--danger-color)}.error-message{color:var(--danger-color);font-size:12px;margin-top:4px}.section-error{margin-bottom:16px;padding:8px 12px}.section-error,.submit-error{background-color:rgba(var(--danger-color-rgb),.1);border:1px solid var(--danger-color);border-radius:4px;font-size:14px}.submit-error{margin-top:16px;padding:12px;text-align:center}.empty-assignments{background-color:var(--background-light);border:2px dashed var(--border-color);border-radius:4px;color:var(--text-secondary);padding:40px 20px;text-align:center}.project-assignments{display:flex;flex-direction:column;gap:16px}.project-assignment-card{background-color:var(--background-light);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.assignment-header{align-items:center;background-color:#fff;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px}.project-selector{align-items:center;display:flex;flex:1 1;gap:12px}.project-selector label{color:var(--text-secondary);font-size:14px;font-weight:500;margin:0}.project-selector select{border:1px solid var(--border-color);border-radius:4px;flex:1 1;font-size:14px;max-width:300px;padding:8px 10px}.roles-section{padding:16px}.roles-section>label{color:var(--text-secondary);display:block;font-size:14px;font-weight:500;margin-bottom:12px}.roles-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.role-checkbox{align-items:flex-start;background-color:#fff;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;display:flex;gap:8px;padding:12px;transition:all .2s ease}.role-checkbox:hover{background-color:rgba(var(--primary-color-rgb),.02);border-color:var(--primary-color)}.role-checkbox input[type=checkbox]{flex-shrink:0;height:16px;margin:0;width:16px}.role-checkbox .role-name{color:var(--text-primary);font-size:14px;font-weight:500;margin-bottom:2px}.role-checkbox .role-description{color:var(--text-secondary);font-size:12px;line-height:1.3}.role-checkbox input[type=checkbox]:checked+.role-name{color:var(--primary-color)}.btn-small{font-size:12px;line-height:1.4;padding:6px 12px}.btn-small svg{height:12px;width:12px}@media (max-width:768px){.add-system-user-container{padding:16px}.add-system-user-header{align-items:flex-start;flex-direction:column;gap:16px}.add-system-user-header .header-actions{justify-content:flex-end;width:100%}.form-grid{grid-template-columns:1fr}.assignment-header{gap:12px}.assignment-header,.project-selector{align-items:stretch;flex-direction:column}.project-selector{gap:6px}.roles-grid{grid-template-columns:1fr}}@media (max-width:480px){.add-system-user-header h1{font-size:24px}.form-section{padding:16px}.role-checkbox{align-items:flex-start;flex-direction:column;gap:6px}.role-checkbox input[type=checkbox]{align-self:flex-start}}.auth-dashboard-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.auth-dashboard-section{border:1px solid #e5e7eb;border-radius:8px;margin:24px;overflow:hidden}.auth-section-title{color:#fff;font-size:15px;font-weight:600;letter-spacing:.025em;margin:0;padding:12px 20px}.auth-dashboard-table{border-top:none!important}.auth-dashboard-table th{background:#f1f5f9;font-size:13px;padding:10px 16px}.auth-count-cell{color:#9ca3af;cursor:default;font-weight:600;text-align:center}.auth-count-cell.has-pending{background:#eef2ff;border-radius:4px;color:#4f46e5;cursor:pointer}.auth-count-cell.has-pending:hover{background:#e0e7ff;text-decoration:underline}.auth-count-cell.has-pending-red{background:#fef2f2;border-radius:4px;color:#dc2626;cursor:pointer}.auth-count-cell.has-pending-red:hover{background:#fee2e2;text-decoration:underline}.auth-count-cell.total{color:#1f2937;font-size:15px;font-weight:700}.auth-totals-row{border-top:2px solid #e5e7eb}.auth-totals-row,.auth-totals-row:hover{background:#f8fafc!important}.auth-hidden-header{background:#fef2f2!important;color:#dc2626!important}.compact-action-bar{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;border-top:none;box-shadow:0 1px 2px #0000000d;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;min-height:60px;padding:14px 0}.action-bar-left,.action-bar-right{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.action-bar-left{flex:1 1}@media (max-width:768px){.compact-action-bar{gap:10px;padding:10px 15px}.action-bar-left,.action-bar-right{gap:8px}.compact-action-bar .btn,.compact-action-bar .btn-primary,.compact-action-bar .btn-secondary{font-size:13px;padding:8px 12px}}@media (max-width:480px){.compact-action-bar{align-items:stretch;flex-direction:column}.action-bar-left,.action-bar-right{justify-content:flex-start;width:100%}}.cancel-booking-modal{background:#fff;border-radius:12px;box-shadow:0 20px 50px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:90%}.modal-header{background:#fff8f0}.modal-header h2{align-items:center;color:#dc2626;display:flex;font-size:1.25rem;gap:10px}.warning-icon{color:#f59e0b;font-size:1.1rem}.close-btn{font-size:1.2rem;transition:all .2s}.close-btn:disabled{cursor:not-allowed;opacity:.5}.booking-summary{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:24px;padding:16px}.booking-summary h3{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 12px}.summary-grid{grid-gap:12px;gap:12px;grid-template-columns:1fr 1fr}.summary-item .label{color:#64748b;font-weight:500}.summary-item .value{color:#1e293b;font-weight:600}.summary-item .value.amount{color:#059669}.form-group label{font-size:.9rem}.form-group input,.form-group select,.form-group textarea{font-size:.9rem;padding:10px 12px;transition:border-color .2s,box-shadow .2s}.form-group input.error,.form-group textarea.error{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f9fafb;cursor:not-allowed;opacity:.7}.help-text{color:#6b7280;font-size:.8rem}.error-text{color:#dc2626;display:block;font-size:.8rem;font-weight:500;margin-top:4px}.refund-summary{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin:16px 0;padding:16px}.summary-row{font-size:.9rem;margin-bottom:8px}.summary-row:last-child{margin-bottom:0}.summary-row.total{border-top:1px solid #bae6fd;font-size:1rem;font-weight:600;margin-top:8px;padding-top:8px}.summary-row .refund{color:#dc2626;font-weight:600}.refund-details{background:#fefce8;border:1px solid #fde047;border-radius:8px;margin:20px 0;padding:20px}.refund-details h4{align-items:center;color:#a16207;display:flex;font-size:1rem;font-weight:600;gap:8px;margin:0 0 16px}.form-grid{grid-gap:16px;gap:16px}.modal-actions{padding-top:20px}.btn-cancel,.btn-confirm{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .2s}.btn-cancel{background:#f3f4f6;color:#374151}.btn-cancel:hover:not(:disabled){background:#e5e7eb}.btn-confirm{background:#dc2626}.btn-confirm:hover:not(:disabled){background:#b91c1c}.btn-cancel:disabled,.btn-confirm:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.cancel-booking-modal{margin:10px;width:95%}.form-grid,.summary-grid{grid-template-columns:1fr}.modal-actions{flex-direction:column}.btn-cancel,.btn-confirm{width:100%}}.cancel-booking-modal.loading{pointer-events:none}.cancel-booking-modal.loading:before{background:#ffffffb3;bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:10}.confirm-dialog-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1001}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{animation:slideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 25px 50px -12px #00000040;margin:20px;max-width:420px;padding:0;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.confirm-dialog-header{align-items:flex-start;display:flex;justify-content:space-between;padding:24px 24px 0}.confirm-dialog-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:20px;height:48px;justify-content:center;width:48px}.confirm-dialog-icon.danger{background:#fee2e2;color:#dc2626}.confirm-dialog-icon.warning{background:#fef3c7;color:#d97706}.confirm-dialog-icon.info{background:#dbeafe;color:#2563eb}.confirm-dialog-close{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;font-size:16px;height:24px;justify-content:center;padding:4px;transition:color .2s ease;width:24px}.confirm-dialog-close:hover{color:#6b7280}.confirm-dialog-content{padding:16px 24px 24px}.confirm-dialog-title{color:#1f2937;font-size:18px;font-weight:600;line-height:1.4;margin:0 0 8px}.confirm-dialog-message{color:#6b7280;font-size:14px;line-height:1.5;margin:0}.confirm-dialog-actions{display:flex;gap:12px;justify-content:flex-end;padding:0 24px 24px}.btn-confirm{border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-confirm.danger{background:#dc2626}.btn-confirm.danger:hover{background:#b91c1c}.btn-confirm.warning{background:#d97706}.btn-confirm.warning:hover{background:#b45309}.btn-confirm.info{background:#2563eb}.btn-confirm.info:hover{background:#1d4ed8}@media (max-width:480px){.confirm-dialog{margin:16px;max-width:none}.confirm-dialog-header{padding:20px 20px 0}.confirm-dialog-content{padding:16px 20px 20px}.confirm-dialog-actions{flex-direction:column-reverse;padding:0 20px 20px}.btn-confirm,.btn-secondary{justify-content:center;width:100%}}.booking-details-page{width:100%}.page-header,.search-section{margin-bottom:2rem}.search-section{box-shadow:0 2px 4px #0000001a;padding:1.5rem}.search-bar{gap:1rem;margin-bottom:1rem}.search-bar input{border:1px solid #ddd;border-radius:4px;flex:1 1;padding:.75rem}.search-btn{align-items:center;background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:background-color .2s}.search-btn:hover{background:#2980b9}.search-btn:disabled{background:#bdc3c7;cursor:not-allowed}.search-results{margin-top:1.5rem}.search-results h3{color:#2c3e50;margin-bottom:1rem}.results-list{display:flex;flex-direction:column;gap:.5rem}.result-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;cursor:pointer;padding:1rem;transition:all .2s}.result-item:hover{background:#e3f2fd;border-color:#3498db}.result-main{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.customer-name{color:#2c3e50;font-size:1.1rem}.booking-id{background:#3498db;border-radius:3px;color:#fff;font-size:.9rem;padding:.25rem .5rem}.result-details{color:#666;display:flex;font-size:.9rem;gap:1rem}.result-details span{background:#fff;border:1px solid #e9ecef;border-radius:3px;padding:.25rem .5rem}.booking-details{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:2rem}.details-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.details-header h2{color:#2c3e50;margin:0}.add-payment-btn{align-items:center;background:#27ae60;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:background-color .2s}.add-payment-btn:hover{background:#219a52}.cancel-booking-btn{align-items:center;background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:background-color .2s}.cancel-booking-btn:hover{background:#c82333}.details-grid{grid-gap:2rem;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.booking-info h3,.payment-summary h3{border-bottom:2px solid #3498db;color:#2c3e50;font-size:1.3rem;margin-bottom:1rem;padding-bottom:.5rem}.info-row{border-bottom:1px solid #f1f2f6;display:flex;justify-content:space-between;padding:.75rem 0}.info-row .label{color:#555;font-weight:600}.info-row .value{color:#2c3e50;font-weight:500}.summary-row{border-bottom:1px solid #f1f2f6;display:flex;font-size:1.1rem;justify-content:space-between;padding:.75rem 0}.summary-row.total{border-bottom:2px solid #2c3e50;color:#2c3e50;font-size:1.2rem;font-weight:700}.summary-row.paid .value{color:#27ae60;font-weight:600}.summary-row.pending .value{color:#f39c12;font-weight:600}.summary-row.remaining .value{color:#e74c3c;font-weight:600}.add-payment-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.add-payment-section h3{color:#2c3e50;margin-bottom:1rem}.payment-form{width:100%}.form-grid{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(3,1fr);margin-bottom:1.5rem}.form-group input,.form-group select,.form-group textarea{border-radius:4px;font-size:1rem;padding:.75rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.form-actions{gap:1rem}.submit-btn{align-items:center;background:#27ae60;border-radius:4px;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:background-color .2s}.submit-btn:hover{background:#219a52}.cancel-btn{background:#95a5a6;border:none;border-radius:4px;color:#fff;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s}.cancel-btn:hover{background:#7f8c8d}.payment-history{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.history-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.history-header h3{align-items:center;color:#2c3e50;display:flex;gap:.5rem;margin:0}.payment-count{background:#3498db;border-radius:15px;color:#fff;font-size:.9rem;font-weight:500;padding:.25rem .75rem}.no-payments{color:#666;padding:3rem;text-align:center}.no-payments p{font-size:1.1rem;margin:0}.payments-table{overflow-x:auto}.payments-table table{border-collapse:collapse;font-size:.95rem;width:100%}.payments-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#2c3e50;font-weight:600;padding:1rem .75rem;text-align:left}.payments-table td{border-bottom:1px solid #f1f2f6;padding:1rem .75rem;vertical-align:middle}.payments-table tr:hover{background:#e5e7eb}.status-badge{border-radius:15px;padding:.25rem .75rem}.status-approved{background:#d1f2eb}.action-buttons{gap:.5rem}.delete-btn{align-items:center;background:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:background-color .2s}.delete-btn:hover{background:#c0392b}.error-message{border-radius:4px;margin-top:1rem}@media (max-width:1200px){.details-grid{grid-template-columns:1fr}.form-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.details-header,.search-bar{flex-direction:column}.details-header{align-items:stretch;gap:1rem}.form-grid{grid-template-columns:1fr}.payments-table{font-size:.85rem}.payments-table td,.payments-table th{padding:.5rem .25rem}.result-details{flex-direction:column;gap:.5rem}}@media (max-width:480px){.page-header h1{font-size:1.5rem}.customer-name,.page-header p{font-size:1rem}.booking-id{font-size:.8rem}}.booking-history-page{background:linear-gradient(135deg,#f8fafc,#e2e8f0);min-height:100vh;padding:0;width:100%}.page-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #0000001a;color:#fff;padding:16px 32px;width:100%}.header-content{margin:0}.header-content h1{align-items:center;display:flex;font-size:2.5rem;font-weight:700;gap:1rem;margin:0 0 .5rem}.header-content p{font-size:1.1rem;margin:0;opacity:.9}.error-message{background:#fee2e2;border-left:4px solid #dc2626;padding:1rem 2rem;width:100%}.error-close{border-radius:4px;color:#dc2626;font-size:1.5rem;padding:.25rem;transition:background-color .2s ease}.error-close:hover{background:#dc26261a}.search-section{border-bottom:1px solid #e5e7eb;padding:2rem;width:100%}.search-container{margin:0 auto;max-width:1400px}.search-header{align-items:center;display:flex;gap:.75rem;margin-bottom:1.5rem}.search-header h3{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0}.section-icon{color:#3b82f6;font-size:1.25rem}.form-group{margin:0 0 1.5rem}.form-group label{font-size:.95rem}.form-select{background:#fff;border:2px solid #d1d5db;border-radius:12px;color:#374151;cursor:pointer;font-size:1rem;max-width:500px;padding:1rem;transition:all .3s ease;width:100%}.form-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-select option{padding:.5rem}.searchable-dropdown{max-width:500px}.search-input-container input{background:#fff;border:2px solid #d1d5db;border-radius:12px;font-size:1rem;padding:1rem 1rem 1rem 3rem;transition:all .3s ease}.search-input-container input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-icon{color:#6b7280;font-size:1rem;left:1rem}.dropdown-options{border:2px solid #d1d5db;border-radius:0 0 12px 12px;border-top:none;box-shadow:0 10px 25px -5px #0000001a}.dropdown-option{border-bottom:1px solid #f3f4f6;padding:1rem}.dropdown-option:hover{background:#f8fafc}.unit-option{gap:.25rem}.unit-number{color:#1f2937;font-size:1rem}.unit-details{font-size:.875rem}.history-content{margin:0 auto;max-width:1400px;padding:2rem;width:100%}.unit-summary-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;margin-bottom:2rem;padding:2rem}.unit-header{display:flex;flex-direction:column;gap:1rem}.unit-title{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.unit-title h2{color:#1f2937;font-size:2rem;font-weight:700;margin:0}.status-badge{border-radius:50px;font-size:.875rem;letter-spacing:.025em;padding:.5rem 1rem}.status-badge.sold{background:#fecaca;color:#991b1b}.status-badge.unsold{background:#d1fae5;color:#065f46}.status-badge.hold{background:#fef3c7;color:#92400e}.status-badge.approval_pending{background:#e0e7ff;color:#3730a3}.unit-meta{display:flex;flex-wrap:wrap;gap:2rem}.meta-item{color:#6b7280;font-size:1rem}.meta-item strong{color:#374151}.timeline-container{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;padding:2rem}.timeline-header{margin-bottom:2rem;text-align:center}.timeline-header h3{color:#1f2937;font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.timeline-header p{color:#6b7280;font-size:1rem;margin:0}.timeline{padding-left:2rem;position:relative}.timeline:before{background:linear-gradient(180deg,#3b82f6,#8b5cf6);border-radius:1px;bottom:0;content:"";left:1rem;position:absolute;top:0;width:2px}.timeline-item{margin-bottom:2rem;padding-left:2rem}.timeline-marker{border:3px solid #fff;box-shadow:0 2px 8px #0000001a;height:2rem;left:-2rem;top:.5rem;width:2rem}.timeline-icon{color:#fff;font-size:.875rem}.timeline-marker .create{background:#10b981}.timeline-marker .update{background:#3b82f6}.timeline-marker .approve{background:#10b981}.timeline-marker .reject{background:#ef4444}.timeline-marker .cancel{background:#f59e0b}.timeline-marker .transfer{background:#3b82f6}.timeline-marker .delete{background:#ef4444}.timeline-marker .default{background:#6b7280}.timeline-item.success .timeline-marker{background:#10b981}.timeline-item.warning .timeline-marker{background:#f59e0b}.timeline-item.info .timeline-marker{background:#3b82f6}.timeline-item.danger .timeline-marker{background:#ef4444}.timeline-item.default .timeline-marker{background:#6b7280}.timeline-content{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:1.5rem}.timeline-header-item{align-items:flex-start;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;margin-bottom:1rem}.timeline-title{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.timeline-date{color:#6b7280;font-size:.875rem;font-weight:500}.timeline-body{color:#374151}.booking-details,.detail-grid{margin-bottom:1rem}.detail-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.detail-item{align-items:center;font-size:.875rem;gap:.5rem}.detail-icon{color:#3b82f6;flex-shrink:0;font-size:1rem}.booking-id{background:#e0f2fe;border-left:3px solid #0284c7;margin-bottom:.5rem}.booking-id,.remarks{border-radius:8px;font-size:.875rem;padding:.5rem 1rem}.remarks{background:#fef3c7;border-left:3px solid #f59e0b}.action-details{font-size:.875rem}.action-data{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:8px;padding:1rem}.data-item{align-items:flex-start;display:flex;gap:.5rem;margin-bottom:.5rem}.data-item:last-child{margin-bottom:0}.data-item strong{color:#475569;min-width:120px;text-transform:capitalize}.data-item span{color:#1e293b;word-break:break-word}.no-history,.no-selection{padding:4rem 2rem;text-align:center;width:100%}.no-history-content,.no-selection-content{margin:0 auto;max-width:400px}.no-history-icon,.no-selection-icon{color:#d1d5db;font-size:4rem;margin-bottom:1rem}.no-history-content h3,.no-selection-content h3{color:#374151;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.no-history-content p,.no-selection-content p{color:#6b7280;font-size:1rem;line-height:1.5;margin:0}.loading{padding:4rem 2rem;width:100%}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:3rem;margin:0 auto 1rem;width:3rem}.loading p{color:#6b7280;font-size:1rem;margin:0}@media (max-width:768px){.page-header{padding:2rem 1rem}.header-content h1{font-size:1.75rem}.search-section{padding:1.5rem 1rem}.history-content{padding:1rem}.timeline-container,.unit-summary-card{padding:1.5rem}.unit-title{align-items:flex-start;flex-direction:column}.unit-title h2{font-size:1.5rem}.unit-meta{flex-direction:column;gap:.5rem}.timeline,.timeline-item{padding-left:1.5rem}.timeline-marker{height:1.5rem;left:-1.5rem;width:1.5rem}.timeline-icon{font-size:.75rem}.timeline-header-item{align-items:flex-start;flex-direction:column;gap:.25rem}.detail-grid{gap:.75rem;grid-template-columns:1fr}.timeline-content{padding:1rem}}@media (max-width:480px){.page-header{padding:1.5rem 1rem}.header-content h1{align-items:flex-start;flex-direction:column;font-size:1.5rem;gap:.5rem}.search-section{padding:1rem}.searchable-dropdown{max-width:none}.timeline-container,.unit-summary-card{padding:1rem}.timeline-title{font-size:1.125rem}}.page-header{border-bottom:2px solid #eee;justify-content:between}.page-header h1{gap:10px}.search-section{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:25px}.search-container h3{color:#333;margin:0 0 20px}.unit-search-wrapper{max-width:500px}.searchable-dropdown{position:relative;width:100%}.search-input-container{align-items:center;display:flex;position:relative}.search-input-container .search-icon{color:#666;left:12px;position:absolute;z-index:1}.search-input-container input{border:2px solid #ddd;border-radius:6px;font-size:16px;padding:12px 12px 12px 40px;transition:border-color .2s ease;width:100%}.search-input-container input:focus{border-color:#007bff;outline:none}.dropdown-options{background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;left:0;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.dropdown-option{border-bottom:1px solid #f0f0f0;cursor:pointer;padding:12px;transition:background-color .2s ease}.dropdown-option:hover{background-color:#f8f9fa}.dropdown-option:last-child{border-bottom:none}.unit-option{display:flex;flex-direction:column;gap:4px}.unit-number{font-size:16px}.unit-details{color:#666;font-size:14px}.history-content{display:flex;flex-direction:column;gap:30px}.unit-info-card{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:25px}.unit-info-card h3{align-items:center;color:#333;display:flex;font-size:20px;gap:10px;margin:0 0 20px}.unit-details-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-item label{color:#666;font-size:14px;font-weight:600}.detail-item span{color:#333;font-size:16px}.bookings-section{border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:25px}.bookings-section h3{color:#333;font-size:20px;margin:0 0 20px}.bookings-list{display:flex;flex-direction:column;gap:15px}.booking-card{border:1px solid #e0e0e0;border-radius:6px;padding:20px;transition:box-shadow .2s ease}.booking-card:hover{box-shadow:0 2px 8px #0000001a}.booking-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.booking-id{font-size:18px}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.cancelled{background-color:#f8d7da;color:#721c24}.status-badge.completed{background-color:#d1ecf1;color:#0c5460}.booking-details{display:flex;flex-direction:column;gap:8px}.detail-row span:first-child{color:#666;font-weight:500}.detail-row span:last-child{color:#333}.detail-row .amount{color:#007bff;font-weight:600}.history-section{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:25px}.history-section h3{color:#333;font-size:20px;margin:0 0 25px}.history-timeline{padding-left:30px;position:relative}.history-timeline:before{background:#e0e0e0;bottom:0;content:"";left:15px;position:absolute;top:0;width:2px}.timeline-item{margin-bottom:25px;padding-bottom:20px;position:relative}.timeline-item:last-child{margin-bottom:0;padding-bottom:0}.timeline-marker{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:50%;display:flex;height:30px;justify-content:center;left:-30px;position:absolute;top:0;width:30px}.action-badge{border-radius:12px;font-size:10px;font-weight:600;padding:2px 6px;text-transform:uppercase}.badge-warning{background-color:#fff3cd;color:#856404}.badge-danger{background-color:#f8d7da;color:#721c24}.badge-info{background-color:#d1ecf1;color:#0c5460}.badge-secondary{background-color:#e2e3e5;color:#383d41}.timeline-content{background:#f8f9fa;border-left:4px solid #007bff;border-radius:6px;padding:15px}.action-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.action-title{color:#333;font-size:16px;font-weight:600}.action-date{color:#666;font-size:14px}.action-details{color:#555;font-size:14px}.action-data{display:flex;flex-direction:column;gap:5px}.action-data div{padding:3px 0}.no-data{padding:40px 20px}.instruction-message,.no-data-message{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;color:#666;padding:60px 20px;text-align:center}.instruction-message p{font-size:18px;margin:0}.error-message{background-color:#f8d7da}.error-close{color:#721c24;font-size:20px;margin-left:10px}@media (max-width:768px){.booking-history-page{padding:10px}.page-header h1{font-size:24px}.bookings-section,.history-section,.search-section,.unit-info-card{padding:15px}.unit-details-grid{grid-template-columns:1fr}.booking-header{gap:10px}.booking-header,.detail-row{align-items:flex-start;flex-direction:column}.detail-row{gap:4px}.action-header{align-items:flex-start;flex-direction:column;gap:5px}.history-timeline{padding-left:20px}.timeline-marker{height:20px;left:-20px;width:20px}.history-timeline:before{left:10px}}.booking-summary-container{box-sizing:border-box;margin:0;max-width:100vw;padding:15px;width:100%}.page-header{margin-bottom:20px}.page-header h1{color:#333;font-size:1.5rem;margin-bottom:8px}.page-header p{font-size:.9rem}.project-selection{background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 1px 4px #0000001a;margin-bottom:20px;padding:15px}.form-group{gap:6px}.form-control,.form-group label{font-size:.85rem}.form-control{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:8px 12px;transition:border-color .2s ease}.form-control:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.form-control:disabled{background-color:#f8f9fa;cursor:not-allowed}.loading-state{background:#fff;border-radius:8px;margin:20px 0;padding:60px 20px;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:40px;margin:0 auto 15px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-state{background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;margin:20px 0;padding:40px 20px;text-align:center}.error-state p{color:#e53e3e;font-size:1.1rem;margin-bottom:15px}.error-state button{background:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px}.error-state button:hover{background:#0056b3}.booking-summary-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;max-width:100%;overflow:visible;width:100%}.summary-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.summary-header h3{color:#333;font-size:1.3rem;margin:0}.booking-count{background:#007bff;border-radius:15px;color:#fff;font-size:.9rem;font-weight:500;padding:6px 12px}.table-container{-webkit-overflow-scrolling:touch;background:linear-gradient(90deg,#fff 30%,#fff0),linear-gradient(90deg,#fff0,#fff 70%) 100% 0,radial-gradient(farthest-side at 0 50%,#0003,#0000),radial-gradient(farthest-side at 100% 50%,#0003,#0000) 100% 0;background-attachment:local,local,scroll,scroll;background-repeat:no-repeat;background-size:40px 100%,40px 100%,14px 100%,14px 100%;border:1px solid #e0e0e0;border-radius:4px;display:block;max-height:60vh;overflow-x:auto!important;overflow-y:auto!important;position:relative;scroll-behavior:smooth;width:100%}.table-container::-webkit-scrollbar{height:12px;width:12px}.table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:5px}.table-container::-webkit-scrollbar-thumb{background:#007bff;border-radius:5px}.table-container::-webkit-scrollbar-thumb:hover{background:#0056b3}.booking-summary-table{border-collapse:collapse;font-size:.75rem;min-width:100%;table-layout:auto;width:-webkit-max-content;width:max-content}.booking-summary-table th{background:#f1f3f4;border-bottom:2px solid #ddd;color:#333;font-size:.75rem;font-weight:600;padding:8px 6px;position:-webkit-sticky;position:sticky;text-align:left;top:0;white-space:nowrap;z-index:10}.booking-summary-table td{border-bottom:1px solid #eee;font-size:.75rem;padding:8px 6px;white-space:nowrap}.booking-summary-table tbody tr:hover{background-color:#e5e7eb}.booking-summary-table tbody tr:nth-child(2n){background-color:#fafafa}.booking-summary-table tbody tr:nth-child(2n):hover{background-color:#f0f0f0}.booking-summary-table td:first-child,.booking-summary-table th:first-child{min-width:50px;text-align:center}.booking-summary-table td:nth-child(2),.booking-summary-table th:nth-child(2){min-width:80px}.booking-summary-table td:nth-child(3),.booking-summary-table th:nth-child(3){min-width:150px}.booking-summary-table td:nth-child(4),.booking-summary-table td:nth-child(5),.booking-summary-table td:nth-child(6),.booking-summary-table td:nth-child(7),.booking-summary-table th:nth-child(4),.booking-summary-table th:nth-child(5),.booking-summary-table th:nth-child(6),.booking-summary-table th:nth-child(7){min-width:120px}.booking-summary-table td:nth-child(10),.booking-summary-table td:nth-child(8),.booking-summary-table td:nth-child(9),.booking-summary-table th:nth-child(10),.booking-summary-table th:nth-child(8),.booking-summary-table th:nth-child(9){min-width:140px}.booking-summary-table td:nth-child(11),.booking-summary-table th:nth-child(11){min-width:100px}.booking-summary-table td:nth-child(12),.booking-summary-table th:nth-child(12){min-width:80px}.booking-summary-table td:nth-child(13),.booking-summary-table th:nth-child(13){min-width:80px;text-align:center}.unit-ref{color:#333;font-weight:600}.customer-name{font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis}.contact-number{color:#666}.amount,.contact-number{font-family:Courier New,monospace}.amount{text-align:right}.amount.sale-deed{color:#28a745}.amount.given-sd{color:#17a2b8}.amount.pending-sd{color:#dc3545}.amount.hidden-expected{color:#6f42c1}.amount.hidden-received{color:#20c997}.amount.hidden-pending{color:#fd7e14}.amount.negative{color:#dc3545;font-weight:700}.view-button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;min-width:60px;padding:6px 12px;transition:background-color .2s;white-space:nowrap}.view-button:hover{background:#0056b3}.action-cell{padding:8px!important;text-align:center}.booking-date{color:#666;font-size:.85rem}.status{border-radius:4px;padding:4px 8px;text-align:center}.status.active{background:#d4edda;color:#155724}.status.completed{background:#cce5ff;color:#004085}.status.cancelled{background:#f8d7da;color:#721c24}.status.transferred{background:#fff3cd;color:#856404}.no-bookings{color:#666;padding:60px 20px;text-align:center}.no-bookings p{font-size:1.2rem;margin:0}.summary-totals{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:25px}.summary-totals h4{border-bottom:2px solid #007bff;color:#333;font-size:1.3rem;margin:0 0 20px;padding-bottom:10px}.totals-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.total-item{align-items:center;background:#f8f9fa;border-left:4px solid #007bff;border-radius:6px;display:flex;justify-content:space-between;padding:15px 20px}.total-item span:first-child{color:#333;font-weight:500}.total-item .amount{color:#007bff;font-size:1.1rem;font-weight:700}.unauthorized-access{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;height:60vh;margin:20px}.unauthorized-content{box-shadow:0 20px 40px #0000001a;max-width:400px}.unauthorized-content h2{font-size:1.8rem}.unauthorized-content p{color:#666;margin-bottom:15px}@media (max-width:1200px){.booking-summary-table{font-size:.85rem}.booking-summary-table td,.booking-summary-table th{padding:10px 6px}}@media (max-width:768px){.booking-summary-container{padding:15px}.page-header h1{font-size:1.8rem}.summary-header{flex-direction:column;gap:10px;text-align:center}.booking-summary-table{font-size:.8rem}.booking-summary-table td,.booking-summary-table th{padding:8px 4px}.customer-name{max-width:100px}.totals-grid{grid-template-columns:1fr}.total-item{flex-direction:column;gap:8px;text-align:center}}@media (max-width:480px){.booking-summary-table td,.booking-summary-table th{font-size:.75rem;padding:6px 3px}.project-selection{padding:20px}}.modal-content{box-shadow:0 20px 40px #0003;max-width:500px}.modal-header{padding:20px 30px}.modal-header h3{color:#333;font-size:1.3rem}.close-button{border-radius:50%;color:#666;height:30px;padding:0;transition:all .3s ease;width:30px}.close-button:hover{background:#f8f9fa;color:#333}.cancel-button{background:#6c757d;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:.9rem;padding:10px 20px;transition:background-color .3s ease}.cancel-button:hover{background:#5a6268}.fullscreen-modal-overlay{align-items:center;background-color:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:0;position:fixed;right:0;top:0;z-index:10000}.fullscreen-modal-overlay .fullscreen-modal-content,.modal-overlay.fullscreen-modal-overlay .modal-content.fullscreen-modal-content{background:#fff!important;border-radius:12px!important;display:flex;flex-direction:column;height:90vh!important;max-height:90vh!important;max-width:75vw!important;overflow:hidden;width:75vw!important}.fullscreen-modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:3px solid #5568d3;color:#fff;display:flex;flex-shrink:0;justify-content:space-between;padding:24px 40px}.fullscreen-modal-header h2{font-size:1.8rem;font-weight:600;margin:0}.fullscreen-modal-header .close-button{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:32px;height:48px;justify-content:center;line-height:1;transition:all .3s ease;width:48px}.fullscreen-modal-header .close-button:hover{background:#ffffff4d;transform:rotate(90deg)}.fullscreen-modal-body{background:#f8f9fa;flex:1 1;overflow-y:auto;padding:30px 40px}.booking-details-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:30px}.section-title{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:1.4rem;font-weight:600;margin:0 0 24px;padding-bottom:12px}.details-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.detail-section{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;padding:20px}.detail-section h4{color:#667eea;font-size:1.1rem;font-weight:600;margin:0 0 16px}.detail-row{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:10px 0}.detail-row:last-child{border-bottom:none}.detail-row .label{color:#718096;font-size:.95rem;font-weight:500}.detail-row .value{color:#2d3748;font-size:.95rem;font-weight:600;text-align:right}.detail-row .value.amount{font-family:Courier New,monospace;font-size:1rem}.detail-row .value.amount.success{color:#48bb78}.detail-row .value.amount.pending{color:#f56565}.detail-row.total-row{border-top:2px solid #667eea;margin-top:8px;padding-top:12px}.detail-row.total-row .label,.detail-row.total-row .value{font-size:1.05rem;font-weight:700}.detail-divider{background:#cbd5e0;height:1px;margin:12px 0}.applicant-block{padding:12px 0;position:relative}.primary-badge{background:#667eea;border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;margin-bottom:12px;padding:4px 12px;text-transform:uppercase}.applicant-divider{background:linear-gradient(90deg,#0000,#cbd5e0,#0000);height:2px;margin:16px 0}.status-badge{font-size:.85rem;padding:6px 16px}.status-badge.status-active{background:#c6f6d5;color:#22543d}.status-badge.status-cancelled{background:#fed7d7;color:#742a2a}.status-badge.status-completed{background:#bee3f8;color:#2c5282}.transactions-table-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:30px}.transactions-table-container:after{background:linear-gradient(90deg,#0000,#f8f9fa 20%,#f8f9fa 80%,#0000);border-top:1px solid #e9ecef;color:#6c757d;content:"← Scroll to see more →";display:block;font-size:12px;font-style:italic;padding:8px;text-align:center}@media (min-width:1200px){.transactions-table-container:after{display:none}}.transaction-modal{display:none!important}.transaction-summary{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;margin-bottom:20px}.transaction-summary h5{font-size:1.1rem;margin:0 0 15px}.summary-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-item{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;display:flex;justify-content:space-between;padding:12px 15px}.summary-item .overpaid{color:orange;font-weight:600}.income-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;overflow:hidden}.income-section h5{background:#f8f9fa;border-bottom:1px solid #e0e0e0;color:#333;font-size:1.1rem;margin:0;padding:15px 20px}.income-summary{border-bottom:1px solid #f0f0f0;padding:15px 20px}.income-summary .summary-grid{gap:10px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.income-summary .summary-item{background:#f8f9fa;color:#333;font-size:.9rem;padding:8px 12px}.hidden-transactions-by-type,.hidden-transactions-list,.payments-list{padding:20px}.hidden-transactions-by-type h6,.hidden-transactions-list h6,.payments-list h6{border-bottom:1px solid #f0f0f0;color:#666;font-size:1rem;margin:0 0 15px;padding-bottom:8px}.payment-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:8px;padding:12px}.payment-amount{color:#28a745;font-size:1.1rem;font-weight:600}.payment-details{color:#666;display:flex;font-size:.9rem;gap:15px}.payment-remarks{color:#888;font-size:.85rem;font-style:italic;margin-top:5px}.income-type-section{background:#fafafa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:15px;overflow:hidden}.income-type-header{background:#f1f3f4;border-bottom:1px solid #e9ecef;padding:15px}.income-type-header h6{color:#333;font-size:1.1rem;font-weight:600;margin:0 0 10px}.income-type-summary{color:#666;display:flex;flex-wrap:wrap;font-size:.9rem;gap:15px}.income-type-summary .overpaid{color:orange;font-weight:600}.installments-list{padding:15px}.installments-list h6{color:#555;font-size:.95rem;font-weight:500;margin:0 0 12px}.installment-item{background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 1px 3px #0000001a;margin-bottom:10px;padding:15px}.installment-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:10px;padding-bottom:8px}.installment-number{background:#007bff;border-radius:4px;color:#fff;font-size:.8rem;font-weight:600;padding:4px 8px}.installment-amount{color:#28a745;font-size:1.1rem;font-weight:600}.installment-date{color:#666;font-size:.9rem}.installment-balance{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;margin:10px 0;padding:10px}.balance-row{display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:5px}.balance-row.payment{color:#dc3545;font-weight:500}.balance-row.after{border-top:1px solid #dee2e6;font-weight:600;margin-top:5px;padding-top:5px}.balance-row .paid{color:#28a745}.installment-status{border-top:1px solid #f0f0f0;color:#888;display:flex;font-size:.85rem;gap:15px;margin-top:8px;padding-top:8px}.installment-description{background:#f8f9fa;border-left:3px solid #007bff;border-radius:4px;color:#555;font-size:.9rem;margin-top:8px;padding:8px}@media (max-width:768px){.modal-content{margin:20px;width:95%}.modal-body,.modal-footer,.modal-header{padding:20px}.transaction-modal{max-height:85vh}.summary-grid{grid-template-columns:1fr}.income-type-summary,.installment-header{flex-direction:column;gap:8px}.installment-header{align-items:flex-start}.payment-details{flex-direction:column;gap:5px}}.transactions-table-section{margin-top:20px}.category-summary{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:15px 0}.category-item{align-items:center;background:#e9ecef;border-radius:6px;display:flex;font-weight:500;justify-content:space-between;padding:10px 15px}.transactions-table-container{-webkit-overflow-scrolling:touch;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-top:15px;max-width:100%;overflow-x:auto;width:100%}.transactions-table{border-collapse:collapse;font-size:14px;min-width:900px;table-layout:auto;width:100%}.transactions-table thead{background:#007bff;color:#fff}.transactions-table td,.transactions-table th{border-bottom:1px solid #dee2e6;padding:10px 12px;text-align:left;vertical-align:middle}.transactions-table th{background:#007bff;font-weight:600;position:-webkit-sticky;position:sticky;top:0;white-space:nowrap;z-index:10}.transactions-table tbody tr{border-bottom:1px solid #e9ecef}.transactions-table tbody tr:hover{background-color:#e5e7eb}.main-income-row{background-color:#28a7450d}.hidden-income-row{background-color:#ffc1070d}.transaction-type{border-radius:12px;display:inline-block;font-size:12px;padding:4px 8px}.transaction-type.sale-deed{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.transaction-type.hidden-income{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.amount-cell{min-width:120px}.installment-info{color:#6c757d;font-size:10px;margin-top:2px;white-space:normal}.status{border-radius:10px;display:inline-block;font-size:11px;padding:3px 8px}.status.approved,.status.paid,.status.received{background-color:#d4edda;color:#155724}.status.pending{background-color:#fff3cd;color:#856404}.no-transactions{background:#f8f9fa;color:#6c757d;padding:40px 20px;text-align:center}.filters-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:15px 20px}.filters-section h3{display:none}.filters-grid{align-items:center;display:flex;flex-wrap:nowrap;gap:12px}.filter-item{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.filter-item label{color:#555;font-size:.8rem;font-weight:500;white-space:nowrap}.filter-item input{border:1px solid #ddd;border-radius:6px;font-size:.9rem;min-width:0;padding:8px 10px;transition:all .3s ease}.filter-item input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.filter-item small{color:#6c757d;font-size:.7rem;font-style:italic;white-space:nowrap}.filter-actions{align-items:flex-end;flex-shrink:0;gap:8px}.apply-filter-btn,.clear-filter-btn{border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;padding:8px 16px;transition:all .3s ease;white-space:nowrap}.apply-filter-btn{background:#007bff;color:#fff}.apply-filter-btn:hover{background:#0056b3;box-shadow:0 4px 8px #007bff4d;transform:translateY(-1px)}.clear-filter-btn{background:#6c757d;color:#fff}.clear-filter-btn:hover{background:#545b62;transform:translateY(-1px)}.pagination-controls{border-top:1px solid #e0e0e0;gap:20px;margin-top:20px;padding:20px}.pagination-btn{background:#007bff;border:none;color:#fff;font-size:.95rem;padding:10px 20px}.pagination-btn:hover:not(:disabled){background:#0056b3;box-shadow:0 4px 8px #007bff4d}.pagination-btn:disabled{background:#ccc;opacity:.6}.pagination-info{color:#333;font-size:1rem}@media (max-width:768px){.transaction-modal .modal-content{margin:10px;max-width:98vw}.fullscreen-modal-content{padding:0}.fullscreen-modal-header{padding:16px 20px}.fullscreen-modal-header h2{font-size:1.3rem}.fullscreen-modal-body{padding:15px}.details-grid{grid-template-columns:1fr!important}.filters-grid{grid-template-columns:1fr}.filter-actions{width:100%}.apply-filter-btn,.clear-filter-btn{flex:1 1}.pagination-controls{flex-direction:column;gap:10px}.pagination-btn{width:100%}.transactions-table-container{border-radius:4px;margin-left:-15px;margin-right:-15px;width:calc(100% + 30px)}.transactions-table{font-size:12px;min-width:700px}.transactions-table td,.transactions-table th{font-size:11px;padding:8px 6px}.transaction-type{font-size:10px;padding:3px 6px}.amount-cell{font-size:12px;min-width:100px}.installment-info,.status{font-size:9px}.status{padding:2px 6px}.booking-details-card{padding:15px}.section-title{font-size:1.1rem}.detail-section{padding:12px}.detail-section h4{font-size:.95rem}.detail-row .label,.detail-row .value{font-size:.85rem}.category-summary{grid-template-columns:1fr}.transaction-details{font-size:11px}}@media (max-width:480px){.fullscreen-modal-header h2{font-size:1.1rem}.fullscreen-modal-header .close-button{font-size:24px;height:36px;width:36px}.transactions-table{font-size:11px;min-width:600px}.transactions-table td,.transactions-table th{padding:6px 4px}.detail-row{align-items:flex-start!important;flex-direction:column;gap:4px}.detail-row .value{text-align:left!important}}.brokers-container{margin:0;min-height:100vh;padding:0;width:100%}.brokers-header{align-items:center;background:#fff;border-bottom:1px solid #e0e0e0;box-sizing:border-box;display:flex;justify-content:space-between;padding:20px 24px;width:100%}.search-bar input{width:300px}.brokers-table-container{background:#fff;border:1px solid #e0e0e0;border-radius:0;box-shadow:none;margin:0;overflow:hidden;width:100%}.brokers-table{border:none;border-collapse:collapse;table-layout:fixed;width:100%}.brokers-table thead{background:#f8f9fa;border-bottom:1px solid #e0e0e0}.brokers-table th{border-bottom:1px solid #e0e0e0;border-left-style:solid;border-right:1px solid #e0e0e0;border-top-style:solid;color:#1565c0;font-size:14px;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase}.brokers-table th:last-child{border-right:none}.brokers-table td{border-bottom:1px solid #e0e0e0;border-left-style:solid;border-right:1px solid #e0e0e0;border-top-style:solid;padding:16px 20px;vertical-align:middle}.brokers-table td:last-child{border-right:none}.brokers-table tbody tr:hover{background:#e5e7eb}.brokers-table tbody tr:last-child td{border-bottom:none}.broker-name{align-items:center;color:#333;display:flex;font-weight:500;gap:12px}.broker-icon{color:#1976d2;font-size:18px}.broker-mobile{align-items:center;color:#666;display:flex;gap:8px}.mobile-icon{color:#4caf50;font-size:16px}.broker-address{align-items:flex-start;color:#666;display:flex;gap:8px;line-height:1.5}.address-icon{color:#f44336;flex-shrink:0;font-size:16px;margin-top:2px}.no-address{color:#999;font-style:italic}.broker-actions{display:flex;gap:8px}.form-group input,.form-group textarea{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;padding:12px;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#1976d2;outline:none}@media (max-width:768px){.brokers-container{padding:16px}.brokers-header{align-items:flex-start;flex-direction:column;gap:16px}.header-actions{justify-content:flex-start;width:100%}.brokers-controls{align-items:stretch;flex-direction:column;gap:12px}.search-bar{max-width:none;width:100%}.brokers-table-container{overflow-x:auto}.brokers-table{min-width:600px}.broker-address{word-wrap:break-word;max-width:200px}.modal{margin:16px;width:95%}.modal-actions{flex-direction:column}.btn{justify-content:center;width:100%}}.cancelled-bookings-page{max-width:100%;padding:20px}.page-header{align-items:center;border-bottom:2px solid #ffebee}.page-header h1,.page-icon{color:#d32f2f}.page-stats{display:flex;gap:20px}.stat-item{color:#666;font-size:14px}.stat-item strong{color:#d32f2f;font-size:16px}.filters-section{flex-wrap:wrap;margin-bottom:25px}.filter-group{position:relative}.search-box{width:300px}.search-box input{border:2px solid #e0e0e0;padding:12px 40px 12px 15px;transition:all .3s ease}.search-box input:focus{border-color:#d32f2f;box-shadow:0 0 0 3px #d32f2f1a}.search-icon{right:15px}.filter-group select{background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;min-width:150px;padding:12px 15px;transition:all .3s ease}.filter-group select:focus{border-color:#d32f2f;box-shadow:0 0 0 3px #d32f2f1a;outline:none}.table-container{margin-bottom:25px}.cancelled-bookings-table{border-collapse:collapse;font-size:14px;width:100%}.cancelled-bookings-table thead{background:#ffebee}.cancelled-bookings-table thead th{border-bottom:2px solid #ffcdd2;color:#d32f2f;font-weight:600;padding:18px 15px;text-align:left;white-space:nowrap}.cancelled-bookings-table tbody tr{border-bottom:1px solid #f0f0f0;transition:all .3s ease}.cancelled-bookings-table tbody tr:hover{background-color:#e5e7eb;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.cancelled-bookings-table tbody td{padding:15px;vertical-align:top}.booking-id{color:#d32f2f;font-family:monospace;font-weight:600}.customer-info{display:flex;flex-direction:column;gap:4px}.customer-name{color:#333;font-weight:600}.customer-contact{color:#666;font-size:12px}.unit-info{display:flex;flex-direction:column;gap:4px}.unit-number{color:#333;font-weight:600}.unit-type{background:#f5f5f5;border-radius:4px;color:#666;display:inline-block;font-size:12px;padding:2px 6px}.amount{color:#d32f2f;font-family:monospace}.cancellation-reason{word-wrap:break-word;color:#666;font-style:italic;max-width:200px}.actions{align-items:center}.btn{border-radius:6px;font-size:12px;gap:6px;padding:8px 12px}.btn-small{font-size:11px;padding:6px 10px}.btn-secondary{background:#757575}.btn-secondary:hover{background:#616161;box-shadow:0 4px 8px #7575754d;transform:translateY(-1px)}.loading,.no-data{padding:50px}.no-data{color:#999}.no-data svg{color:#d32f2f;font-size:48px;margin-bottom:15px}.no-data p{font-size:16px;margin:0}.pagination-container{border-top:1px solid #e0e0e0;margin-top:25px;padding-top:20px}.pagination-info{color:#666;font-weight:500;margin-bottom:15px}.pagination{display:flex!important;flex-direction:row!important;flex-wrap:nowrap}.pagination-btn{border:2px solid #e0e0e0;border-radius:6px;color:#666;display:inline-block;font-size:14px;font-weight:500;min-width:45px;padding:10px 15px;transition:all .3s ease;white-space:nowrap}.pagination-btn:hover:not(:disabled){border-color:#d32f2f;color:#d32f2f;transform:translateY(-1px)}.pagination-btn.active{background:#d32f2f;border-color:#d32f2f;color:#fff}.pagination-btn:disabled{transform:none!important}.modal{box-shadow:0 20px 40px #0000004d;width:100%}.modal-header{background:#fafafa;border-bottom:2px solid #ffebee;padding:25px 30px}.modal-header h2{color:#d32f2f;font-size:22px}.modal-close{border-radius:4px;padding:5px;transition:all .3s ease}.modal-close:hover{background:#f5f5f5;color:#d32f2f}.booking-details{padding:30px}.cancellation-notice{align-items:flex-start;background:#ffebee;border:2px solid #ffcdd2;border-radius:8px;display:flex;gap:15px;margin-bottom:30px;padding:20px}.cancel-icon{color:#d32f2f;font-size:24px;margin-top:5px}.cancellation-notice h3{color:#d32f2f;font-size:18px;margin:0 0 10px}.cancellation-notice p{color:#c62828;margin:5px 0}.details-section{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:30px;padding:20px}.details-section h3{border-bottom:2px solid #e0e0e0;color:#333;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:10px}.info-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{display:flex;flex-direction:column;gap:4px}.info-item label{color:#666;font-size:13px;font-weight:600}.info-item span{color:#333;font-weight:500}.unit-status.available{color:#4caf50;font-weight:600}.applicants-list{display:flex;flex-direction:column;gap:15px}.applicant-card{border:1px solid #e0e0e0;padding:15px}.applicant-header h4{align-items:center;color:#333;display:flex;font-size:16px;gap:10px;margin:0 0 8px}.primary-badge{background:#2196f3;border-radius:4px;color:#fff;font-size:11px;font-weight:500;padding:2px 8px}.applicant-contact{color:#666;font-size:14px}.payment-breakdown{display:flex;flex-direction:column;gap:12px}.payment-item{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:10px 0}.payment-item.total{border-bottom:none;border-top:2px solid #d32f2f;color:#d32f2f;font-size:16px;margin-top:10px}.remarks-text{background:#fff;border:1px solid #e0e0e0;border-radius:6px;color:#333;line-height:1.6;padding:15px;white-space:pre-wrap}.modal-footer{background:#fafafa;border-top:1px solid #e0e0e0;padding:20px 30px}.error-message{background-color:#ffebee;border:1px solid #ef9a9a;justify-content:space-between;padding:15px}.error-close,.error-message{align-items:center;color:#c62828;display:flex}.error-close{background:none;border:none;cursor:pointer;font-size:18px;font-weight:700;height:24px;justify-content:center;padding:0;width:24px}@media (max-width:768px){.cancelled-bookings-page{padding:15px}.page-header{align-items:flex-start}.filters-section,.page-header{flex-direction:column;gap:15px}.search-box{width:100%}.cancelled-bookings-table{font-size:12px}.cancelled-bookings-table tbody td,.cancelled-bookings-table thead th{padding:10px 8px}.cancellation-reason{max-width:150px}.info-grid{grid-template-columns:1fr}.modal{margin:10px}.booking-details{padding:20px}.pagination{flex-wrap:wrap}}.unit-search-container input{border:1px solid #e5e7eb;border-radius:6px;font-size:14px;padding:10px;width:100%}.unit-search-container input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.success-message{align-items:center;animation:slideInRight .3s ease;background:linear-gradient(135deg,#10b981,#059669);border-radius:8px;box-shadow:0 4px 12px #10b9814d;color:#fff;display:flex;gap:16px;justify-content:space-between;max-width:400px;padding:16px 24px;position:fixed;right:20px;top:20px;z-index:10000}.success-message .error-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:28px;justify-content:center;transition:background .2s;width:28px}.success-message .error-close:hover{background:#ffffff4d}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.pagination{border-top:1px solid #e1e5e9;flex-direction:column;gap:1rem;margin-top:1rem;padding:1rem 0}.pagination.loading{opacity:.6;pointer-events:none}.pagination-info{text-align:center}.results-info{color:#666;font-size:.875rem}.pagination-controls{flex-wrap:wrap;justify-content:center}.pagination-btn,.pagination-controls{align-items:center;display:flex;gap:.5rem}.pagination-btn{background:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#374151;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{background:#f9fafb;cursor:not-allowed;opacity:.5}.pagination-btn.next svg,.pagination-btn.prev svg{font-size:.75rem}.page-btn,.page-numbers{align-items:center}.page-btn{border-radius:.375rem;display:flex;font-size:.875rem;font-weight:500;height:2.5rem;justify-content:center;min-width:2.5rem;transition:all .2s}.page-btn:hover:not(:disabled){background:#f3f4f6}.page-btn.active{background:#3b82f6;border-color:#3b82f6}.page-btn.active:hover{background:#2563eb;border-color:#2563eb}.ellipsis{color:#6b7280;font-weight:500;padding:0 .5rem}@media (max-width:768px){.pagination{padding:.75rem 0}.pagination-controls{gap:.25rem}.pagination-btn{font-size:.75rem;padding:.375rem .75rem}.page-btn{height:2rem;min-width:2rem}.page-btn,.results-info{font-size:.75rem}}@media (max-width:480px){.pagination-controls{flex-direction:column;gap:.5rem}.pagination-btn{justify-content:center;min-width:120px}}.return-cancel-income-page{display:flex;flex-direction:column;height:100vh;max-width:100%;overflow:hidden;padding:20px}.page-header{border-bottom:2px solid #e3f2fd;padding-bottom:15px}.header-content{align-items:center;display:flex;justify-content:space-between}.title-section h1{margin:0}.add-cancel-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease}.add-cancel-btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.page-header h1{align-items:center;color:#1976d2;display:flex;font-size:28px;gap:12px;margin:0}.page-header p{color:#666;font-size:14px;margin:5px 0 0}.search-filters{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:25px}.search-box{min-width:300px}.search-box input{border:1px solid #ddd;border-radius:8px;padding:12px 40px 12px 16px}.search-icon{color:#666;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.summary-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.summary-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;gap:15px;padding:20px}.card-icon,.summary-card{align-items:center;display:flex}.card-icon{border-radius:50%;color:#fff;font-size:20px;height:50px;justify-content:center;width:50px}.card-icon.refund{background:linear-gradient(135deg,#4caf50,#66bb6a)}.card-icon.retained{background:linear-gradient(135deg,#ff9800,#ffb74d)}.card-icon.total{background:linear-gradient(135deg,#2196f3,#42a5f5)}.card-content h3{color:#333;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.card-content .amount{color:#1976d2;font-size:20px;font-weight:700;margin:0}.card-content .count{color:#1976d2;font-size:24px;font-weight:700;margin:0}.cancel-receivable-table-container,.table-container{border-radius:12px;box-shadow:0 4px 6px #0000001a;flex:1 1;margin-bottom:20px;overflow:auto!important}.cancel-receivable-table-container{background:#fff}.cancel-receivable-table-container::-webkit-scrollbar,.table-container::-webkit-scrollbar{height:10px;width:10px}.cancel-receivable-table-container::-webkit-scrollbar-track,.table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.cancel-receivable-table-container::-webkit-scrollbar-thumb,.table-container::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.cancel-receivable-table-container::-webkit-scrollbar-thumb:hover,.table-container::-webkit-scrollbar-thumb:hover{background:#555}.loading{padding:40px}.cancelled-incomes-table{border-collapse:collapse;display:table;width:100%}.cancelled-incomes-table th{background:#f5f5f5;border-bottom:2px solid #ddd;box-shadow:0 2px 2px -1px #0000001a;color:#333;font-size:13px;font-weight:600;letter-spacing:.5px;padding:15px 12px;position:-webkit-sticky;position:sticky;text-align:left;text-transform:uppercase;top:0;z-index:10}.cancelled-incomes-table td{border-bottom:1px solid #eee;padding:15px 12px;vertical-align:middle}.cancelled-incomes-table tbody tr:hover{background-color:#e5e7eb}.amount{color:#333}.amount.refund{color:#4caf50}.amount.retained{color:#ff9800}.status-badge{letter-spacing:.5px;padding:6px 12px}.status-badge.processed{background:#e8f5e8;color:#4caf50}.status-badge.pending{background:#fff3e0;color:#ff9800}.status-badge.cancelled{background:#ffebee;color:#f44336}.action-buttons{display:flex;gap:8px}.action-btn{border-radius:6px;font-size:14px;padding:8px 10px}.action-btn.view{background:#e3f2fd;color:#1976d2}.action-btn.view:hover{background:#1976d2;color:#fff}.pagination{gap:20px;padding:20px 0}.pagination button{background:#fff;border:1px solid #ddd;border-radius:6px;color:#333;cursor:pointer;font-size:14px;padding:10px 16px;transition:all .2s ease}.pagination button:hover:not(:disabled){background:#1976d2;border-color:#1976d2;color:#fff}.pagination button:disabled{cursor:not-allowed;opacity:.5}.pagination span{color:#666;font-size:14px}@media (max-width:768px){.return-cancel-income-page{padding:10px}.summary-cards{grid-template-columns:1fr}.search-filters{flex-direction:column}.table-container{overflow-x:auto}.cancelled-incomes-table{min-width:800px}}.modal-overlay{background-color:#00000080}.modal-content{box-shadow:0 10px 25px #0003;padding:0}.modal-content.large{max-width:75vw!important;width:75vw!important}.modal-header{border-bottom:1px solid #eee;padding:20px}.modal-header h2{color:#1976d2}.modal-close{color:#666;font-size:24px;height:30px;width:30px}.modal-close:hover{color:#333}.modal-body{padding:20px}.form-grid{grid-gap:15px;gap:15px;grid-template-columns:1fr 1fr}.form-group.full-width{grid-column:1/-1}.form-group label{margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:6px;padding:10px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{box-shadow:0 0 0 2px #1976d21a}.modal-footer{border-top:1px solid #eee;gap:10px;padding:20px}.btn-primary,.btn-secondary{font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)}.btn-primary:hover{box-shadow:0 4px 12px #667eea4d}.btn-secondary{color:#666}.amount.received{color:#4caf50;font-weight:600}.amount.pending{color:#ff9800;font-weight:600}.card-icon.received{background:linear-gradient(135deg,#4caf50,#81c784)}.dashboard{padding:0}.dashboard-header{margin-bottom:30px}.dashboard-header h1{color:#1f2937;font-size:28px;font-weight:700;margin:0 0 8px}.dashboard-header p{color:#6b7280;font-size:16px;margin:0}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:40px}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.stat-content{align-items:center;display:flex;justify-content:space-between}.stat-info{flex:1 1}.stat-title{color:#6b7280;font-size:14px;font-weight:500;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.stat-value{color:#1f2937;font-size:32px;font-weight:700;margin:0 0 8px}.stat-change{align-items:center;display:flex;font-size:14px;font-weight:500;gap:4px}.stat-change.positive{color:#16a34a}.stat-change.negative{color:#dc2626}.stat-icon{align-items:center;border-radius:12px;color:#fff;display:flex;font-size:24px;height:60px;justify-content:center;width:60px}.stat-icon.blue{background:linear-gradient(135deg,#6b7280,#4b5563)}.stat-icon.green{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-icon.orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.dashboard-content{grid-gap:30px;display:grid;gap:30px}.dashboard-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.section-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.section-header h2{color:#1f2937;font-size:20px;font-weight:600;margin:0}.btn{padding:10px 20px}.data-table td,.data-table th{border-bottom:1px solid #e5e7eb;padding:12px 16px;text-align:left}.data-table th{background:#f9fafb;color:#374151;font-size:14px;letter-spacing:.5px;text-transform:uppercase}.data-table td{color:#4b5563}.data-table tr:hover{background:#e5e7eb}.amount{color:#1f2937}.status{letter-spacing:.5px}.status.confirmed{background:#dcfce7;color:#166534}.status.pending{background:#fef3c7;color:#92400e}.status.under-review{background:#f3f4f6;color:#374151}.quick-actions{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.action-card{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;color:#4b5563;cursor:pointer;display:flex;flex-direction:column;font-size:16px;gap:12px;padding:20px;transition:all .2s ease}.action-card:hover{background:#374151;border-color:#374151;color:#fff;transform:translateY(-2px)}.action-card svg{font-size:24px}@media (max-width:768px){.stats-grid{grid-template-columns:1fr}.section-header{align-items:stretch;flex-direction:column;gap:16px}.quick-actions{grid-template-columns:repeat(2,1fr)}.dashboard-header h1{font-size:24px}}.modal-overlay{animation:modalOverlayFadeIn .2s ease-out;background:#000000bf;z-index:1050}@keyframes modalOverlayFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:modalSlideIn .3s ease-out;border-radius:16px;box-shadow:0 25px 50px -12px #00000059;position:relative}.modal-content.large-modal{max-width:75vw;width:75vw}.modal-content.xlarge-modal{max-width:85vw;width:85vw}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px 16px 0 0;padding:24px 30px}.modal-header h3{color:#1f2937;font-size:24px;font-weight:700;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-size:24px;font-weight:300;height:40px;justify-content:center;padding:8px;transition:all .2s ease;width:40px}.close-button:hover{background:#f3f4f6;color:#374151}.modal-body{max-height:60vh;padding:30px}.modal-footer{background:#f9fafb;border-radius:0 0 16px 16px;border-top:1px solid #e5e7eb;padding:20px 30px 30px}.payment-terms-display{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:24px;padding:20px}.payment-terms-display h4{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 16px}.payment-summary{grid-gap:12px;display:grid;gap:12px}.payment-summary>div{align-items:center;border-bottom:1px solid #e2e8f0;color:#475569;display:flex;font-size:14px;justify-content:space-between;padding:8px 0}.payment-summary>div:last-child{border-bottom:none}.payment-summary .total{border-top:2px solid #cbd5e1;color:#1e293b;font-size:16px;font-weight:600;margin-top:8px;padding-top:12px}.form-group input,.form-group select,.form-group textarea{background:#fff;border:1px solid #d1d5db;padding:12px 16px;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{min-height:80px}.radio-group{display:flex;gap:20px;margin-top:8px}.radio-label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:8px}.radio-label input[type=radio]{margin:0;width:auto}.new-applicants-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:20px;padding:20px}.applicants-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.applicants-header h4{color:#1e293b;font-size:16px;font-weight:600;margin:0}.btn-sm{font-size:12px;min-width:auto;padding:8px 16px}.applicant-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:16px;padding:16px}.applicant-card:last-child{margin-bottom:0}.applicant-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.applicant-label{color:#374151;font-size:14px;font-weight:600}.remove-applicant-btn{align-items:center;background:#fee2e2;border:none;border-radius:50%;color:#dc2626;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:24px;justify-content:center;transition:all .2s ease;width:24px}.remove-applicant-btn:hover{background:#fecaca}.applicant-form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.applicant-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr 1fr;margin-bottom:12px}.applicant-row:last-child{margin-bottom:0}.transfer-amounts-display{background:#f0f9ff;border:1px solid #bae6fd;border-radius:12px;margin-bottom:20px;padding:20px}.transfer-amounts-display h4{color:#0c4a6e;font-size:16px;font-weight:600;margin:0 0 16px}.transfer-amounts-section{background:#fefce8;border:1px solid #fef08a;border-radius:12px;margin-bottom:20px;padding:20px}.transfer-amounts-section h4{color:#713f12;font-weight:600;margin:0 0 16px}.amounts-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.amount-item{align-items:center;background:#fff;border:1px solid #e0f2fe;border-radius:8px;display:flex;font-size:14px;justify-content:space-between;padding:10px 12px}.amount-item .label{color:#0f172a;font-weight:500}.amount-item .value{color:#1e40af;font-weight:600}.unit-search-container{position:relative}.unit-dropdown{background:#fff;border:1px solid #d1d5db;border-radius:0 0 8px 8px;border-top:none;box-shadow:0 4px 6px -1px #0000001a;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.unit-option{border-bottom:1px solid #f3f4f6;cursor:pointer;padding:12px 16px;transition:background-color .2s ease}.unit-option:hover{background:#f8fafc}.unit-option:last-child{border-bottom:none}.unit-main{color:#1f2937;font-size:14px;font-weight:600}.unit-details{color:#6b7280;font-size:12px;margin-top:2px}.no-results{color:#6b7280;font-style:italic;padding:12px 16px;text-align:center}.btn{border:none;display:inline-flex;font-weight:600;justify-content:center;min-width:120px;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#f8fafc;border:1px solid #cbd5e1;color:#475569}.btn-secondary:hover:not(:disabled){background:#f1f5f9;border-color:#94a3b8}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-primary{background:#2563eb}.btn-primary:hover:not(:disabled){background:#1d4ed8}.error{color:#dc2626;display:block;font-size:13px;margin-top:4px}@media (max-width:768px){.modal-overlay{padding:16px}.modal-content{margin:0;max-width:none}.modal-header{padding:20px 24px}.modal-header h3{font-size:20px}.modal-body{padding:24px}.modal-footer{flex-direction:column-reverse;padding:16px 24px 24px}.btn{width:100%}.radio-group{flex-direction:column;gap:12px}.applicant-form-grid{gap:12px;grid-template-columns:1fr}.applicant-row{gap:8px;grid-template-columns:1fr}.amounts-grid{gap:12px;grid-template-columns:1fr}}@media (max-width:480px){.modal-header{padding:16px 20px}.modal-body{padding:20px}.modal-footer{padding:12px 20px 20px}}.unit-base-price-info{background-color:#f8f9fa;border-left:4px solid #007bff;border-radius:6px;margin-bottom:15px;padding:8px 12px}.unit-base-price-info small{color:#495057;font-weight:500}.help-text{color:#6c757d;display:block;font-size:12px;line-height:1.3;margin-top:4px}.transfer-amounts-section h4{color:#495057;font-size:16px;margin-bottom:15px}.income-container{margin:0;min-height:100vh;padding:0;width:100%}.income-header{background:#fff;border-bottom:1px solid #e0e0e0;box-sizing:border-box;justify-content:space-between;padding:20px 24px;width:100%}.add-income-btn,.income-header{align-items:center;display:flex}.add-income-btn{background:#1976d2;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;gap:8px;padding:12px 24px;text-decoration:none;transition:all .3s ease}.add-income-btn:hover{background:#1565c0;transform:translateY(-1px)}.income-controls{background:#fff;flex-wrap:wrap;gap:16px;justify-content:flex-start;padding:20px 24px}.income-controls,.search-bar{align-items:center;display:flex}.search-bar svg{z-index:1}.filter-bar select{min-width:150px}.income-table-container{background:#fff;border:1px solid #e0e0e0;border-radius:0;box-shadow:none;margin:0;overflow-x:auto;overflow-y:hidden;width:100%}.income-table{border:none;border-collapse:collapse;min-width:1100px;table-layout:fixed;width:100%}.income-table thead{background:#f8f9fa;border-bottom:1px solid #e0e0e0}.income-table th{border-bottom:1px solid #e0e0e0;border-left-style:solid;border-right:1px solid #e0e0e0;border-top-style:solid;color:#1565c0;font-size:14px;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase}.income-table th:last-child{border-right:none}.income-table td{border-bottom:1px solid #e0e0e0;border-left-style:solid;border-right:1px solid #e0e0e0;border-top-style:solid;padding:16px 20px;vertical-align:middle}.income-table td:last-child{border-right:none}.income-table tbody tr:hover{background:#e5e7eb}.income-table tbody tr:last-child td{border-bottom:none}.status{border-radius:12px;font-size:12px;padding:4px 12px}.amount{color:#1976d2;font-weight:600}.booking-id{color:#333;font-weight:500}.customer-info,.payment-method,.project-name,.reference,.unit-number{color:#666}.created-date,.payment-date{color:#666;font-size:13px}.income-actions{align-items:center;display:flex;gap:8px}.btn-icon{font-size:14px}.btn-icon.view{background:#e3f2fd;color:#1976d2}.btn-icon.view:hover{background:#bbdefb}.btn-icon.edit{background:#fff3e0;color:#f57c00}.btn-icon.edit:hover{background:#ffe0b2}.btn-icon.delete{background:#ffebee}.btn-icon.delete:hover{background:#ffcdd2}.empty-state{padding:60px 20px}.empty-icon{color:#ddd}.empty-state h3{margin-bottom:8px}.empty-state p{margin-bottom:24px}.pagination{background:#fff;border-top:1px solid #e0e0e0;padding:24px}.page-btn{border:1px solid #e0e0e0;border-radius:6px;color:#666;padding:8px 16px}.page-btn:hover:not(:disabled){background:#f5f5f5;border-color:#1976d2;color:#1976d2}.page-btn.active{background:#1976d2;border-color:#1976d2}.modal{box-shadow:0 4px 24px #00000026;max-width:600px}.modal-header{border-bottom:1px solid #e0e0e0;padding:20px 24px}.modal-header h2{color:#333}.close-btn{align-items:center;border-radius:50%;display:flex;height:32px;justify-content:center;padding:0;transition:background-color .3s ease;width:32px}.close-btn:hover{background:#f5f5f5}.modal-content{max-width:600px;padding:24px;width:90%}.modal-content.large-modal{max-width:75vw!important;width:75vw!important}.modal-form{padding:24px}.form-group input,.form-group select,.form-group textarea{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:14px;padding:12px;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#1976d2;outline:none}.form-group textarea{font-family:inherit;resize:vertical}.modal-actions{border-top:1px solid #e0e0e0;padding:24px}.cancel-btn{background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#666;cursor:pointer;padding:12px 24px;transition:all .3s ease}.cancel-btn:hover{background:#f5f5f5;border-color:#ccc}.submit-btn{background:#1976d2;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:12px 24px;transition:all .3s ease}.submit-btn:hover{background:#1565c0}.history-table-container{max-height:400px;overflow-y:auto}.history-table td,.history-table th{border-bottom:1px solid #e0e0e0;padding:12px;text-align:left}.history-table th{color:#1565c0;position:-webkit-sticky;position:sticky;top:0}.loading{align-items:center;display:flex;font-size:18px;justify-content:center;min-height:400px}@media (max-width:768px){.income-controls{align-items:stretch;flex-direction:column}.search-bar{min-width:auto}.filter-bar{justify-content:stretch}.filter-bar select{min-width:auto;width:100%}.income-table{font-size:12px}.income-table td,.income-table th{padding:8px 12px}.modal{margin:20px;width:calc(100% - 40px)}}.large-modal{max-height:80vh;max-width:1200px;width:90%}.tab-navigation{border-bottom:2px solid #e0e0e0;margin-bottom:20px}.tab-btn{background:#0000;color:#666;font-size:14px;padding:12px 24px}.tab-btn.active{background:#1976d20d;border-bottom-color:#1976d2;color:#1976d2}.tab-btn:hover{background:#1976d21a}.tab-content{padding:20px 0}.tab-description{background:#f5f5f5;border-radius:6px;color:#666;font-size:14px;margin-bottom:20px;padding:12px}.cheque-table{border-collapse:collapse;margin-top:15px;width:100%}.cheque-table td,.cheque-table th{border-bottom:1px solid #e0e0e0;padding:12px;text-align:left}.cheque-table th{background:#f8f9fa;color:#333;font-weight:600}.overdue-days{color:#d32f2f;font-weight:600}.days-until-due{color:#ff9800;font-weight:600}.deposit-date-input{border:1px solid #ddd;border-radius:4px;font-size:12px;margin-right:8px;padding:6px 8px;width:140px}.deposit-date-input:focus{border-color:#1976d2;outline:none}.deposit-date-action{align-items:center;display:flex;gap:8px}.apply-btn{background:#1976d2;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;min-width:70px;padding:6px 12px;transition:background .3s ease}.apply-btn:hover:not(:disabled){background:#1565c0}.apply-btn:disabled{background:#ccc;cursor:not-allowed}.no-data{color:#666}.btn.btn-secondary{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .3s ease}.btn.btn-secondary:hover{background:#5a6268}.btn.btn-secondary svg{margin-right:6px}.income-page .content-section{background:#fff;margin:0;padding:0}.income-page .standard-table{border-collapse:collapse;font-size:14px;width:100%}.income-page .standard-table td,.income-page .standard-table th{background:#0000!important}.income-page .standard-table.slim td,.income-page .standard-table.slim th{padding:8px 12px}.income-page .standard-table tbody tr:hover{background:#e5e7eb!important}.income-page .booking-id{background:none!important;border-radius:0!important;color:#111!important;display:inline-block;font-family:inherit!important;font-weight:500!important;padding:0!important}.income-page td.amount-cell{text-align:right}.income-page .status-text{color:#374151;font-size:13px}.historical-upload-container{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;padding:20px}.upload-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;margin-bottom:30px;padding:20px;text-align:center}.upload-header h2{font-size:2rem;margin:0 0 10px}.upload-header p{margin:0;opacity:.9}.step-indicator{display:flex;gap:20px;justify-content:center;margin-top:20px}.step{background:#fff3;border-radius:20px;color:#ffffffb3;font-size:.9rem;padding:8px 16px;transition:all .3s ease}.step.active{background:#ffffff4d;color:#fff;font-weight:600}.step.completed{background:#4caf50cc;color:#fff}.upload-form{background:#fff;border-radius:10px;box-shadow:0 4px 6px #0000001a;margin-bottom:30px;padding:30px}.form-group label{font-weight:600;margin-bottom:8px}.form-group input[type=file],.form-group select{border:2px solid #e1e5e9;font-size:14px;padding:12px;transition:border-color .3s ease}.form-group input[type=file]:focus,.form-group select:focus{border-color:#667eea}.form-group input[type=file]:disabled,.form-group select:disabled{background-color:#f8f9fa;cursor:not-allowed}.file-info{background-color:#e8f5e8;border:1px solid #28a745;border-radius:4px;color:#155724;font-size:14px;margin-top:8px;padding:8px 12px}.template-btn{background:#17a2b8;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .3s ease}.template-btn:hover:not(:disabled){background:#138496}.template-btn:disabled{background:#6c757d;cursor:not-allowed}.upload-btn{background:#28a745;font-size:16px;font-weight:600;padding:15px;transition:background-color .3s ease}.upload-btn:hover:not(:disabled){background:#218838}.upload-btn:disabled{background:#6c757d}.error-message{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;margin-top:15px;padding:12px}.success-result{background:#d4edda;border:1px solid #c3e6cb;border-radius:6px;margin-top:20px;padding:20px}.success-result h3{color:#155724;margin:0 0 15px}.result-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.stat{background:#fff;border-left:4px solid #28a745;border-radius:6px;padding:12px}.created-bookings,.error-list{margin-top:20px}.created-bookings h4,.error-list h4{color:#155724;margin:0 0 10px}.booking-list,.errors{background:#fff;border-radius:6px;max-height:200px;overflow-y:auto;padding:10px}.booking-item,.error-item{border-bottom:1px solid #e9ecef;font-size:14px;padding:8px}.booking-item:last-child,.error-item:last-child{border-bottom:none}.error-item{color:#721c24}.more-items{color:#6c757d;font-style:italic;padding:8px;text-align:center}.instructions{background:#fff;border-radius:10px;box-shadow:0 4px 6px #0000001a;padding:30px}.instructions h3{border-bottom:2px solid #667eea;color:#333;margin:0 0 15px;padding-bottom:10px}.instructions ol,.instructions ul{padding-left:20px}.instructions li{line-height:1.6;margin-bottom:8px}.format-info{background:#f8f9fa;border-left:4px solid #17a2b8;border-radius:6px;margin-top:20px;padding:20px}.format-info h4{color:#333;margin:0 0 10px}.format-info ul{margin:0}@media (max-width:768px){.historical-upload-container{padding:10px}.instructions,.upload-form{padding:20px}.upload-header h2{font-size:1.5rem}.result-stats{grid-template-columns:1fr}}.preview-btn{background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px;transition:all .3s ease;width:100%}.preview-btn:hover:not(:disabled){box-shadow:0 6px 12px #4caf504d;transform:translateY(-2px)}.preview-btn:disabled{background:#ccc;cursor:not-allowed}.preview-container{background:#fff;border-radius:10px;box-shadow:0 4px 6px #0000001a;margin-bottom:30px;padding:30px}.preview-header{background:#f8f9fa;border-radius:8px;margin-bottom:30px;padding:20px;text-align:center}.preview-data{margin-bottom:30px;max-height:600px;overflow-y:auto}.booking-preview{background:#fafafa;border:2px solid #e1e5e9;border-radius:8px;margin-bottom:20px}.booking-header{background:#f0f2f5;border-bottom:1px solid #e1e5e9;border-radius:6px 6px 0 0;padding:15px 20px}.booking-header h4{align-items:center;color:#333;display:flex;justify-content:space-between;margin:0}.booking-type{border-radius:12px;font-size:.8rem;font-weight:600;padding:4px 12px}.booking-type.cancelled{background:#ffebee;color:#c62828}.booking-type.transferred{background:#e3f2fd;color:#1565c0}.transaction-summary{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;padding:20px}.transaction-group{border:1px solid #ddd;border-radius:6px;padding:15px}.transaction-group.sale-deed{background:#f9f9f9;border-color:#2196f3}.transaction-group.hidden{background:#fff8e1;border-color:#ff9800}.transaction-group h5{color:#333;margin:0 0 10px}.summary-stats{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:10px}.summary-stats span{border-radius:4px;font-size:.9rem;font-weight:600;padding:4px 8px}.summary-stats .income{background:#e8f5e8;color:#2e7d32}.summary-stats .refund{background:#ffebee;color:#c62828}.summary-stats .net{background:#e3f2fd;color:#1565c0;font-weight:700}.transaction-details{margin-top:10px}.transaction-details summary{color:#555;cursor:pointer;font-weight:600;margin-bottom:8px}.transaction{background:#f5f5f5;border-radius:4px;font-size:.9rem;margin:4px 0;padding:6px 12px}.transaction.refund{background:#ffebee;color:#c62828}.preview-actions{border-top:1px solid #e1e5e9;display:flex;gap:20px;justify-content:center;padding-top:20px}.back-btn,.proceed-btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 30px;transition:all .3s ease}.back-btn{background:#6c757d;color:#fff}.back-btn:hover{background:#5a6268}.proceed-btn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.proceed-btn:hover:not(:disabled){box-shadow:0 6px 12px #4caf504d;transform:translateY(-2px)}.proceed-btn:disabled{background:#ccc;cursor:not-allowed}.results-container{background:#fff;border-radius:10px;box-shadow:0 4px 6px #0000001a;padding:30px}.result-actions{border-top:1px solid #e1e5e9;margin-top:30px;padding-top:20px;text-align:center}.new-upload-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 30px;transition:all .3s ease}.new-upload-btn:hover{box-shadow:0 6px 12px #667eea4d;transform:translateY(-2px)}.historical-upload-container{margin:0;max-width:none;padding:0}.page-header{margin-bottom:1rem}.tabs-container{border-bottom:2px solid #e0e0e0;display:flex;gap:1rem;margin-bottom:2rem}.tab-btn{background:none;border:none;border-bottom:3px solid #0000;color:#7f8c8d;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.tab-btn:hover{background:#f8f9fa;color:#2c3e50}.tab-btn.active{border-bottom-color:#3498db;color:#3498db}.page-header h1{margin-bottom:.5rem}.page-description{color:#7f8c8d;font-size:1rem}.instructions-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:1.5rem}.instructions-card h3{color:#2c3e50;margin-bottom:1rem}.instructions-card ul{list-style:none;padding-left:0}.instructions-card li{color:#34495e;font-size:.95rem;padding:.5rem 0}.instructions-card li code{background:#ecf0f1;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem;padding:.2rem .4rem}.download-sample-btn{background:#3498db;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;margin-top:1rem;padding:.75rem 1.5rem;transition:background .3s}.download-sample-btn:hover{background:#2980b9}.upload-form-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:2rem}.upload-form-card h3{color:#2c3e50;margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#2c3e50;margin-bottom:.5rem}.form-group input[type=file],.form-group select{border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:.75rem;width:100%}.form-group input[type=file]:focus,.form-group select:focus{border-color:#3498db;outline:none}.file-info{background:#ecf0f1;margin-top:1rem;padding:1rem}.file-info p{color:#34495e;margin:.25rem 0}.error-message{background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;margin-bottom:1rem;padding:1rem}.upload-btn{background:#27ae60;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:500;padding:1rem;transition:background .3s;width:100%}.upload-btn:hover:not(:disabled){background:#229954}.upload-btn:disabled{background:#95a5a6;cursor:not-allowed}.result-card{border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:2rem}.result-card.success{background:#d4edda;border:1px solid #c3e6cb}.result-card.error{background:#f8d7da;border:1px solid #f5c6cb}.result-card h3{color:#2c3e50;margin-bottom:1rem}.result-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:1.5rem 0}.summary-item{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;padding:1rem}.summary-item strong{color:#7f8c8d;display:block;font-size:.85rem;margin-bottom:.5rem}.cancel-units-result{margin-top:2rem}.cancel-units-result h4{color:#2c3e50;margin-bottom:1rem}.stats{display:flex;gap:1rem;margin-bottom:1.5rem}.stat-item{border-radius:6px;flex:1 1;padding:1rem}.stat-item.success{background:#d4edda;color:#155724}.stat-item.failed{background:#f8d7da;color:#721c24}.errors-section{background:#fff3cd;border-radius:6px;margin-bottom:1.5rem;padding:1rem}.errors-section h5{color:#856404;margin-bottom:.5rem}.errors-section ul{color:#856404;margin:.5rem 0 0 1.5rem}.bookings-section{background:#fff;border-radius:6px;padding:1.5rem}.bookings-section h5{color:#2c3e50;margin-bottom:1rem}.bookings-table-container{overflow-x:auto}.bookings-table{border-collapse:collapse;width:100%}.bookings-table td,.bookings-table th{border-bottom:1px solid #ddd;padding:.75rem;text-align:left}.bookings-table th{background:#ecf0f1;color:#2c3e50;font-weight:600}.bookings-table tr:hover{background:#e5e7eb}.format-reference{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:2rem}.format-reference h3{color:#2c3e50;margin-bottom:1.5rem}.format-section{margin-bottom:2rem}.format-section h4{color:#34495e;margin-bottom:.75rem}.format-section pre{background:#2c3e50;border-radius:6px;color:#ecf0f1;font-family:Courier New,monospace;font-size:.9rem;overflow-x:auto;padding:1rem}.format-section code{background:#ecf0f1;border-radius:4px;font-family:Courier New,monospace;padding:.2rem .4rem}.format-table{border-collapse:collapse;margin-top:1rem;width:100%}.format-table td,.format-table th{border:1px solid #ddd;padding:.75rem;text-align:left}.format-table th{background:#ecf0f1;color:#2c3e50;font-weight:600}.format-notes{background:#e8f4f8;border-left:4px solid #3498db;border-radius:6px;padding:1.5rem}.format-notes h4{color:#2c3e50;margin-bottom:1rem}.format-notes ul{list-style:none;padding-left:0}.format-notes li{color:#34495e;padding:.5rem 0}.format-notes li strong{color:#2c3e50}.format-notes li code{background:#d4e6f1;border-radius:4px;color:#1a5490;font-family:Courier New,monospace;padding:.2rem .4rem}@media (max-width:768px){.historical-upload-container{padding:1rem}.result-summary{grid-template-columns:1fr}.stats{flex-direction:column}}.login-container{align-items:center;background:linear-gradient(135deg,#1e3a8a,#3730a3);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-header h1{color:#1f2937;font-size:28px;font-weight:700;margin:0 0 8px}.login-header p{color:#6b7280;font-size:16px;margin:0}.form-group input{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.form-group input:focus{border-color:#1e3a8a;box-shadow:0 0 0 3px #1e3a8a1a;outline:none}.login-btn{background:#1e3a8a;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;margin-top:20px;padding:12px 16px;transition:all .2s ease;width:100%}.login-btn:hover:not(:disabled){background:#1e40af;transform:translateY(-1px)}.login-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;margin-bottom:20px;padding:12px 16px}.login-footer{border-top:1px solid #e5e7eb;margin-top:30px;padding-top:20px;text-align:center}.login-footer p{color:#6b7280;font-size:12px;margin:4px 0}.login-footer p:first-child{color:#374151;font-weight:500}@media (max-width:480px){.login-container{padding:10px}.login-card{padding:30px 20px}}.other-income-container{background:#f8f9fa;min-height:100vh;padding:2rem}.other-income-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.other-income-header h1{color:#2c3e50;font-size:2rem;font-weight:600;margin:0}.add-other-income-btn{align-items:center;background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.add-other-income-btn:hover{background:linear-gradient(135deg,#0056b3,#004085);box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}.bulk-approve-btn{align-items:center;background:linear-gradient(135deg,#28a745,#1e7e34);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.bulk-approve-btn:hover{background:linear-gradient(135deg,#1e7e34,#155724);box-shadow:0 4px 12px #28a7454d;transform:translateY(-2px)}.other-income-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.filter-bar input,.filter-bar select{background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;font-size:.95rem;outline:none;padding:.75rem 1rem;transition:all .3s ease}.filter-bar input:focus,.filter-bar select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.clear-filters-btn{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:.75rem 1rem;transition:all .3s ease}.clear-filters-btn:hover{background:#545b62}.other-income-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;overflow:hidden}.other-income-table{border-collapse:collapse;width:100%}.other-income-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#2c3e50;font-weight:600;padding:1rem .75rem;text-align:left;white-space:nowrap}.other-income-table td{border-bottom:1px solid #f1f2f6;padding:1rem .75rem;vertical-align:middle}.other-income-table tr:hover{background:#e5e7eb}.income-head-info{display:flex;flex-direction:column}.head-name{color:#2c3e50;font-weight:600}.head-description{color:#6c757d;font-size:.85rem;margin-top:.25rem}.other-income-actions{align-items:center;display:flex;gap:.5rem}.btn-icon.approve{color:#28a745}.btn-icon.approve:hover{background:#d4edda;color:#155724}.btn-icon.reject{color:#dc3545}.btn-icon.reject:hover{background:#f8d7da;color:#721c24}@media (max-width:768px){.other-income-container{padding:1rem}.other-income-header{flex-direction:column;gap:1rem;text-align:center}.other-income-controls{align-items:stretch;flex-direction:column}.search-bar{min-width:0;min-width:auto}.other-income-table-container{overflow-x:auto}.other-income-table{min-width:800px}}.partner-ledger-container{background:#f8f9fa;min-height:100vh;padding:2rem}.partner-ledger-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.header-left{gap:1rem}.page-icon{color:#007bff;font-size:2rem}.partner-ledger-header h1{color:#2c3e50;font-size:2rem;font-weight:600;margin:0}.header-actions{gap:1rem}.add-partner-income-btn{align-items:center;background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.add-partner-income-btn:hover{background:linear-gradient(135deg,#0056b3,#004085);box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}.partner-ledger-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.search-bar{min-width:300px}.search-bar input{border:2px solid #e9ecef;font-size:1rem;outline:none;padding:.75rem 1rem .75rem 2.5rem;transition:all .3s ease}.search-bar input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.search-bar svg{color:#6c757d;left:.75rem}.filter-bar{gap:.5rem}.filter-bar select{border:2px solid #e9ecef;font-size:.95rem;outline:none;padding:.75rem 1rem;transition:all .3s ease}.filter-bar select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.partner-ledger-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;overflow:hidden}.partner-ledger-table{border-collapse:collapse;width:100%}.partner-ledger-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#2c3e50;font-weight:600;padding:1rem .75rem;text-align:left;white-space:nowrap}.partner-ledger-table td{border-bottom:1px solid #f1f2f6;padding:1rem .75rem;vertical-align:middle}.partner-ledger-table tr:hover{background:#e5e7eb}.transaction-type{border-radius:20px;font-size:.85rem;font-weight:500;padding:.25rem .75rem;text-transform:uppercase}.transaction-income{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.transaction-disbursement{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.income-amount{color:#28a745;font-weight:600}.disbursement-amount{color:#dc3545;font-weight:600}.status{border-radius:20px;font-size:.85rem;font-weight:500;padding:.25rem .75rem;text-transform:uppercase}.status-pending{background:#fff3cd;border:1px solid #ffeaa7;color:#856404}.status-approved{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.status-rejected{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.partner-income-actions{align-items:center;display:flex;gap:.5rem}.btn-icon{border-radius:4px;font-size:.9rem;padding:.5rem}.btn-icon.view{color:#007bff}.btn-icon.view:hover{background:#e3f2fd;color:#0056b3}.btn-icon.edit{color:#ffc107}.btn-icon.edit:hover{background:#fff3e0;color:#f57c00}.btn-icon.delete{color:#dc3545}.empty-state{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:4rem 2rem}.empty-icon{color:#dee2e6;font-size:4rem;margin-bottom:1rem}.empty-state h3{color:#6c757d;margin-bottom:.5rem}.empty-state p{color:#adb5bd;margin-bottom:2rem}.pagination{gap:.5rem;margin-top:2rem}.page-btn{border:1px solid #dee2e6;color:#495057;padding:.5rem 1rem;transition:all .3s ease}.page-btn:hover:not(:disabled){color:#fff}.page-btn.active,.page-btn:hover:not(:disabled){background:#007bff;border-color:#007bff}.page-numbers{gap:.25rem}.modal{box-shadow:0 10px 25px #0003}.modal.large{max-width:75vw;width:75vw}.modal-header{padding:1.5rem 2rem}.close-btn{color:#6c757d;font-size:1.5rem;padding:.25rem}.close-btn:hover{background:#f8f9fa;color:#dc3545}.modal-content{max-width:75vw;overflow-y:auto;padding:1.5rem 2rem;width:75vw}.modal-body-with-table{-webkit-overflow-scrolling:touch;max-width:100%;overflow-x:auto}.history-table-container{overflow-x:auto}.history-table{border-collapse:collapse;font-size:.9rem;width:100%}.history-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#2c3e50;font-weight:600;padding:.75rem .5rem;text-align:left;white-space:nowrap}.history-table td{border-bottom:1px solid #f1f2f6;padding:.75rem .5rem;vertical-align:middle}.history-table tr:hover{background:#e5e7eb}.loading{color:#6c757d;font-style:italic;padding:2rem}@media (max-width:768px){.partner-ledger-container{padding:1rem}.partner-ledger-header{flex-direction:column;gap:1rem;text-align:center}.partner-ledger-controls{align-items:stretch;flex-direction:column}.search-bar{min-width:0;min-width:auto}.partner-ledger-table-container{overflow-x:auto}.partner-ledger-table{min-width:800px}.modal{margin:1rem;width:95%}}.partners-container{padding:24px;width:100%}.partners-header{align-items:center;border-bottom:2px solid #e3f2fd;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.header-left{align-items:center;gap:12px}.header-left h1{color:#1565c0;font-size:28px;font-weight:600;margin:0}.page-icon{color:#1976d2;font-size:32px}.header-actions{align-items:center}.partners-controls{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px}.search-bar{flex:1 1;max-width:300px;position:relative}.search-bar svg{color:#666;font-size:16px;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.search-bar input{border:2px solid #e0e0e0;border-radius:8px;font-size:14px;padding:12px 12px 12px 40px;transition:border-color .3s ease;width:100%}.search-bar input:focus{border-color:#1976d2;outline:none}.filter-bar{align-items:center;gap:8px;position:relative}.filter-bar svg{color:#666;font-size:16px}.filter-bar select{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:14px;min-width:200px;padding:12px 16px;transition:border-color .3s ease}.filter-bar select:focus{border-color:#1976d2;outline:none}.partners-table-container{background:#fff;border:2px solid #e3f2fd;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.partners-table{border-collapse:collapse;width:100%}.partners-table thead{background:#f8f9fa;border-bottom:2px solid #e3f2fd}.partners-table th{color:#1565c0;font-size:14px;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase}.partners-table td{border-bottom:1px solid #f0f0f0;padding:16px 20px;vertical-align:middle}.partners-table tbody tr:hover{background:#e5e7eb}.partners-table tbody tr:last-child td{border-bottom:none}.partner-name{align-items:center;color:#333;display:flex;font-weight:500;gap:12px}.partner-icon{color:#1976d2;font-size:18px}.partner-projects{color:#666;line-height:1.5}.partner-actions{display:flex;gap:8px}.btn-icon{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .3s ease}.btn-icon.edit{color:#1976d2}.btn-icon.edit:hover{background:#e3f2fd;color:#1565c0}.btn-icon.delete{color:#d32f2f}.btn-icon.delete:hover{background:#ffebee;color:#c62828}.empty-state{color:#666;padding:48px 24px;text-align:center}.empty-icon{color:#ccc;font-size:64px;margin-bottom:16px}.empty-state h3{color:#333;margin:0 0 8px}.empty-state p{margin:0 0 24px}.pagination{gap:16px;padding:24px 0}.pagination .page-numbers{display:flex;gap:8px}.pagination .page-btn{background:#fff;border:2px solid #1976d2;border-radius:6px;color:#1976d2;cursor:pointer;font-weight:500;min-width:44px;padding:8px 16px;transition:all .3s ease}.pagination .page-btn:hover:not(:disabled){background:#1976d2;color:#fff}.pagination .page-btn:disabled{border-color:#ccc;color:#ccc;cursor:not-allowed}.pagination .page-btn.active{background:#1976d2;color:#fff}.pagination span{color:#333;font-weight:500}.modal{max-width:500px}.modal-header{padding:24px 24px 0}.modal-header h2{color:#1565c0}.close-btn{color:#666;transition:all .3s ease}.close-btn:hover{background:#f0f0f0;color:#333}.modal form{padding:0 24px 24px}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block}.form-group input,.form-group select{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;padding:12px;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#1976d2}.btn{align-items:center;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 24px;text-decoration:none;transition:all .3s ease}.btn-primary{background:#1976d2}.btn-primary:hover{background:#1565c0;transform:translateY(-1px)}.btn-secondary{background:#f5f5f5;border-color:#e0e0e0;color:#333}.btn-secondary:hover{background:#e0e0e0;border-color:#ccc}.loading{color:#666;padding:48px}@media (max-width:768px){.partners-container{padding:16px}.partners-header{align-items:flex-start;flex-direction:column;gap:16px}.header-actions{justify-content:flex-start;width:100%}.partners-controls{align-items:stretch;flex-direction:column;gap:12px}.filter-bar select,.search-bar{max-width:none;width:100%}.partners-table-container{overflow-x:auto}.partners-table{min-width:600px}.modal{margin:16px;width:95%}.modal-actions{flex-direction:column}.btn{justify-content:center;width:100%}}.units-page{padding:20px}.page-header{justify-content:space-between}.header-left,.page-header{align-items:flex-start;display:flex}.header-left{gap:20px}.back-btn{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:10px 16px;transition:all .2s ease;white-space:nowrap}.back-btn:hover{background:#e5e7eb;border-color:#9ca3af}.page-header h1{color:#1f2937;font-size:24px;font-weight:600;margin:0 0 4px}.header-subtitle{color:#6b7280;font-size:14px;margin:0}.header-actions{display:flex;gap:12px}.filters-section{align-items:center;display:flex;gap:20px;margin-bottom:24px}.search-box{flex:1 1;max-width:400px;position:relative}.search-box svg{color:#9ca3af;font-size:14px;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.search-box input{background:#fff;border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-size:14px;padding:10px 40px 10px 36px;width:100%}.search-box input:focus{border-color:#6b7280;box-shadow:0 0 0 3px #6b72801a;outline:none}.clear-search-btn{align-items:center;background:none;border:none;border-radius:3px;color:#9ca3af;cursor:pointer;display:flex;height:24px;justify-content:center;padding:4px;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:all .2s ease;width:24px}.clear-search-btn:hover{background:#f3f4f6;color:#6b7280}.filter-select{align-items:center;display:flex;gap:8px;position:relative}.filter-select svg{color:#6b7280;font-size:14px}.filter-select select{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;min-width:150px;padding:10px 12px}.filter-select select:focus{border-color:#6b7280;box-shadow:0 0 0 3px #6b72801a;outline:none}.filter-select span{color:#6b7280;font-size:14px;white-space:nowrap}.pagination-info{align-items:center;color:#6b7280;display:flex;font-size:14px;justify-content:center;margin:20px 0 10px}.table-container{border:1px solid #e5e7eb;margin-bottom:24px;overflow:hidden}.units-table{border-collapse:collapse;width:100%}.units-table td,.units-table th{border-bottom:1px solid #f3f4f6;padding:12px;text-align:left}.units-table th{background:#f9fafb;color:#374151;font-size:14px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.units-table tbody tr:hover{background:#e5e7eb}.units-table tbody tr:last-child td{border-bottom:none}.unit-no{color:#1f2937;font-weight:600}.unit-type{color:#374151;font-weight:500}.wing{color:#6b7280;font-weight:500}.size{color:#4b5563}.amount{color:#059669;font-weight:500}.text-right{text-align:right}.status-badge{border-radius:20px;display:inline-block;font-weight:600;text-transform:uppercase}.status-sold{background:#d1fae5;color:#065f46}.status-unsold{background:#fee2e2;color:#991b1b}.status-pending{background:#fef3c7;color:#92400e}.status-hold{background:#e0e7ff;color:#3730a3}.status-default{background:#f3f4f6;color:#374151}.actions{display:flex;gap:8px}.action-btn{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:12px;height:28px;justify-content:center;padding:6px;transition:all .2s ease;width:28px}.action-btn.edit{background:#fef3c7;color:#d97706}.action-btn.edit:hover{background:#fde68a}.action-btn.delete{background:#fee2e2;color:#dc2626}.action-btn.delete:hover{background:#fecaca}.no-data{color:#6b7280;padding:40px}.pagination{align-items:center;display:flex;gap:8px;justify-content:center}.page-btn{background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;font-size:14px;padding:8px 12px;transition:all .2s ease}.page-btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.page-btn:disabled{cursor:not-allowed;opacity:.5}.page-btn.active{background:#374151;border-color:#374151;color:#fff}.page-numbers{display:flex;gap:4px}.loading{color:#6b7280;font-size:16px;padding:60px;text-align:center}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:24px}.form-group{display:flex;flex-direction:column}.form-group label{color:#374151;font-size:14px;font-weight:500;margin-bottom:6px}.form-group input,.form-group select{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{border-color:#6b7280;box-shadow:0 0 0 3px #6b72801a;outline:none}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.btn-primary{align-items:center;background:#374151;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:background .2s ease}.btn-primary:hover{background:#1f2937}.btn-secondary{align-items:center;background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af}@media (max-width:1200px){.form-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.units-page{padding:16px}.page-header{align-items:stretch;flex-direction:column;gap:16px}.header-left{gap:12px}.filters-section,.header-actions,.header-left{flex-direction:column}.filters-section{gap:12px}.search-box{max-width:none}.table-container{overflow-x:auto}.units-table{min-width:1200px}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.pagination{flex-wrap:wrap}}.modal-overlay{background:#00000080;z-index:1000}.modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-height:90vh;max-width:75vw;overflow-y:auto;padding:0;width:90%}.modal.large{max-width:75vw!important;width:75vw!important}.modal-header{border-bottom:1px solid #e5e7eb;margin-bottom:24px;padding:24px 24px 16px}.modal-header h2{color:#1f2937}.close-btn{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:24px;padding:4px;transition:all .2s ease}.close-btn:hover{background:#f3f4f6;color:#374151}.modal-body{padding:0 24px}.modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding:16px 24px 24px}.upload-section{margin-bottom:20px}.upload-steps{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;margin:20px 0;padding:16px}.upload-steps ol{margin:0;padding-left:20px}.upload-steps li{color:#475569;margin-bottom:8px}.file-upload{margin:20px 0;position:relative}.file-upload input[type=file]{cursor:pointer;height:100%;opacity:0;position:absolute;width:100%}.file-upload-label{background:#f8fafc;border:2px dashed #cbd5e1;border-radius:6px;color:#64748b;cursor:pointer;display:block;padding:12px 16px;text-align:center;transition:all .2s ease}.file-upload-label:hover{background:#f1f5f9;border-color:#94a3b8}.file-upload input[type=file]:focus+.file-upload-label{background:#eff6ff;border-color:#3b82f6}.file-info{background:#ecfdf5;border:1px solid #bbf7d0;margin-top:12px;padding:12px}.file-info p{color:#166534;font-size:14px}.file-info p:first-child{font-weight:500}.modal-actions button:disabled{cursor:not-allowed;opacity:.6}.upload-data-container{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0;max-width:none;padding:20px}.page-header{margin-bottom:30px;text-align:center}.page-header h1{color:#2c3e50;font-size:2rem;margin-bottom:10px}.page-header p{color:#7f8c8d;font-size:1.1rem}.tab-navigation{border-bottom:2px solid #ecf0f1;display:flex;margin-bottom:30px}.tab-button{background:#0000;border:none;border-bottom:3px solid #0000;color:#7f8c8d;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:15px 20px;transition:all .3s ease}.tab-button:hover{background-color:#f8f9fa;color:#2c3e50}.tab-button.active{background-color:#f8f9fa;border-bottom-color:#3498db;color:#3498db}.upload-content{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.upload-section{padding:30px}.section-header{margin-bottom:30px}.section-header h2{color:#2c3e50;font-size:1.5rem;margin-bottom:10px}.section-header p{color:#7f8c8d;line-height:1.6}.template-section{background:#f8f9fa;border-left:4px solid #3498db;border-radius:8px;margin-bottom:30px;padding:25px}.template-section h3{color:#2c3e50;font-size:1.2rem;margin-bottom:15px}.format-info{margin-bottom:20px}.format-info p{color:#34495e;font-weight:500;margin-bottom:15px}.format-info ul{list-style:none;padding:0}.format-info li{border-bottom:1px solid #ecf0f1;color:#2c3e50;padding:8px 0}.format-info li:last-child{border-bottom:none}.format-info strong{color:#e74c3c;font-weight:600}.template-button{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:500;gap:8px;padding:12px 24px;transition:all .3s ease}.template-button:hover{background:linear-gradient(135deg,#2980b9,#3498db);box-shadow:0 4px 12px #3498db4d;transform:translateY(-2px)}.file-upload-section{background:#fff;border-top:1px solid #ecf0f1;padding:30px}.file-upload-section h3{color:#2c3e50;font-size:1.2rem;margin-bottom:20px}.file-input-container{margin-bottom:20px}.file-input{display:none}.file-input-label{border:2px dashed #bdc3c7;border-radius:8px;color:#7f8c8d;cursor:pointer;display:block;font-size:1rem;padding:15px 20px;text-align:center;transition:all .3s ease}.file-input-label:hover{background-color:#f8f9fa;border-color:#3498db;color:#3498db}.file-info{background:#d4edda;border:1px solid #c3e6cb;border-radius:6px;margin-bottom:20px;padding:12px 16px}.file-info p{color:#155724;font-weight:500;margin:0}.upload-button{background:linear-gradient(135deg,#27ae60,#2ecc71);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;max-width:300px;padding:15px 30px;transition:all .3s ease;width:100%}.upload-button:hover:not(:disabled){background:linear-gradient(135deg,#2ecc71,#27ae60);box-shadow:0 4px 15px #2ecc714d;transform:translateY(-2px)}.upload-button:disabled{background:#bdc3c7;box-shadow:none;cursor:not-allowed;transform:none}.error-message,.success-message{border-left:4px solid;border-radius:8px;margin-top:20px;padding:20px}.error-message{background:#fadbd8;border-left-color:#e74c3c;color:#c0392b}.success-message{background:#d4edda;border-left-color:#27ae60;color:#27ae60}.error-message h4,.success-message h4{font-size:1.1rem;margin:0 0 10px}.error-message p,.success-message p{line-height:1.5;margin:0}.result-details{margin-top:15px}.result-details p{font-weight:500;margin:5px 0}.error-details,.warning-details{border-radius:6px;margin-top:15px;padding:15px}.error-details{background:#f8d7da;border:1px solid #f5c6cb}.warning-details{background:#fff3cd;border:1px solid #ffeaa7}.error-details h5,.warning-details h5{color:#721c24;margin:0 0 10px}.warning-details h5{color:#856404}.error-details ul,.warning-details ul{margin:0;padding-left:20px}.error-details li,.warning-details li{color:#721c24;margin:5px 0}.warning-details li{color:#856404}.unauthorized-access{align-items:center;display:flex;justify-content:center;min-height:60vh;padding:20px}.unauthorized-content{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:500px;padding:40px;text-align:center;width:100%}.unauthorized-content h2{color:#e74c3c;font-size:2rem;margin-bottom:20px}.unauthorized-content p{color:#7f8c8d;font-size:1.1rem;line-height:1.6;margin-bottom:10px}@media (max-width:768px){.upload-data-container{padding:15px}.tab-navigation{flex-direction:column}.tab-button{margin-bottom:1px}.file-upload-section,.template-section,.upload-section{padding:20px}.page-header h1{font-size:1.5rem}}.project-selection{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:25px;padding:20px}.project-selection h3{color:#2c3e50;font-size:1.1rem;margin:0 0 15px}.project-select{background-color:#fff;border:2px solid #e9ecef;border-radius:6px;font-size:1rem;padding:12px 16px;transition:border-color .3s ease;width:100%}.project-select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.selection-warning{color:#e67e22;font-size:.9rem;font-style:italic;margin:10px 0 0}.upload-warning{color:#e74c3c;font-size:.9rem;font-weight:500;margin:10px 0 0;text-align:center}.loading-spinner{color:#7f8c8d;font-style:italic;padding:20px;text-align:center}.sample-format{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:20px;padding:20px}.sample-format h4{color:#2c3e50;font-size:1rem;margin:0 0 15px}.sample-table{margin-top:10px;overflow-x:auto}.sample-table table{background:#fff;border-collapse:collapse;border-radius:6px;box-shadow:0 1px 3px #0000001a;overflow:hidden;width:100%}.sample-table td,.sample-table th{border-bottom:1px solid #e9ecef;font-size:.85rem;padding:12px 8px;text-align:left}.sample-table th{background:#f1f3f4;color:#2c3e50;font-size:.8rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.sample-table td{color:#495057}.sample-table tr:hover{background:#e5e7eb}.sample-table tr:last-child td{border-bottom:none}.unit-report-container{background:#f8f9fa;min-height:100vh;padding:24px}@media (max-width:768px){.unit-report-container{padding:16px}.report-filters{flex-direction:column}.filter-group{min-width:100%}.charts-grid,.kpi-cards{grid-template-columns:1fr}.chart-card-wide{grid-column:span 1}.bar-label{font-size:12px;min-width:100px}.modal-content{margin:0;max-width:100%}}.income-report-container{background:#f8f9fa;min-height:100vh;padding:24px}.report-header{margin-bottom:24px}.report-header h1{font-size:28px;font-weight:600;margin:0 0 8px}.report-description{color:#6c757d;font-size:14px;margin:0}.report-filters{align-items:flex-end;background:#fff;border-radius:8px;box-shadow:0 2px 4px #00000014;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:20px}.filter-group{gap:6px;min-width:200px}.filter-group label{font-size:13px;font-weight:500}.filter-input,.filter-select{border:1px solid #ced4da;border-radius:6px;font-size:14px;padding:8px 12px;transition:all .2s}.filter-input:focus,.filter-select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.btn-primary,.btn-secondary{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;height:38px;padding:8px 20px;transition:all .2s}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover{background:#0056b3}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.kpi-cards{grid-gap:16px;gap:16px;margin-bottom:24px}.kpi-card{align-items:center;background:#fff;box-shadow:0 2px 4px #00000014;gap:16px;transition:all .2s}.kpi-card:hover{box-shadow:0 4px 8px #0000001f;transform:translateY(-2px)}.kpi-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:24px;height:56px;justify-content:center;width:56px}.kpi-content h3{color:#2c3e50;font-size:24px;font-weight:700;margin:0 0 4px}.kpi-content p{color:#6c757d;font-size:13px;font-weight:500;margin:0}.charts-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.chart-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #00000014;padding:24px}.chart-card-wide{grid-column:span 2}@media (max-width:1200px){.chart-card-wide{grid-column:span 1}}.chart-title{border-bottom:2px solid #f0f0f0;color:#2c3e50;font-size:16px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.chart-content{min-height:280px}.chart-content,.donut-chart{display:flex;flex-direction:column}.donut-chart{gap:12px;padding:16px 0}.donut-segment{cursor:pointer;transition:all .2s}.donut-segment:hover{opacity:.9;transform:translateX(4px)}.segment-bar{align-items:center;border-radius:8px;color:#fff;display:flex;font-size:16px;font-weight:600;height:50px;justify-content:center;margin-bottom:6px;transition:all .2s}.segment-label{display:flex;font-size:13px;justify-content:space-between;padding:0 8px}.status-name{color:#495057;font-weight:500;text-transform:capitalize}.status-count{color:#2c3e50;font-weight:600}.bar-chart-horizontal{display:flex;flex-direction:column;gap:20px;padding:16px 0}.bar-group{align-items:center;display:flex;gap:16px}.bar-label{color:#495057;font-size:14px;font-weight:500;min-width:150px}.bar-container{border-radius:6px;box-shadow:0 2px 4px #00000014;display:flex;flex:1 1;height:40px;overflow:hidden}.bar-segment{align-items:center;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;justify-content:center;transition:all .2s}.bar-segment:hover{filter:brightness(.9);transform:scaleY(1.05)}.bar-segment.sold{background:#28a745}.bar-segment.unsold{background:#ff6b6b}.bar-segment.booked{background:#90ee90}.bar-segment.hold{background:#dc3545}.bar-segment.pending{background:#6c757d}.bar-chart-vertical{align-items:flex-end;display:flex;gap:24px;height:240px;justify-content:space-around;padding:20px 0}.bar-column{align-items:center;flex:1 1;gap:12px}.bar-column,.bar-stack{display:flex;flex-direction:column}.bar-stack{gap:4px;height:100%;justify-content:flex-end;max-width:80px;width:100%}.bar-part{align-items:center;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;justify-content:center;min-height:30px;transition:all .2s;width:100%}.bar-part:hover{filter:brightness(.9);transform:scaleX(1.05)}.bar-part.sold-bar{background:#28a745}.bar-part.unsold-bar{background:#ff6b6b}.bar-part.booked-bar{background:#90ee90}.bar-label-bottom{color:#495057;font-size:13px;font-weight:500;text-align:center}.line-chart{align-items:flex-end;display:flex;gap:16px;height:240px;justify-content:space-around;padding:20px 0}.line-bar{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:12px;height:100%}.line-bar-fill{align-items:flex-start;background:linear-gradient(0deg,#007bff,#0056b3);border-radius:6px 6px 0 0;cursor:pointer;display:flex;justify-content:center;max-width:60px;padding-top:8px;position:relative;transition:all .2s;width:100%}.line-bar-fill:hover{filter:brightness(.9);transform:scaleY(1.05)}.line-value{color:#fff;font-size:14px;font-weight:600}.line-label{color:#495057;font-size:13px;font-weight:500}.price-chart{display:flex;flex-direction:column;gap:24px;padding:20px 0}.price-row{align-items:center;display:flex;gap:16px}.price-type{color:#495057;font-size:14px;font-weight:500;min-width:80px}.price-bar-container{display:flex;flex:1 1;flex-direction:column;gap:8px;position:relative}.price-bar{background:linear-gradient(90deg,#28a745,#ffc107);border-radius:6px;cursor:pointer;height:32px;position:relative;transition:all .2s}.price-bar:hover{filter:brightness(.9);transform:scaleY(1.1)}.price-avg-marker{background:#dc3545;border-radius:2px;bottom:-4px;position:absolute;top:-4px;width:3px}.price-labels{color:#6c757d;display:flex;font-size:11px;justify-content:space-between}.price-label-avg{color:#dc3545;font-weight:600}.price-count{color:#6c757d;font-size:13px;min-width:80px;text-align:right}.chart-legend{border-top:1px solid #e9ecef;display:flex;gap:16px;justify-content:center;margin-top:16px;padding-top:16px}.legend-item{align-items:center;color:#495057;display:flex;font-size:13px;gap:6px}.legend-color{border-radius:4px;height:16px;width:16px}.legend-color.sold{background:#28a745}.legend-color.unsold{background:#ff6b6b}.legend-color.booked{background:#90ee90}.legend-color.hold{background:#dc3545}.legend-color.pending{background:#6c757d}.legend-color.sold-bar{background:#28a745}.legend-color.unsold-bar{background:#ff6b6b}.legend-color.booked-bar{background:#90ee90}.modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:1200px;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:24px}.modal-header h2{color:#2c3e50;font-size:20px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:6px;color:#6c757d;cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.modal-close:hover{background:#f8f9fa;color:#2c3e50}.modal-body{flex:1 1;overflow-y:auto;padding:24px}.modal-footer{border-top:1px solid #e9ecef;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.data-table{border-collapse:collapse;font-size:14px;width:100%}.data-table thead{background:#f8f9fa}.data-table th{border-bottom:2px solid #dee2e6;color:#495057;font-weight:600;padding:12px;text-align:left;white-space:nowrap}.data-table td{border-bottom:1px solid #e9ecef;color:#2c3e50;padding:12px}.data-table tbody tr:hover{background:#f8f9fa}.status-badge{border-radius:12px;font-size:12px;font-weight:500;padding:4px 12px;text-transform:capitalize}.status-badge.status-sold{background:#d4edda;color:#155724}.status-badge.status-unsold{background:#fff3cd;color:#856404}.status-badge.status-hold{background:#d1ecf1;color:#0c5460}.status-badge.status-approval_pending{background:#e2e3e5;color:#383d41}.pie-chart-container{display:flex;flex-direction:column;gap:12px;padding:20px 0}.pie-segment{align-items:center;background:#f8f9fa;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .2s}.pie-segment:hover{background:#e9ecef;transform:translateX(4px)}.pie-color{border-radius:6px;flex-shrink:0;height:24px;width:24px}.pie-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.pie-label{color:#2c3e50;font-size:14px;font-weight:600}.pie-value{color:#28a745;font-size:16px;font-weight:700}.pie-count{color:#6c757d;font-size:12px}.bar-segment.income-bar{background:linear-gradient(90deg,#28a745,#20c997);position:relative}.bar-value{color:#fff;font-size:13px;font-weight:600;padding:0 8px;white-space:nowrap}.amount-cell{color:#28a745;font-weight:600;text-align:right}.badge{background:#e9ecef;border-radius:4px;color:#495057;display:inline-block;font-size:11px;font-weight:600;padding:4px 8px}@media (max-width:768px){.income-report-container{padding:16px}.report-filters{flex-direction:column}.filter-group{min-width:100%}.charts-grid,.kpi-cards{grid-template-columns:1fr}.chart-card-wide{grid-column:span 1}.bar-label{font-size:12px;min-width:100px}.modal-content{margin:0;max-width:100%}}.follow-up-report-container{margin:0 auto;max-width:100%;padding:20px}.report-header{margin-bottom:30px;text-align:center}.report-header h1{color:#2c3e50;font-size:2rem;margin-bottom:10px}.report-subtitle{color:#7f8c8d;font-size:1rem}.filter-bar{align-items:flex-end;background:#f8f9fa;border-radius:8px;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:20px;padding:20px}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{color:#495057;font-size:.9rem;font-weight:600}.filter-group input,.filter-group select{border:1px solid #ced4da;border-radius:4px;font-size:.95rem;min-width:150px;padding:8px 12px}.filter-actions{display:flex;gap:10px;margin-left:auto}.btn-advanced,.btn-apply,.btn-clear{border:none;border-radius:4px;cursor:pointer;font-size:.95rem;font-weight:500;padding:8px 16px;transition:all .2s}.btn-apply{background-color:#007bff;color:#fff}.btn-apply:hover{background-color:#0056b3;box-shadow:0 2px 4px #007bff4d;transform:translateY(-1px)}.btn-clear{background-color:#6c757d;color:#fff}.btn-clear:hover{background-color:#5a6268;box-shadow:0 2px 4px #6c757d4d;transform:translateY(-1px)}.btn-advanced{background-color:#007bff;color:#fff}.btn-advanced:hover{background-color:#0056b3;box-shadow:0 2px 4px #007bff4d;transform:translateY(-1px)}.filter-builder{background:#fff;border:2px solid #007bff;border-radius:8px;margin-bottom:20px;padding:20px}.filter-builder-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.filter-builder-header h3{color:#007bff;font-size:1.3rem;margin:0}.logic-toggle{align-items:center;display:flex;gap:10px}.logic-toggle label{font-size:.95rem;font-weight:600}.logic-toggle select{border:1px solid #ced4da;border-radius:4px;font-size:.9rem;padding:6px 12px}.conditions-list{display:flex;flex-direction:column;gap:15px;margin-bottom:15px}.condition-row{align-items:center;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;display:flex;gap:10px;padding:12px}.condition-number{color:#6c757d;font-weight:700;min-width:25px}.condition-row input,.condition-row select{border:1px solid #ced4da;border-radius:4px;font-size:.9rem;padding:6px 10px}.condition-row select:first-of-type{min-width:180px}.condition-row select:nth-of-type(2){min-width:100px}.condition-row input{min-width:120px}.between-inputs{align-items:center;display:flex;gap:8px}.between-inputs input{min-width:100px}.between-inputs span{color:#6c757d;font-weight:600}.btn-remove{align-items:center;background-color:#dc3545;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:700;height:32px;justify-content:center;line-height:1;margin-left:auto;min-width:32px;transition:all .2s;width:32px}.btn-remove:hover{background-color:#c82333;box-shadow:0 2px 6px #dc354566;transform:scale(1.1)}.btn-add-condition{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:10px 20px;transition:all .2s}.btn-add-condition:hover{background-color:#0056b3;box-shadow:0 2px 4px #007bff4d;transform:translateY(-1px)}.report-actions{display:flex;gap:15px;justify-content:flex-end;margin-bottom:20px}.btn-export,.btn-print{border:none;border-radius:4px;cursor:pointer;font-size:.95rem;font-weight:500;padding:10px 20px;transition:all .2s}.btn-export{background-color:#28a745;color:#fff}.btn-export:hover{background-color:#218838;box-shadow:0 2px 4px #28a7454d;transform:translateY(-1px)}.btn-print{background-color:#6c757d;color:#fff}.btn-print:hover{background-color:#5a6268;box-shadow:0 2px 4px #6c757d4d;transform:translateY(-1px)}.kpi-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:30px}.kpi-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;box-shadow:0 4px 6px #0000001a;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:120px;overflow:hidden;padding:20px}.kpi-card-warning{background:linear-gradient(135deg,#f093fb,#f5576c)}.kpi-label{font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-bottom:10px;opacity:.9;text-transform:uppercase}.kpi-value{font-size:1.5rem;font-weight:700;line-height:1.2;word-break:break-word}.kpi-note{font-size:.7rem;line-height:1.3;margin-top:8px;opacity:.85}.table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.follow-up-table{border-collapse:collapse;font-size:.9rem;width:100%}.follow-up-table thead{background-color:#2c3e50;color:#fff}.follow-up-table th{font-weight:600;padding:12px 10px;position:-webkit-sticky;position:sticky;text-align:left;top:0;white-space:nowrap;z-index:10}.follow-up-table td{border-bottom:1px solid #dee2e6;padding:10px;white-space:nowrap}.follow-up-table tbody tr:hover{background-color:#f1f3f5}.high-risk-row{background-color:#ffe5e5!important}.high-risk-row:hover{background-color:#ffc9c9!important}.pending-percent{color:#dc3545;font-weight:700}.no-data{color:#6c757d;font-style:italic;padding:40px!important;text-align:center}.totals-row{background-color:#e9ecef!important;border-top:3px solid #495057!important;font-weight:700}.totals-row td{font-size:.95rem;padding:14px 10px!important}.totals-row:hover{background-color:#e9ecef!important}.error,.loading{font-size:1.1rem;padding:40px;text-align:center}.loading{color:#007bff}.error{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#dc3545}@media print{.btn-advanced,.btn-apply,.btn-clear,.btn-export,.btn-print,.filter-bar,.filter-builder,.report-actions{display:none!important}.follow-up-report-container{padding:0}.report-header h1{font-size:1.5rem}.kpi-cards{gap:10px;grid-template-columns:repeat(5,1fr)}.kpi-card{padding:10px;page-break-inside:avoid}.kpi-value{font-size:1.3rem}.follow-up-table{font-size:.75rem}.follow-up-table td,.follow-up-table th{padding:6px 4px}}@media (max-width:768px){.filter-bar{flex-direction:column}.filter-actions{margin-left:0;width:100%}.filter-actions button{flex:1 1}.kpi-cards{grid-template-columns:1fr}.condition-row{flex-wrap:wrap}.condition-row input,.condition-row select{min-width:100%}}.afr-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;margin:0 auto;max-width:100%;padding:20px 24px}.afr-header{align-items:flex-start;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.afr-header h1{color:#1a202c;font-size:1.75rem;font-weight:700;margin:0 0 4px}.afr-subtitle{color:#718096;font-size:.9rem;margin:0}.afr-header-actions{display:flex;gap:8px}.afr-btn{border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 16px;transition:all .15s ease;white-space:nowrap}.afr-btn:hover{box-shadow:0 2px 8px #0000001f;transform:translateY(-1px)}.afr-btn:active{transform:translateY(0)}.afr-btn-primary{background:#3182ce;color:#fff}.afr-btn-primary:hover{background:#2b6cb0}.afr-btn-primary:disabled{background:#a0aec0;box-shadow:none;cursor:not-allowed;transform:none}.afr-btn-secondary{background:#e2e8f0;color:#4a5568}.afr-btn-secondary:hover{background:#cbd5e0}.afr-btn-advanced{background:#805ad5;color:#fff}.afr-btn-advanced:hover{background:#6b46c1}.afr-btn-export{background:#38a169;color:#fff}.afr-btn-export:hover{background:#2f855a}.afr-btn-print{background:#4a5568;color:#fff}.afr-btn-print:hover{background:#2d3748}.afr-btn-save{background:#d69e2e;color:#fff}.afr-btn-save:hover{background:#b7791f}.afr-btn-columns{background:#319795;color:#fff}.afr-btn-columns:hover{background:#2c7a7b}.afr-btn-add{background:#edf2f7;border:1px dashed #a0aec0;color:#4a5568;margin-top:8px}.afr-btn-add:hover{background:#e2e8f0;border-color:#718096}.afr-btn-sm{background:#edf2f7;color:#4a5568;font-size:.8rem;padding:4px 12px}.afr-btn-sm:hover{background:#e2e8f0}.afr-btn-remove{background:#fed7d7;border:none;border-radius:4px;color:#c53030;cursor:pointer;font-size:.85rem;font-weight:600;padding:4px 10px}.afr-btn-remove:hover{background:#feb2b2}.afr-preset-bar{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;flex-wrap:wrap;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.afr-preset-bar,.afr-preset-left{align-items:center;display:flex;gap:10px}.afr-preset-left label{color:#4a5568;font-size:.875rem;font-weight:600}.afr-preset-delete-select,.afr-preset-select{background:#fff;border:1px solid #cbd5e0;border-radius:6px;font-size:.85rem;min-width:200px;padding:6px 10px}.afr-preset-delete-select{color:#c53030;min-width:160px}.afr-preset-right{display:flex;gap:8px}.afr-column-manager{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:16px;padding:16px}.afr-column-manager-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.afr-column-manager-header h3{color:#2d3748;font-size:1rem;margin:0}.afr-column-list{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.afr-column-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;font-size:.85rem;justify-content:space-between;padding:6px 10px}.afr-column-toggle{align-items:center;cursor:pointer;display:flex;gap:8px}.afr-column-toggle input[type=checkbox]{accent-color:#3182ce;cursor:pointer;height:16px;width:16px}.afr-column-arrows{display:flex;gap:2px}.afr-arrow-btn{background:#edf2f7;border:1px solid #e2e8f0;border-radius:3px;color:#718096;cursor:pointer;font-size:.65rem;line-height:1;padding:2px 6px}.afr-arrow-btn:hover{background:#e2e8f0;color:#2d3748}.afr-filter-bar{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:16px;padding:16px}.afr-filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:10px}.afr-filter-group{display:flex;flex-direction:column;gap:4px}.afr-filter-group label{color:#4a5568;font-size:.8rem;font-weight:600}.afr-filter-group input,.afr-filter-group select{background:#fff;border:1px solid #cbd5e0;border-radius:6px;font-size:.875rem;min-width:140px;padding:7px 10px}.afr-filter-separator{align-self:flex-end;background:#cbd5e0;height:40px;margin:0 4px;width:1px}.afr-quick-dates{align-items:center;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.afr-quick-label{color:#718096;font-size:.8rem;font-weight:600}.afr-quick-btn{background:#fff;border:1px solid #cbd5e0;border-radius:20px;color:#4a5568;cursor:pointer;font-size:.78rem;padding:4px 10px;transition:all .15s}.afr-quick-btn:hover{background:#3182ce;border-color:#3182ce;color:#fff}.afr-filter-actions{display:flex;flex-wrap:wrap;gap:8px}.afr-filter-builder{background:#fefcfb;border:1px solid #e2e8f0;border-left:4px solid #805ad5;border-radius:8px;margin-bottom:16px;padding:16px}.afr-fb-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.afr-fb-header h3{color:#553c9a;font-size:1rem;margin:0}.afr-fb-logic{align-items:center;display:flex;gap:8px}.afr-fb-logic label{color:#4a5568;font-size:.85rem;font-weight:600}.afr-fb-logic select{border:1px solid #cbd5e0;border-radius:6px;font-size:.85rem;padding:6px 10px}.afr-conditions{display:flex;flex-direction:column;gap:8px}.afr-condition-row{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-wrap:wrap;gap:8px;padding:8px 10px}.afr-cond-num{color:#805ad5;font-weight:700;min-width:20px}.afr-cond-field{min-width:180px}.afr-cond-field,.afr-cond-op{border:1px solid #cbd5e0;border-radius:6px;font-size:.85rem;padding:6px 8px}.afr-cond-op{min-width:90px}.afr-cond-value{border:1px solid #cbd5e0;border-radius:6px;font-size:.85rem;min-width:120px;padding:6px 8px}.afr-between{align-items:center;display:flex;gap:6px}.afr-between input{border:1px solid #cbd5e0;border-radius:6px;font-size:.85rem;padding:6px 8px;width:80px}.afr-between span{color:#718096;font-size:.85rem}.afr-kpis{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));margin-bottom:20px}.afr-kpi-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;border-top:3px solid #a0aec0;padding:16px;text-align:center;transition:all .2s}.afr-kpi-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.afr-kpi-value{color:#2d3748;font-size:1.35rem;font-weight:700;margin-bottom:4px;word-break:break-word}.afr-kpi-label{color:#718096;font-size:.78rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.afr-kpi-success{border-top-color:#38a169}.afr-kpi-success .afr-kpi-value{color:#276749}.afr-kpi-warning{border-top-color:#d69e2e}.afr-kpi-warning .afr-kpi-value{color:#975a16}.afr-kpi-info{border-top-color:#3182ce}.afr-kpi-info .afr-kpi-value{color:#2b6cb0}.afr-kpi-danger{border-top-color:#e53e3e}.afr-kpi-danger .afr-kpi-value{color:#c53030}.afr-kpi-period{border-top-color:#805ad5}.afr-kpi-period .afr-kpi-value{color:#6b46c1}.afr-loading{align-items:center;color:#718096;display:flex;font-size:1rem;gap:12px;justify-content:center;padding:40px}.afr-spinner{animation:afr-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#3182ce;height:24px;width:24px}@keyframes afr-spin{to{transform:rotate(1turn)}}.afr-error{background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;color:#c53030;font-size:.9rem;margin-bottom:16px;padding:12px 16px}.afr-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}.afr-table-info{background:#f7fafc;border-bottom:1px solid #e2e8f0;color:#4a5568;font-size:.85rem;padding:10px 16px}.afr-col-count{color:#718096}.afr-table-scroll{overflow-x:auto}.afr-table{border-collapse:collapse;font-size:.85rem;width:100%}.afr-table thead{position:-webkit-sticky;position:sticky;top:0;z-index:10}.afr-th{background:#2d3748;border-right:1px solid #4a5568;color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;padding:10px 12px;text-align:left;transition:background .15s;-webkit-user-select:none;user-select:none;white-space:nowrap}.afr-th:last-child{border-right:none}.afr-th:hover{background:#4a5568}.afr-th-right{text-align:right}.afr-th-sorted{background:#553c9a}.afr-sort-icon{font-size:.7rem}.afr-table tbody tr{transition:background .1s}.afr-table tbody tr:hover{background:#ebf8ff!important}.afr-table tbody tr:nth-child(2n){background:#f7fafc}.afr-table td{border-bottom:1px solid #edf2f7;color:#2d3748;padding:8px 12px;white-space:nowrap}.afr-td-right{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;text-align:right}.afr-td-danger{color:#c53030!important;font-weight:600}.afr-td-success{color:#276749!important;font-weight:600}.afr-td-highlight{color:#6b46c1!important;font-weight:600}.afr-no-data{color:#a0aec0;font-size:1rem;padding:40px!important;text-align:center}.afr-row-high-risk{background-color:#fff5f5!important;border-left:3px solid #e53e3e}.afr-row-high-risk:hover{background-color:#fed7d7!important}.afr-row-medium-risk{background-color:#fffaf0!important;border-left:3px solid #d69e2e}.afr-row-medium-risk:hover{background-color:#fefcbf!important}.afr-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.afr-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;max-width:90vw;width:480px}.afr-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:16px 20px}.afr-modal-header h3{color:#2d3748;font-size:1.1rem;margin:0}.afr-modal-close{background:none;border:none;color:#a0aec0;cursor:pointer;font-size:1.2rem;padding:4px 8px}.afr-modal-close:hover{color:#e53e3e}.afr-modal-body{padding:20px}.afr-modal-body p{color:#718096;font-size:.9rem;margin:0 0 16px}.afr-modal-input-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.afr-modal-input-group label{color:#4a5568;font-size:.85rem;font-weight:600}.afr-modal-input-group input{border:1px solid #cbd5e0;border-radius:6px;font-size:.9rem;padding:10px 12px}.afr-modal-input-group input:focus{border-color:#3182ce;box-shadow:0 0 0 3px #3182ce26;outline:none}.afr-modal-summary{background:#f7fafc;border-radius:6px;font-size:.85rem;padding:12px 16px}.afr-modal-summary strong{color:#2d3748}.afr-modal-summary ul{color:#718096;margin:6px 0 0;padding-left:20px}.afr-modal-summary li{margin-bottom:2px}.afr-modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:8px;justify-content:flex-end;padding:16px 20px}@media print{.afr-btn,.afr-column-manager,.afr-filter-actions,.afr-filter-bar,.afr-filter-builder,.afr-header-actions,.afr-preset-bar,.afr-quick-dates{display:none!important}.afr-container{padding:0}.afr-header{border-bottom:2px solid #000;margin-bottom:10px}.afr-kpis{gap:8px;grid-template-columns:repeat(5,1fr)}.afr-kpi-card{border:1px solid #ccc;padding:8px}.afr-table{font-size:.7rem}.afr-th{background:#333!important;color:#fff!important;padding:6px 8px;-webkit-print-color-adjust:exact;print-color-adjust:exact}.afr-table td{padding:4px 6px}.afr-row-high-risk{background-color:#ffeaea!important}.afr-row-high-risk,.afr-row-medium-risk{-webkit-print-color-adjust:exact;print-color-adjust:exact}.afr-row-medium-risk{background-color:#fff8e1!important}}@media (max-width:768px){.afr-header{flex-direction:column;gap:12px}.afr-preset-bar{align-items:flex-start}.afr-filter-row,.afr-preset-bar{flex-direction:column}.afr-filter-separator{display:none}.afr-kpis{grid-template-columns:repeat(2,1fr)}.afr-column-list{grid-template-columns:1fr}}
/*# sourceMappingURL=main.e457a806.css.map*/