@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand-primary:#0056d2;--brand-secondary:#00b4d8;--brand-accent:#48cae4;--bg-base:#f0f4ff;--bg-card:#fff;--bg-card-hover:#f7f9ff;--text-primary:#0d1b2a;--text-secondary:#4a5568;--text-muted:#a0aec0;--border:#e2e8f0;--success:#38a169;--warning:#d69e2e;--danger:#e53e3e;--info:#3182ce;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 16px #0056d21a;--shadow-lg:0 8px 32px #0056d224;--transition:.2s cubic-bezier(.4,0,.2,1);--font:"Inter", system-ui, sans-serif}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;line-height:1.5}.portal-layout{flex-direction:column;min-height:100vh;display:flex}.portal-header{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:50;height:60px;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:0 1.5rem;display:flex;position:sticky;top:0}.portal-header .logo{color:var(--brand-primary);align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;display:flex}.portal-main{flex:1;width:100%;max-width:640px;margin:0 auto;padding:1.5rem 1rem 3rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition);padding:1.5rem}.card:hover{box-shadow:var(--shadow-md)}.card-sm{border-radius:var(--radius-md);padding:1rem 1.25rem}.btn{font-family:var(--font);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.4rem;padding:.65rem 1.4rem;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--brand-primary);color:#fff}.btn-primary:hover:not(:disabled){background:#0046b8;transform:translateY(-1px);box-shadow:0 4px 12px #0056d259}.btn-ghost{color:var(--brand-primary);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-base)}.btn-full{width:100%}.btn-lg{border-radius:var(--radius-md);padding:.85rem 1.75rem;font-size:1rem}.field{flex-direction:column;gap:.35rem;margin-bottom:1rem;display:flex}.field label{color:var(--text-secondary);letter-spacing:.02em;text-transform:uppercase;font-size:.82rem;font-weight:600}.field input{font-family:var(--font);border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-base);color:var(--text-primary);transition:border-color var(--transition), box-shadow var(--transition);outline:none;width:100%;padding:.7rem 1rem;font-size:1rem}.field input:focus{border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 3px #0056d21f}.status-badge{border-radius:999px;align-items:center;gap:.3rem;padding:.25rem .65rem;font-size:.78rem;font-weight:600;display:inline-flex}.status-solicitacao_recebida{color:#2b6cb0;background:#ebf4ff}.status-encaminhada_logistica{color:#6b46c1;background:#faf5ff}.status-aguardando_agendamento{color:#975a16;background:ivory}.status-agendada{color:#276749;background:#f0fff4}.status-tecnico_deslocamento{color:#744210;background:#fefcbf}.status-atendimento_andamento{color:#2c7a7b;background:#e6fffa}.status-concluida{color:#22543d;background:#f0fff4}.status-cancelada{color:#9b2c2c;background:#fff5f5}.timeline{padding-left:1.5rem;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--brand-primary), var(--border));width:2px;position:absolute;top:12px;bottom:12px;left:10px}.timeline-item{padding:0 0 1.25rem 1rem;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{background:var(--brand-primary);border:2.5px solid var(--bg-card);width:18px;height:18px;box-shadow:0 0 0 2px var(--brand-primary);border-radius:50%;position:absolute;top:4px;left:-1.5rem}.timeline-dot.active{background:var(--brand-secondary);animation:2s infinite pulse;box-shadow:0 0 0 3px #00b4d84d}.timeline-dot.done{background:var(--success);box-shadow:0 0 0 2px var(--success)}.timeline-dot.canceled{background:var(--danger);box-shadow:0 0 0 2px var(--danger)}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #00b4d84d}50%{box-shadow:0 0 0 6px #00b4d81a}}.timeline-label{color:var(--text-primary);font-size:.88rem;font-weight:600}.timeline-time{color:var(--text-muted);margin-top:.1rem;font-size:.75rem}.stars{gap:.4rem;display:flex}.star{cursor:pointer;color:var(--border);transition:color var(--transition), transform var(--transition);font-size:2rem;line-height:1}.star.selected,.star:hover{color:#ecc94b;transform:scale(1.15)}.page-title{color:var(--text-primary);margin-bottom:.25rem;font-size:1.3rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.88rem}.divider{background:var(--border);height:1px;margin:1.25rem 0}.alert{border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.88rem;font-weight:500}.alert-error{color:var(--danger);background:#fff5f5;border:1px solid #fed7d7}.alert-success{color:var(--success);background:#f0fff4;border:1px solid #c6f6d5}.alert-info{color:var(--info);background:#ebf8ff;border:1px solid #bee3f8}.spinner{border:3px solid var(--border);border-top-color:var(--brand-primary);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.center{flex-direction:column;justify-content:center;align-items:center;gap:.75rem;display:flex}.text-muted{color:var(--text-muted)}.text-sm{font-size:.85rem}.text-xs{font-size:.78rem}.font-medium{font-weight:500}.font-bold{font-weight:700}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.gap-2{gap:.5rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-col{flex-direction:column}.w-full{width:100%}.login-page{background:linear-gradient(135deg,#ebf4ff 0%,#f0f4ff 50%,#e6fffa 100%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-box{background:var(--bg-card);border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:2.5rem 2rem}.login-logo{text-align:center;margin-bottom:2rem}.login-logo h1{color:var(--brand-primary);margin-top:.5rem;font-size:1.4rem;font-weight:800}.login-logo p{color:var(--text-muted);margin-top:.2rem;font-size:.85rem}.contrato-item{border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);background:var(--bg-card);justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:1rem 1.25rem;display:flex}.contrato-item:hover{border-color:var(--brand-primary);background:var(--bg-card-hover);transform:translate(2px)}.os-item{border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);background:var(--bg-card);color:inherit;flex-direction:column;gap:.5rem;margin-bottom:.75rem;padding:1.1rem 1.25rem;text-decoration:none;display:flex}.os-item:hover{border-color:var(--brand-primary);background:var(--bg-card-hover);box-shadow:var(--shadow-md)}@media (width<=480px){.portal-main{padding:1rem .75rem 2.5rem}.login-box{padding:2rem 1.25rem}.card{padding:1.25rem}}
