:root{--navy:#001f4d;--navy2:#002b68;--cyan:#16d9ff;--blue:#1877f2;--bg:#f4f8fd;--text:#07264d;--muted:#64748b;--line:#d6e3f3;--green:#00a884;--red:#ef4444;--orange:#f59e0b}*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:linear-gradient(120deg,#f8fbff,#eef5ff);color:var(--text)}a{text-decoration:none;color:inherit}.login-wrap{min-height:100vh;display:grid;grid-template-columns:420px 1fr}.brand-panel{background:radial-gradient(circle at 65% 40%,#0a74b9 0,#062b68 34%,#001b43 70%);color:#fff;padding:34px;position:relative;overflow:hidden}.brand-panel:after{content:"";position:absolute;inset:auto -80px 70px auto;width:260px;height:260px;border:1px solid #24dfff55;transform:rotate(45deg);box-shadow:0 0 60px #16d9ff66}.brand-title{font-size:38px;font-weight:800;line-height:1.08;margin:45px 0 15px}.version{display:inline-block;border:1px solid var(--cyan);color:var(--cyan);border-radius:12px;padding:4px 10px;font-weight:700;font-size:12px}.login-box{display:flex;align-items:center;justify-content:center;padding:40px}.card-login{width:420px;background:#fff;border:1px solid var(--line);border-radius:22px;padding:32px;box-shadow:0 22px 50px #08315e18}.field{margin:14px 0}.field label{display:block;font-size:13px;font-weight:700;margin-bottom:7px}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px;background:#fbfdff;color:var(--text)}.btn{display:inline-flex;align-items:center;gap:8px;border:0;border-radius:12px;background:linear-gradient(135deg,#0f6cdb,#16d9ff);color:white;padding:11px 16px;font-weight:800;cursor:pointer}.btn-secondary{background:#eaf3ff;color:#0750a3}.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,#001b43,#002a63);color:#d9ecff;padding:18px 15px;position:sticky;top:0;height:100vh}.logo{display:flex;align-items:center;gap:12px;margin-bottom:22px}.logo-mark{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#16d9ff,#0a4b95);display:grid;place-items:center;font-weight:900}.logo strong{display:block;color:#fff}.logo small{color:#8ab5e5}.menu a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:12px;margin:4px 0;color:#dbeafe;font-size:14px}.menu a:hover,.menu a.active{background:#ffffff14;color:#fff;border:1px solid #24dfff33}.content{min-width:0}.topbar{height:70px;background:#ffffffdd;backdrop-filter:blur(12px);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:10}.page-title h1{font-size:22px;margin:0}.page-title span{font-size:13px;color:var(--muted)}.userbar{display:flex;align-items:center;gap:12px}.avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#002b68,#16d9ff);display:grid;place-items:center;color:white;font-weight:900;box-shadow:0 8px 25px #0f6cdb25}.container{padding:24px}.hero{background:linear-gradient(135deg,#fff,#edf7ff);border:1px solid var(--line);border-radius:20px;padding:24px;margin-bottom:20px;display:flex;justify-content:space-between;gap:20px}.hero h2{font-size:27px;margin:0 0 8px;color:#062b68}.pill{display:inline-flex;border:1px solid #c9ddf5;border-radius:12px;padding:8px 11px;background:#fff;font-weight:700;font-size:12px;margin:5px}.grid{display:grid;gap:16px}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 12px 35px #062b6810}.kpi-title{font-size:13px;color:var(--muted);font-weight:700}.kpi-value{font-size:25px;font-weight:900;margin-top:7px;color:#002b68}.kpi-sub{font-size:12px;color:var(--green);margin-top:5px}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;color:#516987;font-size:12px;padding:11px;border-bottom:1px solid var(--line)}.table td{padding:12px;border-bottom:1px solid #edf3fa}.badge{padding:5px 9px;border-radius:999px;font-size:11px;font-weight:800}.ok{background:#e8fff7;color:#008765}.warn{background:#fff7e6;color:#a25d00}.bad{background:#fff0f0;color:#bd1b1b}.info{background:#eaf3ff;color:#0750a3}.section-head{display:flex;align-items:center;justify-content:space-between;margin:22px 0 12px}.section-head h2{font-size:18px;margin:0}.progress{height:8px;background:#e5effb;border-radius:99px;overflow:hidden}.progress span{display:block;height:100%;background:linear-gradient(90deg,#1a73e8,#16d9ff);border-radius:99px}.mock-chart{height:180px;display:flex;align-items:end;gap:10px}.bar{flex:1;background:linear-gradient(180deg,#16d9ff,#1a73e8);border-radius:9px 9px 0 0;min-height:20px}.chat{display:grid;grid-template-columns:280px 1fr;height:520px}.chat-list{border-right:1px solid var(--line);padding-right:14px}.chat-msg{background:#f2f7ff;border:1px solid #dbeafe;border-radius:14px;padding:11px;margin:10px 0;max-width:70%}.chat-msg.me{margin-left:auto;background:#e8fff7;border-color:#b9f3df}.footer-note{font-size:12px;color:var(--muted);margin-top:18px}@media(max-width:1000px){.app{grid-template-columns:1fr}.sidebar{height:auto;position:relative}.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.login-wrap{grid-template-columns:1fr}.brand-panel{display:none}}

.company-logo{width:48px;height:48px;object-fit:contain;border-radius:14px;background:#fff;padding:4px;box-shadow:0 8px 24px #00000022}.avatar-img{width:42px;height:42px;border-radius:50%;object-fit:cover;border:2px solid #d6e3f3;box-shadow:0 8px 25px #0f6cdb25}.logo{align-items:center}.logo strong{max-width:155px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand-logo{width:210px;max-width:100%;background:#fff;border-radius:16px;padding:10px;margin:25px 0}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.upload-box{border:1px dashed #9bc5f3;border-radius:16px;padding:16px;background:#f8fbff}.preview-logo{height:70px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:14px;padding:8px}.preview-avatar{width:70px;height:70px;border-radius:50%;object-fit:cover;background:#fff;border:1px solid var(--line);padding:4px}@media(max-width:900px){.form-grid{grid-template-columns:1fr}}
/* V1.2 - Login multiempresa e chat lateral */
.field select{width:100%;border:1px solid #cfe0f3;border-radius:10px;padding:12px;background:#fff;color:#002b5c;font-weight:700;outline:none}
.chat-fab{position:fixed;right:24px;bottom:24px;z-index:50;border:none;border-radius:999px;padding:12px 18px;background:linear-gradient(135deg,#1688e8,#1fd0ef);color:#fff;font-weight:900;box-shadow:0 16px 30px rgba(0,45,99,.25);cursor:pointer;display:flex;gap:8px;align-items:center}.chat-fab b{background:#ffb000;color:#002b5c;border-radius:50%;min-width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;font-size:12px}.chat-drawer{position:fixed;top:0;right:-430px;width:410px;height:100vh;background:#fff;z-index:60;box-shadow:-20px 0 50px rgba(0,43,92,.18);transition:.25s ease;border-left:1px solid #cfe0f3;display:flex;flex-direction:column}.chat-drawer.open{right:0}.chat-drawer-head{height:70px;background:#002b5c;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 18px}.chat-drawer-head button{border:none;background:#0fc7e8;color:#002b5c;border-radius:10px;width:34px;height:34px;font-size:22px;cursor:pointer}.chat-drawer-body{padding:16px;display:grid;grid-template-columns:145px 1fr;gap:12px;height:calc(100vh - 70px);overflow:hidden}.chat-users{border-right:1px solid #d7e7f8;padding-right:12px;overflow:auto}.chat-user,.chat-contact{display:flex;gap:10px;align-items:center;padding:10px;border:1px solid #d7e7f8;border-radius:12px;margin-bottom:8px;background:#f8fbff}.chat-user strong,.chat-contact strong{font-size:12px;color:#002b5c}.chat-user small,.chat-contact small{display:block;font-size:10px;color:#64748b}.dot{width:9px;height:9px;background:#00c48c;border-radius:50%;flex:0 0 9px}.chat-window,.chat-main{display:flex;flex-direction:column;min-height:0}.chat-msg{background:#f2f7fd;border:1px solid #d7e7f8;border-radius:14px;padding:10px;margin:7px 0;color:#002b5c;font-size:13px;max-width:88%}.chat-msg.me{background:#dff9ff;margin-left:auto}.chat-compose{margin-top:auto;display:flex;gap:8px}.chat-compose input{flex:1;border:1px solid #cfe0f3;border-radius:12px;padding:12px}.chat-compose button{border:none;border-radius:12px;padding:0 14px;background:#1688e8;color:#fff;font-weight:800}.chat-page{display:grid;grid-template-columns:280px 1fr;gap:18px;min-height:520px}.chat-main{border-left:1px solid #d7e7f8;padding-left:18px}.chat-contact{display:block;cursor:pointer}.chat-contact:hover{border-color:#1fd0ef;background:#eefaff}@media(max-width:800px){.chat-drawer{width:100%;right:-100%}.chat-drawer-body{grid-template-columns:1fr}.chat-users{border-right:0;border-bottom:1px solid #d7e7f8}.chat-page{grid-template-columns:1fr}.chat-main{border-left:0;padding-left:0}}
/* V1.3 - Dashboard por perfil, gráficos informativos, chat funcional */
.chart-caption,.muted{color:#64748b;font-size:13px}.mock-chart.labeled{align-items:end;gap:18px}.bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:180px;justify-content:flex-end}.bar-wrap small{font-size:11px;color:#516987;font-weight:700;text-align:center}.bar.expense{background:linear-gradient(180deg,#ffb000,#ef4444)}.bar.result{background:linear-gradient(180deg,#21e6c1,#00a884)}.legend{display:flex;gap:12px;font-size:12px;color:#516987;font-weight:700;margin:10px 0}.project-card h3{margin-top:0}.project-meter{--p:0;width:110px;height:110px;border-radius:50%;margin:12px auto;background:conic-gradient(#16d9ff calc(var(--p)*1%), #e6f0fb 0);display:grid;place-items:center;position:relative}.project-meter:before{content:"";position:absolute;width:78px;height:78px;border-radius:50%;background:#fff}.project-meter span{position:relative;font-size:22px;font-weight:900;color:#002b68}.mini-metrics{display:grid;gap:10px;margin:14px 0}.mini-metrics strong{display:block;font-size:12px;margin-bottom:5px;color:#516987}.chat-messages{overflow:auto;min-height:0;flex:1;padding-right:4px}.chat-msg small{display:block;text-align:right;color:#64748b;font-size:10px;margin-top:5px}.chat-user{cursor:pointer}.chat-user:hover{border-color:#1fd0ef;background:#eefaff}
/* V2.0 - telas de detalhes, alertas financeiros e dashboard executivo */
.card-dark{min-width:310px;background:linear-gradient(135deg,#001b43,#002b68)!important;color:#fff!important}.center{text-align:center}.btn-mini{padding:7px 10px;border-radius:9px;font-size:12px}.due{background:#fff1df;color:#c2410c}.modal{position:fixed;inset:0;background:rgba(0,20,50,.48);z-index:100;display:none;align-items:center;justify-content:center;padding:30px}.modal.open{display:flex}.modal-box{width:min(760px,96vw);max-height:88vh;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:22px;padding:24px;box-shadow:0 35px 80px rgba(0,31,77,.35);position:relative}.modal-large{width:min(1050px,96vw)}.modal-close{position:absolute;right:18px;top:14px;border:0;background:#eaf3ff;color:#002b68;border-radius:12px;width:34px;height:34px;font-size:22px;cursor:pointer}.bar{position:relative}.bar span{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);font-size:11px;color:#002b68;font-weight:900;white-space:nowrap;margin-bottom:5px}.chat-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;background:#fff;border:1px solid #cfe0f3;display:grid;place-items:center;color:#002b68;font-weight:900;flex:0 0 30px}.chat-avatar.letter{background:linear-gradient(135deg,#eaf3ff,#dff9ff)}.chat-mini{width:22px;height:22px;border-radius:50%;object-fit:cover}.chat-line-head{display:flex;align-items:center;gap:7px;margin-bottom:4px}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px}.status-ok{background:#00a884}.status-warn{background:#facc15}.status-due{background:#fb923c}.status-bad{background:#ef4444}@media(max-width:900px){.modal{padding:12px}.modal-box{padding:18px}.card-dark{min-width:0}}

/* V2.1 - listagem limpa, modal real, portal cliente e engenharia */
.table-clean tbody tr.detail-row{display:none}.actions{white-space:nowrap}.modal-body-grid{display:grid;grid-template-columns:220px 1fr;gap:10px}.modal-body-grid div{padding:8px;border-bottom:1px solid #edf3fa}.modal-body-grid div:nth-child(odd){font-weight:800;color:#516987}.timeline{position:relative;margin:18px 0;padding-left:22px}.timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:#d6e3f3}.tl-item{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;margin:10px 0}.tl-item:before{content:"";position:absolute;left:-20px;top:17px;width:12px;height:12px;border-radius:50%;background:#16d9ff;border:2px solid #fff;box-shadow:0 0 0 2px #d6e3f3}.stat-row{display:grid;grid-template-columns:130px 1fr 55px;gap:10px;align-items:center;margin:9px 0}.bar-red{background:linear-gradient(180deg,#ff8a8a,#ef4444)!important}.bar-blue{background:linear-gradient(180deg,#16d9ff,#1877f2)!important}.bar-green{background:linear-gradient(180deg,#34d399,#00a884)!important}.bar-yellow{background:linear-gradient(180deg,#fde68a,#f59e0b)!important}.chart-note{font-size:12px;color:#64748b;margin-top:8px}.file-drop{border:1px dashed #9bc5f3;border-radius:16px;padding:18px;background:#f8fbff;text-align:center}.role-alert{background:#fff7e6;border:1px solid #ffe2a8;color:#8a5200;border-radius:16px;padding:14px;margin-bottom:16px}.client-step{display:flex;justify-content:space-between;gap:10px;align-items:center}.client-step strong{display:block}.lock-note{font-size:12px;color:#64748b}.kpi-receita .kpi-value{color:#00a884}.kpi-despesa .kpi-value{color:#ef4444}.kpi-resultado .kpi-value{color:#1877f2}@media(max-width:800px){.modal-body-grid{grid-template-columns:1fr}.stat-row{grid-template-columns:1fr}.client-step{align-items:flex-start;flex-direction:column}}
