@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,400&family=Syne:wght@700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800;0,9..40,900;1,9..40,400&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;900&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,400;0,500;0,700;1,400&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700;9..40,800&display=swap";@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid}}}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.container{width:100%}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.h-full{height:100%}.h-screen{height:100vh}.w-full{width:100%}.flex-1{flex:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.items-center{align-items:center}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.border{border-style:var(--tw-border-style);border-width:1px}.text-left{text-align:left}.uppercase{text-transform:uppercase}.italic{font-style:italic}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}html,body{margin:0;padding:0;overflow-x:hidden;max-width:100vw;font-family:Arial,sans-serif;background-color:var(--bg-light)}:root{--primary-color: #e53958;--secondary-color: #ffc107;--sidebar-width: 250px;--bg-light: #f8fafc;--text-dark: #333}.app-container{display:flex;min-height:100vh;width:100%;overflow-x:hidden}.content-area{margin-left:var(--sidebar-width);width:calc(100% - var(--sidebar-width));min-height:100vh;transition:margin-left .3s ease-in-out,width .3s ease-in-out;background-color:var(--bg-light);box-sizing:border-box}.main-content-wrapper{padding:24px;width:100%;box-sizing:border-box}.header{padding-top:30px;margin-bottom:20px;border-bottom:1px solid #eee}.top-row{display:flex;justify-content:space-between;align-items:center;padding-right:40px;margin-bottom:20px}.welcome-message{font-size:1.8em;color:var(--text-dark);font-weight:400}.user-profile{display:flex;align-items:center}.notification-icon{font-size:1.5em;margin-right:20px;cursor:pointer}.profile-pic{width:40px;height:40px;border-radius:50%;object-fit:cover}.tabs-row{display:flex;gap:10px;padding-bottom:20px}.tab-button{padding:10px 20px;border:none;background-color:var(--secondary-color);color:var(--text-dark);font-weight:700;border-radius:8px;cursor:pointer;opacity:.8;transition:opacity .2s,transform .2s}.tab-button:hover{opacity:1}.tab-button.active-tab{background-color:var(--secondary-color);box-shadow:0 5px 10px #ffc10766;opacity:1}.inventory-section,.page-content-wrapper{padding-top:10px}.section-title{color:var(--primary-color);font-size:1.5em;margin-bottom:20px}.table-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.search-box{display:flex;align-items:center;padding:8px 15px;border:1px solid #ddd;border-radius:8px;width:300px}.search-box input{border:none;outline:none;margin-left:10px;width:100%}.action-buttons button{padding:10px 20px;margin-left:10px;border:none;border-radius:8px;cursor:pointer;font-weight:700}.add-button{background-color:#3f51b5;color:#fff}.filter-button{background-color:#f0f0f0;color:var(--text-dark);border:1px solid #ccc}.data-table table{width:100%;border-collapse:collapse}.data-table th,.data-table td{text-align:left;padding:15px;border-bottom:1px solid #eee}.data-table th{background-color:var(--bg-light);font-weight:700;color:#777}.data-table tr:hover{background-color:#fafafa}.data-table td:last-child{color:#888}.status-badge{display:inline-block;padding:5px 10px;border-radius:5px;color:#fff;font-size:.9em;font-weight:700}.in-stock{background-color:#8bc34a}.low-stock{background-color:#f44336}.edit-button{background-color:#9c27b0;color:#fff;padding:5px 15px;border:none;border-radius:5px;cursor:pointer}.sidebar{display:flex;flex-direction:column;justify-content:space-between;width:var(--sidebar-width);background-color:#fff;color:var(--text-dark);padding:20px 0;border-right:1px solid #e2e8f0;box-shadow:2px 0 5px #0000000d}.logo{display:flex;align-items:center;padding:0 20px 30px;font-size:1.2em;font-weight:700;color:var(--primary-color)}.sidebar-logo-img{width:30px;height:30px;margin-right:10px}.nav-menu ul{list-style:none;padding:0;margin:0}.nav-item{display:flex;align-items:center;padding:12px 30px;cursor:pointer;color:var(--text-dark);transition:background-color .2s,color .2s}.nav-item .icon{margin-right:15px;font-size:1.1em}.nav-item:hover{background-color:#fcebeb}.nav-item.active{background-color:var(--primary-color);color:#fff;border-left:5px solid darkred;padding-left:25px}.nav-item.disabled{opacity:.4;cursor:not-allowed;pointer-events:none;filter:grayscale(1)}.lock-icon{margin-left:auto;font-size:10px}.sidebar-footer{padding:20px;border-top:1px solid #f1f5f9}.btn-logout{display:flex;align-items:center;width:100%;padding:12px 15px 20px;background:#fff5f5;color:#c53030;border:1px solid #fed7d7;border-radius:10px;font-weight:700;cursor:pointer;transition:all .2s ease}.btn-logout:hover{background:#c53030;color:#fff;border-color:#c53030}.btn-logout .icon{margin-right:10px}@media screen and (max-width:768px){.content-area{margin-left:0!important;width:100vw!important;box-sizing:border-box}.main-content-wrapper{width:100%;padding:16px;box-sizing:border-box;display:flex;flex-direction:column;align-items:center}header,.main-header{padding-left:70px!important;padding-right:70px!important;justify-content:center!important}}:root{--sidebar-bg: #FFFFFF;--sidebar-text: #64748B;--sidebar-text-dark: #1E293B;--sidebar-active-bg: #DF2941;--sidebar-active-text: #FFFFFF;--sidebar-border: #E2E8F0;--sidebar-width: 250px}.hamburger-btn{display:none;position:fixed;top:15px;left:15px;z-index:1001;background-color:var(--sidebar-active-bg);color:#fff;border:none;border-radius:8px;width:44px;height:44px;font-size:1.5rem;cursor:pointer;box-shadow:0 2px 5px #0003;transition:background-color .2s}.hamburger-btn:hover{background-color:#b91c32}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0006;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar{display:flex;flex-direction:column;justify-content:space-between;width:var(--sidebar-width);height:100vh;background-color:var(--sidebar-bg);color:var(--sidebar-text);border-right:1px solid var(--sidebar-border);position:fixed;top:0;left:0;z-index:1000;transition:transform .3s ease-in-out;font-family:DM Sans,sans-serif}.sidebar-logo-container{display:flex;align-items:center;padding:24px;margin-bottom:8px}.sidebar-logo-img{width:32px;height:32px;margin-right:12px}.sidebar-logo-text{font-weight:800;font-size:1.3rem;color:#000}.sidebar-nav-menu ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}.sidebar-nav-item{display:flex;align-items:center;padding:14px 24px;cursor:pointer;color:var(--sidebar-text);transition:background-color .2s ease,color .2s ease}.sidebar-nav-item:hover:not(.disabled):not(.active){background-color:#f1f5f9;color:var(--sidebar-text-dark)}.sidebar-nav-item.active{background-color:var(--sidebar-active-bg);color:var(--sidebar-active-text)}.sidebar-nav-item.disabled{opacity:.5;cursor:not-allowed}.sidebar-icon{margin-right:14px;font-size:1.2rem}.sidebar-item-name{flex:1;font-size:.95rem;font-weight:500}.sidebar-lock-icon{font-size:.8rem}.sidebar-footer{padding:24px;border-top:1px solid var(--sidebar-border)}.sidebar-btn-logout{display:flex;align-items:center;width:100%;padding:12px 16px;background-color:#fef2f2;border:none;color:#dc2626;font-size:.95rem;font-weight:700;cursor:pointer;border-radius:8px;transition:all .2s ease}.sidebar-btn-logout:hover{background-color:#fee2e2}@media screen and (max-width:768px){.hamburger-btn{display:block;position:fixed;top:20px;left:20px;z-index:2000}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar.open~.sidebar-overlay,.sidebar-overlay{display:block}}body.hide-hamburger .hamburger-btn{display:none!important}.header-wrapper{width:100%;position:sticky;top:0;z-index:900;font-family:DM Sans,sans-serif}.main-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:0 40px;height:90px;border-bottom:2px solid #EBDBD6;box-shadow:0 4px 12px #00000008}.header-left{display:flex;align-items:center;gap:20px}.user-info{display:flex;flex-direction:column}.welcome-msg{font-size:1.25rem;color:#221f1f;margin:0 0 4px;font-weight:800}.live-date{font-size:.85rem;color:#497b97;margin:0;font-weight:500}.live-time{font-weight:800;color:#ff1817;margin-left:6px}.header-right{display:flex;align-items:center;justify-content:flex-end}.user-avatar{width:44px;height:44px;background:#ebdbd6;color:#221f1f;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;border:2px solid #497B97;box-shadow:0 2px 5px #0000001a}@media(max-width:1024px){.main-header{padding:0 30px}}@media(max-width:768px){.main-header{display:flex!important;flex-direction:row!important;justify-content:space-between!important;align-items:center!important;height:80px;width:100%;box-sizing:border-box;padding:0 20px 0 75px!important}.header-left{display:flex;justify-content:flex-start;width:auto}.user-info{display:flex;flex-direction:column;align-items:flex-start}.header-right{display:flex;justify-content:flex-end;align-items:center;width:auto;margin:0;padding:0}.welcome-msg{font-size:1.1rem;margin-bottom:3px}.live-date{font-size:.75rem}.user-avatar{width:42px;height:42px;font-size:1.1rem;margin:0}}.profile-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease-out}.profile-modal-content{background-color:#fff;width:90%;max-width:800px;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;position:relative;overflow:hidden;animation:slideUp .3s ease-out}.profile-close-btn{position:absolute;top:20px;right:20px;background:none;border:none;font-size:1.2rem;color:#94a3b8;cursor:pointer;z-index:10;transition:color .2s}.profile-close-btn:hover{color:#0f172a}.profile-modal-grid{display:grid;grid-template-columns:1fr 1.5fr}.profile-identity-section{background-color:#f8fafc;padding:40px 30px;display:flex;flex-direction:column;align-items:center;text-align:center;border-right:1px solid #e2e8f0}.profile-avatar-large-wrapper{position:relative;width:120px;height:120px;border-radius:50%;margin-bottom:20px;border:4px solid #ffffff;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden}.profile-avatar-large{width:100%;height:100%;background-color:#1e293b;color:#fff;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:800;background-size:cover;background-position:center}.avatar-upload-overlay{position:absolute;bottom:0;left:0;width:100%;height:40%;background-color:#0009;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;cursor:pointer;opacity:0;transition:opacity .2s ease-in-out}.profile-avatar-large-wrapper:hover .avatar-upload-overlay{opacity:1}.avatar-upload-overlay span{font-size:1.2rem}.avatar-upload-overlay small{font-size:.6rem;font-weight:600;text-transform:uppercase;margin-top:2px}.profile-name{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0 0 5px}.profile-email{font-size:.9rem;color:#64748b;margin:0 0 20px}.profile-badges{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.profile-badge{padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.profile-badge.dept{background-color:#e0f2fe;color:#0369a1}.profile-badge.role{background-color:#f1f5f9;color:#475569}.profile-security-section{padding:40px 30px;background-color:#fff}.security-title{font-size:1.2rem;font-weight:800;color:#0f172a;margin:0 0 5px}.security-subtitle{font-size:.9rem;color:#64748b;margin:0 0 25px}.passport-card{background:linear-gradient(135deg,#1e293b,#0f172a);border-radius:12px;padding:24px;color:#fff;box-shadow:0 10px 15px -3px #0f172a4d;position:relative;overflow:hidden}.passport-card:after{content:"VISION";position:absolute;bottom:-20px;right:-10px;font-size:5rem;font-weight:900;color:#ffffff08;pointer-events:none}.passport-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:15px;margin-bottom:15px}.passport-logo{font-weight:800;letter-spacing:2px;font-size:.9rem;color:#cbd5e1}.passport-status{font-size:.7rem;font-weight:700;background-color:#16a34a33;color:#4ade80;padding:4px 8px;border-radius:4px}.passport-label{font-size:.7rem;color:#94a3b8;font-weight:700;letter-spacing:1px;display:block;margin-bottom:10px}.permission-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:25px}.perm-tag{background-color:#ffffff1a;padding:6px 12px;border-radius:4px;font-size:.8rem;font-weight:600;border:1px solid rgba(255,255,255,.1)}.perm-tag.all-access{background-color:#eab30833;color:#fde047;border-color:#eab3084d}.passport-footer{display:flex;justify-content:space-between;border-top:1px solid rgba(255,255,255,.1);padding-top:15px}.passport-info{display:flex;flex-direction:column}.passport-info small{color:#94a3b8;font-size:.65rem;font-weight:700;letter-spacing:1px}.passport-info strong{font-size:.95rem;color:#f8fafc;margin-top:2px}.text-right{text-align:right}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.profile-modal-content{width:95%;max-height:90vh;overflow-y:auto}.profile-modal-grid{grid-template-columns:1fr}.profile-identity-section,.profile-security-section{padding:25px 20px}.profile-identity-section{border-right:none;border-bottom:1px solid #e2e8f0}.passport-header{flex-direction:column;gap:10px;align-items:flex-start}}.notif-wrapper{position:relative;display:inline-block}.notif-button{background:none;border:none;cursor:pointer;position:relative;padding:8px;color:#497b97;transition:color .2s ease;display:flex;align-items:center;justify-content:center}.notif-button:hover{color:#003049}.notif-badge{position:absolute;top:0;right:0;background-color:#ff1817;color:#fff;font-size:11px;font-weight:900;padding:3px 6px;border-radius:50%;transform:translate(25%,-25%);animation:pulse 2s infinite}.notif-dropdown{position:absolute;top:130%;right:0;width:320px;background-color:#fff;border-radius:12px;box-shadow:0 10px 30px #00000026;border:1px solid #e5e7eb;overflow:hidden;z-index:9999}.notif-header{background-color:#003049;color:#fff;font-weight:900;font-size:13px;padding:16px;text-transform:uppercase;letter-spacing:.5px;display:flex;justify-content:space-between;align-items:center}.notif-header-badge{background-color:#ff1817;padding:4px 8px;border-radius:6px;font-size:11px}.notif-body{max-height:350px;overflow-y:auto;text-align:left}.notif-empty{padding:30px;text-align:center;color:#94a3b8;font-weight:700;font-style:italic}.notif-item{padding:16px;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background-color .2s;background-color:#fff}.notif-item:hover{background-color:#f8fafc}.notif-item.rejected{background-color:#fef2f2}.notif-item.rejected:hover{background-color:#fee2e2}.notif-text{font-size:13px;font-weight:700;color:#1e293b;margin:0 0 6px;line-height:1.4}.notif-text.rejected-text{color:#b91c1c}.notif-hint{font-size:11px;color:#94a3b8;margin:0;font-weight:600}@keyframes pulse{0%,to{transform:translate(25%,-25%) scale(1)}50%{transform:translate(25%,-25%) scale(1.1)}}:root{--v-navy: #1A1A2E;--v-navy-mid: #16213E;--v-blue: #497B97;--v-blue-lt: #6B9DB5;--v-red: #FF1817;--v-red-dark: #C20100;--v-cream: #EBDBD6;--v-cream-lt: #F5EDE9;--v-black: #221F1F;--v-white: #FFFFFF;--v-surface: #F8F5F2;--v-border: #E2D4CE;--v-font-display: "Syne", sans-serif;--v-font-body: "DM Sans", sans-serif;--v-shadow-card: 0 2px 0 rgba(34,31,31,.06), 0 8px 24px rgba(34,31,31,.08);--v-shadow-hover: 0 4px 0 var(--v-red), 0 16px 40px rgba(34,31,31,.14);--v-radius: 12px;--v-transition: all .22s cubic-bezier(.4, 0, .2, 1)}.pm-page{min-height:100vh;background:var(--v-surface);font-family:var(--v-font-body);color:var(--v-black)}.pm-page-header{background:var(--v-navy);padding:28px 40px 24px;border-bottom:3px solid var(--v-red);display:flex;align-items:flex-end;justify-content:space-between;gap:20px}.pm-page-eyebrow{font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#ffffff59;display:block;margin-bottom:6px}.pm-page-title{font-family:var(--v-font-display);font-size:26px;font-weight:800;color:var(--v-white);margin:0;line-height:1.1}.pm-page-title span{color:var(--v-red)}.pm-page-count{display:inline-flex;align-items:center;gap:8px;background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:6px 16px;font-size:12px;font-weight:700;color:#fff9;letter-spacing:.5px}.pm-page-count strong{color:var(--v-white);font-size:15px}.pm-project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:32px 40px;max-width:1440px;margin:0 auto}.pm-proj-card{background:var(--v-white);border:1px solid var(--v-border);border-radius:var(--v-radius);overflow:hidden;cursor:pointer;box-shadow:var(--v-shadow-card);transition:var(--v-transition);display:flex;flex-direction:column;position:relative;opacity:0;transform:translateY(12px);animation:pm-card-in .4s cubic-bezier(.4,0,.2,1) forwards}@keyframes pm-card-in{to{opacity:1;transform:translateY(0)}}.pm-proj-card:nth-child(1){animation-delay:.04s}.pm-proj-card:nth-child(2){animation-delay:.08s}.pm-proj-card:nth-child(3){animation-delay:.12s}.pm-proj-card:nth-child(4){animation-delay:.16s}.pm-proj-card:nth-child(5){animation-delay:.2s}.pm-proj-card:nth-child(6){animation-delay:.24s}.pm-proj-card:nth-child(7){animation-delay:.28s}.pm-proj-card:nth-child(8){animation-delay:.32s}.pm-proj-card:nth-child(n+9){animation-delay:.36s}.pm-proj-card:hover{box-shadow:var(--v-shadow-hover);transform:translateY(-3px);border-color:transparent}.pm-proj-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--v-red);transform:scaleY(0);transform-origin:bottom;transition:transform .22s cubic-bezier(.4,0,.2,1)}.pm-proj-card:hover:before{transform:scaleY(1)}.pm-card-strip{height:4px;width:100%;background:var(--v-blue);flex-shrink:0}.pm-card-strip.strip-monitoring{background:var(--v-blue)}.pm-card-strip.strip-pending{background:#f59e0b}.pm-card-strip.strip-billing{background:#16a34a}.pm-card-strip.strip-completed{background:#6b7280}.pm-card-strip.strip-sales{background:var(--v-blue-lt)}.pm-card-strip.strip-engineering{background:var(--v-navy-mid)}.pm-card-strip.strip-active{background:var(--v-red)}.pm-card-head{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 18px 10px;gap:12px}.pm-card-id{font-size:10px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;color:#bbb}.pm-status-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:9px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.pm-status-chip.chip-active{background:#fef2f2;color:var(--v-red-dark);border:1px solid #fecaca}.pm-status-chip.chip-pending{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.pm-status-chip.chip-billing{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.pm-status-chip.chip-completed{background:#f8fafc;color:#475569;border:1px solid #e2e8f0}.pm-status-chip.chip-engineering{background:var(--v-cream-lt);color:var(--v-black);border:1px solid var(--v-cream)}.pm-status-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.chip-active .pm-status-dot{background:var(--v-red)}.chip-pending .pm-status-dot{background:#f59e0b}.chip-billing .pm-status-dot{background:#16a34a}.chip-completed .pm-status-dot{background:#94a3b8}.chip-engineering .pm-status-dot{background:var(--v-blue)}.pm-card-body{padding:0 18px 16px;flex:1;display:flex;flex-direction:column;gap:0}.pm-card-project-name{font-family:var(--v-font-display);font-size:16px;font-weight:700;color:var(--v-navy);margin:0 0 10px;line-height:1.25}.pm-card-meta{display:flex;flex-direction:column;gap:5px}.pm-card-meta-row{display:flex;align-items:baseline;gap:6px;font-size:12px}.pm-card-meta-key{font-size:9px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--v-blue);min-width:62px;flex-shrink:0}.pm-card-meta-val{color:var(--v-black);font-weight:500;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pm-card-foot{margin-top:auto;padding:12px 18px;border-top:1px solid var(--v-border);display:flex;align-items:center;justify-content:space-between;background:#fdfcfb}.pm-open-label{font-size:11px;font-weight:700;letter-spacing:.4px;color:var(--v-blue);display:flex;align-items:center;gap:5px;transition:gap .18s ease}.pm-proj-card:hover .pm-open-label{gap:9px;color:var(--v-red)}.pm-card-type-tag{font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#bbb}.pm-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:64px 24px;background:var(--v-white);border:1.5px dashed var(--v-border);border-radius:var(--v-radius)}.pm-empty-icon{font-size:40px;opacity:.4}.pm-empty-title{font-family:var(--v-font-display);font-size:18px;font-weight:700;color:var(--v-navy);margin:0}.pm-empty-sub{font-size:13px;color:#aaa;margin:0;text-align:center}.pm-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 24px;font-family:var(--v-font-body)}.pm-spinner{width:36px;height:36px;border:3px solid var(--v-cream);border-top-color:var(--v-red);border-radius:50%;animation:pm-spin .9s linear infinite}@keyframes pm-spin{to{transform:rotate(360deg)}}.pm-loading-text{font-size:12px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:#bbb}.pm-error{margin:32px 40px;padding:16px 20px;background:#fff1f1;border:1px solid #fecaca;border-left:4px solid var(--v-red);border-radius:8px;font-size:13px;color:var(--v-red-dark);font-weight:500;font-family:var(--v-font-body)}@media(max-width:900px){.pm-project-grid{padding:24px 20px;gap:16px}.pm-page-header{padding:20px 20px 16px;flex-direction:column;align-items:flex-start}}@media(max-width:600px){.pm-project-grid{grid-template-columns:1fr}.pm-page-title{font-size:20px}}.boq-wrapper{width:100%;box-sizing:border-box;min-width:0}.boq-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;box-sizing:border-box;border-radius:6px;scrollbar-width:thin;scrollbar-color:var(--pm-border-dark, #ccc) transparent}.boq-scroll::-webkit-scrollbar{height:6px}.boq-scroll::-webkit-scrollbar-track{background:transparent}.boq-scroll::-webkit-scrollbar-thumb{background:var(--pm-border-dark, #ccc);border-radius:10px}.boq-table{width:100%;border-collapse:collapse;font-family:var(--pm-font, "DM Sans", sans-serif);font-size:13px;table-layout:auto;min-width:800px;background:#fff}.boq-table.boq-table--readonly{min-width:700px;font-size:12px}.boq-table thead tr{background:var(--pm-black, #221F1F);border-bottom:3px solid var(--pm-red, #C20100)}.boq-table thead th{padding:12px 14px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#fff;text-align:left;white-space:nowrap;border-right:1px solid rgba(255,255,255,.08)}.boq-table thead th:last-child{border-right:none}.boq-th-category{min-width:150px}.boq-th-code{min-width:130px}.boq-th-unit,.boq-th-qty{min-width:70px;text-align:center}.boq-th-cost,.boq-th-total,.boq-th-stock{min-width:110px;text-align:center}.boq-th-action{min-width:50px;text-align:center}.boq-th-hint{font-size:10px;font-weight:400;opacity:.7}.boq-table tbody tr{border-bottom:1px solid var(--pm-border-soft, #e5e7eb);transition:background .1s}.boq-table tbody tr:last-child{border-bottom:none}.boq-table tbody tr:nth-child(2n){background:#fafafa}.boq-table tbody tr:hover{background:#497b970d!important}.boq-table tbody tr.boq-row-warn{background:#fffbeb!important}.boq-table tbody tr.boq-row-warn:hover{background:#fef3c7!important}.boq-table tbody td{padding:10px 12px;vertical-align:middle}.boq-readonly-cell{display:block;font-size:12px;font-weight:500;color:var(--pm-text-dark, #221f1f);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.boq-code-chip{background:#f0f4f8;border:1px solid #d1dce6;border-radius:4px;padding:2px 7px;font-family:Courier New,monospace;font-size:11px;color:var(--pm-blue, #497B97);font-weight:600}.boq-stock-inline{display:flex;align-items:center;gap:4px;margin-top:3px}.boq-stock-label{font-size:10px;font-weight:600;white-space:nowrap}.boq-stock-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap}.boq-stock-no{background:#fee2e2;color:#991b1b}.boq-stock-unknown{background:#f3f4f6;color:#9ca3af}.boq-total-cell{font-weight:700;color:var(--pm-black, #221f1f);text-align:right;white-space:nowrap}.boq-table tfoot tr{background:var(--pm-black, #221f1f);border-top:2px solid var(--pm-red, #C20100)}.pm-boq-total-label{padding:12px!important;font-size:16px!important;font-weight:700!important;letter-spacing:.05em!important;text-transform:uppercase!important;color:#fff!important;text-align:right!important}.pm-boq-total-val{padding:12px!important;font-size:16px!important;font-weight:900!important;color:#fff!important;white-space:nowrap!important;text-align:right!important}.boq-empty-row{text-align:center;color:#9ca3af;font-style:italic;padding:24px!important;font-size:13px}.boq-add-row{text-align:center;padding:14px;background:#fff;border-top:1px dashed var(--pm-border-soft, #e5e7eb)}.boq-loading-bar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f0f9ff;border-bottom:1px solid #bae6fd;font-size:12px;color:#0369a1;overflow:hidden}.boq-loading-inner{height:3px;flex:1;background:linear-gradient(90deg,#38bdf8,#0ea5e9,#38bdf8);background-size:200% 100%;animation:boq-shimmer 1.4s infinite;border-radius:2px}@keyframes boq-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.boq-alert-banner{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:#fffbeb;border:1.5px solid #fbbf24;border-radius:8px;margin-bottom:10px}.boq-alert-icon{font-size:18px;flex-shrink:0}.boq-alert-title{font-size:13px;font-weight:700;color:#92400e;display:block;margin-bottom:6px}.boq-alert-list{display:flex;flex-wrap:wrap;gap:6px}.boq-alert-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600}.chip-low{background:#fef3c7;color:#92400e;border:1px solid #fbbf24}.chip-no{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.boq-alert-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.boq-dd-trigger{min-height:32px}.boq-dd-panel{position:absolute;top:calc(100% + 4px);left:0;z-index:999;width:100%;min-width:200px;background:#fff;border:1.5px solid var(--pm-border-soft, #e5e7eb);border-radius:8px;box-shadow:0 10px 25px #00000026;overflow:hidden}.boq-dd-search{width:100%;border:none;border-bottom:1px solid var(--pm-border-soft, #e5e7eb);padding:10px;font-size:12px;outline:none;box-sizing:border-box}.boq-dd-list{max-height:200px;overflow-y:auto}.boq-dd-item{padding:10px 12px;font-size:12px;cursor:pointer;transition:background .1s}.boq-dd-item:hover{background:#f0f4f8}.boq-dd-item.active{background:#e0edff;font-weight:600;color:var(--pm-blue, #497B97)}.boq-dd-empty{padding:10px 12px;font-size:12px;color:#9ca3af;font-style:italic}@media(max-width:640px){.boq-table{min-width:550px}.boq-table.boq-table--readonly{min-width:480px}.boq-table thead th{padding:8px;font-size:10px}.boq-table tbody td{padding:8px}.boq-readonly-cell{font-size:11px}.boq-stock-label{font-size:9px}.boq-stock-badge{font-size:10px;padding:2px 6px}.pm-boq-total-label{font-size:11px}.pm-boq-total-val{font-size:12px}}.si-wrapper{--si-black: #221F1F;--si-red: #C20100;--si-red-bright: #FF1817;--si-red-dark: #A00101;--si-blue: #497B97;--si-cream: #EBDBD6;--si-white: #FFFFFF;--si-surface: #F7F3F1;--si-border: #D9CECA;--si-border-dark: #B5A9A4;--si-text: #221F1F;--si-text-muted: #6B5F5C;--si-text-light: #A8948F;--si-radius: 10px;--si-radius-sm: 6px}.si-wrapper{display:flex;flex-direction:column;gap:1.5rem;font-family:DM Sans,sans-serif;width:100%;box-sizing:border-box;padding:0 .5rem}.si-form-card{background:var(--si-white);border:1px solid var(--si-border);border-radius:var(--si-radius);box-shadow:0 1px 3px #221f1f0f,0 8px 32px #221f1f1a,0 0 0 3px #c201000f;overflow:hidden;position:relative;width:100%;box-sizing:border-box}.si-form-card:before{content:"";display:block;height:4px;background:linear-gradient(90deg,var(--si-red-dark) 0%,var(--si-red-bright) 60%,var(--si-red) 100%)}.si-letterhead{display:flex;align-items:center;gap:1.5rem;padding:1.25rem 2rem 1.1rem;background:var(--si-white);border-bottom:3px solid var(--si-black);position:relative}.si-letterhead:after{content:"";position:absolute;right:0;top:0;bottom:0;width:160px;background:linear-gradient(135deg,transparent 30%,rgba(235,219,214,.35) 100%);pointer-events:none}.si-letterhead-logo{flex-shrink:0}.si-logo-circle{width:72px;height:72px;border-radius:50%;background:radial-gradient(circle at 70% 30%,#ff4b4b 0%,var(--si-red) 45%,var(--si-red-dark) 100%);border:3px solid var(--si-black);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #c2010059;position:relative;overflow:hidden}.si-logo-circle:before{content:"";position:absolute;top:-8px;right:-8px;width:36px;height:36px;border-radius:50%;background:#ffffff38;filter:blur(6px)}.si-logo-circle span{font-family:DM Sans,sans-serif;font-size:2rem;font-weight:900;color:var(--si-white);letter-spacing:-.04em;position:relative;z-index:1;text-shadow:0 2px 6px rgba(0,0,0,.3)}.si-letterhead-text{flex:1;text-align:center}.si-company-name{font-family:Ministry of Morons,DM Sans,sans-serif;font-size:1.25rem;font-weight:900;color:var(--si-black);margin:0 0 3px;letter-spacing:.06em;text-transform:uppercase;line-height:1.1}.si-company-tagline{font-size:.82rem;color:var(--si-red);margin:0 0 4px;font-weight:700;font-style:italic;letter-spacing:.02em}.si-company-address,.si-company-contact{font-size:.68rem;color:var(--si-text-muted);margin:0;line-height:1.5}.si-form-title{text-align:center;font-family:Ministry of Morons,DM Sans,sans-serif;font-size:1.3rem;font-weight:900;letter-spacing:.18em;color:var(--si-white);padding:.9rem 2rem;background:var(--si-black);text-transform:uppercase;border-bottom:3px solid var(--si-red);position:relative;overflow:hidden}.si-form-title:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 140%,rgba(194,1,0,.45) 0%,transparent 65%);pointer-events:none}.si-header-fields{padding:1.5rem 2rem .75rem;display:flex;flex-direction:column;gap:.55rem;background:var(--si-white);border-bottom:2px solid var(--si-black)}.si-field-row{display:flex;align-items:center;gap:.85rem;min-height:38px;border-bottom:1px solid var(--si-border);padding-bottom:.45rem}.si-field-row:last-child{border-bottom:none}.si-field-row-top{align-items:flex-start;padding-top:4px}.si-field-label{font-size:.68rem;font-weight:900;text-transform:uppercase;letter-spacing:.07em;color:var(--si-black);white-space:nowrap;min-width:230px;flex-shrink:0}.si-field-input{flex:1;border:none;border-bottom:1.5px solid var(--si-border-dark);border-radius:0;padding:.3rem .4rem;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:var(--si-text);background:transparent;outline:none;transition:border-color .15s;min-width:0}.si-field-input:focus{border-bottom-color:var(--si-red);background:#c2010005}.si-field-select{border:1.5px solid var(--si-border);border-radius:var(--si-radius-sm);padding:.38rem .65rem;background:var(--si-surface);font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:var(--si-text);cursor:pointer;outline:none;transition:border-color .15s,box-shadow .15s;flex:1;min-width:0}.si-field-select:focus{border-color:var(--si-red);box-shadow:0 0 0 3px #c201001a}.si-field-datetime{display:flex;gap:.5rem;flex:1;flex-wrap:wrap}.si-field-textarea{flex:1;border:1.5px solid var(--si-border);border-radius:var(--si-radius-sm);padding:.55rem .75rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;color:var(--si-text);resize:vertical;outline:none;transition:border-color .15s,box-shadow .15s;background:var(--si-surface);min-width:0}.si-field-textarea:focus{border-color:var(--si-red);box-shadow:0 0 0 3px #c201001a}.si-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.si-table{width:100%;border-collapse:collapse;font-family:DM Sans,sans-serif;font-size:.8rem;min-width:480px}.si-table thead tr{background:var(--si-black);border-bottom:3px solid var(--si-red)}.si-th-label{text-align:left;padding:.75rem 1.1rem;color:var(--si-cream);font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.09em;min-width:200px;border-right:1px solid rgba(255,255,255,.08)}.si-th-check{text-align:center;padding:.75rem .85rem;color:var(--si-cream);font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.09em;width:52px;border-right:1px solid rgba(255,255,255,.08)}.si-th-reco{text-align:left;padding:.75rem 1.1rem;color:var(--si-cream);font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.09em;min-width:140px}.si-th-action{width:36px;text-align:center;padding:.75rem .5rem;color:#ffffff4d;font-size:.6rem}.si-check-row td{border-bottom:1px solid var(--si-border);vertical-align:middle;transition:background .1s}.si-check-row:nth-child(2n) td{background:#ebdbd62e}.si-check-row:hover td{background:#497b9712!important}.si-td-label{padding:.55rem 1.1rem;min-width:200px;border-right:1px solid var(--si-border)}.si-td-check{text-align:center;padding:.55rem .5rem;border-right:1px solid var(--si-border);width:52px}.si-td-reco{padding:.55rem 1.1rem;min-width:140px}.si-td-action{text-align:center;padding:.3rem;width:36px;border-left:1px solid var(--si-border)}.si-inline-input{width:100%;border:none;border-bottom:1px dashed transparent;background:transparent;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;color:var(--si-text);padding:.2rem .3rem;outline:none;transition:border-color .15s,background .12s;border-radius:3px 3px 0 0;box-sizing:border-box}.si-inline-input:focus{border-bottom-color:var(--si-red);background:#c2010008}.si-inline-input::placeholder{color:var(--si-text-light)}.si-checkbox{width:17px;height:17px;accent-color:var(--si-red);cursor:pointer}.si-remove-btn{background:none;border:none;cursor:pointer;color:var(--si-red);font-weight:900;font-size:.82rem;padding:.22rem .4rem;border-radius:4px;transition:background .12s;line-height:1;opacity:.55}.si-remove-btn:hover{background:#c2010014;opacity:1}.si-add-row-wrap{padding:.7rem 1.1rem;background:linear-gradient(90deg,rgba(235,219,214,.3) 0%,transparent 100%);border-top:1.5px dashed var(--si-border-dark)}.si-add-row-btn{background:none;border:1.5px dashed var(--si-blue);color:var(--si-blue);font-family:DM Sans,sans-serif;font-size:.73rem;font-weight:700;padding:.42rem 1.1rem;border-radius:var(--si-radius-sm);cursor:pointer;letter-spacing:.04em;transition:all .15s}.si-add-row-btn:hover{background:var(--si-blue);color:#fff;border-style:solid}.si-notes-section{padding:1.1rem 2rem 1.5rem;border-top:2px solid var(--si-black);background:var(--si-surface)}.si-notes-label{font-size:.68rem;font-weight:900;text-transform:uppercase;letter-spacing:.09em;color:var(--si-black);margin-bottom:.65rem;display:flex;align-items:center;gap:.5rem}.si-notes-label:before{content:"";display:inline-block;width:12px;height:3px;background:var(--si-red);border-radius:2px;flex-shrink:0}.si-notes-textarea{width:100%;border:1.5px solid var(--si-border);border-radius:var(--si-radius-sm);padding:.75rem .9rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;color:var(--si-text);resize:vertical;outline:none;transition:border-color .15s,box-shadow .15s;min-height:90px;background:var(--si-white);box-sizing:border-box}.si-notes-textarea:focus{border-color:var(--si-red);box-shadow:0 0 0 3px #c201001a}.si-signature-row{display:none;justify-content:space-around;padding:2.5rem 2rem 2rem;border-top:1.5px solid var(--si-border);gap:3rem;background:var(--si-white)}.si-sig-block{flex:1;max-width:280px;text-align:center}.si-sig-line{border-bottom:2px solid var(--si-black);height:52px;margin-bottom:.6rem}.si-sig-label{font-size:.68rem;font-weight:700;color:var(--si-text-muted);margin:0;text-transform:uppercase;letter-spacing:.05em}.si-actions{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;padding:1rem 1.25rem;background:var(--si-white);border:1px solid var(--si-border);border-radius:var(--si-radius);box-shadow:0 1px 4px #221f1f12}.si-actions-left,.si-actions-right{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap}.si-save-draft-btn{display:inline-flex;align-items:center;gap:.45rem;padding:.65rem 1.35rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:800;letter-spacing:.04em;color:var(--si-black);background:var(--si-white);border:2px solid var(--si-black);border-radius:var(--si-radius-sm);cursor:pointer;transition:background .15s,color .15s,box-shadow .15s;white-space:nowrap;box-shadow:0 1px 3px #221f1f14}.si-save-draft-btn:hover{background:var(--si-black);color:var(--si-white);box-shadow:0 4px 14px #221f1f38}.si-save-draft-btn:active{transform:translateY(1px);box-shadow:none}.si-save-draft-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.si-saved-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.38rem .9rem;font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:800;letter-spacing:.04em;color:#065f46;background:#d1fae5;border:1px solid #6ee7b7;border-radius:20px;animation:si-badge-pop .2s ease;white-space:nowrap}@keyframes si-badge-pop{0%{opacity:0;transform:translateY(-4px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}.si-print-btn{display:inline-flex;align-items:center;gap:.45rem;background:var(--si-white);border:1.5px solid var(--si-border-dark);color:var(--si-text);font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:700;padding:.65rem 1.35rem;border-radius:var(--si-radius-sm);cursor:pointer;letter-spacing:.03em;transition:all .15s;box-shadow:0 1px 3px #221f1f14;white-space:nowrap}.si-print-btn:hover{background:var(--si-black);color:var(--si-white);border-color:var(--si-black);box-shadow:0 4px 12px #221f1f2e}.si-print-btn:disabled{opacity:.5;cursor:not-allowed}.si-ref-docs{margin-bottom:.25rem}.si-loading-text{font-style:italic;color:var(--si-text-muted);font-size:.82rem}@media(max-width:640px){.si-wrapper{padding:0;gap:1rem}.si-letterhead{flex-direction:column;align-items:center;text-align:center;padding:1rem 1rem .9rem;gap:.75rem}.si-letterhead:after{display:none}.si-logo-circle{width:56px;height:56px}.si-logo-circle span{font-size:1.5rem}.si-company-name{font-size:1rem;letter-spacing:.03em}.si-company-tagline{font-size:.75rem}.si-company-address,.si-company-contact{font-size:.62rem}.si-form-title{font-size:1rem;letter-spacing:.1em;padding:.75rem 1rem}.si-header-fields{padding:1rem 1rem .5rem;gap:.75rem}.si-field-row{flex-direction:column;align-items:flex-start;gap:.3rem;padding-bottom:.65rem}.si-field-label{min-width:unset;font-size:.63rem;color:var(--si-text-muted)}.si-field-input,.si-field-select,.si-field-textarea{width:100%;font-size:.82rem}.si-field-datetime{flex-direction:column;gap:.4rem;width:100%}.si-field-datetime .si-field-input{width:100%!important}.si-notes-section{padding:.9rem 1rem 1.1rem}.si-table{min-width:420px;font-size:.74rem}.si-th-label,.si-td-label{min-width:140px;padding:.5rem .75rem}.si-th-check,.si-td-check{width:42px;padding:.5rem .35rem}.si-th-reco,.si-td-reco{min-width:110px;padding:.5rem .75rem}.si-actions{flex-direction:column;align-items:stretch;padding:.85rem 1rem;gap:.6rem}.si-actions-left,.si-actions-right{flex-direction:column;align-items:stretch;gap:.5rem;width:100%}.si-save-draft-btn,.si-print-btn{width:100%;justify-content:center;padding:.75rem 1rem}.si-saved-badge{align-self:flex-start}.si-add-row-btn{width:100%;justify-content:center;text-align:center}.si-add-row-wrap{padding:.6rem .75rem}}@media(min-width:641px)and (max-width:900px){.si-letterhead{padding:1rem 1.25rem .9rem;gap:1rem}.si-logo-circle{width:60px;height:60px}.si-logo-circle span{font-size:1.65rem}.si-company-name{font-size:1.05rem}.si-header-fields{padding:1.1rem 1.25rem .6rem}.si-field-label{min-width:180px;font-size:.65rem}.si-actions{padding:.85rem 1rem}.si-notes-section{padding:1rem 1.25rem 1.25rem}}@media print{.no-print{display:none!important}.print-only{display:flex!important}body{background:#fff!important}.si-form-card{border:none;box-shadow:none;border-radius:0}.si-form-card:before,.si-table thead tr,.si-form-title,.si-logo-circle{-webkit-print-color-adjust:exact;print-color-adjust:exact}.si-check-row:nth-child(2n) td{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#ebdbd640!important}.si-field-input{border-bottom:1px solid #999}.si-inline-input{border-bottom:1px solid #ccc}.si-field-textarea,.si-notes-textarea,.si-field-select{border:1px solid #ccc}.si-add-row-wrap,.si-td-action,.si-th-action{display:none!important}.si-signature-row{display:flex!important}}.pm-phase-wrapper{display:flex;flex-direction:column;gap:16px;width:100%;max-width:100%;min-height:0;box-sizing:border-box;overflow-x:hidden}.pm-phase-wrapper .pm-card{padding:0;overflow:hidden;display:flex;flex-direction:column;height:auto;min-height:0;margin-bottom:0;transition:none;cursor:default;width:100%;box-sizing:border-box;background:#fff;border:1px solid var(--pm-border-soft, #e5e7eb);border-radius:12px}.pm-phase-wrapper .pm-card:hover{transform:none;box-shadow:var(--pm-shadow);border-color:var(--pm-border-soft)}.pm-phase-wrapper .pm-card>.pm-card-navy{flex-shrink:0;border-radius:0}.pm-phase-wrapper .pm-card>.pm-card-body{flex:1 1 auto}.pm-phase-wrapper .pm-card-body{display:flex;flex-direction:column;gap:20px;padding:28px 30px 32px;box-sizing:border-box;width:100%;min-width:0}.pm-phase-wrapper .pm-card-gray{margin-bottom:0;box-sizing:border-box;width:100%;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px;min-width:0}.pm-phase-wrapper .pm-card-cream{margin-bottom:0;box-sizing:border-box;width:100%;text-align:center;border-style:dashed;background:#fffaf0;border:1px solid #feebc8;border-radius:8px;padding:20px}.pm-phase-wrapper>.pm-card-red{margin-bottom:0;background:#fff5f5;border-left:4px solid #f56565;padding:16px}.pm-phase-wrapper .pm-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.pm-phase-wrapper .pm-file-input{display:block;width:100%;max-width:400px;margin:0 auto 20px;padding:10px;font-family:inherit;font-size:13px;color:var(--pm-black);border:1.5px dashed var(--pm-blue);border-radius:var(--pm-radius);background:#497b970d;cursor:pointer;box-sizing:border-box}.pm-phase-wrapper .pm-btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 22px;border-radius:var(--pm-radius);font-weight:600;font-size:13px;cursor:pointer;background:transparent;border:2px solid var(--pm-red);color:var(--pm-red);white-space:nowrap;transition:all .2s ease}.pm-phase-wrapper .pm-btn-outline:hover{background:var(--pm-red);color:#fff}.pm-stock-legend{display:flex;flex-wrap:wrap;align-items:center;gap:14px;padding:12px 16px;background:#f1f5f9;border:1px dashed var(--pm-border-soft, #e5e7eb);border-radius:8px}.pm-stock-legend-title{font-size:11px;font-weight:800;letter-spacing:.05em;color:var(--pm-black);text-transform:uppercase}.pm-stock-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--pm-text-dark, #221f1f);font-weight:500}.pm-stock-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.pm-phase-wrapper .pm-card>.pm-card-navy{width:100%;padding:18px 28px;display:flex;align-items:center;justify-content:space-between;background:#1e293b;border-bottom:3px solid #FF1817;box-sizing:border-box}.pm-award-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:24px;align-items:start;width:100%;min-width:0}.pm-award-form-block{background:#fff;border:1.5px solid var(--pm-border-soft, #e5e7eb);border-radius:8px;padding:24px;display:flex;flex-direction:column;gap:20px;box-sizing:border-box;width:100%}.pm-upload-label{display:flex;align-items:center;gap:12px;padding:14px 18px;border:1.5px dashed #497B97;border-radius:8px;background:#497b970a;cursor:pointer}@media(max-width:900px){.pm-award-grid{grid-template-columns:1fr}}@media(max-width:640px){.pm-phase-wrapper .pm-card-body{padding:16px;gap:16px}.pm-phase-wrapper .pm-grid-2{grid-template-columns:1fr}.pm-phase-wrapper .pm-card>.pm-card-navy{padding:14px 16px;flex-wrap:wrap;gap:10px}.pm-award-form-block{padding:16px}.pm-upload-label{flex-direction:column;align-items:flex-start;gap:6px;padding:12px}}.pm-mob-wrapper{display:flex;flex-direction:column;gap:16px;width:100%;max-width:100%}.pm-mob-wrapper .pm-card{padding:0!important;overflow:hidden!important;display:flex;flex-direction:column;height:auto;min-height:0;margin-bottom:0;transition:none;cursor:default;width:100%;max-width:100%;box-sizing:border-box}.pm-mob-wrapper .pm-card:hover{transform:none;box-shadow:var(--pm-shadow);border-color:var(--pm-border-soft)}.pm-mob-wrapper .pm-card>.pm-card-navy{flex-shrink:0;border-radius:0;width:100%;padding:18px 28px;display:flex;align-items:center;justify-content:space-between;background:#1a1a2e;border-bottom:3px solid #FF1817;box-sizing:border-box}.pm-mob-wrapper .pm-card-body{display:flex;flex-direction:column;gap:20px;padding:28px 30px 32px;height:auto;overflow:visible}.pm-mob-wrapper .pm-card-gray,.pm-mob-wrapper .pm-card-cream,.pm-mob-wrapper .pm-card-red{margin-bottom:0;height:auto;overflow:visible}.pm-mob-title{color:#fff;margin:0;font-family:DM Sans,sans-serif;font-weight:700;font-size:15px}.pm-mob-section-label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:12px}.pm-mob-label-blue{color:var(--pm-blue)}.pm-mob-confirm-heading{margin-bottom:16px}.pm-mob-nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%}.pm-mob-nav-sub{color:#ffffff80;font-size:12px;margin:4px 0 0}.pm-mob-count-badge{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#ffffffd9;font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;padding:5px 14px;border-radius:20px;white-space:nowrap;flex-shrink:0}.pm-mob-checklist{display:flex;flex-direction:column;gap:10px}.pm-mob-check-item{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;background:var(--pm-white);border:1.5px solid var(--pm-border-soft);border-radius:var(--pm-radius);cursor:pointer;transition:border-color .18s ease,background .18s ease}.pm-mob-check-item input[type=checkbox]{margin-top:3px;width:16px;height:16px;accent-color:var(--pm-red);flex-shrink:0;cursor:pointer}.pm-mob-check-item.pm-mob-check-done{border-color:#1a7a4a;background:#f0faf4}.pm-mob-check-text{display:flex;flex-direction:column;gap:3px}.pm-mob-check-title{font-weight:600;font-size:13px;color:var(--pm-black)}.pm-mob-check-sub{font-size:12px;color:#888;line-height:1.4}.pm-mob-check-item.pm-mob-check-done .pm-mob-check-title{color:#1a7a4a}.pm-mob-table-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.pm-mob-table-sub{margin-top:4px}.pm-mob-add-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--pm-blue);color:#fff;border:none;border-radius:var(--pm-radius);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .2s ease;flex-shrink:0}.pm-mob-add-btn:hover{background:#3a6a85}.pm-mob-table-wrap{overflow-x:auto;border-radius:var(--pm-radius);border:1px solid var(--pm-border-soft)}.pm-mob-table{width:100%;border-collapse:collapse;font-size:13px}.pm-mob-table thead tr{background:var(--pm-black);border-bottom:2px solid var(--pm-red)}.pm-mob-table thead th{padding:11px 14px;text-align:left;color:#ffffffd9;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase}.pm-mob-col-num{width:40px}.pm-mob-col-pos{width:200px}.pm-mob-col-del{width:60px}.pm-mob-table tbody tr{border-bottom:1px solid var(--pm-border-soft);background:#fff;transition:background .15s ease}.pm-mob-table tbody tr:last-child{border-bottom:none}.pm-mob-table tbody tr:hover{background:#fafafa}.pm-mob-table tbody tr.pm-mob-row-filled{background:#f6fbf8}.pm-mob-table td{padding:8px 10px;vertical-align:middle}.pm-mob-row-num{text-align:center;color:#aaa;font-size:12px;font-weight:600}.pm-mob-input{width:100%;padding:8px 12px;border:1.5px solid var(--pm-border-soft);border-radius:6px;font-size:13px;font-family:inherit;color:var(--pm-black);background:#fff;outline:none;transition:border-color .18s ease}.pm-mob-input:focus{border-color:var(--pm-blue);box-shadow:0 0 0 3px #497b971f}.pm-mob-select{cursor:pointer}.pm-mob-remove-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#fee2e2;color:var(--pm-red);border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;transition:background .15s ease;margin:0 auto}.pm-mob-remove-btn:hover:not(:disabled){background:var(--pm-red);color:#fff}.pm-mob-remove-btn:disabled{opacity:.3;cursor:not-allowed}.pm-mob-summary{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--pm-border-soft)}.pm-mob-pill{padding:4px 12px;background:#497b971a;border:1px solid rgba(73,123,151,.25);color:var(--pm-blue);border-radius:20px;font-size:12px;font-weight:600}.pm-mob-upload-section{text-align:left}.pm-mob-upload-title{margin-bottom:6px}.pm-mob-upload-desc{margin-bottom:14px}.pm-upload-label{display:flex;align-items:center;gap:12px;padding:14px 18px;border:1.5px dashed var(--pm-blue);border-radius:var(--pm-radius);background:#497b970a;cursor:pointer;transition:background .2s ease,border-color .2s ease}.pm-upload-label:hover{background:#497b971a;border-color:var(--pm-red)}.pm-upload-icon{font-size:18px;flex-shrink:0}.pm-upload-text{font-size:13px;color:var(--pm-blue);font-weight:500;word-break:break-all}.pm-hidden-file{display:none}@media(max-width:600px){.pm-mob-wrapper .pm-card-body{padding:18px 16px 24px}.pm-mob-table-header{flex-direction:column;align-items:stretch}.pm-mob-add-btn{width:100%;justify-content:center}.pm-mob-nav-inner{flex-direction:column;align-items:flex-start}}:root{--m-navy: #1A1A2E;--m-blue: #497B97;--m-red: #FF1817;--m-red-dark: #C20100;--m-black: #221F1F;--m-cream: #EBDBD6;--m-white: #FFFFFF;--m-surface: #F8F6F3;--m-border: #E2D9D2;--m-border-md: #C8BDB5;--m-green: #15803d;--m-green-bg: #f0fdf4;--m-red-bg: #fff1f1;--m-blue-bg: #EEF4F8;--m-shadow-xs: 0 1px 3px rgba(34,31,31,.07);--m-shadow-sm: 0 2px 8px rgba(34,31,31,.08);--m-shadow-md: 0 4px 16px rgba(34,31,31,.1);--m-radius-sm: 6px;--m-radius: 10px;--m-radius-lg: 14px;--m-font: "DM Sans", sans-serif;--m-transition: all .18s ease}.mon-section{display:flex;flex-direction:column;gap:0;font-family:var(--m-font);color:var(--m-black);animation:mon-fadein .25s ease}@keyframes mon-fadein{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.mon-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px;background:var(--m-navy);border-radius:var(--m-radius-lg) var(--m-radius-lg) 0 0;border-bottom:3px solid var(--m-red);flex-wrap:wrap}.mon-header-meta{display:flex;flex-wrap:wrap;gap:10px 20px;flex:1;min-width:0}.mon-header-field{display:flex;flex-direction:column;gap:1px;min-width:80px}.mon-header-label{font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:#ffffff73}.mon-header-value{font-size:12px;font-weight:600;color:#ffffffeb}.mon-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap}.mon-header-actions .mon-btn{font-size:11px;font-weight:700;padding:7px 12px;border-radius:6px;border:none;cursor:pointer;transition:var(--m-transition);white-space:nowrap;font-family:var(--m-font);display:inline-flex;align-items:center;gap:5px}.mon-header-actions .mon-btn-outline{background:#ebdbd61f;color:var(--m-cream);border:1.5px solid rgba(235,219,214,.35)}.mon-header-actions .mon-btn-outline:hover{background:#ebdbd638}.mon-header-actions .mon-btn-navy{background:var(--m-red);color:var(--m-white)}.mon-header-actions .mon-btn-navy:hover{background:var(--m-red-dark)}.mon-header-actions .mon-btn-navy:disabled{background:#ffffff26;color:#fff6;cursor:not-allowed}.mon-body{background:var(--m-white);border:1px solid var(--m-border);border-top:none;border-radius:0 0 var(--m-radius-lg) var(--m-radius-lg);padding:16px 14px 24px;display:flex;flex-direction:column;gap:18px}.mon-error{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--m-red-bg);border:1px solid #fecaca;border-left:4px solid var(--m-red);border-radius:var(--m-radius-sm);font-size:13px;color:var(--m-red-dark);font-weight:500}.mon-success{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--m-green-bg);border:1px solid #86efac;border-left:4px solid var(--m-green);border-radius:var(--m-radius-sm);font-size:13px;color:var(--m-green);font-weight:500}.mon-boq-notice{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--m-blue-bg);border:1px solid rgba(73,123,151,.25);border-radius:var(--m-radius-sm);font-size:12px;color:var(--m-blue);flex-wrap:wrap}.mon-boq-notice-icon{font-size:15px;flex-shrink:0}.mon-boq-badge{display:inline-block;padding:1px 7px;background:var(--m-blue);color:var(--m-white);border-radius:4px;font-size:9px;font-weight:800;letter-spacing:.5px;margin:0 2px;vertical-align:middle;white-space:nowrap}.mon-row-boq{background:#f8fbfd!important}.mon-top-row{display:flex;flex-direction:column;gap:12px;padding:14px;background:var(--m-surface);border:1px solid var(--m-border);border-radius:var(--m-radius)}.mon-top-field{display:flex;flex-direction:column;gap:5px}.mon-top-datepicker{display:flex;flex-direction:column;gap:6px}.mon-date-input-inline{padding:9px 14px;border:2px solid var(--m-border-md);border-radius:var(--m-radius-sm);font-family:var(--m-font);font-size:14px;font-weight:600;color:var(--m-navy);background:var(--m-white);outline:none;cursor:pointer;transition:var(--m-transition);width:100%;max-width:220px}.mon-date-input-inline:focus{border-color:var(--m-blue);box-shadow:0 0 0 3px #497b971f}.mon-textarea-sm{min-height:62px;resize:vertical}.mon-timeline-block{background:var(--m-surface);border:1px solid var(--m-border);border-radius:var(--m-radius);overflow:hidden}.mon-block-header{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--m-border);background:var(--m-white)}.mon-block-title{font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--m-black)}.mon-timeline-paired{display:flex;flex-direction:column}.mon-timeline-col{display:flex;flex-direction:column;gap:0;padding:14px 16px}.mon-timeline-col:first-child{border-bottom:1px solid var(--m-border)}.mon-timeline-col .mon-input-group{padding-bottom:12px;border-bottom:1px dashed var(--m-border);margin-bottom:12px}.mon-timeline-col .mon-input-group:last-child{padding-bottom:0;border-bottom:none;margin-bottom:0}.mon-input-group{display:flex;flex-direction:column;gap:5px}.mon-input-label{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#888}.mon-input{padding:9px 12px;border:1.5px solid var(--m-border);border-radius:var(--m-radius-sm);font-family:var(--m-font);font-size:13px;color:var(--m-black);background:var(--m-white);outline:none;transition:var(--m-transition);width:100%}.mon-input:focus{border-color:var(--m-blue);box-shadow:0 0 0 3px #497b971f}.mon-input::placeholder{color:#c0b8b0}.mon-input-actual{border-left:3px solid var(--m-blue)!important;background:var(--m-blue-bg)!important}.mon-input-actual:focus{border-color:var(--m-blue)!important;background:var(--m-white)!important}.mon-textarea{padding:9px 12px;border:1.5px solid var(--m-border);border-radius:var(--m-radius-sm);font-family:var(--m-font);font-size:13px;color:var(--m-black);background:var(--m-white);outline:none;transition:var(--m-transition);width:100%;resize:vertical;min-height:72px}.mon-textarea:focus{border-color:var(--m-blue);box-shadow:0 0 0 3px #497b971f}.mon-mat-toolbar{display:flex;flex-direction:column;gap:8px}.mon-date-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.mon-field-label{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--m-black);white-space:nowrap}.mon-date-input{padding:8px 12px;border:2px solid var(--m-border-md);border-radius:var(--m-radius-sm);font-family:var(--m-font);font-size:13px;font-weight:600;color:var(--m-navy);background:var(--m-white);outline:none;cursor:pointer;transition:var(--m-transition)}.mon-date-input:focus{border-color:var(--m-blue);box-shadow:0 0 0 3px #497b971f}.mon-date-hint{font-size:11px;color:#6b7280;font-style:italic;line-height:1.4}.mon-date-status{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}.mon-date-status.exists{background:var(--m-green-bg);color:var(--m-green);border:1px solid #bbf7d0}.mon-date-status.new{background:var(--m-blue-bg);color:var(--m-blue);border:1px solid #bfdbfe}.mon-table-card{border:1px solid var(--m-border);border-radius:var(--m-radius);overflow:hidden;box-shadow:var(--m-shadow-xs)}.mon-table-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--m-navy);border-bottom:2px solid var(--m-red);gap:8px}.mon-table-title{font-size:11px;font-weight:700;letter-spacing:.5px;color:#ffffffe6}.mon-add-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;background:#ffffff1f;color:#ffffffe6;border:1px solid rgba(255,255,255,.2);border-radius:var(--m-radius-sm);font-family:var(--m-font);font-size:11px;font-weight:700;cursor:pointer;transition:var(--m-transition);white-space:nowrap}.mon-add-btn:hover{background:#ffffff38}.mon-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.mon-table{width:100%;border-collapse:collapse;font-size:12px;font-family:var(--m-font);min-width:560px}.mon-table thead tr{background:var(--m-navy)}.mon-table thead tr.thead-sub{background:#13132a;border-bottom:2px solid var(--m-red)}.mon-table thead th{padding:9px 10px;text-align:center;font-size:8px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:#ffffffb3;border-right:1px solid rgba(255,255,255,.06);white-space:nowrap}.mon-table thead th:last-child{border-right:none}.mon-table thead th.th-left{text-align:left}.mon-table thead tr.thead-sub th{font-size:8px;color:#ffffff80;padding:6px 10px}.mon-table thead th.th-date-group{background:#ff18171f;color:#ff8a87}.mon-table tbody tr{border-bottom:1px solid var(--m-border);background:var(--m-white);transition:background .12s}.mon-table tbody tr:last-child{border-bottom:none}.mon-table tbody tr:hover{background:#fdfcfb}.mon-table tbody tr.row-filled{background:#f8fdf9}.mon-table td{padding:6px 8px;vertical-align:middle;text-align:center;border-right:1px solid var(--m-border)}.mon-table td:last-child{border-right:none}.mon-table td.td-left{text-align:left}.mon-table td.td-num{color:#b0a8a8;font-size:11px;font-weight:700}.mon-table td.td-bold{font-weight:700}.mon-table td.td-red{color:var(--m-red);font-weight:700}.mon-table td.td-green{color:var(--m-green);font-weight:700}.mon-table td.td-blue{color:var(--m-blue);font-weight:700}.mon-table td.td-consumed{background:#ff18170a}.mon-cell-input{width:100%;padding:5px 8px;border:1.5px solid transparent;border-radius:5px;font-family:var(--m-font);font-size:12px;color:var(--m-black);background:transparent;outline:none;transition:var(--m-transition)}.mon-cell-input:hover{border-color:var(--m-border);background:var(--m-white)}.mon-cell-input:focus{border-color:var(--m-blue);background:var(--m-white);box-shadow:0 0 0 2px #497b971f}.mon-cell-input::placeholder{color:#ccc}.mon-cell-input.input-wide{min-width:100px}.mon-cell-input.input-num{max-width:64px;text-align:center}.mon-cell-input.input-date{min-width:110px}.mon-cell-input.input-red{color:var(--m-red);font-weight:700}.mon-cell-input.input-blue{color:var(--m-blue);font-weight:700}.mon-cell-select{padding:5px 8px;border:1.5px solid transparent;border-radius:5px;font-family:var(--m-font);font-size:12px;color:var(--m-black);background:transparent;outline:none;cursor:pointer;width:100%;transition:var(--m-transition)}.mon-cell-select:hover{border-color:var(--m-border);background:var(--m-white)}.mon-cell-select:focus{border-color:var(--m-blue);background:var(--m-white)}.mon-remove-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;margin:0 auto;background:#fee2e2;color:var(--m-red);border:none;border-radius:5px;font-size:11px;font-weight:700;cursor:pointer;transition:var(--m-transition)}.mon-remove-btn:hover:not(:disabled){background:var(--m-red);color:var(--m-white)}.mon-remove-btn:disabled{opacity:.25;cursor:not-allowed}.mon-photo-section{background:var(--m-surface);border:1px solid var(--m-border);border-radius:var(--m-radius);overflow:hidden}.mon-photo-grid{display:grid;grid-template-columns:1fr;gap:12px;padding:14px 16px}.mon-photo-label{display:block;font-size:9px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#888;margin-bottom:6px}.mon-upload-trigger{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1.5px dashed var(--m-border-md);border-radius:var(--m-radius-sm);background:var(--m-white);cursor:pointer;transition:var(--m-transition)}.mon-upload-trigger:hover{border-color:var(--m-blue);background:var(--m-blue-bg)}.mon-upload-trigger.has-file{border-color:var(--m-green);border-style:solid;background:var(--m-green-bg)}.mon-upload-icon{font-size:16px;flex-shrink:0}.mon-upload-name{font-size:12px;font-weight:500;color:var(--m-blue);word-break:break-all;line-height:1.3}.mon-upload-trigger.has-file .mon-upload-name{color:var(--m-green)}.mon-file-hidden{display:none}.mon-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--m-radius-sm);font-family:var(--m-font);font-size:12px;font-weight:700;letter-spacing:.3px;cursor:pointer;border:none;transition:var(--m-transition);white-space:nowrap}.mon-btn-navy{background:var(--m-navy);color:var(--m-white)}.mon-btn-navy:hover{background:#0f0f22}.mon-btn-navy:disabled{opacity:.5;cursor:not-allowed}.mon-btn-green{background:var(--m-green);color:var(--m-white)}.mon-btn-green:hover{background:#166534}.mon-btn-red{background:var(--m-red);color:var(--m-white)}.mon-btn-red:hover{background:var(--m-red-dark)}.mon-btn-outline{background:transparent;color:var(--m-navy);border:1.5px solid var(--m-border-md)}.mon-btn-outline:hover{border-color:var(--m-navy);background:var(--m-surface)}.mon-history{border-top:1px solid var(--m-border);padding-top:16px}.mon-history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.mon-history-title{font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--m-black)}.mon-history-count{display:inline-flex;align-items:center;justify-content:center;background:var(--m-blue-bg);color:var(--m-blue);border-radius:20px;padding:1px 9px;font-size:11px;font-weight:700;margin-left:8px}.mon-toggle-btn{font-family:var(--m-font);font-size:12px;font-weight:600;color:var(--m-blue);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:4px;transition:var(--m-transition)}.mon-toggle-btn:hover{background:var(--m-blue-bg)}.mon-history-list{display:flex;flex-direction:column;gap:6px}.mon-history-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--m-surface);border:1px solid var(--m-border);border-radius:var(--m-radius-sm);cursor:pointer;transition:var(--m-transition)}.mon-history-item:hover{border-color:var(--m-blue);background:var(--m-blue-bg)}.mon-history-date{font-size:13px;font-weight:700;color:var(--m-black)}.mon-history-meta{font-size:11px;color:#888;margin-top:2px}.mon-history-badge{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--m-blue);padding:3px 10px;border:1px solid var(--m-blue);border-radius:20px;white-space:nowrap;margin-left:8px}.mon-roster-badge{display:inline-block;margin-left:8px;padding:2px 9px;background:#497b9726;color:var(--m-blue);border:1px solid rgba(73,123,151,.3);border-radius:20px;font-size:10px;font-weight:700;vertical-align:middle}.mon-roster-summary{display:flex;flex-wrap:wrap;gap:6px;padding:10px 14px;border-top:1px solid var(--m-border);background:var(--m-surface)}.mon-roster-pill{padding:3px 12px;background:var(--m-blue-bg);border:1px solid rgba(73,123,151,.25);color:var(--m-blue);border-radius:20px;font-size:11px;font-weight:600}.mon-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px 20px;color:#aaa;font-size:13px;font-family:var(--m-font)}@media(min-width:600px){.mon-page-header{padding:16px 20px}.mon-body{padding:20px 20px 28px;gap:20px}.mon-top-row{flex-direction:row;flex-wrap:wrap;align-items:flex-start}.mon-top-field{flex:1;min-width:140px}.mon-top-datepicker{flex:0 0 200px}.mon-photo-grid{grid-template-columns:repeat(2,1fr)}.mon-timeline-paired{flex-direction:row}.mon-timeline-col{flex:1}.mon-timeline-col:first-child{border-right:1px solid var(--m-border);border-bottom:none}}@media(min-width:900px){.mon-page-header{padding:18px 24px}.mon-body{padding:28px 28px 32px;gap:24px}.mon-header-value{font-size:13px}.mon-top-row{flex-wrap:nowrap}.mon-photo-grid{grid-template-columns:repeat(3,1fr)}.mon-table{min-width:unset}}:root{--tg-navy: #1A1A2E;--tg-blue: #497B97;--tg-red: #FF1817;--tg-red-dk: #C20100;--tg-green: #16a34a;--tg-cream: #EBDBD6;--tg-black: #221F1F;--tg-border: #D9CBC5;--tg-surface: #F8F6F3;--tg-white: #FFFFFF;--tg-radius: 8px;--tg-shadow: 0 2px 8px rgba(34,31,31,.08);--tg-font: "DM Sans", sans-serif}.tg-section{display:flex;flex-direction:column;gap:16px;font-family:var(--tg-font);color:var(--tg-black);animation:tg-fadein .22s ease}@keyframes tg-fadein{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.tg-success{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#dcfce7;border:1px solid #86efac;border-left:4px solid #16a34a;border-radius:var(--tg-radius);font-size:13px;color:#15803d;font-weight:500}.tg-error{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff1f1;border:1px solid #fecaca;border-left:4px solid var(--tg-red);border-radius:var(--tg-radius);font-size:13px;color:var(--tg-red-dk);font-weight:500}.tg-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:0;background:var(--tg-white);border:1px solid var(--tg-border);border-radius:var(--tg-radius);overflow:hidden;box-shadow:var(--tg-shadow)}.tg-summary-card{display:flex;flex-direction:column;gap:6px;padding:16px 18px;border-right:1px solid var(--tg-border);border-bottom:1px solid var(--tg-border);position:relative}.tg-summary-card:nth-child(2n){border-right:none}.tg-summary-card:nth-child(3),.tg-summary-card:nth-child(4){border-bottom:none}.tg-summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.tg-summary-card.card-project:before{background:var(--tg-navy)}.tg-summary-card.card-duration:before{background:var(--tg-red)}.tg-summary-card.card-start:before{background:var(--tg-blue)}.tg-summary-card.card-end:before{background:var(--tg-green)}.tg-summary-label{font-size:9px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:#999}.tg-summary-value{font-size:15px;font-weight:700;color:var(--tg-black);line-height:1.2}.tg-summary-card.card-duration .tg-summary-value{color:var(--tg-red);font-size:20px;font-weight:900}.tg-summary-empty{font-size:14px;color:#ccc;font-weight:400}.tg-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.tg-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--tg-radius);font-family:var(--tg-font);font-size:12px;font-weight:700;cursor:pointer;border:none;transition:all .18s ease;white-space:nowrap}.tg-btn-navy{background:var(--tg-navy);color:var(--tg-white)}.tg-btn-navy:hover{background:#0f0f22}.tg-btn-navy:disabled{opacity:.45;cursor:not-allowed}.tg-btn-success{background:var(--tg-green);color:var(--tg-white)}.tg-btn-success:hover{background:#166534}.tg-card{background:var(--tg-white);border:1px solid var(--tg-border);border-radius:var(--tg-radius);overflow:hidden;box-shadow:var(--tg-shadow)}.tg-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;background:var(--tg-navy);border-bottom:2px solid var(--tg-red);flex-wrap:wrap}.tg-card-title{font-size:11px;font-weight:700;letter-spacing:.5px;color:#ffffffe6}.tg-header-btns{display:flex;gap:6px;flex-wrap:wrap}.tg-add-btn{padding:5px 12px;background:#ffffff1f;color:#ffffffe6;border:1px solid rgba(255,255,255,.22);border-radius:6px;font-family:var(--tg-font);font-size:11px;font-weight:700;cursor:pointer;transition:background .18s;white-space:nowrap}.tg-add-btn:hover{background:#ffffff38}.tg-add-btn.secondary{background:transparent;border-color:#ffffff26;color:#ffffff80}.tg-add-btn.secondary:hover{background:#ffffff1a;color:#ffffffe6}.tg-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.tg-table{width:100%;border-collapse:collapse;font-size:12px;font-family:var(--tg-font);min-width:520px}.tg-table thead tr{background:var(--tg-navy)}.tg-table thead th{padding:9px 10px;text-align:center;font-size:8px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:#ffffffa6;border-right:1px solid rgba(255,255,255,.06);white-space:nowrap}.tg-table thead th.th-left{text-align:left}.tg-table thead th:last-child{border-right:none}.tg-table tbody tr{border-bottom:1px solid var(--tg-border);background:var(--tg-white);transition:background .12s}.tg-table tbody tr:last-child{border-bottom:none}.tg-table tbody tr:hover{background:#fdfcfb}.tg-table tbody tr.tr-group{background:#f1f5f9}.tg-table td{padding:6px 8px;vertical-align:middle;text-align:center;border-right:1px solid var(--tg-border)}.tg-table td:last-child{border-right:none}.tg-table td.td-left{text-align:left}.tg-table td.td-dur{font-weight:900;color:var(--tg-red);font-size:13px}.tg-input{width:100%;padding:5px 8px;border:1.5px solid transparent;border-radius:5px;font-family:var(--tg-font);font-size:12px;color:var(--tg-black);background:transparent;outline:none;transition:all .15s}.tg-input:hover{border-color:var(--tg-border);background:var(--tg-white)}.tg-input:focus{border-color:var(--tg-blue);background:var(--tg-white);box-shadow:0 0 0 2px #497b971f}.tg-input::placeholder{color:#ccc}.tg-input.group-input{font-weight:700;font-size:12px;text-transform:uppercase;border:none;background:transparent}.tg-input.group-input:focus{border-bottom:2px solid var(--tg-red)}.tg-select{width:100%;padding:5px 8px;border:1.5px solid transparent;border-radius:5px;font-family:var(--tg-font);font-size:12px;color:var(--tg-black);background:transparent;outline:none;cursor:pointer;transition:all .15s}.tg-select:hover{border-color:var(--tg-border);background:var(--tg-white)}.tg-percent-cell{display:flex;align-items:center;justify-content:center;gap:3px;font-weight:700;color:var(--tg-green)}.tg-percent-input{width:44px;padding:4px 5px;border:1px solid var(--tg-border);border-radius:4px;font-family:var(--tg-font);font-size:12px;text-align:center;outline:none}.tg-remove-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;margin:0 auto;background:#fee2e2;color:var(--tg-red);border:none;border-radius:5px;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s}.tg-remove-btn:hover{background:var(--tg-red);color:var(--tg-white)}.tg-gantt-card{background:var(--tg-white);border:1px solid var(--tg-border);border-radius:var(--tg-radius);overflow:hidden;box-shadow:var(--tg-shadow)}.tg-gantt-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;background:var(--tg-navy);border-bottom:2px solid var(--tg-red);flex-wrap:wrap}.tg-gantt-legend{display:flex;gap:12px;font-size:11px;font-weight:700}.tg-legend-target{color:#ff8a87}.tg-legend-actual{color:#86efac}.tg-gantt-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.tg-gantt-table{width:100%;border-collapse:collapse;font-size:11px;font-family:var(--tg-font);table-layout:fixed;min-width:600px}.tg-gantt-table thead tr{background:var(--tg-navy)}.tg-gantt-table thead th{padding:7px 3px;text-align:center;font-size:8px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:#fff9;border-right:1px solid rgba(255,255,255,.05);white-space:nowrap}.tg-gantt-task-col{width:160px;text-align:left!important;position:sticky;left:0;z-index:2;background:var(--tg-navy);padding-left:12px!important}.tg-gantt-date-col{min-width:40px}.tg-gantt-table tbody tr{background:var(--tg-white)}.tg-gantt-table tbody tr.tr-group{background:#f1f5f9}.tg-gantt-name{text-align:left;font-size:11px;color:var(--tg-black);padding:4px 8px!important;position:sticky;left:0;background:var(--tg-white);z-index:1;min-width:140px;border-right:1px solid var(--tg-border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tg-gantt-name.name-group{background:#f1f5f9;font-weight:700;font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:#777}.tg-gantt-name.name-actual{color:#bbb;font-size:10px}.tg-label-tag{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:3px;font-size:8px;font-weight:900;color:#fff;margin-right:4px;flex-shrink:0}.tg-label-target{background:var(--tg-red)}.tg-label-actual{background:var(--tg-green)}.tg-gantt-cell{height:18px;padding:2px!important;border:1px solid #ebebeb;transition:background .1s}.tg-gantt-cell.cell-target{background:var(--tg-red)!important}.tg-gantt-cell.cell-actual{background:var(--tg-green)!important}.tg-gantt-cell.cell-group{background:#e8edf2!important}.tg-gantt-cell.cell-clickable{cursor:pointer}.tg-gantt-cell.cell-clickable:hover{background:#16a34a2e!important}.tg-gantt-hint{font-size:11px;color:#bbb;padding:7px 14px;border-top:1px solid var(--tg-border);margin:0;font-style:italic}.tg-empty{text-align:center;color:#bbb;font-size:13px;padding:24px 16px;background:var(--tg-surface);border-radius:var(--tg-radius);border:1px dashed var(--tg-border);font-style:italic}@media(min-width:600px){.tg-section{gap:20px}.tg-summary{grid-template-columns:repeat(4,1fr)}.tg-summary-card{border-bottom:none}.tg-summary-card:nth-child(2n){border-right:1px solid var(--tg-border)}.tg-summary-card:last-child{border-right:none}.tg-summary-card.card-project,.tg-summary-card.card-duration,.tg-summary-card.card-start{border-right:1px solid var(--tg-border)}.tg-gantt-task-col{width:200px}}@media(min-width:900px){.tg-section{gap:24px}.tg-summary-value{font-size:17px}.tg-summary-card.card-duration .tg-summary-value{font-size:22px}.tg-summary-card{padding:22px 28px}.tg-table{min-width:unset}}:root{--cc-navy: #1A1A2E;--cc-blue: #497B97;--cc-red: #FF1817;--cc-red-dark: #C20100;--cc-cream: #EBDBD6;--cc-black: #221F1F;--cc-green: #16a34a;--cc-border: #D9CBC5;--cc-surface: #F5F2F0;--cc-white: #FFFFFF;--cc-radius: 8px;--cc-shadow: 0 2px 12px rgba(34,31,31,.1);--cc-font: "DM Sans", sans-serif}.cc-section{display:flex;flex-direction:column;gap:20px;font-family:var(--cc-font);color:var(--cc-black)}.cc-installer-header{display:grid;grid-template-columns:1fr auto;gap:20px;background:var(--cc-white);border:1px solid var(--cc-border);border-radius:var(--cc-radius);padding:20px 24px;box-shadow:var(--cc-shadow)}.cc-project-meta{display:flex;flex-direction:column;gap:8px}.cc-meta-row{display:flex;align-items:baseline;gap:12px}.cc-meta-label{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--cc-blue);min-width:110px;flex-shrink:0}.cc-meta-value{font-size:14px;font-weight:500;color:var(--cc-black)}.cc-meta-empty{color:#aaa;font-style:italic}.cc-date-picker-block{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.cc-date-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--cc-black)}.cc-date-input{padding:10px 14px;border:2px solid var(--cc-blue);border-radius:var(--cc-radius);font-family:var(--cc-font);font-size:14px;font-weight:600;color:var(--cc-navy);outline:none;cursor:pointer}.cc-date-input:focus{border-color:var(--cc-red)}.cc-date-badge{font-size:12px;font-weight:600;padding:3px 12px;border-radius:20px;background:#497b971f;color:var(--cc-blue)}.cc-field-row{display:flex;align-items:center;gap:16px}.cc-area-input{max-width:280px;margin:0!important}.cc-timeline-section{padding:20px 24px}.cc-section-title{font-size:13px;font-weight:700;color:var(--cc-navy);margin-bottom:14px;display:block}.cc-timeline-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.cc-completion-big{font-size:28px!important;font-weight:900!important;color:var(--cc-red)!important;text-align:center}.cc-photo-section{padding:20px 24px}.cc-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:12px}.cc-upload-zone{display:flex;align-items:center;gap:10px;padding:12px 16px;border:1.5px dashed var(--cc-blue);border-radius:var(--cc-radius);background:#497b970a;cursor:pointer;font-size:13px;color:var(--cc-blue);font-weight:500;transition:background .2s,border-color .2s}.cc-upload-zone:hover{background:#497b971a;border-color:var(--cc-red)}.cc-file-hidden{display:none}.cc-history-block{border-top:2px solid var(--cc-border);padding-top:20px}.cc-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.cc-history-list{display:flex;flex-direction:column;gap:8px}.cc-history-item{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--cc-white);border:1px solid var(--cc-border);border-radius:var(--cc-radius);cursor:pointer;transition:border-color .18s,background .18s}.cc-history-item:hover{border-color:var(--cc-blue);background:#497b970a}.cc-history-meta{font-size:12px;color:#888}.cc-history-tag{font-size:11px;font-weight:700;color:var(--cc-blue);text-transform:uppercase;letter-spacing:.5px}.cc-table-card{background:var(--cc-white);border:1px solid var(--cc-border);border-radius:var(--cc-radius);overflow:hidden;box-shadow:var(--cc-shadow)}.cc-table-head-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;background:var(--cc-navy);border-bottom:2px solid var(--cc-red)}.cc-table-title{color:#fff;font-size:13px;font-weight:700;letter-spacing:.5px}.cc-add-row-btn{padding:6px 16px;background:var(--cc-blue);color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;transition:background .2s}.cc-add-row-btn:hover{background:#3a6a85}.cc-add-section-btn{padding:6px 16px;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;transition:background .2s}.cc-add-section-btn:hover{background:#ffffff40}.cc-btn-group{display:flex;gap:8px}.cc-table-scroll{overflow-x:auto}.cc-table{width:100%;border-collapse:collapse;font-size:12px;font-family:var(--cc-font)}.cc-table thead tr{background:var(--cc-navy);border-bottom:2px solid var(--cc-red)}.cc-table thead th{padding:10px 12px;text-align:center;color:#ffffffe6;font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;border:1px solid rgba(255,255,255,.1);white-space:nowrap}.cc-table tbody tr{border-bottom:1px solid var(--cc-border);background:var(--cc-white);transition:background .15s}.cc-table tbody tr:last-child{border-bottom:none}.cc-table tbody tr:hover{background:#fafafa}.cc-table tbody tr.cc-tr-filled{background:#f6fbf8}.cc-table tbody tr.cc-tr-group{background:#f1f5f9}.cc-table td{padding:7px 10px;vertical-align:middle;text-align:center;border:1px solid var(--cc-border)}.cc-cell-input{width:100%;padding:6px 10px;border:1px solid var(--cc-border);border-radius:5px;font-family:var(--cc-font);font-size:12px;color:var(--cc-black);background:#fff;outline:none;transition:border-color .18s}.cc-cell-input:focus{border-color:var(--cc-blue)}.cc-group-input{font-weight:700;text-transform:uppercase;background:transparent;border:none}.cc-group-input:focus{border-bottom:2px solid var(--cc-red)}.cc-th-num{width:40px}.cc-td-num{text-align:center;color:#aaa;font-size:11px;font-weight:600}.cc-td-center{text-align:center}.cc-td-left{text-align:left!important}.cc-td-bold{font-weight:700;text-align:center}.cc-td-red{color:var(--cc-red)!important;font-weight:900}.cc-remove-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;margin:0 auto;background:#fee2e2;color:var(--cc-red);border:none;border-radius:5px;font-size:11px;font-weight:700;cursor:pointer;transition:background .15s}.cc-remove-btn:hover:not(:disabled){background:var(--cc-red);color:#fff}.cc-remove-btn:disabled{opacity:.3;cursor:not-allowed}.cc-timeline-summary{display:flex;gap:12px;flex-wrap:wrap}.cc-summary-card{background:var(--cc-white);border:1px solid var(--cc-border);border-radius:var(--cc-radius);padding:12px 18px;display:flex;flex-direction:column;gap:4px;min-width:120px;box-shadow:var(--cc-shadow)}.cc-summary-card.cc-summary-red .cc-summary-val{color:var(--cc-red);font-weight:900}.cc-summary-label{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#888}.cc-summary-val{font-size:15px;font-weight:700;color:var(--cc-navy)}.cc-summary-input{padding:4px 8px;border:1.5px solid var(--cc-border);border-radius:5px;font-size:14px;font-weight:700;width:60px;text-align:center;outline:none;font-family:var(--cc-font)}.cc-percent-cell{display:flex;align-items:center;justify-content:center;gap:4px;font-weight:700;color:var(--cc-green)}.cc-percent-input{width:50px;border:1px solid var(--cc-border);border-radius:5px;padding:4px 6px;text-align:center;font-family:var(--cc-font);font-size:12px;outline:none}.cc-gantt-table{table-layout:fixed;min-width:800px}.cc-gantt-task-col{width:200px;text-align:left!important;position:sticky;left:0;z-index:2;background:var(--cc-navy)}.cc-gantt-date-col{min-width:50px;font-size:9px!important;padding:6px 4px!important}.cc-gantt-task-name{text-align:left;font-size:11px;color:var(--cc-black);padding:5px 10px!important;position:sticky;left:0;background:var(--cc-white);z-index:1;min-width:180px}.cc-gantt-actual-label{color:#aaa;font-size:10px}.cc-group-cell,.cc-gantt-group-cell{background:#f1f5f9!important}.cc-gantt-cell{padding:3px!important;min-width:50px;height:18px;border:1px solid #e5e5e5}.cc-gantt-target{background:var(--cc-red)!important}.cc-gantt-actual{background:var(--cc-green)!important}.cc-gantt-clickable{cursor:pointer;transition:background .15s}.cc-gantt-clickable:hover{background:#16a34a33}.cc-gantt-target-row td{height:18px}.cc-gantt-actual-row td{height:16px}.cc-gantt-legend{display:flex;gap:12px;font-size:12px;font-weight:600}.cc-legend-red{color:var(--cc-red)}.cc-legend-green{color:var(--cc-green)}.cc-gantt-hint{font-size:11px;color:#aaa;padding:8px 16px;border-top:1px solid var(--cc-border);margin:0}.cc-gantt-empty{text-align:center;color:#aaa;font-size:13px;padding:24px;background:var(--cc-surface);border-radius:var(--cc-radius);border:1px dashed var(--cc-border)}.cc-gantt-label-tag{display:inline-block;padding:1px 5px;border-radius:3px;font-size:9px;font-weight:700;color:#fff;margin-right:4px}.cc-tag-target{background:var(--cc-red)}.cc-tag-actual{background:var(--cc-green)}.cc-mb-20{margin-bottom:20px}.cc-materials-meta{padding:16px 20px}.cc-meta-grid-6{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.cc-meta-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.cc-tab-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.cc-date-row{display:flex;align-items:center;gap:12px}.cc-btn-row{display:flex;gap:8px}.cc-no-margin{margin:0!important}.cc-materials-table{min-width:max-content}.cc-th-date-col{background:#fef2f2!important;color:var(--cc-red)!important}.cc-text-blue{color:var(--cc-blue)!important;font-weight:700}.cc-text-red{color:var(--cc-red)!important;font-weight:700}.cc-text-green{color:var(--cc-green)!important;font-weight:700}.cc-w-full{min-width:120px}.cc-w-num{max-width:70px;text-align:center}.cc-th-left,.cc-td-left{text-align:left!important}.cc-insp-meta{padding:16px 20px}.cc-insp-form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.cc-insp-block{background:var(--cc-white);border:1px solid var(--cc-border);border-radius:var(--cc-radius);overflow:hidden;box-shadow:var(--cc-shadow)}.cc-insp-block-header{font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:10px 16px}.cc-insp-header-green{background:#d6e4bc;color:#2d5016}.cc-insp-textarea{width:100%;border:none!important;border-radius:0!important;resize:vertical;padding:14px 16px;font-family:var(--cc-font);font-size:13px}.cc-insp-ps-header{display:grid;grid-template-columns:1fr 1fr}.cc-insp-col-header{flex:1}.cc-insp-ps-row{display:grid;grid-template-columns:28px 1fr 1fr 28px;gap:0;border-bottom:1px solid var(--cc-border);align-items:stretch}.cc-insp-ps-num{display:flex;align-items:flex-start;justify-content:center;padding:12px 4px;font-size:11px;font-weight:700;color:#aaa;border-right:1px solid var(--cc-border);background:#f9f9f9}.cc-insp-ps-area{border:none!important;border-radius:0!important;border-right:1px solid var(--cc-border)!important;resize:none;padding:12px 14px;font-size:13px;font-family:var(--cc-font)}.cc-ps-remove{margin:8px auto!important;align-self:flex-start}.cc-add-problem-btn{display:block;width:100%;padding:12px;background:#497b970f;border:none;border-top:1px dashed var(--cc-border);font-family:var(--cc-font);font-size:13px;font-weight:600;color:var(--cc-blue);cursor:pointer;text-align:center;transition:background .2s}.cc-add-problem-btn:hover{background:#497b971f}.cc-action-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.cc-timeline-section .cc-timeline-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media(max-width:900px){.cc-installer-header{grid-template-columns:1fr}.cc-timeline-grid{grid-template-columns:1fr 1fr}.cc-photo-grid{grid-template-columns:1fr}.cc-meta-grid-6,.cc-meta-grid-4{grid-template-columns:repeat(2,1fr)}.cc-insp-form-row{grid-template-columns:1fr}.cc-insp-ps-row{grid-template-columns:24px 1fr 1fr 24px}.cc-timeline-summary{flex-direction:column}}@media(max-width:600px){.cc-insp-ps-row{grid-template-columns:1fr}.cc-insp-ps-num{display:none}.cc-timeline-grid{grid-template-columns:1fr}}.pm-cc-wrapper{display:flex;flex-direction:column;gap:16px;width:100%}.pm-cc-wrapper .pm-card{padding:0!important;overflow:hidden!important;display:flex;flex-direction:column;height:auto;min-height:0;margin-bottom:0;transition:none;cursor:default}.pm-cc-wrapper .pm-card:hover{transform:none;box-shadow:var(--pm-shadow);border-color:var(--pm-border-soft)}.pm-cc-wrapper .pm-card>.pm-card-navy{flex-shrink:0;border-radius:0}.pm-cc-nav-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.pm-navy-orange{background:#f97316!important}.pm-in-progress-badge{background:#16a34a;color:#fff;padding:5px 15px;border-radius:20px;font-weight:900;font-size:12px;white-space:nowrap}.pm-cc-wrapper .pm-tabs-wrapper{flex-shrink:0;display:flex;width:100%}.pm-cc-wrapper .pm-tab-btn{flex:1;text-align:center}.pm-cc-body{padding:30px;height:auto;overflow:visible;flex:1 1 auto;display:flex;flex-direction:column;gap:20px}.pm-cc-wrapper .pm-card-gray,.pm-cc-wrapper .pm-card-cream,.pm-cc-wrapper .pm-card-red{margin-bottom:0;height:auto;overflow:visible}.pm-cream-orange{background:#fff7ed!important;border-color:#fdba74!important}.pm-checklist-orange{border-color:#fed7aa!important}.pm-text-white{color:#fff;margin:0}.pm-text-orange{color:var(--pm-orange);margin:0}.pm-text-orange-dark{color:#c2410c}.pm-text-blue{color:var(--pm-blue)}.pm-text-red{color:var(--pm-red)}.pm-text-green{color:#16a34a}.pm-text-navy{color:var(--pm-navy)}.pm-no-margin{margin:0}.pm-tab-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:15px}.pm-btn-row{display:flex;gap:10px}.pm-date-row{display:flex;align-items:center;gap:15px}.pm-date-input{width:auto!important;margin:0!important;padding:10px!important}.pm-btn-ghost{background:transparent;border:none;font-size:13px;font-weight:600;color:var(--pm-blue);cursor:pointer;padding:4px 0}.pm-btn-muted{color:var(--pm-text-muted)!important;border-color:var(--pm-text-muted)!important}.pm-input-flush{margin:0!important}.pm-input-sm{margin:0!important;padding:5px!important;font-size:12px!important}.pm-input-readonly{background:#f1f5f9!important}.pm-completion-input{font-size:24px!important;color:var(--pm-red)!important}.pm-consumed-input{color:var(--pm-red)!important;font-weight:900!important}.pm-table-wide{min-width:max-content}.pm-mb-24{margin-bottom:24px!important}.pm-th-cream{background:var(--pm-cream)!important}.pm-th-md{font-size:14px!important}.pm-th-lg{font-size:16px!important}.pm-th-date-col{background:#fef2f2!important;color:var(--pm-red)!important}.pm-td-bold{font-weight:900}.pm-td-project-name{font-weight:900;color:var(--pm-navy)}.pm-td-duration{font-weight:900;color:var(--pm-red)}.pm-td-percent{background:#f0fdf4}.pm-tr-group{background:#f1f5f9}.pm-tr-selected{background:#f973160d}.pm-photo-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:20px;background:#f8f9fa}.pm-file-input-compact{margin:0!important;padding:10px!important}.pm-add-row-footer{padding:15px}.pm-history-section{border-top:2px solid var(--pm-border-soft);padding-top:30px;margin-top:20px}.pm-history-controls{display:flex;align-items:center;gap:10px}.pm-filter-input{width:200px!important;margin:0!important;padding:10px!important;display:inline-block!important}.pm-log-card-wrap{flex-wrap:wrap;gap:15px}.pm-log-stats{font-weight:700;margin:5px 0}.pm-req-items-list{font-weight:700;color:var(--pm-navy);margin:0;padding-left:0;list-style:none}.pm-req-status-dispatched{background:#dcfce7!important;color:#16a34a!important}.pm-req-status-denied{background:#fef2f2!important;color:#c1121f!important}.pm-req-status-pending{background:var(--pm-cream)!important;color:var(--pm-navy)!important}.pm-percent-cell{display:flex;align-items:center;justify-content:center;font-weight:900;color:#16a34a}.pm-percent-input{margin:0!important;background:transparent!important;border:none!important;width:60px!important;padding:5px!important}.pm-timeline-add-row{display:flex;gap:10px;margin-top:15px}.pm-card-solution{background:#f0fdf4!important;border:2px solid #bbf7d0!important}.pm-label-green{color:#16a34a!important}.pm-issue-problem-block{border-bottom:1px solid var(--pm-border-soft);padding-bottom:15px;margin-bottom:15px}.pm-section-divider{border:none;border-top:2px dashed var(--pm-border-soft);margin:40px 0}.pm-insp-card{overflow:visible!important;margin-bottom:20px;display:flex;flex-direction:column}.pm-insp-card>.pm-card-navy{border-radius:0;overflow:hidden;flex-shrink:0}.pm-insp-card-footer{display:flex;gap:10px;padding:15px;background:#fff}.pm-insp-title-input{background:transparent!important;border:none!important;color:#fff!important;font-weight:900!important;text-transform:uppercase!important;text-align:center!important;width:100%!important;padding:10px!important;margin:0!important}.pm-th-check-item{text-align:left!important;width:35%!important}.pm-insp-group-input{margin:0!important;background:transparent!important;border:none!important;text-transform:uppercase!important;font-weight:900!important}.pm-insp-cell-input{margin:0!important;background:transparent!important;border:none!important}.pm-insp-score-input{margin:0!important;padding:5px!important;background:transparent!important;border:none!important}.pm-insp-attach-header span{font-weight:900;text-transform:uppercase;letter-spacing:1px;color:#fff}.pm-insp-attach-body{padding:30px}.pm-modal-orange{border-top-color:var(--pm-orange)!important}.pm-modal-table-scroll{max-height:400px;overflow-y:auto}.pm-thead-sticky{position:sticky;top:0;z-index:10;background:var(--pm-surface-2)}.pm-req-qty-input{width:80px!important;margin:0 auto!important;padding:8px!important}.pm-req-qty-active{border-color:var(--pm-orange)!important}.pm-req-checkbox{width:22px;height:22px;accent-color:var(--pm-orange);cursor:pointer}@media(max-width:768px){.pm-cc-body{padding:18px 16px 24px}.pm-photo-row{grid-template-columns:1fr}.pm-tab-toolbar,.pm-cc-nav-header{flex-direction:column;align-items:flex-start}}:root{--bill-black: #221F1F;--bill-black-deep: #151313;--bill-black-mid: #2d2929;--bill-red: #FF1817;--bill-red-dark: #C20100;--bill-red-deeper: #A00101;--bill-blue: #497B97;--bill-cream: #EBDBD6;--bill-white: #FFFFFF;--bill-surface: #F8F6F3;--bill-border-soft: #E2D9D2;--bill-radius: 12px;--bill-radius-sm: 8px;--bill-font: "DM Sans", sans-serif}.bill-wrapper{font-family:var(--bill-font);color:var(--bill-black);border-radius:var(--bill-radius);overflow:hidden;background:var(--bill-white);border:1px solid var(--bill-border-soft);box-shadow:0 4px 24px #221f1f21;animation:bill-fadein .28s ease}@keyframes bill-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.bill-header{position:relative;padding:0;min-height:80px;background:linear-gradient(135deg,var(--bill-black-deep) 0%,var(--bill-black) 55%,var(--bill-black-mid) 100%);border-bottom:3px solid var(--bill-red)}.bill-header:before{content:"";position:absolute;top:0;right:-40px;bottom:0;width:220px;transform:skew(-16deg);background:#ff181717;z-index:0}.bill-header:after{content:"";position:absolute;top:0;right:-120px;bottom:0;width:160px;transform:skew(-16deg);background:#ff18170a;z-index:0}.bill-header-inner{display:flex;align-items:center;gap:16px;padding:20px 28px;position:relative;z-index:1}.bill-header-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;font-size:22px;flex-shrink:0;background:#ff181724;border:1px solid rgba(255,24,23,.35)}.bill-header-text{display:flex;flex-direction:column;gap:3px}.bill-header-title{font-size:17px;font-weight:800;color:var(--bill-white);margin:0;letter-spacing:.2px}.bill-header-subtitle{font-size:10px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:#ff6464bf}.bill-body{padding:24px 28px 28px;display:flex;flex-direction:column;gap:20px;background:var(--bill-white)}.bill-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.bill-statement{background:var(--bill-surface);border:1px solid var(--bill-border-soft);border-radius:var(--bill-radius);padding:22px 22px 22px 26px;display:flex;flex-direction:column;gap:0;position:relative;overflow:hidden}.bill-statement:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--bill-red) 0%,var(--bill-red-dark) 100%)}.bill-statement-title{font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#999;padding-bottom:14px;border-bottom:1px solid var(--bill-border-soft);margin-bottom:16px}.bill-statement-row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px dashed var(--bill-border-soft)}.bill-statement-row:last-child{border-bottom:none}.bill-statement-label{font-size:12px;color:#888;font-weight:500}.bill-statement-value{font-size:15px;font-weight:700;color:var(--bill-black)}.bill-percent-badge{display:inline-flex;align-items:center;padding:5px 14px;border-radius:20px;font-size:13px;font-weight:900;letter-spacing:.5px}.bill-percent-badge.progress{background:#eff6ff;color:var(--bill-blue);border:1px solid rgba(73,123,151,.25)}.bill-percent-badge.final{background:#ff181712;color:var(--bill-red-dark);border:1px solid rgba(255,24,23,.22)}.bill-payable-row{display:flex;justify-content:space-between;align-items:center;padding:16px 0 2px;margin-top:6px;border-top:2px dashed var(--bill-border-soft)}.bill-payable-label{font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--bill-black)}.bill-payable-amount{font-size:22px;font-weight:900;color:var(--bill-red-dark);letter-spacing:-.5px}.bill-proof-card{background:var(--bill-surface);border:1px solid var(--bill-border-soft);border-radius:var(--bill-radius);padding:22px 22px 22px 26px;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden}.bill-proof-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--bill-red) 0%,var(--bill-red-dark) 100%)}.bill-proof-title{font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#999;padding-bottom:14px;border-bottom:1px solid var(--bill-border-soft)}.bill-site-photo{width:100%;height:180px;object-fit:cover;border-radius:var(--bill-radius-sm);border:1px solid var(--bill-border-soft);display:block}.bill-photo-empty{width:100%;height:180px;background:var(--bill-white);border-radius:var(--bill-radius-sm);border:1.5px dashed var(--bill-border-soft);display:flex;align-items:center;justify-content:center}.bill-photo-empty-text{font-size:12px;color:#bbb;margin:0}.bill-photo-date{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#aaa}.bill-upload-section{background:var(--bill-surface);border:1px solid var(--bill-border-soft);border-top:3px solid var(--bill-red);border-radius:var(--bill-radius);padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.bill-upload-title{font-size:15px;font-weight:800;color:var(--bill-black);margin:0}.bill-upload-desc{font-size:12px;color:#888;margin:0;max-width:440px;line-height:1.6}.bill-upload-zone{display:flex;align-items:center;gap:12px;padding:13px 22px;border:1.5px dashed #c8bdb5;border-radius:var(--bill-radius-sm);background:var(--bill-white);cursor:pointer;font-size:13px;font-weight:600;color:#888;transition:all .18s ease;width:100%;max-width:440px}.bill-upload-zone:hover{border-color:var(--bill-red);background:#ff181708;color:var(--bill-red-dark)}.bill-upload-zone.has-file{border-color:var(--bill-red-dark);border-style:solid;background:#ff18170d;color:var(--bill-red-dark)}.bill-file-hidden{display:none}@media(max-width:700px){.bill-grid{grid-template-columns:1fr}.bill-body{padding:16px 16px 20px;gap:14px}.bill-header-inner{padding:16px 18px}.bill-statement,.bill-proof-card{padding:16px 16px 16px 20px}.bill-upload-section{padding:20px 16px}}:root{--pc-black: #221F1F;--pc-black-deep: #151313;--pc-black-mid: #2d2929;--pc-red: #FF1817;--pc-red-dark: #C20100;--pc-red-deeper: #A00101;--pc-blue: #497B97;--pc-blue-light: #6da0bc;--pc-cream: #EBDBD6;--pc-white: #FFFFFF;--pc-surface: #F8F6F3;--pc-border: #E2D9D2;--pc-border-mid: #C8BDB5;--pc-radius: 12px;--pc-radius-sm: 8px;--pc-font: "DM Sans", sans-serif;--pc-shadow: 0 4px 24px rgba(34,31,31,.11);--pc-shadow-sm: 0 2px 8px rgba(34,31,31,.07)}.pc-wrapper{font-family:var(--pc-font);color:var(--pc-black);display:flex;flex-direction:column;gap:20px;animation:pc-fadein .3s ease}@keyframes pc-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pc-hero{position:relative;border-radius:var(--pc-radius);overflow:hidden;background:linear-gradient(135deg,var(--pc-black-deep) 0%,var(--pc-black) 55%,var(--pc-black-mid) 100%);border-bottom:4px solid var(--pc-red);box-shadow:var(--pc-shadow);padding:36px 40px 32px}.pc-hero:before{content:"";position:absolute;top:0;right:-60px;bottom:0;width:300px;transform:skew(-16deg);background:#ff181714;pointer-events:none}.pc-hero:after{content:"";position:absolute;top:0;right:-160px;bottom:0;width:200px;transform:skew(-16deg);background:#ff18170a;pointer-events:none}.pc-hero-inner{position:relative;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.pc-hero-left{display:flex;flex-direction:column;gap:8px}.pc-hero-eyebrow{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#ff1817bf;margin:0}.pc-hero-title{font-size:32px;font-weight:900;color:var(--pc-white);margin:0;letter-spacing:-.5px;line-height:1.15;display:flex;align-items:center;gap:12px}.pc-hero-project{font-size:14px;font-weight:600;color:#ffffff8c;margin:0;letter-spacing:.2px}.pc-hero-project span{color:#ffffffe6;font-weight:700}.pc-status-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;background:#ff181726;border:1px solid rgba(255,24,23,.35);border-radius:20px;font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#ff9696e6;white-space:nowrap;align-self:flex-start;margin-top:4px}.pc-status-dot{width:6px;height:6px;border-radius:50%;background:var(--pc-red);box-shadow:0 0 6px var(--pc-red);animation:pc-pulse 2s ease-in-out infinite}@keyframes pc-pulse{0%,to{opacity:1}50%{opacity:.4}}.pc-vault-card{background:var(--pc-white);border:1px solid var(--pc-border);border-radius:var(--pc-radius);overflow:hidden;box-shadow:var(--pc-shadow-sm)}.pc-vault-toolbar{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--pc-black);border-bottom:3px solid var(--pc-red);flex-wrap:wrap;gap:12px}.pc-vault-toolbar-left{display:flex;align-items:center;gap:10px}.pc-vault-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#ff181724;border:1px solid rgba(255,24,23,.3);border-radius:8px;font-size:16px;flex-shrink:0}.pc-vault-title{font-size:14px;font-weight:800;color:var(--pc-white);margin:0}.pc-vault-actions{display:flex;gap:10px;flex-wrap:wrap}.pc-btn-red{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--pc-red);color:var(--pc-white);border:none;border-radius:var(--pc-radius-sm);font-family:var(--pc-font);font-size:12px;font-weight:700;cursor:pointer;transition:background .18s;white-space:nowrap}.pc-btn-red:hover{background:var(--pc-red-dark)}.pc-btn-outline{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;color:#fffc;border:1.5px solid rgba(255,255,255,.2);border-radius:var(--pc-radius-sm);font-family:var(--pc-font);font-size:12px;font-weight:700;cursor:pointer;transition:all .18s;white-space:nowrap}.pc-btn-outline:hover{background:#ffffff14;border-color:#fff6}.pc-vault-body{padding:24px}.pc-vault-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.pc-vault-section{display:flex;flex-direction:column;gap:0;border:1px solid var(--pc-border);border-radius:var(--pc-radius-sm);overflow:hidden}.pc-vault-section-header{padding:10px 14px;font-size:9px;font-weight:900;letter-spacing:1.5px;text-transform:uppercase;border-bottom:2px solid var(--pc-border)}.pc-vault-section.section-technical .pc-vault-section-header{background:#497b9714;color:var(--pc-blue);border-bottom-color:var(--pc-blue)}.pc-vault-section.section-procurement .pc-vault-section-header{background:#ff18170f;color:var(--pc-red-dark);border-bottom-color:var(--pc-red)}.pc-vault-section.section-financial .pc-vault-section-header{background:#221f1f0d;color:var(--pc-black);border-bottom-color:var(--pc-black-mid)}.pc-vault-section.section-turnover .pc-vault-section-header{background:#c201000f;color:var(--pc-red-dark);border-bottom-color:var(--pc-red-dark)}.pc-vault-docs{display:flex;flex-direction:column;gap:0;background:var(--pc-surface);flex:1}.pc-contract-block{padding:14px;border-top:1px dashed var(--pc-border);background:var(--pc-white)}.pc-contract-label{font-size:9px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:#aaa;margin:0 0 4px}.pc-contract-amount{font-size:18px;font-weight:900;color:var(--pc-black);margin:0;letter-spacing:-.3px}.pc-archive-card{background:var(--pc-white);border:1px solid var(--pc-border);border-top:3px solid var(--pc-red);border-radius:var(--pc-radius);padding:28px 32px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;box-shadow:var(--pc-shadow-sm)}.pc-archive-title{font-size:16px;font-weight:800;color:var(--pc-black);margin:0}.pc-archive-desc{font-size:13px;color:#888;margin:0;max-width:440px;line-height:1.6}@media(max-width:960px){.pc-vault-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.pc-vault-grid{grid-template-columns:1fr}.pc-hero{padding:24px 20px}.pc-hero-title{font-size:24px}.pc-vault-body{padding:14px}.pc-vault-toolbar{padding:12px 16px}.pc-archive-card{padding:20px 16px}}@media print{.pc-vault-actions,.pc-archive-card{display:none!important}.pc-hero{border-radius:0}.pc-vault-card{box-shadow:none;border:1px solid #ccc}}:root{--pm-black: #221F1F;--pm-red: #C20100;--pm-dark-red: #A00101;--pm-blue: #497B97;--pm-blue-dark: #3A6480;--pm-cream: #EBDBD6;--pm-cream-dark: #DFD0CA;--pm-navy: #1A2E40;--pm-orange: #f97316;--pm-green: #16a34a;--pm-white: #ffffff;--pm-surface: #f8f6f4;--pm-surface-2: #f0ece9;--pm-border-soft: #E0D9D4;--pm-border-md: #C8BDB8;--pm-text-dark: #221F1F;--pm-text-muted: #7A706C;--pm-text-light: #B0A49F;--pm-font: "DM Sans", sans-serif;--pm-radius: 12px;--pm-radius-sm: 8px;--pm-shadow: 0 2px 12px rgba(34,31,31,.08);--pm-shadow-lg: 0 8px 32px rgba(34,31,31,.12)}.pm-container,.pm-container *{font-family:var(--pm-font);box-sizing:border-box}.pm-container{min-height:100vh;background:var(--pm-surface);padding:0}.pm-phase-container{padding:1.5rem 2rem 3rem;max-width:1400px;margin:0 auto}.pm-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding:1.1rem 2rem;background:var(--pm-white);border-bottom:3px solid var(--pm-red);box-shadow:0 2px 8px #221f1f0f}.pm-header-left{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap}.pm-header-title{font-size:1.25rem;font-weight:900;color:var(--pm-black);margin:0}.pm-header-title span{color:var(--pm-red)}.pm-back-btn{background:transparent;border:1.5px solid var(--pm-border-md);color:var(--pm-text-muted);border-radius:var(--pm-radius-sm);padding:.45rem 1rem;font-family:var(--pm-font);font-size:.75rem;font-weight:700;cursor:pointer;letter-spacing:.04em;transition:all .15s}.pm-back-btn:hover{background:var(--pm-black);color:var(--pm-white);border-color:var(--pm-black)}.pm-back-phase-btn{display:inline-flex;align-items:center;gap:5px;background:#c2010012;border:1.5px dashed var(--pm-red);color:var(--pm-red);border-radius:var(--pm-radius-sm);padding:.38rem .85rem;font-family:var(--pm-font);font-size:.75rem;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap}.pm-back-phase-btn:hover{background:var(--pm-red);color:#fff;border-style:solid}.pm-back-phase-btn:disabled{opacity:.5;cursor:not-allowed}.pm-personnel-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;background:var(--pm-black);padding:.65rem 2rem;border-bottom:2px solid rgba(194,1,0,.4)}.pm-personnel-left{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;font-size:.78rem;color:#ffffffbf}.pm-personnel-left strong{color:#fff}.pm-personnel-sep{display:flex;align-items:center;gap:.4rem}.pm-personnel-sep:before{content:"·";color:#ffffff4d;margin-right:.2rem}.pm-personnel-missing{color:#ffffff4d!important;font-style:italic;font-weight:400!important}.pm-mode-badge{background:#ebdbd61f;color:var(--pm-cream);border:1px solid rgba(235,219,214,.22);font-size:.68rem;font-weight:800;padding:.25rem .75rem;border-radius:20px;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.pm-card{background:var(--pm-white);border:1px solid var(--pm-border-soft);border-radius:var(--pm-radius);padding:1.5rem;margin-bottom:1.25rem;box-shadow:var(--pm-shadow)}.pm-card-gray{background:var(--pm-surface-2);border:1px solid var(--pm-border-soft);border-radius:var(--pm-radius);padding:1.5rem;margin-bottom:1.25rem}.pm-card-cream{background:#fdf7f5;border:1.5px solid var(--pm-cream-dark);border-radius:var(--pm-radius);padding:1.5rem;margin-bottom:1.25rem}.pm-card-red{background:#fef2f2;border:1.5px solid #FECACA;border-left:4px solid var(--pm-red);border-radius:var(--pm-radius);padding:1.25rem 1.5rem;margin-bottom:1.25rem}.pm-card-navy{background:var(--pm-black);border-bottom:2px solid var(--pm-red);padding:.9rem 1.5rem}.pm-card-green{background:linear-gradient(135deg,#064e3b,#065f46);border-radius:var(--pm-radius);padding:2rem 2.5rem;margin-bottom:1.25rem}.pm-action-card{background:var(--pm-white);border:1px solid var(--pm-border-soft);border-radius:var(--pm-radius);padding:1.5rem;text-align:center;margin-bottom:1rem}.pm-action-card[data-variant=orange]{border-top:3px solid var(--pm-orange)}.pm-action-card[data-variant=blue]{border-top:3px solid var(--pm-blue)}.pm-action-card[data-variant=red]{border-top:3px solid var(--pm-red)}.pm-action-title{font-size:1rem;font-weight:800;color:var(--pm-black);margin:0 0 .5rem}.pm-action-card[data-variant=orange] .pm-action-title{color:var(--pm-orange)}.pm-action-card[data-variant=blue] .pm-action-title{color:var(--pm-blue)}.pm-action-card[data-variant=red] .pm-action-title{color:var(--pm-red)}.pm-waiting-wrapper{display:flex;flex-direction:column;gap:1.5rem;padding:0 0 2rem}.pm-waiting-card{background:#fffbeb;border:2px solid #FCD34D;border-radius:var(--pm-radius);padding:2.5rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.8rem}.pm-waiting-icon{font-size:3rem;animation:pm-pulse 2s ease-in-out infinite}@keyframes pm-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}.pm-waiting-title{font-size:1.3rem;font-weight:900;color:#92400e;margin:0}.pm-waiting-msg{font-size:.95rem;color:#78350f;line-height:1.7;margin:0;max-width:540px}.pm-waiting-badge{display:inline-block;background:#fef3c7;border:1.5px solid #F59E0B;color:#92400e;font-size:.72rem;font-weight:800;padding:.3rem .9rem;border-radius:20px;text-transform:uppercase;letter-spacing:.06em}.pm-waiting-hint{font-size:.78rem;color:#a16207;margin:0;line-height:1.6;opacity:.85}.pm-readonly-summary{background:var(--pm-white);border:1px solid var(--pm-border-soft);border-radius:var(--pm-radius);overflow:hidden;box-shadow:var(--pm-shadow)}.pm-readonly-header{background:var(--pm-black);color:#fffc;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.6rem 1.1rem;border-bottom:2px solid var(--pm-red)}.pm-readonly-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.pm-readonly-item{display:flex;flex-direction:column;gap:.25rem;padding:.9rem 1.1rem;border-right:1px solid var(--pm-border-soft);border-bottom:1px solid var(--pm-border-soft)}.pm-readonly-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--pm-text-muted)}.pm-readonly-val{font-size:.85rem;font-weight:600;color:var(--pm-black)}.pm-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1.5rem;border-radius:var(--pm-radius-sm);font-family:var(--pm-font);font-size:.85rem;font-weight:700;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}.pm-btn:disabled{opacity:.5;cursor:not-allowed}.pm-btn-navy{background:var(--pm-black);color:#fff}.pm-btn-navy:hover:not(:disabled){background:#3a3737}.pm-btn-red{background:var(--pm-red);color:#fff}.pm-btn-red:hover:not(:disabled){background:var(--pm-dark-red)}.pm-btn-green{background:var(--pm-green);color:#fff}.pm-btn-green:hover:not(:disabled){background:#15803d}.pm-btn-orange{background:var(--pm-orange);color:#fff}.pm-btn-orange:hover:not(:disabled){background:#ea580c}.pm-btn-outline{background:transparent;border:1.5px solid var(--pm-border-md);color:var(--pm-text-dark);border-radius:var(--pm-radius-sm);padding:.55rem 1.1rem;font-family:var(--pm-font);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.pm-btn-outline:hover{background:var(--pm-surface-2)}.pm-btn-icon-danger{background:none;border:none;cursor:pointer;color:var(--pm-red);font-weight:900;font-size:1rem;padding:.2rem .4rem;border-radius:4px;transition:background .12s}.pm-btn-icon-danger:hover{background:#fef2f2}.pm-btn-success-sm{background:var(--pm-green);color:#fff;border:none;border-radius:var(--pm-radius-sm);padding:.45rem .9rem;font-family:var(--pm-font);font-size:.75rem;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap}.pm-btn-success-sm:hover{background:#15803d}.pm-btn-navy-sm{background:var(--pm-black);color:#fff;border:none;border-radius:var(--pm-radius-sm);padding:.45rem .9rem;font-family:var(--pm-font);font-size:.75rem;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap}.pm-btn-navy-sm:hover{background:#3a3737}.pm-close-btn{background:var(--pm-surface-2);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--pm-text-dark);transition:background .12s}.pm-close-btn:hover{background:var(--pm-cream-dark)}.pm-tabs-wrapper{display:flex;flex-wrap:wrap;gap:0;background:var(--pm-surface-2);border-bottom:2px solid var(--pm-border-soft);overflow-x:auto}.pm-tab-btn{background:transparent;border:none;border-bottom:3px solid transparent;padding:.85rem 1.25rem;font-family:var(--pm-font);font-size:.72rem;font-weight:700;letter-spacing:.05em;color:var(--pm-text-muted);cursor:pointer;white-space:nowrap;transition:all .15s}.pm-tab-btn:hover{color:var(--pm-black);background:#221f1f0a}.pm-tab-btn.active{color:var(--pm-red);border-bottom-color:var(--pm-red);background:var(--pm-white)}.pm-input{width:100%;padding:.6rem .85rem;border:1.5px solid var(--pm-border-soft);border-radius:var(--pm-radius-sm);background:var(--pm-white);font-family:var(--pm-font);font-size:.85rem;color:var(--pm-text-dark);margin-bottom:.75rem;transition:border-color .15s;outline:none}.pm-input:focus{border-color:var(--pm-blue);box-shadow:0 0 0 3px #497b971f}.pm-input:disabled{background:var(--pm-surface-2);color:var(--pm-text-muted);cursor:not-allowed}.pm-textarea{width:100%;padding:.7rem .85rem;border:1.5px solid var(--pm-border-soft);border-radius:var(--pm-radius-sm);background:var(--pm-white);font-family:var(--pm-font);font-size:.85rem;color:var(--pm-text-dark);resize:vertical;min-height:110px;margin-bottom:.75rem;outline:none;transition:border-color .15s}.pm-textarea:focus{border-color:var(--pm-blue);box-shadow:0 0 0 3px #497b971f}.pm-file-input{display:block;width:100%;padding:.65rem .85rem;border:2px dashed var(--pm-border-md);border-radius:var(--pm-radius-sm);background:var(--pm-surface);font-family:var(--pm-font);font-size:.8rem;color:var(--pm-text-muted);cursor:pointer;margin:.75rem 0;transition:border-color .15s,background .15s}.pm-file-input:hover{border-color:var(--pm-blue);background:#eef4f8}.pm-label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--pm-text-muted);margin-bottom:.4rem}.pm-label-red{color:var(--pm-red)}.pm-step-header{display:flex;align-items:center;gap:10px;background:var(--pm-black);border-bottom:2px solid var(--pm-red);border-radius:var(--pm-radius) var(--pm-radius) 0 0;padding:.9rem 1.5rem}.pm-step-header-icon{font-size:1.3rem;flex-shrink:0}.pm-step-header-eyebrow{font-size:.65rem;font-weight:700;letter-spacing:.1em;color:#ffffff73;text-transform:uppercase;display:block;margin-bottom:2px}.pm-step-header-title{font-size:1.05rem;font-weight:900;color:#fff;margin:0}.pm-card-below-header{background:var(--pm-white);border:1px solid var(--pm-border-soft);border-top:none;border-radius:0 0 var(--pm-radius) var(--pm-radius);padding:1.5rem;margin-bottom:1.25rem;box-shadow:var(--pm-shadow)}.pm-info-blurb{display:flex;gap:12px;align-items:flex-start;background:#eef4f8;border:1px solid #C7DDE8;border-radius:var(--pm-radius-sm);padding:1rem 1.1rem;margin-bottom:1.5rem}.pm-info-blurb-icon{font-size:1.2rem;flex-shrink:0}.pm-info-blurb p{margin:0;font-size:.82rem;color:var(--pm-blue-dark);line-height:1.6}.pm-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;width:100%;min-height:200px;padding:3.5rem 2rem;border:2px dashed var(--pm-border-md);border-radius:var(--pm-radius-sm);background:var(--pm-surface);cursor:pointer;transition:border-color .2s,background .2s;margin-bottom:1.25rem;box-sizing:border-box}.pm-upload-zone:hover{border-color:var(--pm-blue);background:#eef4f8}.pm-upload-zone.has-file{border-color:#86efac;background:#f0fdf4}.pm-upload-zone-icon{font-size:2rem}.pm-upload-zone-name{font-size:.82rem;font-weight:600;color:var(--pm-text-muted)}.pm-upload-zone.has-file .pm-upload-zone-name{color:#15803d}.pm-upload-zone-hint{font-size:.7rem;color:var(--pm-text-light)}.pm-verdict-strip{display:flex;align-items:center;gap:10px;background:var(--pm-surface-2);border:1px solid var(--pm-border-soft);border-radius:var(--pm-radius-sm);padding:1rem 1.25rem;margin-bottom:1.25rem}.pm-verdict-strip-icon{font-size:1.1rem;flex-shrink:0}.pm-verdict-strip p{margin:0;font-size:.82rem;color:var(--pm-text-muted);line-height:1.5}.pm-checklist-item{display:flex;align-items:center;gap:.75rem;padding:.8rem 1rem;background:var(--pm-white);border:1.5px solid var(--pm-border-soft);border-radius:var(--pm-radius-sm);cursor:pointer;font-size:.85rem;font-weight:600;color:var(--pm-black);transition:border-color .15s,background .15s;margin-bottom:.5rem}.pm-checklist-item:hover{border-color:var(--pm-blue);background:#eef4f8}.pm-checklist-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--pm-blue);cursor:pointer;flex-shrink:0}.pm-table-wrapper{overflow-x:auto;border-radius:var(--pm-radius);border:1px solid var(--pm-border-soft);margin-bottom:1.25rem;box-shadow:var(--pm-shadow)}.pm-table{width:100%;border-collapse:collapse;font-family:var(--pm-font);font-size:.82rem;background:var(--pm-white)}.pm-table th{background:var(--pm-black);color:#ffffffd9;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.75rem 1rem;text-align:left;border-bottom:2px solid var(--pm-red);white-space:nowrap}.pm-table td{padding:.65rem 1rem;border-bottom:1px solid var(--pm-border-soft);color:var(--pm-text-dark);vertical-align:middle}.pm-table tbody tr:hover{background:#fafaf9}.pm-table tbody tr:last-child td{border-bottom:none}.pm-boq-total-label{text-align:right;font-weight:900;text-transform:uppercase;padding:15px!important;color:var(--pm-text-dark)}.pm-boq-total-val{text-align:center;font-weight:900;color:var(--pm-red);font-size:1.1rem;padding:15px!important}.pm-status-badge{display:inline-block;padding:.22rem .65rem;border-radius:20px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.pm-status-badge[data-status=Delayed]{background:#fef2f2;color:var(--pm-red)}.pm-status-badge[data-status=Completed]{background:#dcfce7;color:#15803d}.pm-status-badge[data-status="In Progress"]{background:#e0f2fe;color:#0369a1}.pm-status-badge[data-status=Pending]{background:var(--pm-surface-2);color:var(--pm-text-muted)}.pm-modal-overlay{position:fixed;inset:0;background:#221f1f8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.pm-modal-content{background:var(--pm-white);border-radius:var(--pm-radius);padding:2rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--pm-shadow-lg);border-top:4px solid var(--pm-red);animation:pm-modal-in .2s ease}.pm-modal-content.large{max-width:760px}@keyframes pm-modal-in{0%{opacity:0;transform:translateY(-16px) scale(.97)}to{opacity:1;transform:none}}.pm-doc-link{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fdf7f5;border:1.5px solid var(--pm-cream-dark);border-radius:var(--pm-radius-sm);padding:.8rem 1.1rem;margin-bottom:.75rem}.pm-doc-label{font-size:.82rem;font-weight:600;color:var(--pm-text-dark)}.pm-doc-btn{display:inline-flex;align-items:center;gap:.3rem;background:var(--pm-blue);color:#fff;border:none;border-radius:var(--pm-radius-sm);padding:.4rem 1rem;font-family:var(--pm-font);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;text-decoration:none;cursor:pointer;transition:background .15s;white-space:nowrap}.pm-doc-btn:hover{background:var(--pm-blue-dark)}.pm-log-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--pm-white);border:1px solid var(--pm-border-soft);border-left:4px solid var(--pm-blue);border-radius:var(--pm-radius-sm);padding:1rem 1.25rem;margin-bottom:.75rem;box-shadow:var(--pm-shadow)}.pm-log-date{font-size:1rem;font-weight:900;color:var(--pm-red);margin:0 0 .25rem}.pm-log-meta{display:block;font-size:.7rem;color:var(--pm-text-muted);margin-bottom:.2rem}.pm-vault-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;margin-top:1.25rem}.pm-vault-section{background:var(--pm-surface);border:1px solid var(--pm-border-soft);border-radius:var(--pm-radius-sm);padding:1rem 1.1rem}.pm-vault-header{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--pm-blue);border-bottom:1.5px solid var(--pm-border-soft);padding-bottom:.5rem;margin-bottom:.75rem}.pm-title-lg{font-size:1.15rem;font-weight:900;color:var(--pm-black);margin-bottom:1rem}.pm-title-md{font-size:.95rem;font-weight:800;color:var(--pm-black);margin-bottom:.75rem}.pm-text-muted{font-size:.85rem;color:var(--pm-text-muted);line-height:1.6}.pm-grid-1{display:flex;flex-direction:column;gap:.75rem}.pm-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.pm-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:900px){.pm-grid-3{grid-template-columns:1fr 1fr}.pm-grid-2{grid-template-columns:1fr}}@media(max-width:600px){.pm-grid-3{grid-template-columns:1fr}.pm-phase-container{padding:1rem}.pm-header{padding:.85rem 1rem}.pm-personnel-bar{padding:.6rem 1rem}}.pm-flex-between{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.text-center{text-align:center}.mt-4{margin-top:1.25rem}.mb-4{margin-bottom:1.25rem}.m-0{margin:0}.pm-animate-fadein{animation:pm-fadein .25s ease}@keyframes pm-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media print{.no-print{display:none!important}.pm-container{background:#fff}.pm-table th{background:#221f1f!important;-webkit-print-color-adjust:exact}}.boq-table-extended{min-width:1100px}.boq-th-category{min-width:170px}.boq-th-code{min-width:180px}.boq-th-desc{min-width:160px}.boq-th-unit,.boq-th-qty{min-width:75px;text-align:center}.boq-th-cost,.boq-th-total{min-width:120px;text-align:center}.boq-th-stock{min-width:110px;text-align:center}.boq-th-action{min-width:44px;text-align:center}.boq-th-hint{font-size:.6rem;font-weight:400;opacity:.65;text-transform:none;letter-spacing:0}.boq-td-category{min-width:170px;vertical-align:top;padding-top:10px!important}.boq-td-code{min-width:180px;vertical-align:top;padding-top:10px!important}.boq-td-stock{text-align:center;vertical-align:middle}.boq-row-warn{background:#fffbf0!important}.boq-row-warn:hover{background:#fff6e0!important}.boq-empty-row{text-align:center;padding:2rem 1rem!important;color:var(--pm-text-muted);font-size:.85rem;font-style:italic}.boq-readonly-cell{font-size:.82rem;font-weight:600;color:var(--pm-text-dark)}.boq-code-chip{display:inline-block;background:#eef4f8;color:var(--pm-blue);padding:.15rem .55rem;border-radius:6px;font-size:.75rem;font-weight:700}.boq-total-cell{font-weight:900;color:var(--pm-black)}.boq-dd-wrap{position:relative;width:100%}.boq-dd-trigger{-webkit-user-select:none;user-select:none;min-height:38px;padding:.5rem .75rem}.boq-dd-disabled{opacity:.55}.boq-dd-panel{position:absolute;top:calc(100% + 4px);left:0;width:240px;background:var(--pm-white);border:1.5px solid var(--pm-blue);border-radius:var(--pm-radius-sm);box-shadow:0 8px 24px #221f1f24;z-index:1000;overflow:hidden}.boq-dd-search{display:block;width:100%;padding:.55rem .85rem;border:none;border-bottom:1.5px solid var(--pm-border-soft);font-family:var(--pm-font);font-size:.82rem;color:var(--pm-text-dark);outline:none;background:var(--pm-surface)}.boq-dd-list{max-height:210px;overflow-y:auto}.boq-dd-item{padding:.55rem .85rem;font-size:.82rem;font-weight:500;color:var(--pm-text-dark);cursor:pointer;transition:background .1s}.boq-dd-item:hover{background:#eef4f8;color:var(--pm-blue)}.boq-dd-item.active{background:var(--pm-blue);color:#fff;font-weight:700}.boq-dd-empty{padding:.7rem .85rem;font-size:.78rem;color:var(--pm-text-muted);text-align:center;font-style:italic}.boq-stock-inline{display:flex;align-items:center;gap:5px;margin-top:4px;padding:0 2px}.boq-stock-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.boq-stock-label{font-size:.68rem;font-weight:700;letter-spacing:.02em}.boq-stock-on{color:#059669}.boq-stock-low{color:#d97706}.boq-stock-no{color:#dc2626}.boq-stock-badge{display:inline-flex;align-items:center;gap:5px;padding:.22rem .65rem;border-radius:20px;font-size:.67rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.boq-stock-on{background:#d1fae5;color:#065f46}.boq-stock-low{background:#fef3c7;color:#92400e}.boq-stock-no{background:#fee2e2;color:#7f1d1d}.boq-stock-unknown{background:var(--pm-surface-2);color:var(--pm-text-muted)}.boq-alert-banner{display:flex;align-items:flex-start;gap:.85rem;background:#fffbeb;border:1.5px solid #FCD34D;border-left:4px solid #F59E0B;border-radius:var(--pm-radius-sm);padding:.9rem 1.1rem;margin-bottom:1rem;animation:boq-banner-in .25s ease}@keyframes boq-banner-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.boq-alert-icon{font-size:1.2rem;flex-shrink:0;margin-top:1px}.boq-alert-body{flex:1}.boq-alert-title{display:block;font-size:.8rem;font-weight:800;color:#92400e;margin-bottom:.45rem}.boq-alert-list{display:flex;flex-wrap:wrap;gap:.4rem}.boq-alert-chip{display:inline-flex;align-items:center;gap:5px;padding:.2rem .65rem;border-radius:20px;font-size:.72rem;font-weight:700}.boq-alert-chip.chip-low{background:#fef3c7;color:#92400e}.boq-alert-chip.chip-no{background:#fee2e2;color:#7f1d1d}.boq-loading-bar{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;background:#eef4f8;border-bottom:1px solid var(--pm-border-soft);font-size:.75rem;color:var(--pm-blue);font-weight:600;overflow:hidden;position:relative}.boq-loading-inner{position:absolute;left:0;top:0;height:3px;width:40%;background:var(--pm-blue);border-radius:2px;animation:boq-load-slide 1.2s ease-in-out infinite}@keyframes boq-load-slide{0%{left:-40%;width:40%}50%{left:30%;width:50%}to{left:110%;width:40%}}.customer-container{padding:20px 30px;width:100%;height:100%;overflow-y:auto;background-color:#f8fafc;box-sizing:border-box}.customer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.customer-header h1{color:#221f1f;font-size:1.8rem;margin:0}.btn-add-lead{background-color:#ff1817;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:700;font-size:.95rem;transition:background-color .2s}.btn-add-lead:hover{background-color:#d11211}.btn-cancel{background-color:transparent;color:#64748b;border:1px solid #cbd5e1;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:700;transition:all .2s}.btn-cancel:hover{background-color:#f1f5f9;color:#334155}.btn-save-lead{background-color:#221f1f;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:700;transition:background-color .2s}.btn-save-lead:hover{background-color:#000}.btn-delete-small{background:transparent;color:#ff1817;border:1px solid #fee2e2;padding:6px 12px;border-radius:6px;font-weight:700;font-size:.8rem;cursor:pointer;transition:all .2s ease-in-out}.btn-delete-small:hover{background:#fef2f2}.status-badge{padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:700;text-transform:capitalize}.project-created{background-color:#e0f2fe;color:#0369a1}.lead-card{background:#fff;border-radius:12px;border:1px solid #EBDBD6;box-shadow:0 1px 3px #0000001a;overflow:hidden}.lead-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.departments-list{display:flex;flex-direction:column;gap:30px;animation:fadeIn .4s ease-in}.department-card{background:#fff;border-radius:12px;border:1px solid #EBDBD6;box-shadow:0 1px 3px #0000001a;overflow:hidden}.department-header{background-color:#221f1f;color:#fff;padding:14px 20px;font-weight:700;font-size:1.1rem}.department-table-container{padding:10px 20px 20px}.users-table{width:100%;border-collapse:collapse;text-align:left}.users-table thead tr{border-bottom:2px solid #EBDBD6}.users-table th{color:#497b97;font-size:.85rem;padding:12px 10px;font-weight:700;text-transform:uppercase}.users-table tbody tr{border-bottom:1px solid #f1f5f9}.users-table tbody tr:hover{background-color:#f8fafc}.users-table td{padding:14px 10px;font-size:.95rem}.user-name{font-weight:700;color:#221f1f}.user-email{color:#64748b;font-size:.9rem}.action-column{text-align:right}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999!important;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content.compact-modal{background:#fff;padding:30px;border-radius:12px;width:90%;max-width:500px;box-shadow:0 10px 25px #0003;animation:slideDown .3s ease-out}.modal-header-compact h2{margin-top:0;margin-bottom:20px;color:#221f1f;font-size:1.4rem;border-bottom:2px solid #f1f5f9;padding-bottom:10px}.compact-grid{display:flex;flex-direction:column;gap:15px;margin-bottom:25px}.form-group-compact label{display:block;margin-bottom:6px;font-size:.9rem;color:#497b97;font-weight:700}.form-group-compact input,.form-group-compact select{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:6px;outline:none;font-size:.95rem;box-sizing:border-box}.form-group-compact input:focus,.form-group-compact select:focus{border-color:#ff1817}.modal-footer-compact{display:flex;justify-content:flex-end;gap:12px}.spinner-container{display:flex;justify-content:center;align-items:center;height:200px}.loading-circle{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #FF1817;border-radius:50%;animation:spin 1s linear infinite}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.customer-container{padding:15px 10px}.customer-header{flex-direction:column;align-items:center;text-align:center;gap:15px}.btn-add-lead{width:100%;justify-content:center}.department-table-container{padding:10px;overflow-x:hidden}.users-table,.users-table tbody{display:block;width:100%;min-width:0}.users-table thead{display:none}.users-table tr{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px 10px;border-bottom:3px solid #f1f5f9;gap:8px}.users-table td{display:block;padding:0;white-space:normal;width:100%}.user-name{font-size:1.1rem}.action-column{display:flex;justify-content:center;gap:15px;margin-top:10px;text-align:center}.compact-grid{grid-template-columns:1fr;gap:15px}}.password-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.password-input-wrapper input{width:100%}.password-toggle-eye{position:absolute;right:12px;background:none;border:none;color:#94a3b8;font-size:.65rem;font-weight:800;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;padding:5px;transition:color .2s;z-index:5}.password-toggle-eye:hover{color:#497b97}.activity-container-card{background-color:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 10px #0000000d;display:flex;flex-direction:column;height:70vh}.activity-filter-bar{display:flex;gap:15px;margin-bottom:20px}.activity-search-input{flex:1;padding:10px 15px;border-radius:6px;border:1px solid #e2e8f0;font-size:.95rem}.activity-module-select{padding:10px 15px;border-radius:6px;border:1px solid #e2e8f0;background-color:#f8fafc;font-size:.95rem;cursor:pointer;min-width:150px}.activity-table-wrapper{flex:1;overflow-y:auto;overflow-x:hidden}.activity-table{width:100%;text-align:left;border-collapse:collapse}.activity-table th{padding:12px;position:sticky;top:0;background-color:#fff;border-bottom:2px solid #e2e8f0;color:#64748b;font-size:.85rem;text-transform:uppercase;z-index:10}.activity-table td{padding:15px 12px;border-bottom:1px solid #f1f5f9;font-size:.9rem}.activity-module-badge{background-color:#f1f5f9;color:#497b97;padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:700}@media(max-width:768px){.activity-filter-bar{flex-direction:column;gap:10px}.activity-module-select{width:100%}.activity-table thead{display:none}.activity-table,.activity-table tbody,.activity-table tr,.activity-table td{display:block;width:100%}.activity-table tr{margin-bottom:15px;border:1px solid #e2e8f0;border-radius:8px;background-color:#fff;box-shadow:0 1px 3px #0000000d;padding:10px}.activity-table td{text-align:right;padding:8px 5px;border-bottom:1px solid #f8fafc;position:relative;display:flex;justify-content:space-between;align-items:center}.activity-table td:last-child{border-bottom:0}.activity-table td:before{content:attr(data-label);float:left;font-weight:700;text-transform:uppercase;color:#64748b;font-size:.75rem;margin-right:15px;text-align:left}}:root{--brand-black: #221F1F;--brand-blue: #497B97;--brand-red: #C20100;--brand-red-dk: #A00101;--brand-cream: #EBDBD6;--bg-page: #F4F2F0;--bg-card: #FFFFFF;--bg-subtle: #FAF8F6;--border: #E0D9D4;--border-md: #C8BDB8;--text-pri: #221F1F;--text-muted: #7A706C;--text-light: #A89E9A;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--sh-sm: 0 1px 3px rgba(34,31,31,.07);--sh-md: 0 4px 16px rgba(34,31,31,.1);--sh-lg: 0 12px 40px rgba(34,31,31,.16)}@keyframes eng-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes eng-spin{to{transform:rotate(360deg)}}@keyframes eng-blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes eng-card{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes eng-modal{0%{opacity:0;transform:scale(.96) translateY(14px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes eng-overlay{0%{opacity:0}to{opacity:1}}@keyframes eng-toast{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.dashboard-wrapper{font-family:DM Sans,sans-serif;background:var(--bg-page);min-height:100vh;padding-bottom:3rem;color:var(--text-pri)}.dashboard-header{background:var(--brand-black);border-bottom:3px solid var(--brand-red);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:0}.header-text h2{font-size:1.1rem;font-weight:800;color:#fff;letter-spacing:-.015em;text-transform:uppercase;margin:0}.header-text p{font-size:.72rem;color:var(--brand-cream);opacity:.8;margin:0}.refresh-btn{width:34px;height:34px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-sm);color:#fff;font-size:1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,transform .3s;flex-shrink:0}.refresh-btn:hover:not(:disabled){background:#ffffff2e}.refresh-btn:disabled{opacity:.4;cursor:not-allowed}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.25rem 1.75rem 0}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.1rem 1.1rem .9rem;display:flex;align-items:center;gap:.9rem;box-shadow:var(--sh-sm);position:relative;overflow:hidden;animation:eng-rise .5s ease both}.stat-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--brand-blue);border-radius:0 0 var(--r-lg) var(--r-lg)}.stat-card.task-highlight{background:var(--brand-black);border-color:var(--brand-black)}.stat-card.task-highlight:after{background:var(--brand-red)}.stat-card.task-highlight .stat-label{color:#ebdbd68c}.stat-card.task-highlight .stat-value{color:var(--brand-cream)}.stat-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 2px}.stat-value{font-size:1.65rem;font-weight:800;color:var(--text-pri);line-height:1;letter-spacing:-.02em}.task-flex{display:flex;align-items:center;gap:.7rem}.mini-assign-btn{display:flex;align-items:center;gap:4px;background:var(--brand-red);color:#fff;border:none;border-radius:var(--r-sm);padding:.3rem .65rem;font-family:DM Sans,sans-serif;font-size:.7rem;font-weight:700;cursor:pointer;transition:background .15s}.mini-assign-btn:hover{background:var(--brand-red-dk)}.proj-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden;margin:1.1rem 1.75rem 0;animation:eng-rise .5s ease both}.proj-title-lg{font-size:.82rem;font-weight:800;color:var(--text-pri);text-transform:uppercase;letter-spacing:.04em}.approval-section{margin:1.1rem 1.75rem 0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden;animation:eng-rise .5s ease both}.section-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.1rem;background:var(--brand-black);border-bottom:2px solid var(--brand-red)}.section-header h2{font-size:.82rem!important;font-weight:800!important;color:#fff!important;text-transform:uppercase;letter-spacing:.04em;margin:0}.section-header p{font-size:.66rem;color:#ffffff80;margin:0}.active-projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;padding:1.1rem}.project-task-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1rem 1.1rem;box-shadow:var(--sh-sm);display:flex;flex-direction:column;justify-content:space-between;gap:1rem;transition:box-shadow .18s,transform .18s,border-color .18s;animation:eng-card .3s ease both}.project-task-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-color:var(--brand-blue)}.project-task-card.completed{background:var(--bg-subtle);border-color:var(--border);opacity:.9}.card-header-flex{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.tag-id{font-size:.65rem;font-weight:700;letter-spacing:.04em;padding:.18rem .55rem;border-radius:4px;background:var(--brand-black);color:var(--brand-cream)}.tag-progress{font-size:.65rem;font-weight:700;padding:.18rem .55rem;border-radius:4px;background:var(--brand-red);color:#fff}.tag-progress.finished{background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.tag-progress[style*="background: rgb(254, 242, 242)"],.tag-progress[style*="background:#fef2f2"],.tag-progress[style*="color: rgb(194, 1, 0)"]{background:#c2010014!important;color:var(--brand-red)!important;border:1px solid rgba(194,1,0,.2)!important}.project-name-title{font-size:.88rem;font-weight:700;color:var(--text-pri);margin:0 0 .3rem;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.completed .project-name-title{color:var(--text-muted)}.project-client-sub{font-size:.72rem;color:var(--text-muted);margin:0 0 .75rem}.phase-box{background:#ebdbd659;border:1px solid var(--border);border-radius:var(--r-sm);padding:.55rem .75rem}.phase-box-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);margin:0 0 2px}.phase-box-value{font-size:.8rem;font-weight:700;color:var(--text-pri);margin:0}.phase-box-value.finished{color:#065f46;text-transform:uppercase}.open-workspace-btn{width:100%;padding:.55rem 1rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:700;border:1.5px solid var(--brand-black);background:transparent;color:var(--text-pri);cursor:pointer;transition:background .15s,color .15s,border-color .15s;text-align:center}.open-workspace-btn:hover{background:var(--brand-black);color:#fff}.open-workspace-btn.finished{border-color:var(--brand-blue);color:var(--brand-blue)}.open-workspace-btn.finished:hover{background:var(--brand-blue);color:#fff;border-color:var(--brand-blue)}.open-workspace-btn[style*="backgroundColor: var(--fo-blue)"],.open-workspace-btn[style*=background]{border-color:transparent!important}.archive-periods-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:.6rem;margin-top:1rem;padding:0}.period-card{padding:.9rem .5rem;border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-subtle);text-align:center;transition:background .15s,border-color .15s,transform .15s}.period-card.active{cursor:pointer;border-color:var(--brand-blue)}.period-card.active:hover{background:var(--brand-black);border-color:var(--brand-black);transform:translateY(-1px)}.period-card.active:hover .period-name,.period-card.active:hover .period-count{color:#fff!important}.period-card.disabled{opacity:.4;cursor:not-allowed}.period-name{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.period-count{font-size:1.5rem;font-weight:800;color:var(--text-pri);line-height:1.1;margin-top:3px}.period-card p[style*=fo-red],.period-card p[style*="color: var(--fo-red)"]{color:var(--brand-red)!important}.modal-overlay{position:fixed;inset:0;background:#221f1f8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:eng-overlay .2s ease}.modal-content{background:var(--bg-card);border-radius:var(--r-lg);box-shadow:var(--sh-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:eng-modal .25s cubic-bezier(.22,1,.36,1);overflow-x:hidden}.modal-content.large{max-width:820px}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.9rem 1.2rem;background:var(--brand-black);border-bottom:2px solid var(--brand-red);border-radius:var(--r-lg) var(--r-lg) 0 0}.modal-header h3{font-size:.95rem;font-weight:800;color:#fff;margin:0}.modal-header p{font-size:.72rem;color:#ffffff80;margin:2px 0 0}.close-modal{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:28px;height:28px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:.95rem;cursor:pointer;flex-shrink:0;line-height:1;transition:background .12s}.close-modal:hover{background:#ffffff38}.close-modal:disabled{opacity:.4;cursor:not-allowed}.modal-content>form,.modal-content>div:not(.modal-header):not(.modal-actions){padding:1rem 1.2rem}.modal-content label[style],.modal-content label{font-family:DM Sans,sans-serif!important;font-size:.68rem!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.05em!important;color:var(--text-muted)!important;display:block;margin-bottom:.35rem}.modal-content select,.modal-content input[type=number],.modal-content input[type=text],.modal-content textarea{font-family:DM Sans,sans-serif!important;font-size:.82rem!important;font-weight:500!important;color:var(--text-pri)!important;background:var(--bg-page)!important;border:1px solid var(--border)!important;border-radius:var(--r-sm)!important;padding:.55rem .85rem!important;width:100%!important;box-sizing:border-box!important;outline:none!important;transition:border-color .15s,box-shadow .15s!important;appearance:none!important;-webkit-appearance:none!important}.modal-content select:focus,.modal-content input:focus,.modal-content textarea:focus{border-color:var(--brand-blue)!important;box-shadow:0 0 0 3px #497b971f!important}.modal-actions{display:flex;justify-content:flex-end;gap:.6rem;padding:.85rem 1.2rem 1.1rem;border-top:1px solid var(--border);margin-top:.5rem}.btn-cancel{background:var(--bg-page);border:1px solid var(--border-md);color:var(--text-muted);padding:.5rem 1.1rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;cursor:pointer;transition:background .12s}.btn-cancel:hover{background:var(--brand-cream)}.confirm-btn{display:flex;align-items:center;gap:6px;background:var(--brand-black);color:#fff;border:none;padding:.5rem 1.3rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s}.confirm-btn:hover:not(:disabled){background:var(--brand-red)}.confirm-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.8}.back-btn{display:inline-flex;align-items:center;gap:5px;background:var(--bg-page);border:1px solid var(--border-md);color:var(--text-muted);padding:.4rem .85rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:600;cursor:pointer;margin:.75rem 1.2rem .5rem;transition:background .12s,color .12s,border-color .12s}.back-btn:hover{background:var(--brand-cream);border-color:var(--brand-black);color:var(--text-pri)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.6rem;z-index:9999;pointer-events:none}.toast{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;border-radius:var(--r-md);min-width:240px;pointer-events:all;cursor:pointer;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;box-shadow:var(--sh-md);animation:eng-toast .22s ease;border:1px solid transparent}.toast-icon{font-size:.9rem;flex-shrink:0}.toast-success{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.toast-error{background:#fef2f2;color:#991b1b;border-color:#fecaca}.toast-info{background:var(--brand-cream);color:var(--brand-black);border-color:var(--border-md)}.approval-section>div[style*="textAlign: center"],div[style*="textAlign: center"][style*=dashed]{border:2px dashed var(--border-md)!important;border-radius:var(--r-lg)!important;background:var(--bg-subtle)!important;margin:1rem 1.1rem!important;padding:2.5rem 1rem!important;color:var(--text-light)!important}.proj-card select[style]{font-family:DM Sans,sans-serif!important;font-size:.78rem!important;font-weight:700!important;padding:.45rem .9rem!important;border-radius:var(--r-sm)!important;border:1px solid var(--border)!important;background:var(--bg-page)!important;color:var(--text-pri)!important;cursor:pointer!important;outline:none!important;appearance:none!important}.btn-open-archives{display:inline-flex;align-items:center;gap:5px;background:var(--brand-black);color:#fff;border:none;padding:.48rem 1rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap}.btn-open-archives:hover{background:var(--brand-red)}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:1.4rem}}@media(max-width:768px){.dashboard-header{padding:.85rem 1rem}.header-text h2{font-size:.95rem}.stats-grid{padding:.85rem 1rem 0;gap:.65rem}.approval-section,.proj-card{margin-left:1rem;margin-right:1rem}.active-projects-grid{grid-template-columns:1fr}.modal-content.large{max-width:100%}.archive-periods-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}.modal-content>form,.modal-content>div:not(.modal-header):not(.modal-actions){padding:.85rem 1rem}.modal-actions{padding:.75rem 1rem .9rem}.back-btn{margin:.6rem 1rem .4rem}}@media(max-width:480px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.stat-card{padding:.9rem .85rem .75rem}.stat-label{font-size:.65rem}.stat-value{font-size:1.25rem}.modal-actions{flex-direction:column-reverse}.modal-actions .btn-cancel,.modal-actions .confirm-btn{width:100%;justify-content:center}.project-task-card{padding:.85rem .9rem}}@media print{.no-print{display:none!important}}.dashboard-wrapper ::-webkit-scrollbar{width:5px;height:5px}.dashboard-wrapper ::-webkit-scrollbar-track{background:transparent}.dashboard-wrapper ::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:4px}.dashboard-wrapper ::-webkit-scrollbar-thumb:hover{background:var(--brand-blue)}@keyframes sd-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes sd-spin{to{transform:rotate(360deg)}}@keyframes sd-blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes sd-pulse{0%,to{opacity:.5}50%{opacity:1}}.sd-wrapper{font-family:DM Sans,sans-serif;background:var(--bg-page);min-height:100vh;padding-bottom:3rem;color:var(--text-pri)}.sd-header{background:var(--brand-black);border-bottom:3px solid var(--brand-red);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.sd-header-left{display:flex;align-items:center;gap:.85rem}.sd-header-right{display:flex;align-items:center;gap:.65rem}.sd-header-icon{width:42px;height:42px;background:var(--brand-red);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.sd-header-title{font-size:1.05rem;font-weight:800;color:#fff;letter-spacing:-.01em;text-transform:uppercase;margin:0}.sd-header-sub{font-size:.72rem;color:var(--brand-cream);opacity:.8;margin:0}.sd-live-pill{display:flex;align-items:center;gap:6px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:.3rem .85rem;font-size:.7rem;font-weight:600;color:#fffc;white-space:nowrap}.sd-live-dot{width:7px;height:7px;background:#10b981;border-radius:50%;animation:sd-blink 1.6s infinite;flex-shrink:0}.sd-sync-label{display:flex;align-items:center;gap:4px;font-size:.68rem;color:#ffffff80;white-space:nowrap}.sd-refresh-btn{width:34px;height:34px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-sm);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.sd-refresh-btn:hover{background:#ffffff2e}.sd-refresh-btn.spinning svg{animation:sd-spin .75s linear infinite}.sd-loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:5rem 1rem;color:var(--text-muted);font-size:.85rem}.sd-spinner{width:30px;height:30px;border:3px solid var(--border);border-top-color:var(--brand-red);border-radius:50%;animation:sd-spin .7s linear infinite}.sd-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.25rem 1.75rem 0}.sd-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.1rem 1.1rem .9rem;display:flex;align-items:center;gap:.9rem;box-shadow:var(--sh-sm);animation:sd-rise .5s ease both;overflow:hidden;position:relative}.sd-stat-card.highlight{background:var(--brand-red);border-color:var(--brand-red-dk)}.sd-stat-card.highlight .sd-stat-label,.sd-stat-card.highlight .sd-stat-value{color:#fff}.sd-stat-card.highlight .sd-stat-sub{color:#ebdbd699}.sd-stat-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sd-stat-body{display:flex;flex-direction:column;gap:2px;min-width:0}.sd-stat-value{font-size:1.65rem;font-weight:800;color:var(--text-pri);line-height:1;letter-spacing:-.025em}.sd-stat-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.sd-stat-sub{font-size:.67rem;color:var(--text-light)}.sd-body{display:grid;grid-template-columns:1fr 300px;gap:1.1rem;padding:1.1rem 1.75rem 0;align-items:start}.sd-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden;animation:sd-rise .5s ease both}.sd-card-head{display:flex;align-items:flex-start;justify-content:space-between;padding:.75rem 1.1rem;background:var(--brand-black);border-bottom:2px solid var(--brand-red)}.sd-card-title{font-size:.82rem;font-weight:700;color:#fff;margin:0}.sd-card-sub{font-size:.7rem;color:var(--brand-cream);opacity:.7;margin:2px 0 0}.sd-table-wrap{overflow-x:auto}.sd-table{width:100%;border-collapse:collapse;font-size:.78rem;min-width:480px}.sd-table thead tr{background:var(--bg-subtle)}.sd-table thead th{padding:.55rem 1rem;text-align:left;font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}.sd-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.sd-table tbody tr:last-child{border-bottom:none}.sd-table tbody tr:hover{background:var(--bg-subtle)}.sd-table td{padding:.62rem 1rem;vertical-align:middle}.sd-client{font-weight:700;font-size:.8rem;white-space:nowrap}.sd-project{font-size:.78rem;color:var(--text-muted)}.sd-empty-cell{text-align:center;padding:2.5rem 1rem!important;color:var(--text-light);font-size:.82rem}.sd-status{display:inline-flex;align-items:center;gap:5px;padding:.22rem .6rem;border-radius:20px;font-size:.7rem;font-weight:700;white-space:nowrap}.sd-status.project-created{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.sd-status.to-be-contacted{background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.sd-status.pending{background:#fffbeb;color:#92400e;border:1px solid #FCD34D}.sd-status.rejected{background:#fef2f2;color:#991b1b;border:1px solid #FECACA}.sd-status.won{background:#f0fdf4;color:#166534;border:1px solid #BBF7D0}.sd-status.default{background:var(--bg-subtle);color:var(--text-muted);border:1px solid var(--border)}.sd-details-btn{display:inline-flex;align-items:center;gap:3px;background:var(--bg-subtle);border:1px solid var(--border-md);color:var(--text-muted);border-radius:var(--r-sm);padding:.28rem .65rem;font-family:DM Sans,sans-serif;font-size:.7rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .12s,color .12s,border-color .12s}.sd-details-btn:hover{background:var(--brand-black);color:#fff;border-color:var(--brand-black)}.sd-pipeline{display:flex;flex-direction:column;border-bottom:1px solid var(--border)}.sd-pipeline-row{display:flex;align-items:center;justify-content:space-between;padding:.62rem 1.1rem;border-bottom:1px solid var(--border);font-size:.78rem;transition:background .1s}.sd-pipeline-row:last-child{border-bottom:none}.sd-pipeline-row:hover{background:var(--bg-subtle)}.sd-pipeline-label{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-weight:500}.sd-pipeline-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sd-pipeline-count{font-size:.88rem;font-weight:800;color:var(--text-pri)}.sd-pipeline-bar-wrap{display:flex;flex-direction:column;gap:.65rem;padding:.9rem 1.1rem 1rem}.sd-pipeline-bar-label{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted);font-weight:600;margin-bottom:4px}.sd-bar-track{height:8px;background:var(--bg-page);border:1px solid var(--border);border-radius:20px;overflow:hidden}.sd-bar-fill{height:100%;border-radius:20px;transition:width .6s ease;min-width:3px}.sd-overlay{position:fixed;inset:0;background:#221f1f8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.sd-modal{background:var(--bg-card);border-radius:var(--r-lg);box-shadow:var(--sh-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:sd-rise .22s ease}.sd-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem 1.3rem .85rem;background:var(--brand-black);border-bottom:2px solid var(--brand-red);border-radius:var(--r-lg) var(--r-lg) 0 0}.sd-modal-title{color:#fff;font-size:.95rem;font-weight:700;margin:0}.sd-modal-sub{color:var(--brand-cream);font-size:.72rem;opacity:.75;margin:2px 0 0}.sd-modal-close{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#fff;width:28px;height:28px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;line-height:1;transition:background .12s;flex-shrink:0}.sd-modal-close:hover{background:#fff3}.sd-modal-body{padding:.85rem 1.3rem;display:flex;flex-direction:column;gap:.55rem}.sd-detail-row{display:flex;align-items:flex-start;gap:1rem;padding:.45rem 0;border-bottom:1px solid var(--border);font-size:.8rem}.sd-detail-row:last-child{border-bottom:none}.sd-detail-label{min-width:110px;flex-shrink:0;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.sd-detail-value{color:var(--text-pri);font-weight:500}.sd-modal-footer{display:flex;justify-content:flex-end;padding:.75rem 1.3rem;border-top:1px solid var(--border)}.sd-btn-cancel{background:var(--bg-page);border:1px solid var(--border-md);color:var(--text-muted);padding:.48rem 1.2rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .12s}.sd-btn-cancel:hover{background:var(--brand-cream)}.sd-toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:2000}.sd-toast{display:flex;align-items:center;gap:8px;padding:.65rem 1rem;border-radius:var(--r-md);font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;box-shadow:var(--sh-md);cursor:pointer;animation:sd-rise .25s ease;max-width:320px}.sd-toast-success{background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.sd-toast-error{background:#fef2f2;color:#991b1b;border:1px solid #FECACA}.sd-toast-info{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.sd-footer{display:flex;align-items:center;gap:6px;padding:1.25rem 1.75rem 0;font-size:.7rem;color:var(--text-light)}@media(max-width:1100px){.sd-stats-grid{grid-template-columns:repeat(2,1fr)}.sd-body{grid-template-columns:1fr}}@media(max-width:640px){.sd-header{padding:.85rem 1rem;flex-wrap:wrap}.sd-stats-grid{padding:.85rem 1rem 0;gap:.65rem}.sd-body{padding:.85rem 1rem 0}.sd-stat-value{font-size:1.3rem}.sd-live-pill,.sd-project{display:none}}@media(max-width:420px){.sd-stats-grid{grid-template-columns:1fr 1fr}}.sd-main-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}@media(min-width:1024px){.sd-main-grid{grid-template-columns:repeat(3,1fr)}.sd-card-span-2{grid-column:span 2}}@media(max-width:768px){.sd-main-grid{grid-template-columns:1fr}.sd-card-span-2{grid-column:span 1}}.sd-flex-between{display:flex;justify-content:space-between;align-items:flex-start}.sd-export-btn{display:flex;align-items:center;gap:6px;background-color:#10b981;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.sd-export-btn:hover:not(:disabled){background-color:#059669;transform:translateY(-1px)}.sd-export-btn:disabled{opacity:.7;cursor:not-allowed}.sd-vertical-graph-container{height:250px;padding:20px 10px 10px;position:relative;display:flex;flex-direction:column;justify-content:flex-end}.sd-graph-axes{position:absolute;inset:20px 0 30px;display:flex;flex-direction:column;justify-content:space-between;z-index:1}.sd-graph-bars{position:relative;z-index:2;display:flex;justify-content:space-around;align-items:flex-end;height:calc(100% - 30px);padding:0 10px}.sd-graph-bar-group{display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;width:40px}.sd-graph-bar-wrapper{flex-grow:1;width:100%;display:flex;align-items:flex-end;justify-content:center;position:relative}.sd-graph-bar{width:30px;border-radius:4px 4px 0 0;position:relative;transition:height .6s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0000001a}.sd-graph-bar:hover{filter:brightness(1.1);cursor:pointer}.sd-graph-value{position:absolute;top:-22px;left:50%;transform:translate(-50%);font-size:.75rem;font-weight:700;color:var(--text-dark);background:var(--bg-main);padding:2px 6px;border-radius:4px;border:1px solid var(--border);box-shadow:0 1px 3px #0000001a}.sd-graph-label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-align:center}.sd-vertical-graph-container{height:280px;padding:40px 10px 10px 30px;position:relative;display:flex;flex-direction:column;justify-content:flex-end}.sd-graph-legend{position:absolute;top:0;left:0;width:100%;display:flex;justify-content:center;gap:15px;z-index:5}.sd-legend-item{display:flex;align-items:center;gap:5px;font-size:.75rem;font-weight:600;color:var(--text-dark)}.sd-legend-color{width:10px;height:10px;border-radius:2px}.sd-graph-y-axis{position:absolute;top:40px;left:0;bottom:30px;display:flex;flex-direction:column;justify-content:space-between;color:var(--text-muted);font-size:.65rem;font-weight:600;width:25px;text-align:right}.sd-graph-axes{position:absolute;inset:40px 0 30px 30px;display:flex;flex-direction:column;justify-content:space-between;z-index:1}.sd-axis-line{border-top:1px dashed var(--border);width:100%;height:0}.sd-graph-bars{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-end;height:calc(100% - 30px);padding:0 0 0 10px}.sd-month-group{display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;flex:1}.sd-month-bars{flex-grow:1;width:100%;display:flex;align-items:flex-end;justify-content:center;gap:4px;position:relative}.sd-month-bar{width:12px;border-radius:3px 3px 0 0;position:relative;transition:height .6s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000001a}@media(max-width:1200px){.sd-month-bar{width:8px}}.sd-month-bar:hover{filter:brightness(1.15);cursor:pointer}.sd-month-bar .sd-graph-value{opacity:0;transition:opacity .2s;pointer-events:none}.sd-month-bar:hover .sd-graph-value{opacity:1}.sd-graph-value{position:absolute;top:-22px;left:50%;transform:translate(-50%);font-size:.7rem;font-weight:700;color:var(--text-dark);background:var(--bg-main);padding:2px 6px;border-radius:4px;border:1px solid var(--border);box-shadow:0 1px 3px #0000001a;z-index:10}.sd-graph-label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-align:center;text-transform:uppercase}:root{--brand-black: #221F1F;--brand-blue: #497B97;--brand-red: #C20100;--brand-red-dk: #A00101;--brand-cream: #EBDBD6;--brand-white: #FFFFFF;--bg-page: #F4F2F0;--bg-card: #FFFFFF;--border: #E0D9D4;--border-md: #C8BDB8;--text-pri: #221F1F;--text-muted: #7A706C;--text-light: #A89E9A;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--sh-sm: 0 1px 3px rgba(34,31,31,.07);--sh-md: 0 4px 16px rgba(34,31,31,.1)}.id-wrapper{font-family:DM Sans,sans-serif;background:var(--bg-page);min-height:100vh;padding-bottom:3rem;color:var(--text-pri)}@keyframes id-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes id-spin{to{transform:rotate(360deg)}}@keyframes id-blink{0%,to{opacity:1}50%{opacity:.35}}.id-header{background:var(--brand-black);border-bottom:3px solid var(--brand-red);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.id-header-left{display:flex;align-items:center;gap:.85rem}.id-header-icon{width:42px;height:42px;background:var(--brand-red);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.id-header-title{font-size:1.1rem;font-weight:800;color:#fff;letter-spacing:-.015em;margin:0;text-transform:uppercase}.id-header-sub{font-size:.72rem;color:var(--brand-cream);opacity:.8;margin:0}.id-header-right{display:flex;align-items:center;gap:.6rem}.id-live-pill{display:flex;align-items:center;gap:6px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:.3rem .75rem;font-size:.7rem;font-weight:700;color:#ffffffd9;text-transform:uppercase;letter-spacing:.05em}.id-live-dot{width:7px;height:7px;background:#10b981;border-radius:50%;animation:id-blink 1.6s ease-in-out infinite;flex-shrink:0}.id-refresh-btn{width:34px;height:34px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-sm);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.id-refresh-btn:hover{background:#ffffff2e}.id-refresh-btn.spinning svg{animation:id-spin .75s linear infinite}.id-loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:60vh;color:var(--text-muted);font-size:.85rem}.id-loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--brand-red);border-radius:50%;animation:id-spin .75s linear infinite}.id-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.25rem 1.75rem 0}.id-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.1rem 1.1rem .9rem;display:flex;align-items:center;gap:.9rem;box-shadow:var(--sh-sm);position:relative;overflow:hidden;animation:id-rise .5s ease both}.id-stat-accent-bar{position:absolute;bottom:0;left:0;right:0;height:3px;border-radius:0 0 var(--r-lg) var(--r-lg)}.id-stat-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.id-stat-body{display:flex;flex-direction:column;gap:1px;min-width:0}.id-stat-value{font-size:1.65rem;font-weight:800;color:var(--text-pri);line-height:1;letter-spacing:-.02em}.id-stat-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.id-stat-sub{font-size:.68rem;color:var(--text-light);margin-top:1px}.id-main-grid{display:grid;grid-template-columns:1fr 380px;gap:1.1rem;padding:1.1rem 1.75rem 0;align-items:start}.id-col-left,.id-col-right{display:flex;flex-direction:column;gap:1.1rem}.id-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden;animation:id-rise .5s ease both}.id-section-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.1rem;background:var(--brand-black);border-bottom:2px solid var(--brand-red)}.id-section-title-group{display:flex;align-items:center;gap:.6rem}.id-section-icon{width:28px;height:28px;background:var(--brand-red);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.id-section-title{font-size:.82rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.04em;margin:0}.id-section-sub{font-size:.66rem;color:#ffffff80;margin:0}.id-section-link{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--brand-cream);font-family:DM Sans,sans-serif;font-size:.7rem;font-weight:600;cursor:pointer;opacity:.75;transition:opacity .15s}.id-section-link:hover{opacity:1}.id-card-body{display:flex;flex-direction:column}.id-empty-state{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2.5rem 1rem;color:var(--text-light);font-size:.82rem}.id-alert-row{display:flex;align-items:center;gap:.75rem;padding:.65rem 1.1rem;border-bottom:1px solid var(--border);transition:background .12s}.id-alert-row:last-child{border-bottom:none}.id-alert-row:hover{background:#faf7f5}.id-alert-dot-wrap{flex-shrink:0}.id-alert-dot{display:block;width:8px;height:8px;border-radius:50%}.id-alert-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.id-alert-name{font-size:.8rem;font-weight:700;color:var(--text-pri);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.id-alert-meta{font-size:.7rem;color:var(--text-muted)}.id-avail-badge{flex-shrink:0;font-size:.62rem;font-weight:700;padding:.18rem .5rem;border-radius:20px;white-space:nowrap}.id-feed-row{display:flex;align-items:center;gap:.75rem;padding:.65rem 1.1rem;border-bottom:1px solid var(--border);transition:background .12s}.id-feed-row:last-child{border-bottom:none}.id-feed-row:hover{background:#faf7f5}.id-feed-icon{width:30px;height:30px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.feed-done{background:#10b9811a;color:#065f46}.feed-transit{background:#497b971f;color:#497b97}.feed-intl{background:#c2010014;color:var(--brand-red)}.feed-local{background:#497b971f;color:#2d5f78}.id-feed-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.id-feed-title{font-size:.8rem;font-weight:700;color:var(--text-pri);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.id-feed-cat{font-weight:400;color:var(--text-muted);font-size:.75rem}.id-feed-meta{font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.id-feed-right{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:2px}.id-feed-date{font-size:.65rem;color:var(--text-light)}.id-tba{font-style:italic}.id-delivery-badge{font-size:.62rem;font-weight:700;padding:.16rem .45rem;border-radius:20px;white-space:nowrap}.badge-delivered{background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.badge-transit{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.id-ship-badge{font-size:.62rem;font-weight:700;padding:.16rem .45rem;border-radius:20px;white-space:nowrap}.badge-arrived{background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.badge-departure{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.badge-waiting{background:#fffbeb;color:#92400e;border:1px solid #FCD34D}.id-inv-chip{display:inline-block;margin-left:6px;background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0;border-radius:4px;font-size:.6rem;font-weight:700;padding:.08rem .35rem;vertical-align:middle}.id-arrived-banner{display:flex;align-items:center;gap:8px;background:#ecfdf5;border-bottom:1px solid #A7F3D0;padding:.55rem 1.1rem;font-size:.75rem;color:#065f46;font-weight:600}.id-snapshot-bars{padding:1rem 1.1rem .6rem;display:flex;flex-direction:column;gap:.65rem}.id-snapshot-row{display:grid;grid-template-columns:72px 1fr 30px;align-items:center;gap:.6rem}.id-snap-label{font-size:.72rem;font-weight:600;color:var(--text-muted);white-space:nowrap}.id-snap-bar-track{height:8px;background:var(--bg-page);border-radius:20px;overflow:hidden;border:1px solid var(--border)}.id-snap-bar{height:100%;border-radius:20px;transition:width .6s ease;min-width:4px}.id-snap-bar.on{background:#10b981}.id-snap-bar.low{background:#f59e0b}.id-snap-bar.none{background:var(--brand-red)}.id-snap-count{font-size:.75rem;font-weight:700;color:var(--text-pri);text-align:right}.id-nostock-list{border-top:1px solid var(--border);padding:.75rem 1.1rem}.id-nostock-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--brand-red);margin-bottom:.45rem}.id-nostock-row{display:flex;align-items:center;gap:.5rem;padding:.28rem 0;border-bottom:1px dashed var(--border)}.id-nostock-row:last-child{border-bottom:none}.id-nostock-dot{width:6px;height:6px;background:var(--brand-red);border-radius:50%;flex-shrink:0}.id-nostock-cat{font-size:.7rem;color:var(--text-muted);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.id-nostock-code{font-size:.72rem;font-weight:700;color:var(--text-pri);font-family:DM Mono,monospace}.id-nostock-more{font-size:.68rem;color:var(--text-light);font-style:italic;margin-top:.35rem}.id-footer{display:flex;align-items:center;gap:6px;padding:1.25rem 1.75rem 0;font-size:.7rem;color:var(--text-light)}.id-section-loading{display:flex;align-items:center;gap:.6rem;padding:1.5rem 1.1rem;font-size:.8rem;color:var(--text-muted)}.id-spinner-sm{width:18px!important;height:18px!important;border-width:2px!important;flex-shrink:0}.id-section-error{display:flex;align-items:center;gap:.55rem;padding:1rem 1.1rem;font-size:.78rem;color:#b91c1c;background:#fef2f2;border-top:1px solid #FECACA}@media(max-width:1100px){.id-stats-grid{grid-template-columns:repeat(2,1fr)}.id-main-grid{grid-template-columns:1fr}}@media(max-width:640px){.id-header{padding:.85rem 1rem;flex-wrap:wrap;gap:.75rem}.id-stats-grid{grid-template-columns:1fr 1fr;padding:.85rem 1rem 0;gap:.65rem}.id-main-grid{padding:.85rem 1rem 0}.id-stat-value{font-size:1.35rem}.id-live-pill{display:none}}@media(max-width:420px){.id-stats-grid{grid-template-columns:1fr}}:root{--brand-black: #221F1F;--brand-blue: #497B97;--brand-red: #C20100;--brand-red-dk: #A00101;--brand-cream: #EBDBD6;--bg-page: #F4F2F0;--bg-card: #FFFFFF;--border: #E0D9D4;--border-md: #C8BDB8;--text-pri: #221F1F;--text-muted:#7A706C;--text-light:#A89E9A;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--sh-sm: 0 1px 3px rgba(34,31,31,.08);--sh-md: 0 4px 16px rgba(34,31,31,.12)}*{box-sizing:border-box;margin:0;padding:0}.ac-wrapper{font-family:DM Sans,sans-serif;background:var(--bg-page);min-height:100vh;padding-bottom:3rem;color:var(--text-pri)}.ac-header{background:var(--brand-black);border-bottom:3px solid var(--brand-red);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between}.ac-header-left{display:flex;align-items:center;gap:.85rem}.ac-header-icon{width:38px;height:38px;background:var(--brand-red);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.ac-title{font-size:1.05rem;font-weight:700;color:#fff;letter-spacing:-.01em}.ac-subtitle{font-size:.72rem;color:var(--brand-cream);opacity:.75}.ac-refresh-btn{width:34px;height:34px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-sm);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.ac-refresh-btn:hover{background:#ffffff2e}.ac-refresh-btn.spinning svg{animation:ac-spin .8s linear infinite}@keyframes ac-spin{to{transform:rotate(360deg)}}.ac-stats{display:flex;gap:1rem;padding:1rem 1.75rem;flex-wrap:wrap}.ac-stat{display:flex;align-items:center;gap:.75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:.75rem 1.1rem;box-shadow:var(--sh-sm);min-width:160px}.ac-stat-icon{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.icon-red{background:#c201001a;color:var(--brand-red)}.icon-blue{background:#497b971a;color:var(--brand-blue)}.ac-stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.ac-stat-value{font-size:1.2rem;font-weight:700;color:var(--text-pri);line-height:1.1}.ac-body{display:grid;grid-template-columns:1fr 380px;gap:1.25rem;padding:0 1.75rem;align-items:start}.ac-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden}.ac-card-head{display:flex;align-items:center;gap:.5rem;background:var(--brand-black);color:#fff;padding:.75rem 1.1rem;font-size:.82rem;font-weight:700;border-bottom:2px solid var(--brand-red)}.ac-form{padding:1.2rem 1.2rem 1rem;display:flex;flex-direction:column;gap:.85rem}.ac-form-group{display:flex;flex-direction:column;gap:.3rem}.ac-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.ac-req{color:var(--brand-red)}.ac-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.65rem}.ac-form-row-3{grid-template-columns:1fr .6fr .8fr}.mt-6{margin-top:6px}.ac-origin-toggle{display:flex;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.ac-origin-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:.45rem .75rem;background:none;border:none;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.ac-origin-btn.active{background:var(--brand-red);color:#fff;border-radius:var(--r-sm);font-weight:700}.ac-input{font-family:DM Sans,sans-serif;font-size:.82rem;color:var(--text-pri);background:var(--bg-page);border:1px solid var(--border);border-radius:var(--r-sm);padding:.5rem .75rem;width:100%;transition:border-color .15s,box-shadow .15s}.ac-input:focus{outline:none;border-color:var(--brand-blue);box-shadow:0 0 0 3px #497b971f}.ac-select-wrap .ac-input{appearance:none;padding-right:2rem;cursor:pointer}.ac-sqm-wrap{position:relative}.ac-sqm-wrap .ac-input{padding-right:3rem}.ac-unit-tag{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:.65rem;font-weight:700;color:var(--text-light);text-transform:uppercase;pointer-events:none}.ac-projects{display:flex;flex-direction:column;gap:.6rem}.ac-project-card{background:#faf8f6;border:1px solid var(--border);border-left:3px solid var(--brand-red);border-radius:var(--r-sm);padding:.75rem .9rem;display:flex;flex-direction:column;gap:.45rem}.ac-project-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.ac-project-num{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--brand-red)}.ac-remove-btn{display:flex;align-items:center;gap:4px;background:none;border:none;font-family:DM Sans,sans-serif;font-size:.7rem;color:var(--text-muted);cursor:pointer;padding:2px 6px;border-radius:var(--r-sm);transition:background .12s,color .12s}.ac-remove-btn:hover{background:#fef2f2;color:var(--brand-red)}.ac-add-project-btn{display:flex;align-items:center;gap:6px;background:none;border:1.5px dashed var(--border-md);border-radius:var(--r-sm);padding:.5rem .85rem;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:600;color:var(--brand-blue);cursor:pointer;width:100%;justify-content:center;transition:background .12s,border-color .12s}.ac-add-project-btn:hover{background:#497b970f;border-color:var(--brand-blue)}.ac-submit-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;background:var(--brand-red);color:#fff;border:none;border-radius:var(--r-sm);padding:.65rem 1rem;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;margin-top:.25rem;transition:background .15s,transform .1s}.ac-submit-btn:hover{background:var(--brand-red-dk)}.ac-submit-btn:active{transform:scale(.98)}.ac-submit-btn:disabled{background:#ccc;cursor:not-allowed;transform:none}.ac-feed{display:flex;flex-direction:column;padding:.5rem 0}.ac-feed-item{display:flex;align-items:flex-start;gap:.75rem;padding:.8rem 1.1rem;border-bottom:1px solid var(--border);transition:background .12s}.ac-feed-item:last-child{border-bottom:none}.ac-feed-item:hover{background:#faf8f6}.ac-feed-icon{width:30px;height:30px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.ac-feed-body{flex:1;min-width:0}.ac-feed-title{font-size:.82rem;font-weight:700;color:var(--text-pri);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ac-feed-sub{font-size:.7rem;color:var(--text-muted);margin-top:1px}.ac-feed-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}.ac-project-tag{background:#497b971a;color:#2d5f78;border:1px solid rgba(73,123,151,.2);padding:.12rem .45rem;border-radius:4px;font-size:.65rem;font-weight:600;white-space:nowrap}.ac-status-tag{flex-shrink:0;font-size:.65rem;font-weight:700;padding:.22rem .55rem;border-radius:20px;white-space:nowrap;align-self:flex-start;margin-top:3px}.tag-arrived{background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.tag-departure{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.tag-waiting{background:#fffbeb;color:#92400e;border:1px solid #FCD34D}.ac-loading{display:flex;align-items:center;gap:8px;padding:2rem 1.1rem;font-size:.82rem;color:var(--text-muted)}.ac-empty{padding:2rem 1.1rem;text-align:center;font-size:.82rem;color:var(--text-light)}.ac-spinner{animation:ac-spin .75s linear infinite}@media(max-width:900px){.ac-body{grid-template-columns:1fr}}@media(max-width:640px){.ac-header,.ac-stats,.ac-body{padding-left:1rem;padding-right:1rem}.ac-form-row{grid-template-columns:1fr}.ac-form-row-3{grid-template-columns:1fr 1fr}}.ac-purpose-toggle{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.ac-purpose-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:.65rem .75rem;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg-page);font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .15s;text-align:center}.ac-purpose-btn:hover{border-color:var(--brand-red);color:var(--brand-red);background:#c201000a}.ac-purpose-btn.active{border-color:var(--brand-red);background:var(--brand-red);color:#fff;font-weight:700}.ac-purpose-hint{font-size:.7rem;color:var(--text-light);line-height:1.5;margin-top:4px}.ac-stock-card{border-left-color:var(--brand-blue)!important}.ac-label-sm{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);display:block;margin-bottom:.28rem}.ac-new-field-wrap{display:flex;gap:5px;align-items:center}.ac-new-field-wrap .ac-input{flex:1;border-color:var(--brand-blue);box-shadow:0 0 0 2px #497b971f}.ac-back-pick-btn{flex-shrink:0;background:var(--bg-page);border:1px solid var(--border-md);border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.68rem;font-weight:600;color:var(--text-muted);padding:.38rem .55rem;cursor:pointer;white-space:nowrap;transition:background .12s,color .12s}.ac-back-pick-btn:hover{background:var(--brand-cream);color:var(--text-pri)}.ac-feed-meta-row{display:flex;align-items:center;gap:6px;margin-top:1px;flex-wrap:wrap}.ac-purpose-tag{font-size:.62rem;font-weight:700;padding:.1rem .4rem;border-radius:20px;white-space:nowrap}.purpose-reserve{background:#c2010014;color:var(--brand-red);border:1px solid rgba(194,1,0,.2)}.purpose-stock{background:#497b971a;color:#2d5f78;border:1px solid rgba(73,123,151,.2)}.ac-stat-warn{border-color:#fcd34d;background:#fffbeb;transition:box-shadow .15s}.ac-stat-warn:hover{box-shadow:0 4px 16px #f59e0b2e}.icon-warn{background:#f59e0b1f;color:#92400e}.ac-card-head-tabs{padding:0!important;background:var(--brand-black);display:flex!important;border-bottom:2px solid var(--brand-red)}.ac-tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:.65rem .75rem;background:none;border:none;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:600;color:#ffffff80;cursor:pointer;transition:color .15s,background .15s;position:relative}.ac-tab-btn:hover{color:#fffc}.ac-tab-btn.active{color:#fff;background:#ffffff0f;border-bottom:2px solid var(--brand-red)}.ac-tab-btn.has-alert{color:#fcd34d}.ac-tab-btn.has-alert.active{color:#fcd34d;border-bottom-color:#f59e0b}.ac-tab-badge{background:#c20100;color:#fff;border-radius:20px;font-size:.62rem;font-weight:800;min-width:16px;height:16px;padding:0 4px;display:inline-flex;align-items:center;justify-content:center}.ac-feed-item-btn{width:100%;text-align:left;background:none;border:none;font-family:DM Sans,sans-serif;cursor:pointer}.ac-report-feed-item:hover{background:#fffbeb!important}.ac-report-tag{background:#f59e0b1a;color:#92400e;border:1px solid rgba(245,158,11,.25);padding:.1rem .4rem;border-radius:4px;font-size:.63rem;font-weight:600;white-space:nowrap}.ac-view-report{flex-shrink:0;font-size:.7rem;font-weight:700;color:#92400e;white-space:nowrap;align-self:center}.ac-overlay{position:fixed;inset:0;background:#221f1f8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.ac-modal{background:#fff;border-radius:12px;box-shadow:0 12px 40px #221f1f33;width:100%;max-width:580px;max-height:88vh;overflow-y:auto;animation:ac-modal-in .2s cubic-bezier(.22,1,.36,1)}@keyframes ac-modal-in{0%{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.ac-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.2rem;border-bottom:1px solid #E0D9D4;border-radius:12px 12px 0 0}.ac-modal-header-warn{background:#78350f;border-bottom:2px solid #F59E0B}.ac-modal-header-warn .ac-modal-title{color:#fff;font-size:.95rem;font-weight:700}.ac-modal-header-warn .ac-modal-sub{color:#fde68a;font-size:.72rem}.ac-modal-close{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fff;width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;transition:background .12s}.ac-modal-close:hover{background:#ffffff38}.ac-modal-body{padding:1rem 1.2rem}.ac-report-table{width:100%;border-collapse:collapse;font-size:.8rem;border:1px solid #E0D9D4;border-radius:8px;overflow:hidden}.ac-report-table thead tr{background:#221f1f}.ac-report-table thead th{color:#ffffffbf;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.55rem .8rem;text-align:left}.ac-report-table tbody tr{border-bottom:1px solid #EDE9E6}.ac-report-table tbody tr:last-child{border-bottom:none}.ac-report-table tbody td{padding:.55rem .8rem;vertical-align:middle}.ac-code{font-family:monospace;font-size:.75rem;color:#221f1f}.ac-issue{color:#7a706c;font-size:.77rem}.ac-cond-tag{display:inline-block;font-size:.68rem;font-weight:700;padding:.18rem .5rem;border-radius:4px}.cond-defective{background:#fffbeb;color:#78350f}.cond-wrong-item{background:#f5f3ff;color:#5b21b6}.ac-report-meta{margin-top:.75rem;font-size:.7rem;color:#a89e9a;text-align:right}@keyframes sa-spin{to{transform:rotate(360deg)}}@keyframes sa-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes sa-blink{0%,to{opacity:1}50%{opacity:.3}}.sa-wrapper{font-family:DM Sans,sans-serif;background:var(--bg-page);min-height:100vh;padding:0 0 3rem;color:var(--text-pri)}.sa-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;color:var(--text-muted);font-weight:500}.sa-spinner{width:30px;height:30px;border:3px solid var(--border);border-top-color:var(--brand-red);border-radius:50%;animation:sa-spin .7s linear infinite;margin-bottom:15px}.sa-header{background:var(--brand-black);border-bottom:3px solid var(--brand-red);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.sa-header-left{display:flex;align-items:center;gap:.85rem}.sa-header-right{display:flex;align-items:center;gap:.65rem}.sa-header-icon{width:42px;height:42px;background:var(--brand-red);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sa-title{font-size:1.05rem;font-weight:800;color:#fff;letter-spacing:-.01em;text-transform:uppercase;margin:0}.sa-subtitle{font-size:.72rem;color:var(--brand-cream);opacity:.8;margin:0}.sa-live-badge{display:flex;align-items:center;gap:6px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:.3rem .85rem;font-size:.7rem;font-weight:600;color:#fffc;white-space:nowrap}.sa-live-dot{width:7px;height:7px;background:#10b981;border-radius:50%;animation:sa-blink 1.6s infinite;flex-shrink:0}.sa-clock{font-size:.68rem;color:#ffffff80;white-space:nowrap;font-variant-numeric:tabular-nums}.sa-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.25rem 1.75rem 0}.sa-kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.1rem 1.1rem .9rem;display:flex;align-items:center;gap:.9rem;box-shadow:var(--sh-sm);animation:sa-rise .5s ease both;overflow:hidden;position:relative;transition:transform .18s,box-shadow .18s}.sa-kpi-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--kpi-accent, var(--brand-blue));border-radius:0 0 var(--r-lg) var(--r-lg)}.sa-kpi-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}.sa-kpi-card.sa-kpi-alert{background:var(--brand-red);border-color:var(--brand-red-dk)}.sa-kpi-card.sa-kpi-alert:after{background:var(--brand-red-dk)}.sa-kpi-card.sa-kpi-alert .sa-kpi-data h3,.sa-kpi-card.sa-kpi-alert .sa-kpi-data p,.sa-kpi-card.sa-kpi-alert .sa-kpi-note{color:#fff}.sa-kpi-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sa-kpi-data h3{font-size:1.65rem;font-weight:800;color:var(--text-pri);line-height:1;letter-spacing:-.025em;margin:0}.sa-kpi-data p{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:4px 0 0}.sa-kpi-note{font-size:.67rem;color:var(--text-light);margin:2px 0 0}.sa-main-grid{display:grid;grid-template-columns:3fr 2fr;gap:1.1rem;padding:1.1rem 1.75rem 0;align-items:start}.sa-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden;animation:sa-rise .5s ease both;display:flex;flex-direction:column}.sa-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:.75rem 1.1rem;background:var(--brand-black);border-bottom:2px solid var(--brand-red)}.sa-panel-header-text h2{font-size:.82rem;font-weight:700;color:#fff;margin:0;text-transform:uppercase;letter-spacing:.06em}.sa-panel-header-text p{font-size:.7rem;color:var(--brand-cream);opacity:.7;margin:2px 0 0}.sa-panel-header-action{display:flex;align-items:center;gap:6px;background:#10b981;color:#fff;border:none;padding:6px 12px;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .2s,transform .2s;flex-shrink:0}.sa-panel-header-action:hover{background:#059669;transform:translateY(-1px)}.sa-bottleneck-list{padding:1rem 1.1rem;display:flex;flex-direction:column;gap:1rem}.sa-dept-row{display:flex;flex-direction:column;gap:6px}.sa-dept-info{display:flex;justify-content:space-between;font-size:.82rem;font-weight:600}.sa-dept-name{color:var(--text-pri)}.sa-dept-count{color:var(--text-muted);font-weight:700}.sa-progress-bar{width:100%;height:7px;background:var(--bg-page);border:1px solid var(--border);border-radius:20px;overflow:hidden}.sa-progress-fill{height:100%;border-radius:20px;transition:width 1.1s cubic-bezier(.4,0,.2,1);min-width:3px}.sa-activity-feed{padding:.85rem 1.1rem;flex:1;display:flex;flex-direction:column;gap:.85rem}.sa-feed-item{display:flex;gap:.65rem;align-items:flex-start;padding-bottom:.85rem;border-bottom:1px solid var(--border)}.sa-feed-item:last-child{border-bottom:none;padding-bottom:0}.sa-feed-icon{margin-top:2px;color:var(--text-light);flex-shrink:0}.sa-feed-content{flex:1}.sa-feed-desc{font-size:.8rem;margin:0 0 3px;color:var(--text-pri);line-height:1.45}.sa-feed-desc strong{color:var(--brand-black)}.sa-feed-time{font-size:.68rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.05em}.sa-no-data{font-size:.82rem;color:var(--text-light);text-align:center;padding:2rem 0}.sa-panel-footer{padding:.75rem 1.1rem;border-top:1px solid var(--border);text-align:center}.sa-btn-link{background:none;border:none;color:var(--brand-red);font-weight:700;font-size:.78rem;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:color .15s;font-family:DM Sans,sans-serif}.sa-btn-link:hover{color:var(--brand-red-dk)}@media(max-width:1100px){.sa-kpi-grid{grid-template-columns:repeat(2,1fr)}.sa-main-grid{grid-template-columns:1fr}}@media(max-width:640px){.sa-header{padding:.85rem 1rem;flex-wrap:wrap}.sa-kpi-grid{padding:.85rem 1rem 0;gap:.65rem}.sa-main-grid{padding:.85rem 1rem 0}.sa-live-badge{display:none}}@media(max-width:420px){.sa-kpi-grid{grid-template-columns:1fr 1fr}}.sa-kpi-split{display:flex;gap:8px;font-size:.75rem;margin-top:6px;font-weight:700}.sa-active-text{color:#059669}.sa-trashed-text{color:#dc2626}.sa-divider{color:#cbd5e1;font-weight:400}.sa-bar-chart{display:flex;align-items:flex-end;justify-content:space-around;height:220px;padding:30px 10px 0;border-bottom:1px dashed #e2e8f0;margin-top:10px;margin-bottom:15px}.sa-bar-col{display:flex;flex-direction:column;align-items:center;gap:10px;width:50px;height:100%;justify-content:flex-end}.sa-bar-fill{width:100%;border-radius:4px 4px 0 0;position:relative;transition:height .6s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0000001a}.sa-bar-fill:hover{filter:brightness(1.15);cursor:default}.sa-bar-val{position:absolute;top:-24px;left:50%;transform:translate(-50%);font-size:.7rem;font-weight:800;color:#1e293b;background:#fff;padding:2px 8px;border-radius:4px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a}.sa-bar-label{font-size:.7rem;font-weight:700;color:#64748b;text-align:center;line-height:1.2}@media(min-width:1024px){.sa-main-grid{grid-template-columns:repeat(3,1fr)}}@keyframes mgr-spin{to{transform:rotate(360deg)}}@keyframes mgr-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes mgr-blink{0%,to{opacity:1}50%{opacity:.3}}.manager-wrapper{font-family:DM Sans,sans-serif;background:var(--bg-page);min-height:100vh;padding:0 0 3rem;color:var(--text-pri)}.manager-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;color:var(--text-muted);font-weight:500;gap:15px}.manager-spinner{width:30px;height:30px;border:3px solid var(--border);border-top-color:var(--brand-red);border-radius:50%;animation:mgr-spin .7s linear infinite}.manager-header{background:var(--brand-black);border-bottom:3px solid var(--brand-red);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:0}.manager-header-left{display:flex;align-items:center;gap:.85rem}.manager-header-icon{width:42px;height:42px;background:var(--brand-red);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.manager-title{font-size:1.05rem;font-weight:800;color:#fff;letter-spacing:-.01em;text-transform:uppercase;margin:0}.manager-subtitle{font-size:.72rem;color:var(--brand-cream);opacity:.8;margin:0;background:none;padding:0;border-radius:0;display:block;font-weight:400}.manager-date-badge{display:flex;align-items:center;gap:6px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:.3rem .85rem;font-size:.7rem;font-weight:600;color:#fffc;white-space:nowrap}.manager-kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1.25rem 1.75rem 0;margin-bottom:0}.manager-kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.1rem 1.1rem .9rem;display:flex;align-items:center;gap:.9rem;box-shadow:var(--sh-sm);animation:mgr-rise .5s ease both;overflow:hidden;position:relative;transition:transform .18s,box-shadow .18s}.manager-kpi-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--kpi-accent, var(--brand-blue));border-radius:0 0 var(--r-lg) var(--r-lg)}.manager-kpi-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}.manager-kpi-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.manager-kpi-data h3{font-size:1.65rem;font-weight:800;color:var(--text-pri);line-height:1;letter-spacing:-.025em;margin:0}.manager-kpi-data p{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:4px 0 0}.manager-main-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;padding:1.1rem 1.75rem 0;align-items:start}@media(max-width:900px){.manager-main-grid{grid-template-columns:1fr}}.manager-graph-row{padding:0 1.75rem;margin-top:1.1rem}.manager-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden;animation:mgr-rise .5s ease both;display:flex;flex-direction:column}.manager-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:.75rem 1.1rem;background:var(--brand-black);border-bottom:2px solid var(--brand-red)}.manager-panel-header h2{font-size:.82rem;font-weight:700;color:#fff;margin:0;text-transform:uppercase;letter-spacing:.06em}.manager-panel-header p{font-size:.7rem;color:var(--brand-cream);opacity:.7;margin:2px 0 0}.manager-pipeline{padding:.85rem 1.1rem;display:flex;flex-direction:column;gap:.7rem}.pipeline-stage{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-md);padding:.85rem 1rem;transition:box-shadow .15s,transform .15s}.pipeline-stage:hover{box-shadow:var(--sh-sm);transform:translate(3px)}.stage-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.stage-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.stage-header h4{margin:0;font-size:.82rem;font-weight:700;color:var(--text-pri)}.stage-value{font-size:1.15rem;font-weight:800;color:var(--brand-black);margin-bottom:3px;letter-spacing:-.02em}.stage-desc{font-size:.72rem;color:var(--text-muted);margin:0}.manager-activity-list{padding:.85rem 1.1rem;display:flex;flex-direction:column;gap:.75rem;flex:1}.activity-row{display:flex;gap:.65rem;align-items:flex-start;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.activity-row:last-child{border-bottom:none;padding-bottom:0}.activity-bullet{width:7px;height:7px;background:var(--brand-blue);border-radius:50%;margin-top:5px;flex-shrink:0}.activity-content p{font-size:.8rem;margin:0 0 3px;color:var(--text-pri);line-height:1.45}.activity-content p strong{color:var(--brand-black)}.activity-content span{font-size:.68rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.05em}.no-activity{font-size:.82rem;color:var(--text-light);text-align:center;padding:2rem 0}.mgr-graph-wrap{padding:1rem 1.1rem 1.25rem}.mgr-graph-legend{display:flex;gap:16px;justify-content:flex-end;margin-bottom:1rem}.mgr-legend-item{display:flex;align-items:center;gap:5px;font-size:.7rem;font-weight:600;color:var(--text-muted)}.mgr-legend-dot{width:9px;height:9px;border-radius:2px}.mgr-graph-inner{display:flex;gap:8px;height:200px;align-items:flex-end}.mgr-y-axis{display:flex;flex-direction:column;justify-content:space-between;height:100%;padding-bottom:24px;flex-shrink:0}.mgr-y-label{font-size:.62rem;font-weight:600;color:var(--text-light);text-align:right;line-height:1}.mgr-graph-body{flex:1;display:flex;flex-direction:column;height:100%;position:relative}.mgr-grid-lines{position:absolute;inset:0 0 24px;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}.mgr-grid-line{border-top:1px dashed var(--border);width:100%}.mgr-bars-row{flex:1;display:flex;justify-content:space-around;align-items:flex-end;gap:8px;padding:0 4px;position:relative;z-index:1}.mgr-bar-group{display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;flex:1;max-width:80px}.mgr-bars{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;gap:4px}.mgr-bar{width:14px;border-radius:3px 3px 0 0;position:relative;transition:height .7s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #221f1f1f;cursor:default}.mgr-bar:hover{filter:brightness(1.12)}.mgr-bar-tip{position:absolute;top:-22px;left:50%;transform:translate(-50%);font-size:.62rem;font-weight:800;color:var(--text-pri);background:var(--bg-card);padding:1px 5px;border-radius:var(--r-sm);border:1px solid var(--border);box-shadow:var(--sh-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s}.mgr-bar:hover .mgr-bar-tip{opacity:1}.mgr-bar-label{font-size:.65rem;font-weight:700;color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:.04em;line-height:1.2;height:24px;display:flex;align-items:center;justify-content:center}.manager-pipeline-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}@media(max-width:640px){.manager-pipeline-grid{grid-template-columns:1fr}}@media(max-width:1100px){.manager-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.manager-header{padding:.85rem 1rem;flex-wrap:wrap}.manager-kpi-grid{padding:.85rem 1rem 0;gap:.65rem}.manager-main-grid{padding:.85rem 1rem 0}.manager-graph-row{padding:0 1rem}.manager-date-badge{display:none}}@media(max-width:420px){.manager-kpi-grid{grid-template-columns:1fr 1fr}}.manager-kpi-split{display:flex;gap:8px;font-size:.75rem;margin-top:6px;font-weight:700}.manager-active-text{color:#059669}.manager-trashed-text{color:#dc2626}.manager-divider{color:#cbd5e1;font-weight:400}:root{--vision-red: #FF1817;--vision-red-deep: #C20100;--vision-blue: #497B97;--vision-charcoal: #221F1F;--vision-white: #FFFFFF;--vision-off-white: #EBDBD6;--vision-bg-light: #f8fafc;--vision-green: #16a34a;--vision-green-deep: #166534;--shadow-sm: 0 1px 3px rgba(0,0,0,.1);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.1);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1);--transition: all .2s ease-in-out}.customer-container{padding:24px;max-width:1400px;margin:0 auto;box-sizing:border-box;animation:fadeIn .3s ease-in-out;background-color:var(--vision-bg-light);min-height:100vh;font-family:DM Sans,sans-serif}.customer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:var(--vision-white);padding:20px 32px;border-radius:12px;box-shadow:var(--shadow-sm);border-bottom:4px solid var(--vision-red);box-sizing:border-box}.customer-header h1{font-family:DM Sans,sans-serif;font-size:1.8rem;color:var(--vision-charcoal);margin:0}.header-actions{display:flex;gap:12px}.lead-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;justify-content:center;animation:fadeIn .5s ease-in}.lead-card{background:var(--vision-white);border-radius:12px;border:1px solid var(--vision-off-white);padding:20px;transition:var(--transition);display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;height:100%;box-sizing:border-box}.lead-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--vision-blue)}.lead-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.lead-id{font-size:.8rem;color:var(--vision-blue);font-weight:700}.status-badge{padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase}.to-be-contacted{background:#fee2e2;color:#991b1b}.contacted{background:#dcfce7;color:#166534}.for-presentation{background:#dbeafe;color:#1e40af}.ready-for-creating-project{background:#fef08a;color:#854d0e}.project-created{background:#e0e7ff;color:#3730a3}.lead-body h3{font-size:1.15rem;font-weight:700;color:var(--vision-charcoal);margin-bottom:8px;margin-top:0}.lead-body p{font-size:.9rem;color:var(--vision-blue);margin-bottom:12px;margin-top:0}.lead-body small{display:block;font-size:.85rem;color:#64748b;margin-bottom:15px}.lead-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:15px;border-top:1px solid #f1f5f9}.lead-click-hint{font-size:.7rem;color:var(--vision-blue);font-style:italic;margin-top:0}.btn-create-project{background:var(--vision-blue);color:#fff;padding:8px 14px;border-radius:6px;border:none;font-weight:700;font-size:.8rem;cursor:pointer;transition:var(--transition)}.btn-create-project:hover{background:#3a637a;transform:translateY(-1px)}.modal-overlay{position:fixed;inset:0;background:#221f1fb3;display:flex;align-items:center;justify-content:center;z-index:2001;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.compact-modal{background:#fff;width:100%;max-width:600px;border-radius:20px;padding:24px;box-shadow:0 20px 25px -5px #0003;border-top:12px solid var(--vision-red);box-sizing:border-box}.modal-header-compact h2{margin-top:0;color:var(--vision-charcoal);font-size:1.5rem}.compact-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group-compact{display:flex;flex-direction:column;gap:6px}.form-group-compact.full-width{grid-column:span 2}.form-group-compact label{font-size:.85rem;font-weight:700;color:var(--vision-charcoal);text-transform:uppercase}.form-group-compact input,.form-group-compact select,.form-group-compact textarea{padding:10px;border:1px solid var(--vision-off-white);border-radius:8px;font-size:.9rem;transition:border-color .2s;box-sizing:border-box}.form-group-compact input:focus,.form-group-compact select:focus,.form-group-compact textarea:focus{outline:none;border-color:var(--vision-blue)}.modal-footer-compact{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid #f1f5f9}.footer-right{display:flex;gap:12px}.btn-save-lead,.btn-update-save,.btn-add-lead{background-color:var(--vision-red);color:#fff;padding:10px 20px;border-radius:8px;border:none;font-weight:700;cursor:pointer;transition:background .2s}.btn-save-lead:hover,.btn-add-lead:hover{background-color:var(--vision-red-deep)}.btn-delete{background:transparent;color:var(--vision-red);border:1px solid #fee2e2;padding:10px 16px;border-radius:8px;font-weight:700;cursor:pointer;transition:var(--transition)}.btn-delete:hover{background:#fef2f2}.btn-cancel{background:var(--vision-bg-light);color:var(--vision-charcoal);padding:10px 20px;border-radius:8px;border:1px solid var(--vision-off-white);font-weight:700;cursor:pointer;transition:var(--transition)}.btn-cancel:hover{background:#e2e8f0}.locked-input-field{background-color:var(--vision-bg-light)!important;color:var(--vision-blue)!important;border:1px solid var(--vision-off-white)!important;font-weight:700;cursor:not-allowed}.spinner-container{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:50px}.loading-circle{width:50px;height:50px;border:5px solid var(--vision-off-white);border-top:5px solid var(--vision-blue);border-radius:50%;animation:spin 1s linear infinite}.no-leads-container{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;background:var(--vision-white);border:3px dashed var(--vision-off-white);border-radius:20px;text-align:center}.no-leads-icon{font-size:4rem;margin-bottom:20px;color:var(--vision-off-white)}.no-leads-container h3{color:var(--vision-charcoal);margin-bottom:10px;font-size:1.6rem}.no-leads-container p{color:var(--vision-blue);max-width:450px;font-size:1rem;line-height:1.6}.trash-item-actions{display:flex;gap:10px}.btn-restore{background:var(--vision-green);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:700;cursor:pointer;transition:var(--transition)}.btn-restore:hover{background:var(--vision-green-deep);transform:translateY(-1px)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.floating-history-btn{position:fixed;bottom:30px;right:30px;background-color:var(--vision-blue);color:var(--vision-white);padding:14px 28px;border-radius:50px;box-shadow:var(--shadow-lg);cursor:pointer;font-weight:700;font-size:.95rem;z-index:900;display:flex;align-items:center;gap:10px;transition:var(--transition);border:2px solid transparent}.floating-history-btn:hover{transform:translateY(-4px);background-color:var(--vision-charcoal);box-shadow:0 15px 25px -5px #0003}.history-list{max-height:400px;overflow-y:auto;padding:10px 5px;margin:10px 0}.history-list::-webkit-scrollbar{width:6px}.history-list::-webkit-scrollbar-track{background:var(--vision-bg-light);border-radius:10px}.history-list::-webkit-scrollbar-thumb{background:var(--vision-off-white);border-radius:10px}.history-list::-webkit-scrollbar-thumb:hover{background:var(--vision-blue)}.history-item{padding:16px;border-bottom:1px solid var(--vision-off-white);display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:12px;transition:var(--transition);cursor:pointer}.history-item:last-child{border-bottom:none}.history-item:hover{background-color:var(--vision-bg-light);border-radius:8px}.history-item-content{display:flex;flex-direction:column;gap:4px}.history-item-title{font-weight:700;color:var(--vision-charcoal);font-size:1.05rem}.history-item-client{color:var(--vision-blue);font-weight:500;font-size:.9rem}@media screen and (max-width:768px){.customer-header{flex-direction:column;align-items:center;text-align:center;gap:16px;padding:20px;width:100%}.header-actions{flex-direction:column;width:100%}.btn-add-lead,.btn-cancel{width:100%}.lead-grid{grid-template-columns:1fr;width:100%}.compact-grid{grid-template-columns:1fr}.form-group-compact.full-width{grid-column:span 1}}@media screen and (max-width:480px){.customer-container{padding:16px}.lead-card{width:100%}.compact-modal{padding:16px;margin:16px;max-height:90vh;overflow-y:auto}.modal-footer-compact{flex-direction:column-reverse;gap:12px}.footer-right{width:100%;flex-direction:column;gap:12px}.btn-save-lead,.btn-cancel,.btn-delete{width:100%;text-align:center}.floating-history-btn{bottom:20px;right:20px;padding:12px 20px;font-size:.85rem}}.inv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:25px;padding:30px;max-width:1200px;margin:0 auto}.inv-card{background:#fff9c4;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:24px;height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:all .3s ease;color:#fff}.inv-card:hover{transform:translateY(-8px);background:#3b82f633;border-color:#3b82f680;box-shadow:0 12px 40px #0006}.inv-card.add-card{background:transparent;border:2px dashed #94a3b8;color:#64748b}.inv-card.add-card:hover{background:#10b9811a;border-color:#10b981;color:#065f46}.card-number{position:absolute;top:20px;left:25px;font-size:14px;font-weight:800;color:#1e3a8a1a}.inv-card:hover .card-number{color:#ffffff4d}.card-icon{font-size:45px;margin-bottom:12px}.card-title{font-weight:700;font-size:16px;letter-spacing:.5px;color:#000}@media(max-width:768px){.inv-grid{grid-template-columns:repeat(2,1fr);gap:16px;padding:20px}.inv-card{height:170px;border-radius:18px}.card-icon{font-size:36px;margin-bottom:10px}.card-title{font-size:14px}.card-number{font-size:12px;top:14px;left:18px}}@media(max-width:480px){.inv-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:16px}.inv-card{height:150px;border-radius:16px;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease}.inv-card:hover{transform:none}.card-icon{font-size:32px;margin-bottom:8px}.card-title{font-size:13px;letter-spacing:.3px}.card-number{font-size:11px;top:12px;left:14px}}@media(hover:none){.inv-card:hover{transform:none}.inv-card:active{transform:scale(.97);background:#3b82f633;border-color:#3b82f680;box-shadow:0 4px 20px #0000004d}.inv-card.add-card:active{background:#10b9811a;border-color:#10b981;color:#065f46}}.inventory-wrapper,.wh-container{width:100%;max-width:100%;align-self:stretch;box-sizing:border-box}:root{--brand-black: #221F1F;--brand-blue: #497B97;--brand-red: #C20100;--brand-red-dk: #A00101;--brand-cream: #EBDBD6;--brand-white: #FFFFFF;--bg-page: #F4F2F0;--bg-card: #FFFFFF;--bg-header: #221F1F;--border: #E0D9D4;--border-strong: #C8BDB8;--text-primary: #221F1F;--text-muted: #7A706C;--text-light: #A89E9A;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(34,31,31,.08);--shadow-md: 0 4px 16px rgba(34,31,31,.12);--shadow-lg: 0 12px 40px rgba(34,31,31,.18)}.wh-container{font-family:DM Sans,sans-serif;background:var(--bg-page);min-height:100vh;padding:0 0 3rem;color:var(--text-primary)}.wh-topbar{background:var(--bg-header);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between;border-bottom:3px solid var(--brand-red)}.wh-topbar-left{display:flex;align-items:center;gap:1rem}.wh-back-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;padding:.4rem .85rem;border-radius:var(--radius-sm);font-size:.78rem;font-family:DM Sans,sans-serif;font-weight:500;cursor:pointer;transition:background .15s;white-space:nowrap}.wh-back-btn:hover{background:#ffffff26}.wh-title-block{line-height:1.2}.wh-title{color:#fff;font-size:1.15rem;font-weight:700;margin:0;letter-spacing:-.01em}.wh-subtitle{color:var(--brand-cream);font-size:.72rem;margin:0;opacity:.75}.wh-add-btn{display:flex;align-items:center;gap:6px;background:var(--brand-red);color:#fff;border:none;padding:.5rem 1.1rem;border-radius:var(--radius-sm);font-family:DM Sans,sans-serif;font-weight:600;font-size:.82rem;cursor:pointer;transition:background .15s,transform .1s;white-space:nowrap}.wh-add-btn:hover{background:var(--brand-red-dk)}.wh-add-btn:active{transform:scale(.97)}.wh-filters{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.9rem 1.75rem;background:var(--bg-card);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}.wh-type-toggle{display:flex;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;flex-shrink:0}.wh-toggle-btn{background:none;border:none;padding:.38rem .85rem;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.wh-toggle-btn.active{background:var(--brand-red);color:#fff;border-radius:var(--radius-sm)}.wh-filter-select-wrap,.wh-select-wrap{position:relative;display:flex;align-items:center}.wh-filter-select{appearance:none;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.38rem 2rem .38rem .75rem;font-family:DM Sans,sans-serif;font-size:.78rem;color:var(--text-primary);cursor:pointer;min-width:180px}.wh-select-icon{position:absolute;right:8px;pointer-events:none;color:var(--text-muted)}.wh-search-wrap{position:relative;display:flex;align-items:center;margin-left:auto}.wh-search-icon{position:absolute;left:10px;color:var(--text-light)}.wh-search-input{padding:.38rem .75rem .38rem 2rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:DM Sans,sans-serif;font-size:.78rem;background:var(--bg-page);color:var(--text-primary);width:220px;transition:border-color .15s,box-shadow .15s}.wh-search-input:focus{outline:none;border-color:var(--brand-blue);box-shadow:0 0 0 3px #497b971f}.wh-table-wrap{margin:1.25rem 1.75rem 0;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:auto}.wh-table{width:100%;border-collapse:collapse;font-size:.78rem}.wh-table thead tr{background:var(--bg-header)}.wh-table thead th{color:#fffc;font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:.7rem .9rem;white-space:nowrap;border-bottom:2px solid var(--brand-red);text-align:left}.wh-table thead th.text-right{text-align:right}.wh-table thead th.text-center{text-align:center}.wh-row{border-bottom:1px solid var(--border);transition:background .12s}.wh-row:last-child{border-bottom:none}.wh-row:hover{background:#faf7f5}.wh-table td{padding:.6rem .9rem;vertical-align:middle;color:var(--text-primary)}.wh-table td.text-right{text-align:right}.wh-table td.text-center{text-align:center}.wh-category-badge{display:inline-block;background:#497b971a;color:#2d5f78;border:1px solid rgba(73,123,151,.25);padding:.18rem .55rem;border-radius:4px;font-size:.68rem;font-weight:600;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}.wh-code{font-family:DM Mono,Courier New,monospace;font-size:.75rem;color:var(--brand-black);white-space:nowrap}.wh-avail{display:inline-flex;align-items:center;gap:5px;padding:.2rem .6rem;border-radius:20px;font-size:.68rem;font-weight:700;white-space:nowrap}.wh-avail:before{content:"";width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}.avail-on{background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.avail-on:before{background:#10b981}.avail-low{background:#fffbeb;color:#92400e;border:1px solid #FCD34D}.avail-low:before{background:#f59e0b}.avail-no{background:#fef2f2;color:#991b1b;border:1px solid #FECACA}.avail-no:before{background:#ef4444}.wh-num{font-variant-numeric:tabular-nums}.wh-total{font-weight:700}.wh-total.negative{color:var(--brand-red)}.wh-unit{color:var(--text-muted);font-size:.73rem}.wh-condition{font-size:.7rem;font-weight:600;padding:.18rem .5rem;border-radius:4px}.cond-good{background:#ecfdf5;color:#065f46}.cond-damaged{background:#fef2f2;color:#991b1b}.cond-returned{background:#fff7ed;color:#92400e}.wh-pill{font-size:.68rem;font-weight:700;padding:.2rem .6rem;border-radius:20px;white-space:nowrap}.wh-pill.main{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.wh-pill.consumable{background:#f5f3ff;color:#5b21b6;border:1px solid #DDD6FE}.wh-actions{display:flex;gap:6px;justify-content:center}.wh-edit-btn,.wh-del-btn{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-page);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.wh-edit-btn{color:var(--brand-blue)}.wh-edit-btn:hover{background:var(--brand-blue);color:#fff;border-color:var(--brand-blue)}.wh-del-btn{color:var(--brand-red)}.wh-del-btn:hover{background:var(--brand-red);color:#fff;border-color:var(--brand-red)}.wh-del-btn:disabled{opacity:.5;cursor:not-allowed}.wh-loading-cell,.wh-empty-cell{text-align:center;padding:3rem 1rem!important;color:var(--text-muted);font-size:.85rem}.wh-loading-cell{display:flex;align-items:center;justify-content:center;gap:8px}.wh-spinner{animation:wh-spin .75s linear infinite}@keyframes wh-spin{to{transform:rotate(360deg)}}.wh-overlay{position:fixed;inset:0;background:#221f1f8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.wh-modal{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;animation:wh-modal-in .22s cubic-bezier(.22,1,.36,1)}@keyframes wh-modal-in{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.wh-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem .9rem;border-bottom:1px solid var(--border);background:var(--bg-header);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.wh-modal-title-row{display:flex;align-items:center;gap:8px}.wh-modal-icon{color:var(--brand-cream)}.wh-modal-title{color:#fff;font-size:1rem;font-weight:700;margin:0}.wh-modal-close{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#fff;width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s;flex-shrink:0}.wh-modal-close:hover{background:#fff3}.wh-form{padding:1.2rem 1.4rem 1rem;display:flex;flex-direction:column;gap:.85rem}.wh-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.wh-form-row-3{grid-template-columns:repeat(3,1fr)}.wh-form-group{display:flex;flex-direction:column;gap:.3rem}.wh-form-group label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.req{color:var(--brand-red)}.wh-optional{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-light)}.wh-form-group input,.wh-form-group textarea,.wh-select-wrap select{font-family:DM Sans,sans-serif;font-size:.82rem;color:var(--text-primary);background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .75rem;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box}.wh-form-group input:focus,.wh-form-group textarea:focus,.wh-select-wrap select:focus{outline:none;border-color:var(--brand-blue);box-shadow:0 0 0 3px #497b971f}.wh-select-wrap{position:relative}.wh-select-wrap select{appearance:none;padding-right:2rem;cursor:pointer}.wh-form-group textarea{resize:vertical;min-height:56px}.wh-label-row{display:flex;align-items:center;justify-content:space-between}.wh-toggle-code-btn{background:none;border:none;font-family:DM Sans,sans-serif;font-size:.7rem;color:var(--brand-blue);cursor:pointer;padding:0;text-decoration:underline}.wh-hint{font-size:.68rem;color:var(--text-light);margin:0;line-height:1.4}.wh-checkbox-group{justify-content:flex-end;padding-bottom:2px}.wh-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.82rem;font-weight:500;color:var(--text-primary);text-transform:none;letter-spacing:0;padding:.5rem .75rem;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;transition:background .12s}.wh-checkbox-label:hover{background:var(--brand-cream)}.wh-checkbox-label input[type=checkbox]{width:15px;height:15px;accent-color:var(--brand-red);cursor:pointer;flex-shrink:0}.wh-modal-footer{display:flex;gap:.6rem;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--border);margin-top:.5rem}.wh-btn-cancel{background:var(--bg-page);border:1px solid var(--border-strong);color:var(--text-muted);padding:.5rem 1.1rem;border-radius:var(--radius-sm);font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;cursor:pointer;transition:background .12s}.wh-btn-cancel:hover{background:var(--brand-cream)}.wh-btn-save{display:flex;align-items:center;gap:6px;background:var(--brand-red);color:#fff;border:none;padding:.5rem 1.3rem;border-radius:var(--radius-sm);font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s}.wh-btn-save:hover{background:var(--brand-red-dk)}.wh-btn-save:active{transform:scale(.97)}.wh-btn-save:disabled{background:#ccc;cursor:not-allowed;transform:none}.wh-pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.85rem 1.1rem;border-top:1px solid var(--border);background:var(--bg-card);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.wh-pagination-info{font-size:.75rem;color:var(--text-muted)}.wh-pagination-controls{display:flex;align-items:center;gap:.75rem}.wh-perpage-wrap{display:flex;align-items:center;gap:.4rem}.wh-perpage-label{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.wh-perpage-select{appearance:none;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.28rem 1.6rem .28rem .6rem;font-family:DM Sans,sans-serif;font-size:.75rem;color:var(--text-primary);cursor:pointer}.wh-page-btns{display:flex;align-items:center;gap:3px}.wh-page-btn{min-width:30px;height:30px;padding:0 .45rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:500;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s,color .12s}.wh-page-btn:hover:not(:disabled):not(.active){background:var(--brand-cream);border-color:var(--border-strong)}.wh-page-btn.active{background:var(--brand-red);border-color:var(--brand-red);color:#fff;font-weight:700}.wh-page-btn:disabled{opacity:.35;cursor:not-allowed}.wh-page-nav{color:var(--text-muted)}.wh-page-ellipsis{font-size:.75rem;color:var(--text-light);padding:0 .2rem;-webkit-user-select:none;user-select:none}@media(max-width:1024px){.wh-topbar,.wh-filters{padding-left:1.25rem;padding-right:1.25rem}.wh-table-wrap{margin-left:1.25rem;margin-right:1.25rem}.wh-search-input{width:180px}.wh-filter-select{min-width:140px}}@media(max-width:768px){.inventory-wrapper,.wh-container{width:100%!important;max-width:100%!important;align-self:stretch!important}.wh-topbar{padding:.75rem 1rem;flex-wrap:wrap;gap:.6rem}.wh-title{font-size:.95rem}.wh-subtitle{display:none}.wh-filters{padding:.65rem 1rem;gap:.5rem}.wh-search-wrap{margin-left:0;width:100%;order:10}.wh-search-input{width:100%}.wh-table-wrap{margin:16px 16px 0;border-radius:12px;overflow:hidden}.wh-table{min-width:unset;display:block}.wh-table thead{display:none}.wh-table tbody{display:flex;flex-direction:column;gap:0}.wh-table tbody tr.wh-row{display:grid;grid-template-columns:1fr 1fr;grid-template-areas:"category  code" "avail     avail" "stock     unit" "reserve   total" "condition type" "actions   actions";gap:6px 12px;padding:16px 18px;border-bottom:1px solid var(--border);border-radius:0;transition:background .12s}.wh-table tbody tr.wh-row:first-child{border-radius:12px 12px 0 0}.wh-table tbody tr.wh-row:last-child{border-bottom:none;border-radius:0 0 12px 12px}.wh-table tbody tr.wh-row:hover{background:#faf7f5}.wh-table tbody tr.wh-row td{padding:2px 0}.wh-table tbody tr.wh-row td:nth-child(1){grid-area:category;align-self:center}.wh-table tbody tr.wh-row td:nth-child(2){grid-area:code;align-self:center;text-align:right}.wh-table tbody tr.wh-row td:nth-child(3){grid-area:avail;padding-top:4px}.wh-table tbody tr.wh-row td:nth-child(4){grid-area:stock}.wh-table tbody tr.wh-row td:nth-child(5){grid-area:unit;text-align:right;align-self:flex-end}.wh-table tbody tr.wh-row td:nth-child(6){grid-area:reserve}.wh-table tbody tr.wh-row td:nth-child(7){grid-area:total;text-align:right}.wh-table tbody tr.wh-row td:nth-child(8){grid-area:condition}.wh-table tbody tr.wh-row td:nth-child(9){grid-area:type;text-align:right}.wh-table tbody tr.wh-row td:nth-child(10){grid-area:actions;display:flex;justify-content:flex-end;gap:8px;padding-top:8px;margin-top:4px;border-top:1px dashed var(--border)}.wh-table tbody tr.wh-row td:nth-child(4):before{content:"Stock";display:block;font-size:.62rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.04em;margin-bottom:1px}.wh-table tbody tr.wh-row td:nth-child(6):before{content:"Reserve";display:block;font-size:.62rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.04em;margin-bottom:1px}.wh-table tbody tr.wh-row td:nth-child(7):before{content:"After Rsv";display:block;font-size:.62rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.04em;margin-bottom:1px;text-align:right}.wh-table tbody td.text-right,.wh-table tbody td.text-center{text-align:inherit}.wh-loading-cell,.wh-empty-cell{display:flex!important;grid-column:1 / -1}.wh-pagination{flex-direction:column;align-items:flex-start;padding:.75rem 1rem}.wh-overlay{align-items:flex-end;padding:0}.wh-modal{max-width:100%;border-radius:16px 16px 0 0;max-height:95vh;animation:wh-sheet-in .25s cubic-bezier(.22,1,.36,1)}@keyframes wh-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.wh-modal-header{border-radius:16px 16px 0 0}.wh-form-row,.wh-form-row-3{grid-template-columns:1fr}}@media(max-width:480px){.wh-topbar{flex-direction:column;align-items:flex-start;gap:.5rem;padding:.65rem .75rem}.wh-topbar-left{width:100%}.wh-add-btn{width:100%;justify-content:center}.wh-filters{flex-direction:column;align-items:stretch;gap:.45rem;padding:.55rem .75rem}.wh-type-toggle{width:100%}.wh-toggle-btn{flex:1;text-align:center;font-size:.73rem;padding:.38rem .4rem}.wh-filter-select-wrap{width:100%}.wh-filter-select{width:100%;min-width:unset;box-sizing:border-box}.wh-table-wrap{margin:.5rem 0 0;border-radius:0;border-left:none;border-right:none}.wh-table tbody tr.wh-row{grid-template-columns:1fr;grid-template-areas:"category" "code" "avail" "stock" "unit" "reserve" "total" "condition" "type" "actions";padding:16px 18px}.wh-table tbody tr.wh-row:first-child{border-radius:0}.wh-table tbody tr.wh-row:last-child{border-radius:0}.wh-table tbody tr.wh-row td:nth-child(2),.wh-table tbody tr.wh-row td:nth-child(5),.wh-table tbody tr.wh-row td:nth-child(7),.wh-table tbody tr.wh-row td:nth-child(9){text-align:left}.wh-table tbody tr.wh-row td:nth-child(7):before{text-align:left}.wh-pagination{padding:.65rem .75rem}.wh-perpage-wrap{display:none}.wh-page-btn{min-width:26px;height:26px;font-size:.7rem}.wh-pagination-info{font-size:.7rem}.wh-modal{border-radius:14px 14px 0 0}.wh-modal-header{padding:.85rem 1rem .75rem;border-radius:14px 14px 0 0}.wh-form{padding:.9rem 1rem .85rem}.wh-modal-footer{flex-direction:column-reverse;gap:.5rem}.wh-btn-cancel,.wh-btn-save{width:100%;justify-content:center}.wh-form-row-3{grid-template-columns:1fr 1fr}.wh-form-row-3 .wh-form-group:first-child{grid-column:1 / -1}}@media(hover:none){.wh-add-btn:hover{background:var(--brand-red);transform:none}.wh-add-btn:active{background:var(--brand-red-dk);transform:scale(.97)}.wh-btn-save:active{transform:scale(.97)}.wh-row:hover{background:transparent}.wh-row:active{background:#faf7f5}.wh-edit-btn:hover{background:var(--bg-page);color:var(--brand-blue);border-color:var(--border)}.wh-del-btn:hover{background:var(--bg-page);color:var(--brand-red);border-color:var(--border)}.wh-edit-btn,.wh-del-btn{width:36px;height:36px}}.inventory-wrapper,.is-wrapper{width:100%;max-width:100%;align-self:stretch;box-sizing:border-box}:root{--brand-black: #221F1F;--brand-blue: #497B97;--brand-red: #C20100;--brand-red-dk: #A00101;--brand-cream: #EBDBD6;--bg-page: #F4F2F0;--bg-card: #FFFFFF;--border: #E0D9D4;--border-md: #C8BDB8;--text-pri: #221F1F;--text-muted:#7A706C;--text-light:#A89E9A;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--sh-sm: 0 1px 3px rgba(34,31,31,.08);--sh-md: 0 4px 16px rgba(34,31,31,.12);--sh-lg: 0 12px 40px rgba(34,31,31,.18)}.is-wrapper{font-family:DM Sans,sans-serif;background:var(--bg-page);min-height:100vh;padding-bottom:3rem;color:var(--text-pri)}.is-topbar{background:var(--brand-black);border-bottom:3px solid var(--brand-red);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between}.is-topbar-left{display:flex;align-items:center;gap:.85rem}.is-topbar-right{display:flex;align-items:center;gap:.6rem}.is-back-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;padding:.38rem .8rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;cursor:pointer;transition:background .15s;white-space:nowrap}.is-back-btn:hover{background:#ffffff2e}.is-title-block{line-height:1.2}.is-title{color:#fff;font-size:1.05rem;font-weight:700;margin:0;letter-spacing:-.01em}.is-subtitle{color:var(--brand-cream);font-size:.72rem;opacity:.75;margin:0}.is-refresh-btn{width:32px;height:32px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-sm);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s;flex-shrink:0}.is-refresh-btn:hover{background:#ffffff2e}.is-refresh-btn.spinning svg{animation:is-spin .8s linear infinite}@keyframes is-spin{to{transform:rotate(360deg)}}.is-table-wrap{margin:1.25rem 1.75rem 0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:auto}.is-table{width:100%;border-collapse:collapse;font-size:.78rem}.is-table thead tr{background:var(--brand-black)}.is-table thead th{color:#fffc;font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:.7rem .9rem;white-space:nowrap;border-bottom:2px solid var(--brand-red);text-align:left}.is-table th.text-center{text-align:center}.is-row{border-bottom:1px solid var(--border);transition:background .12s}.is-row:last-child{border-bottom:none}.is-row:hover{background:#faf7f5}.is-table td{padding:.6rem .9rem;vertical-align:middle}.is-table td.text-right{text-align:right}.is-table td.text-center{text-align:center}.is-shipno{font-weight:700;font-size:.8rem;white-space:nowrap}.is-container{color:var(--text-muted);font-size:.75rem;white-space:nowrap}.is-location{font-size:.75rem;color:var(--text-muted)}.is-origin-tag{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;font-weight:700;padding:.18rem .5rem;border-radius:4px;white-space:nowrap}.is-origin-tag.intl{background:#c2010014;color:var(--brand-red);border:1px solid rgba(194,1,0,.2)}.is-origin-tag.local{background:#497b9714;color:#2d5f78;border:1px solid rgba(73,123,151,.2)}.is-prod-tag{font-size:.68rem;font-weight:600;padding:.18rem .5rem;border-radius:4px;white-space:nowrap}.prod-on{background:#ecfdf5;color:#065f46}.prod-ready{background:#eff6ff;color:#1e40af}.prod-ongoing{background:#fffbeb;color:#92400e}.is-pill{display:inline-flex;align-items:center;gap:5px;padding:.22rem .65rem;border-radius:20px;font-size:.68rem;font-weight:700;white-space:nowrap}.is-pill:before{content:"";width:6px;height:6px;border-radius:50%;display:inline-block}.pill-arrived{background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.pill-arrived:before{background:#10b981}.pill-departure{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.pill-departure:before{background:#3b82f6}.pill-waiting{background:#fffbeb;color:#92400e;border:1px solid #FCD34D}.pill-waiting:before{background:#f59e0b}.is-date-badge{background:#497b971a;color:#2d5f78;border:1px solid rgba(73,123,151,.2);padding:.18rem .55rem;border-radius:4px;font-size:.72rem;font-weight:600;white-space:nowrap}.is-tba{color:var(--text-light);font-size:.72rem;font-style:italic}.is-project-btn{display:inline-flex;align-items:center;gap:5px;background:#497b9714;border:1px solid rgba(73,123,151,.2);border-radius:var(--r-sm);color:#2d5f78;font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:600;padding:.25rem .6rem;cursor:pointer;white-space:nowrap;transition:background .12s}.is-project-btn:hover{background:#497b9726}.is-actions{display:flex;gap:6px;justify-content:center}.is-edit-btn{display:flex;align-items:center;gap:7px;background:#497b9714;border:1px solid rgba(73,123,151,.25);color:#2d5f78;border-radius:6px;padding:.48rem 1rem;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s}.is-edit-btn:hover{background:var(--brand-blue);color:#fff;border-color:var(--brand-blue)}.is-loading-cell,.is-empty-cell{text-align:center;padding:3rem 1rem!important;color:var(--text-muted);font-size:.85rem}.is-loading-cell{display:flex;align-items:center;justify-content:center;gap:8px}.is-spinner{animation:is-spin .75s linear infinite}.is-overlay{position:fixed;inset:0;background:#221f1f8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.is-modal{background:var(--bg-card);border-radius:var(--r-lg);box-shadow:var(--sh-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:is-modal-in .22s cubic-bezier(.22,1,.36,1)}@keyframes is-modal-in{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.is-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem 1.3rem .85rem;background:var(--brand-black);border-bottom:2px solid var(--brand-red);border-radius:var(--r-lg) var(--r-lg) 0 0}.is-modal-title{color:#fff;font-size:.95rem;font-weight:700;margin:0}.is-modal-sub{color:var(--brand-cream);font-size:.72rem;opacity:.75;margin:2px 0 0}.is-modal-close{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#fff;width:28px;height:28px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .12s}.is-modal-close:hover{background:#fff3}.is-modal-body{padding:1rem 1.3rem;overflow-x:auto}.is-mini-table{width:100%;border-collapse:collapse;font-size:.8rem}.is-mini-table thead th{background:var(--bg-page);border-bottom:2px solid var(--border);padding:.5rem .75rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);white-space:nowrap}.is-mini-table th.text-right{text-align:right}.is-mini-table td{padding:.55rem .75rem;border-bottom:1px solid var(--border)}.is-mini-table td.text-right{text-align:right}.is-mini-table tbody tr:hover{background:#faf7f5}.is-proj-name{font-weight:700}.is-proj-cat{color:var(--text-muted);font-size:.75rem}.is-proj-num{font-variant-numeric:tabular-nums;font-weight:600}.is-mini-total{background:#f4f2f0;font-weight:700;font-size:.78rem}.is-mini-total td{padding:.6rem .75rem;color:var(--text-pri);border-top:2px solid var(--border-md);border-bottom:none}.is-mini-total td.text-right{color:var(--brand-blue)}.is-modal-form{padding:1.1rem 1.3rem 1rem}.is-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.85rem}.is-field{display:flex;flex-direction:column;gap:.3rem}.is-field label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.is-input{font-family:DM Sans,sans-serif;font-size:.82rem;color:var(--text-pri);background:var(--bg-page);border:1px solid var(--border);border-radius:var(--r-sm);padding:.5rem .75rem;width:100%;transition:border-color .15s,box-shadow .15s;appearance:none}.is-input:focus{outline:none;border-color:var(--brand-blue);box-shadow:0 0 0 3px #497b971f}.ac-select-wrap{position:relative}.ac-select-wrap .is-input{padding-right:2rem;cursor:pointer}.ac-select-icon{position:absolute;right:8px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-muted)}.is-modal-footer{display:flex;gap:.6rem;justify-content:flex-end;padding-top:.75rem;border-top:1px solid var(--border)}.is-btn-cancel{background:var(--bg-page);border:1px solid var(--border-md);color:var(--text-muted);padding:.48rem 1rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .12s}.is-btn-cancel:hover{background:var(--brand-cream)}.is-btn-save{display:flex;align-items:center;gap:6px;background:var(--brand-red);color:#fff;border:none;padding:.48rem 1.2rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s}.is-btn-save:hover{background:var(--brand-red-dk)}.is-btn-save:active{transform:scale(.98)}.is-btn-save:disabled{background:#ccc;cursor:not-allowed;transform:none}.is-purpose-tag{display:inline-flex;align-items:center;gap:4px;font-size:.67rem;font-weight:700;padding:.18rem .5rem;border-radius:4px;white-space:nowrap}.is-purpose-tag.purpose-reserve,.purpose-reserve{background:#c2010014;color:#a00101;border:1px solid rgba(194,1,0,.2)}.is-purpose-tag.purpose-stock,.purpose-stock{background:#497b971a;color:#2d5f78;border:1px solid rgba(73,123,151,.2)}.is-modal-wide{max-width:720px}.is-proj-code{font-family:DM Mono,monospace;font-size:.73rem}.is-proj-unit{font-size:.72rem;color:var(--text-muted)}.is-select-wrap{position:relative}.is-select-wrap .is-input{appearance:none;padding-right:2rem;cursor:pointer}.is-select-icon{position:absolute;right:8px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-muted)}.is-received-stock-btn{display:flex;align-items:center;gap:6px;background:#065f46;color:#fff;border:none;border-radius:6px;padding:.45rem .95rem;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s;white-space:nowrap}.is-received-stock-btn:hover{background:#047857}.is-received-stock-btn:active{transform:scale(.97)}.is-received-badge{display:inline-flex;align-items:center;justify-content:center;background:#fff;color:#065f46;border-radius:20px;font-size:.65rem;font-weight:800;min-width:18px;height:18px;padding:0 5px;margin-left:2px}.is-inv-tag{display:inline-block;margin-left:6px;background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0;border-radius:4px;font-size:.6rem;font-weight:700;padding:.1rem .35rem;vertical-align:middle}.is-row-done{opacity:.72}.is-modal-received{max-width:880px!important;width:96vw!important;max-height:88vh!important;display:flex;flex-direction:column;overflow:hidden!important}.is-received-header{display:flex!important;align-items:center;justify-content:space-between;background:#221f1f;border-bottom:2px solid #C20100;border-radius:14px 14px 0 0;padding:.9rem 1.2rem}.is-received-header-left{display:flex;align-items:center;gap:.75rem}.is-received-header-icon{width:36px;height:36px;background:#065f46;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.is-received-layout{display:grid;grid-template-columns:220px 1fr;flex:1;overflow:hidden;min-height:0}.is-received-list{background:#f4f2f0;border-right:1px solid #E0D9D4;overflow-y:auto;padding:.4rem 0}.is-received-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:3rem 1rem;color:#a89e9a;font-size:.78rem;text-align:center}.is-received-item{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.7rem .9rem;background:none;border:none;border-bottom:1px solid #EDE9E6;cursor:pointer;text-align:left;transition:background .12s;gap:.5rem}.is-received-item:last-child{border-bottom:none}.is-received-item:hover{background:#eceae7}.is-received-item.active{background:#fff;border-right:3px solid #C20100}.is-received-item-inner{display:flex;flex-direction:column;gap:2px;min-width:0}.is-received-seq{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#c20100}.is-received-code{font-size:.8rem;font-weight:600;color:#221f1f;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.is-received-purpose{display:inline-flex;align-items:center;gap:3px;font-size:.62rem;font-weight:700;padding:.1rem .38rem;border-radius:20px;width:fit-content;margin-top:1px}.is-received-chevron{color:#c8bdb8;flex-shrink:0}.is-received-detail{overflow-y:auto;background:#fff}.is-received-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:320px;color:#c8bdb8;font-size:.82rem;gap:.6rem}.is-detail-wrap{padding:1.1rem 1.2rem;display:flex;flex-direction:column;gap:.85rem}.is-detail-meta{display:grid;grid-template-columns:1fr 1fr;gap:.5rem .9rem;background:#f9f7f5;border:1px solid #E0D9D4;border-radius:8px;padding:.75rem 1rem}.is-detail-meta-item{display:flex;flex-direction:column;gap:3px}.is-detail-label{font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#7a706c}.is-detail-value{font-size:.82rem;font-weight:600;color:#221f1f}.is-detail-table-wrap{border:1px solid #E0D9D4;border-radius:8px;overflow:hidden}.is-detail-note{display:flex;align-items:flex-start;gap:7px;background:#eff6ff;border:1px solid #BFDBFE;border-radius:7px;padding:.55rem .75rem;font-size:.72rem;color:#1e40af;line-height:1.55}.is-detail-note svg{flex-shrink:0;margin-top:1px}.is-detail-actions{display:flex;gap:.6rem;justify-content:flex-end;padding-top:.15rem}.is-action-add{display:flex;align-items:center;gap:6px;background:#065f46;color:#fff;border:none;border-radius:6px;padding:.52rem 1.1rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s}.is-action-add:hover{background:#047857}.is-action-report{display:flex;align-items:center;gap:6px;background:#fffbeb;color:#92400e;border:1.5px solid #FCD34D;border-radius:6px;padding:.52rem 1rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s}.is-action-report:hover{background:#fef3c7}.is-modal-report{max-width:540px!important}.is-modal-header-warn{background:#78350f!important;border-bottom:2px solid #F59E0B!important}.is-report-hint{font-size:.76rem;color:#7a706c;margin-bottom:.75rem;line-height:1.5}.is-report-items{display:flex;flex-direction:column;gap:.45rem}.is-report-item{border:1.5px solid #E0D9D4;border-radius:8px;overflow:hidden;transition:border-color .15s}.is-report-item.selected{border-color:#f59e0b}.is-report-check-label{display:flex;align-items:center;gap:10px;padding:.6rem .85rem;cursor:pointer;background:#faf8f6;transition:background .12s}.is-report-check-label:hover{background:#f0ede9}.is-report-check-label input[type=checkbox]{width:15px;height:15px;accent-color:#C20100;cursor:pointer;flex-shrink:0}.is-report-item-name{display:flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:#221f1f}.is-report-fields{padding:.65rem .85rem;display:grid;grid-template-columns:1fr 1fr;gap:.6rem;background:#fff;border-top:1px solid #E0D9D4}.is-report-fields .is-field label{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#7a706c;display:block;margin-bottom:.28rem}.is-btn-report{display:flex;align-items:center;gap:6px;background:#92400e;color:#fff;border:none;border-radius:6px;padding:.5rem 1.2rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s}.is-btn-report:hover{background:#78350f}.is-btn-report:disabled{background:#ccc;cursor:not-allowed}@media(max-width:1024px){.is-topbar{padding-left:1.25rem;padding-right:1.25rem}.is-table-wrap{margin-left:1.25rem;margin-right:1.25rem}.is-received-layout{grid-template-columns:190px 1fr}}@media(max-width:768px){.inventory-wrapper,.is-wrapper{width:100%!important;max-width:100%!important;align-self:stretch!important}.is-topbar{padding:.75rem 1rem;flex-wrap:wrap;gap:.6rem}.is-title{font-size:.95rem}.is-subtitle{display:none}.is-table-wrap{margin:16px 16px 0;border-radius:12px;overflow:hidden}.is-table{min-width:unset;display:block}.is-table thead{display:none}.is-table tbody{display:flex;flex-direction:column;gap:0}.is-table tbody tr.is-row{display:grid;grid-template-columns:1fr 1fr;grid-template-areas:"shipno   origin" "status   status" "prod     prod" "date     location" "projects projects" "actions  actions";gap:6px 12px;padding:16px 18px;border-bottom:1px solid var(--border);border-radius:0}.is-table tbody tr.is-row:first-child{border-radius:12px 12px 0 0}.is-table tbody tr.is-row:last-child{border-bottom:none;border-radius:0 0 12px 12px}.is-table tbody tr.is-row:hover{background:#faf7f5}.is-table tbody tr.is-row td{padding:2px 0}.is-table tbody tr.is-row td:nth-child(1){grid-area:shipno;align-self:center}.is-table tbody tr.is-row td:nth-child(2){grid-area:origin;align-self:center;text-align:right}.is-table tbody tr.is-row td:nth-child(3){grid-area:status;padding-top:4px}.is-table tbody tr.is-row td:nth-child(4){grid-area:prod}.is-table tbody tr.is-row td:nth-child(5){grid-area:date}.is-table tbody tr.is-row td:nth-child(6){grid-area:location;text-align:right;align-self:center}.is-table tbody tr.is-row td:nth-child(7){grid-area:projects}.is-table tbody tr.is-row td:nth-child(8){grid-area:actions;display:flex;justify-content:flex-end;gap:8px;padding-top:8px;margin-top:4px;border-top:1px dashed var(--border)}.is-table tbody tr.is-row td:nth-child(5):before{content:"ETA";display:block;font-size:.62rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.04em;margin-bottom:1px}.is-table tbody td.text-right,.is-table tbody td.text-center{text-align:inherit}.is-loading-cell,.is-empty-cell{display:flex!important;grid-column:1 / -1}.is-overlay{align-items:flex-end;padding:0}.is-modal{max-width:100%;border-radius:16px 16px 0 0;max-height:95vh;animation:is-sheet-in .25s cubic-bezier(.22,1,.36,1)}@keyframes is-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.is-modal-wide,.is-modal-received{max-width:100%!important;width:100%!important}.is-modal-header,.is-received-header{border-radius:16px 16px 0 0}.is-received-layout{grid-template-columns:1fr}.is-received-list{border-right:none;border-bottom:1px solid #E0D9D4;max-height:160px;overflow-y:auto}.is-modal-grid,.is-report-fields{grid-template-columns:1fr}.is-detail-meta{grid-template-columns:1fr 1fr}}@media(max-width:640px){.is-topbar{padding:.65rem .85rem}.is-topbar-right .is-refresh-btn,.is-received-stock-btn span{display:none}.is-table-wrap{margin:.75rem .5rem 0;border-radius:8px}.is-modal{border-radius:14px 14px 0 0}.is-modal-header{padding:.85rem 1rem .75rem;border-radius:14px 14px 0 0}.is-modal-form{padding:.9rem 1rem .85rem}.is-modal-footer{flex-direction:column-reverse;gap:.5rem}.is-btn-cancel,.is-btn-save,.is-btn-report{width:100%;justify-content:center}.is-detail-actions{flex-direction:column}.is-action-add,.is-action-report{width:100%;justify-content:center}.is-received-list{max-height:140px}}@media(max-width:480px){.is-topbar{flex-direction:column;align-items:flex-start;gap:.5rem;padding:.65rem .75rem}.is-topbar-left{width:100%}.is-topbar-right{width:100%;justify-content:flex-end}.is-received-stock-btn span{display:inline}.is-received-stock-btn{width:100%;justify-content:center}.is-topbar-right .is-refresh-btn{display:flex}.is-table-wrap{margin:.5rem 0 0;border-radius:0;border-left:none;border-right:none}.is-table tbody tr.is-row{grid-template-columns:1fr;grid-template-areas:"shipno" "origin" "status" "prod" "date" "location" "projects" "actions";padding:16px 18px}.is-table tbody tr.is-row:first-child{border-radius:0}.is-table tbody tr.is-row:last-child{border-radius:0}.is-table tbody tr.is-row td:nth-child(2),.is-table tbody tr.is-row td:nth-child(6){text-align:left}.is-detail-meta{grid-template-columns:1fr}.is-received-list{max-height:120px}.is-received-code{font-size:.75rem}}@media(hover:none){.is-received-stock-btn:hover{background:#065f46;transform:none}.is-received-stock-btn:active{transform:scale(.97)}.is-btn-save:active,.is-btn-report:active{transform:scale(.98)}.is-row:hover{background:transparent}.is-row:active{background:#faf7f5}.is-edit-btn:hover{background:#497b9714;color:#2d5f78;border-color:#497b9740}.is-project-btn:hover{background:#497b9714}.is-edit-btn{padding:.6rem 1.1rem}.is-project-btn{padding:.4rem .8rem}}.inventory-wrapper,.dl-wrapper{width:100%;max-width:100%;align-self:stretch;box-sizing:border-box}:root{--brand-black: #221F1F;--brand-blue: #497B97;--brand-red: #C20100;--brand-red-dk: #A00101;--brand-cream: #EBDBD6;--bg-page: #F4F2F0;--bg-card: #FFFFFF;--border: #E0D9D4;--border-md: #C8BDB8;--text-pri: #221F1F;--text-muted:#7A706C;--text-light:#A89E9A;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--sh-sm: 0 1px 3px rgba(34,31,31,.08);--sh-lg: 0 12px 40px rgba(34,31,31,.18)}*{box-sizing:border-box}.dl-wrapper{font-family:DM Sans,sans-serif;background:var(--bg-page);min-height:100vh;padding-bottom:3rem;color:var(--text-pri)}.dl-topbar{background:var(--brand-black);border-bottom:3px solid var(--brand-red);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between}.dl-topbar-left{display:flex;align-items:center;gap:.85rem}.dl-topbar-right{display:flex;align-items:center;gap:.6rem}.dl-back-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;padding:.38rem .8rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;cursor:pointer;transition:background .15s;white-space:nowrap}.dl-back-btn:hover{background:#ffffff2e}.dl-title-block{line-height:1.2}.dl-title{color:#fff;font-size:1.05rem;font-weight:700;margin:0;letter-spacing:-.01em}.dl-subtitle{color:var(--brand-cream);font-size:.72rem;opacity:.75;margin:0}.dl-refresh-btn{width:32px;height:32px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-sm);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s;flex-shrink:0}.dl-refresh-btn:hover{background:#ffffff2e}.dl-refresh-btn.spinning svg{animation:dl-spin .8s linear infinite}@keyframes dl-spin{to{transform:rotate(360deg)}}.dl-add-btn{display:flex;align-items:center;gap:6px;background:var(--brand-red);color:#fff;border:none;padding:.45rem 1rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s;white-space:nowrap}.dl-add-btn:hover{background:var(--brand-red-dk)}.dl-add-btn:active{transform:scale(.98)}.dl-filters{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.9rem 1.75rem;background:var(--bg-card);border-bottom:1px solid var(--border);box-shadow:var(--sh-sm)}.dl-type-toggle{display:flex;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;flex-shrink:0}.dl-toggle-btn{background:none;border:none;padding:.38rem .85rem;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.dl-toggle-btn.active{background:var(--brand-red);color:#fff;border-radius:var(--r-sm)}.dl-search-wrap{position:relative;display:flex;align-items:center;margin-left:auto}.dl-search-icon{position:absolute;left:10px;color:var(--text-light)}.dl-search-input{padding:.38rem .75rem .38rem 2rem;border:1px solid var(--border);border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.78rem;background:var(--bg-page);color:var(--text-pri);width:240px;transition:border-color .15s,box-shadow .15s}.dl-search-input:focus{outline:none;border-color:var(--brand-blue);box-shadow:0 0 0 3px #497b971f}.dl-table-wrap{margin:1.25rem 1.75rem 0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:auto}.dl-table{width:100%;border-collapse:collapse;font-size:.78rem}.dl-table thead tr{background:var(--brand-black)}.dl-table thead th{color:#fffc;font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:.7rem .9rem;white-space:nowrap;border-bottom:2px solid var(--brand-red);text-align:left}.dl-table th.text-right{text-align:right}.dl-table th.text-center{text-align:center}.dl-row{border-bottom:1px solid var(--border);transition:background .12s}.dl-row:last-child{border-bottom:none}.dl-row:hover{background:#faf7f5}.dl-table td{padding:.6rem .9rem;vertical-align:middle}.dl-table td.text-right{text-align:right}.dl-table td.text-center{text-align:center}.dl-trucking{font-weight:700;white-space:nowrap}.dl-code{font-family:DM Mono,monospace;font-size:.75rem;white-space:nowrap}.dl-project{font-weight:600}.dl-driver{color:var(--text-muted);font-size:.75rem}.dl-dest{font-size:.75rem}.dl-qty{font-weight:700;font-variant-numeric:tabular-nums}.dl-date{font-size:.75rem;white-space:nowrap;color:var(--text-muted)}.dl-tba{color:var(--text-light);font-style:italic}.dl-category-badge{display:inline-block;background:#497b971a;color:#2d5f78;border:1px solid rgba(73,123,151,.25);padding:.18rem .55rem;border-radius:4px;font-size:.68rem;font-weight:600;white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}.dl-pill{font-size:.68rem;font-weight:700;padding:.2rem .6rem;border-radius:20px;white-space:nowrap}.dl-pill.main{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.dl-pill.consumable{background:#f5f3ff;color:#5b21b6;border:1px solid #DDD6FE}.dl-status-pill{display:inline-flex;align-items:center;gap:5px;padding:.22rem .65rem;border-radius:20px;font-size:.68rem;font-weight:700;white-space:nowrap}.dl-status-pill:before{content:"";width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}.pill-delivered{background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.pill-delivered:before{background:#10b981}.pill-transit{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.pill-transit:before{background:#3b82f6}.dl-actions{display:flex;justify-content:center}.dl-deliver-btn{display:inline-flex;align-items:center;gap:4px;padding:.3rem .65rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.72rem;font-weight:600;background:#10b98114;border:1px solid rgba(16,185,129,.25);color:#065f46;cursor:pointer;transition:background .12s}.dl-deliver-btn:hover{background:#10b981;color:#fff;border-color:#10b981}.dl-deliver-btn:disabled{opacity:.55;cursor:not-allowed}.dl-done-label{font-size:.72rem;color:#10b981;font-weight:700}.dl-loading-cell,.dl-empty-cell{text-align:center;padding:3rem 1rem!important;color:var(--text-muted);font-size:.85rem}.dl-loading-cell{display:flex;align-items:center;justify-content:center;gap:8px}.dl-spinner{animation:dl-spin .75s linear infinite}.dl-pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.85rem 1.1rem;border-top:1px solid var(--border);background:var(--bg-card);border-radius:0 0 var(--r-lg) var(--r-lg)}.dl-pagination-info{font-size:.75rem;color:var(--text-muted)}.dl-pagination-controls{display:flex;align-items:center;gap:.75rem}.dl-perpage-wrap{display:flex;align-items:center;gap:.4rem}.dl-perpage-label{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.dl-select-wrap{position:relative;display:flex;align-items:center}.dl-perpage-select{appearance:none;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--r-sm);padding:.28rem 1.6rem .28rem .6rem;font-family:DM Sans,sans-serif;font-size:.75rem;color:var(--text-pri);cursor:pointer}.dl-select-icon{position:absolute;right:7px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-muted)}.dl-page-btns{display:flex;align-items:center;gap:3px}.dl-page-btn{min-width:30px;height:30px;padding:0 .45rem;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-card);font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:500;color:var(--text-pri);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s,color .12s}.dl-page-btn:hover:not(:disabled):not(.active){background:var(--brand-cream);border-color:var(--border-md)}.dl-page-btn.active{background:var(--brand-red);border-color:var(--brand-red);color:#fff;font-weight:700}.dl-page-btn:disabled{opacity:.35;cursor:not-allowed}.dl-page-nav{color:var(--text-muted)}.dl-page-ellipsis{font-size:.75rem;color:var(--text-light);padding:0 .2rem;-webkit-user-select:none;user-select:none}.dl-overlay{position:fixed;inset:0;background:#221f1f8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.dl-modal{background:var(--bg-card);border-radius:var(--r-lg);box-shadow:var(--sh-lg);width:100%;max-width:580px;max-height:92vh;overflow-y:auto;animation:dl-modal-in .22s cubic-bezier(.22,1,.36,1)}@keyframes dl-modal-in{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.dl-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem 1.3rem .85rem;background:var(--brand-black);border-bottom:2px solid var(--brand-red);border-radius:var(--r-lg) var(--r-lg) 0 0}.dl-modal-title{color:#fff;font-size:.95rem;font-weight:700;margin:0}.dl-modal-sub{color:var(--brand-cream);font-size:.72rem;opacity:.75;margin:2px 0 0}.dl-modal-close{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#fff;width:28px;height:28px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s;flex-shrink:0}.dl-modal-close:hover{background:#fff3}.dl-form{padding:1.2rem 1.3rem 1rem;display:flex;flex-direction:column;gap:.85rem}.dl-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.dl-form-group{display:flex;flex-direction:column;gap:.3rem}.dl-form-group label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.dl-req{color:var(--brand-red)}.dl-input{font-family:DM Sans,sans-serif;font-size:.82rem;color:var(--text-pri);background:var(--bg-page);border:1px solid var(--border);border-radius:var(--r-sm);padding:.5rem .75rem;width:100%;transition:border-color .15s,box-shadow .15s;appearance:none}.dl-input:focus{outline:none;border-color:var(--brand-blue);box-shadow:0 0 0 3px #497b971f}.dl-input:disabled{opacity:.5;cursor:not-allowed}.dl-select-wrap .dl-input{padding-right:2rem;cursor:pointer}.dl-warn{display:flex;align-items:center;gap:6px;background:#fffbeb;border:1px solid #FCD34D;color:#92400e;border-radius:var(--r-sm);padding:.4rem .65rem;font-size:.72rem;font-weight:600;margin-top:4px}.dl-type-indicator{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--r-sm)}.dl-type-label{font-size:.72rem;color:var(--text-muted);font-weight:600}.dl-modal-footer{display:flex;gap:.6rem;justify-content:flex-end;padding-top:.75rem;border-top:1px solid var(--border)}.dl-btn-cancel{background:var(--bg-page);border:1px solid var(--border-md);color:var(--text-muted);padding:.48rem 1rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .12s}.dl-btn-cancel:hover{background:var(--brand-cream)}.dl-btn-save{display:flex;align-items:center;gap:6px;background:var(--brand-red);color:#fff;border:none;padding:.48rem 1.2rem;border-radius:var(--r-sm);font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s}.dl-btn-save:hover{background:var(--brand-red-dk)}.dl-btn-save:active{transform:scale(.98)}.dl-btn-save:disabled{background:#ccc;cursor:not-allowed;transform:none}@media(max-width:1024px){.dl-topbar,.dl-filters{padding-left:1.25rem;padding-right:1.25rem}.dl-table-wrap{margin-left:1.25rem;margin-right:1.25rem}.dl-search-input{width:180px}}@media(max-width:768px){.inventory-wrapper,.dl-wrapper{width:100%!important;max-width:100%!important;align-self:stretch!important}.dl-topbar{padding:.75rem 1rem;flex-wrap:wrap;gap:.6rem}.dl-title{font-size:.95rem}.dl-subtitle{display:none}.dl-filters{padding:.65rem 1rem;gap:.5rem}.dl-search-wrap{margin-left:0;width:100%;order:10}.dl-search-input{width:100%}.dl-table-wrap{margin:16px 16px 0;border-radius:12px;overflow:hidden}.dl-table{min-width:unset;display:block}.dl-table thead{display:none}.dl-table tbody{display:flex;flex-direction:column;gap:0}.dl-table tbody tr.dl-row{display:grid;grid-template-columns:1fr 1fr;grid-template-areas:"type     trucking" "project  project" "category category" "driver   dest" "qty      date" "status   status" "actions  actions";gap:6px 12px;padding:16px 18px;border-bottom:1px solid var(--border);border-radius:0}.dl-table tbody tr.dl-row:first-child{border-radius:12px 12px 0 0}.dl-table tbody tr.dl-row:last-child{border-bottom:none;border-radius:0 0 12px 12px}.dl-table tbody tr.dl-row:hover{background:#faf7f5}.dl-table tbody tr.dl-row td{padding:2px 0}.dl-table tbody tr.dl-row td:nth-child(1){grid-area:type;align-self:center}.dl-table tbody tr.dl-row td:nth-child(2){grid-area:trucking;align-self:center;text-align:right}.dl-table tbody tr.dl-row td:nth-child(3){grid-area:project;padding-top:4px}.dl-table tbody tr.dl-row td:nth-child(4){grid-area:category}.dl-table tbody tr.dl-row td:nth-child(5){grid-area:driver}.dl-table tbody tr.dl-row td:nth-child(6){grid-area:dest;text-align:right;align-self:center}.dl-table tbody tr.dl-row td:nth-child(7){grid-area:qty}.dl-table tbody tr.dl-row td:nth-child(8){grid-area:date;text-align:right;align-self:center}.dl-table tbody tr.dl-row td:nth-child(9){grid-area:status;padding-top:2px}.dl-table tbody tr.dl-row td:nth-child(10){grid-area:actions;display:flex;justify-content:flex-end;gap:8px;padding-top:8px;margin-top:4px;border-top:1px dashed var(--border)}.dl-table tbody tr.dl-row td:nth-child(7):before{content:"Qty";display:block;font-size:.62rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.04em;margin-bottom:1px}.dl-table tbody tr.dl-row td:nth-child(8):before{content:"Date";display:block;font-size:.62rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.04em;margin-bottom:1px;text-align:right}.dl-table tbody td.text-right,.dl-table tbody td.text-center{text-align:inherit}.dl-loading-cell,.dl-empty-cell{display:flex!important;grid-column:1 / -1}.dl-pagination{flex-direction:column;align-items:flex-start;padding:.75rem 1rem}.dl-overlay{align-items:flex-end;padding:0}.dl-modal{max-width:100%;border-radius:16px 16px 0 0;max-height:95vh;animation:dl-sheet-in .25s cubic-bezier(.22,1,.36,1)}@keyframes dl-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.dl-modal-header{border-radius:16px 16px 0 0}.dl-form-row{grid-template-columns:1fr}}@media(max-width:640px){.dl-topbar{padding:.65rem .85rem}.dl-topbar-right .dl-refresh-btn,.dl-add-btn span{display:none}.dl-filters{padding:.55rem .85rem}.dl-table-wrap{margin:.75rem .5rem 0;border-radius:8px}.dl-pagination{padding:.65rem .85rem;gap:.5rem}.dl-perpage-wrap{display:none}.dl-page-btn{min-width:26px;height:26px;font-size:.7rem}.dl-modal{border-radius:14px 14px 0 0}.dl-modal-header{padding:.85rem 1rem .75rem;border-radius:14px 14px 0 0}.dl-form{padding:.9rem 1rem .85rem}.dl-modal-footer{flex-direction:column-reverse;gap:.5rem}.dl-btn-cancel,.dl-btn-save{width:100%;justify-content:center}}@media(max-width:480px){.dl-topbar{flex-direction:column;align-items:flex-start;gap:.5rem;padding:.65rem .75rem}.dl-topbar-left{width:100%}.dl-topbar-right{width:100%;justify-content:flex-end}.dl-add-btn{width:100%;justify-content:center}.dl-add-btn span{display:inline}.dl-topbar-right .dl-refresh-btn{display:flex}.dl-filters{flex-direction:column;align-items:stretch;gap:.45rem;padding:.55rem .75rem}.dl-type-toggle{width:100%}.dl-toggle-btn{flex:1;text-align:center;font-size:.73rem;padding:.38rem .4rem}.dl-search-wrap,.dl-search-input{width:100%}.dl-table-wrap{margin:.5rem 0 0;border-radius:0;border-left:none;border-right:none}.dl-table tbody tr.dl-row{grid-template-columns:1fr;grid-template-areas:"type" "trucking" "project" "category" "driver" "dest" "qty" "date" "status" "actions";padding:16px 18px}.dl-table tbody tr.dl-row:first-child{border-radius:0}.dl-table tbody tr.dl-row:last-child{border-radius:0}.dl-table tbody tr.dl-row td:nth-child(2),.dl-table tbody tr.dl-row td:nth-child(6),.dl-table tbody tr.dl-row td:nth-child(8){text-align:left}.dl-table tbody tr.dl-row td:nth-child(8):before{text-align:left}.dl-pagination-info{font-size:.7rem}}@media(hover:none){.dl-add-btn:hover{background:var(--brand-red);transform:none}.dl-add-btn:active{background:var(--brand-red-dk);transform:scale(.98)}.dl-btn-save:active{transform:scale(.98)}.dl-row:hover{background:transparent}.dl-row:active{background:#faf7f5}.dl-deliver-btn:hover{background:#10b98114;color:#065f46;border-color:#10b98140}.dl-deliver-btn{padding:.45rem .85rem}}.landing-screen{width:100vw;min-height:100vh;background-size:cover!important;background-position:center!important;background-repeat:no-repeat!important;background-attachment:scroll;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;padding:1.5rem 1rem 0;box-sizing:border-box}.brand-divisions{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.25rem .35rem;margin-top:.3rem;animation:fadeUp .5s ease .5s both}.brand-divisions span{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#ffffffd9;text-shadow:0 1px 4px rgba(0,0,0,.5)}.brand-divisions .divider{color:#fca5a5;font-weight:400}.input-group input:disabled{opacity:.55;cursor:not-allowed}.lockout-banner{background:#fff7ed;color:#92400e;border:1px solid #fed7aa;border-radius:8px;padding:.6rem .75rem;font-size:.78rem;text-align:center;margin-bottom:.7rem;line-height:1.5}.lockout-banner strong{font-family:monospace;font-size:.85rem;letter-spacing:.04em}.enter-btn{width:100%;background:#b31d33;color:#fff;padding:.72rem 1rem;border:none;border-radius:8px;font-weight:700;font-size:.92rem;cursor:pointer;margin-top:.6rem;transition:background .2s,transform .1s;position:relative;overflow:hidden;min-height:46px;touch-action:manipulation;animation:fadeUp .4s ease 1.05s both;letter-spacing:.02em}.otp-input{text-align:center!important;font-size:1.5rem!important;letter-spacing:8px;font-weight:700;font-family:monospace}.timer-display{font-size:.78rem;margin-bottom:6px;color:#64748b;text-align:center}.timer-display .urgent{color:#e74c3c;font-weight:700}.resend-container{margin-top:10px;text-align:center}.resend-btn{background:none;border:none;color:#b31d33;text-decoration:underline;cursor:pointer;font-size:.85rem;font-weight:600;min-height:44px;padding:.5rem}.resend-btn:hover{color:#991626}.back-link{background:none;border:none;color:#64748b;margin-top:8px;cursor:pointer;font-size:.82rem;font-weight:600;width:100%;min-height:44px;display:flex;align-items:center;justify-content:center;gap:4px;transition:color .2s;letter-spacing:.01em}.back-link:hover{color:#b31d33}.login-error{background:#fef2f2;color:#b91c1c;padding:.6rem .75rem;border-radius:8px;font-size:.78rem;margin-top:.9rem;text-align:center;border:1px solid #fecaca;line-height:1.45}.login-footer{width:100%;z-index:1;display:flex;flex-direction:column;align-items:center;gap:.55rem;padding:1rem 1rem 1.2rem;margin-top:.4rem;border-top:1px solid rgba(255,255,255,.1);animation:fadeUp .5s ease 1.2s both;box-sizing:border-box}.footer-socials{display:flex;gap:.85rem;align-items:center}.footer-socials a{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:50%;color:#fffc;text-decoration:none;transition:background .2s,color .2s,transform .15s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.footer-socials a:hover{background:#b31d33;border-color:#b31d33;color:#fff;transform:translateY(-2px)}.footer-contact{display:flex;flex-direction:column;align-items:center;gap:.2rem;text-align:center}.footer-contact span{font-size:.67rem;color:#ffffffb3;letter-spacing:.01em;line-height:1.5}.footer-glory{font-size:.65rem;font-style:italic;font-weight:600;color:#fca5a5;margin:0;letter-spacing:.04em;text-shadow:0 1px 4px rgba(0,0,0,.4)}@media(min-width:600px){.landing-screen{gap:1.4rem;padding:2rem 1.5rem 0}.brand-logo{width:72px;height:72px}.brand-name{font-size:1.1rem;max-width:340px}.brand-tagline{font-size:.78rem}.brand-divisions span{font-size:.67rem}.login-box{max-width:380px;padding:2rem 1.75rem 2.1rem}.input-group input{font-size:.95rem;padding:.68rem .95rem}.enter-btn{font-size:.95rem}.footer-contact{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:.25rem 1rem}}@media(min-width:1024px){.landing-screen{background-attachment:fixed;gap:1.6rem}.brand-logo{width:80px;height:80px;border-radius:20px}.brand-name{font-size:1.2rem;max-width:380px;letter-spacing:.04em}.brand-tagline{font-size:.82rem}.brand-divisions span{font-size:.7rem}.login-box{max-width:400px;padding:2.25rem 2rem 2.35rem;border-radius:16px}.login-box:before{height:4px}.card-system-label{margin-bottom:1.3rem}.input-group{margin-bottom:1rem}.input-group input{font-size:1rem;padding:.72rem 1rem}.enter-btn{font-size:1rem;padding:.78rem 1rem}.footer-contact{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:.25rem 1.2rem}.footer-contact span{font-size:.7rem}}@media(max-height:520px)and (orientation:landscape){.landing-screen{flex-direction:row;justify-content:center;align-items:center;gap:2rem;padding:1rem 2rem;overflow-y:auto}.brand-above{flex-shrink:0;max-width:180px;animation:fadeUp .5s ease .2s both}.brand-logo{width:50px;height:50px}.brand-name{font-size:.82rem}.brand-tagline{font-size:.68rem}.brand-divisions{display:none}.login-box{max-width:300px;padding:1.1rem 1.25rem 1.2rem}.card-system-label{margin-bottom:.7rem}.input-group{margin-bottom:.65rem}.input-group input{padding:.55rem .8rem}.enter-btn{margin-top:.4rem;padding:.6rem}.login-footer{display:none}}@keyframes cardRise{0%{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes lineExpand{0%{left:50%;right:50%}to{left:0;right:0}}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeDown{0%{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmerSweep{0%{transform:translate(-100%)}to{transform:translate(200%)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.75}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.landing-screen{width:100vw;min-height:100vh;background-size:cover!important;background-position:center!important;background-repeat:no-repeat!important;background-attachment:scroll;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;padding:1.5rem 1rem;box-sizing:border-box}.landing-screen:after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(179,29,51,.04) 50%,transparent 70%);animation:shimmerSweep 3.5s ease-out forwards;pointer-events:none;z-index:0}.brand-above{display:flex;flex-direction:column;align-items:center;gap:.35rem;z-index:1;animation:fadeDown .6s cubic-bezier(.22,1,.36,1) .2s both;text-align:center;padding:0 .5rem}.brand-logo{width:64px;height:64px;object-fit:contain;border-radius:16px;padding:6px;filter:drop-shadow(0 4px 14px rgba(0,0,0,.45));margin-bottom:.2rem}.brand-name{font-size:1rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.03em;line-height:1.25;margin:0;text-shadow:0 2px 12px rgba(0,0,0,.6);max-width:280px}.brand-tagline{font-size:.75rem;font-style:italic;color:#fca5a5;font-weight:600;margin:0;text-shadow:0 1px 6px rgba(0,0,0,.5)}.login-box{background:#fff;padding:1.6rem 1.4rem 1.75rem;border-radius:14px;box-shadow:0 20px 40px #00000059,0 6px 12px #0000001f;width:100%;max-width:340px;position:relative;z-index:1;overflow:hidden;box-sizing:border-box;animation:cardRise .65s cubic-bezier(.22,1,.36,1) .4s both}.login-box:before{content:"";position:absolute;top:0;left:50%;right:50%;height:3px;background:#b31d33;animation:lineExpand .5s cubic-bezier(.22,1,.36,1) .9s forwards}.card-system-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;text-align:center;margin:0 0 1.1rem}.input-group{margin-bottom:.9rem}.input-group:nth-of-type(1){animation:fadeUp .4s ease .85s both}.input-group:nth-of-type(2){animation:fadeUp .4s ease .95s both}.input-group:nth-of-type(3){animation:fadeUp .4s ease 1.05s both}.input-group label{display:block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#475569;margin-bottom:.35rem}.input-group input{width:100%;font-size:16px;padding:.62rem .85rem;border:1px solid #e2e8f0;border-radius:8px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;color:#1e293b;background:#f8fafc}.input-group input:focus{outline:none;border-color:#b31d33;background:#fff;box-shadow:0 0 0 3px #b31d331a}.password-wrapper{position:relative;display:flex;align-items:center}.password-wrapper input{padding-right:3.5rem}.password-toggle-btn{position:absolute;right:0;top:0;bottom:0;background:transparent;border:none;cursor:pointer;padding:0 .8rem;font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#94a3b8;transition:color .2s;display:flex;align-items:center;justify-content:center;min-width:44px}.password-toggle-btn:hover{color:#b31d33}.enter-btn{width:100%;background:#b31d33;color:#fff;padding:.72rem 1rem;border:none;border-radius:8px;font-weight:700;font-size:.92rem;cursor:pointer;margin-top:.6rem;transition:background .2s,transform .1s;position:relative;overflow:hidden;min-height:46px;touch-action:manipulation;animation:fadeUp .4s ease 1.15s both;letter-spacing:.02em}.enter-btn:hover{background:#991626}.enter-btn:active{transform:scale(.98)}.enter-btn:disabled{background:#9ca3af;cursor:not-allowed}.loader-container{display:flex;align-items:center;justify-content:center;gap:8px}.spinner{width:16px;height:16px;border:2.5px solid rgba(255,255,255,.35);border-radius:50%;border-top-color:#fff;animation:spin .75s linear infinite;display:inline-block;flex-shrink:0}.checking-pulse{animation:pulse 1.5s infinite}.login-error{background:#fef2f2;color:#b91c1c;padding:.6rem .75rem;border-radius:8px;font-size:.78rem;margin-top:.9rem;margin-bottom:.9rem;text-align:center;border:1px solid #fecaca;line-height:1.45;animation:fadeIn .3s ease-out}.reset-success-box{text-align:center;animation:fadeUp .5s ease}.success-icon{font-size:3rem;margin-bottom:10px;animation:pulse 2s infinite}.helper-text{font-size:.75rem;color:#94a3b8;margin-top:6px;text-align:center;font-style:italic}.animate-fade-in{animation:fadeIn .8s ease-out forwards}.bg-fixed-cover{background-size:cover!important;background-position:center!important;background-repeat:no-repeat!important}@media(min-width:600px){.landing-screen{gap:1.4rem;padding:2rem 1.5rem}.brand-logo{width:72px;height:72px}.brand-name{font-size:1.1rem;max-width:340px}.brand-tagline{font-size:.78rem}.login-box{max-width:380px;padding:2rem 1.75rem 2.1rem}.input-group input{font-size:.95rem;padding:.68rem .95rem}.enter-btn{font-size:.95rem}}@media(min-width:1024px){.landing-screen{background-attachment:fixed;gap:1.6rem}.brand-logo{width:80px;height:80px;border-radius:20px}.brand-name{font-size:1.2rem;max-width:380px;letter-spacing:.04em}.brand-tagline{font-size:.82rem}.login-box{max-width:400px;padding:2.25rem 2rem 2.35rem;border-radius:16px}.login-box:before{height:4px}.card-system-label{margin-bottom:1.3rem}.input-group{margin-bottom:1rem}.input-group input{font-size:1rem;padding:.72rem 1rem}.enter-btn{font-size:1rem;padding:.78rem 1rem}}@media(min-width:1440px){.brand-logo{width:88px;height:88px}.brand-name{font-size:1.3rem}.login-box{max-width:420px;padding:2.5rem 2.25rem 2.6rem}}@media(max-height:520px)and (orientation:landscape){.landing-screen{flex-direction:row;justify-content:center;align-items:center;gap:2rem;padding:1rem 2rem;overflow-y:auto}.brand-above{flex-shrink:0;max-width:180px;animation:fadeUp .5s ease .2s both}.brand-logo{width:50px;height:50px}.brand-name{font-size:.82rem}.brand-tagline{font-size:.68rem}.login-box{max-width:300px;padding:1.1rem 1.25rem 1.2rem}.card-system-label{margin-bottom:.7rem}.input-group{margin-bottom:.65rem}.input-group input{padding:.55rem .8rem}.enter-btn{margin-top:.4rem;padding:.6rem}}:root{--brand-black: #221F1F;--brand-blue: #497B97;--brand-red: #C20100;--brand-red-dk: #A00101;--brand-cream: #EBDBD6;--bg-page: #F4F2F0;--bg-card: #FFFFFF;--bg-subtle: #FAF8F6;--border: #E0D9D4;--border-md: #C8BDB8;--text-pri: #221F1F;--text-muted: #7A706C;--text-light: #A89E9A;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--sh-sm: 0 1px 3px rgba(34,31,31,.07);--sh-md: 0 4px 16px rgba(34,31,31,.1);--sh-lg: 0 12px 40px rgba(34,31,31,.18)}@keyframes ad-spin{to{transform:rotate(360deg)}}@keyframes ad-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes ad-blink{0%,to{opacity:1}50%{opacity:.3}}.ad-wrapper{font-family:DM Sans,sans-serif;background:var(--bg-page);min-height:100vh;padding:0 0 3rem;color:var(--text-pri)}.ad-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;color:var(--text-muted);font-weight:500;gap:15px}.ad-spinner{width:30px;height:30px;border:3px solid var(--border);border-top-color:var(--brand-red);border-radius:50%;animation:ad-spin .7s linear infinite}.ad-header{background:var(--brand-black);border-bottom:3px solid var(--brand-red);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;border-radius:0;box-shadow:none;margin-bottom:0}.ad-header-left{display:flex;align-items:center;gap:.85rem}.ad-header-right{display:flex;align-items:center;gap:.65rem}.ad-header-icon{width:42px;height:42px;background:var(--brand-red);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:none}.ad-title{font-size:1.05rem;font-weight:800;color:#fff;letter-spacing:-.01em;text-transform:uppercase;margin:0}.ad-subtitle{font-size:.72rem;color:var(--brand-cream);opacity:.8;margin:0}.ad-live-badge{display:flex;align-items:center;gap:6px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:.3rem .85rem;font-size:.7rem;font-weight:600;color:#fffc;white-space:nowrap}.ad-live-dot{width:7px;height:7px;background:#10b981;border-radius:50%;animation:ad-blink 1.6s infinite;flex-shrink:0;transform:none}.ad-clock{font-size:.68rem;color:#ffffff80;white-space:nowrap;font-variant-numeric:tabular-nums;background:none;padding:0;border-radius:0}.ad-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.25rem 1.75rem 0;margin-bottom:0}.ad-kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.1rem 1.1rem .9rem;display:flex;align-items:center;gap:.9rem;box-shadow:var(--sh-sm);animation:ad-rise .5s ease both;overflow:hidden;position:relative;transition:transform .18s,box-shadow .18s;border-top:1px solid var(--border)}.ad-kpi-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--kpi-accent, var(--brand-blue));border-radius:0 0 var(--r-lg) var(--r-lg)}.ad-kpi-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}.ad-kpi-alert{background:var(--brand-red)!important;border-color:var(--brand-red-dk)!important;color:unset}.ad-kpi-alert:after{background:var(--brand-red-dk)!important}.ad-kpi-alert .ad-kpi-data h3,.ad-kpi-alert .ad-kpi-data p,.ad-kpi-alert .ad-kpi-note{color:#fff!important}.ad-kpi-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ad-kpi-data h3{font-size:1.65rem;font-weight:800;color:var(--text-pri);line-height:1;letter-spacing:-.025em;margin:0}.ad-kpi-data p{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:4px 0 0}.ad-kpi-note{font-size:.67rem!important;font-weight:400!important;color:var(--text-light);margin:2px 0 0;opacity:1!important}.ad-kpi-split{display:flex;gap:8px;font-size:.75rem;margin-top:6px;font-weight:700}.ad-active-text{color:#059669}.ad-trashed-text{color:#dc2626}.ad-divider{color:var(--border-md);font-weight:400}.ad-main-grid{display:grid;gap:1.1rem;padding:1.1rem 1.75rem 0;align-items:start;grid-template-columns:1fr}@media(min-width:1024px){.ad-main-grid{grid-template-columns:repeat(2,1fr)}}.ad-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden;animation:ad-rise .5s ease both;display:flex;flex-direction:column;padding:0}.ad-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:.75rem 1.1rem;background:var(--brand-black);border-bottom:2px solid var(--brand-red);margin-bottom:0}.ad-panel-header h2{font-size:.82rem;font-weight:700;color:#fff;margin:0;text-transform:uppercase;letter-spacing:.06em}.ad-panel-header p{font-size:.7rem;color:var(--brand-cream);opacity:.7;margin:2px 0 0}.ad-bottleneck-list{padding:1rem 1.1rem;display:flex;flex-direction:column;gap:1rem;flex-grow:1;justify-content:center}.ad-dept-row{display:flex;flex-direction:column;gap:6px}.ad-dept-info{display:flex;justify-content:space-between;font-size:.82rem;font-weight:600}.ad-dept-name{color:var(--text-pri)}.ad-dept-count{color:var(--text-muted);font-weight:700}.ad-progress-bar{width:100%;height:7px;background:var(--bg-page);border:1px solid var(--border);border-radius:20px;overflow:hidden}.ad-progress-fill{height:100%;border-radius:20px;transition:width 1.1s cubic-bezier(.4,0,.2,1);min-width:3px}.ad-bar-chart{display:flex;align-items:flex-end;justify-content:space-around;height:220px;padding:30px 1.1rem 0;border-bottom:1px dashed var(--border);margin-top:10px;flex-grow:1}.ad-bar-col{display:flex;flex-direction:column;align-items:center;gap:10px;width:50px;height:100%;justify-content:flex-end}.ad-bar-fill{width:100%;border-radius:var(--r-sm) var(--r-sm) 0 0;position:relative;transition:height .6s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #221f1f1a}.ad-bar-fill:hover{filter:brightness(1.12);cursor:default}.ad-bar-val{position:absolute;top:-24px;left:50%;transform:translate(-50%);font-size:.7rem;font-weight:800;color:var(--text-pri);background:var(--bg-card);padding:2px 8px;border-radius:var(--r-sm);border:1px solid var(--border);box-shadow:var(--sh-sm);white-space:nowrap}.ad-bar-label{font-size:.7rem;font-weight:700;color:var(--text-muted);text-align:center;line-height:1.2}@media(max-width:1100px){.ad-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.ad-header{padding:.85rem 1rem;flex-wrap:wrap}.ad-kpi-grid{padding:.85rem 1rem 0;gap:.65rem}.ad-main-grid{padding:.85rem 1rem 0}.ad-live-badge{display:none}}@media(max-width:420px){.ad-kpi-grid{grid-template-columns:1fr 1fr}}
