@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.btn{display:inline-block;font-weight:400;line-height:1.5;color:#1e293b;text-align:center;text-decoration:none;vertical-align:middle;cursor:pointer;-webkit-user-select:none;user-select:none;background-color:transparent;border:1px solid transparent;padding:.375rem .75rem;font-size:1rem;border-radius:.375rem;transition:all .2s ease-in-out}.btn:hover{color:#1e293b;text-decoration:none}.btn:focus,.focus.btn{outline:0;box-shadow:0 1px 3px #0000001a}.btn:disabled,.disabled.btn{opacity:.65;cursor:not-allowed}.row{box-sizing:border-box;margin:0 auto;width:100%;display:-webkit-flex;display:-ms-flexbox;display:flex;flex:0 1 auto;flex-direction:row;flex-wrap:wrap}.row.auto-width{width:auto;max-width:100%;margin:initial}.row.reverse{flex-direction:row-reverse}.row.natural-height{align-items:flex-start}.row.flex-column{flex-direction:column}.col{box-sizing:border-box;flex-grow:1;flex-basis:0;max-width:100%;padding:.5em}.col.reverse{flex-direction:column-reverse}.first{order:-1}.last{order:1}.align-start{align-self:flex-start}.align-end{align-self:flex-end}.align-center{align-self:center}.align-baseline{align-self:baseline}.align-stretch{align-self:stretch}.col-xs{box-sizing:border-box;flex-grow:1;flex-basis:0;max-width:100%;padding:.5em}.col-xs-1{box-sizing:border-box;flex-basis:8.3333333333%;max-width:8.3333333333%;padding:.5em}.col-xs-offset-1{margin-left:8.3333333333%}.col-xs-2{box-sizing:border-box;flex-basis:16.6666666667%;max-width:16.6666666667%;padding:.5em}.col-xs-offset-2{margin-left:16.6666666667%}.col-xs-3{box-sizing:border-box;flex-basis:25%;max-width:25%;padding:.5em}.col-xs-offset-3{margin-left:25%}.col-xs-4{box-sizing:border-box;flex-basis:33.3333333333%;max-width:33.3333333333%;padding:.5em}.col-xs-offset-4{margin-left:33.3333333333%}.col-xs-5{box-sizing:border-box;flex-basis:41.6666666667%;max-width:41.6666666667%;padding:.5em}.col-xs-offset-5{margin-left:41.6666666667%}.col-xs-6{box-sizing:border-box;flex-basis:50%;max-width:50%;padding:.5em}.col-xs-offset-6{margin-left:50%}.col-xs-7{box-sizing:border-box;flex-basis:58.3333333333%;max-width:58.3333333333%;padding:.5em}.col-xs-offset-7{margin-left:58.3333333333%}.col-xs-8{box-sizing:border-box;flex-basis:66.6666666667%;max-width:66.6666666667%;padding:.5em}.col-xs-offset-8{margin-left:66.6666666667%}.col-xs-9{box-sizing:border-box;flex-basis:75%;max-width:75%;padding:.5em}.col-xs-offset-9{margin-left:75%}.col-xs-10{box-sizing:border-box;flex-basis:83.3333333333%;max-width:83.3333333333%;padding:.5em}.col-xs-offset-10{margin-left:83.3333333333%}.col-xs-11{box-sizing:border-box;flex-basis:91.6666666667%;max-width:91.6666666667%;padding:.5em}.col-xs-offset-11{margin-left:91.6666666667%}.col-xs-12{box-sizing:border-box;flex-basis:100%;max-width:100%;padding:.5em}.col-xs-offset-12{margin-left:100%}.row.start-xs{justify-content:flex-start}.row.center-xs{justify-content:center}.row.end-xs{justify-content:flex-end}.row.top-xs{align-items:flex-start}.row.middle-xs{align-items:center}.row.bottom-xs{align-items:flex-end}.row.around-xs{justify-content:space-around}.row.between-xs{justify-content:space-between}.first-xs{order:-1}.last-xs{order:1}@media only screen and (min-width:483px){.col-sm{box-sizing:border-box;flex-grow:1;flex-basis:0;max-width:100%;padding:.5em}.col-sm-1{box-sizing:border-box;flex-basis:8.3333333333%;max-width:8.3333333333%;padding:.5em}.col-sm-offset-1{margin-left:8.3333333333%}.col-sm-2{box-sizing:border-box;flex-basis:16.6666666667%;max-width:16.6666666667%;padding:.5em}.col-sm-offset-2{margin-left:16.6666666667%}.col-sm-3{box-sizing:border-box;flex-basis:25%;max-width:25%;padding:.5em}.col-sm-offset-3{margin-left:25%}.col-sm-4{box-sizing:border-box;flex-basis:33.3333333333%;max-width:33.3333333333%;padding:.5em}.col-sm-offset-4{margin-left:33.3333333333%}.col-sm-5{box-sizing:border-box;flex-basis:41.6666666667%;max-width:41.6666666667%;padding:.5em}.col-sm-offset-5{margin-left:41.6666666667%}.col-sm-6{box-sizing:border-box;flex-basis:50%;max-width:50%;padding:.5em}.col-sm-offset-6{margin-left:50%}.col-sm-7{box-sizing:border-box;flex-basis:58.3333333333%;max-width:58.3333333333%;padding:.5em}.col-sm-offset-7{margin-left:58.3333333333%}.col-sm-8{box-sizing:border-box;flex-basis:66.6666666667%;max-width:66.6666666667%;padding:.5em}.col-sm-offset-8{margin-left:66.6666666667%}.col-sm-9{box-sizing:border-box;flex-basis:75%;max-width:75%;padding:.5em}.col-sm-offset-9{margin-left:75%}.col-sm-10{box-sizing:border-box;flex-basis:83.3333333333%;max-width:83.3333333333%;padding:.5em}.col-sm-offset-10{margin-left:83.3333333333%}.col-sm-11{box-sizing:border-box;flex-basis:91.6666666667%;max-width:91.6666666667%;padding:.5em}.col-sm-offset-11{margin-left:91.6666666667%}.col-sm-12{box-sizing:border-box;flex-basis:100%;max-width:100%;padding:.5em}.col-sm-offset-12{margin-left:100%}.row.start-sm{justify-content:flex-start}.row.center-sm{justify-content:center}.row.end-sm{justify-content:flex-end}.row.top-sm{align-items:flex-start}.row.middle-sm{align-items:center}.row.bottom-sm{align-items:flex-end}.row.around-sm{justify-content:space-around}.row.between-sm{justify-content:space-between}.first-sm{order:-1}.last-sm{order:1}}@media only screen and (min-width:769px){.col-md{box-sizing:border-box;flex-grow:1;flex-basis:0;max-width:100%;padding:.5em}.col-md-1{box-sizing:border-box;flex-basis:8.3333333333%;max-width:8.3333333333%;padding:.5em}.col-md-offset-1{margin-left:8.3333333333%}.col-md-2{box-sizing:border-box;flex-basis:16.6666666667%;max-width:16.6666666667%;padding:.5em}.col-md-offset-2{margin-left:16.6666666667%}.col-md-3{box-sizing:border-box;flex-basis:25%;max-width:25%;padding:.5em}.col-md-offset-3{margin-left:25%}.col-md-4{box-sizing:border-box;flex-basis:33.3333333333%;max-width:33.3333333333%;padding:.5em}.col-md-offset-4{margin-left:33.3333333333%}.col-md-5{box-sizing:border-box;flex-basis:41.6666666667%;max-width:41.6666666667%;padding:.5em}.col-md-offset-5{margin-left:41.6666666667%}.col-md-6{box-sizing:border-box;flex-basis:50%;max-width:50%;padding:.5em}.col-md-offset-6{margin-left:50%}.col-md-7{box-sizing:border-box;flex-basis:58.3333333333%;max-width:58.3333333333%;padding:.5em}.col-md-offset-7{margin-left:58.3333333333%}.col-md-8{box-sizing:border-box;flex-basis:66.6666666667%;max-width:66.6666666667%;padding:.5em}.col-md-offset-8{margin-left:66.6666666667%}.col-md-9{box-sizing:border-box;flex-basis:75%;max-width:75%;padding:.5em}.col-md-offset-9{margin-left:75%}.col-md-10{box-sizing:border-box;flex-basis:83.3333333333%;max-width:83.3333333333%;padding:.5em}.col-md-offset-10{margin-left:83.3333333333%}.col-md-11{box-sizing:border-box;flex-basis:91.6666666667%;max-width:91.6666666667%;padding:.5em}.col-md-offset-11{margin-left:91.6666666667%}.col-md-12{box-sizing:border-box;flex-basis:100%;max-width:100%;padding:.5em}.col-md-offset-12{margin-left:100%}.row.start-md{justify-content:flex-start}.row.center-md{justify-content:center}.row.end-md{justify-content:flex-end}.row.top-md{align-items:flex-start}.row.middle-md{align-items:center}.row.bottom-md{align-items:flex-end}.row.around-md{justify-content:space-around}.row.between-md{justify-content:space-between}.first-md{order:-1}.last-md{order:1}}@media only screen and (min-width:991px){.col-lg{box-sizing:border-box;flex-grow:1;flex-basis:0;max-width:100%;padding:.5em}.col-lg-1{box-sizing:border-box;flex-basis:8.3333333333%;max-width:8.3333333333%;padding:.5em}.col-lg-offset-1{margin-left:8.3333333333%}.col-lg-2{box-sizing:border-box;flex-basis:16.6666666667%;max-width:16.6666666667%;padding:.5em}.col-lg-offset-2{margin-left:16.6666666667%}.col-lg-3{box-sizing:border-box;flex-basis:25%;max-width:25%;padding:.5em}.col-lg-offset-3{margin-left:25%}.col-lg-4{box-sizing:border-box;flex-basis:33.3333333333%;max-width:33.3333333333%;padding:.5em}.col-lg-offset-4{margin-left:33.3333333333%}.col-lg-5{box-sizing:border-box;flex-basis:41.6666666667%;max-width:41.6666666667%;padding:.5em}.col-lg-offset-5{margin-left:41.6666666667%}.col-lg-6{box-sizing:border-box;flex-basis:50%;max-width:50%;padding:.5em}.col-lg-offset-6{margin-left:50%}.col-lg-7{box-sizing:border-box;flex-basis:58.3333333333%;max-width:58.3333333333%;padding:.5em}.col-lg-offset-7{margin-left:58.3333333333%}.col-lg-8{box-sizing:border-box;flex-basis:66.6666666667%;max-width:66.6666666667%;padding:.5em}.col-lg-offset-8{margin-left:66.6666666667%}.col-lg-9{box-sizing:border-box;flex-basis:75%;max-width:75%;padding:.5em}.col-lg-offset-9{margin-left:75%}.col-lg-10{box-sizing:border-box;flex-basis:83.3333333333%;max-width:83.3333333333%;padding:.5em}.col-lg-offset-10{margin-left:83.3333333333%}.col-lg-11{box-sizing:border-box;flex-basis:91.6666666667%;max-width:91.6666666667%;padding:.5em}.col-lg-offset-11{margin-left:91.6666666667%}.col-lg-12{box-sizing:border-box;flex-basis:100%;max-width:100%;padding:.5em}.col-lg-offset-12{margin-left:100%}.row.start-lg{justify-content:flex-start}.row.center-lg{justify-content:center}.row.end-lg{justify-content:flex-end}.row.top-lg{align-items:flex-start}.row.middle-lg{align-items:center}.row.bottom-lg{align-items:flex-end}.row.around-lg{justify-content:space-around}.row.between-lg{justify-content:space-between}.first-lg{order:-1}.last-lg{order:1}}@media only screen and (min-width:1201px){.col-xl{box-sizing:border-box;flex-grow:1;flex-basis:0;max-width:100%;padding:.5em}.col-xl-1{box-sizing:border-box;flex-basis:8.3333333333%;max-width:8.3333333333%;padding:.5em}.col-xl-offset-1{margin-left:8.3333333333%}.col-xl-2{box-sizing:border-box;flex-basis:16.6666666667%;max-width:16.6666666667%;padding:.5em}.col-xl-offset-2{margin-left:16.6666666667%}.col-xl-3{box-sizing:border-box;flex-basis:25%;max-width:25%;padding:.5em}.col-xl-offset-3{margin-left:25%}.col-xl-4{box-sizing:border-box;flex-basis:33.3333333333%;max-width:33.3333333333%;padding:.5em}.col-xl-offset-4{margin-left:33.3333333333%}.col-xl-5{box-sizing:border-box;flex-basis:41.6666666667%;max-width:41.6666666667%;padding:.5em}.col-xl-offset-5{margin-left:41.6666666667%}.col-xl-6{box-sizing:border-box;flex-basis:50%;max-width:50%;padding:.5em}.col-xl-offset-6{margin-left:50%}.col-xl-7{box-sizing:border-box;flex-basis:58.3333333333%;max-width:58.3333333333%;padding:.5em}.col-xl-offset-7{margin-left:58.3333333333%}.col-xl-8{box-sizing:border-box;flex-basis:66.6666666667%;max-width:66.6666666667%;padding:.5em}.col-xl-offset-8{margin-left:66.6666666667%}.col-xl-9{box-sizing:border-box;flex-basis:75%;max-width:75%;padding:.5em}.col-xl-offset-9{margin-left:75%}.col-xl-10{box-sizing:border-box;flex-basis:83.3333333333%;max-width:83.3333333333%;padding:.5em}.col-xl-offset-10{margin-left:83.3333333333%}.col-xl-11{box-sizing:border-box;flex-basis:91.6666666667%;max-width:91.6666666667%;padding:.5em}.col-xl-offset-11{margin-left:91.6666666667%}.col-xl-12{box-sizing:border-box;flex-basis:100%;max-width:100%;padding:.5em}.col-xl-offset-12{margin-left:100%}.row.start-xl{justify-content:flex-start}.row.center-xl{justify-content:center}.row.end-xl{justify-content:flex-end}.row.top-xl{align-items:flex-start}.row.middle-xl{align-items:center}.row.bottom-xl{align-items:flex-end}.row.around-xl{justify-content:space-around}.row.between-xl{justify-content:space-between}.first-xl{order:-1}.last-xl{order:1}}.col-gutter-lr{padding:0 .5em}.col-no-gutter{padding:0}.show{display:block!important}.row.show{display:-webkit-flex!important;display:-ms-flexbox!important;display:flex!important}.hide{display:none!important}.show-xs{display:block!important}.row.show-xs{display:-webkit-flex!important;display:-ms-flexbox!important;display:flex!important}.hide-xs{display:none!important}@media only screen and (max-width:482px){.show-xs-only{display:block!important}.row.show-xs-only{display:-webkit-flex!important;display:-ms-flexbox!important;display:flex!important}.hide-xs-only{display:none!important}}@media only screen and (min-width:483px){.show-sm{display:block!important}.row.show-sm{display:-webkit-flex!important;display:-ms-flexbox!important;display:flex!important}.hide-sm{display:none!important}}@media only screen and (min-width:483px)and (max-width:768px){.show-sm-only{display:block!important}.row.show-sm-only{display:-webkit-flex!important;display:-ms-flexbox!important;display:flex!important}.hide-sm-only{display:none!important}}@media only screen and (min-width:769px){.show-md{display:block!important}.row.show-md{display:-webkit-flex!important;display:-ms-flexbox!important;display:flex!important}.hide-md{display:none!important}}@media only screen and (min-width:769px)and (max-width:990px){.show-md-only{display:block!important}.row.show-md-only{display:-webkit-flex!important;display:-ms-flexbox!important;display:flex!important}.hide-md-only{display:none!important}}@media only screen and (min-width:991px){.show-lg{display:block!important}.row.show-lg{display:-webkit-flex!important;display:-ms-flexbox!important;display:flex!important}.hide-lg{display:none!important}}@media only screen and (min-width:991px)and (max-width:1200px){.show-lg-only{display:block!important}.row.show-lg-only{display:-webkit-flex!important;display:-ms-flexbox!important;display:flex!important}.hide-lg-only{display:none!important}}@media only screen and (min-width:1201px){.show-xl{display:block!important}.row.show-xl{display:-webkit-flex!important;display:-ms-flexbox!important;display:flex!important}.hide-xl{display:none!important}}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1rem;font-weight:400;line-height:1.5;color:#1e293b;text-align:left;background-color:#fff}.container-fluid{max-width:1200px;margin:0 auto;padding:0 1rem}[tabindex="-1"]:focus:not(:focus-visible){outline:0!important}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem}p{margin-top:0;margin-bottom:1rem}abbr[title],abbr[data-original-title]{text-decoration:underline;text-decoration:underline dotted;cursor:help;border-bottom:0;text-decoration-skip-ink:none}address{margin-bottom:1rem;font-style:normal;line-height:inherit}ol,ul,dl{margin-top:0;margin-bottom:1rem}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#3b82f6;text-decoration:none;background-color:transparent}a:hover{color:#0a59da;text-decoration:underline}a:not([href]):not([class]),a:not([href]):not([class]):hover{color:inherit;text-decoration:none}h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6{margin-bottom:.5rem;font-weight:500;line-height:1.2}h1,.h1{font-size:2.5rem}h2,.h2{font-size:2rem}h3,.h3{font-size:1.75rem}h4,.h4{font-size:1.5rem}h5,.h5{font-size:1.25rem}h6,.h6{font-size:1rem}.lead{font-size:1.25rem;font-weight:300}.display-1{font-size:6rem;font-weight:300;line-height:1.2}.display-2{font-size:5.5rem;font-weight:300;line-height:1.2}.display-3{font-size:4.5rem;font-weight:300;line-height:1.2}.display-4{font-size:3.5rem;font-weight:300;line-height:1.2}.small{font-size:80%;font-weight:400}.mark{padding:.2em;background-color:#fcf8e3}.text-left{text-align:left!important}.text-right{text-align:right!important}.text-center{text-align:center!important}.text-justify{text-align:justify!important}.text-wrap{white-space:normal!important}.text-nowrap{white-space:nowrap!important}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clearfix:after{display:block;clear:both;content:""}.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.text-muted{color:#64748b!important}.text-primary{color:#3b82f6!important}.text-success{color:#10b981!important}.text-info{color:#06b6d4!important}.text-warning{color:#f59e0b!important}.text-danger{color:#ef4444!important}.text-light{color:#f8fafc!important}.text-dark{color:#1e293b!important}@media(min-width:768px){.mobile-only{display:none!important}}@media(max-width:767px){.desktop-only{display:none!important}}.tablet-only{display:none!important}@media(min-width:576px)and (max-width:1199px){.tablet-only{display:block!important}}@media(hover:none)and (pointer:coarse){button,a,input[type=checkbox],input[type=radio],.btn,.btn-icon{min-height:44px;min-width:44px}}@media(max-width:576px){.container{padding-left:1rem;padding-right:1rem}}@media(max-width:1200px){.projects-grid,.documents-grid,.trades-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.projects-grid,.documents-grid,.trades-grid{grid-template-columns:1fr}}@media(max-width:1200px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:576px){.dashboard-stats{grid-template-columns:1fr}}@media(max-width:576px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}.dashboard-header .btn{width:100%}}@media(max-width:576px){.modal-content{width:95%;max-width:none;margin:1rem;max-height:calc(100vh - 2rem);overflow-y:auto}}@media(max-width:576px){.form-row{flex-direction:column}}@media(max-width:768px){.tab-navigation{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-navigation::-webkit-scrollbar{height:4px}.tab-navigation::-webkit-scrollbar-thumb{background:#0003;border-radius:2px}}@media(max-width:576px){.tab-navigation .tab-button{font-size:.875rem;padding:.75rem 1rem;white-space:nowrap}}@media(max-width:576px){.task-list .task-item,.task-list .assignment-card,.trade-assignments-list .task-item,.trade-assignments-list .assignment-card{flex-direction:column;align-items:flex-start;gap:.75rem}.task-list .task-actions,.task-list .assignment-actions,.trade-assignments-list .task-actions,.trade-assignments-list .assignment-actions{width:100%;justify-content:flex-end}}@media(max-width:768px){.job-calendar .calendar-grid{font-size:.875rem}.job-calendar .day-number{font-size:.75rem}.job-calendar .trade-bar{font-size:.625rem;padding:.125rem .25rem}}@media(max-width:1200px){.job-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:576px){.job-stats-grid{grid-template-columns:1fr}}@media(max-width:576px){.document-actions{flex-direction:column;width:100%}.document-actions .btn{width:100%}}@media(max-width:576px){.documents-list,.tasks-container,.trades-list{-ms-overflow-style:none;scrollbar-width:none}.documents-list::-webkit-scrollbar,.tasks-container::-webkit-scrollbar,.trades-list::-webkit-scrollbar{display:none}}@media(max-width:576px){.toast-container{top:auto;bottom:1rem;left:1rem;right:1rem}}@media(max-height:500px)and (orientation:landscape){.modal-content{max-height:90vh;overflow-y:auto}.dashboard-stats{grid-template-columns:repeat(4,1fr)}}.btn{position:relative;overflow:hidden;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 6px #00000012}.btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 3px #0000001a}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.btn-primary{color:#fff;background-color:#3b82f6;border-color:#3b82f6}.btn-primary:hover{color:#fff;background-color:#166bf4;border-color:#0b63f3}.btn-primary:focus,.btn-primary.focus{color:#fff;background-color:#166bf4;border-color:#0b63f3;box-shadow:0 0 0 .2rem #3b82f680}.btn-primary:disabled,.btn-primary.disabled{color:#fff;background-color:#3b82f6;border-color:#3b82f6;opacity:.65}.btn-primary:hover:not(:disabled){background-color:#0b63f3;border-color:#0b63f3}.btn-form{color:#fff;background-color:#3b82f6;border-color:#3b82f6}.btn-form:hover{color:#fff;background-color:#166bf4;border-color:#0b63f3}.btn-form:focus,.btn-form.focus{color:#fff;background-color:#166bf4;border-color:#0b63f3;box-shadow:0 0 0 .2rem #3b82f680}.btn-form:disabled,.btn-form.disabled{color:#fff;background-color:#3b82f6;border-color:#3b82f6;opacity:.65}.btn-secondary{color:#fff;background-color:#64748b;border-color:#64748b}.btn-secondary:hover{color:#fff;background-color:#546175;border-color:#4f5b6d}.btn-secondary:focus,.btn-secondary.focus{color:#fff;background-color:#546175;border-color:#4f5b6d;box-shadow:0 0 0 .2rem #64748b80}.btn-secondary:disabled,.btn-secondary.disabled{color:#fff;background-color:#64748b;border-color:#64748b;opacity:.65}.btn-secondary:hover:not(:disabled){background-color:#4f5b6d;border-color:#4f5b6d}.btn-success{color:#fff;background-color:#10b981;border-color:#10b981}.btn-success:hover{color:#fff;background-color:#0d9668;border-color:#0c8a60}.btn-success:focus,.btn-success.focus{color:#fff;background-color:#0d9668;border-color:#0c8a60;box-shadow:0 0 0 .2rem #10b98180}.btn-success:disabled,.btn-success.disabled{color:#fff;background-color:#10b981;border-color:#10b981;opacity:.65}.btn-success:hover:not(:disabled){background-color:#0c8a60;border-color:#0c8a60}.btn-danger{color:#fff;background-color:#ef4444;border-color:#ef4444}.btn-danger:hover{color:#fff;background-color:#ec2121;border-color:#eb1515}.btn-danger:focus,.btn-danger.focus{color:#fff;background-color:#ec2121;border-color:#eb1515;box-shadow:0 0 0 .2rem #ef444480}.btn-danger:disabled,.btn-danger.disabled{color:#fff;background-color:#ef4444;border-color:#ef4444;opacity:.65}.btn-danger:hover:not(:disabled){background-color:#eb1515;border-color:#eb1515}.btn-warning{color:#1e293b;background-color:#f59e0b;border-color:#f59e0b}.btn-warning:hover{color:#1e293b;background-color:#d18709;border-color:#c57f08}.btn-warning:focus,.btn-warning.focus{color:#1e293b;background-color:#d18709;border-color:#c57f08;box-shadow:0 0 0 .2rem #f59e0b80}.btn-warning:disabled,.btn-warning.disabled{color:#1e293b;background-color:#f59e0b;border-color:#f59e0b;opacity:.65}.btn-warning:hover:not(:disabled){background-color:#c57f08;border-color:#c57f08}.btn-info{color:#fff;background-color:#06b6d4;border-color:#06b6d4}.btn-info:hover{color:#fff;background-color:#0596af;border-color:#058ba2}.btn-info:focus,.btn-info.focus{color:#fff;background-color:#0596af;border-color:#058ba2;box-shadow:0 0 0 .2rem #06b6d480}.btn-info:disabled,.btn-info.disabled{color:#fff;background-color:#06b6d4;border-color:#06b6d4;opacity:.65}.btn-info:hover:not(:disabled){background-color:#058ba2;border-color:#058ba2}.btn-light{color:#1e293b;background-color:#f8fafc;border-color:#f8fafc}.btn-light:hover{color:#1e293b;background-color:#dde7f1;border-color:#d4e1ed}.btn-light:focus,.btn-light.focus{color:#1e293b;background-color:#dde7f1;border-color:#d4e1ed;box-shadow:0 0 0 .2rem #f8fafc80}.btn-light:disabled,.btn-light.disabled{color:#1e293b;background-color:#f8fafc;border-color:#f8fafc;opacity:.65}.btn-light:hover:not(:disabled){background-color:#e6edf4;border-color:#e6edf4}.btn-dark{color:#fff;background-color:#1e293b;border-color:#1e293b}.btn-dark:hover{color:#fff;background-color:#111722;border-color:#0d1219}.btn-dark:focus,.btn-dark.focus{color:#fff;background-color:#111722;border-color:#0d1219;box-shadow:0 0 0 .2rem #1e293b80}.btn-dark:disabled,.btn-dark.disabled{color:#fff;background-color:#1e293b;border-color:#1e293b;opacity:.65}.btn-dark:hover:not(:disabled){background-color:#2f405d;border-color:#2f405d}.btn-lg{padding:.75rem 1.5rem;font-size:1.25rem;border-radius:.5rem}.btn-sm{padding:.25rem .5rem;font-size:.875rem;border-radius:.25rem}.btn-full{width:100%}.btn-outline{background-color:transparent;border:2px solid #3b82f6;color:#3b82f6;transition:all .3s ease}.btn-outline:hover:not(:disabled){background-color:#3b82f6;color:#fff;transform:translateY(-2px)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;border:none;color:#64748b;cursor:pointer;border-radius:.25rem;transition:all .2s ease}.btn-icon:hover:not(:disabled){background-color:#0000000d;color:#1e293b}.btn-icon:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.btn-icon.btn-edit:hover{color:#06b6d4;background-color:#06b6d41a}.btn-icon.btn-danger:hover{color:#ef4444;background-color:#ef44441a}.btn-icon.btn-success:hover{color:#10b981;background-color:#10b9811a}.btn.loading{position:relative;pointer-events:none;opacity:.8}.btn.loading:before{content:"";display:inline-block;width:1rem;height:1rem;margin-right:.5rem;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}.job-calendar,.overview-calendar{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem}.job-calendar .calendar-header,.overview-calendar .calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.job-calendar .calendar-header h3,.overview-calendar .calendar-header h3{margin:0;color:#3b82f6}.job-calendar .calendar-header .nav-button,.overview-calendar .calendar-header .nav-button{background:#3b82f6;color:#fff;border:none;border-radius:50%;width:40px;height:40px;cursor:pointer;font-size:1.2rem;transition:background-color .2s}.job-calendar .calendar-header .nav-button:hover,.overview-calendar .calendar-header .nav-button:hover{background:#0b63f3}.job-calendar .calendar-grid,.overview-calendar .calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e5e7eb;border-radius:8px;overflow:hidden}.job-calendar .calendar-grid.overview,.overview-calendar .calendar-grid.overview{margin-bottom:2rem}.job-calendar .calendar-grid .day-header,.overview-calendar .calendar-grid .day-header{background:#3b82f6;color:#fff;padding:1rem;text-align:center;font-weight:600;font-size:.9rem}.job-calendar .calendar-grid .calendar-day,.overview-calendar .calendar-grid .calendar-day{background:#fff;min-height:120px;padding:.5rem;position:relative;cursor:pointer;transition:all .2s ease}.job-calendar .calendar-grid .calendar-day:not(.empty):hover,.overview-calendar .calendar-grid .calendar-day:not(.empty):hover{background:#f9fafb;box-shadow:inset 0 0 0 2px #3b82f6}.job-calendar .calendar-grid .calendar-day.empty,.overview-calendar .calendar-grid .calendar-day.empty{background:#f9fafb;cursor:default}.job-calendar .calendar-grid .calendar-day.today,.overview-calendar .calendar-grid .calendar-day.today{background:#fef3c7}.job-calendar .calendar-grid .calendar-day.today:hover,.overview-calendar .calendar-grid .calendar-day.today:hover{background:#fde68a}.job-calendar .calendar-grid .calendar-day.today .day-number,.overview-calendar .calendar-grid .calendar-day.today .day-number{background:#3b82f6;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-weight:700}.job-calendar .calendar-grid .calendar-day.has-activities,.overview-calendar .calendar-grid .calendar-day.has-activities{border-left:3px solid #3b82f6}.job-calendar .calendar-grid .calendar-day.overview,.overview-calendar .calendar-grid .calendar-day.overview{min-height:100px}.job-calendar .calendar-grid .calendar-day .day-number,.overview-calendar .calendar-grid .calendar-day .day-number{font-weight:600;margin-bottom:.5rem;font-size:.9rem}.job-calendar .calendar-grid .calendar-day .day-events,.overview-calendar .calendar-grid .calendar-day .day-events{display:flex;flex-direction:column;gap:2px}.job-calendar .calendar-grid .calendar-day .more-events,.overview-calendar .calendar-grid .calendar-day .more-events{font-size:.7rem;color:#64748b;text-align:center;padding:2px;background:#f3f4f6;border-radius:4px}.job-calendar .trade-bar,.overview-calendar .trade-bar{padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:500;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);margin-bottom:2px;cursor:pointer;transition:opacity .2s}.job-calendar .trade-bar:hover,.overview-calendar .trade-bar:hover{opacity:.8}.job-calendar .trade-bar.overview,.overview-calendar .trade-bar.overview{font-size:.6rem;padding:1px 4px}.job-calendar .trade-bar .trade-bar-text,.overview-calendar .trade-bar .trade-bar-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-calendar .trade-tooltip-wrapper,.overview-calendar .trade-tooltip-wrapper{position:relative;display:block;width:100%}.job-calendar .trade-tooltip,.overview-calendar .trade-tooltip{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:0;min-width:250px;max-width:350px;pointer-events:none;animation:fadeIn .2s ease-in-out;z-index:9999}.job-calendar .trade-tooltip .trade-tooltip-content,.overview-calendar .trade-tooltip .trade-tooltip-content{padding:0}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-header,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-header{background:#3b82f6;color:#fff;padding:.75rem 1rem;border-radius:8px 8px 0 0;font-size:.95rem}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-header strong,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-header strong{font-weight:600}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-header .tooltip-job-name,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-header .tooltip-job-name{font-size:.8rem;opacity:.9;margin-top:.25rem}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-body,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-body{padding:1rem}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-row,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;font-size:.85rem}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-row.tooltip-total,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-row.tooltip-total{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb;font-weight:600;font-size:.9rem}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-row.tooltip-total .tooltip-value,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-row.tooltip-total .tooltip-value{color:#3b82f6;font-size:1rem}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-row .tooltip-label,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-row .tooltip-label{color:#64748b;margin-right:1rem;flex-shrink:0}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-row .tooltip-value,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-row .tooltip-value{color:#1e293b;text-align:right}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-notes,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-notes{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-notes .tooltip-label,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-notes .tooltip-label{display:block;color:#64748b;font-size:.85rem;margin-bottom:.25rem}.job-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-notes p,.overview-calendar .trade-tooltip .trade-tooltip-content .tooltip-body .tooltip-notes p{margin:0;color:#1e293b;font-size:.85rem;line-height:1.4}.job-calendar .trade-tooltip .tooltip-arrow,.overview-calendar .trade-tooltip .tooltip-arrow{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid white}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-100%) translateY(-5px)}to{opacity:1;transform:translate(-50%,-100%) translateY(0)}}.job-calendar .day-hover-tooltip-wrapper,.overview-calendar .day-hover-tooltip-wrapper{position:relative;width:100%;height:100%}.job-calendar .day-hover-tooltip,.overview-calendar .day-hover-tooltip{background:#fff;border-radius:8px;box-shadow:0 4px 16px #0003;padding:0;min-width:280px;max-width:400px;pointer-events:none;animation:fadeIn .2s ease-in-out;z-index:10000}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-header,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-header{background:#3b82f6;color:#fff;padding:.75rem 1rem;border-radius:8px 8px 0 0;font-size:.95rem}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-header strong,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-header strong{font-weight:600;display:block}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-header .tooltip-count,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-header .tooltip-count{font-size:.8rem;opacity:.9;margin-top:.25rem}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body{padding:.75rem 1rem;max-height:300px;overflow-y:auto}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item{padding:.5rem 0;border-bottom:1px solid #f0f0f0}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item:last-child,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item:last-child{border-bottom:none}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item .trade-item-header,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item .trade-item-header{display:flex;flex-direction:column;gap:.25rem}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item .trade-item-header .trade-name,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item .trade-item-header .trade-name{font-weight:600;color:#1e293b;font-size:.9rem}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item .trade-item-header .job-name,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item .trade-item-header .job-name{font-size:.8rem;color:#666}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item .trade-item-description,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item .trade-item-description{font-size:.8rem;color:#555;margin-top:.5rem;line-height:1.4;font-style:italic}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item .trade-item-detail,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-body .tooltip-trade-item .trade-item-detail{font-size:.75rem;color:#888;margin-top:.25rem}.job-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-footer,.overview-calendar .day-hover-tooltip .day-hover-tooltip-content .tooltip-footer{padding:.5rem 1rem;background:#f8f9fa;border-radius:0 0 8px 8px;font-size:.75rem;color:#666;text-align:center;font-style:italic}.job-calendar .day-hover-tooltip:before,.overview-calendar .day-hover-tooltip:before{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid white;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.job-calendar .trade-legend,.overview-calendar .trade-legend{margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.job-calendar .trade-legend h4,.overview-calendar .trade-legend h4{margin:0 0 1rem;color:#3b82f6}.job-calendar .trade-legend .legend-grid,.overview-calendar .trade-legend .legend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.5rem}.job-calendar .trade-legend .legend-item,.overview-calendar .trade-legend .legend-item{display:flex;align-items:center;gap:.5rem}.job-calendar .trade-legend .legend-item .legend-color,.overview-calendar .trade-legend .legend-item .legend-color{width:16px;height:16px;border-radius:4px}.job-calendar .trade-legend .legend-item .legend-label,.overview-calendar .trade-legend .legend-item .legend-label{font-size:.9rem}.job-calendar .calendar-summary,.overview-calendar .calendar-summary{display:flex;justify-content:space-around;padding:1rem;background:#f9fafb;border-radius:8px}.job-calendar .calendar-summary .summary-stat,.overview-calendar .calendar-summary .summary-stat{text-align:center}.job-calendar .calendar-summary .summary-stat .stat-label,.overview-calendar .calendar-summary .summary-stat .stat-label{display:block;font-size:.8rem;color:#64748b;margin-bottom:.25rem}.job-calendar .calendar-summary .summary-stat .stat-value,.overview-calendar .calendar-summary .summary-stat .stat-value{display:block;font-size:1.5rem;font-weight:700;color:#3b82f6}.filters-container{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.filters-container .filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.filters-container .filters-header h4{margin:0;color:#3b82f6;font-size:1.1rem;font-weight:600}.filters-container .filters-header .btn-reset-filters{background:#ef4444;color:#fff;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.filters-container .filters-header .btn-reset-filters:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.filters-container .filters-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media(max-width:768px){.filters-container .filters-grid{grid-template-columns:1fr}}.filters-container .filter-section .filter-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.filters-container .filter-section .filter-section-header h5{margin:0;color:#1e293b;font-size:.95rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.filters-container .filter-section .filter-section-header .filter-badge{background:#3b82f6;color:#fff;border-radius:12px;padding:.15rem .5rem;font-size:.75rem;font-weight:600;min-width:20px;text-align:center}.filters-container .filter-section .filter-section-header .filter-actions{display:flex;gap:.5rem}.filters-container .filter-section .filter-section-header .btn-filter-action{background:transparent;color:#3b82f6;border:1px solid #3b82f6;border-radius:4px;padding:.25rem .75rem;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.filters-container .filter-section .filter-section-header .btn-filter-action:hover{background:#3b82f6;color:#fff}.filters-container .filter-section .filter-options{display:flex;flex-direction:column;gap:.5rem;max-height:250px;overflow-y:auto;padding-right:.5rem}.filters-container .filter-section .filter-options::-webkit-scrollbar{width:6px}.filters-container .filter-section .filter-options::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.filters-container .filter-section .filter-options::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.filters-container .filter-section .filter-options::-webkit-scrollbar-thumb:hover{background:#555}.filters-container .filter-section .filter-checkbox{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:6px;cursor:pointer;transition:background-color .2s;-webkit-user-select:none;user-select:none}.filters-container .filter-section .filter-checkbox:hover{background:#f9fafb}.filters-container .filter-section .filter-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6}.filters-container .filter-section .filter-checkbox .job-color-indicator,.filters-container .filter-section .filter-checkbox .trade-color-indicator{width:16px;height:16px;border-radius:3px;border:1px solid rgba(0,0,0,.1);flex-shrink:0}.filters-container .filter-section .filter-checkbox span{flex:1;font-size:.9rem;color:#1e293b}.overview-calendar .calendar-controls{display:grid;grid-template-columns:1fr 300px;gap:2rem;margin-bottom:2rem}.calendar-loading{display:flex;justify-content:center;align-items:center;height:200px;color:#64748b}.calendar-legend{background:#f9fafb;border-radius:8px;padding:1.5rem;margin-top:2rem}.calendar-legend h4{margin:0 0 .5rem;color:#3b82f6;font-size:1rem}.calendar-legend .legend-description{margin:0;color:#64748b;font-size:.9rem}.calendar-day.has-activities{cursor:pointer;transition:all .2s ease}.calendar-day.has-activities:hover{background-color:#3b82f60d;transform:scale(1.02);box-shadow:0 2px 8px #0000001a}.calendar-day.has-activities:focus{outline:2px solid #3b82f6;outline-offset:2px}.day-detail-modal{max-width:700px;max-height:85vh;overflow-y:auto}.day-detail-modal .modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border-bottom:1px solid #e5e7eb;position:relative}.day-detail-modal .modal-header .modal-header-content{display:flex;justify-content:space-between;align-items:center;flex:1;gap:1rem;margin-right:2rem}.day-detail-modal .modal-header .modal-header-content h2{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937;flex:1}.day-detail-modal .modal-header .modal-header-content .btn-sm{padding:.5rem 1rem;font-size:.875rem;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.day-detail-modal .modal-header .modal-close{position:absolute;top:1.5rem;right:1.5rem}.day-detail-modal .modal-body{padding:1.5rem}.day-detail-modal .modal-footer{display:flex;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid #e5e7eb}.day-activities{display:flex;flex-direction:column;gap:2rem}.activity-section h3{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em}.activity-item{display:flex;gap:1rem;padding:1rem;background:#f9fafb;border-radius:.5rem;transition:all .2s ease}.activity-item:hover{background:#f3f4f6;transform:translate(4px)}.activity-item .activity-indicator{width:4px;border-radius:2px;flex-shrink:0}.activity-item .activity-content{flex:1}.activity-item .activity-content h4{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:#1f2937}.activity-item .activity-content .activity-trade{margin:0 0 .5rem;font-size:.875rem;color:#6b7280;font-weight:500}.activity-item .activity-content .activity-description{margin:0 0 .5rem;font-size:.875rem;color:#4b5563;line-height:1.5}.activity-item .activity-content .activity-details{display:flex;gap:1rem;margin-top:.5rem;font-size:.875rem;color:#6b7280}.activity-item .activity-content .activity-details span{display:flex;align-items:center;gap:.25rem}.activity-item .activity-content .activity-contact{margin:.5rem 0 0;font-size:.875rem;color:#6b7280}.activity-item.trade-assignment-item .activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.activity-item.trade-assignment-item .activity-header h4{margin:0;flex:1}.activity-item.trade-assignment-item .activity-header .trade-type-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;color:#fff;text-transform:capitalize;text-shadow:0 1px 2px rgba(0,0,0,.2)}.activity-item.trade-assignment-item .activity-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;margin-bottom:.75rem}.activity-item.trade-assignment-item .activity-details-grid .detail-item{display:flex;flex-direction:column;gap:.25rem}.activity-item.trade-assignment-item .activity-details-grid .detail-item .detail-label{font-size:.75rem;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.activity-item.trade-assignment-item .activity-details-grid .detail-item .detail-value{font-size:.875rem;color:#1f2937;font-weight:600}.activity-item.trade-assignment-item .work-description{margin-top:.75rem;padding:.75rem;background:#fff;border-radius:6px;border-left:3px solid #3b82f6}.activity-item.trade-assignment-item .work-description .detail-label{display:block;font-size:.75rem;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.activity-item.trade-assignment-item .work-description p{margin:0;font-size:.875rem;color:#4b5563;line-height:1.5}.activity-item.trade-assignment-item .activity-contact{margin-top:.75rem;padding:.5rem .75rem;background:#fff;border-radius:6px;font-size:.875rem;color:#6b7280}.contacts-widget{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;height:100%}.contacts-widget .contacts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid rgba(100,116,139,.1)}.contacts-widget .contacts-header h3{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0}.contacts-widget .contacts-header .btn-sm{padding:.5rem 1rem;font-size:.875rem}.contacts-widget .contacts-loading{display:flex;flex-direction:column;gap:.75rem}.contacts-widget .contacts-loading .skeleton-contact{height:80px;background:linear-gradient(90deg,#64748b1a 25%,#64748b26,#64748b1a 75%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite;border-radius:.375rem}.contacts-widget .contacts-error{text-align:center;padding:2rem 1rem;color:#ef4444;background:#ef44440d;border-radius:.375rem}.contacts-widget .contacts-error p{margin:0}.contacts-widget .contacts-empty{text-align:center;padding:2.5rem 1rem}.contacts-widget .contacts-empty .empty-icon{color:#64748b;margin-bottom:1rem}.contacts-widget .contacts-empty p{color:#64748b;margin-bottom:1rem;font-size:.95rem}.contacts-widget .contacts-empty .btn{display:inline-flex;align-items:center;gap:.5rem}.contacts-widget .contacts-list{display:flex;flex-direction:column;gap:.75rem}.contacts-widget .contact-card{background:#64748b08;border:1px solid rgba(100,116,139,.1);border-radius:.375rem;padding:1rem;transition:all .2s ease}.contacts-widget .contact-card:hover{background:#64748b0d;border-color:#3b82f633;box-shadow:0 2px 8px #3b82f614}.contacts-widget .contact-card .contact-header{margin-bottom:.75rem}.contacts-widget .contact-card .contact-header .contact-info{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.contacts-widget .contact-card .contact-header .contact-info .contact-name{font-size:1rem;font-weight:600;color:#1e293b;margin:0}.contacts-widget .contact-card .contact-header .contact-info .contact-type{font-size:.75rem;padding:.25rem .625rem;border-radius:12px;font-weight:500;text-transform:capitalize;background:#64748b1a;color:#1e293b}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-electrician{background:#ffd70026;color:#665600}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-plumber{background:#4169e126;color:#214cce}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-carpenter{background:#8b451326;color:#753a10}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-bricklayer{background:#dc143c26;color:#ad102f}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-painter{background:#ff69b426;color:#ff0381}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-roofer{background:#2f4f4f26;color:#426f6f}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-plasterer{background:#f0e68c40;color:#9c8e14}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-tiler{background:#20b2aa26;color:#14716c}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-flooring{background:#deb88740;color:#8c6027}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-hvac{background:#ff634726;color:#fa2600}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-glazier{background:#87ceeb40;color:#1f8dba}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-landscaper{background:#32cd3226;color:#1e7b1e}.contacts-widget .contact-card .contact-header .contact-info .contact-type.contact-type-general{background:#80808026;color:#4d4d4d}.contacts-widget .contact-card .contact-details{display:flex;flex-direction:column;gap:.5rem}.contacts-widget .contact-card .contact-details .contact-detail{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#64748b}.contacts-widget .contact-card .contact-details .contact-detail svg{flex-shrink:0;color:#3b82f6}.contacts-widget .contact-card .contact-details .contact-detail span{color:#1e293b}.contacts-widget .contact-card .contact-details .contact-detail .contact-link{color:#3b82f6;text-decoration:none;transition:color .2s ease}.contacts-widget .contact-card .contact-details .contact-detail .contact-link:hover{color:#0b63f3;text-decoration:underline}.contacts-widget .contacts-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(100,116,139,.1);text-align:center}.contacts-widget .contacts-footer .view-all-link{color:#3b82f6;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s ease}.contacts-widget .contacts-footer .view-all-link:hover{color:#0b63f3;text-decoration:underline}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:768px){.contacts-widget .contact-card .contact-header .contact-info{flex-direction:column;align-items:flex-start;gap:.5rem}}.document-manager .document-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.document-manager .document-header h2{margin:0;color:#3b82f6}.document-manager .document-header .document-actions{display:flex;gap:1rem}.document-manager .document-tabs{display:flex;border-bottom:2px solid #e5e7eb;margin-bottom:2rem}.document-manager .document-tabs .tab-button{background:none;border:none;padding:1rem 1.5rem;cursor:pointer;font-weight:500;color:#64748b;border-bottom:2px solid transparent;transition:all .2s}.document-manager .document-tabs .tab-button:hover{color:#3b82f6}.document-manager .document-tabs .tab-button.active{color:#3b82f6;border-bottom-color:#3b82f6}.document-manager .documents-list .loading{text-align:center;padding:2rem;color:#64748b}.document-manager .documents-list .empty-state{text-align:center;padding:3rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.document-manager .documents-list .empty-state p{color:#64748b;margin-bottom:2rem}.document-manager .documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.document-manager .document-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;transition:transform .2s,box-shadow .2s}.document-manager .document-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.document-manager .document-card .document-icon{font-size:2rem;text-align:center;margin-bottom:1rem}.document-manager .document-card .document-info{margin-bottom:1rem}.document-manager .document-card .document-info h4{margin:0 0 .5rem;color:#3b82f6;font-size:1.1rem}.document-manager .document-card .document-info .document-type{font-size:.9rem;color:#64748b;text-transform:capitalize;margin-bottom:.5rem}.document-manager .document-card .document-info .document-description{font-size:.9rem;color:#1e293b;line-height:1.4;margin-bottom:1rem}.document-manager .document-card .document-info .document-meta{display:flex;justify-content:space-between;align-items:center}.document-manager .document-card .document-info .document-meta .document-size{font-size:.8rem;color:#64748b}.document-manager .document-card .document-actions{display:flex;gap:.5rem;justify-content:flex-end}.document-manager .upload-form,.document-manager .rams-form{max-width:600px}.document-manager .upload-form h3,.document-manager .rams-form h3{margin:0 0 2rem;color:#3b82f6}.document-manager .upload-form .form-group,.document-manager .rams-form .form-group{margin-bottom:1.5rem}.document-manager .upload-form .form-group label,.document-manager .rams-form .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#1e293b}.document-manager .upload-form .form-group input,.document-manager .upload-form .form-group textarea,.document-manager .upload-form .form-group select,.document-manager .rams-form .form-group input,.document-manager .rams-form .form-group textarea,.document-manager .rams-form .form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s}.document-manager .upload-form .form-group input:focus,.document-manager .upload-form .form-group textarea:focus,.document-manager .upload-form .form-group select:focus,.document-manager .rams-form .form-group input:focus,.document-manager .rams-form .form-group textarea:focus,.document-manager .rams-form .form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.document-manager .upload-form .form-group textarea,.document-manager .rams-form .form-group textarea{min-height:100px;resize:vertical}.document-manager .upload-form .form-group input[type=file],.document-manager .rams-form .form-group input[type=file]{padding:.5rem}.document-manager .upload-form .form-row,.document-manager .rams-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.document-manager .upload-form .form-actions,.document-manager .rams-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.document-manager .upload-form .form-actions button,.document-manager .rams-form .form-actions button{padding:.75rem 1.5rem;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.document-manager .upload-form .form-actions button[type=button],.document-manager .rams-form .form-actions button[type=button]{background:#f3f4f6;color:#1e293b}.document-manager .upload-form .form-actions button[type=button]:hover,.document-manager .rams-form .form-actions button[type=button]:hover{background:#e5e7eb}.document-manager .upload-form .form-actions button.btn-primary,.document-manager .rams-form .form-actions button.btn-primary{background:#3b82f6;color:#fff}.document-manager .upload-form .form-actions button.btn-primary:hover:not(:disabled),.document-manager .rams-form .form-actions button.btn-primary:hover:not(:disabled){background:#0b63f3}.document-manager .upload-form .form-actions button.btn-primary:disabled,.document-manager .rams-form .form-actions button.btn-primary:disabled{opacity:.6;cursor:not-allowed}.document-manager .rams-form .activity-input{display:flex;gap:.5rem;margin-bottom:.5rem}.document-manager .rams-form .activity-input input{flex:1}.document-manager .rams-form .activity-input button{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem}.document-manager .rams-form .activity-input button:hover{background:#dc2626}.document-manager .rams-form .form-group button{margin-top:.5rem;padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem}.document-manager .rams-form .form-group button:hover{background:#0b63f3}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-overlay .modal-content{background:#fff;border-radius:8px;max-width:90vw;max-height:90vh;overflow-y:auto;padding:2rem;box-shadow:0 20px 25px -5px #0000001a}.file-upload-area{margin-bottom:1rem}.file-upload-area .file-input{display:none}.file-upload-area .file-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;border:2px dashed #d1d5db;border-radius:.5rem;background:#f9fafb;cursor:pointer;transition:all .3s ease}.file-upload-area .file-upload-label:hover{border-color:#3b82f6;background:#fff}.file-upload-area .file-upload-label svg{color:#6b7280}.file-upload-area .file-upload-label span{color:#6b7280;text-align:center}.file-upload-area .file-info{display:flex;align-items:center;justify-content:space-between;padding:.75rem;margin-top:.5rem;background:#fff;border:1px solid #d1d5db;border-radius:.375rem}.file-upload-area .file-info span{font-size:.875rem;color:#1f2937}.file-upload-area .selected-files{margin-top:1rem}.file-upload-area .selected-files h4{margin:0 0 .5rem;font-size:.9rem;color:#1e293b}.file-upload-area .selected-files .file-info{display:flex;align-items:center;justify-content:space-between;padding:.5rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;margin-bottom:.5rem}.file-upload-area .selected-files .file-info span{font-size:.875rem;color:#1e293b}.file-upload-area .upload-progress{margin-top:1rem}.file-upload-area .upload-progress .progress-bar{height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.file-upload-area .upload-progress .progress-bar .progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);transition:width .3s ease;animation:shimmer 1.5s infinite}.file-upload-area .upload-progress .progress-text{display:block;text-align:center;font-size:.875rem;color:#6b7280;font-weight:600}@keyframes shimmer{0%{background-position:-100% 0}to{background-position:200% 0}}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:700;color:#1e293b;font-size:.875rem}.form-group .form-control{display:block;width:100%;padding:.75rem;font-size:1rem;line-height:1.5;color:#1e293b;background-color:#fff;background-clip:padding-box;border:1px solid rgb(186.3723849372,194.2719665272,205.6276150628);border-radius:.375rem;transition:all .2s ease-in-out}.form-group .form-control:focus{color:#1e293b;background-color:#fff;border-color:#3b82f6;outline:0;box-shadow:0 0 0 .2rem #3b82f640}.form-group .form-control.error{border-color:#ef4444;box-shadow:0 0 0 .2rem #ef444440}.form-group .form-control:disabled{background-color:#e7eaee;opacity:1;cursor:not-allowed}.form-group .input-with-icon{position:relative;display:flex;align-items:center}.form-group .input-with-icon .input-icon{position:absolute;left:.75rem;color:#64748b;z-index:1;pointer-events:none}.form-group .input-with-icon .form-control{padding-left:2.5rem;padding-right:2.5rem}.form-group .input-with-icon .password-toggle{position:absolute;right:.75rem;background:none;border:none;color:#64748b;cursor:pointer;padding:.25rem;border-radius:.25rem;display:flex;align-items:center;justify-content:center;z-index:1;transition:color .2s ease}.form-group .input-with-icon .password-toggle:hover:not(:disabled){color:#3b82f6}.form-group .input-with-icon .password-toggle:disabled{opacity:.5;cursor:not-allowed}.form-group textarea.form-control{resize:vertical;min-height:100px}.form-group select.form-control{cursor:pointer}.form-group .error-message{margin-top:.25rem;font-size:.875rem;color:#ef4444}.form-group .form-range{width:100%;height:8px;background:transparent;-webkit-appearance:none;appearance:none;cursor:pointer}.form-group .form-range::-webkit-slider-track{width:100%;height:8px;background:#f8fafc;border-radius:4px}.form-group .form-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:#3b82f6;border-radius:50%;cursor:pointer;transition:all .2s ease}.form-group .form-range::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 0 0 4px #3b82f633}.form-group .form-range::-moz-range-track{width:100%;height:8px;background:#f8fafc;border-radius:4px}.form-group .form-range::-moz-range-thumb{width:20px;height:20px;background:#3b82f6;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.form-group .form-range::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 0 0 4px #3b82f633}.form-group .form-range:focus{outline:none}.form-group .form-range:focus::-webkit-slider-thumb{box-shadow:0 0 0 4px #3b82f64d}.form-group .form-range:focus::-moz-range-thumb{box-shadow:0 0 0 4px #3b82f64d}.form-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:1rem;border-top:1px solid rgb(216.0334728033,220.5188284519,226.9665271967)}.form-actions .btn{min-width:120px}.form-inline .form-group{display:inline-block;margin-bottom:0;margin-right:1rem;vertical-align:middle}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-horizontal .form-group{display:flex;align-items:center;margin-bottom:1rem}.form-horizontal .form-group label{flex:0 0 150px;margin-bottom:0;margin-right:1rem;text-align:right}.form-horizontal .form-group .form-control{flex:1}.create-job-form{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.create-job-form h2{color:#3b82f6;margin-bottom:2rem;font-size:2rem}.loading-spinner{display:flex;justify-content:center;align-items:center;padding:2rem;font-size:1.25rem;color:#64748b}.loading-spinner:before{content:"";width:20px;height:20px;border:2px solid rgb(205.2829268293,223.2926829268,252.7170731707);border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-right:.5rem}.error-message{background-color:#fff;color:#ef4444;padding:1rem;border-radius:.375rem;border:1px solid rgb(247.039408867,161.960591133,161.960591133);margin:1rem 0}.auth-container{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;background:#f8fafc;padding:4rem 1rem 2rem}.auth-card{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:2.5rem;width:100%;max-width:400px;border:1px solid #e2e8f0}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{color:#3b82f6;margin-bottom:.5rem;font-size:2rem;font-weight:600}.auth-header p{color:#40587f;margin:0}.auth-form .form-group{margin-bottom:1.5rem}.auth-form .btn-full{width:100%;padding:.875rem;font-size:1rem;font-weight:500}.auth-footer{text-align:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.auth-footer p{margin:0;color:#64748b;font-size:.875rem}.auth-link{color:#3b82f6;text-decoration:none;font-weight:500}.auth-link:hover{text-decoration:underline}.loading-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#fff}.loading-spinner{text-align:center}.loading-spinner .spinner{width:40px;height:40px;border:4px solid rgb(205.2829268293,223.2926829268,252.7170731707);border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.loading-spinner p{color:#40587f;margin:0}.loading-spinner .form-row{display:flex;gap:1rem}.loading-spinner .form-row .form-group{flex:1}@media(max-width:768px){.loading-spinner .form-row{flex-direction:column;gap:0}}.loading-spinner .delete-warning{text-align:center;margin-bottom:2rem}.loading-spinner .delete-warning .warning-icon{color:#ef4444;margin-bottom:1rem}.loading-spinner .delete-warning h3{color:#ef4444;margin-bottom:1rem;font-size:1.25rem;font-weight:700}.loading-spinner .delete-warning .warning-text{color:#64748b;line-height:1.5;margin:0}.loading-spinner .form-help{margin-top:.25rem;font-size:.875rem;color:#64748b}.loading-spinner .form-help.text-error{color:#ef4444}.project-card{display:flex;flex-direction:column;background:#fff;border:1px solid rgba(100,116,139,.12);border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;text-decoration:none;color:inherit;position:relative;overflow:hidden}.project-card:hover{box-shadow:0 1px 3px #0000001a;border-color:#e2e8f0}.project-card .project-card-header{margin-bottom:1.25rem}.project-card .project-card-header .title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.project-card .project-card-header .title-row .project-title-link{flex:1;text-decoration:none;color:inherit}.project-card .project-card-header .title-row .project-title-link .project-title{font-size:1.125rem;font-weight:600;color:#1e293b;margin:0;line-height:1.3;transition:color .2s ease}.project-card .project-card-header .title-row .project-title-link .project-title:hover{color:#3b82f6}.project-card .project-card-header .title-row .btn-icon{background:none;border:none;padding:.5rem;cursor:pointer;color:#64748b;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.project-card .project-card-header .title-row .btn-icon:hover{background:#3b82f614;color:#3b82f6}.project-card .project-card-header .title-row .btn-icon:active{transform:scale(.95)}.project-card .project-card-header .project-badges{display:flex;gap:.5rem;flex-wrap:wrap}.project-card .project-card-body{display:flex;flex-direction:column;gap:1rem}.project-card .project-card-body .project-info-row{display:flex;align-items:center;gap:.625rem;font-size:.875rem;color:#64748b}.project-card .project-card-body .project-info-row svg{flex-shrink:0;color:#3b82f6}.project-card .project-card-body .project-info-row .days-remaining{color:#10b981;font-weight:600}.project-card .project-card-body .project-info-row .days-overdue{color:#ef4444;font-weight:600}.project-card .project-card-body .progress-section .progress-header{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;font-weight:500;color:#1e293b;margin-bottom:.5rem}.project-card .project-card-body .progress-section .progress-bar{width:100%;height:8px;background:#f8fafc;border-radius:4px;overflow:hidden}.project-card .project-card-body .progress-section .progress-bar .progress-fill{height:100%;background:#3b82f6;border-radius:4px;transition:width .4s ease}.project-card .project-card-body .project-stats{display:flex;gap:1.25rem;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(100,116,139,.1)}.project-card .project-card-body .project-stats .stat-item{display:flex;align-items:center;gap:.4rem;font-size:.875rem}.project-card .project-card-body .project-stats .stat-item .stat-icon{color:#3b82f6;flex-shrink:0}.project-card .project-card-body .project-stats .stat-item .stat-label{color:#64748b;font-weight:500}.project-card .project-card-body .project-stats .stat-item .stat-value{color:#1e293b;font-weight:600}.project-card .status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.project-card .status-badge.status-planning{background:#06b6d41a;color:#058ba2}.project-card .status-badge.status-in-progress{background:#3b82f61a;color:#0b63f3}.project-card .status-badge.status-completed{background:#10b9811a;color:#0c8a60}.project-card .status-badge.status-on-hold{background:#f59e0b1a;color:#ac6f07}.project-card .status-badge.status-cancelled{background:#64748b1a;color:#4f5b6d}.project-card .priority-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.project-card .priority-badge.priority-low{background:#64748b1a;color:#4f5b6d}.project-card .priority-badge.priority-medium{background:#06b6d41a;color:#058ba2}.project-card .priority-badge.priority-high{background:#f59e0b1a;color:#ac6f07}.project-card .priority-badge.priority-urgent{background:#ef44441a;color:#eb1515}@media(max-width:768px){.project-card{padding:1rem}.project-card .project-card-body{gap:.75rem}.project-card .project-card-body .project-stats{flex-wrap:wrap;gap:.75rem}}.cost-summary{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0}.cost-summary.loading,.cost-summary.error{text-align:center;padding:2rem;color:#64748b}.cost-summary.error{color:#ef4444}.cost-summary .cost-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.cost-summary .cost-header h3{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0}.cost-summary .cost-header svg{color:#3b82f6}.cost-summary .cost-total{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.cost-summary .cost-total .cost-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8fafc;border-radius:8px}.cost-summary .cost-total .cost-item .label{font-size:.875rem;color:#64748b;font-weight:500;display:flex;align-items:center;gap:.5rem}.cost-summary .cost-total .cost-item .label svg{flex-shrink:0}.cost-summary .cost-total .cost-item .value{font-size:1rem;font-weight:600;color:#1e293b}.cost-summary .cost-total .cost-item .value.total{font-size:1.5rem;color:#3b82f6}.cost-summary .cost-total .cost-item.variance.over{background:var(--color-error-light)}.cost-summary .cost-total .cost-item.variance.over .label{color:#ef4444}.cost-summary .cost-total .cost-item.variance.over .label svg{color:#ef4444}.cost-summary .cost-total .cost-item.variance.over .value{color:#ef4444}.cost-summary .cost-total .cost-item.variance.under{background:var(--color-success-light)}.cost-summary .cost-total .cost-item.variance.under .label{color:#10b981}.cost-summary .cost-total .cost-item.variance.under .label svg{color:#10b981}.cost-summary .cost-total .cost-item.variance.under .value{color:#10b981}.cost-summary .cost-total .budget-progress{display:flex;flex-direction:column;gap:.5rem}.cost-summary .cost-total .budget-progress .progress-bar{width:100%;height:8px;background:#f8fafc;border-radius:4px;overflow:hidden}.cost-summary .cost-total .budget-progress .progress-bar .progress-fill{height:100%;background:#10b981;transition:width .3s ease;border-radius:4px}.cost-summary .cost-total .budget-progress .progress-bar .progress-fill.over{background:#ef4444}.cost-summary .cost-total .budget-progress .progress-text{font-size:.75rem;color:#94a3b8;text-align:center}.cost-summary .trade-breakdown h4{font-size:1rem;font-weight:600;color:#1e293b;margin:0 0 1rem}.cost-summary .trade-breakdown .breakdown-list{display:flex;flex-direction:column;gap:.75rem}.cost-summary .trade-breakdown .breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8fafc;border-radius:8px;border-left:3px solid #3b82f6;transition:all .2s ease}.cost-summary .trade-breakdown .breakdown-item:hover{background:#fff;transform:translate(4px)}.cost-summary .trade-breakdown .breakdown-item .trade-info{display:flex;flex-direction:column;gap:.25rem}.cost-summary .trade-breakdown .breakdown-item .trade-info .trade-name{font-weight:600;color:#1e293b;font-size:.875rem}.cost-summary .trade-breakdown .breakdown-item .trade-info .trade-type{font-size:.75rem;color:#94a3b8;text-transform:capitalize}.cost-summary .trade-breakdown .breakdown-item .trade-stats{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.cost-summary .trade-breakdown .breakdown-item .trade-stats .assignments{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#64748b}.cost-summary .trade-breakdown .breakdown-item .trade-stats .assignments svg{color:#94a3b8}.cost-summary .trade-breakdown .breakdown-item .trade-stats .cost{font-weight:600;color:#3b82f6;font-size:.875rem}.cost-summary .empty-state{text-align:center;padding:2rem;color:#94a3b8;font-size:.875rem}@media(max-width:768px){.cost-summary{padding:1rem}.cost-summary .cost-header h3{font-size:1.125rem}.cost-summary .cost-total .cost-item .value.total{font-size:1.25rem}.cost-summary .trade-breakdown .breakdown-item{flex-direction:column;align-items:flex-start;gap:.75rem}.cost-summary .trade-breakdown .breakdown-item .trade-stats{width:100%;flex-direction:row;justify-content:space-between;align-items:center}}.snagging-tool .snagging-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.snagging-tool .snagging-header h2{margin:0;color:var(--color-primary)}.snagging-tool .snag-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.snagging-tool .snag-stats .stat-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center}.snagging-tool .snag-stats .stat-card .stat-number{display:block;font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:.5rem}.snagging-tool .snag-stats .stat-card .stat-label{font-size:.9rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.snagging-tool .snag-tabs{display:flex;border-bottom:2px solid #e5e7eb;margin-bottom:2rem}.snagging-tool .snag-tabs .tab-button{background:none;border:none;padding:1rem 1.5rem;cursor:pointer;font-weight:500;color:var(--color-text-secondary);border-bottom:2px solid transparent;transition:all .2s}.snagging-tool .snag-tabs .tab-button:hover{color:var(--color-primary)}.snagging-tool .snag-tabs .tab-button.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.snagging-tool .snags-list .loading{text-align:center;padding:2rem;color:var(--color-text-secondary)}.snagging-tool .snags-list .empty-state{text-align:center;padding:3rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.snagging-tool .snags-list .empty-state p{color:var(--color-text-secondary);margin-bottom:2rem}.snagging-tool .snag-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;margin-bottom:1rem;transition:transform .2s,box-shadow .2s}.snagging-tool .snag-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.snagging-tool .snag-card .snag-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.snagging-tool .snag-card .snag-header h4{margin:0;color:var(--color-primary);flex:1}.snagging-tool .snag-card .snag-header .snag-badges{display:flex;gap:.5rem;flex-shrink:0}.snagging-tool .snag-card .snag-description{color:var(--color-text);line-height:1.5;margin-bottom:1rem}.snagging-tool .snag-card .snag-details{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;font-size:.9rem;color:var(--color-text-secondary)}.snagging-tool .snag-card .snag-details span{display:flex;align-items:center;gap:.25rem}.snagging-tool .snag-card .snag-actions{display:flex;gap:.5rem;justify-content:flex-end}.snagging-tool .create-snag-form{max-width:600px}.snagging-tool .create-snag-form h3{margin:0 0 2rem;color:var(--color-primary)}.snagging-tool .create-snag-form .form-group{margin-bottom:1.5rem}.snagging-tool .create-snag-form .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-text)}.snagging-tool .create-snag-form .form-group input,.snagging-tool .create-snag-form .form-group textarea,.snagging-tool .create-snag-form .form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s}.snagging-tool .create-snag-form .form-group input:focus,.snagging-tool .create-snag-form .form-group textarea:focus,.snagging-tool .create-snag-form .form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.snagging-tool .create-snag-form .form-group textarea{min-height:100px;resize:vertical}.snagging-tool .create-snag-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.snagging-tool .create-snag-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.snagging-tool .create-snag-form .form-actions button{padding:.75rem 1.5rem;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.snagging-tool .create-snag-form .form-actions button[type=button]{background:#f3f4f6;color:var(--color-text)}.snagging-tool .create-snag-form .form-actions button[type=button]:hover{background:#e5e7eb}.snagging-tool .create-snag-form .form-actions button.btn-primary{background:var(--color-primary);color:#fff}.snagging-tool .create-snag-form .form-actions button.btn-primary:hover{background:var(--color-primary-dark)}.badge.bg-yellow-100{background-color:#fef3c7}.badge.text-yellow-800{color:#92400e}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover{background-color:#059669}.task-list{padding:2.5rem 2rem;max-width:1000px;margin:0 auto}.task-list .task-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;gap:1rem;padding:2rem;background:linear-gradient(135deg,#fff,#3b82f605);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 20px #00000014;position:relative;overflow:hidden;animation:headerSlideIn .6s ease-out}.task-list .task-list-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#10b981,#3b82f6)}.task-list .task-list-header .task-stats{display:flex;flex-direction:column;gap:1.5rem;min-width:0;flex:1}.task-list .task-list-header .task-stats .task-stats-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.task-list .task-list-header .task-stats .task-stats-header h3{margin:0;font-size:1.75rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2}.task-list .task-list-header .task-stats .task-stats-header .task-count{display:inline-flex;align-items:center;padding:.375rem .875rem;background:#3b82f6;color:#fff;font-size:.8125rem;font-weight:600;border-radius:16px;box-shadow:0 2px 8px #3b82f633;transition:all .2s ease;white-space:nowrap}.task-list .task-list-header .task-stats .task-stats-header .task-count:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.task-list .task-list-header .task-stats .progress-container{display:flex;flex-direction:column;gap:.75rem}.task-list .task-list-header .task-stats .progress-container .progress-bar{width:100%;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden;position:relative;box-shadow:inset 0 1px 2px #0000001a}.task-list .task-list-header .task-stats .progress-container .progress-bar .progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#3b82f6);border-radius:4px;transition:width .6s ease;position:relative}.task-list .task-list-header .task-stats .progress-container .progress-percentage{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-align:center;margin:0}.task-list .task-add-form{background:linear-gradient(135deg,#007bff08,#007bff03);border:2px dashed var(--primary);box-shadow:0 2px 12px #007bff14}.task-list .task-add-form:hover{background:linear-gradient(135deg,#007bff0d,#007bff05);border-color:var(--primary-dark)}.task-list .tasks-container{display:flex;flex-direction:column;gap:2rem}.task-list .tasks-section{display:flex;flex-direction:column;gap:1rem}.task-list .tasks-section.completed-section{margin-top:2.5rem;padding-top:2.5rem;border-top:2px solid var(--border-color);position:relative}.task-list .tasks-section.completed-section:before{content:"";position:absolute;top:-1px;left:50%;transform:translate(-50%);width:60px;height:2px;background:linear-gradient(90deg,transparent,var(--success),transparent);border-radius:1px}.task-list .tasks-section.completed-section .section-title{display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:.875rem;font-weight:700;color:var(--text-secondary);margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:1px;position:relative}.task-list .tasks-section.completed-section .section-title:before{content:"";display:inline-block;width:1rem;height:1rem;margin-right:.5rem;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20,6 9,17 4,12'/%3E%3C/svg%3E") no-repeat center;background-size:contain;vertical-align:middle}.task-list .tasks-section.completed-section .section-title:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border-color),transparent);margin-left:1rem}.task-list .task-item{display:flex;align-items:center;gap:1.25rem;padding:1.5rem 1.75rem;background:var(--surface);border:2px solid var(--border-color);border-radius:16px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;cursor:pointer;box-shadow:0 2px 8px #0000000a}.task-list .task-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(180deg,var(--primary) 0%,var(--primary-dark) 100%);transform:scaleY(0);transition:transform .4s cubic-bezier(.4,0,.2,1);border-radius:0 3px 3px 0;box-shadow:0 0 10px #3b82f64d}.task-list .task-item:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#3b82f608,#3b82f603,#10b98105);opacity:0;transition:opacity .4s ease;pointer-events:none;border-radius:16px}.task-list .task-item:hover{border-color:var(--primary);box-shadow:0 12px 32px #3b82f626;transform:translateY(-4px) scale(1.005)}.task-list .task-item:hover:before{transform:scaleY(1)}.task-list .task-item:hover:after{opacity:1}.task-list .task-item:active{transform:translateY(-2px) scale(.995);transition-duration:.15s}.task-list .task-item.completed{background:linear-gradient(135deg,#10b9810d,#10b98105,#10b98103);border-color:#10b9814d;animation:taskComplete .6s cubic-bezier(.4,0,.2,1)}.task-list .task-item.completed:before{background:linear-gradient(180deg,var(--success) 0%,rgb(11.9402985075,138.0597014925,96.2686567164) 100%);transform:scaleY(1);box-shadow:0 0 15px #10b98166}.task-list .task-item.completed .task-title{color:var(--text-secondary);opacity:.75;text-decoration:line-through;text-decoration-color:var(--success);text-decoration-thickness:2px}.task-list .task-item.completed .task-title:after{transform:scaleX(1);background:linear-gradient(90deg,var(--success) 0%,var(--success) 100%)}.task-list .task-item.completed:hover{border-color:var(--success);box-shadow:0 8px 24px #10b98126;transform:translateY(-2px) scale(1.002)}.task-list .task-item .task-checkbox{display:flex;align-items:center;flex-shrink:0}.task-list .task-item .task-checkbox input[type=checkbox]{width:22px;height:22px;cursor:pointer;accent-color:var(--success);border-radius:6px;transition:all .2s ease}.task-list .task-item .task-checkbox input[type=checkbox]:hover{transform:scale(1.1)}.task-list .task-item .task-checkbox input[type=checkbox]:checked{animation:checkBounce .3s cubic-bezier(.68,-.55,.265,1.55)}.task-list .task-item .task-content{flex:1;display:flex;flex-direction:column;gap:.75rem}.task-list .task-item .task-content .task-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);line-height:1.4;word-break:break-word;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);letter-spacing:-.01em}.task-list .task-item .task-content .task-title:after{content:"";position:absolute;left:0;right:0;top:50%;height:3px;background:linear-gradient(90deg,var(--success) 0%,var(--success) 100%);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.4,0,.2,1);border-radius:2px}.task-list .task-item .task-content .task-meta{display:flex;align-items:center;gap:1rem;font-size:.875rem}.task-list .task-item .task-content .task-meta .priority-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.task-list .task-item .task-content .task-meta .priority-badge svg{flex-shrink:0}.task-list .task-item .task-content .task-meta .priority-badge.priority-low{background:#6c757d1a;color:var(--text-secondary)}.task-list .task-item .task-content .task-meta .priority-badge.priority-medium{background:#007bff1a;color:var(--primary)}.task-list .task-item .task-content .task-meta .priority-badge.priority-high{background:#ffc1071a;color:var(--warning)}.task-list .task-item .task-content .task-meta .priority-badge.priority-urgent{background:#dc35451a;color:var(--danger);animation:priorityPulse 2s infinite}.task-list .task-item .task-content .task-meta .due-date{color:var(--text-secondary);font-weight:500}.task-list .task-item .task-content .task-meta .due-date.overdue{color:var(--danger);font-weight:600}.task-list .task-item .task-content .task-meta .due-date.overdue:before{content:"";display:inline-block;width:1em;height:1em;margin-right:.25em;background:url("data:image/svg+xml,%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='M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z'/%3E%3Cline x1='12' y1='9' x2='12' y2='13'/%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'/%3E%3C/svg%3E") no-repeat center;background-size:contain;vertical-align:text-bottom}.task-list .task-item .task-content .task-meta .priority-selector{display:flex;gap:.25rem;align-items:center}.task-list .task-item .task-content .task-meta .priority-selector .priority-option{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .625rem;border:2px solid var(--border-color);border-radius:8px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:var(--surface);color:var(--text-primary);cursor:pointer;transition:all .2s ease;position:relative}.task-list .task-item .task-content .task-meta .priority-selector .priority-option svg{flex-shrink:0}.task-list .task-item .task-content .task-meta .priority-selector .priority-option:hover{transform:translateY(-1px);box-shadow:0 2px 8px #007bff26}.task-list .task-item .task-content .task-meta .priority-selector .priority-option:focus{outline:2px solid var(--primary);outline-offset:2px}.task-list .task-item .task-content .task-meta .priority-selector .priority-option.selected{border-color:currentColor;box-shadow:0 0 0 2px #007bff1a;transform:translateY(-1px)}.task-list .task-item .task-content .task-meta .priority-selector .priority-option.loading{opacity:.6;cursor:not-allowed;transform:none}.task-list .task-item .task-content .task-meta .priority-selector .priority-option.loading:hover{transform:none;box-shadow:none}.task-list .task-item .task-content .task-meta .priority-badge-button,.task-list .task-item .task-content .task-meta .due-date-button{background:transparent;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:all .2s ease;display:inline-flex;align-items:center;gap:.25rem;font-size:inherit;font-weight:inherit;color:inherit}.task-list .task-item .task-content .task-meta .priority-badge-button:hover,.task-list .task-item .task-content .task-meta .due-date-button:hover{background:#007bff1a;transform:scale(1.05)}.task-list .task-item .task-content .task-meta .priority-badge-button:focus,.task-list .task-item .task-content .task-meta .due-date-button:focus{outline:2px solid var(--primary);outline-offset:2px}.task-list .task-item .task-content .task-meta .priority-badge-button.overdue:hover,.task-list .task-item .task-content .task-meta .due-date-button.overdue:hover{background:#dc35451a}.task-list .task-item .task-content .task-meta .priority-badge-button.empty,.task-list .task-item .task-content .task-meta .due-date-button.empty{color:var(--text-secondary);opacity:.7}.task-list .task-item .task-content .task-meta .priority-badge-button.empty:hover,.task-list .task-item .task-content .task-meta .due-date-button.empty:hover{opacity:1;background:#007bff0d}.task-list .task-item .task-content .task-meta .priority-badge-button svg,.task-list .task-item .task-content .task-meta .due-date-button svg{flex-shrink:0}.task-list .task-item .task-input{flex:1;padding:.625rem .875rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;font-weight:500;background:var(--surface);color:var(--text-primary);transition:all .2s ease}.task-list .task-item .task-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007bff1a}.task-list .task-item .task-input::placeholder{color:var(--text-secondary);opacity:.6}.task-list .task-item .priority-select{padding:.5rem .75rem;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;font-weight:500;background:var(--surface);color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-width:120px}.task-list .task-item .priority-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007bff1a}.task-list .task-item .priority-select:hover{border-color:var(--primary)}.task-list .task-item .due-date-editor{display:flex;align-items:center;gap:.5rem}.task-list .task-item .due-date-editor .due-date-input{padding:.5rem .75rem;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;font-weight:500;background:var(--surface);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.task-list .task-item .due-date-editor .due-date-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007bff1a}.task-list .task-item .due-date-editor .due-date-input:hover{border-color:var(--primary)}.task-list .task-item .due-date-editor .btn-clear-date{padding:.375rem;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.task-list .task-item .due-date-editor .btn-clear-date:hover{background:#dc35451a;color:var(--danger)}.task-list .task-item .due-date-editor .task-header-controls{display:flex;align-items:center;gap:1rem}.task-list .task-item .due-date-editor .task-header-controls .filter-controls{display:flex;align-items:center;gap:1rem;flex:1}.task-list .task-item .due-date-editor .task-header-controls .filter-controls .search-bar{flex:1;max-width:300px;margin-bottom:.5rem}.task-list .task-item .due-date-editor .task-header-controls .filter-controls .task-filter-select{padding:.5rem .75rem;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;font-weight:500;background:var(--surface);color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-width:120px}.task-list .task-item .due-date-editor .task-header-controls .filter-controls .task-filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.task-list .task-item .due-date-editor .task-header-controls .filter-controls .task-filter-select:hover{border-color:#3b82f6;background:#3b82f605}.task-list .task-item .due-date-editor .task-header-controls .filter-controls .task-filter-select.task-filter-active{border-color:#3b82f6;background:#3b82f60d;color:#3b82f6}.task-list .task-item .due-date-editor .task-header-controls .filter-controls .task-filter-select option{background:var(--surface);color:var(--text-primary)}.task-list .task-item .due-date-editor .task-header-controls .sort-controls{display:flex;align-items:center;gap:.5rem}.task-list .task-item .due-date-editor .task-header-controls .sort-controls .task-sort-select{padding:.5rem .75rem;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;font-weight:500;background:var(--surface);color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-width:140px}.task-list .task-item .due-date-editor .task-header-controls .sort-controls .task-sort-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.task-list .task-item .due-date-editor .task-header-controls .sort-controls .task-sort-select:hover{border-color:#3b82f6;background:#3b82f605}.task-list .task-item .due-date-editor .task-header-controls .sort-controls .task-sort-select option{background:var(--surface);color:var(--text-primary)}.task-list .task-item .due-date-editor .task-header-controls .sort-controls .task-sort-order-btn{padding:.5rem;background:var(--surface);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.task-list .task-item .due-date-editor .task-header-controls .sort-controls .task-sort-order-btn:hover{border-color:#3b82f6;color:#3b82f6;background:#3b82f60d}.task-list .task-item .due-date-editor .task-header-controls .sort-controls .task-sort-order-btn:focus{outline:2px solid #3b82f6;outline-offset:2px}.task-list .task-item .due-date-editor .task-header-controls .sort-controls .task-sort-order-btn:active{transform:scale(.95)}.task-list .task-item .due-date-editor .task-header-controls button.task-add-btn{padding:.75rem 1.25rem!important;background:#3b82f6!important;border:none!important;border-radius:8px!important;color:#fff!important;font-size:.875rem!important;font-weight:600!important;cursor:pointer!important;transition:all .2s ease!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:.5rem!important;box-shadow:0 2px 8px #3b82f64d!important;position:relative!important;z-index:1!important}.task-list .task-item .due-date-editor .task-header-controls button.task-add-btn:hover{background:#2563eb!important;transform:translateY(-1px)!important;box-shadow:0 4px 16px #3b82f666!important}.task-list .task-item .due-date-editor .task-header-controls button.task-add-btn:focus{outline:2px solid #3b82f6!important;outline-offset:2px!important}.task-list .task-item .due-date-editor .task-header-controls button.task-add-btn:active{transform:translateY(0)!important;box-shadow:0 2px 8px #3b82f64d!important}.task-list .task-item .due-date-editor .task-header-controls button.task-add-btn .task-add-btn-text{font-weight:600!important}.task-list .task-item .task-actions{display:flex;gap:.375rem;opacity:0;transition:all .25s cubic-bezier(.4,0,.2,1);transform:translate(8px)}.task-list .task-item:hover .task-actions,.task-list .task-item:focus-within .task-actions{opacity:1;transform:translate(0)}.task-list .task-item .btn-icon{padding:.5rem;background:transparent;border:none;border-radius:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;position:relative}.task-list .task-item .btn-icon:before{content:"";position:absolute;inset:0;border-radius:8px;background:currentColor;opacity:0;transition:opacity .2s ease}.task-list .task-item .btn-icon svg{position:relative;z-index:1}.task-list .task-item .btn-icon:hover{transform:scale(1.1)}.task-list .task-item .btn-icon:hover:before{opacity:.1}.task-list .task-item .btn-icon:active{transform:scale(.95)}.task-list .task-item .btn-icon.btn-success{color:var(--success)}.task-list .task-item .btn-icon.btn-success:hover{color:#1e7e34}.task-list .task-item .btn-icon.btn-danger{color:var(--danger)}.task-list .task-item .btn-icon.btn-danger:hover{color:#bd2130}.task-list .task-item .btn-icon.btn-secondary{color:var(--text-secondary)}.task-list .task-item .btn-icon.btn-secondary:hover{color:var(--text-primary)}.task-list .task-item .btn-icon:disabled{opacity:.4;cursor:not-allowed;transform:none}.task-list .task-item .btn-icon:disabled:hover{transform:none}.task-list .task-item .btn-icon:disabled:hover:before{opacity:0}@keyframes checkBounce{0%,to{transform:scale(1)}50%{transform:scale(1.25)}}@keyframes taskComplete{0%{transform:scale(1);opacity:1}50%{transform:scale(1.02);opacity:.9}to{transform:scale(1);opacity:1}}@keyframes priorityPulse{0%,to{box-shadow:0 0 #dc354566}50%{box-shadow:0 0 0 6px #dc354500}}@keyframes progressShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes progressGlow{0%,to{opacity:0}50%{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes headerSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translate(-50%,-50%) rotate(0)}50%{transform:translate(-50%,-50%) rotate(180deg)}}.task-list .empty-state{text-align:center;padding:8rem 4rem;background:linear-gradient(135deg,#3b82f60a,#3b82f605 30%,#10b98108 70%,#10b98103);border:3px dashed var(--border-color);border-radius:24px;color:var(--text-secondary);position:relative;overflow:hidden;animation:fadeInUp .8s ease-out;box-shadow:inset 0 4px 20px #00000005}.task-list .empty-state:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(59,130,246,.03) 0%,transparent 70%);animation:float 6s ease-in-out infinite;pointer-events:none}.task-list .empty-state .empty-state-icon{margin-bottom:2rem;opacity:.7;color:var(--primary);transform:scale(1);animation:bounceIn .8s ease-out .2s both}.task-list .empty-state .empty-state-icon svg{display:block;margin:0 auto;width:80px;height:80px;filter:drop-shadow(0 4px 12px rgba(59,130,246,.2))}.task-list .empty-state h3{margin:0 0 1rem;font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.3;animation:fadeInUp .8s ease-out .4s both}.task-list .empty-state p{font-size:1.125rem;font-weight:500;line-height:1.6;color:var(--text-secondary);max-width:400px;margin:0 auto;animation:fadeInUp .8s ease-out .6s both}.task-list .loading{text-align:center;padding:4rem 2rem;color:var(--text-secondary);font-size:1.125rem;font-weight:500;background:linear-gradient(135deg,#3b82f605,#3b82f603);border-radius:16px;border:2px dashed var(--border-color);animation:fadeInUp .6s ease-out}.task-list .loading:before{content:"";display:inline-block;width:24px;height:24px;margin-right:.75rem;border:3px solid var(--border-color);border-top:3px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite;vertical-align:middle}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.task-list .error-state{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#dc354505,#dc354503);border:2px dashed var(--danger);border-radius:16px;color:var(--danger)}.task-list .error-state p{margin:0;font-size:1rem;font-weight:500;line-height:1.6}@media(max-width:990px){.task-list{padding:1.5rem 1.25rem;max-width:100%}.task-list .task-list-header{padding:1rem;margin-bottom:2rem}.task-list .task-list-header .task-stats h3{font-size:2rem}.task-list .task-list-header .task-header-controls{gap:.75rem}.task-list .task-list-header .task-header-controls .filter-controls{gap:.5rem;flex:1}.task-list .task-list-header .task-header-controls .filter-controls .search-bar{max-width:250px}.task-list .task-list-header .task-header-controls .filter-controls .task-filter-select{min-width:100px;font-size:.8125rem;padding:.4375rem .625rem}.task-list .task-list-header .task-header-controls .sort-controls{gap:.375rem}.task-list .task-list-header .task-header-controls .sort-controls .task-sort-select{min-width:120px;font-size:.8125rem;padding:.4375rem .625rem}.task-list .task-list-header .task-header-controls .sort-controls .task-sort-order-btn{padding:.4375rem}.task-list .task-item{padding:1.25rem 1.5rem;gap:1rem}.task-list .task-item .task-content .task-title{font-size:1rem}}@media(max-width:768px){.task-list{padding:1rem .75rem}.task-list .task-list-header{flex-direction:column;align-items:flex-start;gap:1.5rem;padding:1.25rem;margin-bottom:1.5rem}.task-list .task-list-header .task-stats{width:100%;flex-direction:column;align-items:flex-start;gap:1rem}.task-list .task-list-header .task-stats h3{font-size:1.75rem}.task-list .task-list-header .task-stats .task-count{align-self:flex-start}.task-list .task-list-header .task-stats .progress-container .progress-bar{height:10px}.task-list .task-list-header .task-stats .progress-container .progress-percentage{font-size:.8125rem;min-width:2.5rem}.task-list .task-list-header .task-header-controls{width:100%;flex-direction:column;gap:1rem}.task-list .task-list-header .task-header-controls .filter-controls{width:100%;flex-direction:column;gap:.75rem}.task-list .task-list-header .task-header-controls .filter-controls .search-bar{max-width:none}.task-list .task-list-header .task-header-controls .filter-controls .task-filter-select{min-width:100%;font-size:.8125rem;padding:.5rem .625rem}.task-list .task-list-header .task-header-controls .sort-controls{width:100%;justify-content:space-between;gap:.5rem}.task-list .task-list-header .task-header-controls .sort-controls .task-sort-select{min-width:110px;font-size:.8125rem;padding:.5rem .625rem}.task-list .task-list-header .task-header-controls .sort-controls .task-sort-order-btn{padding:.5rem}.task-list .task-item{padding:1.125rem;gap:.875rem;border-radius:12px}.task-list .task-item .task-content .task-title{font-size:1rem;font-weight:500}.task-list .task-item .task-content .task-meta{font-size:.8125rem;gap:.75rem}.task-list .task-item .task-content .task-meta .priority-badge{padding:.25rem .5rem;font-size:.6875rem}.task-list .task-item .task-content .task-meta .priority-badge .priority-label{display:none}.task-list .task-item .task-actions{opacity:1;transform:translate(0)}.task-list .task-item .btn-icon{padding:.5rem}.task-list .tasks-section.completed-section{padding-top:1.5rem;margin-top:1rem}.task-list .empty-state{padding:4rem 2rem}.task-list .empty-state .empty-state-icon svg{width:64px;height:64px}.task-list .empty-state h3{font-size:1.25rem}.task-list .empty-state p{font-size:1rem}}@media(max-width:480px){.task-list .task-list-header{padding:.875rem}.task-list .task-list-header .task-stats{flex-direction:column;align-items:flex-start;gap:.5rem}.task-list .task-list-header .task-stats h3{font-size:1.25rem}.task-list .task-list-header .task-header-controls{gap:.75rem}.task-list .task-list-header .task-header-controls .filter-controls{gap:.5rem}.task-list .task-list-header .task-header-controls .filter-controls .search-bar{font-size:.8125rem}.task-list .task-list-header .task-header-controls .filter-controls .task-filter-select{font-size:.8125rem;padding:.5rem .625rem}.task-list .task-list-header .task-header-controls .sort-controls{gap:.375rem}.task-list .task-list-header .task-header-controls .sort-controls .task-sort-select{min-width:100px;font-size:.8125rem;padding:.5rem .625rem}.task-list .task-list-header .task-header-controls .sort-controls .task-sort-order-btn{padding:.5rem}.task-list .task-item{padding:.875rem}.task-list .task-item .task-content .task-meta{flex-wrap:wrap;gap:.5rem}.task-list .task-item .task-checkbox input[type=checkbox]{width:20px;height:20px}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;max-width:400px;pointer-events:none}@media(max-width:768px){.toast-container{left:1rem;right:1rem;max-width:none}}.toast{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#fff;border-radius:.375rem;box-shadow:0 4px 12px #00000026;pointer-events:auto;animation:slideIn .3s ease-out;border-left:4px solid}.toast.toast-success{border-left-color:#10b981}.toast.toast-success .toast-icon{color:#10b981}.toast.toast-error{border-left-color:#ef4444}.toast.toast-error .toast-icon{color:#ef4444}.toast.toast-warning{border-left-color:#f59e0b}.toast.toast-warning .toast-icon{color:#f59e0b}.toast.toast-info{border-left-color:#06b6d4}.toast.toast-info .toast-icon{color:#06b6d4}.toast-icon{flex-shrink:0;margin-top:.125rem}.toast-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.toast-message{margin:0;font-size:.875rem;line-height:1.5;color:#1e293b}.toast-action{align-self:flex-start;padding:.25rem .75rem;background:transparent;border:1px solid #3b82f6;border-radius:.25rem;color:#3b82f6;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.toast-action:hover{background:#3b82f6;color:#fff}.toast-close{flex-shrink:0;padding:.25rem;background:transparent;border:none;color:#64748b;cursor:pointer;transition:color .2s}.toast-close:hover{color:#1e293b}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.loader-spinner{display:inline-block}.loader-spinner.loader-sm{width:1rem;height:1rem}.loader-spinner.loader-md{width:2rem;height:2rem}.loader-spinner.loader-lg{width:3rem;height:3rem}.loader-spinner .spinner{animation:rotate 2s linear infinite;width:100%;height:100%}.loader-spinner .spinner .path{stroke:#3b82f6;stroke-linecap:round;animation:dash 1.5s ease-in-out infinite}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.loader-dots{display:inline-flex;align-items:center;gap:.25rem}.loader-dots .dot{width:.5rem;height:.5rem;background:#3b82f6;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.loader-dots .dot:nth-child(1){animation-delay:-.32s}.loader-dots .dot:nth-child(2){animation-delay:-.16s}.loader-dots.loader-sm .dot{width:.375rem;height:.375rem}.loader-dots.loader-lg .dot{width:.75rem;height:.75rem}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.loader-pulse{background:#3b82f6;border-radius:50%;animation:pulse 1.2s ease-in-out infinite}.loader-pulse.loader-sm{width:1rem;height:1rem}.loader-pulse.loader-md{width:2rem;height:2rem}.loader-pulse.loader-lg{width:3rem;height:3rem}@keyframes pulse{0%,to{opacity:1;transform:scale(.8)}50%{opacity:.5;transform:scale(1.2)}}.button-loader{margin-right:.5rem}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;border-radius:.25rem}.skeleton.skeleton-pulse{animation:pulse-skeleton 1.5s ease-in-out infinite}.skeleton.skeleton-wave{animation:wave 1.5s linear infinite}.skeleton.skeleton-text{height:1em;margin-bottom:.5rem;transform-origin:0 60%;transform:scaleY(.6)}.skeleton.skeleton-circular{border-radius:50%}.skeleton.skeleton-rectangular{border-radius:.375rem}@keyframes pulse-skeleton{0%,to{opacity:1}50%{opacity:.4}}@keyframes wave{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-card{padding:1rem;background:#fff;border-radius:.375rem;box-shadow:0 1px 3px #0000001a}.skeleton-card .skeleton-image{margin-bottom:1rem}.skeleton-card .skeleton-content{display:flex;flex-direction:column;gap:.5rem}.skeleton-project-card{animation:pulse-skeleton 1.5s ease-in-out infinite}.skeleton-table{display:flex;flex-direction:column;gap:.75rem}.skeleton-table-row{display:flex;gap:1rem;padding:1rem;background:#fff;border-radius:.375rem}.skeleton-list{display:flex;flex-direction:column;gap:.75rem}.skeleton-list-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:.375rem}.skeleton-list-item .skeleton-list-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.confirm-modal{max-width:500px;text-align:center;padding:2rem}.confirm-modal.confirm-modal-danger .confirm-modal-icon{color:#ef4444}.confirm-modal.confirm-modal-warning .confirm-modal-icon{color:#f59e0b}.confirm-modal.confirm-modal-info .confirm-modal-icon{color:#06b6d4}.confirm-modal-icon{display:flex;justify-content:center;margin-bottom:1.5rem}.confirm-modal-title{margin:0 0 1rem;font-size:2rem;font-weight:600;color:#1e293b}.confirm-modal-message{margin:0 0 2rem;color:#64748b;line-height:1.6}.confirm-modal-actions{display:flex;gap:1rem;justify-content:center}.confirm-modal-actions .btn{min-width:120px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;gap:1rem}.loading-container .spinner{width:3rem;height:3rem}.loading-container p{color:#64748b;margin:0}.loading-spinner{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-bar{position:relative;display:flex;align-items:center;width:100%;max-width:400px}.search-bar .search-icon{position:absolute;left:1rem;color:#64748b;pointer-events:none}.search-bar .search-input{width:100%;padding:.75rem 2.5rem .75rem 3rem;border:1px solid #e2e8f0;border-radius:.375rem;font-size:1rem;transition:all .2s ease}.search-bar .search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-bar .search-input::placeholder{color:#64748b}.search-bar .search-clear{position:absolute;right:.75rem;padding:.25rem;background:transparent;border:none;color:#64748b;cursor:pointer;border-radius:.25rem;transition:all .2s ease}.search-bar .search-clear:hover{background:#0000000d;color:#1e293b}.search-bar .search-clear:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}@media(max-width:768px){.search-bar{max-width:none}}.drag-drop-upload{width:100%}.drag-drop-upload .drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;border:2px dashed #e2e8f0;border-radius:.375rem;background:#f8fafc;cursor:pointer;transition:all .3s ease}.drag-drop-upload .drop-zone:hover,.drag-drop-upload .drop-zone:focus{border-color:#3b82f6;background:#fff;transform:scale(1.01)}.drag-drop-upload .drop-zone:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.drag-drop-upload .drop-zone.dragging{border-color:#3b82f6;background:#fefeff;border-style:solid;box-shadow:0 0 20px #3b82f633;transform:scale(1.02)}.drag-drop-upload .drop-zone .upload-icon{color:#64748b;margin-bottom:1rem;transition:all .3s ease}.drag-drop-upload .drop-zone:hover .upload-icon,.drag-drop-upload .drop-zone.dragging .upload-icon{color:#3b82f6;transform:scale(1.1)}.drag-drop-upload .drop-zone .drop-zone-text{margin:0 0 .5rem;font-size:1rem;color:#1e293b}.drag-drop-upload .drop-zone .drop-zone-text strong{color:#3b82f6}.drag-drop-upload .drop-zone .drop-zone-hint{margin:0;font-size:.875rem;color:#64748b}.drag-drop-upload .file-input-hidden{display:none}.drag-drop-upload .upload-error{margin-top:.75rem;padding:.75rem;background:#fff;border:1px solid #ef4444;border-radius:.25rem;color:#ef4444;font-size:.875rem}.drag-drop-upload .page-loader{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#fffffff2;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.drag-drop-upload .page-loader__content{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.drag-drop-upload .page-loader__spinner{width:4rem;height:4rem}.drag-drop-upload .page-loader__spinner .spinner{animation:rotate 2s linear infinite;width:100%;height:100%}.drag-drop-upload .page-loader__spinner .spinner .path{stroke:#3b82f6;stroke-linecap:round;animation:dash 1.5s ease-in-out infinite}.drag-drop-upload .page-loader__text{margin:0;font-size:1.25rem;font-weight:500;color:#64748b;animation:pulse-text 1.5s ease-in-out infinite}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.5}}.trades-list{padding:2rem}.trades-list .trades-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.trades-list .trades-header h2{font-size:1.75rem;font-weight:600;color:#1e293b}.trades-list .trades-header .btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease}.trades-list .trades-header .btn:hover{background:#0b63f3;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.trades-list .loading,.trades-list .error{text-align:center;padding:3rem;color:#64748b}.trades-list .error{color:#ef4444}.trades-list .empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;border:2px dashed #e2e8f0}.trades-list .empty-state p{color:#64748b;margin-bottom:1.5rem;font-size:1.125rem}.trades-list .empty-state .btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease}.trades-list .empty-state .btn:hover{background:#0b63f3;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.trades-list .trades-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.trades-list .trade-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0;transition:all .2s ease}.trades-list .trade-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.trades-list .trade-card .trade-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.trades-list .trade-card .trade-header h3{font-size:1.125rem;font-weight:600;color:#1e293b;margin-bottom:.5rem}.trades-list .trade-card .trade-header .trade-type{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize;background:#fff;color:#3b82f6}.trades-list .trade-card .trade-header .trade-type.trade-type-electrician{background:#fef3c7;color:#f59e0b}.trades-list .trade-card .trade-header .trade-type.trade-type-plumber{background:#dbeafe;color:#3b82f6}.trades-list .trade-card .trade-header .trade-type.trade-type-carpenter{background:#fce7f3;color:#ec4899}.trades-list .trade-card .trade-header .trade-type.trade-type-hvac{background:#e0e7ff;color:#6366f1}.trades-list .trade-card .trade-header .trade-type.trade-type-painter{background:#f3e8ff;color:#a855f7}.trades-list .trade-card .trade-header .trade-type.trade-type-roofer{background:#fee2e2;color:#ef4444}.trades-list .trade-card .trade-header .trade-actions{display:flex;gap:.5rem}.trades-list .trade-card .trade-header .trade-actions .btn-icon{background:transparent;border:none;padding:.5rem;cursor:pointer;color:#64748b;border-radius:6px;transition:all .2s ease}.trades-list .trade-card .trade-header .trade-actions .btn-icon:hover{background:#f8fafc;color:#ef4444}.trades-list .trade-card .trade-details{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.trades-list .trade-card .trade-details .detail-row{display:flex;align-items:center;gap:.75rem;color:#64748b;font-size:.875rem}.trades-list .trade-card .trade-details .detail-row svg{flex-shrink:0;color:#94a3b8}.trades-list .trade-card .trade-details .detail-row a{color:#3b82f6;text-decoration:none}.trades-list .trade-card .trade-details .detail-row a:hover{text-decoration:underline}.trades-list .trade-card .trade-pricing{background:#f8fafc;padding:1rem;border-radius:8px;margin-bottom:1rem}.trades-list .trade-card .trade-pricing .pricing-info{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.trades-list .trade-card .trade-pricing .pricing-info:not(:last-child){border-bottom:1px solid #e2e8f0}.trades-list .trade-card .trade-pricing .pricing-info .label{font-size:.875rem;color:#64748b}.trades-list .trade-card .trade-pricing .pricing-info .value{font-weight:600;color:#1e293b}.trades-list .trade-card .trade-notes{padding:.75rem;background:#f8fafc;border-radius:6px;border-left:3px solid #3b82f6}.trades-list .trade-card .trade-notes p{font-size:.875rem;color:#64748b;margin:0;line-height:1.5}.trade-manager .trade-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.trade-manager .trade-header h2{margin:0;color:#3b82f6}.trade-manager .current-assignments{margin-bottom:3rem}.trade-manager .current-assignments h3{margin:0 0 1.5rem;color:#3b82f6}.trade-manager .current-assignments .loading{text-align:center;padding:2rem;color:#64748b}.trade-manager .current-assignments .empty-state{text-align:center;padding:3rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.trade-manager .current-assignments .empty-state p{color:#64748b;margin-bottom:2rem}.trade-manager .assignments-grid,.trade-manager .trades-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.trade-manager .assignment-card,.trade-manager .trade-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;transition:transform .2s,box-shadow .2s}.trade-manager .assignment-card:hover,.trade-manager .trade-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.trade-manager .assignment-header,.trade-manager .trade-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.trade-manager .assignment-header .trade-info,.trade-manager .trade-header .trade-info{display:flex;align-items:flex-start;gap:.75rem;flex:1}.trade-manager .assignment-header .trade-info .trade-color-indicator,.trade-manager .trade-header .trade-info .trade-color-indicator{width:16px;height:16px;border-radius:50%;flex-shrink:0;margin-top:.25rem}.trade-manager .assignment-header .trade-info h4,.trade-manager .trade-header .trade-info h4{margin:0 0 .25rem;color:#3b82f6;font-size:1.1rem}.trade-manager .assignment-header .trade-info .trade-type,.trade-manager .trade-header .trade-info .trade-type{font-size:.9rem;color:#64748b;text-transform:capitalize;margin:0}.trade-manager .assignment-header .trade-info .trade-company,.trade-manager .trade-header .trade-info .trade-company{font-size:.8rem;color:#64748b;margin:0}.trade-manager .assignment-details,.trade-manager .trade-details{margin-bottom:1rem}.trade-manager .assignment-details .detail-item,.trade-manager .trade-details .detail-item{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9rem}.trade-manager .assignment-details .detail-item .label,.trade-manager .trade-details .detail-item .label{color:#64748b;font-weight:500}.trade-manager .assignment-details .detail-item .value,.trade-manager .trade-details .detail-item .value{color:#1e293b;font-weight:500}.trade-manager .assignment-details .trade-stats,.trade-manager .trade-details .trade-stats{display:flex;gap:1rem;margin-bottom:.5rem;font-size:.9rem;color:#64748b}.trade-manager .assignment-details .trade-rate,.trade-manager .trade-details .trade-rate{font-size:1rem;font-weight:600;color:#3b82f6;margin:.5rem 0}.trade-manager .assignment-details .trade-skills,.trade-manager .trade-details .trade-skills{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.5rem}.trade-manager .assignment-details .trade-skills .skill-tag,.trade-manager .trade-details .trade-skills .skill-tag{background:#f3f4f6;color:#64748b;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.trade-manager .assignment-actions,.trade-manager .trade-actions{display:flex;gap:.5rem;justify-content:flex-end}.trade-manager .available-trades h3{margin:0 0 1.5rem;color:#3b82f6}.trade-manager .assign-trade-form{max-width:600px}.trade-manager .assign-trade-form h3{margin:0 0 2rem;color:#3b82f6}.trade-manager .assign-trade-form .form-group{margin-bottom:1.5rem}.trade-manager .assign-trade-form .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#1e293b}.trade-manager .assign-trade-form .form-group input,.trade-manager .assign-trade-form .form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s}.trade-manager .assign-trade-form .form-group input:focus,.trade-manager .assign-trade-form .form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.trade-manager .assign-trade-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.trade-manager .assign-trade-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.trade-manager .assign-trade-form .form-actions button{padding:.75rem 1.5rem;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.trade-manager .assign-trade-form .form-actions button[type=button]{background:#f3f4f6;color:#1e293b}.trade-manager .assign-trade-form .form-actions button[type=button]:hover{background:#e5e7eb}.trade-manager .assign-trade-form .form-actions button.btn-primary{background:#3b82f6;color:#fff}.trade-manager .assign-trade-form .form-actions button.btn-primary:hover{background:#0b63f3}.add-trade-form,.assign-trade-form{padding:2rem;background:#fff;border-radius:8px;max-width:600px;margin:0 auto}.add-trade-form h2,.assign-trade-form h2{margin-bottom:1.5rem;color:#1e293b;font-size:1.5rem;font-weight:600}.add-trade-form form,.assign-trade-form form{display:flex;flex-direction:column;gap:1.25rem}.add-trade-form .form-group,.assign-trade-form .form-group{display:flex;flex-direction:column;gap:.5rem}.add-trade-form .form-group label,.assign-trade-form .form-group label{font-weight:500;color:#1e293b;font-size:.875rem}.add-trade-form .form-group label .required,.assign-trade-form .form-group label .required{color:#ef4444;margin-left:.25rem}.add-trade-form .form-group input,.assign-trade-form .form-group input,.add-trade-form .form-group select,.assign-trade-form .form-group select,.add-trade-form .form-group textarea,.assign-trade-form .form-group textarea{padding:.75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;background:#f8fafc;color:#1e293b;transition:all .2s ease}.add-trade-form .form-group input:focus,.assign-trade-form .form-group input:focus,.add-trade-form .form-group select:focus,.assign-trade-form .form-group select:focus,.add-trade-form .form-group textarea:focus,.assign-trade-form .form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.add-trade-form .form-group input::placeholder,.assign-trade-form .form-group input::placeholder,.add-trade-form .form-group select::placeholder,.assign-trade-form .form-group select::placeholder,.add-trade-form .form-group textarea::placeholder,.assign-trade-form .form-group textarea::placeholder{color:#94a3b8}.add-trade-form .form-group input:disabled,.assign-trade-form .form-group input:disabled,.add-trade-form .form-group select:disabled,.assign-trade-form .form-group select:disabled,.add-trade-form .form-group textarea:disabled,.assign-trade-form .form-group textarea:disabled{background:#fff;cursor:not-allowed;opacity:.6}.add-trade-form .form-group textarea,.assign-trade-form .form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.add-trade-form .form-group select,.assign-trade-form .form-group select{cursor:pointer}.add-trade-form .pricing-type-selector,.assign-trade-form .pricing-type-selector{display:flex;gap:1rem;padding:.5rem 0}.add-trade-form .pricing-type-selector .pricing-option,.assign-trade-form .pricing-type-selector .pricing-option{flex:1;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:6px;background:#f8fafc;color:#1e293b;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.add-trade-form .pricing-type-selector .pricing-option:hover,.assign-trade-form .pricing-type-selector .pricing-option:hover{background:#fff;border-color:#3b82f6}.add-trade-form .pricing-type-selector .pricing-option.active,.assign-trade-form .pricing-type-selector .pricing-option.active{background:#fff;border-color:#3b82f6;color:#3b82f6;font-weight:600}.add-trade-form .pricing-type-selector .radio-option,.assign-trade-form .pricing-type-selector .radio-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:6px;transition:all .2s ease}.add-trade-form .pricing-type-selector .radio-option:hover,.assign-trade-form .pricing-type-selector .radio-option:hover{background:#fff}.add-trade-form .pricing-type-selector .radio-option input[type=radio],.assign-trade-form .pricing-type-selector .radio-option input[type=radio]{width:auto;margin:0;cursor:pointer}.add-trade-form .pricing-type-selector .radio-option span,.assign-trade-form .pricing-type-selector .radio-option span{font-size:.875rem;color:#1e293b}.add-trade-form .pricing-type-selector .radio-option:has(input:checked),.assign-trade-form .pricing-type-selector .radio-option:has(input:checked){background:#fff;border-color:#3b82f6}.add-trade-form .pricing-type-selector .radio-option:has(input:checked) span,.assign-trade-form .pricing-type-selector .radio-option:has(input:checked) span{color:#3b82f6;font-weight:500}.add-trade-form .form-actions,.assign-trade-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.add-trade-form .form-actions .btn,.assign-trade-form .form-actions .btn{padding:.75rem 1.5rem;border-radius:6px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease;border:none}.add-trade-form .form-actions .btn:disabled,.assign-trade-form .form-actions .btn:disabled{opacity:.6;cursor:not-allowed}.add-trade-form .form-actions .btn.btn-primary,.assign-trade-form .form-actions .btn.btn-primary{background:#3b82f6;color:#fff}.add-trade-form .form-actions .btn.btn-primary:hover:not(:disabled),.assign-trade-form .form-actions .btn.btn-primary:hover:not(:disabled){background:#0b63f3;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.add-trade-form .form-actions .btn.btn-secondary,.assign-trade-form .form-actions .btn.btn-secondary{background:#fff;color:#1e293b;border:1px solid #e2e8f0}.add-trade-form .form-actions .btn.btn-secondary:hover:not(:disabled),.assign-trade-form .form-actions .btn.btn-secondary:hover:not(:disabled){background:#f8fafc}.add-trade-form .error-message,.assign-trade-form .error-message{padding:.75rem;background:#fff;color:#ef4444;border-radius:6px;font-size:.875rem;margin-top:1rem}.add-trade-form .existing-trades-list .loading-message,.assign-trade-form .existing-trades-list .loading-message{text-align:center;padding:2rem;color:#64748b}.add-trade-form .existing-trades-list .empty-state,.assign-trade-form .existing-trades-list .empty-state{text-align:center;padding:2rem;background:#fff;border-radius:8px;border:2px dashed #e2e8f0}.add-trade-form .existing-trades-list .empty-state p,.assign-trade-form .existing-trades-list .empty-state p{color:#64748b;margin-bottom:1rem}.add-trade-form .existing-trades-list .empty-state .btn-link,.assign-trade-form .existing-trades-list .empty-state .btn-link{background:transparent;border:none;color:#3b82f6;cursor:pointer;text-decoration:underline;font-size:.875rem}.add-trade-form .existing-trades-list .empty-state .btn-link:hover,.assign-trade-form .existing-trades-list .empty-state .btn-link:hover{color:#0b63f3}.add-trade-form .existing-trades-list .trades-grid,.assign-trade-form .existing-trades-list .trades-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-bottom:1.5rem;max-height:400px;overflow-y:auto;padding:.5rem}.add-trade-form .existing-trades-list .trades-grid .trade-card,.assign-trade-form .existing-trades-list .trades-grid .trade-card{background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s ease}.add-trade-form .existing-trades-list .trades-grid .trade-card:hover,.assign-trade-form .existing-trades-list .trades-grid .trade-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633;transform:translateY(-2px)}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:.5rem}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header h4,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header h4{font-size:1rem;font-weight:600;color:#1e293b;margin:0;flex:1}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge{padding:.25rem .5rem;border-radius:12px;font-size:.7rem;font-weight:500;text-transform:capitalize;white-space:nowrap}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-electrician,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-electrician{background:#fef3c7;color:#f59e0b}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-plumber,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-plumber{background:#dbeafe;color:#3b82f6}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-carpenter,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-carpenter{background:#fce7f3;color:#ec4899}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-hvac,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-hvac{background:#e0e7ff;color:#6366f1}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-painter,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-painter{background:#f3e8ff;color:#a855f7}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-roofer,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-roofer{background:#fee2e2;color:#ef4444}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-bricklayer,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-bricklayer{background:#fef3c7;color:#d97706}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-plasterer,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-plasterer{background:#e0f2fe;color:#0284c7}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-tiler,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-tiler{background:#fce7f3;color:#db2777}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-flooring,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-flooring{background:#fef3c7;color:#ca8a04}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-glazier,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-glazier{background:#dbeafe;color:#2563eb}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-landscaper,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-landscaper{background:#d1fae5;color:#059669}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-general,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-header .badge.trade-type-general{background:#f3f4f6;color:#6b7280}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-details,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-details{display:flex;flex-direction:column;gap:.375rem}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-details p,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-details p{margin:0;font-size:.8rem;color:#64748b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-details p.contact-name,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-details p.contact-name{font-weight:500;color:#1e293b}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-details p.contact-phone,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-details p.contact-phone{color:#64748b}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-details p.contact-email,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-details p.contact-email{color:#94a3b8}.add-trade-form .existing-trades-list .trades-grid .trade-card .trade-details p.pricing,.assign-trade-form .existing-trades-list .trades-grid .trade-card .trade-details p.pricing{font-weight:600;color:#3b82f6;margin-top:.25rem}.add-trade-form .form-subtitle,.assign-trade-form .form-subtitle{color:#64748b;font-size:.875rem;margin-bottom:1.5rem}.assign-trade-form.loading,.assign-trade-form.empty{text-align:center;padding:3rem;color:#64748b}.assign-trade-form.loading .btn,.assign-trade-form.empty .btn{margin-top:1rem}.assign-trade-form .trade-info{padding:1rem;background:#fff;border-radius:8px;border-left:4px solid #3b82f6}.assign-trade-form .trade-info h4{margin:0 0 .5rem;color:#1e293b;font-size:1rem}.assign-trade-form .trade-info p{margin:.25rem 0;font-size:.875rem;color:#64748b}.assign-trade-form .trade-info p.trade-type{text-transform:capitalize;font-weight:500;color:#3b82f6}.assign-trade-form .info-display,.assign-trade-form .cost-display{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0}.assign-trade-form .info-display .label,.assign-trade-form .cost-display .label{font-size:.875rem;color:#64748b;font-weight:500}.assign-trade-form .info-display .value,.assign-trade-form .cost-display .value{font-size:1rem;color:#1e293b;font-weight:600}.assign-trade-form .cost-display{background:#b6f9e3;border-color:#10b981}.assign-trade-form .cost-display .value{color:#10b981;font-size:1.25rem}.trade-assignments-list .assignments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.trade-assignments-list .assignments-header h3{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0}.trade-assignments-list .assignments-header .btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease}.trade-assignments-list .assignments-header .btn:hover{background:#0b63f3;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.trade-assignments-list .loading,.trade-assignments-list .error{text-align:center;padding:2rem;color:#64748b}.trade-assignments-list .error{color:#ef4444}.trade-assignments-list .empty-state{text-align:center;padding:3rem 2rem;background:#fff;border-radius:12px;border:2px dashed #e2e8f0}.trade-assignments-list .empty-state svg{color:#94a3b8;margin-bottom:1rem}.trade-assignments-list .empty-state p{color:#64748b;margin-bottom:1.5rem;font-size:1rem}.trade-assignments-list .empty-state .btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease}.trade-assignments-list .empty-state .btn:hover{background:#0b63f3;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.trade-assignments-list .assignments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.trade-assignments-list .assignment-card{background:#fff;border-radius:12px;padding:1.25rem;border:1px solid #e2e8f0;transition:all .2s ease;position:relative}.trade-assignments-list .assignment-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.trade-assignments-list .assignment-card .assignment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.trade-assignments-list .assignment-card .assignment-header .trade-info{flex:1}.trade-assignments-list .assignment-card .assignment-header .trade-info h4{font-size:1rem;font-weight:600;color:#1e293b;margin:0 0 .5rem}.trade-assignments-list .assignment-card .assignment-header .trade-info .trade-type{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize;background:#fff;color:#3b82f6}.trade-assignments-list .assignment-card .assignment-header .trade-info .trade-type.trade-type-electrician{background:#fef3c7;color:#f59e0b}.trade-assignments-list .assignment-card .assignment-header .trade-info .trade-type.trade-type-plumber{background:#dbeafe;color:#3b82f6}.trade-assignments-list .assignment-card .assignment-header .trade-info .trade-type.trade-type-carpenter{background:#fce7f3;color:#ec4899}.trade-assignments-list .assignment-card .assignment-header .trade-info .trade-type.trade-type-hvac{background:#e0e7ff;color:#6366f1}.trade-assignments-list .assignment-card .assignment-header .btn-delete{background:transparent;border:none;padding:.5rem;cursor:pointer;color:#94a3b8;border-radius:6px;transition:all .2s ease}.trade-assignments-list .assignment-card .assignment-header .btn-delete:hover{background:#fff;color:#ef4444}.trade-assignments-list .assignment-card .assignment-details{display:flex;flex-direction:column;gap:.75rem}.trade-assignments-list .assignment-card .assignment-details .detail-row{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#64748b}.trade-assignments-list .assignment-card .assignment-details .detail-row svg{flex-shrink:0;color:#94a3b8}.trade-assignments-list .assignment-card .assignment-details .detail-row .label{color:#94a3b8}.trade-assignments-list .assignment-card .assignment-details .detail-row .value{font-weight:500;color:#1e293b}.trade-assignments-list .assignment-card .assignment-details .detail-row.pricing{padding:.5rem;background:#f8fafc;border-radius:6px;justify-content:space-between}.trade-assignments-list .assignment-card .assignment-details .cost-total{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:#b6f9e3;border-radius:8px;margin-top:.5rem}.trade-assignments-list .assignment-card .assignment-details .cost-total svg{color:#10b981}.trade-assignments-list .assignment-card .assignment-details .cost-total .label{font-size:.875rem;color:#10b981;font-weight:500}.trade-assignments-list .assignment-card .assignment-details .cost-total .value{font-size:1.125rem;font-weight:700;color:#10b981}.trade-assignments-list .assignment-card .assignment-details .assignment-notes{padding:.75rem;background:#f8fafc;border-radius:6px;border-left:3px solid #3b82f6;margin-top:.5rem}.trade-assignments-list .assignment-card .assignment-details .assignment-notes p{font-size:.875rem;color:#64748b;margin:0;line-height:1.5}.trade-assignments-list .assignment-card .assignment-details .status-badge{display:inline-block;padding:.375rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize;align-self:flex-start;margin-top:.5rem}.trade-assignments-list .assignment-card .assignment-details .status-badge.status-scheduled{background:#dbeafe;color:#3b82f6}.trade-assignments-list .assignment-card .assignment-details .status-badge.status-in_progress,.trade-assignments-list .assignment-card .assignment-details .status-badge.status-in-progress{background:#fef3c7;color:#f59e0b}.trade-assignments-list .assignment-card .assignment-details .status-badge.status-completed{background:#d1fae5;color:#10b981}.trade-assignments-list .assignment-card .assignment-details .status-badge.status-cancelled{background:#fee2e2;color:#ef4444}.badge.bg-green-100{background-color:#dcfce7}.badge.text-green-800{color:#166534}.badge.bg-blue-100{background-color:#dbeafe}.badge.text-blue-800{color:#1e40af}.badge.bg-orange-100{background-color:#fed7aa}.badge.text-orange-800{color:#9a3412}.badge.bg-gray-100{background-color:#f3f4f6}.badge.text-gray-800{color:#1f2937}.badge.bg-red-100{background-color:#fee2e2}.badge.text-red-800{color:#991b1b}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.modal-content{position:relative;background:#f8fafc;border-radius:12px;max-width:650px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}.modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;cursor:pointer;color:#64748b;padding:.5rem;border-radius:6px;transition:all .2s ease;z-index:10}.modal-close:hover{background:#fff;color:#1e293b}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.trades-list{padding:1rem}.trades-list .trades-header{flex-direction:column;align-items:flex-start;gap:1rem}.trades-list .trades-header .btn{width:100%;justify-content:center}.trades-list .trades-grid{grid-template-columns:1fr}.add-trade-form,.assign-trade-form{padding:1.5rem}.add-trade-form h2,.assign-trade-form h2{font-size:1.25rem}.add-trade-form .pricing-type-selector,.assign-trade-form .pricing-type-selector{flex-direction:column;gap:.5rem}.add-trade-form .form-actions,.assign-trade-form .form-actions{flex-direction:column-reverse}.add-trade-form .form-actions .btn,.assign-trade-form .form-actions .btn{width:100%}.trade-assignments-list .assignments-header{flex-direction:column;align-items:flex-start;gap:1rem}.trade-assignments-list .assignments-header .btn{width:100%;justify-content:center}.trade-assignments-list .assignments-grid{grid-template-columns:1fr}.trade-assignments-list .assignment-card .assignment-details .breakdown-item{flex-direction:column;align-items:flex-start;gap:.75rem}.trade-assignments-list .assignment-card .assignment-details .breakdown-item .trade-stats{width:100%;flex-direction:row;justify-content:space-between;align-items:center}.modal-overlay{padding:0}.modal-content{max-height:100vh;border-radius:0}}.header{background-color:#fff;color:#1e293b;padding:.75rem 0;border-bottom:1px solid #e2e8f0;box-shadow:none}.header .navbar{display:flex;justify-content:space-between;align-items:center}.header .navbar-brand{font-size:2rem;font-weight:700;color:#1e293b;text-decoration:none}.header .navbar-brand:hover{color:#3b82f6;text-decoration:none}.header .navbar-nav{display:flex;gap:1.5rem;align-items:center}.header .nav-link{color:#1e293b;text-decoration:none;padding:.5rem 0;transition:all .2s ease-in-out;display:inline-flex;align-items:center;gap:.5rem}.header .nav-link:hover{color:#3b82f6;text-decoration:none}.header .nav-link.nav-link-primary{background-color:#3b82f6;color:#fff;padding:.5rem 1rem;border-radius:.375rem;font-weight:500}.header .nav-link.nav-link-primary:hover{background-color:#196cf4;color:#fff}.header .nav-user{display:flex;align-items:center;gap:1rem;margin-left:1rem;padding-left:1rem;border-left:1px solid #e2e8f0}.header .nav-username{color:#64748b;font-size:.875rem}.header .nav-logout-btn{background:none;border:1px solid #e2e8f0;color:#1e293b;padding:.25rem .75rem;border-radius:.375rem;font-size:.875rem;cursor:pointer;transition:all .2s ease-in-out}.header .nav-logout-btn:hover:not(:disabled){background-color:#f8fafc;border-color:#3b82f6;color:#3b82f6}.header .nav-logout-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.header .navbar{flex-direction:column;gap:1rem;align-items:flex-start}.header .navbar-brand{font-size:1.25rem}.header .navbar-nav{width:100%;flex-direction:column;gap:.75rem;align-items:flex-start}.header .nav-user{width:100%;margin-left:0;padding-left:0;border-left:none;border-top:1px solid rgb(156.5219512195,192.1951219512,250.4780487805);padding-top:.75rem;justify-content:space-between}.header .nav-username{font-size:.75rem}}@media(min-width:769px)and (max-width:1024px){.header .navbar-nav{gap:1rem}.header .nav-username{display:none}}.footer{background-color:#1e293b;color:#f8fafc;padding:2rem 0;margin-top:auto}.sidebar{background-color:#f8fafc;border-right:1px solid #e9ecef;min-height:100vh}.form-group{margin-bottom:1rem}.form-control{display:block;width:100%;padding:.375rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;color:#1e293b;background-color:#fff;background-clip:padding-box;border:1px solid #ced4da;border-radius:.375rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.form-control:focus{color:#1e293b;background-color:#fff;border-color:#b5d0fc;outline:0;box-shadow:0 0 0 .2rem #3b82f640}.home{padding:2rem 0}.home .hero-section{text-align:center;padding:4rem 0;background:linear-gradient(135deg,#fff,#e6effe);border-radius:.5rem;margin-bottom:3rem}.home .hero-section .display-1{font-size:3rem;font-weight:700;color:#3b82f6;margin-bottom:1rem}.home .hero-section .lead{font-size:1.25rem;color:#64748b;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}.home .hero-section .hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.home .features-section{text-align:center;margin-bottom:2rem}.home .features-section h2{color:#3b82f6;font-size:2.5rem;margin-bottom:1rem}.home .feature-card{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;text-align:center;margin-bottom:2rem;transition:all .2s ease-in-out}.home .feature-card:hover{transform:translateY(-5px);box-shadow:0 4px 6px #00000012}.home .feature-card h3{color:#3b82f6;font-size:1.25rem;margin-bottom:1rem}.home .feature-card p{color:#64748b;line-height:1.5}.job-detail{--surface: #ffffff;--surface-muted: #f9fafb;--border: #e5e7eb;--text: #1f2937;--text-muted: #6b7280}.job-detail .container{max-width:1200px;margin:0 auto;padding:2rem}.job-detail .job-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.job-detail .job-header .job-header-content .breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-muted);margin-bottom:1rem}.job-detail .job-header .job-header-content .breadcrumb a{color:#3b82f6;text-decoration:none;font-weight:500}.job-detail .job-header .job-header-content .breadcrumb a:hover{text-decoration:underline}.job-detail .job-header .job-header-content .breadcrumb span{color:var(--text-muted)}.job-detail .job-header .job-header-content h1{font-size:1.75rem;font-weight:700;color:var(--text);margin-bottom:.25rem}.job-detail .job-header .job-header-content .job-address{font-size:.95rem;color:var(--text-muted)}.job-detail .job-header .job-actions{display:flex;gap:.75rem}.job-detail .job-header .job-actions .btn{border-radius:8px;font-weight:600;padding:.6rem 1.2rem;transition:background .2s,transform .2s}.job-detail .job-header .job-actions .btn.btn-secondary{background:var(--surface-muted);color:var(--text);border:1px solid var(--border)}.job-detail .job-header .job-actions .btn.btn-secondary:hover{background:#fff;color:#3b82f6}.job-detail .job-header .job-actions .btn.btn-primary{background:#3b82f6;color:#fff}.job-detail .job-header .job-actions .btn.btn-primary:hover{background:#1469f4;transform:translateY(-2px)}.job-detail .job-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin-bottom:2.5rem}.job-detail .job-stats-grid .stat-card{background:var(--surface);border-radius:1rem;box-shadow:0 2px 8px #0000000f;padding:1.25rem;text-align:center;position:relative;transition:transform .25s ease,box-shadow .25s ease}.job-detail .job-stats-grid .stat-card:hover{transform:translateY(-4px);box-shadow:0 6px 16px #00000014}.job-detail .job-stats-grid .stat-card h3{font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:.75rem}.job-detail .job-stats-grid .stat-card .stat-number{font-size:1.75rem;font-weight:700;color:#3b82f6}.job-detail .job-stats-grid .stat-card .progress-circle{width:80px;height:80px;margin:0 auto .5rem;border-radius:50%;background:conic-gradient(#3b82f6 var(--angle, 0deg),#f3f4f6 0deg);display:flex;align-items:center;justify-content:center}.job-detail .job-stats-grid .stat-card .progress-circle .progress-text{font-weight:700;color:#3b82f6;font-size:1.25rem}.job-detail .tab-navigation{display:flex;flex-wrap:wrap;border-bottom:1px solid var(--border);margin-bottom:2rem}.job-detail .tab-navigation .tab-button{position:relative;background:none;border:none;cursor:pointer;font-weight:600;color:var(--text-muted);padding:1rem 1.5rem;font-size:.95rem;transition:color .2s ease}.job-detail .tab-navigation .tab-button:hover,.job-detail .tab-navigation .tab-button.active{color:#3b82f6}.job-detail .tab-navigation .tab-button.active:after{content:"";position:absolute;left:0;bottom:-1px;width:100%;height:2px;background:#3b82f6;border-radius:2px;animation:tabSlide .3s ease}@keyframes tabSlide{0%{width:0;opacity:.5}to{width:100%;opacity:1}}.job-detail .tab-content{position:relative;min-height:400px;z-index:1}.job-detail .tab-content .tab-panel{opacity:0;transform:translateY(12px);pointer-events:none;position:absolute;inset:0;transition:opacity .35s ease,transform .35s ease}.job-detail .tab-content .tab-panel.active{opacity:1;transform:translateY(0);pointer-events:auto;position:relative}.job-detail .tab-content{transition:min-height .35s ease}.job-detail .overview-tab .overview-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem}@media(max-width:900px){.job-detail .overview-tab .overview-grid{grid-template-columns:1fr}}.job-detail .overview-tab .overview-grid .overview-section{background:var(--surface);border-radius:1rem;box-shadow:0 2px 8px #0000000f;padding:1.5rem}.job-detail .overview-tab .overview-grid .overview-section h3{color:#3b82f6;margin-bottom:1rem;font-size:1.1rem;font-weight:600}.job-detail .overview-tab .overview-grid .overview-section .info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}.job-detail .overview-tab .overview-grid .overview-section .info-grid .info-item label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:.25rem}.job-detail .overview-tab .overview-grid .overview-section .info-grid .info-item span{font-weight:600;color:var(--text)}.job-detail .overview-tab .overview-grid .overview-section .description label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem}.job-detail .overview-tab .overview-grid .overview-section .description p{color:var(--text);line-height:1.5}.job-detail .badge{display:inline-block;padding:.35rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.job-detail .badge.status-planning{background:#06b6d426;color:#058ba2}.job-detail .badge.status-active{background:#10b98126;color:#0a7350}.job-detail .badge.status-on_hold{background:#f59e0b26;color:#ac6f07}.job-detail .badge.status-completed{background:#64748b26;color:#444f5f}.job-detail .badge.status-cancelled{background:#ef444426;color:#eb1515}.job-detail .job-header .breadcrumb .skeleton{display:inline-block;margin:0 .25rem}.job-detail .job-stats-grid .stat-card .skeleton{margin:0 auto}.job-detail .tab-navigation .tab-skeleton{margin-right:.5rem;border-radius:4px}.job-detail .error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:.75rem;padding:2rem;text-align:center;margin-bottom:1.5rem}.job-detail .error-message h2{color:#ef4444;font-size:1.5rem;margin-bottom:.75rem}.job-detail .error-message p{color:var(--text-muted);font-size:1rem;line-height:1.6}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f8fafc}.login .login-form-container{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 4px 6px #00000012;width:100%;max-width:400px}.login .login-form-container h1{text-align:center;margin-bottom:1.5rem;color:#1e293b}.login .login-form-container .alert{margin-bottom:1rem;padding:.75rem;border-radius:.375rem}.login .login-form-container .alert.alert-danger{background-color:#fff;color:#ef4444;border:1px solid rgb(247.039408867,161.960591133,161.960591133)}.login .login-form-container .login-form .form-group{margin-bottom:1rem}.login .login-form-container .login-form .form-group label{display:block;margin-bottom:.5rem;font-weight:700;color:#1e293b}.login .login-form-container .login-form .form-group .form-control{width:100%;padding:.75rem;border:1px solid rgb(186.3723849372,194.2719665272,205.6276150628);border-radius:.375rem;font-size:1rem;transition:all .2s ease-in-out}.login .login-form-container .login-form .form-group .form-control:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f640}.login .login-form-container .login-form .btn{width:100%;padding:.75rem;font-size:1rem;font-weight:700;margin-top:.5rem}.login .login-form-container .dev-login-section{margin-top:1.5rem;text-align:center}.login .login-form-container .dev-login-section hr{margin:1rem 0;border:none;border-top:1px solid rgb(216.0334728033,220.5188284519,226.9665271967)}.login .login-form-container .dev-login-section .dev-login-text{font-size:.875rem;color:#64748b;margin-bottom:1rem;font-style:italic}.login .login-form-container .dev-login-section .btn{width:100%;padding:.75rem;font-size:1rem;font-weight:700}.dashboard{padding:2rem 0}.dashboard .dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem;flex-wrap:wrap;gap:1rem}.dashboard .dashboard-header .dashboard-title{font-size:2rem;font-weight:600;color:#1e293b}.dashboard .dashboard-header .dashboard-title span{color:#3b82f6}.dashboard .dashboard-header .dashboard-subtitle{color:#64748b;font-size:1rem;margin-top:.25rem}.dashboard .dashboard-header .btn-primary{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-weight:600;border-radius:.375rem;background-color:#3b82f6;color:#fff;transition:background .2s}.dashboard .dashboard-header .btn-primary:hover{background-color:#196cf4}.dashboard .dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:3rem}.dashboard .dashboard-stats .stat-card{background:#fff;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;border:1px solid #e2e8f0;display:flex;align-items:center;gap:1rem;transition:box-shadow .2s ease}.dashboard .dashboard-stats .stat-card:hover{box-shadow:0 1px 3px #0000001a}.dashboard .dashboard-stats .stat-card .stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%}.dashboard .dashboard-stats .stat-card .stat-icon.stat-icon-primary{background:#3b82f61f;color:#3b82f6}.dashboard .dashboard-stats .stat-card .stat-icon.stat-icon-success{background:#10b9811f;color:#10b981}.dashboard .dashboard-stats .stat-card .stat-icon.stat-icon-info{background:#06b6d41f;color:#06b6d4}.dashboard .dashboard-stats .stat-card .stat-icon.stat-icon-warning{background:#f59e0b1f;color:#f59e0b}.dashboard .dashboard-stats .stat-card .stat-value{font-size:1.75rem;font-weight:700;color:#1e293b}.dashboard .dashboard-stats .stat-card .stat-label{font-size:.9rem;color:#64748b}.dashboard .dashboard-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.75rem;flex-wrap:wrap;gap:1rem}.dashboard .dashboard-section .section-header h2{font-size:1.5rem;font-weight:600;color:#1e293b}.dashboard .projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.5rem}.dashboard .empty-state{text-align:center;background:#fff;padding:3rem 2rem;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;border:1px solid #e2e8f0}.dashboard .empty-state svg{color:#64748b;margin-bottom:1rem}.dashboard .empty-state h3{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:#1e293b}.dashboard .empty-state p{color:#64748b;margin-bottom:1rem}.dashboard .empty-state .btn{display:inline-flex;align-items:center;gap:.5rem}.dashboard .loading-container{text-align:center;padding:3rem}.dashboard .error-container{text-align:center;padding:2rem;background:#ef44441a;color:#ef4444;border-radius:.375rem}@media(max-width:768px){.dashboard-header{flex-direction:column;align-items:flex-start}}.trades-page{min-height:100vh;background:var(--color-background)}
