@import "https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700&family=DM+Sans:wght@300;400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--navy:#1b3a6b;--blue:#2563eb;--blue-lt:#eff6ff;--blue-mid:#dbeafe;--green:#059669;--green-lt:#ecfdf5;--red:#dc2626;--red-lt:#fef2f2;--amber:#d97706;--amber-lt:#fffbeb;--text:#0f172a;--text-2:#334155;--muted:#64748b;--border:#e2e8f0;--border-2:#cbd5e1;--card:#fff;--bg:#f1f5f9;--sidebar-w:240px;--sidebar-collapsed-w:84px;--topbar-h:64px;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 4px #0f172a0f;--shadow:0 4px 16px #0f172a14;--shadow-md:0 8px 32px #0f172a1a}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);min-height:100vh;padding-bottom:env(safe-area-inset-bottom,0px);font-family:DM Sans,sans-serif;font-size:15px;line-height:1.5}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--navy);z-index:100;flex-direction:column;height:100vh;transition:transform .3s,width .3s;display:flex;position:fixed;top:0;left:0;box-shadow:12px 0 30px #0f172a14}.sidebar-brand{border-bottom:1px solid #ffffff14;padding:24px 20px 20px;position:relative}.sidebar-brand-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.sidebar-brand .logo{color:#fff;letter-spacing:-.02em;align-items:center;gap:10px;min-width:0;font-family:Sora,sans-serif;font-size:1.05rem;font-weight:700;display:flex}.sidebar-brand .logo .icon{background:#ffffff1f;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:flex}.sidebar-brand .brand-text{white-space:nowrap}.sidebar-brand .logo span{opacity:.5;font-weight:300}.sidebar-collapse-btn{color:#fff;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff2e;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.72rem;font-weight:700;transition:background .15s,border-color .15s;display:inline-flex}.sidebar-collapse-btn:hover{background:#ffffff24;border-color:#ffffff47}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:16px 12px;display:flex;overflow-y:auto}.nav-section-label{letter-spacing:.1em;text-transform:uppercase;color:#ffffff4d;padding:16px 8px 6px;font-size:.65rem;font-weight:600}.nav-item{border-radius:var(--radius-sm);color:#ffffffa6;cursor:pointer;align-items:center;gap:10px;min-height:48px;padding:10px 12px;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex;overflow:hidden}.nav-item:hover{color:#fff;background:#ffffff12;text-decoration:none}.nav-item.active{color:#fff;background:#2563eb80}.nav-item .nav-icon{text-align:center;background:#ffffff1f;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.7rem;font-weight:700;display:inline-flex}.nav-item .nav-text{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 12px}.sidebar-logout{justify-content:flex-start;width:100%}.sidebar-logout-icon{background:#ffffff14;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.7rem;font-weight:700;display:inline-flex}.app-layout.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed-w)}.app-layout.sidebar-collapsed .main-content{margin-left:var(--sidebar-collapsed-w)}.app-layout.sidebar-collapsed .brand-text,.app-layout.sidebar-collapsed .nav-section-label,.app-layout.sidebar-collapsed .nav-text,.app-layout.sidebar-collapsed .sidebar-footer-text{display:none}.app-layout.sidebar-collapsed .sidebar-brand{padding-left:14px;padding-right:14px}.app-layout.sidebar-collapsed .sidebar-brand-row,.app-layout.sidebar-collapsed .sidebar-brand .logo{justify-content:center}.app-layout.sidebar-collapsed .sidebar-nav{padding-left:10px;padding-right:10px}.app-layout.sidebar-collapsed .nav-item{justify-content:center;padding-left:0;padding-right:0}.app-layout.sidebar-collapsed .sidebar-footer{padding-left:10px;padding-right:10px}.app-layout.sidebar-collapsed .sidebar-logout{justify-content:center;padding-left:0;padding-right:0}.app-layout.sidebar-collapsed .sidebar-collapse-btn{position:absolute;top:26px;right:10px}.main-content{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .3s;display:flex}.topbar{height:var(--topbar-h);background:var(--card);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0}.standalone-mode .topbar{height:calc(var(--topbar-h) + env(safe-area-inset-top,0px));padding-top:env(safe-area-inset-top,0px)}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-left h1{color:var(--text);letter-spacing:-.02em;font-family:Sora,sans-serif;font-size:1.1rem;font-weight:600}.topbar-left p{color:var(--muted);font-size:.8rem}.topbar-right{align-items:center;gap:12px;display:flex}.page-body{padding:28px;padding-bottom:calc(28px + env(safe-area-inset-bottom,0px));flex:1}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:24px}.card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.card-title{color:var(--text);letter-spacing:-.01em;font-family:Sora,sans-serif;font-size:.95rem;font-weight:600}.card-subtitle{color:var(--muted);margin-top:2px;font-size:.8rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px 24px;position:relative;overflow:hidden}.stat-card:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.stat-card.blue:before{background:var(--blue)}.stat-card.green:before{background:var(--green)}.stat-card.red:before{background:var(--red)}.stat-card.amber:before{background:var(--amber)}.stat-card.navy:before{background:var(--navy)}.stat-label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-size:.75rem;font-weight:600}.stat-value{color:var(--text);letter-spacing:-.03em;font-family:Sora,sans-serif;font-size:1.6rem;font-weight:700;line-height:1.1}.stat-value.positive{color:var(--green)}.stat-value.negative{color:var(--red)}.stat-sub{color:var(--muted);margin-top:4px;font-size:.8rem}.stat-icon{opacity:.12;font-size:28px;position:absolute;top:20px;right:20px}.grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:20px;display:grid}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}thead th{text-align:left;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px;font-size:.72rem;font-weight:600}tbody tr{border-bottom:1px solid var(--border);transition:background .12s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg)}tbody td{color:var(--text-2);padding:12px 14px}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-green{background:var(--green-lt);color:var(--green)}.badge-red{background:var(--red-lt);color:var(--red)}.badge-blue{background:var(--blue-lt);color:var(--blue)}.badge-amber{background:var(--amber-lt);color:var(--amber)}.badge-navy{color:var(--navy);background:#eff3fc}.badge-gray{color:var(--muted);background:#f1f5f9}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:9px 18px;font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:500;text-decoration:none;transition:opacity .15s,transform .1s,box-shadow .15s;display:inline-flex}.btn:active{transform:scale(.98)}.btn-primary{background:var(--blue);color:#fff;box-shadow:0 2px 8px #2563eb40}.btn-primary:hover{opacity:.9;color:#fff;text-decoration:none;box-shadow:0 4px 12px #2563eb59}.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{opacity:.9;color:#fff;text-decoration:none}.btn-outline{color:var(--text-2);border:1.5px solid var(--border);background:0 0}.btn-outline:hover{background:var(--bg);border-color:var(--border-2);color:var(--text);text-decoration:none}.btn-ghost{color:var(--muted);background:0 0;padding:6px 10px}.btn-ghost:hover{background:var(--bg);color:var(--text);text-decoration:none}.btn-danger{background:var(--red-lt);color:var(--red)}.btn-danger:hover{color:var(--red);background:#fee2e2;text-decoration:none}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-lg{padding:12px 24px;font-size:1rem}.btn:disabled{opacity:.45;cursor:not-allowed}.mobile-nav-toggle{display:none}.mobile-backdrop{z-index:90;background:#0f172a5c;display:none;position:fixed;inset:0}.mobile-backdrop.open{display:block}.table-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.checkbox-row{align-items:center;gap:10px;padding-top:8px;display:flex}.checkbox-row input[type=checkbox]{width:auto}.checkbox-row label{letter-spacing:normal;text-transform:none;margin:0;font-size:.85rem}.form-help{color:var(--muted);margin-top:6px;font-size:.8rem}.form-group{margin-bottom:16px}.form-row{gap:16px;display:grid}.form-row.cols-2{grid-template-columns:1fr 1fr}.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}label{letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-size:.78rem;font-weight:600;display:block}input,select,textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:var(--bg);outline:none;padding:10px 14px;font-family:DM Sans,sans-serif;font-size:.9rem;transition:border-color .2s,box-shadow .2s,background .2s}input:focus,select:focus,textarea:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px #2563eb1a}textarea{resize:vertical;min-height:80px}select{appearance:none;cursor:pointer}input::placeholder{color:var(--border-2)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0f172a66;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-md);width:100%;max-width:520px;max-height:90vh;animation:.2s modal-in;overflow-y:auto}.modal.modal-wide{max-width:780px}@keyframes modal-in{0%{opacity:0;transform:translateY(-12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{justify-content:space-between;align-items:center;padding:24px 24px 0;display:flex}.modal-title{letter-spacing:-.02em;font-family:Sora,sans-serif;font-size:1.05rem;font-weight:600}.modal-body{padding:20px 24px}.modal-footer{justify-content:flex-end;gap:10px;padding:0 24px 24px;display:flex}.btn-close{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:6px;padding:4px;font-size:20px;line-height:1;transition:background .15s}.btn-close:hover{background:var(--bg)}.tipo-toggle{gap:8px;margin-bottom:20px;display:flex}.tipo-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--muted);background:0 0;flex:1;padding:10px;font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:500;transition:all .15s}.tipo-btn.active{border-color:var(--blue);background:var(--blue-lt);color:var(--blue);font-weight:600}.progress-bar{background:var(--border);border-radius:99px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--blue), var(--navy));border-radius:99px;height:100%;transition:width .4s}.progress-fill.done{background:var(--green)}.progress-fill.warn{background:var(--amber)}.installment-preview{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.installment-chip{white-space:nowrap;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.installment-chip-paga{background:var(--green-lt);color:var(--green)}.installment-chip-atrasada{background:var(--red-lt);color:var(--red)}.installment-chip-pendente{color:var(--navy);background:#eff3fc}.installment-chip-neutral{color:var(--muted);border-color:var(--border);background:#f8fafc}.schedule-list{gap:10px;display:grid}.schedule-item{border:1px solid var(--border);border-radius:var(--radius-sm);background:#fbfdff;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.schedule-title{color:var(--text);font-weight:600}.schedule-subtitle{color:var(--muted);margin-top:3px;font-size:.82rem}.schedule-item-right{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.schedule-value{color:var(--text);font-family:Sora,sans-serif;font-size:.9rem;font-weight:600}.payment-summary{border:1px solid var(--border);border-radius:var(--radius-sm);background:linear-gradient(135deg,#f8fbff,#f1f5f9);margin-bottom:18px;padding:16px}.payment-summary-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.payment-summary-title{color:var(--text);font-weight:600}.payment-summary-subtitle{color:var(--muted);margin-top:4px;font-size:.82rem}.payment-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.payment-summary-card{border-radius:var(--radius-sm);background:#ffffffd1;border:1px solid #e2e8f0e6;padding:12px 14px}.payment-summary-label{letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-size:.72rem;font-weight:600}.payment-summary-value{color:var(--text);font-weight:600}.dashboard-alert{background:linear-gradient(135deg,#fff7ed,#fef2f2);border:1px solid #fed7aa;margin-bottom:20px}.alert-list{gap:10px;display:grid}.alert-item{border-radius:var(--radius-sm);background:#ffffffb8;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.alert-title{color:var(--text);font-weight:600}.alert-subtitle{color:var(--muted);margin-top:2px;font-size:.82rem}.status-stack{gap:6px;display:grid}.status-helper{font-size:.78rem;font-weight:600;line-height:1.35}.filters-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.filter-chip{border:1.5px solid var(--border);cursor:pointer;color:var(--muted);background:0 0;border-radius:20px;padding:6px 14px;font-size:.8rem;font-weight:500;transition:all .15s}.filter-chip.active{background:var(--blue);border-color:var(--blue);color:#fff}.filter-chip:hover:not(.active){border-color:var(--border-2);color:var(--text)}.empty-state{text-align:center;color:var(--muted);padding:48px 20px}.empty-state .empty-icon{opacity:.4;margin-bottom:12px;font-size:40px}.empty-state p{font-size:.9rem}#toast-container{bottom:calc(24px + env(safe-area-inset-bottom,0px));right:calc(24px + env(safe-area-inset-right,0px));z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed}.toast{background:var(--text);color:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-md);max-width:300px;padding:12px 18px;font-size:.875rem;animation:.2s toast-in}.toast.success{background:var(--green)}.toast.error{background:var(--red)}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.skeleton{background:linear-gradient(90deg, var(--border) 25%, var(--bg) 50%, var(--border) 75%);background-size:200% 100%;border-radius:6px;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (width<=768px){.sidebar{width:var(--sidebar-w);transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.app-layout.sidebar-collapsed .sidebar{width:var(--sidebar-w)}.app-layout.sidebar-collapsed .main-content{margin-left:0}.app-layout.sidebar-collapsed .brand-text,.app-layout.sidebar-collapsed .nav-section-label,.app-layout.sidebar-collapsed .nav-text{display:block}.app-layout.sidebar-collapsed .sidebar-footer-text{display:inline}.app-layout.sidebar-collapsed .sidebar-brand-row{justify-content:space-between}.app-layout.sidebar-collapsed .sidebar-brand .logo,.app-layout.sidebar-collapsed .nav-item,.app-layout.sidebar-collapsed .sidebar-logout{justify-content:flex-start}.app-layout.sidebar-collapsed .sidebar-collapse-btn{position:static}.page-body{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.grid-2,.grid-3,.form-row.cols-2,.form-row.cols-3{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.mobile-nav-toggle{display:inline-flex}.schedule-item,.alert-item{flex-direction:column;align-items:flex-start}.schedule-item-right{justify-content:flex-start}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.topbar{padding:0 16px;padding-left:calc(16px + env(safe-area-inset-left,0px));padding-right:calc(16px + env(safe-area-inset-right,0px))}}.text-green{color:var(--green)!important}.text-red{color:var(--red)!important}.text-blue{color:var(--blue)!important}.text-muted{color:var(--muted)!important}.text-right{text-align:right}.text-center{text-align:center}.fw-bold{font-weight:600}.font-sora{font-family:Sora,sans-serif}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.flex{display:flex}.flex-center{align-items:center;display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.hidden{display:none!important}.page-stack{flex-direction:column;gap:20px;display:flex}.page-stack.compact{gap:16px}.page-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.toolbar-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.list-stack{flex-direction:column;gap:10px;display:flex}.list-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:16px;padding:14px 0;display:flex}.list-row:last-child{border-bottom:none}.list-title{color:var(--text);font-weight:600}.list-subtitle,.list-muted,.table-secondary{color:var(--muted);font-size:.84rem}.list-right{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.list-value,.summary-value{color:var(--text);font-weight:700}.table-primary{font-weight:600}.modal-form{flex-direction:column;gap:16px;display:flex}.checkbox-line{color:var(--text-2);align-items:center;gap:10px;font-size:.9rem;display:inline-flex}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.summary-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:16px}.summary-label{color:var(--muted);margin-bottom:6px;font-size:.8rem}.status-stack{flex-direction:column;align-items:flex-start;gap:6px;display:flex}.status-helper{font-size:.76rem;font-weight:600}.status-helper.success{color:var(--green)}.status-helper.warning{color:var(--amber)}.status-helper.danger{color:var(--red)}.status-helper.muted{color:var(--muted)}.login-screen{background:radial-gradient(circle at 100% 0,#2563eb29,#0000 32%),linear-gradient(135deg,#f3f6fb 0%,#eef3ff 52%,#fff 100%);grid-template-columns:1.15fr .85fr;min-height:100vh;display:grid}.login-hero{color:#fff;background:linear-gradient(155deg,#16345f 0%,#1d4a87 52%,#2563eb 100%);flex-direction:column;justify-content:space-between;padding:56px;display:flex}.login-brand{align-items:center;gap:12px;font-family:Sora,sans-serif;font-size:1.15rem;font-weight:700;display:flex}.login-brand-icon{background:#ffffff24;border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;display:inline-flex}.login-brand-text span{opacity:.55;font-weight:300}.login-copy{flex-direction:column;gap:16px;max-width:520px;display:flex}.login-copy h1{letter-spacing:-.04em;font-family:Sora,sans-serif;font-size:clamp(2rem,5vw,3.3rem);line-height:1.05}.login-copy p{color:#ffffffd1;max-width:460px;font-size:1rem}.login-eyebrow{text-transform:uppercase;letter-spacing:.14em;color:#ffffff94;font-size:.78rem}.login-highlights{flex-wrap:wrap;gap:12px;display:flex}.login-highlight{background:#ffffff14;border:1px solid #ffffff24;border-radius:999px;padding:10px 14px;font-size:.84rem}.login-card{flex-direction:column;justify-content:center;gap:26px;width:100%;max-width:520px;margin:0 auto;padding:56px;display:flex}.login-card h2{letter-spacing:-.04em;font-family:Sora,sans-serif;font-size:2rem}.login-subtitle{color:var(--muted);margin-top:6px}.login-form{flex-direction:column;gap:18px;display:flex}.password-field{position:relative}.password-field input{padding-right:90px}.password-toggle{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:.82rem;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.btn-login-react{border-radius:12px;width:100%;min-height:52px;font-family:Sora,sans-serif}.login-error{color:var(--red);background:#fff1f2;border:1px solid #fecaca;border-radius:12px;padding:12px 14px;font-size:.9rem}@media (width<=980px){.login-screen{grid-template-columns:1fr}.login-hero{gap:28px;padding:32px 24px 24px}.login-card{padding:32px 24px 48px}}@media (width<=768px){.summary-grid{grid-template-columns:1fr}.page-toolbar{align-items:stretch}.toolbar-actions{width:100%}.toolbar-actions>*{flex:100%}}
