@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;min-height:100vh;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fff;color:#0f172a;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}a{color:#3b82f6;text-decoration:none}a:hover{text-decoration:none}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg, #ffffff);padding:2rem;transition:background-color .3s ease}.login-card{background:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e2e8f0);border-radius:20px;padding:3rem;width:100%;max-width:420px;box-shadow:0 10px 40px #00000014;transition:background-color .3s ease,border-color .3s ease}.login-header{text-align:center;margin-bottom:2rem}.login-logo{height:80px;width:auto;object-fit:contain;margin-bottom:1rem}.login-header h1{font-size:1.75rem;font-weight:700;color:var(--color-text-primary, #0f172a);margin-bottom:.5rem}.login-header p{color:var(--color-text-secondary, #64748b);font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary, #475569)}.form-group input{padding:.875rem 1rem;background:var(--color-bg, #f8fafc);border:1px solid var(--color-border, #e2e8f0);border-radius:10px;color:var(--color-text-primary, #0f172a);font-size:1rem;transition:all .2s}.form-group input::placeholder{color:var(--color-text-muted, #94a3b8)}.form-group input:focus{outline:none;border-color:var(--color-primary, #3b82f6);background:var(--color-surface, #ffffff);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb, 59, 130, 246),.1)}.error-message{padding:.75rem 1rem;background:var(--color-danger-bg, #fef2f2);border:1px solid var(--color-danger-border, #fecaca);border-radius:8px;color:var(--color-danger-text, #dc2626);font-size:.875rem}:root.dark .error-message{background:#450a0a;border-color:#7f1d1d;color:#f87171}.btn--primary{padding:1rem;background:linear-gradient(135deg,var(--color-primary, #3b82f6) 0%,var(--color-primary-dark, #2563eb) 100%);border:none;border-radius:10px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px rgba(var(--color-primary-rgb, 59, 130, 246),.4)}.login-footer{text-align:center;margin-top:.5rem;display:flex;justify-content:center;align-items:center;gap:.75rem}.login-footer a{color:var(--color-primary, #3b82f6);text-decoration:none;font-size:.875rem}.login-footer a:hover{text-decoration:none;opacity:.8}.login-footer .divider{color:var(--color-border, #cbd5e1)}.success-message{padding:.75rem 1rem;background:var(--color-success-bg, #f0fdf4);border:1px solid var(--color-success-border, #bbf7d0);border-radius:8px;color:var(--color-success-text, #16a34a);font-size:.875rem}:root.dark .success-message{background:#064e3b;border-color:#065f46;color:#34d399}@media(max-width:480px){.login-card{padding:2rem}}.otp-info{text-align:center;padding:1rem;background:var(--color-bg, #f8fafc);border-radius:10px;margin-bottom:.5rem}.otp-info p{color:var(--color-text-secondary, #64748b);font-size:.9rem;margin:0}.otp-info strong{color:var(--color-text-primary, #0f172a)}.otp-input{font-size:1.5rem!important;letter-spacing:8px;text-align:center;font-weight:600;font-family:SF Mono,Monaco,Cascadia Code,monospace}.otp-input::placeholder{letter-spacing:8px;opacity:.4}.otp-actions{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:.5rem}.btn--link{background:none;border:none;color:var(--color-primary, #3b82f6);font-size:.875rem;cursor:pointer;padding:.5rem 0}.btn--link:hover:not(:disabled){text-decoration:none;opacity:.8}.btn--link:disabled{color:var(--color-text-muted, #94a3b8);cursor:not-allowed}.login-mode-toggle{text-align:center;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border, #e2e8f0)}.login-mode-toggle .btn--link{font-size:.8rem;opacity:.7}.dashboard{width:100%;max-width:960px;margin:0 auto;min-height:calc(100vh - var(--header-height, 72px));padding:1rem 0}.dashboard__header{margin-bottom:2.5rem}.dashboard__header h1{font-size:2rem;font-weight:700;color:var(--color-text-primary, #0f172a);margin-bottom:.5rem;letter-spacing:-.02em}.dashboard__header p{color:var(--color-text-secondary, #64748b);font-size:1.05rem}.dashboard__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2.5rem}.stat-card{background:var(--color-surface, #fff);border-radius:16px;padding:1.75rem;border:1px solid var(--color-border, #e2e8f0);transition:all .2s ease;color:var(--color-text-primary, #0f172a)}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 25px #0000001a}.stat-card--highlight{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff}.stat-card--highlight:hover{box-shadow:0 12px 25px #3b82f659}.stat-card__value{font-size:3rem;font-weight:700;line-height:1;margin-bottom:.5rem}.stat-card__label{font-size:.95rem;opacity:.8;font-weight:500}.dashboard__actions{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3rem}.action-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem 1.75rem;background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:16px;text-decoration:none;color:var(--color-text-primary, inherit);transition:all .25s ease}.action-card:hover{transform:translateY(-4px);box-shadow:0 15px 35px #0000001a;border-color:#3b82f6}.action-card--primary{background:linear-gradient(135deg,#10b981,#059669);border:none;color:#fff}.action-card--primary:hover{box-shadow:0 15px 35px #10b98159;border-color:transparent}.action-card__icon{font-size:2.5rem}.action-card__text h3{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.action-card__text p{font-size:.9rem;opacity:.75;margin:0}.dashboard__section{margin-top:2rem}.dashboard__section h2{font-size:1.35rem;font-weight:600;margin-bottom:1.25rem;color:var(--color-text-primary, #0f172a)}.claims-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1rem}.claim-item{display:block;padding:1.25rem;background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:14px;text-decoration:none;color:var(--color-text-primary, inherit);transition:all .2s}.claim-item:hover{border-color:#3b82f6;box-shadow:0 8px 20px #00000014;transform:translateY(-2px)}.claim-item__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.claim-item__number{font-weight:600;font-size:.95rem;color:var(--color-text-primary, #0f172a)}.claim-item__status{font-size:.7rem;padding:.3rem .75rem;border-radius:999px;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.claim-item__desc{font-size:.9rem;color:var(--color-text-secondary, #64748b);margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.loading{padding:4rem;text-align:center;color:var(--color-text-secondary, #64748b);font-size:1rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.section-header h2{font-size:1.35rem;font-weight:600;color:var(--color-text-primary, #0f172a);margin:0}.section-link{font-size:.9rem;color:#3b82f6;text-decoration:none;font-weight:500;transition:color .2s}.section-link:hover{color:#2563eb}.workorder-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.workorder-card{background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:16px;padding:1.25rem;transition:all .25s ease;position:relative;overflow:hidden}.workorder-card:hover{border-color:#3b82f6;box-shadow:0 12px 28px #0000001a;transform:translateY(-3px)}.workorder-card--urgent{border-left:4px solid #ef4444;background:linear-gradient(to right,rgba(254,226,226,.3),transparent)}.workorder-card--urgent:hover{border-color:#ef4444;box-shadow:0 12px 28px #ef444426}.workorder-card__top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.workorder-card__badges{display:flex;gap:.5rem;flex-wrap:wrap}.badge{font-size:.65rem;padding:.25rem .6rem;border-radius:999px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.badge--new{background:linear-gradient(135deg,#10b981,#059669);color:#fff;animation:pulse-new 2s infinite}@keyframes pulse-new{0%,to{opacity:1}50%{opacity:.8}}.badge--urgent{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;animation:pulse-urgent 1.5s infinite}@keyframes pulse-urgent{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.badge--status{background:#f1f5f9;color:#475569}.badge--status.status--pending{background:#fef3c7;color:#92400e}.badge--status.status--inprogress{background:#dbeafe;color:#1e40af}.badge--status.status--scheduled{background:#e0e7ff;color:#3730a3}.badge--status.status--onhold{background:#fee2e2;color:#991b1b}.days-indicator{font-size:.75rem;color:var(--color-text-secondary, #64748b);background:#f1f5f9;padding:.25rem .6rem;border-radius:6px;font-weight:500}.days--urgent{background:#fee2e2;color:#991b1b}.workorder-card__main{margin-bottom:.75rem}.workorder-card__number{font-weight:700;font-size:1.1rem;color:var(--color-text-primary, #0f172a);display:block;margin-bottom:.25rem}.workorder-card__customer{font-size:.9rem;color:var(--color-text-secondary, #64748b);margin:0}.workorder-card__location{display:flex;align-items:flex-start;gap:.4rem;font-size:.85rem;color:var(--color-text-secondary, #64748b);margin-bottom:.6rem;line-height:1.4}.location-icon{flex-shrink:0}.workorder-card__issue{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.6rem}.issue-type{font-size:.8rem;background:#f0fdf4;color:#166534;padding:.2rem .6rem;border-radius:6px;font-weight:500}.issue-brand{font-size:.8rem;background:#f8fafc;color:#475569;padding:.2rem .6rem;border-radius:6px;font-weight:500;border:1px solid #e2e8f0}.workorder-card__desc{font-size:.85rem;color:var(--color-text-secondary, #64748b);margin:0 0 .75rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.workorder-card__footer{display:flex;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--color-border, #e2e8f0)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.25rem;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;border:none}.btn--sm{padding:.45rem .9rem;font-size:.8rem;border-radius:8px}.btn--outline{background:transparent;border:1px solid var(--color-border, #e2e8f0);color:var(--color-text-primary, #0f172a)}.btn--outline:hover{background:#f8fafc;border-color:#3b82f6;color:#3b82f6}.btn--success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none}.btn--success:hover{box-shadow:0 4px 12px #10b98159}.btn--success:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none}.btn--primary:hover{box-shadow:0 4px 12px #3b82f659}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--color-surface, #fff);border-radius:16px;padding:2rem;width:100%;max-width:420px;box-shadow:0 25px 50px #00000040}.modal h3{font-size:1.25rem;font-weight:700;margin-bottom:.25rem;color:var(--color-text-primary, #0f172a)}.modal__subtitle{font-size:.9rem;color:var(--color-text-secondary, #64748b);margin-bottom:1.5rem}.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--color-text-primary, #0f172a);margin-bottom:.5rem}.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border, #e2e8f0);border-radius:10px;font-size:.9rem;background:var(--color-surface, #fff);color:var(--color-text-primary, #0f172a);transition:border-color .2s}.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:100px}.dashboard__empty-state{margin-top:2rem}.empty-card{background:linear-gradient(135deg,#f0fdf4,#e0f2fe);border-radius:20px;padding:3rem 2rem;text-align:center;border:1px dashed #a7f3d0}.empty-icon{font-size:3.5rem;display:block;margin-bottom:1rem}.empty-card h3{font-size:1.35rem;font-weight:700;color:#166534;margin-bottom:.5rem}.empty-card p{color:#64748b;margin-bottom:1.5rem}@media(max-width:1024px){.dashboard{padding:2rem}.dashboard__stats,.dashboard__actions{grid-template-columns:repeat(2,1fr)}.workorder-grid{grid-template-columns:1fr}}@media(max-width:640px){.dashboard{padding:1.5rem}.dashboard__stats,.dashboard__actions{grid-template-columns:1fr}.stat-card__value{font-size:2.25rem}.section-header{flex-direction:column;align-items:flex-start;gap:.5rem}.workorder-card__top{flex-direction:column;gap:.5rem}.days-indicator{align-self:flex-start}}.contracts-page{width:100%;min-height:calc(100vh - 72px);padding:2.5rem 3rem;background:var(--color-bg, #ffffff)}.page-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border, #e2e8f0)}.contracts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.5rem}.contract-card{display:flex;flex-direction:column;padding:1.5rem;background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:16px;text-decoration:none;color:var(--color-text-primary, inherit);transition:all .25s ease}.contract-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px #0000001f;border-color:#3b82f6}.contract-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.status-badge{padding:.35rem .9rem;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.contract-card__number{font-family:SF Mono,Monaco,monospace;font-size:.85rem;color:var(--color-text-muted, #94a3b8)}.contract-card__address{font-size:1.15rem;font-weight:600;margin:0 0 .35rem;color:var(--color-text-primary, #0f172a)}.contract-card__location{font-size:.9rem;color:var(--color-text-secondary, #64748b);margin:0 0 1.25rem}.contract-card__client{font-size:.9rem;color:var(--color-text-secondary, #475569);margin-bottom:1rem}.contract-card__email{color:var(--color-text-muted, #94a3b8)}.contract-card__meta{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding-top:1.25rem;border-top:1px solid var(--color-border, #f1f5f9);margin-bottom:1rem}.meta-item{display:flex;flex-direction:column}.meta-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #94a3b8);margin-bottom:.35rem;font-weight:500}.meta-value{font-weight:600;color:var(--color-text-primary, #1e293b);font-size:.95rem}.contract-card__footer{margin-top:auto}.view-link{color:#3b82f6;font-size:.9rem;font-weight:600;display:inline-flex;align-items:center;gap:.25rem}.empty-state{text-align:center;padding:5rem 2rem;background:var(--color-surface, #fff);border-radius:16px;border:1px solid var(--color-border, #e2e8f0);color:var(--color-text-secondary, #64748b)}@media(max-width:768px){.contracts-page{padding:1.5rem}.contracts-grid{grid-template-columns:1fr}}.contract-detail{max-width:1000px;margin:0 auto;padding:2rem}.back-link{display:inline-block;color:var(--color-primary, #3b82f6);text-decoration:none;font-size:.9rem;margin-bottom:1rem}.detail-header{margin-bottom:2rem}.detail-header__main{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.detail-header__main h1{font-size:1.75rem;font-weight:700;color:var(--color-text-primary, #1e293b);margin:0}.detail-header__sub{color:var(--color-text-secondary, #64748b);margin:0}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:2rem}.detail-card{background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:12px;padding:1.5rem;transition:background-color .3s ease,border-color .3s ease}.detail-card--wide{grid-column:1 / -1}.detail-card h2{font-size:1.1rem;font-weight:600;color:var(--color-text-primary, #1e293b);margin:0 0 1rem}.info-list{margin:0}.info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--color-border, #f1f5f9)}.info-row:last-child{border-bottom:none}.info-row dt{color:var(--color-text-secondary, #64748b);font-size:.9rem}.info-row dd{font-weight:500;color:var(--color-text-primary, #1e293b);margin:0}.service-info{color:var(--color-text-secondary, #64748b);font-size:.9rem;margin-bottom:1rem;line-height:1.5}.btn--primary{display:inline-block;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--color-primary, #3b82f6) 0%,var(--color-primary-dark, #2563eb) 100%);border:none;border-radius:8px;color:#fff;font-weight:600;text-decoration:none;cursor:pointer;transition:all .2s}.btn--primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(var(--color-primary-rgb, 59, 130, 246),.35)}.claims-table{margin-top:1rem}.claims-table__header,.claims-table__row{display:grid;grid-template-columns:1fr 1fr 2fr 100px;gap:1rem;padding:.75rem 0;align-items:center}.claims-table__header{font-size:.75rem;text-transform:uppercase;color:var(--color-text-muted, #94a3b8);border-bottom:1px solid var(--color-border, #e2e8f0)}.claims-table__row{border-bottom:1px solid var(--color-border, #f1f5f9);font-size:.9rem;color:var(--color-text-primary)}.claims-table__row:last-child{border-bottom:none}.error-state{text-align:center;padding:4rem;color:var(--color-text-secondary, #64748b)}@media(max-width:768px){.detail-grid{grid-template-columns:1fr}}.claims-page{width:100%;min-height:calc(100vh - 72px);padding:2.5rem 3rem;background:var(--color-bg, #ffffff)}.success-banner{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:1rem 1.5rem;border-radius:12px;margin-bottom:1.5rem;font-weight:600;font-size:1rem;box-shadow:0 4px 12px #10b9814d;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border, #e2e8f0)}.page-header h1{font-size:1.85rem;font-weight:700;color:var(--color-text-primary, #0f172a);margin-bottom:.35rem;letter-spacing:-.02em}.page-header p{color:var(--color-text-secondary, #64748b);font-size:1rem;margin:0}.claims-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.25rem}.claim-card{background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:16px;padding:1.5rem;transition:all .25s ease}.claim-card:hover{box-shadow:0 15px 35px #0000001a;border-color:#3b82f6;transform:translateY(-4px)}.claim-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.claim-card__info{display:flex;flex-direction:column}.claim-card__number{font-weight:700;font-size:1.05rem;color:var(--color-text-primary, #0f172a)}.claim-card__date{font-size:.8rem;color:var(--color-text-muted, #94a3b8);margin-top:.2rem}.claim-card__property{font-size:.9rem;color:var(--color-text-secondary, #475569);margin-bottom:1rem;padding:.65rem .9rem;background:var(--color-bg, #f8fafc);border-radius:10px;border:1px solid var(--color-border, #f1f5f9)}.claim-card__desc{font-size:.95rem;color:var(--color-text-secondary, #475569);margin:0 0 1.25rem;line-height:1.6}.claim-card__footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--color-border, #f1f5f9)}.claim-card__amount{display:flex;gap:.5rem;font-size:.95rem}.claim-card__amount .label{color:var(--color-text-muted, #94a3b8)}.claim-card__amount .value{font-weight:700;color:var(--color-text-primary, #0f172a)}.claim-card--clickable{text-decoration:none;display:block;cursor:pointer}.claim-card__arrow{color:var(--color-text-muted, #94a3b8);font-size:1.25rem;transition:transform .2s,color .2s}.claim-card--clickable:hover .claim-card__arrow{color:var(--color-primary, #3b82f6);transform:translate(4px)}.status--approved{background:#d1fae5;color:#065f46}.btn--primary{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;color:#fff;font-weight:600;font-size:.95rem;text-decoration:none;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #3b82f64d}.btn--primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #3b82f666}.empty-state{text-align:center;padding:5rem 2rem;background:var(--color-surface, #fff);border-radius:16px;border:1px solid var(--color-border, #e2e8f0)}.empty-state p{color:var(--color-text-secondary, #64748b);margin-bottom:1.5rem;font-size:1.05rem}.loading{padding:4rem;text-align:center;color:var(--color-text-secondary, #64748b)}@media(max-width:768px){.claims-page{padding:1.5rem}.claims-list{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}}.claim-detail-page{max-width:800px;margin:0 auto;padding:1.5rem}.claim-header{margin-bottom:1.5rem}.back-link{color:var(--color-primary, #3b82f6);text-decoration:none;font-size:.875rem;display:inline-block;margin-bottom:1rem}.back-link:hover{text-decoration:underline}.claim-header__main{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.claim-header__main h1{font-size:1.5rem;font-weight:700;color:var(--color-text-primary, #0f172a);margin:0}.claim-header__date{color:var(--color-text-secondary, #64748b);font-size:.875rem;margin:.25rem 0 0}.claim-info{background:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e2e8f0);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.claim-info__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #94a3b8)}.info-value{font-size:.9rem;color:var(--color-text-primary, #0f172a)}.claim-description{border-top:1px solid var(--color-border, #e2e8f0);padding-top:1rem}.claim-description p{margin:.5rem 0 0;color:var(--color-text-primary, #0f172a);line-height:1.5}.messages-section{background:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e2e8f0);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.messages-section h2{font-size:1rem;font-weight:600;color:var(--color-text-primary, #0f172a);padding:1rem 1.25rem;margin:0;border-bottom:1px solid var(--color-border, #e2e8f0)}.messages-container{min-height:300px;max-height:400px;overflow-y:auto;padding:1rem;background:var(--color-bg, #f8fafc)}.messages-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;text-align:center;color:var(--color-text-muted, #94a3b8)}.messages-empty p{margin:0 0 .25rem;font-size:1rem}.messages-empty span{font-size:.875rem}.messages-list{display:flex;flex-direction:column;gap:1rem}.message{display:flex;flex-direction:column;max-width:75%}.message--customer{align-self:flex-end;align-items:flex-end}.message--staff{align-self:flex-start;align-items:flex-start}.message__bubble{padding:.75rem 1rem;border-radius:16px;max-width:100%;word-wrap:break-word}.message--customer .message__bubble{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-bottom-right-radius:4px}.message--staff .message__bubble{background:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e2e8f0);color:var(--color-text-primary, #0f172a);border-bottom-left-radius:4px}.message__author{font-size:.75rem;font-weight:600;color:var(--color-primary, #3b82f6);margin-bottom:.25rem;display:block}.message__content{margin:0;font-size:.9rem;line-height:1.4;white-space:pre-wrap}.message__time{font-size:.7rem;color:var(--color-text-muted, #94a3b8);margin-top:.25rem}.message-form{display:flex;gap:.75rem;padding:1rem;border-top:1px solid var(--color-border, #e2e8f0);background:var(--color-surface, #ffffff)}.message-form input{flex:1;padding:.75rem 1rem;background:var(--color-bg, #f8fafc);border:1px solid var(--color-border, #e2e8f0);border-radius:24px;font-size:.9rem;color:var(--color-text-primary, #0f172a);transition:all .2s}.message-form input:focus{outline:none;border-color:var(--color-primary, #3b82f6);background:var(--color-surface, #ffffff)}.message-form input::placeholder{color:var(--color-text-muted, #94a3b8)}.message-form .btn--primary{padding:.75rem 1.5rem;border-radius:24px;font-weight:600}.error-page{text-align:center;padding:3rem}.error-page p{color:var(--color-danger-text, #dc2626);margin-bottom:1rem}.error-toast{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);background:var(--color-danger-bg, #fef2f2);border:1px solid var(--color-danger-border, #fecaca);color:var(--color-danger-text, #dc2626);padding:.75rem 1.5rem;border-radius:8px;font-size:.875rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}:root.dark .message--staff .message__bubble{background:var(--color-surface-elevated, #1e293b)}:root.dark .messages-container{background:var(--color-bg, #0f172a)}.status-badge{padding:.35rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.status--inprogress,.status--inwork{background:#dbeafe;color:#1e40af}.status--completed,.status--closed{background:#dcfce7;color:#166534}.status--denied,.status--cancelled{background:#fee2e2;color:#991b1b}@media(max-width:600px){.claim-detail-page{padding:1rem}.message{max-width:85%}.messages-container{max-height:350px}}.new-claim-page{max-width:700px;margin:0 auto;padding:2rem}.claim-form{background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:16px;padding:2rem;transition:background-color .3s ease,border-color .3s ease}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.9rem;font-weight:500;color:var(--color-text-secondary, #334155);margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.875rem 1rem;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:1rem;color:var(--color-text-primary, #1e293b);background:var(--color-bg, #ffffff);transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb, 59, 130, 246),.1)}.form-group textarea{resize:vertical;min-height:120px}.error-message{padding:1rem;background:var(--color-danger-bg, #fef2f2);border:1px solid var(--color-danger-border, #fecaca);border-radius:8px;color:var(--color-danger-text, #dc2626);margin-bottom:1.5rem}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border, #e2e8f0)}.btn--secondary{padding:.75rem 1.5rem;background:var(--color-bg, #f1f5f9);border:1px solid var(--color-border, #e2e8f0);border-radius:8px;color:var(--color-text-secondary, #475569);font-weight:500;cursor:pointer;transition:all .2s}.btn--secondary:hover{background:var(--color-border, #e2e8f0);color:var(--color-text-primary)}.btn--primary{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--color-primary, #3b82f6) 0%,var(--color-primary-dark, #2563eb) 100%);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}@media(max-width:640px){.new-claim-page{padding:1rem}.form-row{grid-template-columns:1fr}}.profile-page{max-width:700px;margin:0 auto;padding:2rem}.profile-form{background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:16px;padding:2rem;transition:background-color .3s ease,border-color .3s ease}.form-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--color-border, #f1f5f9)}.form-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section h2{font-size:1.1rem;font-weight:600;color:var(--color-text-primary, #1e293b);margin:0 0 1.25rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-secondary, #475569);margin-bottom:.5rem}.form-group input{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:1rem;color:var(--color-text-primary, #1e293b);background:var(--color-bg, #ffffff);transition:all .2s}.form-group input:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb, 59, 130, 246),.1)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row--3{grid-template-columns:2fr 1fr 1fr}.message{padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem}.message--success{background:var(--color-success-bg, #dcfce7);border:1px solid var(--color-success-border, #86efac);color:var(--color-success-text, #166534)}.message--error{background:var(--color-danger-bg, #fef2f2);border:1px solid var(--color-danger-border, #fecaca);color:var(--color-danger-text, #dc2626)}:root.dark .message--success{background:#064e3b;border-color:#065f46;color:#34d399}:root.dark .message--error{background:#450a0a;border-color:#7f1d1d;color:#f87171}.form-actions{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border, #e2e8f0)}.btn--primary{padding:.875rem 2rem;background:linear-gradient(135deg,var(--color-primary, #3b82f6) 0%,var(--color-primary-dark, #2563eb) 100%);border:none;border-radius:8px;color:#fff;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px rgba(var(--color-primary-rgb, 59, 130, 246),.35)}@media(max-width:640px){.profile-page{padding:1rem}.form-row,.form-row--3{grid-template-columns:1fr}}.workorders-page{width:100%;min-height:calc(100vh - 72px);padding:2.5rem 3rem;background:var(--color-bg, #ffffff)}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.85rem;font-weight:700;color:#0f172a;margin-bottom:.35rem}.page-header p{color:#64748b;font-size:1rem;margin:0}.filter-tabs{display:flex;gap:.5rem;margin-bottom:2rem}.filter-tab{padding:.65rem 1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:999px;font-size:.9rem;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s}.filter-tab:hover{border-color:#3b82f6;color:#3b82f6}.filter-tab.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.workorders-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:1.5rem}.workorder-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.5rem;transition:all .25s}.workorder-card:hover{box-shadow:0 15px 35px #00000014;border-color:#3b82f6}.workorder-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.workorder-card__info{display:flex;flex-direction:column}.workorder-card__number{font-weight:700;font-size:1.1rem;color:#0f172a}.workorder-card__date{font-size:.8rem;color:#94a3b8;margin-top:.2rem}.workorder-card__property{padding:.75rem 1rem;background:#f8fafc;border-radius:10px;border:1px solid #f1f5f9;font-size:.9rem;color:#475569;margin-bottom:1rem}.workorder-card__details{margin-bottom:1rem}.workorder-card__details p{font-size:.9rem;color:#475569;margin:.35rem 0}.workorder-card__desc{margin-top:.75rem!important;line-height:1.5}.workorder-card__notes{padding:.75rem;background:#fef3c7;border:1px solid #fde68a;border-radius:8px;font-size:.85rem;color:#92400e;margin-bottom:1rem}.workorder-card__actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid #f1f5f9}.btn--success{padding:.6rem 1rem;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:10px;color:#fff;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s}.btn--success:hover:not(:disabled){box-shadow:0 6px 15px #10b98159}.btn--outline{padding:.6rem 1rem;background:transparent;border:1px solid #e2e8f0;border-radius:10px;color:#475569;font-weight:500;font-size:.85rem;cursor:pointer;transition:all .2s}.btn--outline:hover{border-color:#3b82f6;color:#3b82f6}.status-badge{padding:.4rem .9rem;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.status--scheduled{background:#d1fae5;color:#065f46}.status--onhold{background:#fee2e2;color:#991b1b}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:16px;padding:2rem;width:100%;max-width:480px;box-shadow:0 25px 50px #00000040}.modal h3{font-size:1.35rem;margin-bottom:.25rem}.modal__subtitle{font-size:.9rem;color:#64748b;margin-bottom:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.85rem;font-weight:500;color:#475569;margin-bottom:.5rem}.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.95rem;font-family:inherit}.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6}.modal__actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.btn--primary{padding:.75rem 1.25rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;color:#fff;font-weight:600;cursor:pointer}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;border:1px solid #e2e8f0;color:#64748b}.loading{padding:4rem;text-align:center;color:#64748b}@media(max-width:768px){.workorders-page{padding:1.5rem}.workorders-list{grid-template-columns:1fr}.filter-tabs{flex-wrap:wrap}}.ac-page{min-height:100%}.ac-container{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:.75rem}.ac-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.ac-toolbar__filters{display:flex;gap:4px;background:var(--color-surface, #ffffff);padding:3px;border-radius:10px;border:1px solid var(--color-border, #e2e8f0)}.ac-toolbar__right{display:flex;align-items:center;gap:.5rem}.ac-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border:none;background:transparent;color:var(--color-text-secondary, #64748b);font-size:.78rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s;white-space:nowrap}.ac-pill:hover{color:var(--color-text-primary, #0f172a);background:var(--color-bg, #f8fafc)}.ac-pill--active{color:var(--color-primary, #3b82f6);background:var(--color-bg, #f1f5f9);font-weight:600}.ac-pill__count{font-size:.68rem;font-weight:600;padding:1px 5px;border-radius:99px;background:var(--color-bg, #e2e8f0);color:var(--color-text-secondary, #475569)}.ac-pill--active .ac-pill__count{background:#3b82f61f;color:var(--color-primary, #3b82f6)}.ac-search{position:relative;display:flex;align-items:center}.ac-search__icon{position:absolute;left:10px;color:var(--color-text-muted, #94a3b8);pointer-events:none}.ac-search input{padding:7px 30px 7px 32px;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:.8rem;background:var(--color-surface, #fff);color:var(--color-text-primary, #0f172a);width:260px;transition:all .15s}.ac-search input:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f614}.ac-search input::placeholder{color:var(--color-text-muted, #94a3b8)}.ac-search__clear{position:absolute;right:6px;background:none;border:none;color:var(--color-text-muted, #94a3b8);cursor:pointer;font-size:1.1rem;line-height:1;padding:2px 4px}.ac-search__clear:hover{color:var(--color-text-primary, #0f172a)}.ac-btn-new{display:inline-flex;align-items:center;gap:4px;padding:7px 14px;background:linear-gradient(135deg,var(--color-primary, #3b82f6),var(--color-primary-dark, #2563eb));color:#fff;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap}.ac-btn-new:hover{transform:translateY(-1px);box-shadow:0 4px 14px #3b82f64d}.ac-btn-new span{font-size:1rem;font-weight:300}.ac-table-wrap{background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000005}.ac-table{width:100%;border-collapse:collapse;font-size:.82rem}.ac-table thead{background:var(--color-bg, #f8fafc);border-bottom:1px solid var(--color-border, #e2e8f0)}.ac-table th{padding:10px 14px;text-align:left;font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary, #64748b);white-space:nowrap}.ac-table tbody tr{border-bottom:1px solid var(--color-border, #f1f5f9);cursor:pointer;transition:background .1s}.ac-table tbody tr:last-child{border-bottom:none}.ac-table tbody tr:hover{background:#3b82f605}.ac-table td{padding:10px 14px;color:var(--color-text-primary, #0f172a);vertical-align:middle}.ac-col-contract{display:flex;flex-direction:column;gap:1px}.ac-contract-link{color:var(--color-primary, #3b82f6);font-weight:600;font-size:.82rem;text-decoration:none}.ac-contract-link:hover{text-decoration:underline}.ac-plan-name{font-size:.7rem;color:var(--color-text-muted, #94a3b8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.ac-col-property{display:flex;flex-direction:column;gap:1px}.ac-client-name{font-weight:500;font-size:.82rem}.ac-address{font-size:.74rem;color:var(--color-text-secondary, #64748b)}.ac-col-date{white-space:nowrap;color:var(--color-text-secondary, #64748b)!important;font-size:.78rem}.ac-col-right{text-align:right!important}.ac-col-center{text-align:center!important}.ac-col-amount{font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}.ac-status{display:inline-block;padding:2px 8px;border-radius:99px;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.ac-status--active{background:#dcfce7;color:#15803d}.ac-status--draft{background:#fef3c7;color:#b45309}.ac-status--expired{background:#f1f5f9;color:#64748b}.ac-status--pending{background:#e0e7ff;color:#4338ca}.ac-status--cancelled,.ac-status--canceled{background:#fee2e2;color:#dc2626}.ac-actions{display:flex;gap:4px;align-items:center;justify-content:center}.ac-action-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:28px;border:1px solid var(--color-border, #e2e8f0);background:var(--color-surface, #fff);border-radius:6px;cursor:pointer;color:var(--color-text-secondary, #64748b);transition:all .15s;padding:0}.ac-action-btn:hover{background:var(--color-bg, #f1f5f9);color:var(--color-text-primary, #0f172a);border-color:var(--color-text-muted, #94a3b8)}.ac-action-btn--pay{width:auto;padding:0 10px;font-size:.72rem;font-weight:600;color:#16a34a;border-color:#bbf7d0;background:#f0fdf4}.ac-action-btn--pay:hover{background:#dcfce7;border-color:#86efac;color:#15803d}.ac-empty{text-align:center;padding:3rem 1.5rem;color:var(--color-text-secondary, #64748b);background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:12px;box-shadow:0 1px 3px #0000000a}.ac-empty__icon{font-size:2.5rem;margin-bottom:.5rem;opacity:.6}.ac-empty p{margin:0 0 1rem;font-size:.9rem}.ac-btn-new--inline{margin-top:.25rem}.ac-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:3rem;color:var(--color-text-secondary, #64748b);font-size:.85rem}.ac-loading__spinner{width:20px;height:20px;border:2px solid var(--color-border, #e2e8f0);border-top-color:var(--color-primary, #3b82f6);border-radius:50%;animation:ac-spin .6s linear infinite}@keyframes ac-spin{to{transform:rotate(360deg)}}.ac-mobile-list{display:none}@media(max-width:768px){.ac-page{padding:1rem .75rem}.ac-table-wrap{display:none}.ac-mobile-list{display:flex;flex-direction:column;gap:8px}.ac-card{background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:10px;padding:12px 14px;cursor:pointer;transition:box-shadow .15s;box-shadow:0 1px 3px #00000008}.ac-card:active{background:var(--color-bg, #f8fafc)}.ac-card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.ac-card__num{font-weight:600;font-size:.82rem;color:var(--color-primary, #3b82f6)}.ac-card__client{font-weight:500;font-size:.85rem;color:var(--color-text-primary, #0f172a)}.ac-card__addr{font-size:.76rem;color:var(--color-text-secondary, #64748b);margin-bottom:8px}.ac-card__bottom{display:flex;justify-content:space-between;align-items:center;font-size:.76rem;color:var(--color-text-secondary, #64748b);margin-bottom:8px}.ac-card__amount{font-weight:600;color:var(--color-text-primary, #0f172a)}.ac-card__actions{display:flex;gap:6px;padding-top:8px;border-top:1px solid var(--color-border, #f1f5f9)}.ac-card-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:6px 0;font-size:.76rem;font-weight:500;background:var(--color-bg, #f1f5f9);border:none;border-radius:6px;color:var(--color-text-secondary, #475569);cursor:pointer;transition:background .15s}.ac-card-btn:active{background:var(--color-border, #e2e8f0)}.ac-card-btn--pay{background:#f0fdf4;color:#16a34a;font-weight:600}.ac-card-btn--pay:active{background:#dcfce7}.ac-toolbar{flex-direction:column;align-items:stretch}.ac-toolbar__filters{overflow-x:auto;-webkit-overflow-scrolling:touch}.ac-toolbar__right{flex-direction:column;gap:8px}.ac-search input{width:100%}.ac-btn-new{width:100%;justify-content:center;padding:10px}}.ac-modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:ac-fade-in .15s ease}@keyframes ac-fade-in{0%{opacity:0}to{opacity:1}}.ac-modal{background:var(--color-surface, #fff);border-radius:14px;width:100%;max-width:440px;box-shadow:0 20px 60px #00000026;animation:ac-slide-up .2s ease}@keyframes ac-slide-up{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.ac-modal__header{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:16px 20px;border-bottom:1px solid var(--color-border, #e2e8f0)}.ac-modal__header h3{font-size:.95rem;font-weight:600;color:var(--color-text-primary, #0f172a);margin:0}.ac-modal__sub{font-size:.75rem;color:var(--color-text-muted, #94a3b8)}.ac-modal__close{margin-left:auto;background:none;border:none;font-size:1.3rem;color:var(--color-text-muted, #94a3b8);cursor:pointer;padding:0 4px;line-height:1}.ac-modal__close:hover{color:var(--color-text-primary, #0f172a)}.ac-dropzone{margin:16px 20px;padding:28px 20px;border:2px dashed var(--color-border, #d1d5db);border-radius:10px;text-align:center;cursor:pointer;transition:all .15s;background:var(--color-bg, #f8fafc)}.ac-dropzone:hover,.ac-dropzone--active{border-color:var(--color-primary, #3b82f6);background:#3b82f60a}.ac-dropzone--has-file{padding:14px 16px;border-style:solid;border-color:var(--color-border, #e2e8f0)}.ac-dropzone__icon{color:var(--color-text-muted, #94a3b8);margin-bottom:8px}.ac-dropzone__text{font-size:.82rem;color:var(--color-text-secondary, #64748b);margin:0}.ac-dropzone__text span{color:var(--color-primary, #3b82f6);font-weight:600}.ac-dropzone__hint{font-size:.7rem;color:var(--color-text-muted, #94a3b8);margin:6px 0 0}.ac-dropzone__file{display:flex;align-items:center;gap:10px;text-align:left}.ac-dropzone__file-icon{font-size:1.5rem}.ac-dropzone__file-info{flex:1;min-width:0}.ac-dropzone__file-name{display:block;font-size:.82rem;font-weight:500;color:var(--color-text-primary, #0f172a);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ac-dropzone__file-size{font-size:.7rem;color:var(--color-text-muted, #94a3b8)}.ac-dropzone__file-remove{background:none;border:none;font-size:1.2rem;color:var(--color-text-muted, #94a3b8);cursor:pointer;padding:2px 6px}.ac-dropzone__file-remove:hover{color:var(--color-danger, #ef4444)}.ac-upload-result{margin:0 20px;padding:8px 12px;border-radius:8px;font-size:.78rem;font-weight:500}.ac-upload-result--success{background:#f0fdf4;color:#15803d}.ac-upload-result--error{background:#fef2f2;color:#dc2626}.ac-modal__footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--color-border, #e2e8f0)}.ac-modal-btn{padding:7px 16px;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px}.ac-modal-btn--cancel{background:transparent;border:1px solid var(--color-border, #e2e8f0);color:var(--color-text-secondary, #64748b)}.ac-modal-btn--cancel:hover{background:var(--color-bg, #f1f5f9)}.ac-modal-btn--upload{background:linear-gradient(135deg,var(--color-primary, #3b82f6),var(--color-primary-dark, #2563eb));border:none;color:#fff}.ac-modal-btn--upload:hover:not(:disabled){box-shadow:0 4px 12px #3b82f64d}.ac-modal-btn--upload:disabled{opacity:.5;cursor:not-allowed}.ac-loading__spinner--sm{width:14px;height:14px;border-width:2px;border-color:#ffffff4d;border-top-color:#fff}:root.dark .ac-page{background:radial-gradient(ellipse at 20% 0%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(99,102,241,.06) 0%,transparent 50%),var(--color-bg, #0f172a)}:root.dark .ac-table-wrap{box-shadow:0 1px 3px #0003}:root.dark .ac-status--active{background:#064e3b;color:#34d399}:root.dark .ac-status--draft{background:#78350f;color:#fbbf24}:root.dark .ac-status--expired{background:#1e293b;color:#94a3b8}:root.dark .ac-status--pending{background:#312e81;color:#a5b4fc}:root.dark .ac-status--cancelled,:root.dark .ac-status--canceled{background:#450a0a;color:#f87171}:root.dark .ac-action-btn--pay{background:#052e16;border-color:#166534;color:#4ade80}:root.dark .ac-action-btn--pay:hover{background:#064e3b;border-color:#22c55e}:root.dark .ac-card-btn--pay{background:#052e16;color:#4ade80}.invoice-page{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:40px 20px}.invoice-container{background:#fff;border-radius:20px;box-shadow:0 25px 80px #00000040;padding:0;width:100%;max-width:560px;overflow:hidden}.invoice-header{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;padding:32px 40px;text-align:center}.invoice-icon{font-size:56px;margin-bottom:16px;display:block}.invoice-icon.success{background:linear-gradient(135deg,#00b894,#00cec9);width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:36px}.invoice-icon.error{background:linear-gradient(135deg,#e74c3c,#c0392b);width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:36px}.invoice-header h1{font-size:1.75rem;font-weight:700;margin:0 0 8px;letter-spacing:-.5px}.invoice-subtitle{color:#ffffffb3;font-size:.95rem;margin:0}.contract-banner{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:20px 40px;border-bottom:1px solid #e0e0e0}.contract-row{display:flex;justify-content:space-between;align-items:flex-start;padding:6px 0}.contract-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;color:#666;font-weight:600}.contract-value{font-size:.9rem;color:#333;font-weight:500;text-align:right;max-width:65%}.invoice-section{padding:24px 40px;border-bottom:1px solid #eee}.invoice-section h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:#888;margin:0 0 16px;font-weight:600}.line-items{background:#fafafa;border-radius:12px;overflow:hidden}.line-item{display:flex;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #eee}.line-item:last-child{border-bottom:none}.line-item.addon{background:#f5f5f5}.line-item.addon .item-name{color:#666}.item-name{font-size:.95rem;color:#333}.item-price{font-size:.95rem;font-weight:600;color:#333}.payments-list{background:#fafafa;border-radius:12px;overflow:hidden}.payment-row{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #eee}.payment-row:last-child{border-bottom:none}.payment-row.overdue{background:#fff5f5}.payment-date{font-size:.9rem;color:#555}.overdue-badge{display:inline-block;background:#e74c3c;color:#fff;font-size:.65rem;text-transform:uppercase;letter-spacing:.3px;padding:3px 8px;border-radius:4px;margin-right:8px;font-weight:600}.payment-amount{font-size:.95rem;font-weight:600;color:#333}.total-section{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:24px 40px}.total-row{display:flex;justify-content:space-between;align-items:center}.total-label{font-size:1.1rem;font-weight:600;color:#fffc;text-transform:uppercase;letter-spacing:.5px}.total-amount{font-size:1.75rem;font-weight:700;color:#fff}.payment-form{padding:32px 40px}.form-section{margin-bottom:28px}.form-section h3{font-size:.95rem;color:#333;margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid #eee;font-weight:600}.form-group label{display:block;font-size:.8rem;font-weight:600;color:#555;margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}.form-group input{width:100%;padding:14px 16px;font-size:1rem;border:2px solid #e0e0e0;border-radius:10px;transition:all .2s ease;background:#fafafa}.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea26}.form-row .form-group,.form-row.three-col .form-group{flex:1}.form-row .form-group.flex-2{flex:2}.save-card-option{margin:24px 0;padding:16px;background:linear-gradient(135deg,#f0f4ff,#e8f0ff);border-radius:12px;border:1px solid #d0dfff}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer}.checkbox-label input[type=checkbox]{width:20px;height:20px;accent-color:#667eea;cursor:pointer}.checkbox-text{font-size:.95rem;color:#333}.submit-btn{width:100%;padding:18px;font-size:1.15rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 20px #667eea66}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 30px #667eea80}.submit-btn:active{transform:translateY(0)}.submit-btn:disabled{background:#bbb;cursor:not-allowed;box-shadow:none;transform:none}.secure-notice{text-align:center;padding:20px 40px 32px;font-size:.85rem;color:#888}.lock-icon{margin-right:6px}.form-error{background:linear-gradient(135deg,#fff5f5,#ffe8e8);border:1px solid #ffcaca;color:#c00;padding:14px 20px;border-radius:10px;margin:0 40px 20px;text-align:center;font-size:.9rem}.error-message,.success-message{padding:40px;text-align:center}.error-message h2{color:#e74c3c;margin:0 0 16px;font-size:1.5rem}.success-message h2{color:#00b894;margin:0 0 16px;font-size:1.5rem}.error-message p,.success-message p{color:#555;margin:0 0 8px}.error-help,.success-help{color:#888;font-size:.9rem;margin-top:16px}.loading-spinner{padding:60px 40px;text-align:center}.spinner{width:48px;height:48px;border:4px solid #eee;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner p{color:#888;font-size:.95rem}@media(max-width:600px){.invoice-page{padding:20px 12px}.invoice-container{border-radius:16px}.invoice-header{padding:28px 24px}.invoice-header h1{font-size:1.5rem}.contract-banner,.invoice-section,.total-section,.payment-form,.secure-notice{padding-left:24px;padding-right:24px}.form-error{margin-left:24px;margin-right:24px}.form-row,.form-row.three-col{flex-direction:column;gap:0}.form-row .form-group.flex-2{flex:1}.contract-row{flex-direction:column;gap:4px}.contract-value{text-align:left;max-width:100%}}.new-contract{max-width:1160px;margin:0 auto;padding:1.25rem 1rem}.new-contract .page-header{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border, #e2e8f0)}.new-contract .page-header__top{display:flex;align-items:center;gap:.5rem}.new-contract .page-header__top h1{font-size:1.35rem;font-weight:700;margin:0;color:var(--color-text-primary, #0f172a)}.new-contract .page-header p{font-size:.85rem;color:var(--color-text-secondary, #475569);margin:.15rem 0 0 2.25rem}.back-btn{display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;padding:.3rem;cursor:pointer;color:var(--color-text-secondary, #475569);transition:background .15s}.back-btn:hover{background:var(--color-border, #e2e8f0)}.new-contract__grid{display:grid;grid-template-columns:1fr 320px;gap:1.25rem;align-items:start}.new-contract__sidebar{position:sticky;top:1rem}.new-contract .card{border:1px solid var(--color-border, #e2e8f0);border-radius:var(--radius-lg, 16px);padding:1.15rem 1.25rem;background:var(--color-surface, #ffffff);margin-bottom:1rem;box-shadow:var(--shadow-sm, 0 1px 2px rgba(0, 0, 0, .05))}.new-contract .form-section h3{display:flex;align-items:center;gap:.45rem;font-size:.95rem;font-weight:600;margin:0 0 .85rem;color:var(--color-text-primary, #0f172a)}.new-contract .form-section h3 svg{opacity:.45;flex-shrink:0}.new-contract .form-group{margin-bottom:.6rem}.new-contract .form-group label{display:block;font-size:.8rem;font-weight:500;margin-bottom:.2rem;color:var(--color-text-secondary, #475569)}.new-contract .form-group .required{color:var(--color-danger, #ef4444)}.new-contract .form-group .optional{color:var(--color-text-muted, #94a3b8);font-weight:400;font-size:.75rem}.new-contract .form-group input,.new-contract .form-group select,.new-contract .form-group textarea{width:100%;padding:.45rem .6rem;font-size:.85rem;border-radius:var(--radius-sm, 6px);border:1px solid var(--color-border, #e2e8f0);background:var(--color-surface, #ffffff);color:var(--color-text-primary, #0f172a);font-family:inherit}.new-contract .form-group input:focus,.new-contract .form-group select:focus,.new-contract .form-group textarea:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.new-contract .readonly-field{background:var(--color-bg, #f1f5f9)!important;color:var(--color-text-secondary, #475569)!important;cursor:not-allowed}.coverage-pdf-link{display:inline-block;margin-top:.4rem;font-size:.8rem;color:var(--color-primary, #2563eb);text-decoration:none}.coverage-pdf-link:hover{text-decoration:underline}.new-contract .form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.new-contract .form-row--3col{grid-template-columns:1fr 1fr 1fr}.new-contract .form-subsection{border-top:1px solid var(--color-border, #e2e8f0);padding-top:.75rem;margin-top:.5rem}.new-contract .form-check{display:flex;align-items:center;gap:.5rem}.new-contract .form-check-label{display:flex;align-items:center;gap:.45rem;font-size:.85rem;cursor:pointer;font-weight:500;color:var(--color-text-primary, #0f172a)}.new-contract .form-check-label input[type=checkbox]{width:auto;margin:0;cursor:pointer;accent-color:var(--color-primary, #3b82f6)}.new-contract .form-hint{font-size:.8rem;color:var(--color-text-muted, #94a3b8);margin:-.25rem 0 .75rem}.addons-table{width:100%;border-collapse:collapse;font-size:.85rem}.addons-table th{text-align:left;padding:.4rem .6rem;border-bottom:2px solid var(--color-border, #e2e8f0);font-weight:600;font-size:.8rem;color:var(--color-text-muted, #94a3b8)}.addons-table td{padding:.45rem .6rem;border-bottom:1px solid var(--color-border, #e2e8f0);color:var(--color-text-primary, #0f172a)}.addons-table tbody tr{cursor:pointer;transition:background .1s}.addons-table tbody tr:hover{background:#3b82f60a}.addons-table .addon-row--selected{background:#3b82f60f}.addons-table .addon-row--selected td:first-child{color:var(--color-primary, #3b82f6);font-weight:700}.addons-table .addon-plus{color:var(--color-text-muted, #94a3b8);font-size:1rem}.addons-table .addon-total-row td{border-top:2px solid var(--color-border, #e2e8f0);border-bottom:none;padding-top:.5rem}.new-contract .form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:.5rem 0 1rem}.new-contract .form-actions .btn{padding:.55rem 1.5rem;border-radius:var(--radius-md, 10px);font-size:.85rem;font-weight:600;border:none;cursor:pointer;transition:all .2s}.new-contract .form-actions .btn--primary{background:linear-gradient(135deg,var(--color-primary, #3b82f6) 0%,var(--color-primary-dark, #2563eb) 100%);color:#fff;box-shadow:0 4px 12px #3b82f640}.new-contract .form-actions .btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #3b82f659}.new-contract .form-actions .btn--primary:disabled{opacity:.5;cursor:not-allowed}.new-contract .form-actions .btn--cancel{background:transparent;border:1px solid var(--color-border, #e2e8f0);color:var(--color-text-secondary, #475569)}.new-contract .form-actions .btn--cancel:hover{background:var(--color-border, #e2e8f0);color:var(--color-text-primary, #0f172a)}.pricing-card{background:var(--color-surface, #ffffff)!important;border:1px solid var(--color-border, #e2e8f0)!important}.pricing-card h3{font-size:1rem;font-weight:700;margin:0 0 .75rem;color:var(--color-text-primary, #0f172a)}.pricing-card .summary-section{margin-bottom:.5rem}.pricing-card .summary-label{font-size:.7rem;text-transform:uppercase;color:var(--color-text-muted, #94a3b8);letter-spacing:.03em}.pricing-card .summary-value{font-size:.85rem;font-weight:500;color:var(--color-text-primary, #0f172a)}.pricing-card .summary-value--small{font-size:.8rem;color:var(--color-text-secondary, #475569)}.pricing-card .summary-divider{height:1px;background:var(--color-border, #e2e8f0);margin:.6rem 0}.pricing-card .pricing-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;padding:.2rem 0;color:var(--color-text-primary, #0f172a)}.pricing-card .pricing-row--total{font-weight:700;font-size:1rem;padding-top:.4rem;border-top:1px solid var(--color-border, #e2e8f0);margin-top:.3rem}.pricing-card .summary-dates{padding:.15rem 0}.pricing-card .summary-date-row{display:flex;justify-content:space-between;font-size:.8rem;padding:.1rem 0;color:var(--color-text-secondary, #475569)}.message-banner{padding:.65rem .85rem;border-radius:var(--radius-md, 10px);margin-bottom:1rem;font-size:.85rem;font-weight:500}.message-banner.success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.message-banner.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}@media(max-width:900px){.new-contract__grid{grid-template-columns:1fr}.new-contract__sidebar{position:static}}@media(max-width:600px){.new-contract .form-row,.new-contract .form-row--3col{grid-template-columns:1fr}}.update-card-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px}.dark .update-card-page{background:linear-gradient(135deg,#1a1a2e,#16213e)}.update-card-container{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;padding:40px;width:100%;max-width:520px}.dark .update-card-container{background:#252836;color:#fff}.update-card-logo{font-size:48px;text-align:center;margin-bottom:20px}.update-card-container h1{text-align:center;font-size:1.5rem;margin-bottom:8px;color:#333}.dark .update-card-container h1{color:#fff}.update-card-subtitle{text-align:center;color:#666;margin-bottom:24px}.dark .update-card-subtitle{color:#a0a0a0}.contract-info-banner{background:#f0f7ff;border:1px solid #d0e3ff;border-radius:8px;padding:12px 16px;margin-bottom:24px;font-size:.9rem;color:#333}.dark .contract-info-banner{background:#1e2235;border-color:#3f4560;color:#ccc}.form-section{margin-bottom:24px}.form-section h3{font-size:1rem;color:#555;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #eee}.dark .form-section h3{color:#aaa;border-bottom-color:#3f4560}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.85rem;font-weight:600;color:#444;margin-bottom:6px}.dark .form-group label{color:#ccc}.form-group input{width:100%;padding:12px 14px;font-size:1rem;border:1px solid #ddd;border-radius:8px;transition:border-color .2s,box-shadow .2s}.dark .form-group input{background:#1e2235;border-color:#3f4560;color:#fff}.form-group input:focus{outline:none;border-color:#0f62fe;box-shadow:0 0 0 3px #0f62fe26}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.form-error{background:#fff0f0;border:1px solid #ffcaca;color:#c00;padding:12px;border-radius:8px;margin-bottom:16px;text-align:center}.dark .form-error{background:#3a1f1f;border-color:#6a3030}.submit-btn{width:100%;padding:14px;font-size:1.1rem;font-weight:600;color:#fff;background:#0f62fe;border:none;border-radius:8px;cursor:pointer;transition:background .2s,transform .1s}.submit-btn:hover{background:#0043ce}.submit-btn:active{transform:scale(.98)}.submit-btn:disabled{background:#aaa;cursor:not-allowed}.secure-notice{text-align:center;font-size:.8rem;color:#888;margin-top:20px}.error-message,.success-message{text-align:center}.error-message h2{color:#c00;margin-bottom:12px}.success-message h2{color:#0a0;margin-bottom:12px}.error-help,.success-help{color:#666;font-size:.9rem;margin-top:16px}.dark .error-help,.dark .success-help{color:#a0a0a0}.loading-spinner{text-align:center;padding:40px;color:#666}.dark .loading-spinner{color:#aaa}@media(max-width:480px){.update-card-container{padding:24px 20px}.form-row{flex-direction:column;gap:0}}*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #3b82f6;--color-primary-dark: #2563eb;--color-primary-rgb: 59, 130, 246;--color-bg: #f1f5f9;--color-surface: #ffffff;--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-text-muted: #94a3b8;--color-border: #e2e8f0;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--header-height: 72px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px}:root.dark{--color-bg: #0f172a;--color-surface: #1e293b;--color-text-primary: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-border: #334155}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background-color .3s ease,color .3s ease}.portal-app{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg)}.portal-nav{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:var(--header-height);background:var(--color-surface);position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #00000014;border-bottom:1px solid var(--color-border);transition:background-color .3s ease,border-color .3s ease}.portal-nav__brand a{font-size:1.35rem;font-weight:700;color:var(--color-text-primary);text-decoration:none;display:flex;align-items:center;gap:.75rem}.portal-nav__logo{height:78px;width:auto;object-fit:contain;image-rendering:high-quality}.portal-nav__links{display:flex;gap:.5rem}.portal-nav__links a{color:var(--color-text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;padding:.6rem 1rem;border-radius:var(--radius-md);transition:all .2s ease}.portal-nav__links a:hover{color:var(--color-text-primary);background:var(--color-border)}.portal-nav__user{display:flex;align-items:center;gap:1rem}.portal-nav__user span{font-size:.9rem;color:var(--color-text-secondary);font-weight:500}.btn--icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--color-border);border-radius:50%;font-size:1rem;cursor:pointer;transition:all .2s}.btn--icon:hover{background:var(--color-border)}.btn--outline{padding:.5rem 1.25rem;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.btn--outline:hover{background:var(--color-border);color:var(--color-text-primary)}.portal-main{flex:1;width:100%;padding:1.5rem;background:radial-gradient(ellipse at 20% 0%,rgba(59,130,246,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(99,102,241,.04) 0%,transparent 50%),var(--color-bg)}.portal-main--full{flex:1}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:1.1rem}.page-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.page-header h1{font-size:1.85rem;font-weight:700;color:var(--color-text-primary);margin-bottom:.35rem;letter-spacing:-.02em}.page-header p{color:var(--color-text-secondary);font-size:1rem;margin:0}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;transition:all .2s ease}.card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.btn--primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border:none;color:#fff;box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px rgba(var(--color-primary-rgb),.4)}.btn--primary:disabled{opacity:.6;cursor:not-allowed}.status-badge{display:inline-flex;align-items:center;padding:.35rem .85rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.status--active{background:#dcfce7;color:#166534}.status--expired{background:#fee2e2;color:#991b1b}.status--pending{background:#fef3c7;color:#92400e}.status--open{background:#dbeafe;color:#1e40af}.status--inprogress{background:#e0e7ff;color:#3730a3}.status--closed{background:#f1f5f9;color:#64748b}.status--complete{background:#dcfce7;color:#166534}.portal-nav__hamburger{display:none;width:40px;height:40px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1.25rem;cursor:pointer;align-items:center;justify-content:center;transition:all .2s}.portal-nav__hamburger:hover{background:var(--color-border)}.portal-mobile-menu{display:none;position:fixed;top:var(--header-height);left:0;right:0;background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:1rem;z-index:99;flex-direction:column;gap:.5rem;box-shadow:var(--shadow-lg);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.portal-mobile-menu a{display:block;padding:.875rem 1rem;color:var(--color-text-primary);text-decoration:none;font-size:1rem;font-weight:500;border-radius:var(--radius-md);transition:background .2s}.portal-mobile-menu a:hover{background:var(--color-border)}.portal-mobile-menu__user{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;margin-top:.5rem;border-top:1px solid var(--color-border);color:var(--color-text-secondary);font-size:.9rem}.portal-mobile-menu .btn--outline{width:100%;margin-top:.5rem;justify-content:center}.portal-nav__role{background:linear-gradient(135deg,var(--color-primary) 0%,#06b6d4 100%);color:#fff;padding:.25rem .75rem;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.portal-nav__switch{font-size:.7rem!important;padding:.2rem .6rem!important;border:1px solid var(--color-border, #e2e8f0)!important;border-radius:999px;background:transparent;color:#fff!important;cursor:pointer;transition:all .2s;text-decoration:none!important}.portal-nav__switch:hover{background:var(--color-primary, #2563eb)!important;color:#fff!important;border-color:var(--color-primary, #2563eb)!important}.portal-nav__switch-mobile{margin-top:.5rem;width:100%}@media(max-width:768px){.portal-nav{padding:0 1rem}.portal-nav__links{display:none}.portal-nav__hide-mobile{display:none!important}.portal-nav__hamburger,.portal-mobile-menu{display:flex}.page-header h1{font-size:1.5rem}.portal-footer{bottom:.5rem;right:.5rem;left:.5rem;justify-content:center}}.portal-footer{position:fixed;bottom:1rem;right:1.5rem;display:flex;align-items:center;gap:.35rem;padding:.3rem .75rem;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #e2e8f0;border-radius:999px;font-size:.6rem;color:#94a3b8;box-shadow:0 2px 10px #0000000d;z-index:50}.portal-footer__brand{display:flex;gap:.25rem;font-weight:700;font-size:.85rem}.brand-warranty{color:#0f172a}.brand-base{background:linear-gradient(135deg,#3b82f6,#06b6d4,#10b981);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 3s ease infinite}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.portal-footer strong{color:#0f172a;font-weight:600}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);border-top:1px solid var(--color-border);padding:.5rem 0;padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0));z-index:100;justify-content:space-around;align-items:center;box-shadow:0 -2px 10px #0000001a}.mobile-bottom-nav__item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .75rem;text-decoration:none;color:var(--color-text-secondary);font-size:.65rem;font-weight:500;background:transparent;border:none;cursor:pointer;transition:all .2s ease;min-width:56px}.mobile-bottom-nav__item:hover,.mobile-bottom-nav__item:active{color:var(--color-primary)}.mobile-bottom-nav__icon{font-size:1.35rem;margin-bottom:.2rem;line-height:1}.mobile-bottom-nav__label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60px}.mobile-bottom-nav__logout{color:var(--color-danger)}.mobile-bottom-nav__logout:hover{color:#dc2626}@media(max-width:768px){.mobile-bottom-nav{display:flex}.portal-footer{display:none}.portal-main{padding-bottom:80px}}
