@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f2f8;--bg-subtle:#e8ebf3;--sidebar-bg:linear-gradient(180deg, #0f172a 0%, #1e293b 100%);--sidebar-text:#94a3b8;--sidebar-active:linear-gradient(135deg, #3b82f6 0%, #6366f1 100%);--card-bg:#fff;--card-hover:#fafbff;--text:#0f172a;--text-muted:#64748b;--border:#e2e8f0;--border-subtle:#f1f5f9;--red:#ef4444;--red-soft:#fef2f2;--red-text:#991b1b;--yellow:#f59e0b;--yellow-soft:#fffbeb;--yellow-text:#92400e;--green:#10b981;--green-soft:#ecfdf5;--green-text:#065f46;--blue:#3b82f6;--blue-soft:#eff6ff;--blue-text:#1e40af;--purple:#8b5cf6;--input-bg:#fff;--shadow-sm:0 1px 2px #0000000a, 0 1px 3px #0000000f;--shadow-md:0 4px 6px -1px #0000000f, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--shadow-card:0 1px 3px #0000000a, 0 4px 12px #0000000a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--transition:.2s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg:#0c111d;--bg-subtle:#141b2d;--sidebar-bg:linear-gradient(180deg, #020617 0%, #0f172a 100%);--sidebar-text:#64748b;--sidebar-active:linear-gradient(135deg, #2563eb 0%, #7c3aed 100%);--card-bg:#1a2236;--card-hover:#1e2940;--text:#e2e8f0;--text-muted:#64748b;--border:#293548;--border-subtle:#1e293b;--red-soft:#2d1215;--red-text:#fca5a5;--yellow-soft:#2d2305;--yellow-text:#fcd34d;--green-soft:#052e16;--green-text:#86efac;--blue-soft:#172554;--blue-text:#93c5fd;--input-bg:#1e293b;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 6px #00000040;--shadow-lg:0 10px 25px #0000004d;--shadow-card:0 2px 8px #0003}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}.app-layout{min-height:100vh;display:flex}.main-content{flex:1;max-width:1400px;padding:2rem 2.5rem;overflow-y:auto}.sidebar{background:var(--sidebar-bg);width:260px;color:var(--sidebar-text);border-right:1px solid #ffffff0d;flex-direction:column;flex-shrink:0;height:100vh;display:flex;position:sticky;top:0}.sidebar-header{border-bottom:1px solid #ffffff0f;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 1.5rem .75rem;display:flex}.sidebar-logo{object-fit:contain;filter:brightness(0)invert();width:97px;height:auto}.sidebar-header h2{color:#fff;letter-spacing:-.02em;background:linear-gradient(135deg,#fff 0%,#94a3b8 100%);-webkit-text-fill-color:transparent;text-align:center;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1rem;font-weight:800}.sidebar-header .theme-toggle{gap:.35rem;margin:0;padding:.3rem .6rem;font-size:.75rem}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:.75rem;display:flex}.sidebar-link{color:var(--sidebar-text);transition:all var(--transition);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.65rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{color:#e2e8f0;background:#ffffff0f}.sidebar-link.active{background:var(--sidebar-active);color:#fff;font-weight:600;box-shadow:0 2px 8px #3b82f64d}.sidebar-group{margin-top:.25rem}.sidebar-group-header{color:#94a3b8b3;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;background:0 0;border:none;align-items:center;gap:.65rem;width:100%;padding:.5rem 1rem;font-size:.7rem;font-weight:700;transition:color .15s;display:flex}.sidebar-group-header:hover{color:#e2e8f0e6}.sidebar-group-header svg:last-child{opacity:.5;margin-left:auto}.sidebar-group-links{flex-direction:column;gap:1px;display:flex}.sidebar-sublink{padding-left:2.2rem!important;font-size:.825rem!important}.logout-btn{border-top:1px solid #ffffff0f;border-radius:0;margin-top:auto}.theme-toggle{color:var(--sidebar-text);cursor:pointer;width:calc(100% - 1.5rem);transition:all var(--transition);border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:.75rem;margin:0 .75rem;padding:.65rem 1rem;font-size:.875rem;font-weight:500;display:flex}.theme-toggle:hover{color:#e2e8f0;background:#ffffff0f}.login-page{background:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,#334155 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle,#3b82f626 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-200px;right:-200px}.login-page:after{content:"";background:radial-gradient(circle,#8b5cf61f 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-100px;left:-100px}.login-form{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);z-index:1;background:#fffffff2;border:1px solid #fff3;flex-direction:column;gap:1rem;width:100%;max-width:420px;padding:3rem;display:flex;position:relative;box-shadow:0 25px 50px -12px #0006}[data-theme=dark] .login-form{background:#1a2236e6;border-color:#ffffff0d}.login-logo{object-fit:contain;width:160px;height:160px;margin:0 auto;display:block}.login-form h1{text-align:center;letter-spacing:-.03em;background:linear-gradient(135deg,#1e293b 0%,#3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:0;font-size:1.75rem;font-weight:800}[data-theme=dark] .login-form h1{background:linear-gradient(135deg,#e2e8f0 0%,#60a5fa 100%);-webkit-background-clip:text;background-clip:text}.login-subtitle{text-align:center;color:var(--text-muted);margin-bottom:.5rem;font-size:.9rem}.login-form input{border:2px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition);background:var(--input-bg);color:var(--text);outline:none;padding:.85rem 1rem;font-family:inherit;font-size:.925rem}.login-form input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3b82f626}.login-form button[type=submit]{color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:linear-gradient(135deg,#3b82f6 0%,#6366f1 100%);border:none;padding:.85rem;font-family:inherit;font-size:1rem;font-weight:600}.login-form button[type=submit]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f659}.login-form button[type=submit]:active{transform:translateY(0)}.toggle-btn{color:var(--blue);cursor:pointer;transition:color var(--transition);background:0 0;border:none;font-family:inherit;font-size:.875rem;font-weight:500}.toggle-btn:hover{color:var(--purple)}.page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}h1{letter-spacing:-.03em;color:var(--text);margin-bottom:1.75rem;font-size:1.65rem;font-weight:800}.page-header h1{margin-bottom:0}h2{letter-spacing:-.02em;font-weight:700}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:.5rem;padding:.55rem 1.15rem;font-family:inherit;font-size:.875rem;font-weight:600;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#6366f1 100%);box-shadow:0 2px 8px #3b82f640}.btn-primary:hover{box-shadow:0 4px 12px #3b82f659}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:var(--card-bg);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--card-hover);box-shadow:var(--shadow-md)}.btn-danger{color:var(--red)}.btn-danger:hover{background:var(--red-soft)}.btn-ss{color:#fff;background:linear-gradient(135deg,#0ea5e9,#6366f1);border:none;font-weight:600}.btn-ss:hover{color:#fff;background:linear-gradient(135deg,#0284c7,#4f46e5)}.btn-ss:disabled{opacity:.5;cursor:not-allowed}.btn-icon{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);box-shadow:var(--shadow-sm);padding:.5rem}.btn-icon:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:all var(--transition);border:1px solid var(--border-subtle);align-items:center;gap:1rem;padding:1.5rem;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-red:before{background:linear-gradient(90deg, var(--red), #f87171)}.stat-yellow:before{background:linear-gradient(90deg, var(--yellow), #fbbf24)}.stat-green:before{background:linear-gradient(90deg, var(--green), #34d399)}.stat-blue:before{background:linear-gradient(90deg, var(--blue), #818cf8)}.stat-red{color:var(--red)}.stat-yellow{color:var(--yellow)}.stat-green{color:var(--green)}.stat-blue{color:var(--blue)}.stat-value{color:var(--text);letter-spacing:-.04em;font-size:2rem;font-weight:800;line-height:1.1;display:block}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:.8rem;font-weight:500}.total-pending{background:var(--card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-card);border:1px solid var(--border-subtle);border-left:4px solid var(--yellow);margin-bottom:2rem;padding:1rem 1.5rem;font-size:1.05rem}.dashboard-section{margin-bottom:2rem}.dashboard-section h2{color:var(--text);margin-bottom:1rem;font-size:1.1rem}.obligation-list{flex-direction:column;gap:.5rem;display:flex}.obligation-item{background:var(--card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition);border:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.obligation-item:hover{box-shadow:var(--shadow-md);transform:translate(2px)}.obligation-item.overdue{border-left:4px solid var(--red)}.obligation-item.pending{border-left:4px solid var(--yellow)}.obligation-client{color:var(--text-muted);margin-top:2px;font-size:.8rem;display:block}.obligation-meta{text-align:right}.obligation-date{color:var(--text-muted);font-size:.8rem;display:block}.obligation-amount{font-size:.95rem;font-weight:700}.client-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem;display:grid}.client-card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:all var(--transition);border:1px solid var(--border-subtle);padding:1.5rem;position:relative}.client-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.client-card.inactive{opacity:.55}.client-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.client-header h3{font-size:1rem;font-weight:700}.nif-badge{background:var(--bg-subtle);letter-spacing:.02em;color:var(--text-muted);border:1.5px solid #0000;border-radius:6px;padding:.3rem .65rem;font-family:SF Mono,Fira Code,monospace;font-size:.75rem;font-weight:600;transition:background .2s,color .2s,border-color .2s}.nif-badge-green{color:#16a34a;background:#22c55e1f;border-color:#22c55e4d}[data-theme=dark] .nif-badge-green{color:#4ade80;background:#22c55e26;border-color:#22c55e40}.client-details{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.85rem;font-size:.85rem;display:flex}.status-badge{letter-spacing:.02em;border-radius:20px;padding:.25rem .65rem;font-size:.75rem;font-weight:600}.status-badge.active{background:var(--green-soft);color:var(--green-text)}.status-badge.inactive{background:var(--red-soft);color:var(--red-text)}.last-sync{color:var(--text-muted);font-size:.8rem}.client-actions{border-top:1px solid var(--border-subtle);justify-content:flex-end;gap:.5rem;padding-top:.5rem;display:flex}.spinning{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.client-form{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--border-subtle);border-top:3px solid var(--blue);margin-bottom:1.5rem;padding:1.75rem}.form-row{gap:1rem;margin-bottom:1rem;display:flex}.form-row input{border:2px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition);background:var(--input-bg);color:var(--text);outline:none;flex:1;padding:.7rem .85rem;font-family:inherit;font-size:.875rem}.form-row input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61f}.form-row input::placeholder{color:var(--text-muted);opacity:.7}.form-actions{gap:.5rem;display:flex}.filters,.calendar-filters{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.75rem;display:flex}.filters select,.calendar-filters select{border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text);cursor:pointer;transition:all var(--transition);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right .7rem center;background-repeat:no-repeat;outline:none;padding:.55rem 2rem .55rem .85rem;font-family:inherit;font-size:.875rem}.filters select:focus,.calendar-filters select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61f}.checkbox-label{align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;display:flex}.year-groups{flex-direction:column;gap:1rem;display:flex}.year-group{border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--border-subtle);overflow:hidden}.year-header{color:#fff;cursor:pointer;width:100%;transition:all var(--transition);background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);border:none;justify-content:space-between;align-items:center;padding:1rem 1.5rem;font-family:inherit;font-size:.95rem;display:flex}.year-header:hover{background:linear-gradient(135deg,#1e293b 0%,#334155 100%)}.year-title{align-items:center;gap:.5rem;display:flex}.year-label{letter-spacing:-.02em;font-size:1.2rem;font-weight:800}.year-count{opacity:.6;margin-left:.25rem;font-size:.8rem;font-weight:400}.year-stats{align-items:center;gap:.5rem;display:flex}.year-stat{text-transform:uppercase;letter-spacing:.03em;border-radius:20px;padding:.25rem .7rem;font-size:.7rem;font-weight:700}.stat-red-badge{color:#fca5a5;background:#ef444433}.stat-yellow-badge{color:#fcd34d;background:#f59e0b33}.stat-green-badge{color:#6ee7b7;background:#10b98133}.year-stat-amount{color:#fbbf24;font-size:.9rem;font-weight:800}.year-group .data-table{box-shadow:none;border:none;border-radius:0}.data-table{border-collapse:collapse;background:var(--card-bg);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-card);border:1px solid var(--border-subtle);overflow:hidden}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border-subtle);padding:.85rem 1.15rem}.data-table th{background:var(--bg-subtle);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:700}.data-table td{font-size:.875rem}.data-table tbody tr{transition:background var(--transition)}.data-table tbody tr:hover{background:var(--card-hover)}.data-table tbody tr:last-child td{border-bottom:none}.type-badge{color:#fff;letter-spacing:.04em;background:linear-gradient(135deg,#1e293b 0%,#334155 100%);border-radius:6px;padding:.25rem .6rem;font-size:.7rem;font-weight:700;display:inline-block}[data-theme=dark] .type-badge{background:linear-gradient(135deg,#334155 0%,#475569 100%)}.status-pill{letter-spacing:.02em;border-radius:20px;padding:.3rem .85rem;font-size:.75rem;font-weight:700;display:inline-block}.status-green{background:var(--green-soft);color:var(--green-text)}.status-yellow{background:var(--yellow-soft);color:var(--yellow-text)}.status-red{background:var(--red-soft);color:var(--red-text)}.mono{letter-spacing:.02em;font-family:SF Mono,Fira Code,monospace;font-size:.85rem}.calendar-legend{background:var(--card-bg);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);gap:1.5rem;margin-bottom:1.25rem;padding:.75rem 1rem;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.825rem;font-weight:500;display:flex}.legend-dot{border-radius:50%;width:10px;height:10px;display:inline-block;box-shadow:0 0 6px #00000026}.fc{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--border-subtle);padding:1rem}.fc .fc-toolbar-title{color:var(--text);font-weight:700;font-size:1.15rem!important}.fc .fc-button{border-radius:var(--radius-sm)!important;font-size:.8rem!important;font-weight:600!important}.fc th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:700}.fc td,.fc th{border-color:var(--border-subtle)!important}.fc .fc-daygrid-day-number{color:var(--text);font-weight:500}[data-theme=dark] .fc .fc-button-primary{background:var(--card-bg);border-color:var(--border)}.event-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#00000080;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.event-modal{background:var(--card-bg);border-radius:var(--radius-xl);width:90%;max-width:450px;box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle);padding:2rem;animation:.25s ease-out slideUp}.event-modal h3{margin-bottom:1.25rem;font-size:1.15rem;font-weight:700}.event-details p{margin-bottom:.6rem;font-size:.9rem;line-height:1.5}.notification-list{flex-direction:column;gap:.5rem;display:flex}.notification-item{background:var(--card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition);border:1px solid var(--border-subtle);align-items:flex-start;gap:1rem;padding:1.15rem 1.25rem;display:flex}.notification-item:hover{box-shadow:var(--shadow-md);transform:translate(2px)}.notification-item.unread{border-left:4px solid var(--blue);background:var(--blue-soft)}.notification-icon{color:var(--text-muted);flex-shrink:0;padding-top:2px}.notification-item.unread .notification-icon{color:var(--blue)}.notification-content{flex:1;min-width:0}.notification-header{justify-content:space-between;gap:1rem;margin-bottom:.25rem;display:flex}.notification-header strong{font-size:.9rem;font-weight:600}.notification-date{color:var(--text-muted);white-space:nowrap;font-size:.75rem;font-weight:500}.notification-client{color:var(--text-muted);font-size:.8rem}.notification-body{color:var(--text-muted);margin-top:.5rem;font-size:.875rem;line-height:1.5}.error-msg{background:var(--red-soft);color:var(--red-text);border-radius:var(--radius-sm);border:1px solid #ef444426;padding:.85rem 1rem;font-size:.875rem;font-weight:500}.sync-result{border-radius:var(--radius-md);justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding:.85rem 1.15rem;font-size:.875rem;font-weight:500;animation:.3s ease-out slideUp;display:flex}.success-msg{background:var(--green-soft);color:var(--green-text);border:1px solid #10b98126}.unread-badge{background:linear-gradient(135deg, var(--red), #f87171);color:#fff;vertical-align:middle;border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;margin-left:.5rem;padding:0 6px;font-size:.7rem;font-weight:800;display:inline-flex;box-shadow:0 2px 4px #ef44444d}.empty-state{text-align:center;color:var(--text-muted);background:var(--card-bg);border-radius:var(--radius-lg);border:2px dashed var(--border);padding:4rem 2rem;font-size:.95rem}.loading{min-height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1.05rem;font-weight:500;display:flex}.search-input{border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);transition:all var(--transition);color:var(--text-muted);align-items:center;gap:.5rem;min-width:220px;padding:.55rem .85rem;display:flex}.search-input:focus-within{border-color:var(--blue);color:var(--text);box-shadow:0 0 0 3px #3b82f61f}.search-input input{color:var(--text);background:0 0;border:none;outline:none;flex:1;min-width:0;font-family:inherit;font-size:.875rem}.search-input input::placeholder{color:var(--text-muted);opacity:.7}.detail-tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:1.5rem;display:flex}.tab-btn{cursor:pointer;color:var(--text-muted);transition:all var(--transition);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.5rem;margin-bottom:-2px;padding:.75rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:600;display:flex}.tab-btn:hover{color:var(--text);background:var(--bg-subtle)}.tab-btn.active{color:var(--blue);border-bottom-color:var(--blue)}.clickable{cursor:pointer}.section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.section-header h2{margin-bottom:0}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.client-chips{flex-wrap:wrap;gap:.5rem;display:flex}.client-chip{background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;color:var(--text);transition:all var(--transition);box-shadow:var(--shadow-sm);align-items:center;gap:.5rem;padding:.5rem .85rem;font-family:inherit;font-size:.825rem;font-weight:500;display:inline-flex}.client-chip:hover{border-color:var(--blue);color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-1px)}.client-chip-selected{border-color:var(--blue);background:var(--blue);color:#fff;box-shadow:var(--shadow-md)}.client-chip-selected:hover{background:var(--blue);color:#fff;opacity:.9}.client-chip-selected .nif-badge{color:#fff;background:#fff3}.toast-container{z-index:200;flex-direction:column-reverse;gap:.5rem;max-width:400px;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{border-radius:var(--radius-md);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid #0000;align-items:center;gap:.65rem;padding:.85rem 1.15rem;font-size:.875rem;font-weight:500;animation:.3s ease-out toastIn;display:flex}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.toast-success{background:var(--green-soft);color:var(--green-text);border-color:#10b98133}.toast-error{background:var(--red-soft);color:var(--red-text);border-color:#ef444433}.toast-info{background:var(--blue-soft);color:var(--blue-text);border-color:#3b82f633}.toast-close{cursor:pointer;color:inherit;opacity:.6;transition:opacity var(--transition);background:0 0;border:none;flex-shrink:0;margin-left:auto;padding:2px}.toast-close:hover{opacity:1}.confirm-modal{background:var(--card-bg);border-radius:var(--radius-xl);width:90%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle);text-align:center;padding:2rem;animation:.25s ease-out slideUp}.confirm-icon{background:var(--yellow-soft);width:48px;height:48px;color:var(--yellow);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}.confirm-icon[data-danger=true]{background:var(--red-soft);color:var(--red)}.confirm-modal h3{margin-bottom:.5rem;font-size:1.1rem;font-weight:700}.confirm-modal p{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem;line-height:1.5}.confirm-actions{justify-content:center;gap:.75rem;display:flex}.btn-confirm-danger{background:linear-gradient(135deg, var(--red), #f87171);color:#fff;box-shadow:0 2px 8px #ef444440}.btn-confirm-danger:hover{box-shadow:0 4px 12px #ef444459}.page-skeleton{padding:0}.skeleton-header{background:linear-gradient(90deg, var(--border-subtle) 25%, var(--border) 50%, var(--border-subtle) 75%);border-radius:var(--radius-sm);background-size:200% 100%;width:200px;height:32px;margin-bottom:2rem;animation:1.5s ease-in-out infinite shimmer}.skeleton-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.skeleton-card{background:linear-gradient(90deg, var(--border-subtle) 25%, var(--border) 50%, var(--border-subtle) 75%);border-radius:var(--radius-lg);background-size:200% 100%;height:100px;animation:1.5s ease-in-out infinite shimmer}.skeleton-block{background:linear-gradient(90deg, var(--border-subtle) 25%, var(--border) 50%, var(--border-subtle) 75%);border-radius:var(--radius-lg);background-size:200% 100%;height:300px;animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.client-counter{border-radius:20px;align-items:center;gap:.3rem;padding:.2rem .55rem;font-size:.7rem;font-weight:700;display:inline-flex}.counter-red{background:var(--red-soft);color:var(--red-text)}.counter-yellow{background:var(--yellow-soft);color:var(--yellow-text)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.mobile-header,.sidebar-overlay{display:none}@media (width<=768px){.mobile-header{color:#fff;z-index:50;background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);border-bottom:1px solid #ffffff0f;align-items:center;gap:.75rem;padding:.65rem 1rem;display:flex;position:sticky;top:0}.mobile-hamburger{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#ffffff14;border:none;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:background .15s;display:flex}.mobile-hamburger:hover,.mobile-hamburger:active{background:#ffffff26}.mobile-title{letter-spacing:-.01em;font-size:.95rem;font-weight:700}.app-layout{flex-direction:column}.sidebar{z-index:200;width:280px;height:100vh;transition:transform .25s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{z-index:199;background:#00000080;animation:.2s ease-out fadeIn;display:block;position:fixed;inset:0}.main-content{max-width:100%;min-height:calc(100vh - 54px);padding:1.25rem 1rem}h1{margin-bottom:1.25rem;font-size:1.3rem}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem}.page-header>div:last-child{width:100%}.page-header .btn{flex:1;justify-content:center;min-height:42px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.65rem;margin-bottom:1.25rem}.stat-card{gap:.65rem;padding:.85rem}.stat-card svg{width:20px;height:20px}.stat-value{font-size:1.5rem}.stat-label{font-size:.7rem}.total-pending{margin-bottom:1.25rem;padding:.75rem 1rem;font-size:.9rem}.dashboard-grid{grid-template-columns:1fr;gap:1rem}.section-header{flex-wrap:wrap;gap:.5rem}.section-header h2{font-size:1rem}.obligation-item{flex-direction:column;align-items:flex-start;gap:.35rem;padding:.85rem 1rem}.obligation-meta{text-align:left;align-items:center;gap:.75rem;display:flex}.client-chips{gap:.35rem}.client-chip{padding:.45rem .7rem;font-size:.78rem}.filters,.calendar-filters{flex-direction:column;gap:.5rem}.filters select,.calendar-filters select{width:100%;min-height:42px}.search-input{width:100%;min-width:0;min-height:42px}.data-table{-webkit-overflow-scrolling:touch;font-size:.8rem;display:block;overflow-x:auto}.data-table thead,.data-table tbody,.data-table tr{table-layout:auto;width:100%;display:table}.data-table thead{display:table-header-group}.data-table tbody{display:table-row-group}.data-table th,.data-table td{white-space:nowrap;padding:.55rem .7rem}.data-table thead tr,.data-table tbody tr{min-width:600px}.year-header{flex-direction:column;align-items:flex-start;gap:.4rem;padding:.85rem 1rem}.year-stats{flex-wrap:wrap;gap:.35rem}.year-label{font-size:1.05rem}.year-stat-amount{font-size:.8rem}.client-grid{grid-template-columns:1fr}.client-card{padding:1.15rem}.client-actions{flex-wrap:wrap}.form-row{flex-direction:column}.client-form{padding:1.25rem}.detail-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.tab-btn{min-height:42px;padding:.6rem .85rem;font-size:.8rem}.calendar-legend{flex-wrap:wrap;gap:.5rem;padding:.5rem .75rem}.legend-item{font-size:.75rem}.notification-header{flex-direction:column;gap:.25rem}.sync-modal{border-radius:var(--radius-md);width:96%;max-width:none;max-height:90vh}.sync-modal-header{padding:1rem}.sync-steps{gap:.3rem;padding:.75rem}.sync-log-container{min-height:150px;max-height:200px;font-size:.7rem}.sync-result-summary{padding:.75rem 1rem}.sync-result-grid{gap:.65rem}.sync-result-value{font-size:1.2rem}.sync-modal-footer{padding:.75rem 1rem}.sync-mini-bar{min-width:0;max-width:none;font-size:.8rem;bottom:1rem;left:.75rem;right:.75rem}.sync-mini-ss{bottom:4.5rem}.toast-container{max-width:none;bottom:.75rem;left:.75rem;right:.75rem}.login-form{width:auto;margin:1rem;padding:2rem 1.5rem}.btn{min-height:40px;padding:.55rem 1rem;font-size:.84rem}.nif-badge{padding:.2rem .5rem;font-size:.7rem}.status-pill{padding:.25rem .65rem;font-size:.7rem}.empty-state{padding:2.5rem 1.5rem;font-size:.9rem}}@media (width<=480px){.main-content{padding:1rem .75rem}.stats-grid{grid-template-columns:1fr;gap:.5rem}.stat-card{flex-direction:row;padding:.75rem}.stat-value{font-size:1.35rem}h1{font-size:1.15rem}.page-header .btn{padding:.45rem .75rem;font-size:.78rem}.sidebar{width:260px}.obligation-item{padding:.75rem}.client-chip{padding:.4rem .6rem;font-size:.72rem}.sync-modal{border-radius:0;width:100%;max-height:100vh}}.sync-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.sync-modal{background:var(--card-bg);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);flex-direction:column;width:90%;max-width:700px;max-height:85vh;animation:.25s ease-out slideUp;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #0006}.sync-modal-header{border-bottom:1px solid var(--border-subtle);color:#fff;background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex;position:relative}.sync-modal-header h3{margin:0;font-size:1rem;font-weight:700}.sync-steps{border-bottom:1px solid var(--border-subtle);background:var(--bg-subtle);flex-wrap:wrap;gap:.4rem;padding:1rem 1.5rem;display:flex}.sync-step{background:var(--card-bg);border:1px solid var(--border);color:var(--text-muted);border-radius:20px;align-items:center;gap:.35rem;padding:.3rem .65rem;font-size:.72rem;font-weight:600;transition:all .2s;display:inline-flex}.sync-step-active{background:var(--blue-soft);border-color:var(--blue);color:var(--blue-text)}.sync-step-done{background:var(--green-soft);color:var(--green-text);border-color:#10b9814d}.sync-step-error{background:var(--red-soft);color:var(--red-text);border-color:#ef44444d}.sync-step-label{white-space:nowrap}.sync-step-msg{opacity:.8;text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-weight:400;overflow:hidden}.sync-log-container{color:#8b949e;background:#0d1117;flex:1;min-height:200px;max-height:300px;padding:.75rem 1rem;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.75rem;line-height:1.6;overflow-y:auto}.sync-log-line{word-break:break-all;padding:1px 0}.sync-log-line.log-error{color:#f85149}.sync-log-line.log-success{color:#3fb950}.sync-log-line.log-info{color:#58a6ff}.sync-result-summary{border-top:1px solid var(--border-subtle);background:var(--bg-subtle);padding:1rem 1.5rem}.sync-result-summary h4{color:var(--text);margin-bottom:.75rem;font-size:.85rem;font-weight:700}.sync-result-grid{flex-wrap:wrap;gap:1rem;display:flex}.sync-result-item{flex-direction:column;align-items:center;min-width:70px;display:flex}.sync-result-value{color:var(--text);font-size:1.5rem;font-weight:800;line-height:1.1}.sync-result-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem;font-weight:500}.sync-errors-list{background:var(--red-soft);border-radius:var(--radius-sm);color:var(--red-text);border:1px solid #ef444426;margin-top:.75rem;padding:.65rem .85rem;font-size:.8rem}.sync-errors-list strong{margin-bottom:.35rem;display:block}.sync-error-item{padding:.15rem 0;font-size:.75rem}.sync-error-banner{background:var(--red-soft);color:var(--red-text);border-top:1px solid #ef444426;align-items:center;gap:.5rem;padding:.85rem 1.5rem;font-size:.875rem;font-weight:500;display:flex}.sync-modal-footer{border-top:1px solid var(--border-subtle);justify-content:flex-end;align-items:center;padding:1rem 1.5rem;display:flex}.sync-status-text{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;display:flex}.sync-header-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;transition:all .15s;display:flex}.sync-header-btn:hover{background:#fff3;border-color:#ffffff59}.sync-mini-bar{color:#fff;border-radius:var(--radius-md);cursor:pointer;z-index:150;background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);border:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:.75rem;min-width:280px;max-width:420px;padding:.65rem 1rem;transition:box-shadow .2s;animation:.25s ease-out toastIn;display:flex;position:fixed;bottom:1.5rem;right:1.5rem;overflow:hidden;box-shadow:0 8px 24px #00000059}.sync-mini-ss{bottom:5.5rem}.sync-mini-bar:hover{box-shadow:0 10px 30px #00000073}.sync-mini-left{align-items:center;gap:.5rem;min-width:0;display:flex}.sync-mini-text{white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.sync-mini-progress{opacity:.6;white-space:nowrap;font-size:.7rem;font-weight:500}.sync-mini-actions{flex-shrink:0;gap:.25rem;display:flex}.sync-mini-btn{color:#fff;cursor:pointer;background:#ffffff14;border:1px solid #ffffff26;border-radius:5px;justify-content:center;align-items:center;width:26px;height:26px;transition:all .15s;display:flex}.sync-mini-btn:hover{background:#fff3}.sync-mini-progress-bar{border-radius:0 0 var(--radius-md) var(--radius-md);background:#ffffff1a;height:3px;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.sync-mini-progress-fill{border-radius:0 0 var(--radius-md) var(--radius-md);background:linear-gradient(90deg,#3b82f6,#6366f1);height:100%;transition:width .5s}.sync-header-progress-bar{background:#ffffff1a;height:3px;position:absolute;bottom:0;left:0;right:0}.sync-header-progress-fill{background:linear-gradient(90deg,#3b82f6,#6366f1,#8b5cf6);height:100%;transition:width .5s}
