:root{
  --bg:#f4f6f8;--panel:#fff;--text:#111827;--muted:#667085;--line:#e5e7eb;--brand:#111827;--brand2:#2563eb;--ok:#047857;--warn:#b45309;--danger:#b91c1c;--soft:#f9fafb;--shadow:0 12px 28px rgba(15,23,42,.08);--radius:18px
}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit}.boot-screen{min-height:100vh;display:grid;place-content:center;text-align:center;color:var(--muted);gap:18px}.loader{width:42px;height:42px;border-radius:50%;border:4px solid #d1d5db;border-top-color:var(--brand);animation:spin .8s linear infinite;margin:auto}@keyframes spin{to{transform:rotate(360deg)}}
.auth-page{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}.auth-hero{background:linear-gradient(135deg,#111827,#1f2937);color:white;padding:72px;display:flex;flex-direction:column;justify-content:space-between}.auth-hero h1{font-size:46px;line-height:1.05;margin:0 0 18px}.auth-hero p{font-size:18px;color:#d1d5db;max-width:680px}.auth-card{display:grid;place-items:center;padding:32px}.auth-panel{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:30px;width:min(480px,100%)}.auth-panel h2{margin:0 0 8px}.tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;background:#f3f4f6;padding:6px;border-radius:14px;margin:20px 0}.tabs.three-tabs{grid-template-columns:1fr 1fr 1fr}.tab-btn{border:0;border-radius:11px;padding:11px;background:transparent}.tab-btn.active{background:#fff;box-shadow:0 4px 12px rgba(0,0,0,.08)}
.app-shell{display:grid;grid-template-columns:285px 1fr;min-height:100vh}.sidebar{background:#0f172a;color:#fff;padding:24px;display:flex;flex-direction:column;gap:24px;position:sticky;top:0;height:100vh}.logo-row{display:flex;gap:12px;align-items:center}.logo-mark{width:46px;height:46px;border-radius:15px;background:#2563eb;display:grid;place-items:center;font-weight:800}.logo-row h1{margin:0;font-size:18px}.logo-row p,.sidebar-footer{color:#cbd5e1;font-size:13px;margin:2px 0 0}.nav{display:grid;gap:8px}.nav-btn{border:0;background:transparent;color:#cbd5e1;text-align:left;padding:12px 14px;border-radius:12px}.nav-btn.active,.nav-btn:hover{background:rgba(255,255,255,.1);color:#fff}.sidebar-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.14);padding-top:18px}.main{padding:28px;max-width:1500px;width:100%;margin:0 auto}.mobile-topbar{display:none}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:22px}.topbar h2{margin:0;font-size:28px}.topbar p{margin:6px 0 0;color:var(--muted)}
.panel,.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.panel{padding:22px;margin-bottom:22px}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.panel-header h3{margin:0}.panel-header p{margin:5px 0 0;color:var(--muted);font-size:14px}.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}.card{padding:20px}.card small{color:var(--muted)}.metric{font-size:31px;font-weight:800;margin-top:8px}.metric-note{color:var(--muted);font-size:13px}.split{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-grid{display:grid;gap:16px}.form-grid.two{grid-template-columns:repeat(2,1fr)}.form-grid.three{grid-template-columns:repeat(3,1fr)}.form-grid.four{grid-template-columns:repeat(4,1fr)}.field label{display:block;font-size:13px;font-weight:700;margin-bottom:7px}input,select,textarea{width:100%;border:1px solid #d1d5db;border-radius:12px;padding:11px 12px;background:#fff;color:var(--text)}textarea{min-height:96px;resize:vertical}.check-list{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.check-item{border:1px solid var(--line);background:#fff;border-radius:12px;padding:10px;display:flex;gap:8px;align-items:center}.check-item input{width:auto}.form-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.primary-btn,.secondary-btn,.small-btn,.danger-btn{border:0;border-radius:12px;padding:11px 16px;font-weight:700}.primary-btn{background:var(--brand);color:#fff}.secondary-btn{background:#eff6ff;color:#1d4ed8}.small-btn{background:#f3f4f6;color:#111827;padding:8px 11px}.danger-btn{background:#fee2e2;color:#991b1b}.primary-btn:disabled,.secondary-btn:disabled,.small-btn:disabled{opacity:.55;cursor:not-allowed}.help-text{color:var(--muted);font-size:13px}.muted{color:var(--muted)}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:14px}table{width:100%;border-collapse:collapse;background:#fff}th,td{text-align:left;border-bottom:1px solid var(--line);padding:13px;vertical-align:top}th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;background:#f9fafb}tr:last-child td{border-bottom:0}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-weight:800;font-size:12px;background:#f3f4f6;color:#374151}.badge.ok{background:#dcfce7;color:#166534}.badge.warn{background:#fef3c7;color:#92400e}.badge.danger{background:#fee2e2;color:#991b1b}.badge.blue{background:#dbeafe;color:#1d4ed8}.empty-state{padding:22px;background:#f9fafb;border:1px dashed #d1d5db;border-radius:14px;color:var(--muted);text-align:center}.alert{padding:12px 14px;border-radius:13px;margin-bottom:16px}.alert.error{background:#fee2e2;color:#991b1b}.alert.ok{background:#dcfce7;color:#166534}.service-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.service-card{border:1px solid var(--line);background:#fff;border-radius:18px;padding:18px}.service-card h3{margin:0 0 6px}.service-card .meta{display:grid;gap:5px;margin:12px 0;color:#475569}.task-row{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line);padding:10px 0}.task-row:last-child{border-bottom:0}.photo-list{display:flex;gap:10px;flex-wrap:wrap}.photo-list img{width:140px;height:100px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}.kpi-line{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:18px 0}.kpi-line div{border:1px solid var(--line);border-radius:14px;padding:14px;background:#f9fafb}.kpi-line span{display:block;color:var(--muted);font-size:13px}.kpi-line strong{font-size:24px}.report-title{display:flex;justify-content:space-between;gap:16px;border-bottom:2px solid var(--text);padding-bottom:14px;margin-bottom:18px}.pill-row{display:flex;gap:8px;flex-wrap:wrap}.pill{border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 10px}.finance{font-weight:800}.employee-only .sidebar{background:#172554}.employee-today{background:#eff6ff;border-color:#bfdbfe}.employee-late{background:#fff7ed;border-color:#fed7aa}
@media(max-width:1050px){.auth-page{grid-template-columns:1fr}.auth-hero{padding:44px}.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.cards-grid,.split,.form-grid.two,.form-grid.three,.form-grid.four,.service-cards{grid-template-columns:1fr}.mobile-topbar{display:flex;position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--line);padding:11px 14px;align-items:center;justify-content:space-between}.mobile-topbar small{display:block;color:var(--muted)}}@media(max-width:640px){.main{padding:16px}.auth-hero{display:none}.auth-card{padding:16px}.auth-panel{padding:22px}.sidebar{padding:16px}.nav{grid-template-columns:1fr 1fr}.topbar{display:block}.check-list{grid-template-columns:1fr}.panel{padding:16px}.cards-grid{gap:10px}.kpi-line{grid-template-columns:1fr 1fr}th,td{padding:10px;font-size:13px}.hide-mobile{display:none}}
@media print{body{background:#fff}.no-print,.sidebar,.mobile-topbar,.topbar .no-print{display:none!important}.app-shell{display:block}.main{padding:0;max-width:none}.panel{box-shadow:none;border:0}.printable-panel{display:block}.table-wrap{overflow:visible;border:0}th,td{font-size:12px}.photo-list img{width:120px;height:80px}}

.form-section-label{font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin:18px 0 2px}
.form-grid > .form-section-label:first-child{margin-top:0}


/* Mobile readiness v5 */
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{min-height:100dvh}input,select,textarea{font-size:16px}.platform-sidebar{background:#020617}.platform-admin-shell .logo-mark{background:#7c3aed}.tabs.multi-tabs{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.table-wrap{max-width:100%;-webkit-overflow-scrolling:touch}.table-wrap table{min-width:760px}.form-grid .full{grid-column:1/-1}.mobile-card-list{display:none}.primary-btn,.secondary-btn,.small-btn,.danger-btn{min-height:42px}.nav-btn{min-height:42px}.auth-panel{max-width:520px}.service-card{overflow:hidden}.platform-mobile{background:#111827;color:#fff}.platform-mobile small{color:#cbd5e1}
@media(max-width:820px){
  .app-shell{display:block}.sidebar{height:auto;position:relative;border-radius:0}.sidebar .logo-row{margin-bottom:6px}.nav{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.nav-btn{text-align:center;background:rgba(255,255,255,.06)}.sidebar-footer{display:none}.main{padding:14px}.panel-header{display:block}.panel-header .form-actions{margin-top:12px}.cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.card{padding:16px}.metric{font-size:25px}.table-wrap{border-radius:12px}th,td{white-space:nowrap}.auth-page{min-height:100dvh}.auth-card{min-height:100dvh}.auth-panel{border-radius:20px}.tabs{overflow:auto}.tab-btn{white-space:nowrap}.form-actions .primary-btn,.form-actions .secondary-btn,.form-actions .small-btn,.form-actions .danger-btn{flex:1 1 auto}.check-list{grid-template-columns:1fr}.photo-list img{width:44%;height:110px}.kpi-line{grid-template-columns:1fr 1fr}.topbar h2{font-size:24px}.topbar p{font-size:14px}.service-cards{grid-template-columns:1fr}
}
@media(max-width:520px){
  .mobile-topbar{padding:calc(10px + env(safe-area-inset-top)) 12px 10px}.mobile-topbar strong{font-size:14px}.mobile-topbar .small-btn{padding:8px 10px}.nav{grid-template-columns:1fr 1fr}.cards-grid,.kpi-line{grid-template-columns:1fr}.panel{padding:14px;margin-bottom:14px}.auth-panel{padding:18px}.auth-card{padding:12px}.tabs.three-tabs,.tabs.multi-tabs{grid-template-columns:1fr}.tab-btn{text-align:center}.form-grid{gap:13px}.split{gap:14px}.photo-list img{width:100%;height:160px}.topbar{margin-bottom:16px}.topbar .no-print{margin-top:12px}.small-btn,.primary-btn,.secondary-btn,.danger-btn{width:auto}.service-card .form-actions button{width:100%}.hide-tiny{display:none!important}
}

/* Branding v11 */
.brand-logo-block img{max-width:320px;width:100%;height:auto;display:block}.auth-hero .brand-logo-block img{filter:drop-shadow(0 8px 18px rgba(0,0,0,.18));background:white;border-radius:18px;padding:10px}.logo-icon{width:48px;height:48px;object-fit:contain;border-radius:14px;background:white;padding:4px}.mobile-brand{display:flex;align-items:center;gap:10px;min-width:0}.mobile-brand img{width:34px;height:34px;object-fit:contain;border-radius:10px;background:white;padding:3px;flex:0 0 auto}.app-logo-center{display:flex;justify-content:center;margin-bottom:14px}.app-logo-center img{width:86px;height:86px;object-fit:contain}.pending-page .auth-panel{text-align:left}.brand-hero{gap:40px}.badge.secondary{background:#eef2ff;color:#3730a3}.badge.neutral{background:#f3f4f6;color:#374151}
@media(max-width:640px){.brand-logo-block img{max-width:250px}.auth-hero .brand-logo-block img{padding:8px}.logo-icon{width:42px;height:42px}.mobile-brand img{width:32px;height:32px}.app-logo-center img{width:72px;height:72px}}

/* v11 — modal de aprovação/planos */
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(15, 23, 42, .55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
}
.modal-card {
  width: min(860px, 100%);
  max-height: 92vh;
  overflow: auto;
  background: #fff;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 22px;
  box-shadow: 0 24px 70px rgba(15, 23, 42, .28);
  padding: 22px;
}
.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}
.modal-header h3 { margin: 0 0 4px; font-size: 22px; }
.modal-header p { margin: 0; color: var(--muted, #64748b); }
.icon-btn {
  border: 0;
  background: #f1f5f9;
  color: #0f172a;
  border-radius: 12px;
  width: 40px;
  height: 40px;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}
.notice-box {
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  color: #1e3a8a;
  border-radius: 14px;
  padding: 12px 14px;
  margin: 12px 0;
}
@media (max-width: 720px) {
  .modal-backdrop { align-items: flex-end; padding: 0; }
  .modal-card { border-radius: 22px 22px 0 0; max-height: 94vh; padding: 18px; }
  .modal-header h3 { font-size: 19px; }
}

/* v12 — UX refinado: navegação mobile, ações rápidas e interface mais limpa */
:root{
  --brand:#0f172a;
  --brand2:#2563eb;
  --brand3:#0ea5e9;
  --bg:#f5f7fb;
  --panel:#ffffff;
  --line:#e6eaf0;
  --muted:#64748b;
  --shadow:0 18px 45px rgba(15,23,42,.07);
  --shadow-soft:0 8px 24px rgba(15,23,42,.06);
}
body{background:linear-gradient(180deg,#f8fbff 0%,#f4f6f8 260px,#f4f6f8 100%)}
.auth-page{background:radial-gradient(circle at 14% 18%, rgba(37,99,235,.16), transparent 28%),linear-gradient(135deg,#0f172a,#1e293b)}
.auth-hero{background:transparent}.auth-card{background:rgba(255,255,255,.92);backdrop-filter:blur(6px)}.auth-panel{box-shadow:0 26px 80px rgba(15,23,42,.16);border-color:rgba(226,232,240,.9)}
.auth-panel h2,.topbar h2{letter-spacing:-.03em}.auth-panel .primary-btn{width:100%;justify-content:center}.build-version{opacity:.65}
.sidebar{box-shadow:inset -1px 0 rgba(255,255,255,.06)}.nav-btn{display:flex;align-items:center;gap:8px}.nav-btn.active{box-shadow:inset 3px 0 var(--brand2);background:rgba(255,255,255,.12)}
.panel,.card,.service-card{box-shadow:var(--shadow-soft);border-color:var(--line)}.panel:hover,.card:hover,.service-card:hover{box-shadow:var(--shadow)}
.card{position:relative;overflow:hidden}.card:after{content:"";position:absolute;right:-24px;top:-24px;width:80px;height:80px;border-radius:999px;background:rgba(37,99,235,.06)}.metric{letter-spacing:-.04em}.metric-note{position:relative;z-index:1}.topbar{background:linear-gradient(135deg,#fff,rgba(239,246,255,.9));border:1px solid var(--line);border-radius:22px;padding:20px 22px;box-shadow:var(--shadow-soft)}
.quick-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:0 0 22px}.quick-action{border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f8fafc);border-radius:18px;padding:16px;text-align:left;box-shadow:var(--shadow-soft);display:grid;grid-template-columns:auto 1fr;column-gap:12px;row-gap:2px;align-items:center;color:var(--text)}.quick-action:hover{transform:translateY(-1px);box-shadow:var(--shadow);border-color:#bfdbfe}.quick-action .quick-icon{width:42px;height:42px;border-radius:14px;background:#eff6ff;color:#1d4ed8;display:grid;place-items:center;font-size:20px;grid-row:1/3}.quick-action strong{font-size:15px}.quick-action small{color:var(--muted);line-height:1.35}.platform-actions .quick-action .quick-icon{background:#f5f3ff;color:#6d28d9}
.next-step-panel{display:flex;align-items:center;justify-content:space-between;gap:18px;background:linear-gradient(135deg,#eff6ff,#fff);border-color:#bfdbfe}.next-step-panel h3{margin:10px 0 6px;font-size:23px;letter-spacing:-.02em}.next-step-panel p{margin:0;color:#475569}.next-step-panel .primary-btn{white-space:nowrap}
.field label{color:#334155}.help-text{line-height:1.45}input:focus,select:focus,textarea:focus{outline:3px solid rgba(37,99,235,.15);border-color:#60a5fa}.primary-btn,.secondary-btn,.small-btn,.danger-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .14s ease,box-shadow .14s ease,background .14s ease}.primary-btn:hover,.secondary-btn:hover,.small-btn:hover{transform:translateY(-1px)}.primary-btn{background:linear-gradient(135deg,#0f172a,#1d4ed8);box-shadow:0 10px 22px rgba(37,99,235,.2)}.secondary-btn{border:1px solid #bfdbfe}.danger-btn{border:1px solid #fecaca}
.service-card{position:relative}.service-card.employee-today:before{content:"Hoje";position:absolute;right:16px;top:16px;background:#dbeafe;color:#1d4ed8;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:800}.employee-only .primary-btn{background:linear-gradient(135deg,#1d4ed8,#0ea5e9)}.task-row label{display:flex;align-items:center;gap:8px}.task-row input{width:18px;height:18px}.service-card details{border:1px solid var(--line);border-radius:14px;padding:12px;background:#f8fafc}.service-card details summary{font-weight:800;cursor:pointer}
.alert{position:sticky;top:14px;z-index:50;border:1px solid transparent;box-shadow:var(--shadow-soft)}.alert.ok{border-color:#86efac}.alert.error{border-color:#fca5a5}.empty-state{background:linear-gradient(135deg,#f8fafc,#fff);padding:26px}.badge{letter-spacing:.01em}.badge.ok{background:#d1fae5;color:#065f46}.badge.warn{background:#fef3c7;color:#92400e}.badge.danger{background:#fee2e2;color:#991b1b}.badge.blue{background:#dbeafe;color:#1e40af}
.bottom-nav{display:none}

@media(max-width:900px){
  .main{padding-bottom:96px}.sidebar{padding-bottom:10px}.sidebar .nav{display:none}.mobile-topbar{box-shadow:0 8px 24px rgba(15,23,42,.08)}.topbar{padding:16px;border-radius:18px}.quick-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.quick-action{padding:13px;border-radius:16px}.quick-action .quick-icon{width:38px;height:38px}.next-step-panel{display:block}.next-step-panel .primary-btn{width:100%;margin-top:14px}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:999;display:flex;gap:6px;overflow-x:auto;background:rgba(255,255,255,.96);backdrop-filter:blur(14px);border-top:1px solid var(--line);padding:8px 10px calc(8px + env(safe-area-inset-bottom));box-shadow:0 -12px 36px rgba(15,23,42,.10);-webkit-overflow-scrolling:touch}.bottom-nav-btn{border:0;background:transparent;color:#64748b;border-radius:14px;min-width:78px;padding:8px 10px;display:grid;place-items:center;gap:2px}.bottom-nav-btn span{font-size:18px}.bottom-nav-btn small{font-size:11px;font-weight:800;white-space:nowrap}.bottom-nav-btn.active{background:#eff6ff;color:#1d4ed8}.bottom-nav-btn.active span{transform:translateY(-1px)}.panel-header{gap:8px}.panel-header h3{font-size:18px}.form-grid.three,.form-grid.four{grid-template-columns:1fr}.table-wrap{box-shadow:inset -18px 0 22px -24px rgba(15,23,42,.25)}
}
@media(max-width:560px){
  body{background:#f8fafc}.auth-card{background:#f8fafc}.auth-panel{border-radius:22px;padding:20px}.auth-panel h2{font-size:24px}.tabs{padding:5px}.tab-btn{min-height:44px}.mobile-topbar{align-items:center}.mobile-brand strong{display:block;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick-actions{grid-template-columns:1fr}.quick-action{grid-template-columns:auto 1fr}.cards-grid{grid-template-columns:1fr}.card{padding:18px}.metric{font-size:30px}.service-card{border-radius:20px;padding:16px}.service-card .panel-header{padding-right:56px}.service-card .form-actions{display:grid;grid-template-columns:1fr;gap:10px}.service-card .form-actions button{width:100%}.check-list{gap:8px}.check-item{min-height:46px}.bottom-nav-btn{min-width:72px}.topbar h2{font-size:22px}.topbar p{font-size:13px}.modal-card{padding-bottom:calc(18px + env(safe-area-inset-bottom))}
}

/* v13 demo access */
.demo-box {
  margin-top: 18px;
  padding: 16px;
  border: 1px solid rgba(37, 99, 235, 0.18);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(239, 246, 255, 0.95), rgba(255, 255, 255, 0.96));
  display: grid;
  gap: 12px;
}
.demo-box p { margin: 4px 0 0; color: var(--muted); font-size: 0.92rem; }
.demo-buttons { display: flex; gap: 10px; flex-wrap: wrap; }
.demo-buttons .secondary-btn { flex: 1 1 160px; }
@media (max-width: 640px) {
  .demo-buttons { display: grid; grid-template-columns: 1fr; }
}

/* v19 public landing */
.public-landing{min-height:100vh;background:linear-gradient(180deg,#f8fafc 0%,#eef5ff 42%,#ffffff 100%);color:#172033;}
.landing-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px clamp(18px,4vw,56px);background:rgba(255,255,255,.88);backdrop-filter:blur(18px);border-bottom:1px solid rgba(15,23,42,.08)}
.landing-brand img{height:52px;width:auto;display:block}.landing-nav{display:flex;gap:20px;align-items:center}.landing-nav a{color:#32445f;text-decoration:none;font-weight:800;font-size:14px}.landing-nav a:hover{color:#0b63ce}.compact{padding:11px 16px!important;border-radius:14px!important}.landing-hero-section{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.92fr);gap:42px;align-items:center;padding:clamp(42px,7vw,92px) clamp(18px,5vw,72px) 52px;max-width:1240px;margin:auto}.landing-copy h1{font-size:clamp(36px,6vw,72px);line-height:.97;letter-spacing:-.055em;margin:12px 0 20px;color:#0e1b2f}.landing-copy p{font-size:clamp(17px,2vw,21px);line-height:1.55;color:#445b78;max-width:720px}.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#e7f1ff;color:#0b63ce;font-weight:900;font-size:13px;text-transform:uppercase;letter-spacing:.06em}.landing-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin:26px 0 20px}.trust-pills{display:flex;gap:9px;flex-wrap:wrap}.trust-pills span{border:1px solid #d7e3f4;background:#fff;border-radius:999px;padding:9px 12px;color:#31445f;font-weight:800;font-size:13px}.landing-product-card{position:relative;display:grid;place-items:center;min-height:560px}.phone-mockup{width:280px;border:10px solid #101a2a;border-radius:38px;background:#fff;box-shadow:0 26px 80px rgba(17,24,39,.22);overflow:hidden;z-index:3}.phone-top{height:26px;background:#101a2a}.phone-content{padding:20px;display:grid;gap:13px}.mini-logo img{width:58px;height:58px;border-radius:18px}.phone-content h3{font-size:22px;line-height:1.1;margin:0}.phone-content p{font-size:14px;color:#58708e;margin:0}.full{width:100%;justify-content:center}.check-row{padding:10px;border:1px solid #dbe7f6;border-radius:12px;background:#f8fbff;font-weight:800}.check-row.done{background:#e9f9ef;color:#117238;border-color:#bce9ca}.desktop-mockup{position:absolute;right:0;bottom:20px;width:330px;background:#fff;border:1px solid #dbe7f6;border-radius:22px;box-shadow:0 22px 60px rgba(17,24,39,.16);padding:18px;transform:rotate(1deg)}.mock-window-bar{display:flex;gap:6px;margin-bottom:14px}.mock-window-bar span{width:10px;height:10px;border-radius:99px;background:#cbd5e1}.mock-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.mock-grid div{background:#f3f8ff;border-radius:14px;padding:12px}.mock-grid small{display:block;color:#64748b;font-size:11px}.mock-grid strong{font-size:22px}.mock-list{display:grid;gap:8px;margin-top:14px}.mock-list span{height:12px;background:#e6edf7;border-radius:99px}.landing-section{padding:64px clamp(18px,5vw,72px);max-width:1240px;margin:auto}.section-heading{text-align:center;max-width:780px;margin:0 auto 32px}.section-heading h2{font-size:clamp(30px,4vw,48px);letter-spacing:-.04em;line-height:1.05;margin:14px 0;color:#0e1b2f}.section-heading p{color:#58708e;font-size:18px;line-height:1.55}.feature-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.feature-grid article,.pricing-grid article,.choice-card,.faq-grid details{background:#fff;border:1px solid #dce7f5;border-radius:24px;padding:22px;box-shadow:0 16px 42px rgba(17,24,39,.06)}.feature-grid article span{font-size:28px}.feature-grid h3,.pricing-grid h3{margin:12px 0 8px;color:#132033}.feature-grid p,.pricing-grid p,.choice-card small,.faq-grid p{color:#5a708c;line-height:1.45}.split-section{display:grid;grid-template-columns:.9fr 1.1fr;gap:36px;align-items:start}.split-section h2{font-size:clamp(30px,4vw,48px);line-height:1.05;letter-spacing:-.04em}.split-section p{color:#58708e;font-size:18px;line-height:1.55}.timeline-list{list-style:none;margin:0;padding:0;display:grid;gap:14px;counter-reset:step}.timeline-list li{counter-increment:step;background:#fff;border:1px solid #dce7f5;border-radius:20px;padding:18px 18px 18px 64px;position:relative}.timeline-list li:before{content:counter(step);position:absolute;left:18px;top:18px;width:30px;height:30px;border-radius:99px;background:#0b63ce;color:#fff;display:grid;place-items:center;font-weight:900}.timeline-list strong{display:block;color:#132033}.timeline-list span{display:block;color:#5a708c;margin-top:4px}.benefits-band{max-width:none;background:linear-gradient(135deg,#0b1628,#0b56c7);color:#fff}.benefits-band .section-heading{max-width:860px}.section-heading.light h2,.section-heading.light p{color:#fff}.benefits-band .eyebrow{background:rgba(255,255,255,.12);color:#fff}.benefit-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.benefit-grid div{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:22px;padding:20px}.benefit-grid strong{display:block;font-size:18px}.benefit-grid span{display:block;color:#dbeafe;margin-top:8px;line-height:1.45}.pricing-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.pricing-grid article{position:relative}.pricing-grid article strong{font-size:28px;color:#0b63ce}.pricing-grid article.recommended{border-color:#0b63ce;box-shadow:0 18px 52px rgba(11,99,206,.16)}.login-landing{background:#fff;border:1px solid #dce7f5;border-radius:36px;margin-top:34px;box-shadow:0 22px 70px rgba(17,24,39,.08)}.login-choice-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.choice-card{border:1px solid #dce7f5;text-align:left;cursor:pointer;transition:.18s ease;min-height:160px}.choice-card:hover{transform:translateY(-3px);box-shadow:0 20px 48px rgba(17,24,39,.12)}.choice-card span{font-size:32px}.choice-card strong{display:block;font-size:18px;margin:10px 0 6px;color:#132033}.choice-card.primary-choice{background:linear-gradient(135deg,#0d2342,#0b63ce);color:#fff}.choice-card.primary-choice strong,.choice-card.primary-choice small{color:#fff}.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.faq-grid summary{font-weight:900;color:#132033;cursor:pointer}.landing-footer{padding:42px 20px;text-align:center;background:#0b1628;color:#dbeafe}.landing-footer .footer-brand{display:inline-flex;align-items:center;justify-content:center;gap:12px;margin-bottom:10px}.landing-footer .footer-brand img{width:54px;height:54px;border-radius:16px;object-fit:cover;background:#fff;padding:2px}.landing-footer .footer-brand strong{font-size:22px;color:#fff}.landing-footer .footer-links{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:10px}.landing-footer a{color:#fff;font-weight:900}.lead-contact-note{margin:8px 0 0;color:#5a708c;font-size:13px}.inline-whatsapp{display:inline-block;margin-top:8px;font-weight:900;color:#075e54!important}.link-btn.auth-back{margin-bottom:14px;border:0;background:transparent;color:#0b63ce;font-weight:900;cursor:pointer;padding:4px 0;text-align:left}
@media (max-width: 980px){.landing-nav{display:none}.landing-brand img{height:42px}.landing-hero-section{grid-template-columns:1fr;padding-top:34px}.landing-product-card{min-height:500px}.desktop-mockup{right:12px;width:250px}.feature-grid{grid-template-columns:repeat(2,1fr)}.split-section{grid-template-columns:1fr}.benefit-grid{grid-template-columns:repeat(2,1fr)}.pricing-grid{grid-template-columns:repeat(2,1fr)}.login-choice-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 620px){.landing-header{padding:12px 14px}.landing-brand img{height:36px;max-width:190px;object-fit:contain}.landing-header .compact{font-size:12px;padding:10px 12px!important}.landing-hero-section{padding:26px 16px 36px}.landing-copy h1{font-size:40px}.landing-copy p{font-size:16px}.landing-product-card{min-height:auto}.phone-mockup{width:100%;max-width:305px}.desktop-mockup{display:none}.landing-section{padding:46px 16px}.feature-grid,.benefit-grid,.pricing-grid,.login-choice-grid,.faq-grid{grid-template-columns:1fr}.login-landing{border-radius:26px;margin:14px 16px}.landing-footer .footer-brand img{width:48px;height:48px}.auth-page{padding-top:18px}}

/* v19 landing, leads, demo limits and PWA polishing */
.note-section { padding-top: 12px; }
.notice-card { max-width: 1060px; margin: 0 auto; border: 1px solid rgba(37,99,235,.14); background: linear-gradient(135deg,#ffffff,#eff6ff); border-radius: 26px; padding: 28px; box-shadow: 0 16px 45px rgba(15,23,42,.08); }
.notice-card h2 { margin: 6px 0 10px; font-size: clamp(24px, 3vw, 38px); }
.notice-card p { color: #475569; line-height: 1.7; margin: 0; }
.strong-notice { border-left: 7px solid #2563eb; }
.case-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.case-grid article { background:#fff; border:1px solid #e2e8f0; border-radius:22px; padding:22px; box-shadow:0 14px 34px rgba(15,23,42,.06); }
.case-grid strong { display:block; font-size:18px; margin-bottom:8px; color:#0f172a; }
.case-grid p { color:#475569; line-height:1.6; margin:0 0 14px; }
.case-grid span { display:inline-block; background:#eff6ff; color:#1d4ed8; border-radius:999px; padding:8px 12px; font-size:13px; font-weight:700; }
.lead-section .lead-form { max-width: 960px; margin: 0 auto; }
.lead-form textarea { min-height: 120px; }
.demo-locked-panel { max-width: 860px; margin: 0 auto; text-align: center; padding: 36px; background: linear-gradient(135deg,#ffffff,#f8fafc); }
.locked-illustration { width: 94px; height: 94px; border-radius: 28px; background:#eff6ff; display:flex; align-items:center; justify-content:center; margin: 0 auto 18px; box-shadow: inset 0 0 0 1px #dbeafe; }
.locked-illustration img { width: 74px; height: 74px; object-fit: contain; }
.demo-locked-panel h3 { font-size: clamp(24px, 3vw, 34px); margin: 0 0 12px; }
.demo-locked-panel p { color:#475569; line-height:1.7; max-width: 700px; margin: 0 auto 14px; }
.demo-mode-alert { border-left: 6px solid #2563eb; }
.app-logo-center img, .mini-logo img, .mobile-brand img, .logo-icon { border-radius: 18px; }
@media (max-width: 900px) { .case-grid { grid-template-columns: 1fr; } .landing-nav { display:none; } .landing-header { padding: 12px 16px; } .landing-brand img { max-width: 190px; } }
@media (max-width: 640px) { .notice-card, .demo-locked-panel { padding: 22px; border-radius: 20px; } .lead-form .form-grid.two { grid-template-columns: 1fr; } .landing-cta-row { align-items: stretch; } .landing-cta-row .primary-btn, .landing-cta-row .secondary-btn { width: 100%; } }

/* ============================================================
   Revisão UX — nunca obrigar a deslocação lateral em mobile/tablet.
   Estas regras ficam propositadamente no final do ficheiro: várias regras
   acima (sidebar, bottom-nav, tabs, table-wrap) partilham os mesmos
   seletores para as mesmas larguras, e em CSS, havendo igual
   especificidade, quem vier depois no ficheiro é que vale. Por isso esta
   secção tem de ser a última.
   ============================================================ */

/* 1) Tabelas (clientes, colaboradores, serviços, ocorrências, etc.) deixam
   de ser uma tabela larga com scroll lateral e passam a uma lista vertical
   de cartões, com a etiqueta de cada coluna acima do valor — e os
   separadores (tabs) deixam de encolher para uma linha com scroll e
   passam a quebrar linha normalmente. */
@media (max-width:900px){
  .table-wrap{overflow:visible;border:0;background:transparent;box-shadow:none;-webkit-overflow-scrolling:auto}
  .table-wrap table{min-width:0;width:100%;display:block}
  .table-wrap thead{display:none}
  .table-wrap tbody{display:block}
  .table-wrap tr{display:block;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-bottom:10px;box-shadow:0 1px 2px rgba(15,23,42,.05)}
  .table-wrap tr:last-child{margin-bottom:0}
  .table-wrap td{display:block;border-bottom:0;padding:6px 0;text-align:left;white-space:normal;word-break:break-word}
  .table-wrap td[data-label]::before{content:attr(data-label);display:block;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
  .table-wrap td .form-actions{margin-top:4px}

  .tabs{overflow:visible}
  .tab-btn{white-space:normal}

  /* 2) O menu inferior deixa de ter scroll lateral: em vez de uma fita
     horizontal, passa a uma grelha de 4 colunas que cresce para baixo
     conforme o número de itens. O espaço reservado por baixo do conteúdo
     (--bn-h) é calculado em JS por bottomNavReserve(), de acordo com o
     número de linhas que o menu vai realmente ocupar. */
  .bottom-nav{display:grid!important;grid-template-columns:repeat(4,1fr);flex-wrap:nowrap;overflow-x:hidden!important}
  .bottom-nav-btn{min-width:0;width:100%}
  .bottom-nav-btn small{white-space:normal;line-height:1.15;word-break:break-word}
  .main{padding-bottom:calc(var(--bn-h, 150px) + env(safe-area-inset-bottom))!important}
}

/* 3) Corrige a duplicação de navegação entre 901–1050px (ex.: portátil
   meio-maximizado, tablet em paisagem): nessa largura o layout já passa a
   coluna única, mas a sidebar só escondia o menu a partir de 900px —
   ficavam os dois visíveis ao mesmo tempo. E aplica aqui o mesmo menu
   inferior em grelha (sem scroll lateral) descrito acima. */
@media (min-width:901px) and (max-width:1050px){
  .sidebar .nav{display:none}
  .sidebar-footer{display:none}
  .main{padding-bottom:calc(var(--bn-h, 150px) + env(safe-area-inset-bottom))!important}
  .bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:999;display:grid!important;grid-template-columns:repeat(4,1fr);gap:6px;overflow-x:hidden!important;background:rgba(255,255,255,.96);backdrop-filter:blur(14px);border-top:1px solid var(--line);padding:8px 10px calc(8px + env(safe-area-inset-bottom));box-shadow:0 -12px 36px rgba(15,23,42,.10)}
  .bottom-nav-btn{border:0;background:transparent;color:#64748b;border-radius:14px;min-width:0;width:100%;padding:8px 10px;display:grid;place-items:center;gap:2px}
  .bottom-nav-btn span{font-size:18px}
  .bottom-nav-btn small{font-size:11px;font-weight:800;white-space:normal;line-height:1.15;word-break:break-word}
  .bottom-nav-btn.active{background:#eff6ff;color:#1d4ed8}
}


/* v24 — UX registo, password segura e ações destrutivas no painel de administração */
.password-field .password-actions,
.field-actions.password-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.password-field .small-btn{min-height:36px;padding:7px 10px;font-size:12px}
.danger-outline{border:1px solid #fecaca;background:#fff1f2!important;color:#991b1b!important}
.onboarding-page .auth-panel{width:min(540px,100%)}
.onboarding-page .notice-box{margin:4px 0 2px}
.auth-panel form .form-grid.two{align-items:start}
@media(max-width:640px){.password-field .small-btn{width:100%}.onboarding-page .auth-card{padding:16px}.onboarding-page .auth-panel{border-radius:22px}}


.analytics-banner {
  position: fixed;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 9999;
  max-width: 980px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  background: #ffffff;
  color: #0f172a;
  border: 1px solid #dbeafe;
  box-shadow: 0 20px 60px rgba(15, 23, 42, 0.20);
  border-radius: 18px;
  padding: 16px 18px;
}
.analytics-banner p { margin: 4px 0 0; color: #475569; font-size: 0.92rem; line-height: 1.45; }
.analytics-banner-actions { display: flex; gap: 10px; flex-shrink: 0; }
@media (max-width: 720px) {
  .analytics-banner { flex-direction: column; align-items: stretch; padding: 14px; }
  .analytics-banner-actions { display: grid; grid-template-columns: 1fr 1fr; }
}

/* v26 — SEO Portugal */
.seo-focus-section{background:#f8fafc;border-radius:28px;padding:44px 26px;border:1px solid #e2e8f0}
.seo-text-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:18px}
.seo-text-grid article{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:18px;box-shadow:0 10px 24px rgba(15,23,42,.05)}
.seo-text-grid h3{margin:0 0 8px;color:#0f172a;font-size:1.02rem}
.seo-text-grid p{margin:0;color:#475569;line-height:1.55}
.legal-page{background:#f6f8fb;min-height:100vh;color:#0f172a;padding:28px 16px}
.legal-page article{max-width:900px;margin:0 auto;background:#fff;border:1px solid #e2e8f0;border-radius:24px;padding:30px;box-shadow:0 16px 40px rgba(15,23,42,.08)}
.legal-page .legal-logo{display:flex;align-items:center;gap:12px;margin-bottom:22px}
.legal-page .legal-logo img{height:42px;width:auto}
.legal-page h1{font-size:2rem;margin:0 0 10px}
.legal-page h2{margin-top:28px;font-size:1.25rem}
.legal-page p,.legal-page li{color:#475569;line-height:1.65}
.legal-page a{color:#0b5ed7;font-weight:700;text-decoration:none}
@media(max-width:760px){.seo-text-grid{grid-template-columns:1fr}.seo-focus-section{padding:28px 18px}.legal-page article{padding:22px}}
