@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{color-scheme:dark;--brand: #dc2626;--brand-hover: #b91c1c;--brand-dim: rgba(220, 38, 38, .1);--brand-glow: rgba(220, 38, 38, .18);--bg: #0d1117;--surface: #161b22;--card: #1c2128;--card-hover: #21262d;--overlay: rgba(0, 0, 0, .72);--border: rgba(240, 246, 252, .07);--border-m: rgba(240, 246, 252, .12);--border-s: rgba(240, 246, 252, .18);--border-focus: rgba(220, 38, 38, .45);--text: #e6edf3;--text-soft: #c9d1d9;--text-muted: #8b949e;--text-subtle: #484f58;--green: #3fb950;--green-bg: rgba(63, 185, 80, .1);--yellow: #d29922;--yellow-bg: rgba(210, 153, 34, .1);--red: #f85149;--red-bg: rgba(248, 81, 73, .1);--blue: #58a6ff;--blue-bg: rgba(88, 166, 255, .1);--gray: #8b949e;--gray-bg: rgba(139, 148, 158, .1);--input-bg: rgba(22, 27, 34, .8);--input-bg-hover: rgba(33, 38, 45, .9);--sidebar-w: 240px;--r-xs: 4px;--r-sm: 6px;--r: 8px;--r-md: 10px;--r-lg: 12px;--r-xl: 16px;--r-2xl: 20px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,select,textarea{font:inherit}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-m);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-s)}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;overflow-y:auto;z-index:100;flex-shrink:0}.sidebar-brand{padding:18px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:11px;flex-shrink:0}.brand-icon{width:34px;height:34px;background:var(--brand);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;flex-shrink:0;box-shadow:0 2px 8px var(--brand-glow)}.brand-text strong{display:block;font-size:13px;font-weight:700;color:var(--text);line-height:1.2}.brand-text span{display:block;font-size:11px;color:var(--text-muted);margin-top:1px}.sidebar-nav{padding:10px 8px;flex:1}.nav-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);padding:10px 8px 4px}.nav-item{display:flex;align-items:center;gap:9px;width:100%;padding:8px 10px;margin-bottom:1px;border-radius:var(--r);border:none;background:transparent;color:var(--text-muted);cursor:pointer;text-align:left;font-size:13px;font-weight:500;transition:background .12s,color .12s}.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.8}.nav-item:hover{background:#ffffff0d;color:var(--text-soft)}.nav-item.active{background:var(--brand-dim);color:var(--text)}.nav-item.active svg{color:var(--brand);opacity:1}.sidebar-footer{padding:12px 8px;border-top:1px solid var(--border);flex-shrink:0}.user-pill{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--r);background:#ffffff08;border:1px solid var(--border)}.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--brand-dim);border:1.5px solid var(--brand-glow);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--brand);flex-shrink:0}.user-info{flex:1;min-width:0;overflow:hidden}.user-info strong{display:block;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info span{display:block;font-size:10.5px;color:var(--text-muted)}.logout-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--r-sm);display:flex;transition:color .12s,background .12s}.logout-btn:hover{color:var(--red);background:var(--red-bg)}.logout-btn svg{width:14px;height:14px}.main-content{margin-left:var(--sidebar-w);flex:1;padding:28px 32px;max-width:calc(100vw - var(--sidebar-w));min-height:100vh}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.page-title{font-size:20px;font-weight:700;color:var(--text)}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:3px}.page-header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);padding:20px}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);padding:18px 20px;display:flex;flex-direction:column;gap:6px;transition:border-color .15s,background .15s}.stat-card:hover{border-color:var(--border-m);background:var(--card-hover)}.stat-label{font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:26px;font-weight:700;color:var(--text);line-height:1.1}.stat-value.danger{color:var(--red)}.stat-hint{font-size:11.5px;color:var(--text-muted);display:flex;align-items:center;gap:4px}.stat-hint.up{color:var(--green)}.stat-hint.down{color:var(--red)}.section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.section-title{font-size:14px;font-weight:600;color:var(--text)}.table-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--border)}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:#ffffff04;border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:12px 14px;font-size:13.5px;color:var(--text-soft);border-bottom:1px solid var(--border);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr{transition:background .1s}.table tbody tr:hover td{background:#ffffff05}.table td.fw{color:var(--text);font-weight:500}.table td.mono{font-variant-numeric:tabular-nums;font-size:13px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge-aberto{background:var(--yellow-bg);color:var(--yellow)}.badge-pago{background:var(--green-bg);color:var(--green)}.badge-vencido{background:var(--red-bg);color:var(--red)}.badge-rascunho{background:var(--gray-bg);color:var(--gray)}.badge-ativo{background:var(--green-bg);color:var(--green)}.badge-inativo{background:var(--gray-bg);color:var(--gray)}.badge-andamento{background:var(--blue-bg);color:var(--blue)}.badge-concluida{background:var(--green-bg);color:var(--green)}.badge-pausada{background:var(--yellow-bg);color:var(--yellow)}.badge-brand{background:var(--brand-dim);color:var(--brand)}.badge-info{background:var(--blue-bg);color:var(--blue)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid .span-2{grid-column:1 / -1}.field{display:flex;flex-direction:column;gap:5px}.field label{font-size:11.5px;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em}.field input,.field select,.field textarea{width:100%;background:var(--input-bg);border:1px solid var(--border-m);border-radius:var(--r);color:var(--text);padding:8px 11px;font-size:13.5px;transition:border-color .15s,box-shadow .15s,background .15s}.field input::placeholder{color:var(--text-subtle)}.field input:hover,.field select:hover{border-color:var(--border-s)}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--brand-dim);background:var(--input-bg-hover)}.field select{appearance:none;cursor:pointer}select option{background:var(--card);color:var(--text)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border-radius:var(--r);border:none;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.btn svg{width:14px;height:14px;flex-shrink:0}.btn-primary{background:var(--brand);color:#fff;box-shadow:0 1px 3px #0000004d}.btn-primary:hover{background:var(--brand-hover);transform:translateY(-1px);box-shadow:0 4px 12px var(--brand-glow)}.btn-secondary{background:#ffffff0d;border:1px solid var(--border-m);color:var(--text-soft)}.btn-secondary:hover{background:#ffffff17;color:var(--text);border-color:var(--border-s)}.btn-ghost{background:none;border:none;color:var(--text-muted);padding:6px 8px}.btn-ghost:hover{color:var(--text);background:#ffffff0f}.btn-danger{background:var(--red-bg);border:1px solid rgba(248,81,73,.25);color:var(--red)}.btn-danger:hover{background:#f851492e}.btn-sm{padding:5px 11px;font-size:12px}.btn-xs{padding:3px 9px;font-size:11.5px}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}.pill-group{display:flex;flex-wrap:wrap;gap:7px}.pill{padding:5px 13px;border-radius:999px;border:1px solid var(--border-m);background:transparent;color:var(--text-muted);font-size:12.5px;cursor:pointer;transition:all .12s}.pill:hover{border-color:var(--border-s);color:var(--text-soft)}.pill.active{background:var(--brand-dim);border-color:#dc26264d;color:var(--text)}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}.input-icon-wrap{position:relative;display:flex;align-items:center}.input-icon-wrap input{padding-left:34px;min-width:200px}.input-icon{position:absolute;left:10px;color:var(--text-muted);pointer-events:none}.input-icon svg{width:14px;height:14px}.action-row{display:flex;gap:9px;flex-wrap:wrap;align-items:center}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.progress-track{background:#ffffff12;border-radius:999px;height:7px;overflow:hidden}.progress-fill{height:100%;border-radius:999px;transition:width .4s ease}.progress-fill.red{background:linear-gradient(90deg,var(--brand),#ff6b6b)}.progress-fill.blue{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.progress-fill.green{background:linear-gradient(90deg,#16a34a,#4ade80)}.msg{padding:9px 14px;border-radius:var(--r);font-size:13px;font-weight:500;margin-top:10px}.msg-success{background:var(--green-bg);color:var(--green);border:1px solid rgba(63,185,80,.2)}.msg-error{background:var(--red-bg);color:var(--red);border:1px solid rgba(248,81,73,.2)}.msg-info{background:var(--gray-bg);color:var(--text-soft);border:1px solid var(--border-m)}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state svg{width:32px;height:32px;opacity:.35;margin-bottom:10px}.empty-state p{font-size:13px;margin-top:6px}.divider{border:none;border-top:1px solid var(--border);margin:18px 0}.modal-overlay{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .15s ease}.modal{background:var(--card);border:1px solid var(--border-m);border-radius:var(--r-2xl);padding:26px;width:100%;max-width:580px;max-height:88vh;overflow-y:auto;box-shadow:0 24px 64px #0009;animation:slideUp .18s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.modal-title{font-size:16px;font-weight:700}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.obra-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);padding:18px;display:flex;flex-direction:column;gap:12px;transition:border-color .15s,background .15s}.obra-card:hover{border-color:var(--border-m);background:var(--card-hover)}.obra-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.obra-card-head h3{font-size:14.5px;font-weight:600}.obra-meta{font-size:12px;color:var(--text-muted)}.obra-progress-label{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted);margin-bottom:5px}.obra-actions{display:flex;gap:6px;padding-top:6px;border-top:1px solid var(--border)}.index-list{display:flex;flex-direction:column;gap:8px}.index-item{display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border-radius:var(--r);border:1px solid var(--border);background:#ffffff05}.index-item-name{font-size:13.5px;font-weight:500}.index-item-val{font-size:16px;font-weight:700;color:var(--brand)}.index-item-edit{display:flex;align-items:center;gap:7px}.index-item-edit input{width:80px}.chart-container{width:100%;height:240px}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:radial-gradient(ellipse at 50% -10%,rgba(220,38,38,.14) 0%,transparent 55%)}.login-card{width:100%;max-width:400px;background:var(--card);border:1px solid var(--border-m);border-radius:var(--r-2xl);padding:36px;box-shadow:0 24px 64px #00000080}.login-logo{width:46px;height:46px;background:var(--brand);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;color:#fff;margin-bottom:20px;box-shadow:0 4px 16px var(--brand-glow)}.login-title{font-size:22px;font-weight:700;margin-bottom:6px}.login-sub{color:var(--text-muted);font-size:13px;margin-bottom:26px}.login-form{display:flex;flex-direction:column;gap:14px}@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0;max-width:100vw;padding:20px 16px}.stats-grid{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}.page-header{flex-direction:column}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}@keyframes modal-in{0%{opacity:0;transform:scale(.94) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes toast-in{0%{opacity:0;transform:translate(calc(100% + 24px))}to{opacity:1;transform:translate(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(calc(100% + 24px))}}.toast{display:flex;align-items:center;gap:11px;padding:13px 16px;border-radius:var(--r-lg);font-size:13.5px;font-weight:500;color:var(--text);min-width:280px;max-width:400px;background:var(--card);border:1px solid var(--border-m);border-left-width:3px;box-shadow:0 8px 28px #0000008c}.toast-in{animation:toast-in .28s cubic-bezier(.22,1,.36,1) forwards}.toast-out{animation:toast-out .24s ease-in forwards}.toast-success{border-left-color:var(--green)}.toast-error{border-left-color:var(--red)}.toast-info{border-left-color:var(--blue)}.toast-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:3px;border-radius:4px;display:flex;align-items:center;opacity:.6;transition:opacity .15s;flex-shrink:0}.toast-close:hover{opacity:1}
