.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b);padding:1rem}.login-card{background:#fff;border-radius:16px;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 25px 50px -12px #00000040}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2.5rem;font-weight:800;color:#0f172a;margin:0;letter-spacing:-.02em}.login-header p{color:#64748b;margin:.5rem 0 0;font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group label{font-size:.875rem;font-weight:500;color:#334155}.form-group input{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background:#f8fafc;cursor:not-allowed}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem 1rem;border-radius:8px;font-size:.875rem}.login-button{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:.875rem 1rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;margin-top:1.5rem;font-size:.875rem;color:#64748b}.login-footer a{color:#3b82f6;text-decoration:none;font-weight:500}.login-footer a:hover{text-decoration:underline}.form-hint{font-size:.75rem;color:#94a3b8;margin-top:.25rem}.otp-info{text-align:center;padding:1rem;background:#f0fdf4;border-radius:8px;margin-bottom:1rem}.otp-info p{font-size:.875rem;color:#059669;margin:0}.otp-info span{font-size:.75rem;color:#64748b}.otp-input{font-size:1.5rem;letter-spacing:.5em;text-align:center;font-family:monospace}.resend-section{text-align:center;margin-top:1rem}.countdown{font-size:.75rem;color:#94a3b8}.resend-button{background:none;border:none;color:#3b82f6;font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem}.resend-button:hover{text-decoration:underline}.resend-button:disabled{color:#94a3b8;cursor:not-allowed}.back-button{background:none;border:none;color:#64748b;font-size:.875rem;cursor:pointer;margin-top:.5rem;padding:.5rem;width:100%}.back-button:hover{color:#0f172a}.app-container{display:flex;min-height:100vh;background:#f1f5f9}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;color:#64748b}.spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sidebar{width:280px;background:linear-gradient(180deg,#0f172a,#1e293b);color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100}.sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);text-align:center}.sidebar-header .logo{max-width:180px;height:auto}.portal-label{display:block;font-size:.75rem;color:#fff9;margin-top:.5rem;text-transform:uppercase;letter-spacing:.1em}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1.5rem;background:none;border:none;color:#ffffffb3;font-size:.9rem;cursor:pointer;transition:all .2s;text-align:left}.nav-item:hover{background:#ffffff0d;color:#fff}.nav-item.active{background:#3b82f633;color:#60a5fa;border-left:3px solid #3b82f6}.nav-icon{font-size:1.25rem}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.user-avatar{width:36px;height:36px;background:#ffffff1a;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fffc}.user-details{display:flex;flex-direction:column}.user-name{font-size:.875rem;font-weight:500}.user-code{font-size:.75rem;color:#ffffff80}.logout-btn{width:100%;padding:.625rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.logout-btn:hover{background:#ef444433}.main-content{flex:1;margin-left:280px;display:flex;flex-direction:column}.content-topbar{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 2rem;background:#fff;border-bottom:1px solid #e2e8f0}.content-topbar h1{font-size:1.5rem;font-weight:600;color:#0f172a;margin:0}.current-date{font-size:.875rem;color:#64748b}.content-area{flex:1;padding:2rem;overflow-y:auto}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0}.stat-card.warning{border-left:4px solid #f59e0b}.stat-card.success{border-left:4px solid #22c55e}.stat-icon-wrapper{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.stat-icon-wrapper.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon-wrapper.primary{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-icon-wrapper.info{background:linear-gradient(135deg,#06b6d4,#0891b2)}.stat-icon-wrapper.secondary{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-info{display:flex;flex-direction:column}.stat-label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.5rem;font-weight:700;color:#0f172a}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.grid-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0;overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #f1f5f9}.card-header h3{font-size:1rem;font-weight:600;color:#0f172a;margin:0}.card-header button{background:none;border:none;color:#3b82f6;font-size:.8rem;cursor:pointer;display:inline-flex;align-items:center;gap:.25rem}.card-content{padding:.5rem 0}.activity-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid #f8fafc}.activity-item:last-child{border-bottom:none}.activity-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border-radius:8px;color:#64748b}.activity-icon.debit{background:#fef2f2;color:#dc2626}.activity-icon.credit{background:#f0fdf4;color:#16a34a}.activity-info{flex:1;display:flex;flex-direction:column}.activity-title{font-size:.875rem;color:#0f172a}.activity-date{font-size:.75rem;color:#94a3b8}.activity-amount{font-size:.875rem;font-weight:600}.activity-amount.debit{color:#dc2626}.activity-amount.credit{color:#16a34a}.content-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0}.content-header{padding:1.5rem;border-bottom:1px solid #e2e8f0}.content-header h2{font-size:1.25rem;font-weight:600;color:#0f172a;margin:0 0 .25rem}.content-header p{font-size:.875rem;color:#64748b;margin:0}.data-table{overflow-x:auto}.data-table table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.875rem 1.25rem;text-align:left;border-bottom:1px solid #f1f5f9}.data-table th{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;background:#f8fafc}.data-table td{font-size:.875rem;color:#334155}.data-table .doc-number{font-weight:500;color:#0f172a}.data-table .amount{font-weight:600}.data-table .debit{color:#dc2626}.data-table .credit{color:#16a34a}.data-table .balance{font-weight:600;color:#0f172a}.badge{display:inline-block;padding:.25rem .625rem;border-radius:4px;font-size:.75rem;font-weight:500}.badge.invoice{background:#dbeafe;color:#1d4ed8}.badge.receipt{background:#d1fae5;color:#059669}.badge.adjustment{background:#fef3c7;color:#d97706}.action-btn{background:#f1f5f9;border:none;padding:.375rem .75rem;border-radius:4px;font-size:.75rem;color:#3b82f6;cursor:pointer;display:inline-flex;align-items:center;gap:.375rem}.action-btn:hover{background:#e2e8f0}.statement-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1.5rem;background:#f8fafc}.summary-card{background:#fff;padding:1rem 1.25rem;border-radius:8px;border:1px solid #e2e8f0}.summary-card .label{display:block;font-size:.75rem;color:#64748b;margin-bottom:.25rem}.summary-card .value{font-size:1.25rem;font-weight:700}.summary-card .value.debit{color:#dc2626}.summary-card .value.credit{color:#16a34a}.summary-card.highlight{background:linear-gradient(135deg,#0f172a,#1e293b)}.summary-card.highlight .label{color:#ffffffb3}.summary-card.highlight .value{color:#fff}.elevator-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:1.5rem}.elevator-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.elevator-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.elevator-icon{color:#3b82f6}.status-badge{font-size:.625rem;padding:.25rem .5rem;border-radius:4px;font-weight:600;text-transform:uppercase}.status-badge.active{background:#d1fae5;color:#059669}.elevator-card h3{font-size:1rem;font-weight:600;color:#0f172a;margin:0 0 .25rem}.elevator-brand{font-size:.875rem;color:#64748b;margin:0 0 .5rem}.elevator-address{font-size:.75rem;color:#94a3b8;margin:0}.next-maintenance{display:flex;justify-content:space-between;margin-top:1rem;padding-top:1rem;border-top:1px solid #f1f5f9;font-size:.75rem}.next-maintenance .label{color:#64748b;display:flex;align-items:center;gap:.375rem}.next-maintenance .date{font-weight:600;color:#f59e0b}.payment-section{padding:1.5rem}.payment-info{text-align:center;padding:2rem;background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:12px;color:#fff;margin-bottom:1.5rem}.payment-info h3{font-size:.875rem;font-weight:400;margin:0 0 .5rem;opacity:.8}.payment-amount{font-size:2.5rem;font-weight:700}.payment-amount.debit{color:#fca5a5}.payment-amount.credit{color:#86efac}.payment-methods h4,.bank-info h4{font-size:.875rem;font-weight:600;color:#0f172a;margin:0 0 1rem}.method-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.method-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.method-card.disabled{opacity:.5}.method-card .icon{font-size:2rem}.method-card span{font-size:.875rem;font-weight:500;color:#0f172a}.method-card small{font-size:.75rem;color:#64748b}.bank-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.25rem}.bank-card p{margin:.5rem 0;font-size:.875rem;color:#334155}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.statement-summary{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.app-container{flex-direction:column;padding-bottom:72px}.sidebar{display:none}.main-content{margin-left:0;width:100%}.content-topbar{padding:1rem;position:sticky;top:0;z-index:50}.content-topbar h1{font-size:1.25rem}.current-date{display:none}.content-area{padding:1rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem}.stat-card{padding:1rem;flex-direction:column;align-items:flex-start;gap:.5rem}.stat-icon-wrapper{width:40px;height:40px}.stat-icon-wrapper svg{width:20px;height:20px}.stat-label{font-size:.625rem}.stat-value{font-size:1.125rem}.dashboard-grid{grid-template-columns:1fr;gap:1rem}.grid-card{border-radius:8px}.card-header{padding:.875rem 1rem}.card-header h3{font-size:.9rem}.activity-item{padding:.625rem 1rem}.statement-summary{grid-template-columns:1fr;gap:.75rem;padding:1rem}.summary-card{padding:.875rem 1rem}.summary-card .value{font-size:1.125rem}.data-table{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table th,.data-table td{padding:.75rem .625rem;font-size:.75rem;white-space:nowrap}.elevator-grid{grid-template-columns:1fr;gap:1rem;padding:1rem}.elevator-card,.payment-section{padding:1rem}.payment-info{padding:1.5rem 1rem}.payment-amount{font-size:2rem}.method-cards{grid-template-columns:1fr}.method-card{padding:1.25rem}.content-section{border-radius:8px}.content-header{padding:1rem}.content-header h2{font-size:1.125rem}}.bottom-nav{display:none}@media(max-width:768px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:72px;background:#fff;border-top:1px solid #e2e8f0;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;background:none;border:none;color:#64748b;font-size:.625rem;cursor:pointer;transition:color .2s;padding:.5rem}.bottom-nav-item:active{background:#f8fafc}.bottom-nav-item.active{color:#3b82f6}.bottom-nav-item svg{width:24px;height:24px}.bottom-nav-item span{font-weight:500}}.mobile-header{display:none}@media(max-width:768px){.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff}.mobile-header .logo{height:32px;width:auto}.mobile-header .user-btn{width:36px;height:36px;border-radius:50%;background:#ffffff1a;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}}.document-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem}.document-modal{background:#fff;border-radius:12px;width:100%;max-width:800px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.document-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0}.document-modal-header h3{margin:0;font-size:1.125rem;color:#0f172a}.document-modal-actions{display:flex;gap:.5rem}.modal-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .75rem;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.modal-btn.primary{background:#3b82f6;color:#fff;border:none}.modal-btn.primary:hover{background:#2563eb}.modal-btn.secondary{background:#f1f5f9;color:#334155;border:1px solid #e2e8f0}.modal-btn.secondary:hover{background:#e2e8f0}.modal-btn.close{background:none;border:none;color:#64748b;padding:.5rem}.document-modal-content{flex:1;overflow-y:auto;padding:1.5rem}@media(max-width:768px){.document-modal-overlay{padding:0}.document-modal{border-radius:0;max-height:100vh;height:100vh}.document-modal-header,.document-modal-content{padding:1rem}}.document-detail{display:flex;flex-direction:column;gap:.5rem}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #f1f5f9}.detail-label{font-size:.875rem;color:#64748b}.detail-value{font-size:.875rem;color:#0f172a;font-weight:500}.detail-value.amount{font-size:1.125rem;font-weight:700;color:#0f172a}.detail-section{margin-top:1rem}.detail-section h4{font-size:.875rem;font-weight:600;color:#0f172a;margin:0 0 .75rem}.line-items-table{overflow-x:auto}.line-items-table table{width:100%;border-collapse:collapse;font-size:.8rem}.line-items-table th,.line-items-table td{padding:.625rem;text-align:left;border-bottom:1px solid #f1f5f9}.line-items-table th{background:#f8fafc;font-weight:600;color:#64748b}.verification-info{display:flex;align-items:center;gap:.5rem;margin-top:1.5rem;padding:1rem;background:#f0fdf4;border-radius:8px;color:#059669;font-size:.875rem}.activity-item{cursor:pointer;transition:background .2s}.activity-item:hover{background:#f8fafc}.category-tabs{display:flex;gap:.5rem;padding:1rem 1.5rem;overflow-x:auto;border-bottom:1px solid #e2e8f0;-webkit-overflow-scrolling:touch}.category-tab{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:#f1f5f9;border:none;border-radius:6px;font-size:.8rem;color:#64748b;cursor:pointer;white-space:nowrap;transition:all .2s}.category-tab:hover{background:#e2e8f0}.category-tab.active{background:#3b82f6;color:#fff}.header-row{display:flex;justify-content:space-between;align-items:flex-start}.add-fault-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.625rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.add-fault-btn:hover{background:#b91c1c}.pending-quotes-alert{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:#fef3c7;color:#92400e;font-size:.875rem}.pending-banner{display:flex;align-items:center;gap:.5rem;padding:1rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;border-radius:12px;margin-bottom:1.5rem;cursor:pointer;transition:transform .2s}.pending-banner:hover{transform:translateY(-2px)}.activity-timeline{padding:1rem 0}.timeline-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .2s}.timeline-item:hover{background:#f8fafc}.timeline-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;color:#fff;flex-shrink:0}.timeline-icon.maintenance{background:linear-gradient(135deg,#3b82f6,#2563eb)}.timeline-icon.repair{background:linear-gradient(135deg,#ef4444,#dc2626)}.timeline-icon.quotes,.timeline-icon.revision{background:linear-gradient(135deg,#f59e0b,#d97706)}.timeline-icon.contracts{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.timeline-icon.financial{background:linear-gradient(135deg,#10b981,#059669)}.timeline-icon.warranty{background:linear-gradient(135deg,#06b6d4,#0891b2)}.timeline-content{flex:1;min-width:0}.timeline-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.timeline-title{font-size:.9rem;font-weight:500;color:#0f172a}.timeline-meta{display:flex;gap:1rem;margin-top:.375rem;font-size:.75rem;color:#64748b}.timeline-meta span{display:inline-flex;align-items:center;gap:.25rem}.timeline-amount{font-weight:600;color:#0f172a!important}.timeline-arrow{color:#94a3b8;flex-shrink:0}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.625rem;font-weight:600;text-transform:uppercase}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.info{background:#dbeafe;color:#1e40af}.status-badge.success{background:#d1fae5;color:#065f46}.status-badge.danger{background:#fee2e2;color:#991b1b}.status-badge.warning{background:#fef3c7;color:#92400e}.status-badge.muted{background:#f1f5f9;color:#64748b}.nav-badge{background:#ef4444;color:#fff;font-size:.625rem;padding:.125rem .375rem;border-radius:10px;margin-left:auto}.bottom-nav-badge{position:absolute;top:4px;right:50%;transform:translate(50%);background:#ef4444;color:#fff;font-size:.5rem;padding:2px 5px;border-radius:8px;margin-left:12px}.bottom-nav-item{position:relative}.fault-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:#0f172a}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6}.form-group textarea{resize:vertical;min-height:100px}.form-error{padding:.75rem;background:#fee2e2;color:#991b1b;border-radius:8px;font-size:.875rem}.form-success{padding:.75rem;background:#d1fae5;color:#065f46;border-radius:8px;font-size:.875rem}.submit-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.submit-btn:hover{background:#2563eb}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#94a3b8;text-align:center}.empty-state p{margin-top:.5rem;font-size:.9rem}@media(max-width:768px){.category-tabs{padding:.75rem 1rem}.category-tab{padding:.5rem .75rem;font-size:.75rem}.category-tab span{display:none}.header-row{flex-direction:column;gap:1rem}.add-fault-btn{width:100%;justify-content:center}.timeline-item{padding:.875rem 1rem}.timeline-icon{width:36px;height:36px}.timeline-meta{flex-wrap:wrap;gap:.5rem}.pending-banner{margin:0 0 1rem;border-radius:0;margin:-1rem -1rem 1rem}}.work-order-modal{max-width:600px}.wo-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #f1f5f9}.wo-section:last-child{border-bottom:none}.wo-section h4{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:#0f172a;margin:0 0 .75rem}.wo-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.wo-info-item{display:flex;flex-direction:column;gap:.25rem}.wo-info-item.full-width{grid-column:span 2}.wo-label{font-size:.75rem;color:#64748b}.wo-value{font-size:.875rem;font-weight:500;color:#0f172a}.wo-checklist{display:flex;flex-direction:column;gap:.5rem}.checklist-item{display:flex;align-items:center;gap:.625rem;padding:.625rem .75rem;background:#f8fafc;border-radius:6px;color:#64748b}.checklist-item.checked{background:#f0fdf4;color:#059669}.checklist-item.critical{border-left:3px solid #ef4444}.checklist-text{flex:1;font-size:.8rem}.critical-badge{font-size:.625rem;padding:.125rem .375rem;background:#fee2e2;color:#dc2626;border-radius:4px;font-weight:600}.wo-parts{display:flex;flex-direction:column;gap:.5rem}.part-item{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;background:#f8fafc;border-radius:6px}.part-info{display:flex;flex-direction:column;gap:.125rem}.part-name{font-size:.8rem;font-weight:500;color:#0f172a}.part-code{font-size:.7rem;color:#64748b}.part-details{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.part-qty{font-size:.75rem;color:#64748b}.part-cost{font-size:.875rem;font-weight:600;color:#0f172a}.wo-description,.wo-notes{font-size:.875rem;color:#475569;line-height:1.6;margin:0}.wo-section.confirmed{background:#f0fdf4;border-radius:8px;padding:1rem;border-bottom:none}.confirmed-badge{display:flex;align-items:center;gap:.75rem;color:#059669}.confirmed-badge strong{display:block;font-size:1rem}.confirmed-badge span{font-size:.8rem;opacity:.8}.confirmed-rating{display:flex;gap:.25rem;margin-top:.5rem;padding-left:2.25rem}.confirmation-form{background:#fefce8;border-radius:8px;padding:1rem;border-bottom:none}.confirm-desc{font-size:.8rem;color:#78716c;margin:0 0 1rem}.rating-input{margin-bottom:1rem}.rating-label{display:block;font-size:.8rem;color:#64748b;margin-bottom:.5rem}.star-rating{display:flex;gap:.25rem}.star-rating button{background:none;border:none;padding:0;cursor:pointer;transition:transform .2s}.star-rating button:hover{transform:scale(1.1)}.confirm-btn{background:#059669}.confirm-btn:hover{background:#047857}@media(max-width:768px){.wo-info-grid{grid-template-columns:1fr}.wo-info-item.full-width{grid-column:span 1}}.quotes-list,.contracts-list{display:flex;flex-direction:column;gap:1rem;padding:1rem 1.5rem}.quote-card,.contract-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem;cursor:pointer;transition:all .2s}.quote-card:hover,.contract-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a}.quote-header,.contract-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.quote-number,.contract-number{font-weight:600;font-size:1rem;color:#0f172a}.quote-type,.contract-type{font-size:.8rem;color:#64748b;margin-bottom:.375rem}.quote-elevator,.contract-elevator,.contract-dates{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:#64748b;margin-bottom:.5rem}.quote-footer,.contract-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem;padding-top:.5rem;border-top:1px solid #f1f5f9}.quote-amount,.contract-amount{font-size:1rem;font-weight:700;color:#0f172a}.quote-date{font-size:.75rem;color:#64748b}.quote-actions{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #f1f5f9}.approve-btn,.reject-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem .75rem;border:none;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.approve-btn{background:#059669;color:#fff}.approve-btn:hover{background:#047857}.reject-btn{background:#f1f5f9;color:#64748b}.reject-btn:hover{background:#e2e8f0;color:#475569}.tab-count{background:#ef4444;color:#fff;font-size:.625rem;padding:.125rem .375rem;border-radius:8px;margin-left:.25rem}@media(max-width:768px){.quotes-list,.contracts-list{padding:1rem}}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:#1a1a2e;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{min-width:320px;min-height:100vh}.container{max-width:640px;margin:0 auto;padding:1rem}.card{background:#fff;border-radius:1rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.card-header{padding:1.5rem;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff}.card-body{padding:1.5rem}.section{margin-bottom:1.5rem}.section-title{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.75rem;color:#64748b}.info-value{font-weight:500;color:#1e293b}.signature-box{border:2px dashed #e2e8f0;border-radius:.5rem;padding:1rem;text-align:center}.signature-image{max-width:100%;max-height:150px}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-verified{background:#dcfce7;color:#166534}.badge-pending{background:#fef3c7;color:#92400e}.parts-table{width:100%;border-collapse:collapse}.parts-table th,.parts-table td{padding:.75rem;text-align:left;border-bottom:1px solid #f1f5f9}.parts-table th{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase}.parts-table td{font-size:.875rem}.total-row{background:#f8fafc;font-weight:600}.digital-footprint{background:#f1f5f9;border-radius:.5rem;padding:1rem;font-size:.75rem;color:#64748b}.digital-footprint code{font-family:SF Mono,Monaco,Menlo,monospace;background:#e2e8f0;padding:.125rem .25rem;border-radius:.25rem}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1rem;color:#64748b}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:2rem}.error-icon{font-size:4rem;margin-bottom:1rem}.error-title{font-size:1.5rem;font-weight:600;color:#1e293b;margin-bottom:.5rem}.error-message{color:#64748b}
