html,body,#root{min-height:100%;margin:0}body{min-height:100vh}button{cursor:pointer}.sidebar .nav-link{border:0;background:transparent;width:100%;text-align:left}.sidebar .nav-link.active{background:#ffffff26}.sidebar-footer .nav-link{margin-right:0;border-radius:999px}.mobile-profile-avatar img{width:100%;height:100%;object-fit:cover;border-radius:999px}.user-avatar,.mobile-profile-avatar{display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;text-transform:uppercase}.banner{padding:.95rem 1rem;border-radius:18px;background:#ffffffb8}.banner-error{color:#8d2c27}.welcome-banner{background:#fff;border-radius:24px;padding:1.5rem;box-shadow:0 12px 30px #0f172a0f}.banner-content{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.banner-text h1{margin:.35rem 0 0;font-size:2rem;line-height:1.1;color:#1f2937}.banner-text p{margin:.65rem 0 0;max-width:42rem;color:#6b7280}.banner-meta{display:flex;flex-wrap:wrap;gap:.65rem;justify-content:flex-end}@media(max-width:768px){.banner-content{flex-direction:column}.banner-meta{justify-content:flex-start}}.chat-message-self{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.chat-message-other{background:#f8fafc;color:#0f172a;border:1px solid #e2e8f0}.agenda-item+.agenda-item{border-top:1px solid #e2e8f0}.calendar-shell{display:grid;grid-template-columns:minmax(0,1.85fr) minmax(280px,.95fr);gap:1.5rem}.calendar-panel{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 16px 40px #0f172a0f}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.view-toggle{display:inline-flex;padding:.25rem;border-radius:999px;background:#ffffff1f;border:1px solid rgba(255,255,255,.16)}.view-toggle button{padding:.6rem 1rem;border-radius:999px;font-size:.875rem;font-weight:600;color:#ffffffd1;background:transparent;border:0}.view-toggle button.active{background:#fff;color:#0f172a}.calendar-weekday{padding:.85rem .75rem;border-bottom:1px solid #e2e8f0;font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#64748b}.calendar-day{min-height:138px;padding:.75rem;border-right:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;background:#fff;cursor:pointer;transition:background-color .2s,box-shadow .2s,transform .2s}.calendar-day:nth-child(7n){border-right:0}.calendar-day:hover{background:#f8fbff;box-shadow:inset 0 0 0 1px #bfdbfe}.calendar-day-muted{background:#f8fafc;color:#94a3b8}.calendar-day-today{background:linear-gradient(180deg,#eff6ff,#fff)}.calendar-day-selected{background:linear-gradient(180deg,#dbeafe,#fff);box-shadow:inset 0 0 0 2px #3b82f6}.calendar-day-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.calendar-day-add{width:1.75rem;height:1.75rem;border:1px solid #cbd5e1;border-radius:999px;background:#ffffffeb;color:#475569;display:inline-flex;align-items:center;justify-content:center;opacity:0;transform:translateY(-2px);transition:opacity .2s,transform .2s,background-color .2s,color .2s}.calendar-day:hover .calendar-day-add,.calendar-day-selected .calendar-day-add,.calendar-day-today .calendar-day-add{opacity:1;transform:translateY(0)}.calendar-day-add:hover{background:#2563eb;color:#fff;border-color:#2563eb}.calendar-dot{display:block;width:100%;text-align:left;border-radius:.85rem;padding:.5rem .6rem;font-size:.75rem;line-height:1.2;margin-top:.45rem;border:1px solid #dbeafe;background:#eff6ff;color:#1d4ed8}.calendar-dot.is-completed{border-color:#bbf7d0;background:#f0fdf4;color:#15803d}.calendar-dot.is-cancelled{border-color:#fecaca;background:#fef2f2;color:#b91c1c}.calendar-empty{border:1px dashed #cbd5e1;background:#f8fafc;color:#64748b}.selected-day-item+.selected-day-item{border-top:1px solid #e2e8f0}@media(max-width:1080px){.calendar-shell{grid-template-columns:1fr}}@media(max-width:768px){.calendar-grid{min-width:720px}.calendar-scroll{overflow-x:auto}}.status-filter-btn{padding:.55rem .9rem;border-radius:999px;border:1px solid #d1d5db;background:#fff;color:#475569;font-size:.875rem;font-weight:600;transition:all .2s ease}.status-filter-btn:hover{background:#f8fafc}.status-filter-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}:root{--primary-color: #3b82f6;--primary-dark: #1d4ed8;--secondary-color: #64748b;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #ef4444;--info-color: #06b6d4;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--text-light: #94a3b8;--border-color: #e2e8f0;--border-light: #f1f5f9;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1)}*{box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:var(--text-primary);background-color:var(--bg-secondary)}.app-layout{display:flex;min-height:100vh;background-color:var(--bg-secondary)}.sidebar{width:256px;background:linear-gradient(180deg,#7a114f,#b91c79 52%,#db2777);color:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 24px #8813372e;position:relative;z-index:40;display:flex;flex-direction:column}.sidebar.collapsed{width:88px}.sidebar-header{padding:1rem 1rem .9rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between}.sidebar-logo{display:flex;align-items:center;font-size:1.25rem;font-weight:700;transition:opacity .3s ease}.sidebar.collapsed .sidebar-logo span{opacity:0;width:0;overflow:hidden}.sidebar-toggle{background:#ffffff24;border:none;color:#fff;padding:.5rem;border-radius:.8rem;cursor:pointer;transition:all .3s ease}.sidebar-toggle:hover{background:#fff3;transform:scale(1.05)}.sidebar-nav{padding:.85rem 0;flex:1}.sidebar-section-label{padding:.75rem 1.15rem .35rem;font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#ffffff94}.sidebar.collapsed .sidebar-section-label{opacity:0;height:0;overflow:hidden;padding:0}.nav-item{margin:.25rem 0}.nav-link{display:flex;align-items:center;padding:.78rem 1.15rem;color:#fffc;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;border-radius:0 25px 25px 0;margin-right:.75rem}.nav-link:hover{color:#fff;background:#ffffff1a;transform:translate(5px)}.nav-link.active{color:#fff;background:#ffffff26;box-shadow:0 4px 12px #00000026}.nav-link.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#ffd3f0;border-radius:0 4px 4px 0}.nav-icon{width:1.25rem;height:1.25rem;margin-right:.75rem;transition:all .3s ease}.sidebar.collapsed .nav-icon{margin-right:0}.sidebar.collapsed .nav-link{justify-content:center;padding:.75rem;margin-right:.5rem}.nav-text{transition:all .3s ease;white-space:nowrap}.sidebar.collapsed .nav-text{opacity:0;width:0;overflow:hidden}.sidebar-footer{padding:.9rem 1rem;border-top:1px solid rgba(255,255,255,.1)}.user-profile{display:flex;align-items:center;color:#ffffffe6;transition:all .3s ease;cursor:pointer;padding:.5rem;border-radius:.5rem}.user-profile:hover{background:#ffffff1a}.user-avatar{width:2.5rem;height:2.5rem;border-radius:50%;background:linear-gradient(135deg,#f472b6,#db2777);display:flex;align-items:center;justify-content:center;margin-right:.75rem;font-weight:600;font-size:1.1rem;box-shadow:0 2px 8px #0003;overflow:hidden;position:relative}.user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.user-avatar.small{width:1.5rem;height:1.5rem;font-size:.7rem}.user-avatar.large{width:4rem;height:4rem;font-size:1.6rem}.user-avatar.xl{width:6rem;height:6rem;font-size:2.4rem}.sidebar.collapsed .user-avatar{margin-right:0}.user-info{flex:1;transition:all .3s ease}.sidebar.collapsed .user-info{opacity:0;width:0;overflow:hidden}.user-name{font-weight:600;font-size:.875rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{font-size:.75rem;color:#ffffffb3}.nav-dropdown{position:relative}.dropdown-toggle{justify-content:space-between;cursor:pointer}.dropdown-arrow{width:1rem;height:1rem;transition:transform .2s ease;margin-left:auto}.nav-dropdown.open .dropdown-arrow{transform:rotate(180deg)}.dropdown-menu{max-height:0;overflow:hidden;transition:max-height .3s ease;background:#0000001a;margin:.25rem 0 .25rem 1.5rem;border-radius:.5rem}.nav-dropdown.open .dropdown-menu{max-height:300px}.dropdown-item{display:flex;align-items:center;padding:.5rem 1rem;color:#ffffffb3;text-decoration:none;transition:all .2s ease;border-radius:.375rem;margin:.125rem;font-size:.875rem}.dropdown-item:hover{color:#fff;background:#ffffff1a;transform:translate(3px)}.dropdown-item.active{color:#fff;background:#ffffff26;font-weight:500}.dropdown-icon{width:1rem;height:1rem;margin-right:.5rem}.sidebar.collapsed .dropdown-menu{display:none}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.content-wrapper{flex:1;padding:2rem;overflow-y:auto;background:#f8fafc;max-width:1400px;margin:0 auto;width:100%}@media(max-width:768px){.content-wrapper{padding:1rem}}.app-header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.header-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem}.logo{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.user-menu{display:flex;align-items:center;gap:1rem}.nav-tabs{display:flex;border-bottom:1px solid var(--border-color);background:var(--bg-primary);margin-bottom:1.5rem;border-radius:.5rem .5rem 0 0;overflow-x:auto}.nav-tab{padding:.75rem 1.5rem;text-decoration:none;color:var(--text-secondary);border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;display:flex;align-items:center;gap:.5rem}.nav-tab:hover{color:var(--primary-color);background-color:var(--bg-tertiary)}.nav-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background-color:var(--bg-secondary)}.card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.75rem;box-shadow:var(--shadow-sm);overflow:hidden}.card-header{padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.card-title{font-size:1.25rem;font-weight:600;margin:0;color:var(--text-primary)}.card-body{padding:1.5rem}.card-footer{padding:1rem 1.5rem;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--bg-primary);padding:1.5rem;border-radius:.75rem;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.stat-card-title{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.stat-card-icon{width:2.5rem;height:2.5rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.stat-card-value{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.stat-card-change{font-size:.875rem;display:flex;align-items:center;gap:.25rem}.stat-card.primary .stat-card-icon{background-color:#3b82f61a;color:var(--primary-color)}.stat-card.success .stat-card-icon{background-color:#10b9811a;color:var(--success-color)}.stat-card.warning .stat-card-icon{background-color:#f59e0b1a;color:var(--warning-color)}.stat-card.error .stat-card-icon{background-color:#ef44441a;color:var(--error-color)}.table-container{overflow-x:auto;border-radius:.75rem;border:1px solid var(--border-color)}.data-table{width:100%;border-collapse:collapse;background:var(--bg-primary)}.data-table th{background:var(--bg-secondary);padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color);white-space:nowrap}.data-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-light);font-size:.875rem}.data-table tbody tr:hover{background-color:var(--bg-tertiary)}.data-table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.badge.success{background-color:#10b9811a;color:var(--success-color)}.badge.warning{background-color:#f59e0b1a;color:var(--warning-color)}.badge.error{background-color:#ef44441a;color:var(--error-color)}.badge.info{background-color:#06b6d41a;color:var(--info-color)}.badge.secondary{background-color:#64748b1a;color:var(--secondary-color)}.status-attivo{background-color:#10b9811a;color:var(--success-color)}.status-in_scadenza{background-color:#f59e0b1a;color:var(--warning-color)}.status-scaduto{background-color:#ef44441a;color:var(--error-color)}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.form-label.required:after{content:" *";color:var(--error-color)}.form-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s;background-color:var(--bg-primary)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.form-input:disabled{background-color:var(--bg-tertiary);color:var(--text-light);cursor:not-allowed}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}.form-textarea{resize:vertical;min-height:100px}.form-error{color:var(--error-color);font-size:.75rem;margin-top:.25rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s;text-align:center;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark)}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-secondary:hover:not(:disabled){background-color:#475569}.btn-success{background-color:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){background-color:#059669}.btn-warning{background-color:var(--warning-color);color:#fff}.btn-warning:hover:not(:disabled){background-color:#d97706}.btn-error{background-color:var(--error-color);color:#fff}.btn-error:hover:not(:disabled){background-color:#dc2626}.btn-outline{background-color:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.btn-outline:hover:not(:disabled){background-color:var(--bg-tertiary)}.btn-sm{padding:.5rem 1rem;font-size:.75rem}.btn-lg{padding:1rem 2rem;font-size:1rem}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.modal-overlay.active{opacity:1;visibility:visible}.modal{background:var(--bg-primary);border-radius:.75rem;box-shadow:var(--shadow-lg);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;transform:scale(.9);transition:transform .3s}.modal-overlay.active .modal{transform:scale(1)}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.25rem;font-weight:600;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background-color .2s}.modal-close:hover{background-color:var(--bg-tertiary)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);display:flex;gap:1rem;justify-content:flex-end}.notification-container{position:fixed;top:1rem;right:1rem;z-index:1100;max-width:400px}.notification{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.5rem;box-shadow:var(--shadow-lg);padding:1rem;margin-bottom:.5rem;display:flex;align-items:flex-start;gap:.75rem;transform:translate(100%);transition:transform .3s}.notification.show{transform:translate(0)}.notification-icon{width:1.25rem;height:1.25rem;flex-shrink:0;margin-top:.125rem}.notification-content{flex:1}.notification-title{font-weight:500;margin-bottom:.25rem;font-size:.875rem}.notification-message{color:var(--text-secondary);font-size:.75rem}.notification-close{background:none;border:none;cursor:pointer;color:var(--text-light);padding:0;margin-left:.5rem}.notification.success{border-left:4px solid var(--success-color)}.notification.error{border-left:4px solid var(--error-color)}.notification.warning{border-left:4px solid var(--warning-color)}.notification.info{border-left:4px solid var(--info-color)}.spinner{width:1.5rem;height:1.5rem;border:2px solid var(--border-color);border-top:2px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,20%,53%,80%,to{transform:translateZ(0)}40%,43%{transform:translate3d(0,-8px,0)}70%{transform:translate3d(0,-4px,0)}90%{transform:translate3d(0,-2px,0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.animate-pulse{animation:pulse 2s infinite}.animate-bounce{animation:bounce 1s infinite}.animate-slideInLeft{animation:slideInLeft .6s ease-out}.animate-slideInRight{animation:slideInRight .6s ease-out}.animate-scaleIn{animation:scaleIn .4s ease-out}.animate-fadeInUp{animation:fadeInUp .6s ease-out}.animate-shake{animation:shake .5s ease-in-out}.card-enhanced{background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(0,0,0,.05);overflow:hidden;position:relative}.card-enhanced:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#1d4ed8);transform:scaleX(0);transition:transform .3s ease}.card-enhanced:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.card-enhanced:hover:before{transform:scaleX(1)}.btn-hover-float:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.btn-hover-grow:hover{transform:scale(1.05)}.btn-hover-glow{position:relative;overflow:hidden}.btn-hover-glow:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.btn-hover-glow:hover:before{left:100%}.loading-skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.progress-bar{background:#e2e8f0;border-radius:9999px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#1d4ed8);border-radius:inherit;transition:width .5s ease;position:relative}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.notification-enter{animation:slideInRight .4s cubic-bezier(.4,0,.2,1)}.notification-exit{animation:slideInRight .3s cubic-bezier(.4,0,.2,1) reverse}.contracts-dropdown{position:absolute;z-index:50;margin-top:.5rem;width:20rem;background-color:#fff;border-radius:.375rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border:1px solid #e5e7eb;right:0}.contracts-dropdown.hidden{display:none}.contracts-dropdown .contracts-list{padding:.75rem;max-height:12rem;overflow-y:auto}.contracts-dropdown .contract-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem;background-color:#f9fafb;border-radius:.25rem;font-size:.75rem;margin-bottom:.5rem}.contracts-dropdown .contract-item:last-child{margin-bottom:0}.dropdown-arrow{transition:transform .2s ease}.dropdown-arrow.rotate-180{transform:rotate(180deg)}.wizard-steps{display:flex;align-items:center;gap:1rem;margin-left:auto}.wizard-step{font-size:.875rem;transition:all .2s ease}.wizard-step.active{color:#3b82f6;font-weight:600}.wizard-step.inactive{color:#9ca3af}.wizard-separator{color:#9ca3af;font-size:.875rem}.business-fields{transition:all .3s ease}.business-fields.hidden{display:none}.table-enhanced tr:hover .contracts-button{background-color:#eff6ff}.contracts-button{transition:all .2s ease;border-radius:.25rem;padding:.25rem .5rem}.contracts-button:hover{background-color:#dbeafe}.contracts-expanded-row{transition:all .3s ease}.contracts-expanded-row.hidden{display:none}.contracts-expanded-row td{border-top:none!important}.contracts-expanded-row .bg-gray-50{background-color:#f9fafb;border-left:4px solid #3b82f6}.row-arrow{transition:transform .2s ease}.row-arrow.rotate-180{transform:rotate(180deg)}.contracts-expanded-row .table-enhanced{margin:0;box-shadow:none}.contracts-expanded-row .table-enhanced th{background-color:#f3f4f6;border-bottom:1px solid #d1d5db}.contract-form{background-color:#fafafa;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;margin-bottom:1rem}input[type=file]{padding:.5rem;border:2px dashed #d1d5db;border-radius:.375rem;background-color:#f9fafb;transition:all .2s ease}input[type=file]:hover{border-color:#3b82f6;background-color:#eff6ff}input[type=file]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.profile-image-selector{display:flex;flex-direction:column;gap:1rem}.image-type-tabs{display:flex;border-bottom:1px solid #e5e7eb}.image-type-tab{padding:.75rem 1rem;background:none;border:none;color:#6b7280;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.image-type-tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.image-type-tab:hover{color:#3b82f6;background-color:#f9fafb}.image-content{padding:1rem 0}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:1rem;max-width:400px}.avatar-option{display:flex;flex-direction:column;align-items:center;padding:1rem;border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;transition:all .3s ease;background:#fff}.avatar-option:hover{border-color:#3b82f6;background-color:#f8fafc}.avatar-option.selected{border-color:#3b82f6;background-color:#eff6ff;box-shadow:0 0 0 1px #3b82f6}.avatar-option img,.avatar-option .avatar-preview{width:48px;height:48px;border-radius:50%;margin-bottom:.5rem}.avatar-option .avatar-name{font-size:.75rem;color:#6b7280;text-align:center}.photo-upload-area{border:2px dashed #d1d5db;border-radius:.5rem;padding:2rem;text-align:center;transition:all .3s ease;background-color:#f9fafb}.photo-upload-area:hover{border-color:#3b82f6;background-color:#eff6ff}.photo-upload-area.dragover{border-color:#3b82f6;background-color:#eff6ff;transform:scale(1.02)}.upload-icon{width:3rem;height:3rem;margin:0 auto 1rem;color:#9ca3af}.current-photo-preview{max-width:150px;max-height:150px;border-radius:.5rem;margin:1rem auto;display:block;box-shadow:0 4px 6px -1px #0000001a}.status-filter-btn{padding:.5rem 1rem;border:1px solid #d1d5db;background-color:#fff;color:#6b7280;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.status-filter-btn:hover{background-color:#f9fafb;border-color:#9ca3af}.status-filter-btn.active{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.status-filter-btn.active:hover{background-color:#2563eb;border-color:#2563eb}.form-select-sm{padding:.25rem .5rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:.375rem;background-color:#fff;color:#374151;min-width:60px}.form-select-sm:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6}#pagination-controls{border-top:1px solid #e5e7eb;background-color:#f9fafb}#page-numbers button{min-width:36px;text-align:center;transition:all .2s ease}#page-numbers button:hover{background-color:#f3f4f6}#page-numbers button.bg-blue-600{background-color:#3b82f6!important;border-color:#3b82f6!important}#page-numbers button.bg-blue-600:hover{background-color:#2563eb!important;border-color:#2563eb!important}#prev-page-btn:disabled,#next-page-btn:disabled{opacity:.5;cursor:not-allowed}#prev-page-btn:disabled:hover,#next-page-btn:disabled:hover{background-color:#fff}.nav-badge,.app-bottom-badge{min-width:1.1rem;height:1.1rem;padding:0 .28rem;border-radius:999px;background:#f87171;color:#fff;font-size:.65rem;font-weight:700;line-height:1.1rem;text-align:center;display:none}.nav-badge.has-items,.app-bottom-badge.has-items{display:inline-block}.nav-badge{margin-left:auto;background:#f87171f2}.mobile-header,.mobile-overlay,.app-bottom-nav{display:none}.mobile-profile-shortcut{width:2.8rem;height:2.8rem;border-radius:999px;border:1px solid rgba(203,213,225,.95);background:#ffffffeb;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 10px 26px #0f172a14;overflow:hidden;color:#0f172a;flex-shrink:0}.mobile-profile-avatar{width:100%;height:100%;display:inline-flex;align-items:center;justify-content:center;overflow:hidden}.mobile-profile-avatar img,.mobile-profile-avatar>div{width:100%;height:100%}@media(max-width:768px){body{background:radial-gradient(circle at top,rgba(59,130,246,.08),transparent 34%),linear-gradient(180deg,#f8fbff,#f8fafc 38%,#eef2ff)}.app-layout{min-height:100dvh;display:block}.sidebar{position:fixed;inset:0 auto 0 0;width:min(86vw,320px);transform:translate(-108%);box-shadow:18px 0 44px #0f172a42;border-radius:0 1.5rem 1.5rem 0;z-index:80}.sidebar.mobile-open{transform:translate(0)}.sidebar.collapsed{width:min(86vw,320px)}.sidebar.collapsed .sidebar-logo span,.sidebar.collapsed .nav-text,.sidebar.collapsed .user-info{opacity:1;width:auto;overflow:visible}.sidebar.collapsed .nav-link{justify-content:flex-start;padding:.9rem 1.1rem;margin-right:1rem}.sidebar.collapsed .nav-icon{margin-right:.75rem}.mobile-overlay{display:block;position:fixed;inset:0;background:#0f172a61;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;z-index:70}.mobile-overlay.active{opacity:1;visibility:visible}.main-content{min-height:100dvh}.mobile-header{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:calc(env(safe-area-inset-top,0px) + .85rem) 1rem .9rem;background:#f8fafcdb;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid rgba(226,232,240,.9)}.mobile-menu-btn{width:2.8rem;height:2.8rem;border-radius:999px;border:1px solid rgba(203,213,225,.9);background:#ffffffeb;color:#0f172a;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 10px 26px #0f172a14}.mobile-header button[data-action=logout],.mobile-header a[data-action=logout],.mobile-header [data-action=logout]{display:none!important}.content-wrapper{padding:1rem 1rem calc(6.5rem + env(safe-area-inset-bottom,0px));max-width:100%;overflow-y:visible}.content-wrapper>*:first-child{margin-top:0}.card-enhanced,.card,.calendar-panel{border-radius:1.25rem!important;box-shadow:0 18px 40px #0f172a14}.app-bottom-nav{position:fixed;left:.75rem;right:.75rem;bottom:calc(.75rem + env(safe-area-inset-bottom,0px));z-index:65;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.35rem;padding:.55rem;border:1px solid rgba(226,232,240,.88);border-radius:1.5rem;background:#ffffffeb;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 20px 44px #0f172a2e}.app-bottom-link{position:relative;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.55rem .35rem;border-radius:1rem;color:#64748b;text-decoration:none;font-size:.66rem;font-weight:700;letter-spacing:.02em}.app-bottom-link.active{color:#0f172a;background:linear-gradient(180deg,#eff6ff,#dbeafe)}.app-bottom-icon{position:relative;display:inline-flex;align-items:center;justify-content:center}.app-bottom-icon svg{width:1.35rem;height:1.35rem}.app-bottom-badge{position:absolute;top:-.35rem;right:-.55rem}.table-enhanced,.data-table{min-width:720px}.modal{width:calc(100% - 1.25rem);max-height:calc(100dvh - 1.5rem);border-radius:1.25rem}}
