:root{--cereja:#e50145;--laranja:#f15a22;--amarelo:#efd600;--verde:#0c893e;--roxo:#6b4e9e;--azul:#2563eb;--fundo:#fff8f2;--cartao:#fff;--texto:#2b2b2b;--suave:#7a7a7a;--borda:#f0e4d8}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--fundo);color:var(--texto);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:240px;background:var(--cartao);border-right:1px solid var(--borda);display:flex;flex-direction:column;padding:20px 0;flex-shrink:0;overflow-y:auto}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 20px 20px;border-bottom:1px solid var(--borda);margin-bottom:16px}.role-card{margin:0 16px 16px;padding:14px;border-radius:10px;background:var(--fundo);border:1px solid var(--borda)}.role-card-title{display:flex;align-items:center;gap:6px;font-size:.78rem;font-weight:800;color:var(--verde);margin-bottom:6px}.role-card-desc{font-size:.72rem;color:var(--suave);line-height:1.4;margin-bottom:10px}.role-select{width:100%;padding:8px 10px;border-radius:8px;border:1.5px solid var(--borda);font-size:.85rem;font-weight:700;background:#fff;color:var(--texto);outline:none}.role-select:focus{border-color:var(--cereja)}.section-label{padding:0 20px;font-size:.68rem;font-weight:800;color:var(--suave);text-transform:uppercase;letter-spacing:.08em;margin:10px 0 6px}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:0 12px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;border:none;background:transparent;color:var(--suave);font-size:.9rem;font-weight:500;cursor:pointer;width:100%;text-align:left;transition:all .15s}.nav-item:hover{background:var(--fundo);color:var(--texto)}.nav-item.active{background:#fde8ef;color:var(--cereja);font-weight:700}.sidebar-user{margin-top:auto;padding:12px 16px;border-top:1px solid var(--borda);gap:10px}.sidebar-user,.user-avatar{display:flex;align-items:center}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--cereja);color:#fff;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.btn-logout{background:none;border:none;cursor:pointer;color:var(--suave);padding:4px;border-radius:4px;display:flex;align-items:center}.btn-logout:hover{color:var(--cereja)}.main-content{flex:1 1;overflow-y:auto}.login-page{display:flex;justify-content:center;align-items:center;height:100vh;background:var(--fundo)}.login-card{background:var(--cartao);border-radius:16px;padding:48px 40px;text-align:center;box-shadow:0 4px 32px rgba(229,1,69,.1);max-width:400px;width:90%}.login-logo{width:56px;height:56px;background:var(--cereja);border-radius:12px;color:#fff;font-size:1.4rem;font-weight:900;margin:0 auto 24px}.btn-google,.login-logo{display:flex;align-items:center;justify-content:center}.btn-google{gap:10px;background:var(--cartao);border:2px solid var(--borda);border-radius:999px;padding:13px 20px;font-size:.95rem;font-weight:600;cursor:pointer;width:100%;color:var(--texto);transition:all .15s}.btn-google:hover{border-color:var(--cereja);color:var(--cereja)}.page{padding:32px;max-width:1400px}.page-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-title{font-size:1.6rem;font-weight:900;color:var(--texto)}.page-subtitle{color:var(--suave);margin-top:4px;font-size:.9rem}.kpi-grid-5{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:16px;gap:16px;margin-bottom:20px}.kpi-solid{border-radius:12px;padding:18px 20px;color:#fff;display:flex;flex-direction:column;gap:6px;min-height:90px;justify-content:center}.kpi-solid .kpi-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;opacity:.92}.kpi-solid .kpi-value{font-size:2rem;font-weight:900;line-height:1}.kpi-yellow{background:var(--amarelo);color:#3a2f00}.kpi-purple{background:var(--roxo)}.kpi-green{background:var(--verde)}.kpi-blue{background:var(--azul)}.kpi-red{background:var(--cereja)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:16px;gap:16px;margin-bottom:24px}.kpi-card{background:var(--cartao);border-radius:12px;padding:18px 20px;border:1px solid var(--borda)}.kpi-card-label{font-size:.72rem;font-weight:700;color:var(--suave);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:6px}.kpi-card-value{font-size:1.8rem;font-weight:900;line-height:1;display:block}.kpi-card-sub{font-size:.78rem;color:var(--suave);margin-top:6px}.toolbar{display:flex;gap:10px;margin-bottom:16px;align-items:flex-end;flex-wrap:wrap}.filter-field{display:flex;flex-direction:column;gap:4px}.filter-field label{font-size:.7rem;font-weight:700;color:var(--suave);text-transform:uppercase;letter-spacing:.05em}.search-input{flex:1 1;min-width:200px;padding:9px 14px;border:1.5px solid var(--borda);border-radius:8px;font-size:.9rem;outline:none;background:var(--cartao)}.date-input:focus,.search-input:focus,.select-input:focus{border-color:var(--cereja)}.date-input,.select-input{padding:9px 12px;border:1.5px solid var(--borda);border-radius:8px;font-size:.88rem;outline:none;background:var(--cartao)}.card{background:var(--cartao);border-radius:12px;border:1px solid var(--borda);overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--borda)}.card-header h3{font-size:1rem;font-weight:800}.table-card{background:var(--cartao);border-radius:12px;border:1px solid var(--borda);overflow:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;font-size:.7rem;font-weight:700;color:var(--suave);text-transform:uppercase;letter-spacing:.05em;background:#fafafa;border-bottom:1px solid var(--borda)}.data-table td,.data-table th{padding:12px 14px;white-space:nowrap}.data-table td{border-bottom:1px solid #f9f4f0;font-size:.87rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#fffaf7}.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:700;white-space:nowrap}.badge-yellow{background:#fdf6cf;color:#8a7600}.badge-purple{background:#ece6f6;color:var(--roxo)}.badge-orange{background:#fef0ea;color:var(--laranja)}.badge-green{background:#e6f4ec;color:var(--verde)}.badge-red{background:#fde8ef;color:var(--cereja)}.badge-gray{background:#f0f0f0;color:var(--suave)}.btn-primary{background:var(--cereja);color:#fff;border:none;border-radius:999px;padding:10px 20px;font-weight:700;cursor:pointer;font-size:.9rem;transition:opacity .15s;white-space:nowrap}.btn-primary:hover:not(:disabled){opacity:.88}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-outline{background:transparent;color:var(--texto);border:1.5px solid var(--borda);border-radius:999px;padding:9px 18px;font-weight:600;cursor:pointer;font-size:.9rem;white-space:nowrap;transition:all .15s}.btn-outline:hover{border-color:var(--cereja);color:var(--cereja)}.btn-outline.small,.btn-primary.small{padding:7px 14px;font-size:.82rem}.action-btn{padding:5px 12px;border-radius:6px;border:none;cursor:pointer;font-size:.78rem;font-weight:700;transition:opacity .15s;margin-left:4px}.action-btn:hover{opacity:.75}.btn-green{background:#e6f4ec;color:var(--verde)}.btn-orange{background:#fef0ea;color:var(--laranja)}.btn-cherry{background:#fde8ef;color:var(--cereja)}.btn-ghost{background:#f5f5f5;color:var(--suave)}.btn-danger{background:#fff0f3;color:var(--cereja)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.modal-box{background:var(--cartao);border-radius:16px;max-width:520px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.15);max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--borda)}.modal-header h3{font-size:1.05rem;font-weight:700}.btn-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--suave);line-height:1;padding:0 4px}.modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-footer{padding:16px 24px;border-top:1px solid var(--borda);display:flex;justify-content:flex-end;gap:10px}.modal-danger-text{font-size:.9rem;color:var(--texto);line-height:1.5}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.82rem;font-weight:600;color:var(--texto)}.form-input,.form-select,.form-textarea{padding:9px 12px;border:1.5px solid var(--borda);border-radius:8px;font-size:.9rem;outline:none;width:100%;background:#fff;font-family:inherit}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--cereja)}.form-textarea{resize:vertical;min-height:70px}.checkbox-row{display:flex;align-items:center;gap:8px}.checkbox-row label{font-size:.85rem;font-weight:600;color:var(--texto)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid #f9f4f0;gap:16px}.detail-row:last-child{border-bottom:none}.detail-label{font-size:.83rem;color:var(--suave);font-weight:500;white-space:nowrap}.detail-value{font-size:.83rem;font-weight:700;text-align:right}.empty-state{text-align:center;padding:40px;color:var(--suave);font-style:italic}@media (max-width:1100px){.kpi-grid-5{grid-template-columns:repeat(3,1fr)}.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.kpi-grid-5{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}.page{padding:16px}.sidebar{width:64px}.nav-item span,.role-card,.section-label,.sidebar-logo span,.sidebar-user .user-info{display:none}}