*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--dark: #1a1f2e;--dark-2: #232838;--steel: #2c3347;--steel-2: #3a4260;--orange: #e8620a;--orange-h: #f07d2e;--orange-dim: rgba(232,98,10,.12);--gold: #c89a3c;--sand: #f0ede8;--sand-2: #e8e4de;--white: #ffffff;--muted: #8a8d96;--border: rgba(0,0,0,.08);--green: #2ecc71;--red: #e74c3c;--teal: #00897b;--sidebar-w: 240px;--topbar-h: 58px;--radius: 10px;--radius-sm: 6px;--shadow-sm: 0 2px 8px rgba(0,0,0,.06);--shadow-md: 0 4px 16px rgba(0,0,0,.1);--font: "Barlow", sans-serif;--font-cond: "Barlow Condensed", sans-serif;--transition: .18s ease}html,body,#root{height:100%}body{font-family:var(--font);background:var(--sand);color:var(--dark);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--sand-2);border-radius:99px}.app-root{display:flex;flex-direction:column;height:100vh}.topbar{height:var(--topbar-h);background:var(--dark);display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:2px solid var(--orange);flex-shrink:0;z-index:100}.logo{display:flex;align-items:center;gap:10px;text-decoration:none}.logo-hex{width:34px;height:34px;background:var(--orange);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-text{font-family:var(--font-cond);font-size:22px;font-weight:800;color:#fff;letter-spacing:1px}.logo-text em{color:var(--orange);font-style:normal}.logo-tagline{font-size:9px;color:var(--muted);letter-spacing:2.5px;text-transform:uppercase}.topbar-right{display:flex;align-items:center;gap:14px}.pwa-badge{display:flex;align-items:center;gap:5px;background:#ffffff12;border:1px solid rgba(255,255,255,.1);color:#aaa;font-size:11px;padding:4px 10px;border-radius:20px}.pwa-badge i{color:var(--orange);font-size:13px}.user-chip{display:flex;align-items:center;gap:8px;color:#ccc;font-size:13px;cursor:pointer}.avatar{width:32px;height:32px;border-radius:50%;background:var(--steel);border:2px solid var(--orange);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;color:var(--orange);flex-shrink:0}.hamburger{display:none;background:none;border:none;color:#fff;font-size:22px;cursor:pointer;padding:4px}.app-body{display:flex;flex:1;min-height:0}.sidebar{width:var(--sidebar-w);background:var(--dark);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;border-right:1px solid rgba(255,255,255,.04);transition:transform var(--transition)}.nav-section{padding:18px 0 4px}.nav-label{font-size:9px;font-weight:700;color:var(--muted);letter-spacing:2.5px;text-transform:uppercase;padding:0 18px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 18px;color:#9aa0b0;font-size:13.5px;cursor:pointer;border-left:3px solid transparent;transition:all var(--transition);text-decoration:none;-webkit-user-select:none;user-select:none}.nav-item:hover{color:#fff;background:#ffffff0a}.nav-item.active{color:#fff;background:var(--orange-dim);border-left-color:var(--orange)}.nav-item i{font-size:18px;flex-shrink:0}.nav-badge{margin-left:auto;background:var(--orange);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px}.sidebar-footer{margin-top:auto;padding:14px 18px;border-top:1px solid rgba(255,255,255,.05);font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}.main-content{flex:1;overflow-y:auto;min-height:0}.page{padding:26px;max-width:1400px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-title{font-family:var(--font-cond);font-size:28px;font-weight:800;color:var(--dark);letter-spacing:.5px;line-height:1}.page-subtitle{font-size:13px;color:var(--muted);margin-top:4px}.header-actions{display:flex;gap:8px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all var(--transition);white-space:nowrap}.btn-primary{background:var(--orange);color:#fff}.btn-primary:hover{background:var(--orange-h)}.btn-secondary{background:var(--white);color:var(--dark);border:1px solid var(--border)}.btn-secondary:hover{background:var(--sand)}.btn-danger{background:var(--red);color:#fff}.btn i{font-size:16px}.card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.card-pad{padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-family:var(--font-cond);font-size:15px;font-weight:700;letter-spacing:.3px}.card-sub{font-size:11px;color:var(--muted);margin-top:2px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}.kpi-card{background:var(--white);border-radius:var(--radius);padding:16px 18px;border-left:4px solid var(--orange);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.kpi-card.green{border-left-color:var(--green)}.kpi-card.red{border-left-color:var(--red)}.kpi-card.gold{border-left-color:var(--gold)}.kpi-card.teal{border-left-color:var(--teal)}.kpi-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;font-weight:700;margin-bottom:6px}.kpi-value{font-family:var(--font-cond);font-size:24px;font-weight:800;color:var(--dark);line-height:1;margin-bottom:5px}.kpi-change{font-size:11px;color:var(--green);display:flex;align-items:center;gap:3px}.kpi-change.neg{color:var(--red)}.kpi-change.neutral{color:var(--muted)}.kpi-bg-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:36px;color:#0000000a}.obras-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:22px}.obra-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition);box-shadow:var(--shadow-sm)}.obra-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.obra-card-header{background:var(--dark);padding:13px 15px;display:flex;justify-content:space-between;align-items:center}.obra-card-header.ativo{background:#1e3a5f}.obra-card-header.concluida{background:#1a3a2a}.obra-card-header.plan{background:#3a2a1a}.obra-card-name{font-family:var(--font-cond);font-size:14px;font-weight:700;color:#fff}.obra-card-body{padding:14px}.obra-client{font-size:11px;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:4px}.obra-progress-row{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-bottom:5px}.obra-progress-row strong{color:var(--dark)}.progress-bar{height:5px;background:var(--sand);border-radius:99px;overflow:hidden;margin-bottom:12px}.progress-fill{height:100%;border-radius:99px;background:var(--orange);transition:width .6s ease}.progress-fill.green{background:var(--green)}.fin-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.fin-item{text-align:center}.fin-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:700}.fin-val{font-family:var(--font-cond);font-size:15px;font-weight:700}.fin-val.receita{color:var(--green)}.fin-val.despesa{color:var(--red)}.fin-val.contrato{color:var(--gold)}.status-badge{font-size:9px;font-weight:700;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.8px;white-space:nowrap}.badge-ativo{background:#2ecc7133;color:#2ecc71}.badge-concluida{background:#ffffff26;color:#ccc}.badge-plan{background:#e8620a40;color:var(--orange-h)}.badge-cancelada{background:#e74c3c33;color:var(--red)}.cat-badge{font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;letter-spacing:.3px;white-space:nowrap;display:inline-block}.cat-insumo{background:#e8f4fd;color:#1565c0}.cat-material{background:#e8f5e9;color:#2e7d32}.cat-mao_obra{background:#fff3e0;color:#e65100}.cat-consumo{background:#f3e5f5;color:#6a1b9a}.cat-aluguel_eq{background:#e0f2f1;color:#00695c}.data-table{width:100%;border-collapse:collapse;font-size:12.5px}.data-table th{background:var(--sand);color:var(--muted);text-transform:uppercase;font-size:10px;letter-spacing:1.2px;padding:9px 12px;text-align:left;font-weight:700;white-space:nowrap}.data-table td{padding:10px 12px;border-bottom:1px solid var(--sand);color:var(--dark)}.data-table tbody tr:hover{background:var(--sand)}.data-table tbody tr:last-child td{border-bottom:none}.data-table td.mono{font-family:monospace;font-size:12px}.data-table td.bold{font-weight:700}.data-table td.right{text-align:right}.upload-zone{border:2px dashed #d0ccc7;border-radius:var(--radius);padding:40px 30px;text-align:center;cursor:pointer;background:#faf9f7;transition:border-color var(--transition),background var(--transition)}.upload-zone:hover,.upload-zone.dragging{border-color:var(--orange);background:#e8620a08}.upload-zone-icon{font-size:48px;color:#ccc;margin-bottom:12px}.upload-zone-text{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:5px}.upload-zone-sub{font-size:12px;color:var(--muted)}.ai-chip{display:inline-flex;align-items:center;gap:6px;background:var(--orange-dim);color:var(--orange);font-size:11px;font-weight:700;padding:5px 12px;border-radius:20px;margin-top:12px;letter-spacing:.5px}.form-row{display:grid;gap:14px;margin-bottom:14px}.form-row.cols-2{grid-template-columns:1fr 1fr}.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.form-control{padding:9px 12px;border:1px solid #ddd;border-radius:var(--radius-sm);font-family:var(--font);font-size:13.5px;color:var(--dark);background:var(--white);transition:border-color var(--transition);width:100%}.form-control:focus{outline:none;border-color:var(--orange)}select.form-control{cursor:pointer}.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:22px}.chart-wrap{position:relative}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:999;padding:20px}.modal{background:var(--white);border-radius:var(--radius);width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border);background:var(--dark)}.modal-title{font-family:var(--font-cond);font-size:18px;font-weight:700;color:#fff}.modal-close{background:none;border:none;color:#aaa;font-size:22px;cursor:pointer}.modal-body{padding:22px}.modal-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.processing-card{text-align:center;padding:40px}.spinner{width:48px;height:48px;border:4px solid var(--sand-2);border-top-color:var(--orange);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.processing-text{font-size:14px;font-weight:600;color:var(--dark);margin-bottom:6px}.processing-sub{font-size:12px;color:var(--muted)}.empty-state{text-align:center;padding:60px 20px}.empty-icon{font-size:56px;color:#ccc;margin-bottom:14px}.empty-text{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:6px}.empty-sub{font-size:13px;color:var(--muted)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{display:flex;align-items:center;gap:10px;background:var(--dark);color:#fff;padding:12px 18px;border-radius:var(--radius-sm);font-size:13px;box-shadow:var(--shadow-md);animation:slideIn .2s ease;border-left:4px solid var(--orange)}.toast.success{border-left-color:var(--green)}.toast.error{border-left-color:var(--red)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.section-title{font-family:var(--font-cond);font-size:16px;font-weight:700;color:var(--dark);letter-spacing:.3px;margin-bottom:14px;display:flex;align-items:center;gap:8px}.section-title i{color:var(--orange)}.tab-bar{display:flex;gap:0;background:var(--white);border-radius:var(--radius-sm);padding:3px;border:1px solid var(--border);margin-bottom:20px}.tab-item{flex:1;padding:8px 12px;text-align:center;font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer;border-radius:calc(var(--radius-sm) - 2px);transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:5px;white-space:nowrap}.tab-item i{font-size:15px}.tab-item.active{background:var(--dark);color:#fff}.chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;background:var(--sand);color:var(--muted)}.chip.orange{background:var(--orange-dim);color:var(--orange)}@media (max-width: 900px){.kpi-grid,.obras-grid{grid-template-columns:repeat(2,1fr)}.charts-row{grid-template-columns:1fr}}@media (max-width: 680px){.sidebar{position:fixed;left:0;top:var(--topbar-h);bottom:0;z-index:200;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.hamburger{display:block}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.obras-grid{grid-template-columns:1fr}.page{padding:16px}.form-row.cols-2,.form-row.cols-3{grid-template-columns:1fr}.page-title{font-size:22px}.pwa-badge span{display:none}.data-table{font-size:11px}.data-table th,.data-table td{padding:8px}}@media (max-width: 400px){.kpi-grid{grid-template-columns:1fr}}
