@import "https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;600;700;800&display=swap";
:root{--primary-900:#1e3a8a;--primary-800:#1e40af;--primary-700:#1d4ed8;--primary-600:#2563eb;--primary-500:#3b82f6;--primary-400:#60a5fa;--primary-300:#93c5fd;--primary-200:#bfdbfe;--primary-100:#dbeafe;--primary-50:#eff6ff;--green-900:var(--primary-900);--green-800:var(--primary-800);--green-700:var(--primary-700);--green-600:var(--primary-600);--green-500:var(--primary-500);--green-400:var(--primary-400);--green-300:var(--primary-300);--green-200:var(--primary-200);--green-100:var(--primary-100);--green-50:var(--primary-50);--blue-900:var(--primary-900);--blue-800:var(--primary-800);--blue-700:var(--primary-700);--blue-600:var(--primary-600);--blue-500:var(--primary-500);--blue-400:var(--primary-400);--blue-300:var(--primary-300);--blue-200:var(--primary-200);--blue-100:var(--primary-100);--blue-50:var(--primary-50);--white:#fff;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--status-paid:#059669;--status-paid-bg:#d1fae5;--status-partial:#d97706;--status-partial-bg:#fef3c7;--status-unpaid:#dc2626;--status-unpaid-bg:#fee2e2;--status-overdue:#b91c1c;--status-overdue-bg:#fee2e2;--status-draft:#6b7280;--status-draft-bg:#f3f4f6;--status-compliant:#059669;--status-compliant-bg:#d1fae5;--status-at-risk:#d97706;--status-at-risk-bg:#fef3c7;--status-expired:#dc2626;--status-expired-bg:#fee2e2;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000000d;--sidebar-width:260px;--sidebar-collapsed:72px;--topbar-height:64px;--border-radius:12px;--border-radius-sm:8px;--border-radius-xs:6px;--border-radius-full:9999px;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{scroll-behavior:smooth;scrollbar-gutter:stable;width:100%;position:relative}body{color:var(--gray-700);background-color:#f3f4f6;font-family:Roboto,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:400;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}img{max-width:100%;height:auto;display:block}.relative{position:relative}.absolute{position:absolute}.mobile-only{display:none}.desktop-only{display:block}@media (max-width:768px){.mobile-only{display:block}.desktop-only{display:none}.mobile-hide{display:none!important}:root{--sidebar-width:0px}}.entity-card-details{color:var(--gray-500);grid-template-columns:1fr 1fr;gap:8px 16px;font-size:.82rem;display:grid}@media (max-width:480px){.entity-card-details{grid-template-columns:1fr;gap:8px}}button,.btn,.sidebar-nav-link,.sidebar-logout{min-height:44px}@media (max-width:640px){.btn{width:100%}.btn-sm{width:auto}}h1,h2,h3,h4,h5,h6{color:var(--gray-900);font-weight:600;line-height:1.3}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}h5{font-size:1rem}h6,.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-muted{color:var(--gray-500)}.text-primary{color:var(--primary-700)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.app-shell{min-height:100vh;display:flex}.main-wrapper{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .4s cubic-bezier(.4,0,.2,1);display:flex}.main-content{margin-top:var(--topbar-height);transition:padding var(--transition-base);flex:1;padding:32px;overflow-y:auto}@media (max-width:1024px){.main-content{padding:24px}}@media (max-width:768px){.main-content{margin-top:calc(var(--topbar-height) - 4px);padding:16px}}.sidebar{width:var(--sidebar-width);background:var(--white);border-right:1px solid var(--gray-200);z-index:100;-ms-overflow-style:none;scrollbar-width:none;flex-direction:column;transition:transform .4s cubic-bezier(.4,0,.2,1),left .4s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar::-webkit-scrollbar{display:none}.sidebar-logo{border-bottom:1px solid var(--gray-50);align-items:center;gap:14px;padding:24px;display:flex}.sidebar-logo-icon{background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.sidebar-logo-text h2{color:var(--gray-900);font-size:.95rem;font-weight:700;line-height:1.2}.sidebar-logo-text span{color:var(--gray-400);letter-spacing:.02em;font-size:.7rem;font-weight:400}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:8px 12px;display:flex}.sidebar-nav-link{color:#64748b;transition:all var(--transition-base);background:0 0;border:none;border-radius:12px;align-items:center;gap:12px;width:100%;margin-bottom:2px;padding:8px 16px;font-size:.88rem;font-weight:500;display:flex}.sidebar-nav-link:hover{color:var(--primary-700);background:#f1f5f9}.sidebar-nav-link.active{background:var(--primary-50);color:var(--primary-700);box-shadow:none;font-weight:600}.sidebar-nav-link.active svg{color:var(--primary-700)}.sidebar-nav-link svg{color:#64748b;width:24px;height:24px;transition:all var(--transition-fast);flex-shrink:0}.sidebar-nav-link:hover svg{color:var(--primary-600)}.page-header h1{color:#1a202c;letter-spacing:-.01em;font-size:1.5rem;font-weight:800}.sidebar-footer{border-top:1px solid var(--gray-100);align-items:center;gap:12px;padding:16px;display:flex}.sidebar-avatar{border-radius:var(--border-radius-full);background:var(--green-100);width:36px;height:36px;color:var(--green-800);flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:600;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-info .name{color:var(--gray-900);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.sidebar-user-info .role{color:var(--gray-400);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem;font-weight:500}.sidebar-logout{color:var(--gray-400);border-radius:var(--border-radius-xs);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;display:flex}.sidebar-logout:hover{background:var(--gray-100);color:var(--gray-700)}.topbar{top:0;right:0;left:var(--sidebar-width);height:var(--topbar-height);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-200);z-index:40;background:#fffc;justify-content:space-between;align-items:center;padding:0 40px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed}@media (max-width:1024px){.topbar{padding:0 24px}}.topbar-title{color:var(--gray-900);font-size:1.25rem;font-weight:600}.topbar-actions{align-items:center;gap:16px;display:flex}.topbar-user-profile{border-left:1px solid var(--gray-100);cursor:pointer;align-items:center;gap:12px;padding-left:20px;transition:opacity .2s;display:flex}.topbar-user-profile:hover{opacity:.8}.user-text{text-align:right}.user-name{color:var(--gray-900);font-size:.875rem;font-weight:600;display:block}@media (max-width:640px){.topbar-user-profile{border-left:none;padding-left:0}.user-text{display:none}}.mobile-menu-btn,.mobile-close-btn{display:none}@media (max-width:768px){.mobile-menu-btn,.mobile-close-btn{display:flex}.sidebar{transform:translate(-100%);box-shadow:20px 0 50px #0000001a;width:280px!important}.sidebar.open{transform:translate(0)}.sidebar.open .sidebar-logo-text,.sidebar.open .sidebar-nav-link span,.sidebar.open .sidebar-user-info{display:block!important}.sidebar.open .sidebar-nav-link{justify-content:flex-start!important;padding:12px 16px!important}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;background:#0006;animation:.2s fadeIn;position:fixed;inset:0}.topbar{padding:0 12px;left:0}.topbar-actions{gap:8px}.topbar-actions .badge{display:none}.main-wrapper{width:100%;max-width:100vw;overflow-x:hidden;margin-left:0!important}.main-content{padding:16px}.topbar-search{display:none}.mobile-menu-btn{background:var(--gray-50);border:1px solid var(--gray-200);width:40px;height:40px;color:var(--gray-600);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;display:flex}.mobile-close-btn{background:var(--gray-100);width:32px;height:32px;color:var(--gray-500);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;margin-left:auto;display:flex}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.topbar-search{width:280px;position:relative}.topbar-search input{border:1px solid var(--gray-200);border-radius:var(--border-radius-full);background:var(--gray-50);width:100%;color:var(--gray-700);transition:all var(--transition-fast);outline:none;padding:8px 14px 8px 38px;font-size:.875rem}.topbar-search input:focus{border-color:var(--primary-600);background:var(--white);box-shadow:0 0 0 3px #2563eb1a}.topbar-search svg{color:var(--gray-400);width:16px;height:16px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.topbar-icon-btn{border-radius:var(--border-radius-sm);width:40px;height:40px;color:var(--gray-500);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:relative}.topbar-icon-btn:hover{background:var(--gray-100);color:var(--gray-700)}.topbar-icon-btn .badge{background:var(--status-unpaid);border:2px solid var(--white);border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.topbar-icon-btn.logout-btn:hover{color:#dc2626!important;background:#fef2f2!important}.btn{border-radius:var(--border-radius-sm);transition:all var(--transition-fast);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:500;display:inline-flex}.btn-primary{background:var(--primary-800);color:var(--white)}.btn-primary:hover{background:var(--primary-700);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:hover{background:var(--gray-50);border-color:var(--gray-300)}.btn-outline{color:var(--primary-800);border:1px solid var(--primary-800);background:0 0}.btn-outline:hover{background:var(--primary-50)}.btn-danger{background:var(--status-unpaid);color:var(--white)}.btn-danger:hover{background:var(--status-overdue)}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:12px 28px;font-size:1rem}.btn-icon{width:36px;height:36px;padding:8px}.card{background:var(--white);border:1px solid #e5e7eb80;border-radius:16px;transition:transform .2s,box-shadow .2s;overflow:hidden;box-shadow:0 4px 20px -4px #0000000d}@media (max-width:768px){.page-header{flex-direction:column;align-items:stretch;gap:16px}}.card:hover{box-shadow:0 10px 25px -5px #00000014}.card-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}@media (max-width:640px){.card-header{flex-direction:column;align-items:flex-start}}.card-body{padding:20px}.card-footer{border-top:1px solid var(--gray-100);background:var(--gray-50);padding:12px 20px}@media (max-width:768px){.grid-2,.grid-3,.grid-4,.stats-grid{grid-template-columns:1fr!important}}@media (max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.stat-card{background:var(--white);border:1px solid #e5e7eb80;border-radius:16px;padding:24px;transition:transform .2s;box-shadow:0 4px 15px #00000008}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card-label{color:#000;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:.75rem;font-weight:700}.stat-card-value{color:#000;font-size:1.75rem;font-weight:850;line-height:1.2}.stat-card-trend{align-items:center;gap:4px;margin-top:8px;font-size:.8rem;font-weight:500;display:flex}.stat-card-trend.up{color:var(--status-compliant)}.stat-card-trend.down{color:var(--status-unpaid)}.stat-card--primary{background:var(--primary-50);border:none}.stat-card--primary .stat-card-value{color:#000}.badge{border-radius:var(--border-radius-full);letter-spacing:.02em;text-transform:uppercase;align-items:center;gap:4px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-paid{background:var(--status-paid-bg);color:var(--status-paid)}.badge-partial{background:var(--status-partial-bg);color:var(--status-partial)}.badge-unpaid{background:var(--status-unpaid-bg);color:var(--status-unpaid)}.badge-overdue{background:var(--status-overdue-bg);color:var(--status-overdue)}.badge-draft{background:var(--status-draft-bg);color:var(--status-draft)}.badge-compliant{background:var(--status-compliant-bg);color:var(--status-compliant)}.badge-at-risk{background:var(--status-at-risk-bg);color:var(--status-at-risk)}.badge-expired{background:var(--status-expired-bg);color:var(--status-expired)}.badge-primary{background:var(--primary-100);color:var(--primary-800)}.badge-role{background:var(--primary-50);color:var(--primary-800);border:1px solid var(--primary-200)}.data-table-wrapper{-webkit-overflow-scrolling:touch;scrollbar-width:none;margin:0 -4px;padding:4px;overflow-x:auto}.data-table-wrapper::-webkit-scrollbar{display:none}.data-table-wrapper:after{content:"";pointer-events:none;opacity:0;background:linear-gradient(270deg,#fffc,#0000);width:40px;transition:opacity .3s;position:absolute;top:0;bottom:0;right:0}@media (max-width:768px){.data-table-wrapper:after{opacity:1}}.data-table{border-collapse:separate;border-spacing:0 12px;width:100%;font-size:.875rem}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-400);border-bottom:none;padding:8px 24px;font-size:.72rem;font-weight:600}.data-table td{background:var(--white);border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);color:var(--gray-700);vertical-align:middle;padding:16px 24px;transition:background .2s}.data-table td:first-child{border-left:1px solid var(--gray-100);border-top-left-radius:12px;border-bottom-left-radius:12px}.data-table td:last-child{border-right:1px solid var(--gray-100);border-top-right-radius:12px;border-bottom-right-radius:12px}.data-table tr:hover td{background:#f8fafc}.data-table-card-row td{box-shadow:0 2px 4px #00000005}.form-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.form-label{color:var(--gray-700);font-size:.85rem;font-weight:500}.form-input,.form-select{border:1.5px solid var(--gray-200);border-radius:var(--border-radius-sm);width:100%;height:48px;color:var(--gray-900);background:var(--white);transition:all var(--transition-base);outline:none;padding:10px 16px;font-size:.9rem}.form-input:focus,.form-select:focus{border-color:var(--primary-600);background:var(--white);box-shadow:0 0 0 4px #2563eb1a}.form-input::placeholder{color:var(--gray-400)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#1e293b66;justify-content:center;align-items:center;width:100%;height:100%;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;top:0;left:0;overflow:hidden}.modal-content{background:var(--white);border-radius:var(--border-radius);width:90%;max-width:600px;max-height:90vh;box-shadow:var(--shadow-xl);animation:.25s slideUp;overflow-y:auto}.invoice-preview-modal .modal-content{max-width:950px}.modal-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{font-size:1.1rem;font-weight:600}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--gray-200);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.tabs{border-bottom:2px solid var(--gray-200);gap:0;display:flex;overflow-x:auto}.tab{color:var(--gray-500);transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:12px 20px;font-size:.875rem;font-weight:500}.tab:hover{color:var(--gray-700)}.tab.active{color:var(--green-800);border-bottom-color:var(--green-800);font-weight:600}.search-input-wrapper{width:100%;max-width:360px;position:relative}.search-input-wrapper svg{color:var(--gray-400);width:18px;height:18px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-input-wrapper input{border:1px solid var(--gray-200);border-radius:var(--border-radius-sm);background:var(--white);width:100%;transition:all var(--transition-fast);outline:none;padding:10px 14px 10px 42px;font-size:.875rem}.search-input-wrapper input:focus{border-color:var(--green-600);box-shadow:0 0 0 3px #16a34a1a}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state-icon{background:var(--green-50);width:64px;height:64px;color:var(--green-600);border-radius:var(--border-radius-full);justify-content:center;align-items:center;margin-bottom:16px;display:flex}.empty-state h3{color:var(--gray-700);margin-bottom:8px}.empty-state p{color:var(--gray-500);max-width:400px;margin-bottom:20px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h1{font-size:1.5rem}.page-header-actions{align-items:center;gap:10px;display:flex}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.filter-chip{border:1px solid var(--gray-200);border-radius:var(--border-radius-full);color:var(--gray-600);background:var(--white);cursor:pointer;transition:all var(--transition-fast);padding:6px 14px;font-size:.8rem;font-weight:500}.filter-chip:hover{border-color:var(--green-600);color:var(--green-700)}.filter-chip.active{background:var(--green-800);color:var(--white);border-color:var(--green-800)}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.timeline{padding-left:28px;position:relative}.timeline:before{content:"";background:var(--gray-200);width:2px;position:absolute;top:0;bottom:0;left:8px}.timeline-item{padding-bottom:24px;position:relative}.timeline-item:before{content:"";background:var(--green-600);border:2px solid var(--white);width:12px;height:12px;box-shadow:0 0 0 2px var(--green-200);border-radius:50%;position:absolute;top:6px;left:-24px}.timeline-item-date{color:var(--gray-400);margin-bottom:4px;font-size:.75rem}.timeline-item-title{color:var(--gray-800);margin-bottom:2px;font-size:.9rem;font-weight:500}.timeline-item-desc{color:var(--gray-500);font-size:.82rem}.notification-item{border-bottom:1px solid var(--gray-100);transition:background var(--transition-fast);cursor:pointer;gap:14px;padding:14px 18px;display:flex}.notification-item:hover{background:var(--gray-50)}.notification-item.unread{background:var(--green-50)}.notification-item.unread:hover{background:var(--green-100)}.notification-icon{border-radius:var(--border-radius-full);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;display:flex}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.p-4{padding:16px}.w-full{width:100%}.text-center{text-align:center}.text-right{text-align:right}.data-table input[type=number],.data-table input[type=text].num-input{font-variant-numeric:tabular-nums;box-sizing:border-box;min-width:0;height:40px;text-align:right!important;appearance:textfield!important;width:100%!important;padding-left:8px!important;padding-right:50px!important}.data-table .form-input{font-variant-numeric:tabular-nums;height:40px!important;box-shadow:none!important;border-radius:0!important;transition:none!important}.data-table .form-input:focus{outline:2px solid var(--primary-200);outline-offset:-2px;box-shadow:none!important;border-color:#0000!important}.data-table td:has(input[type=number]){padding:4px 0 4px 4px!important}.data-table input[type=number]::-webkit-outer-spin-button{margin:0;display:none;appearance:none!important}.data-table input[type=number]::-webkit-inner-spin-button{margin:0;display:none;appearance:none!important}.data-table tfoot td,.data-table tbody tr:last-child td{font-variant-numeric:tabular-nums}.data-table tfoot td:nth-child(2),.data-table tfoot td:nth-child(3){text-align:right!important;padding-right:24px!important}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.animate-slide-up{animation:.3s slideUp}.recharts-cartesian-axis-tick-value{fill:var(--gray-500)!important;font-size:.75rem!important}.mobile-nav{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--gray-200);z-index:50;background:#ffffffd9;justify-content:space-around;align-items:center;height:64px;padding:0 8px;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000d}.mobile-nav-item{color:var(--gray-400);border-radius:var(--border-radius-xs);transition:all var(--transition-fast);background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:6px 10px;font-size:.65rem;font-weight:500;display:flex}.mobile-nav-item.active{color:var(--green-800)}.mobile-nav-item svg{width:22px;height:22px}.mobile-more-overlay{z-index:60;background:#0000004d;justify-content:center;align-items:flex-end;padding-bottom:72px;display:flex;position:fixed;inset:0}.mobile-more-menu{background:var(--white);border-radius:12px 12px 0 0;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;padding:16px;animation:.25s slideUp;display:grid;box-shadow:0 -4px 20px #0000001a}.mobile-more-item{border-radius:var(--border-radius-sm);color:var(--gray-500);transition:all var(--transition-fast);flex-direction:column;align-items:center;gap:6px;padding:14px 8px;font-size:.75rem;font-weight:500;text-decoration:none;display:flex}.mobile-more-item:hover,.mobile-more-item.active{background:var(--green-50);color:var(--green-800)}.quick-actions{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.quick-action-btn{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--border-radius-sm);color:var(--gray-700);transition:all var(--transition-fast);cursor:pointer;align-items:center;gap:10px;padding:14px 16px;font-size:.85rem;font-weight:500;display:flex}.quick-action-btn:hover{border-color:var(--green-600);background:var(--green-50);color:var(--green-800)}.quick-action-btn svg{width:20px;height:20px;color:var(--green-600)}.year-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--border-radius);text-align:center;cursor:pointer;transition:all var(--transition-fast);padding:20px}.year-card:hover{border-color:var(--green-600);box-shadow:var(--shadow-md)}.year-card-year{color:var(--gray-900);margin-bottom:4px;font-size:1.5rem;font-weight:700}.year-card-count{color:var(--gray-500);font-size:.82rem}.service-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--border-radius);transition:all var(--transition-fast);padding:24px}.service-card:hover{box-shadow:var(--shadow-md);border-color:var(--green-300)}.service-card-icon{background:var(--green-50);width:44px;height:44px;color:var(--green-700);border-radius:var(--border-radius-sm);justify-content:center;align-items:center;margin-bottom:14px;display:flex}.service-card h4{margin-bottom:6px}.service-card p{color:var(--gray-500);margin-bottom:14px;font-size:.82rem;line-height:1.5}.service-card-meta{color:var(--gray-500);justify-content:space-between;align-items:center;font-size:.8rem;display:flex}.service-card-price{color:var(--green-800);font-weight:600}@media (max-width:1023px){.sidebar{width:var(--sidebar-collapsed)}.sidebar-logo-text,.sidebar-nav-link span,.sidebar-user-info{display:none}.sidebar-nav-link{justify-content:center;padding:12px}.main-wrapper{margin-left:var(--sidebar-collapsed)}.topbar{left:var(--sidebar-collapsed)}.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:767px){.mobile-nav{display:flex}.main-wrapper{margin-left:0}.main-content{padding:16px 16px 80px}.topbar{left:0}.topbar-search{display:none}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.page-header{flex-direction:column;align-items:flex-start}.filter-bar{flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.data-table-wrapper{margin:0 -16px;padding:0 16px}.quick-actions{grid-template-columns:1fr 1fr}}@media (max-width:480px){.stats-grid,.quick-actions{grid-template-columns:1fr}}.selection-container{background:#f8fafc;justify-content:center;align-items:center;min-height:100vh;font-family:Roboto,sans-serif;display:flex;position:relative;overflow:hidden}.selection-overlay{z-index:1;background:radial-gradient(circle,#0d6b3f0d 0%,#fff0 70%);border-radius:50%;width:40%;height:60%;position:absolute;top:-10%;right:-10%}.selection-content{z-index:2;text-align:center;width:100%;max-width:900px;padding:40px 20px;position:relative}.selection-header{margin-bottom:60px;animation:.6s ease-out fadeInDown}.selection-logo{color:#fff;background:#0d6b3f;border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 20px;display:flex;box-shadow:0 10px 25px #0d6b3f33}.selection-header h1{color:#0f172a;letter-spacing:-.02em;margin-bottom:8px;font-size:2.5rem;font-weight:800}.selection-header p{color:#64748b;font-size:1.1rem;font-weight:400}.selection-grid{grid-template-columns:repeat(2,1fr);gap:30px;margin-bottom:60px;display:grid}.role-card{text-align:left;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:24px;flex-direction:column;padding:40px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.role-card:hover{border-color:#cbd5e1;transform:translateY(-8px);box-shadow:0 20px 40px #00000014}.role-icon-wrapper{border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:24px;transition:transform .3s;display:flex}.role-card:hover .role-icon-wrapper{transform:scale(1.05)rotate(-5deg)}.role-info h3{color:#1e293b;margin-bottom:12px;font-size:1.5rem;font-weight:700}.role-info p{color:#64748b;margin-bottom:30px;font-size:.95rem;line-height:1.6}.role-action{color:#0f172a;align-items:center;gap:8px;margin-top:auto;font-size:.9rem;font-weight:600;transition:gap .2s;display:flex}.role-card:hover .role-action{color:#0d6b3f;gap:12px}.selection-footer{color:#94a3b8;font-size:.85rem}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.selection-grid{grid-template-columns:1fr}.role-card{padding:30px}}.portal-welcome{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.portal-welcome h1{margin-bottom:4px;font-size:1.75rem}.portal-welcome p{color:var(--gray-500)}.portal-list-item{border-bottom:1px solid var(--gray-100);align-items:center;padding:12px 16px;transition:background .2s;display:flex}.portal-list-item:hover{background:var(--gray-50)}.portal-list-item:last-child{border-bottom:none}.portal-list-icon{background:var(--gray-100);width:36px;height:36px;color:var(--gray-600);border-radius:8px;justify-content:center;align-items:center;margin-right:12px;display:flex}.text-blue-600{color:#2563eb}.service-status-header{justify-content:space-between;align-items:flex-start;display:flex}.status-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.status-progress{color:#4f46e5;background:#eef2ff}.status-overdue{color:#dc2626;background:#fef2f2}.status-done{color:#059669;background:#ecfdf5}.service-details-grid{background:var(--gray-50);border-radius:8px;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;padding:12px;display:grid}.detail-item{flex-direction:column;display:flex}.detail-label{color:#000;text-transform:uppercase;letter-spacing:.02em;font-size:.7rem;font-weight:700}.detail-val{color:#000;font-size:.8rem;font-weight:800}.progress-bar-container{margin-top:12px}.progress-bar-label{color:var(--gray-500);justify-content:space-between;margin-bottom:6px;font-size:.75rem;display:flex}.progress-bar-bg{background:#e2e8f0;border-radius:3px;height:6px;overflow:hidden}.progress-bar-fill{border-radius:3px;height:100%}.bg-blue{background:#2563eb}.bg-red{background:#dc2626}@media print{@page{size:A4;margin:10mm}body *{visibility:hidden!important}#printable-invoice,#printable-invoice *,#printable-audit-deck,#printable-audit-deck *,#printable-report,#printable-report *,.modal-overlay,.modal-content,.main-content,.main-wrapper,.app-shell,body,html{visibility:visible!important}#printable-invoice,#printable-audit-deck,#printable-report{background:#fff!important;width:210mm!important;margin:0!important;padding:10mm!important;display:block!important;position:absolute!important;top:0!important;left:0!important}.modal-overlay,.modal-content,.main-content,.main-wrapper,.app-shell,body,html{box-shadow:none!important;background:0 0!important;border:none!important;margin:0!important;padding:0!important;display:block!important;overflow:visible!important}nav,aside,header,.sidebar,.topbar,.page-header-actions,.tabs,.no-print,.hide-on-print,button:not(.btn-show-print){visibility:hidden!important;display:none!important}#printable-report .stats-grid,#printable-report .data-table-wrapper,#printable-report .grid-2,#printable-report .card{visibility:visible!important;grid-template-columns:repeat(2,1fr)!important;margin-bottom:20px!important;display:block!important}#printable-report .stats-grid{grid-template-columns:repeat(3,1fr)!important;gap:15px!important;display:grid!important}:is(#printable-report .card-body:has(.recharts-responsive-container),#printable-report .recharts-responsive-container){display:none!important}.data-table td,.data-table th{padding:8px!important;font-size:10pt!important}#printable-invoice{min-height:auto!important;max-height:280mm!important}.print-only{visibility:visible!important;display:block!important}*{visibility:inherit;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}.print-only,.hide-on-screen{display:none}@media print{.hide-on-screen{display:block!important}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}.animate-fade-in{animation:.4s ease-out forwards fadeIn}
