@charset "UTF-8";*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;color:#334155;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1400px;padding:0 20px}.card{background:#fff;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin-bottom:24px;padding:24px}.btn{font-size:14px;justify-content:center;min-height:44px}.btn-primary{background-color:#3b82f6}.btn-primary:hover{background-color:#2563eb}.btn-secondary{background-color:#6b7280}.btn-secondary:hover{background-color:#4b5563}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover{background-color:#059669}.btn:disabled{cursor:not-allowed;opacity:.5}.loading{align-items:center;display:flex;justify-content:center;padding:40px}.spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:40px;width:40px}@media (max-width:768px){.container{padding:0 16px}.card{margin-bottom:16px;padding:16px}.btn{font-size:13px;padding:10px 16px}}.Toastify__toast{border-radius:8px;font-family:Inter,sans-serif}.Toastify__toast--success{background-color:#10b981}.Toastify__toast--error{background-color:#ef4444}.Toastify__toast--warning{background-color:#f59e0b}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74c3c;--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-toast-width:320px;--toastify-toast-background:#fff;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--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__toast-container{box-sizing:border-box;color:#fff;padding:4px;position:fixed;-webkit-transform:translateZ(9999);-webkit-transform:translateZ(var(--toastify-z-index));width:320px;width:var(--toastify-toast-width);z-index:9999;z-index:var(--toastify-z-index)}.Toastify__toast-container--top-left{left:1em;top:1em}.Toastify__toast-container--top-center{left:50%;top:1em;transform:translateX(-50%)}.Toastify__toast-container--top-right{right:1em;top:1em}.Toastify__toast-container--bottom-left{bottom:1em;left:1em}.Toastify__toast-container--bottom-center{bottom:1em;left:50%;transform:translateX(-50%)}.Toastify__toast-container--bottom-right{bottom:1em;right:1em}@media only screen and (max-width:480px){.Toastify__toast-container{left:0;margin:0;padding:0;width:100vw}.Toastify__toast-container--top-center,.Toastify__toast-container--top-left,.Toastify__toast-container--top-right{top:0;transform:translateX(0)}.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-right{bottom:0;transform:translateX(0)}.Toastify__toast-container--rtl{left:auto;right:0}}.Toastify__toast{border-radius:4px;box-shadow:0 1px 10px 0 #0000001a,0 2px 15px 0 #0000000d;box-sizing:border-box;cursor:default;direction:ltr;display:flex;font-family:sans-serif;font-family:var(--toastify-font-family);justify-content:space-between;margin-bottom:1rem;max-height:800px;max-height:var(--toastify-toast-max-height);min-height:64px;min-height:var(--toastify-toast-min-height);overflow:hidden;padding:8px;position:relative;z-index:0}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{align-items:center;display:flex;flex:1 1 auto;margin:auto 0;padding:6px}.Toastify__toast-body>div:last-child{flex:1 1;word-break:break-word}.Toastify__toast-icon{display:flex;flex-shrink:0;margin-inline-end:10px;width:20px}.Toastify--animate{animation-duration:.7s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}@media only screen and (max-width:480px){.Toastify__toast{border-radius:0;margin-bottom:0}}.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:#e74c3c;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:#e74c3c;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{align-self:flex-start;background:#0000;border:none;color:#fff;cursor:pointer;opacity:.7;outline:none;padding:0;transition:.3s ease}.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:5px;left:0;opacity:.7;position:absolute;transform-origin:left;width:100%;z-index:9999;z-index:var(--toastify-z-index)}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{left:auto;right:0;transform-origin:right}.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,0,0)}to{opacity:0;transform:translate3d(2000px,0,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,0,0)}to{opacity:0;transform:translate3d(-2000px,0,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,-10px,0)}40%,45%{opacity:1;transform:translate3d(0,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,10px,0)}40%,45%{opacity:1;transform:translate3d(0,-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: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:perspective(400px)}30%{opacity:1;transform:perspective(400px) rotateX(-20deg)}to{opacity:0;transform: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:translateZ(0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideOutRight{0%{transform:translateZ(0)}to{transform:translate3d(110%,0,0);visibility:hidden}}@keyframes Toastify__slideOutLeft{0%{transform:translateZ(0)}to{transform:translate3d(-110%,0,0);visibility:hidden}}@keyframes Toastify__slideOutDown{0%{transform:translateZ(0)}to{transform:translate3d(0,500px,0);visibility:hidden}}@keyframes Toastify__slideOutUp{0%{transform:translateZ(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-name:Toastify__slideOutLeft}.Toastify__slide-exit--bottom-right,.Toastify__slide-exit--top-right{animation-name:Toastify__slideOutRight}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown}@keyframes Toastify__spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{margin-left:-4px;position:absolute;width:0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before{border:8px solid #0000;box-sizing:initial;content:"";height:0;left:-8px;position:absolute;width:1px;z-index:-1}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before{border-bottom-color:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{margin-top:-8px;top:0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before{border-bottom-color:#f0f0f0;border-top:none}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after{top:0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before{border-bottom-color:#aeaeae;top:-1px}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{bottom:0;margin-bottom:-8px}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before{border-bottom:none;border-top-color:#fff}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after{bottom:0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before{border-top-color:#aeaeae;bottom:-1px}.react-datepicker-wrapper{border:0;display:inline-block;padding:0}.react-datepicker{background-color:#fff;border:1px solid #aeaeae;border-radius:.3rem;color:#000;display:inline-block;font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;position:relative}.react-datepicker--time-only .react-datepicker__triangle{left:35px}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__triangle{left:50px;position:absolute}.react-datepicker-popper{z-index:1}.react-datepicker-popper[data-placement^=bottom]{padding-top:10px}.react-datepicker-popper[data-placement=bottom-end] .react-datepicker__triangle,.react-datepicker-popper[data-placement=top-end] .react-datepicker__triangle{left:auto;right:50px}.react-datepicker-popper[data-placement^=top]{padding-bottom:10px}.react-datepicker-popper[data-placement^=right]{padding-left:8px}.react-datepicker-popper[data-placement^=right] .react-datepicker__triangle{left:auto;right:42px}.react-datepicker-popper[data-placement^=left]{padding-right:8px}.react-datepicker-popper[data-placement^=left] .react-datepicker__triangle{left:42px;right:auto}.react-datepicker__header{background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative;text-align:center}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__year-dropdown-container--select{display:inline-block;margin:0 15px}.react-datepicker-time__header,.react-datepicker-year-header,.react-datepicker__current-month{color:#000;font-size:.944rem;font-weight:700;margin-top:0}.react-datepicker-time__header{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.react-datepicker__navigation{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:32px;justify-content:center;overflow:hidden;padding:0;position:absolute;text-align:center;text-indent:-999em;top:2px;width:32px;z-index:1}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{display:block;margin-left:auto;margin-right:auto;position:relative;top:0}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover :before{border-color:#a6a6a6}.react-datepicker__navigation-icon{font-size:20px;position:relative;top:-1px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{left:-7px;transform:rotate(45deg)}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{right:-7px;transform:rotate(225deg)}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4rem;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;margin:2px;width:4rem}.react-datepicker__month{margin:.4rem;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;margin:2px;width:4rem}.react-datepicker__input-time-container{clear:both;float:left;margin:5px 0 10px 15px;text-align:left;width:100%}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{display:inline-block;margin-left:5px}.react-datepicker__time-container{border-left:1px solid #aeaeae;float:right;width:85px}.react-datepicker__time-container--with-today-button{border:1px solid #aeaeae;border-radius:.3rem;display:inline;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{background:#fff;border-bottom-right-radius:.3rem;position:relative}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{border-bottom-right-radius:.3rem;margin:0 auto;overflow-x:hidden;text-align:center;width:85px}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{box-sizing:initial;height:calc(195px + .85rem);list-style:none;margin:0;overflow-y:scroll;padding-left:0;padding-right:0;width:100%}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{background-color:#f0f0f0;cursor:pointer}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{background-color:initial;cursor:default}.react-datepicker__week-number{color:#ccc;display:inline-block;line-height:1.7rem;margin:.166rem;text-align:center;width:1.7rem}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected,.react-datepicker__week-number--keyboard-selected):hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__week-number--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__week-number--keyboard-selected{background-color:#2a87d0;border-radius:.3rem;color:#fff}.react-datepicker__week-number--keyboard-selected:hover{background-color:#1d5d90}.react-datepicker__day-names{margin-bottom:-8px;white-space:nowrap}.react-datepicker__week{white-space:nowrap}.react-datepicker__day,.react-datepicker__day-name,.react-datepicker__time-name{color:#000;display:inline-block;line-height:1.7rem;margin:.166rem;text-align:center;width:1.7rem}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:hover,.react-datepicker__month-text:hover,.react-datepicker__quarter-text:hover,.react-datepicker__year-text:hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{background-color:#3dcc4a;border-radius:.3rem;color:#fff}.react-datepicker__day--highlighted:hover,.react-datepicker__month-text--highlighted:hover,.react-datepicker__quarter-text--highlighted:hover,.react-datepicker__year-text--highlighted:hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{background-color:#ff6803;border-radius:.3rem;color:#fff;position:relative}.react-datepicker__day--holidays .holiday-overlay,.react-datepicker__month-text--holidays .holiday-overlay,.react-datepicker__quarter-text--holidays .holiday-overlay,.react-datepicker__year-text--holidays .holiday-overlay{background-color:#333;border-radius:4px;bottom:100%;color:#fff;left:50%;opacity:0;padding:4px;position:absolute;transform:translateX(-50%);transition:visibility 0s,opacity .3s ease-in-out;visibility:hidden;white-space:nowrap}.react-datepicker__day--holidays:hover,.react-datepicker__month-text--holidays:hover,.react-datepicker__quarter-text--holidays:hover,.react-datepicker__year-text--holidays:hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .holiday-overlay,.react-datepicker__month-text--holidays:hover .holiday-overlay,.react-datepicker__quarter-text--holidays:hover .holiday-overlay,.react-datepicker__year-text--holidays:hover .holiday-overlay{opacity:1;visibility:visible}.react-datepicker__day--in-range,.react-datepicker__day--in-selecting-range,.react-datepicker__day--selected,.react-datepicker__month-text--in-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--selected,.react-datepicker__quarter-text--in-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--selected,.react-datepicker__year-text--in-range,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__day--in-range:hover,.react-datepicker__day--in-selecting-range:hover,.react-datepicker__day--selected:hover,.react-datepicker__month-text--in-range:hover,.react-datepicker__month-text--in-selecting-range:hover,.react-datepicker__month-text--selected:hover,.react-datepicker__quarter-text--in-range:hover,.react-datepicker__quarter-text--in-selecting-range:hover,.react-datepicker__quarter-text--selected:hover,.react-datepicker__year-text--in-range:hover,.react-datepicker__year-text--in-selecting-range:hover,.react-datepicker__year-text--selected:hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{background-color:#bad9f1;border-radius:.3rem;color:#000}.react-datepicker__day--keyboard-selected:hover,.react-datepicker__month-text--keyboard-selected:hover,.react-datepicker__quarter-text--keyboard-selected:hover,.react-datepicker__year-text--keyboard-selected:hover{background-color:#1d5d90}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{color:#ccc;cursor:default}.react-datepicker__day--disabled:hover,.react-datepicker__month-text--disabled:hover,.react-datepicker__quarter-text--disabled:hover,.react-datepicker__year-text--disabled:hover{background-color:initial}.react-datepicker__input-container{display:inline-block;position:relative;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{box-sizing:initial;padding:.5rem;position:absolute}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__month-read-view,.react-datepicker__month-year-read-view,.react-datepicker__year-read-view{border:1px solid #0000;border-radius:.3rem;position:relative}.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover,.react-datepicker__year-read-view:hover{cursor:pointer}.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__year-read-view--down-arrow{right:-16px;top:0;transform:rotate(135deg)}.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown,.react-datepicker__year-dropdown{background-color:#f0f0f0;border:1px solid #aeaeae;border-radius:.3rem;left:25%;position:absolute;text-align:center;top:30px;width:50%;z-index:1}.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover,.react-datepicker__year-dropdown:hover{cursor:pointer}.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable,.react-datepicker__year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__month-option,.react-datepicker__month-year-option,.react-datepicker__year-option{display:block;line-height:20px;margin-left:auto;margin-right:auto;width:100%}.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type,.react-datepicker__year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type,.react-datepicker__year-option:last-of-type{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem;-webkit-user-select:none;user-select:none}.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover,.react-datepicker__year-option:hover{background-color:#ccc}.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected,.react-datepicker__year-option--selected{left:15px;position:absolute}.react-datepicker__close-icon{background-color:initial;border:0;cursor:pointer;display:table-cell;height:100%;outline:0;padding:0 6px 0 0;position:absolute;right:0;top:0;vertical-align:middle}.react-datepicker__close-icon:after{background-color:#216ba5;border-radius:50%;color:#fff;content:"×";cursor:pointer;display:table-cell;font-size:12px;height:16px;line-height:1;padding:2px;text-align:center;vertical-align:middle;width:16px}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{background-color:#ccc;cursor:default}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;clear:left;cursor:pointer;font-weight:700;padding:5px 0;text-align:center}.react-datepicker__portal{align-items:center;background-color:#000c;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:2147483647}.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__time-name{line-height:3rem;width:3rem}@media (max-height:550px),(max-width:400px){.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__time-name{line-height:2rem;width:2rem}}.react-datepicker__portal .react-datepicker-time__header,.react-datepicker__portal .react-datepicker__current-month{font-size:1.44rem}.react-datepicker__children-container{height:auto;margin:.4rem;padding-left:.2rem;padding-right:.2rem;width:13.8rem}.react-datepicker__aria-live{border:0;clip-path:circle(0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.react-datepicker__calendar-icon{height:1em;vertical-align:-.125em;width:1em}.filter-panel{margin-bottom:32px;transition:all .3s ease}.filter-header{justify-content:space-between;margin-bottom:24px}.filter-header,.filter-title{align-items:center;display:flex}.filter-title{gap:12px}.filter-title h3{color:#1e293b;font-size:20px;font-weight:600;margin:0}.active-filters-count{background-color:#3b82f6;border-radius:12px;color:#fff;font-size:12px;font-weight:500;min-width:20px;padding:4px 8px;text-align:center}.filter-actions{align-items:center;display:flex;gap:12px}.btn-clear{background:none;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.btn-clear:hover{background-color:#fef2f2;border-color:#dc2626;color:#dc2626}.btn-toggle{align-items:center;background:none;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.btn-toggle:hover{background-color:#eff6ff;border-color:#3b82f6;color:#3b82f6}.chevron{transition:transform .3s ease}.chevron.up{transform:rotate(180deg)}.filter-content{overflow:hidden;transition:all .3s ease}.filter-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.filter-group{display:flex;flex-direction:column;min-height:100px}.filter-header-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px;min-height:24px}.filter-label{align-items:center;color:#374151;display:flex;font-size:14px;font-weight:600;gap:8px}.filter-label .required{color:#dc2626;font-size:14px;font-weight:600}.options-count{color:#6b7280;font-size:.75rem;font-weight:400}.select-wrapper{display:flex;flex-direction:column;gap:4px}.filter-group:hover .options-count{background-color:#e5e7eb;color:#374151}.select-container .select__control--is-disabled{background-color:#f9fafb!important;border-color:#e5e7eb!important;opacity:.6}.select-container .select__placeholder--is-disabled,.select-container .select__single-value--is-disabled{color:#9ca3af!important}.select-container{font-size:14px}.select-container,.select-container .select__indicators{overflow:visible!important}.select-container .select__indicator-separator{margin-right:4px}.select-container .select__indicator{padding:0 4px!important}.date-input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;min-height:44px;overflow:visible;padding:12px 16px;transition:border-color .2s ease;width:100%}.date-input:focus{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6;outline:none}.react-datepicker-wrapper,.react-datepicker__input-container{overflow:visible!important}.react-datepicker__close-icon{margin-right:8px!important;padding:4px!important}.filter-panel.collapsed .filter-content{margin-bottom:-24px;max-height:0;opacity:0}.filter-panel.expanded .filter-content{max-height:500px;opacity:1}@media (max-width:768px){.filter-grid{gap:16px;grid-template-columns:1fr}.filter-header{align-items:stretch;flex-direction:column;gap:16px}.filter-actions,.filter-title{justify-content:center}.filter-group{min-height:80px}.filter-header-row{flex-wrap:wrap;gap:4px}}.filter-help{margin-bottom:24px}.help-message{align-items:flex-start;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:12px;box-shadow:0 2px 4px #3b82f60d;display:flex;gap:12px;padding:16px}.help-icon{flex-shrink:0;font-size:20px;margin-top:2px}.help-text{color:#0c4a6e;font-size:14px;line-height:1.5}.help-text strong{color:#0369a1;display:block;margin-bottom:4px}.help-text p{margin:0;opacity:.9}.filter-info-message{align-items:flex-start;background-color:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;color:#0369a1;display:flex;font-size:13px;gap:8px;margin-top:8px;padding:8px 12px}.info-icon{flex-shrink:0;font-size:14px;margin-top:1px}.info-text{line-height:1.4}.charts-container{margin:32px 0}.tab-navigation{background:#fff;border-radius:12px 12px 0 0;box-shadow:0 2px 8px #0000001a;display:flex;margin-bottom:0;overflow:hidden}.tab-button{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;display:flex;flex:1 1;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:20px 24px;position:relative;transition:all .3s ease}.tab-button:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#374151}.tab-button.active{color:#fff}.tab-button.active:after{bottom:-3px;content:"";height:3px;left:0;position:absolute;right:0}.tab-icon{font-size:18px}.tab-content{background:#fff;border-radius:0 0 12px 12px;box-shadow:0 4px 16px #0000001a;margin-bottom:32px;padding:32px}.coming-soon{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px dashed #bae6fd;border-radius:16px;padding:80px 40px;text-align:center}.coming-soon h3{color:#0369a1;font-size:28px;font-weight:700;margin-bottom:16px}.coming-soon p{color:#0c4a6e;font-size:18px;margin-bottom:32px;opacity:.8}.features-preview{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:800px}.feature-item{background:#fff;border:1px solid #e0f2fe;border-radius:12px;box-shadow:0 2px 8px #3b82f61a;color:#0369a1;font-size:14px;font-weight:600;padding:16px 20px;transition:all .3s ease}.feature-item:hover{border-color:#3b82f6;box-shadow:0 4px 16px #3b82f633;transform:translateY(-2px)}.performance-table{padding:24px}.performance-table h3{color:#1e293b;font-size:20px;font-weight:600;margin-bottom:20px;text-align:center}.table-container{overflow-x:auto}.performance-table-content{border-collapse:collapse;font-size:14px;width:100%}.performance-table-content th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:2px solid #e5e7eb;color:#374151;font-size:13px;font-weight:600;letter-spacing:.05em;padding:12px 8px;text-align:left;text-transform:uppercase}.performance-table-content th:nth-child(3){min-width:150px}.performance-table-content td{border-bottom:1px solid #f3f4f6;padding:12px 8px;transition:background-color .2s ease}.performance-table-content tr:hover td{background-color:#f9fafb}.broker-name{color:#1e293b;font-weight:600;gap:8px;position:relative}.broker-name,.rank-badge{align-items:center;display:flex}.rank-badge{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;color:#fff;flex-shrink:0;font-size:10px;font-weight:700;height:20px;justify-content:center;min-width:20px;padding:4px 6px}.top-1 .rank-badge{background:linear-gradient(135deg,gold,#ffb700);color:#92400e}.top-2 .rank-badge{background:linear-gradient(135deg,silver,#a0a0a0);color:#374151}.top-3 .rank-badge{background:linear-gradient(135deg,#cd7f32,#b8661e);color:#fff}.revenue{color:#059669;font-weight:600}.volume{align-items:center;color:#3b82f6;display:flex;font-weight:500;gap:4px}.volume-breakdown{display:flex;flex-direction:column;gap:4px;min-width:120px}.volume-item{align-items:center;display:flex;gap:6px;padding:2px 0}.volume-item.main-volume{color:#1e40af;font-weight:600}.volume-item.secondary-volume{color:#6b7280;font-size:13px;font-weight:500}.volume-value{font-weight:600}.volume-unit{color:#64748b;font-size:12px;font-weight:500}.deals{color:#7c3aed;font-weight:500}.multiple-units-indicator{color:#f59e0b;cursor:help;font-size:12px;margin-left:4px;opacity:.8;transition:opacity .2s ease}.multiple-units-indicator:hover{opacity:1}.charts-grid{grid-auto-rows:minmax(400px,auto);grid-template-columns:1fr 1fr}.chart-card{display:flex;flex-direction:column;position:relative}.chart-half{grid-column:span 1}.chart-container{max-width:100%;overflow-x:hidden}.chart-container canvas{height:auto;max-width:100%!important;width:100%!important}.chart-container:hover{background-color:#fafafa;transition:background-color .2s ease}.chart-info{background:linear-gradient(135deg,#e0f2fe,#f0f9ff);border-radius:0 0 12px 12px;border-top:1px solid #e2e8f0;margin:0 -24px -24px;padding:12px;text-align:center}.chart-info p{align-items:center;color:#0369a1;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;margin:0}.chart-info p:before{content:"👆";font-size:16px}.chart-controls{background-color:#f8fafc;border-bottom:1px solid #e2e8f0;gap:12px;margin:-24px -24px 16px;padding:16px 24px}.control-label{margin:0}.control-select{border-radius:8px;min-width:120px;padding:10px 14px}.no-data{color:#64748b;padding:80px 40px;text-align:center}.no-data h3{color:#374151;font-size:24px;margin-bottom:12px}.no-data p{font-size:16px;margin:0}.stats-card{padding:32px 24px}.stats-card h3{color:#1e293b;font-size:20px;font-weight:600;margin-bottom:24px;text-align:center}.stats-grid{grid-gap:16px;gap:16px;grid-template-columns:1fr 1fr}.stat-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;padding:20px 16px;position:relative;text-align:center;transition:all .15s ease}.stat-item:hover{background:#fafafa;border-color:#d1d5db;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.stat-item:before{background:linear-gradient(90deg,#3b82f6,#1d4ed8);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .15s ease}.stat-item:hover:before{opacity:1}.stat-value{color:#1d4ed8;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:26px;font-weight:700;line-height:1.1;margin-bottom:8px}.stat-label{color:#6b7280;font-size:13px;font-weight:500;letter-spacing:.025em;line-height:1.3;text-transform:none}@media (max-width:1200px){.charts-grid{gap:20px;grid-template-columns:1fr}.chart-half{grid-column:span 1}}@media (max-width:768px){.charts-container{margin:20px 0}.charts-grid{gap:16px;grid-auto-rows:minmax(300px,auto)}.chart-container{min-height:280px;padding:12px}.stats-grid{gap:12px;grid-template-columns:1fr}.stat-item{padding:16px 12px}.stat-value{font-size:22px}.stat-label{font-size:12px}.chart-info{padding:8px}.chart-info p{font-size:13px}.chart-controls{align-items:stretch;flex-direction:column;gap:8px;padding:12px 16px}.control-label{font-size:13px;text-align:center}.control-select{text-align:center;width:100%}.tab-navigation{flex-direction:column}.tab-button{border-bottom:none;border-right:3px solid #0000;font-size:14px;padding:16px 20px}.tab-button.active{border-bottom:none;border-right-color:#1e40af}.tab-button.active:after{background:linear-gradient(180deg,#60a5fa,#3b82f6,#1d4ed8);bottom:0;height:100%;left:auto;right:-3px;width:3px}.tab-content{padding:20px 16px}.coming-soon{padding:40px 20px}.coming-soon h3{font-size:24px}.coming-soon p{font-size:16px}.features-preview{gap:12px;grid-template-columns:1fr}}.global-controls{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:16px;padding:12px 16px;width:100%}.control-group{gap:12px}.control-label{font-size:14px;font-weight:500}.control-select{font-size:14px}.top-controls{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000000d;gap:20px;justify-content:space-between;margin-bottom:20px;padding:20px}.global-controls,.top-controls{align-items:center;display:flex}.global-controls{background:#0000;border:none;box-shadow:none;height:fit-content;margin:0;padding:0;width:auto}.quick-stats{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px;width:100%}.quick-stats .stat-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;display:flex;flex:0 0 auto;flex-direction:column;min-height:100px;min-width:200px;padding:12px;transition:all .2s ease}.quick-stats .stat-item:hover{background:#f1f5f9;border-color:#cbd5e1;box-shadow:0 4px 6px #0000000d;transform:translateY(-1px)}.quick-stats .stat-header{align-items:center;border-bottom:1px solid #0000001a;display:flex;justify-content:space-between;margin-bottom:8px;padding-bottom:6px}.quick-stats .stat-unit{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.quick-stats .stat-selected-indicator{align-items:center;border-radius:50%;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;width:16px}.quick-stats .stat-content{display:flex;flex:1 1;flex-direction:column;gap:8px}.quick-stats .stat-row{align-items:center;display:flex;justify-content:space-between;padding:4px 0}.quick-stats .stat-row .stat-label{color:#6b7280;font-size:11px;font-weight:500;margin-right:8px}.quick-stats .stat-row .stat-value{color:#1f2937;font-size:14px;font-weight:700;text-align:right}.quick-stats .stat-item.selected{color:#fff}.quick-stats .stat-item.selected .stat-unit{color:#ffffffe6}.quick-stats .stat-item.selected .stat-row .stat-label{color:#fffc}.quick-stats .stat-item.selected .stat-row .stat-value{color:#fff}@media (max-width:768px){.quick-stats{gap:8px}.quick-stats .stat-item{min-height:90px;min-width:180px;padding:10px}.quick-stats .stat-row .stat-value{font-size:12px}.quick-stats .stat-row .stat-label{font-size:10px}.quick-stats .stat-unit{font-size:11px}}.filter-info-card{margin-bottom:16px;padding:12px}.filter-info-header h3{font-weight:500}.filter-info-content{gap:8px}.filter-item{padding:6px 10px}.filter-badge{align-items:center;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;color:#92400e;display:inline-flex;font-size:12px;font-weight:600;gap:6px;margin-bottom:12px;padding:4px 12px}.filter-note{align-items:center;color:#6b7280;display:flex;font-size:14px;font-style:italic;gap:6px;margin-top:8px}.filter-note:before{content:"📊";font-size:16px}@media (max-width:768px){.filter-info-card{margin-bottom:12px;padding:10px}.filter-info-header h3{font-size:13px}.filter-info-content{flex-direction:column;gap:6px}.filter-item{align-items:flex-start;flex-direction:column;gap:3px;padding:5px 8px}.filter-label,.filter-value{font-size:11px}}.data-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:8px;font-size:14px;margin-top:16px;padding:12px}.data-warning p{color:#92400e;font-weight:500;margin:0}.data-warning p:first-child{font-weight:600;margin-bottom:4px}.data-warning p:last-child{font-size:12px;opacity:.8}.error-message{border:2px solid #ef4444;padding:60px 20px}.error-message h3{font-size:24px;margin:0 0 16px}.error-message p{color:#991b1b;margin:0 0 20px}.retry-button{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.retry-button:hover{box-shadow:0 4px 12px #ef44444d;transform:translateY(-1px)}.no-data-message{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #0ea5e9;padding:40px 20px}.no-data-message p{color:#0c4a6e;font-style:italic}.loading-container{text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#3b82f6;height:40px;margin:0 auto 16px;width:40px}.prime-table-container{margin-bottom:24px}.prime-table-container h4{border-bottom:2px solid #e2e8f0;color:#1e293b;font-size:20px;font-weight:600;margin:0 0 16px;padding-bottom:12px}.prime-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;width:100%}.prime-table th{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;color:#fff;font-size:14px;font-weight:600;padding:16px 12px;text-align:left}.prime-table td{border-bottom:1px solid #e2e8f0;color:#374151;font-size:14px;padding:14px 12px}.prime-table tr:hover{background-color:#f8fafc}.prime-table tr:last-child td{border-bottom:none}.prime-summary-container{background:#fff;border:1px solid #f3f4f6;border-radius:16px;box-shadow:0 1px 3px #0000001a;padding:28px}.prime-summary-container h4{color:#111827;font-size:16px;font-weight:600;letter-spacing:-.025em;margin:0 0 24px;text-align:center}.summary-grid{grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-item{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;padding:20px 16px;position:relative;text-align:center;transition:all .15s ease}.summary-item:hover{background:#fafafa;border-color:#d1d5db;box-shadow:0 4px 12px #00000014}.summary-item:before{background:linear-gradient(90deg,#10b981,#059669);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .15s ease}.summary-item:hover:before{opacity:1}.courtier-name{color:#6b7280;font-size:13px;font-weight:500;letter-spacing:.025em;line-height:1.4;margin-bottom:8px;text-transform:none}.prime-total{color:#059669;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:22px;font-weight:700;line-height:1.1}@media (max-width:768px){.prime-courtiers-container{padding:16px}.prime-courtiers-header h3{font-size:24px}.prime-courtiers-header p{font-size:14px}.active-filters-info{align-items:center;flex-direction:column}.filter-badge{font-size:12px;padding:4px 12px}.prime-table td,.prime-table th{font-size:12px;padding:10px 8px}.summary-grid{gap:10px;grid-template-columns:1fr}.summary-item{padding:16px 12px}.courtier-name{font-size:12px}.prime-total{font-size:18px}.error-message,.no-data-message,.no-filters-message{padding:40px 16px}.error-message h3,.no-filters-message h3{font-size:20px}.retry-button{font-size:13px;padding:10px 20px}}.courtier-name{color:#1e40af;font-weight:600}.invoice-date{color:#059669;font-family:Courier New,monospace}.document-number{color:#7c3aed;font-weight:500}.execution-number{color:#dc2626;font-family:Courier New,monospace}.price-currency,.prime-amount,.prime-amount-eur{color:#059669;font-family:Courier New,monospace;font-weight:600;text-align:right}.price-currency.negative,.prime-amount-eur.negative,.prime-amount.negative{color:#ef4444}.amount-cell,.price-currency.positive,.prime-amount-eur.positive,.prime-amount.positive{color:#059669}.amount-cell{font-family:Courier New,monospace;font-weight:600;text-align:right}.previsionnel-courtiers-container{padding:24px}.previsionnel-charts{margin-bottom:32px}.previsionnel-charts .row{display:flex;gap:24px;margin-bottom:24px}.previsionnel-charts .col-md-6{flex:1 1}.chart-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.contract-details{border-radius:12px;box-shadow:0 4px 16px #0000001a;margin-top:32px}.contract-details h5{color:#fff;font-weight:600;margin-bottom:20px}.contract-details .table-responsive{border-radius:8px;overflow:hidden}.contract-details table{margin-bottom:0}.contract-details th{background-color:#f8f9fa;border-bottom:2px solid #dee2e6;color:#495057;font-weight:600;padding:12px 16px}.contract-details td{border-bottom:1px solid #dee2e6;padding:12px 16px;vertical-align:middle}.contract-details tbody tr:hover{background-color:#f8f9fa}.contract-details a{color:#007bff;font-weight:500;text-decoration:none}.contract-details a:hover{color:#0056b3;text-decoration:underline}.contract-details .btn{border-radius:6px;font-size:12px;padding:6px 12px}@media (max-width:768px){.previsionnel-charts .row{flex-direction:column;gap:16px}.previsionnel-charts .col-md-6{width:100%}.chart-container,.contract-details{padding:16px}.contract-details td,.contract-details th{font-size:12px;padding:8px 12px}.contract-details .btn{font-size:11px;padding:4px 8px}}.chart-header{margin-bottom:24px;text-align:center}.chart-header h4{color:#1e293b;font-size:20px;font-weight:600;margin:0 0 8px}.chart-header p{color:#64748b;font-size:14px;margin:0}.no-chart-data{background:#f8fafc;border:2px dashed #cbd5e1;border-radius:8px;color:#64748b;padding:60px 20px;text-align:center}.no-chart-data p{font-size:16px;font-weight:500;margin:0}@media (max-width:768px){.chart-header h4{font-size:18px}.chart-header p{font-size:13px}}.oil-prices-container{padding:20px}.oil-summary-container{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:1px solid #e2e8f0;border-radius:12px;margin-bottom:24px;padding:24px}.oil-summary-container h4{color:#1e293b;font-size:20px;font-weight:600;margin-bottom:20px;text-align:center}.filter-indicator{margin-bottom:16px;text-align:center}.filter-badge{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:20px;box-shadow:0 2px 8px #3b82f64d;color:#fff;display:inline-block;font-size:14px;font-weight:500;padding:8px 16px}.coverage-info{margin-top:8px;text-align:center}.coverage-info small{background:#64748b1a;border-radius:12px;color:#64748b;display:inline-block;font-size:12px;padding:4px 8px}.data-coverage-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:8px;box-shadow:0 2px 4px #f59e0b1a;color:#92400e;font-size:13px;margin-top:12px;padding:12px;text-align:center}.error-message{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #ef4444;border-radius:12px;margin:20px 0;padding:24px;text-align:center}.error-message h3{color:#dc2626;font-size:20px;font-weight:600;margin-bottom:16px}.error-message p{color:#7f1d1d;font-size:16px;margin-bottom:12px}.error-details{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#991b1b;font-family:monospace;font-size:14px;margin:16px 0;padding:12px}.error-timestamp{color:#6b7280;font-size:14px;font-style:italic;margin:16px 0}.error-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:20px}.debug-button,.retry-button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .3s ease}.retry-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.retry-button:hover{background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 4px 12px #3b82f64d;transform:translateY(-2px)}.debug-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.debug-button:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b9814d;transform:translateY(-2px)}.summary-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:20px}.summary-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:20px;transition:all .3s ease}.summary-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.oil-type{font-size:18px;font-weight:600}.oil-price,.oil-type{color:#1e293b;margin-bottom:12px;text-align:center}.oil-price{font-size:24px;font-weight:700}.price-change{display:block;font-size:14px;font-weight:500;margin-top:4px}.price-change.positive{color:#10b981}.price-change.negative{color:#ef4444}.oil-details{align-items:center;display:flex;flex-direction:column;gap:4px}.oil-details small{color:#64748b;font-size:12px}.fallback-warning{color:#f59e0b!important;font-weight:500}.last-update{color:#64748b;font-size:14px;font-style:italic;text-align:center}@media (max-width:768px){.summary-grid{grid-template-columns:1fr}.oil-summary-container,.summary-item{padding:16px}.oil-price{font-size:20px}.filter-badge{font-size:12px;padding:6px 12px}}.oil-table-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:20px 0;padding:24px}.export-btn{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .3s ease}.export-btn:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.refresh-btn{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;margin-left:8px;padding:8px 16px;transition:all .3s ease}.refresh-btn:hover{background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.loading-indicator{align-items:center;background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;margin:20px 0;min-height:400px;padding:40px;position:absolute;right:0;top:0;width:100%;z-index:10}.loading-indicator .spinner{animation:spin 1s linear infinite;border:5px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:50px;margin-bottom:20px;width:50px}.loading-indicator span{color:#6c757d;font-size:18px;font-weight:500;text-align:center}.execution-delivery{word-wrap:break-word;line-height:1.4;max-width:300px}.execution-delivery p{color:#374151;font-size:14px;margin:0 0 8px}.execution-delivery br{display:block;margin:4px 0}.execution-delivery:last-child p:last-child{margin-bottom:0}.contract-code-link{transition:all .2s ease}.contract-code-link:hover{transform:translateY(-1px)}.contract-code-link:active{transform:translateY(0)}.prime-charts-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;padding:24px}.chart-controls{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:8px;box-sizing:border-box;flex-wrap:wrap;gap:20px;margin:16px 0 24px;max-width:100%;padding:16px 20px}.chart-controls,.control-group{align-items:center;display:flex}.control-group{flex-shrink:0;gap:8px;min-width:180px}.control-label{color:#374151;flex-shrink:0;font-size:13px;font-weight:600;white-space:nowrap}.control-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:13px;font-weight:500;max-width:200px;min-width:140px;padding:8px 12px;transition:all .2s ease}.control-select:hover{background:#f9fafb;border-color:#9ca3af}.control-select:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.charts-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:2fr 1fr;margin-bottom:24px}.chart-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000000d;margin-bottom:24px;padding:20px;transition:all .3s ease}.chart-card:has(canvas){padding:16px}.chart-card .chartjs-render-monitor{border-radius:8px}.chart-card-graph{align-items:center;display:flex;justify-content:center;min-height:400px;padding:16px!important}.chart-card-graph canvas{height:auto!important;max-width:100%!important}.chart-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.chart-container{height:400px}.chart-container,.chart-container-full{align-items:center;display:flex;justify-content:center;position:relative;width:100%}.chart-container-full{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000000d;height:500px;margin-bottom:24px;min-height:500px;padding:24px;transition:all .3s ease}.chart-container-full:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.quick-stats-container h4{border-bottom:1px solid #e2e8f0;color:#1e293b;font-size:14px;font-weight:600;margin:0 0 10px;padding-bottom:6px;text-align:center}.stats-by-currency{display:flex;flex-direction:row;flex-wrap:wrap;gap:8px;justify-content:center}.currency-stats{background:#f8fafc;border:1px solid #e5e7eb;border-radius:6px;flex:1 1;max-width:180px;min-width:150px;padding:8px}.currency-title{background:#3b82f6;border-radius:4px;box-sizing:border-box;color:#fff;display:block;font-size:12px;font-weight:500;margin:0 0 6px;padding:4px 8px;text-align:center;width:100%}.stats-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:1fr}.stats-grid .stat-item{background:#fff;border:1px solid #e2e8f0;border-radius:4px;overflow:hidden;padding:6px;position:relative;text-align:center;transition:all .2s ease}.stats-grid .stat-item:hover{background:#f8fafc;border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d;transform:translateY(-1px)}.stats-grid .stat-item:before{background:linear-gradient(90deg,#3b82f6,#1d4ed8);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s ease}.stats-grid .stat-item:hover:before{opacity:1}.stats-grid .stat-label{color:#6b7280;font-size:10px;font-weight:500;letter-spacing:.2px;line-height:1.1;margin-bottom:2px;text-transform:uppercase}.stats-grid .stat-value{color:#1d4ed8;font-size:12px;font-weight:600}.stats-grid .stat-amount,.stats-grid .stat-value{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;line-height:1.1}.stats-grid .stat-amount{color:#6b7280;font-size:10px;font-weight:500;margin-top:2px}.filter-info-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:16px;padding:16px}.filter-info-header{align-items:center;display:flex;gap:8px;margin-bottom:12px}.filter-icon{color:#64748b;font-size:16px}.filter-info-header h3{color:#475569;font-size:14px;font-weight:600;margin:0}.filter-info-content{display:flex;flex-wrap:wrap;gap:12px}.filter-item{align-items:center;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:6px;padding:8px 12px}.filter-label{color:#64748b}.filter-label,.filter-value{font-size:12px;font-weight:500}.filter-value{color:#475569}.no-data-message{background:#f8fafc;border:2px dashed #cbd5e1;border-radius:8px;color:#64748b;padding:60px 20px;text-align:center}.no-data-message p{font-size:16px;font-weight:500;margin:0}@media (max-width:1200px){.charts-grid{gap:20px;grid-template-columns:1fr}.chart-card{padding:16px}}@media (max-width:768px){.prime-charts-container{margin-bottom:16px;padding:16px}.chart-controls{align-items:stretch;flex-direction:column;gap:12px;margin:12px 0 20px;padding:12px 16px}.control-group{align-items:center;flex-direction:row;gap:12px;justify-content:space-between;min-width:auto}.control-label{font-size:12px;min-width:80px;text-align:left}.control-select{flex:1 1;min-width:120px;text-align:left}.chart-container{height:300px}.chart-container-full{height:300px;padding:16px}.stats-by-currency{flex-direction:column;gap:8px}.currency-stats{max-width:none;min-width:auto}.stats-grid{gap:8px}.stats-grid .stat-item{padding:8px}.stats-grid .stat-value{font-size:14px}.stats-grid .stat-amount{font-size:12px}.filter-info-content{flex-direction:column;gap:8px}.filter-item{align-items:flex-start;flex-direction:column;gap:4px;padding:6px 10px}}.chart-container{animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chartjs-tooltip{background:#000c!important;border:none!important;border-radius:8px!important;box-shadow:0 4px 20px #0000004d!important;padding:12px!important}.chart-container canvas,.chart-container-full canvas{border-radius:8px;box-shadow:0 2px 8px #0000001a}.chart-container-full canvas{height:auto!important;max-width:100%}.prime-charts-container .chart-container-full{padding:30px 24px}.chart-container-full .chartjs-render-monitor{border-radius:8px}@media (min-width:1200px){.chart-container-full{height:550px;padding:30px}.prime-charts-container{padding:30px}}.chart-loading{align-items:center;color:#64748b;display:flex;font-size:16px;font-weight:500;height:400px;justify-content:center}.chart-loading:before{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#3b82f6;content:"";height:40px;margin-right:16px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.table-container{margin:32px 0}.table-header{align-items:flex-start;display:flex;gap:24px;justify-content:space-between;margin-bottom:24px}.table-title{display:flex;flex-direction:column;gap:4px}.table-title h3{color:#1e293b;font-size:20px;font-weight:600;margin:0}.data-count{color:#64748b;font-size:14px;font-weight:500}.table-info{margin-top:4px}.table-info small{color:#6b7280;font-size:12px;font-style:italic}.table-actions{gap:16px}.table-actions,.table-search{align-items:center;display:flex}.table-search{position:relative}.search-input{border:1px solid #d1d5db;border-radius:8px;font-size:14px;padding:12px 16px 12px 44px;transition:border-color .2s ease;width:300px}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6;outline:none}.search-icon{color:#9ca3af;left:14px;pointer-events:none;position:absolute}.export-controls{align-items:center;display:flex;gap:12px}.export-select{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;padding:12px 16px;transition:border-color .2s ease}.export-select:focus{border-color:#3b82f6;outline:none}.table-wrapper{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;overflow-x:auto}.data-table{background-color:#fff;border-collapse:collapse;font-size:14px;width:100%}.data-table th{background-color:#f9fafb;border-bottom:1px solid #e5e7eb;color:#374151;cursor:pointer;font-weight:600;padding:16px 12px;position:sticky;text-align:left;top:0;-webkit-user-select:none;user-select:none;z-index:10}.data-table th:hover{background-color:#f3f4f6}.header-content{gap:8px}.sort-indicator{align-items:center;color:#9ca3af;display:flex;transition:color .2s ease}.data-table th:hover .sort-indicator{color:#6b7280}.sort-default{opacity:.5}.data-table td{border-bottom:1px solid #f3f4f6;padding:12px;vertical-align:middle}.data-table tbody tr:hover{background-color:#f8fafc}.data-table tbody tr:last-child td{border-bottom:none}.contract-id{color:#3b82f6;font-family:Courier New,monospace;font-weight:600}.contract-code{color:#1e293b;font-weight:500}.contract-link{color:#3b82f6;font-weight:500;text-decoration:none;transition:color .2s ease}.contract-link:hover{color:#2563eb;text-decoration:underline}.contract-type{border-radius:4px;font-size:12px;font-weight:500;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.contract-type.marchandise{background-color:#dcfce7;color:#166534}.contract-type.transport{background-color:#dbeafe;color:#1e40af}.contract-type.inconnu{background-color:#f3f4f6;color:#6b7280}.contract-type-icon{align-items:center;border-radius:6px;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.contract-type-icon i{color:#6b7280;transition:color .2s ease}.contract-type-icon i.fa-wheat-awn{color:#059669}.contract-type-icon i.fa-truck{color:#2563eb}.contract-type-icon:hover i{transform:scale(1.1)}.contract-type-unknown{color:#9ca3af;font-size:12px;font-style:italic}.buyer-name,.seller-name{color:#374151;font-weight:500}.broker-name{color:#7c3aed;font-weight:500}.merchandise-name{color:#059669;font-weight:500}.harvest-year{background-color:#fef3c7;border-radius:4px;color:#92400e;font-size:12px;font-weight:500;padding:2px 6px}.quantity{color:#1e293b}.price,.quantity{font-family:Courier New,monospace;font-weight:600;text-align:right}.price{color:#059669}.unit-price{color:#3b82f6;font-weight:600;text-align:right}.delivery-date,.unit-price{font-family:Courier New,monospace}.delivery-date{color:#6b7280}.table-pagination{align-items:center;display:flex;gap:16px;justify-content:space-between}.pagination-info{color:#64748b;font-size:14px}.pagination-controls{align-items:center;display:flex;gap:16px}.page-size-select{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px}.pagination-buttons{align-items:center;display:flex;gap:8px}.btn-page{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;min-width:40px;padding:8px 12px;transition:all .2s ease}.btn-page:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.btn-page:disabled{cursor:not-allowed;opacity:.5}.page-info{color:#374151;font-size:14px;font-weight:500;padding:0 12px}.no-data-table{color:#64748b;padding:60px 40px;text-align:center}.no-data-table p{font-size:16px;margin:0}@media (max-width:1024px){.table-header{gap:16px}.table-actions,.table-header{align-items:stretch;flex-direction:column}.table-actions{gap:12px}.search-input{width:100%}.export-controls{justify-content:space-between}}@media (max-width:768px){.table-container{margin:20px 0}.data-table{font-size:13px}.data-table td,.data-table th{padding:8px 6px}.table-pagination{flex-direction:column;gap:12px}.pagination-buttons,.pagination-controls{justify-content:center}.pagination-buttons{flex-wrap:wrap}.search-input{font-size:16px}}.header{background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 1px 5px 0 #e0e0e0;-webkit-box-shadow:0 1px 5px 0 #e0e0e0;color:#fff;position:sticky;top:0;z-index:1000}.header-content{justify-content:space-between;padding:20px 0}.header-content,.logo{align-items:center;display:flex}.logo{gap:16px;position:relative}.courteo-logo{align-items:center;display:flex;justify-content:center}.courteo-logo-img{border-radius:10px;height:80px;object-fit:contain;width:auto}.nav,.nav-info{align-items:center;display:flex}.nav{gap:20px;position:relative}.nav-text{font-size:14px;font-weight:500;opacity:.9}.nav-actions{gap:12px;margin-left:20px}.btn-shortcuts,.nav-actions{align-items:center;display:flex}.btn-shortcuts{background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:20px;box-shadow:0 2px 8px #22c55e4d;color:#fff;cursor:pointer;font-size:12px;font-weight:600;gap:6px;padding:8px 16px;text-shadow:0 1px 2px #0003;transition:all .2s ease}.btn-shortcuts:hover{background:linear-gradient(135deg,#4ade80,#22c55e);box-shadow:0 4px 12px #22c55e66;transform:translateY(-1px)}.shortcuts-icon{flex-shrink:0;height:14px;width:14px}.user-info{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;gap:20px;margin-left:20px;padding:12px 16px}.user-info,.user-profile{align-items:center;display:flex}.user-profile{gap:12px}.user-avatar{align-items:center;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;box-shadow:0 2px 6px #22c55e4d;display:flex;height:32px;justify-content:center;width:32px}.avatar-text{color:#424242;font-size:14px;font-weight:700;text-shadow:0 1px 2px #0000004d}.user-text{display:flex;flex-direction:column;gap:8px}.user-name{color:#424242;font-size:14px;font-weight:600;text-shadow:0 1px 2px #0000004d}.user-actions{gap:6px}.btn-profile,.user-actions{align-items:center;display:flex}.btn-profile{background:#8b5cf6;border:none;border-radius:8px;box-shadow:0 2px 6px #8b5cf64d;color:#fff;cursor:pointer;justify-content:center;padding:8px;transition:all .2s ease}.btn-profile:hover{background:#a78bfa;box-shadow:0 3px 8px #8b5cf666;transform:translateY(-1px)}.btn-logout{align-items:center;background:#ef4444;border:none;border-radius:8px;box-shadow:0 2px 6px #ef44444d;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.btn-logout:hover{background:#f87171;box-shadow:0 3px 8px #ef444466;transform:translateY(-1px)}.btn-return{align-items:center;background:#3b82f6;border:none;border-radius:8px;box-shadow:0 2px 6px #3b82f64d;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:8px;text-decoration:none;transition:all .2s ease}.btn-return:hover{background:#60a5fa;box-shadow:0 3px 8px #3b82f666;color:#fff;transform:translateY(-1px)}.logout-icon,.profile-icon,.return-icon{height:16px;width:16px}.client-logo{align-items:center;display:flex;justify-content:center;margin-left:16px}.client-logo-img{max-height:40px;max-width:120px;object-fit:contain}.client-logo-placeholder{align-items:center;background:#fffc;border:2px dashed #0003;border-radius:6px;color:#00000080;display:flex;font-size:8px;font-weight:600;height:30px;justify-content:center;text-transform:uppercase;width:80px}@media (max-width:768px){.header-content{flex-direction:column;gap:12px;text-align:center}.logo{flex-direction:column;gap:8px}.courteo-logo-img{height:40px}.user-info{flex-direction:column;gap:12px}.client-logo,.user-info{margin-left:0}.client-logo-img{max-height:35px;max-width:100px}}.loading-container{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;display:flex;justify-content:center;margin:24px 0;padding:60px 20px}.loading-content{text-align:center}.loading-message{color:#64748b;font-size:16px;font-weight:500;margin-top:16px}.auth-error,.auth-required{align-items:center;background:#f8f9fa;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column;justify-content:center;margin:40px auto;max-width:500px;min-height:400px;padding:40px 20px;text-align:center}.auth-error h2,.auth-required h2{color:#dc3545;font-size:24px;font-weight:600;margin-bottom:16px}.auth-required h2{color:#6c757d}.auth-error p,.auth-required p{color:#6c757d;font-size:16px;line-height:1.5;margin-bottom:24px}.btn{border-radius:6px;display:inline-block;font-size:16px;padding:12px 24px;text-align:center}.btn-primary{background:#007bff}.btn-primary:hover{background:#0056b3;box-shadow:0 4px 12px #007bff4d;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.auth-actions{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.auth-actions .btn{min-width:120px}.auth-status{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin:20px 0;padding:30px}.auth-status h3{color:#333;font-size:20px;font-weight:600;margin-bottom:24px;text-align:center}.status-section{background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;margin-bottom:30px;padding:20px}.status-section h4{color:#495057;font-size:16px;font-weight:600;margin-bottom:16px}.status-section p{color:#6c757d;font-size:14px;margin-bottom:8px}.status-details,.test-result,.user-details{background:#fff;border-radius:6px;margin-top:15px;padding:15px}.test-result .error{color:#dc3545;font-weight:500}.cookies-info{background:#fff;border-radius:6px;margin-top:15px;padding:15px}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#545b62;box-shadow:0 4px 12px #6c757d4d;transform:translateY(-1px)}.btn-secondary:disabled{background:#adb5bd;box-shadow:none;cursor:not-allowed;transform:none}@media (max-width:768px){.auth-error,.auth-required{margin:20px;padding:30px 20px}.auth-error h2,.auth-required h2{font-size:20px}.auth-error p,.auth-required p,.btn{font-size:14px}.btn{padding:10px 20px}.auth-status{margin:10px;padding:20px}.status-section{padding:15px}}.profile-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:calc(100vh - 80px);padding:2rem 0}.profile-header{margin-bottom:2rem;position:relative;text-align:center}.profile-actions{left:0;position:absolute;top:0}.profile-title h1{font-size:2.5rem;font-weight:600;margin-bottom:.5rem}.profile-title p{color:#666;font-size:1.1rem;margin:0}.profile-content{margin:0 auto;max-width:800px}.user-info-card{align-items:center;background:#fff;border:1px solid #e1e5e9;border-radius:16px;box-shadow:0 10px 30px #0000001a;display:flex;gap:2rem;margin-bottom:2rem;padding:2rem}.user-avatar-large{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;flex-shrink:0;height:100px;justify-content:center;width:100px}.avatar-text-large{color:#fff;font-size:2.5rem;font-weight:700;text-transform:uppercase}.user-details-summary h2{color:#333;font-size:1.8rem;margin:0 0 .5rem}.user-email{color:#666;font-size:1.1rem;margin:0 0 1rem}.user-meta{display:flex;flex-wrap:wrap;gap:1rem}.meta-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:20px;color:#555;font-size:.9rem;padding:.5rem 1rem}.auth-status-section{background:#fff;border:1px solid #e1e5e9;border-radius:16px;box-shadow:0 10px 30px #0000001a;padding:2rem}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea66;color:#fff}.btn-primary:hover{box-shadow:0 6px 20px #667eea99;transform:translateY(-2px)}@media (max-width:768px){.profile-page{padding:1rem 0}.profile-title h1{font-size:2rem}.user-info-card{flex-direction:column;padding:1.5rem;text-align:center}.user-avatar-large{height:80px;width:80px}.avatar-text-large{font-size:2rem}.user-meta{justify-content:center}}.session-notification{animation:slideIn .4s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 20px 40px #00000026;max-width:420px;overflow:hidden;position:fixed;right:24px;top:24px;z-index:9999}.session-notification.warning{background:linear-gradient(135deg,#fef3c7f2,#fde68af2);border-color:#f59e0b4d;color:#92400e}.session-notification.expired{background:linear-gradient(135deg,#fee2e2f2,#fecacaf2);border-color:#ef44444d;color:#991b1b}.notification-content{align-items:flex-start;display:flex;gap:16px;padding:20px}.notification-icon{flex-shrink:0;height:24px;margin-top:2px;width:24px}.notification-icon svg{height:100%;width:100%}.notification-text{display:flex;flex:1 1;flex-direction:column;gap:4px}.notification-title{font-size:14px;font-weight:700;letter-spacing:-.2px;line-height:1.3}.notification-message{font-size:13px;font-weight:500;line-height:1.4;opacity:.9}.notification-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}.notification-btn{align-items:center;border:none;border-radius:10px;box-shadow:0 2px 8px #0000001a;cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:6px;padding:8px 16px;text-shadow:0 1px 2px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1)}.notification-btn.extend{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.notification-btn.extend:hover{background:linear-gradient(135deg,#60a5fa,#3b82f6);box-shadow:0 4px 16px #3b82f666;transform:translateY(-2px)}.notification-btn.extend:active{transform:translateY(0)}.notification-btn.dismiss{background:#00000014;border-radius:8px;color:inherit;min-width:32px;padding:8px}.notification-btn.dismiss:hover{background:#00000026;transform:scale(1.05)}.notification-btn svg{flex-shrink:0;height:14px;width:14px}@keyframes slideIn{0%{opacity:0;transform:translateX(100%) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.session-notification.warning .notification-icon{animation:pulse 2s infinite}@media (max-width:768px){.session-notification{border-radius:12px;left:16px;max-width:none;right:16px;top:16px}.notification-content{flex-direction:column;gap:12px;padding:16px;text-align:center}.notification-actions{justify-content:center;width:100%}.notification-btn{flex:1 1;justify-content:center}.notification-btn.dismiss{flex:0 0 auto}}@media (max-width:480px){.session-notification{left:12px;right:12px;top:12px}.notification-content{padding:14px}.notification-title{font-size:13px}.notification-message{font-size:12px}}.App{background-color:#f8fafc;min-height:100vh}.data-table-toggle{display:flex;justify-content:center;margin:20px 0}.toggle-button{align-items:center;background:linear-gradient(135deg,#6b7280,#4b5563);border:none;border-radius:12px;box-shadow:0 4px 12px #6b72804d;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;padding:14px 28px;transition:all .3s ease}.toggle-button:hover{box-shadow:0 6px 20px #6b728066;transform:translateY(-2px)}.toggle-button.active{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d}.toggle-button.active:hover{box-shadow:0 6px 20px #10b98166}.main-content{padding:32px 0}.welcome-section{padding:80px 0;text-align:center}.welcome-card{margin:0 auto;max-width:600px;text-align:center}.welcome-card h2{color:#1e293b;font-size:32px;font-weight:600;margin-bottom:16px}.welcome-card p{color:#64748b;font-size:18px;line-height:1.6;margin-bottom:32px}.dashboard-header{align-items:flex-start;display:flex;gap:24px;justify-content:space-between;margin-bottom:32px}.dashboard-title h1{color:#1e293b;font-size:36px;font-weight:700;margin-bottom:8px}.dashboard-title p{color:#64748b;font-size:16px}.dashboard-actions{align-items:center;display:flex;gap:16px}@media (max-width:768px){.main-content{padding:20px 0}.welcome-section{padding:40px 0}.welcome-card h2{font-size:24px}.welcome-card p{font-size:16px}.dashboard-header{align-items:stretch;flex-direction:column}.dashboard-title h1{font-size:28px}.dashboard-actions{justify-content:stretch}.dashboard-actions .btn{flex:1 1}}